[REV] Revert lazy sitemap

This commit is contained in:
Fabien Meghazi 2014-05-14 17:11:16 +02:00
parent 230a9c34b1
commit 2e0e242c82
2 changed files with 9 additions and 17 deletions

View File

@ -2,7 +2,6 @@
import cStringIO
import json
import logging
import math
import re
from sys import maxint
@ -70,14 +69,12 @@ class Website(openerp.addons.web.controllers.main.Home):
@http.route('/sitemap.xml', type='http', auth="public", website=True)
def sitemap_xml_index(self):
count = 0
for loc in request.website.enumerate_pages():
count += 1
if count <= LOC_PER_SITEMAP:
return self.__sitemap_xml(0)
pages = list(request.website.enumerate_pages())
if len(pages)<=LOC_PER_SITEMAP:
return self.__sitemap_xml(pages, 0)
# Sitemaps must be split in several smaller files with a sitemap index
values = {
'pages': range(int(math.ceil(float(count) / LOC_PER_SITEMAP))),
'pages': range(len(pages)/LOC_PER_SITEMAP+1),
'url_root': request.httprequest.url_root
}
headers = {
@ -87,16 +84,12 @@ class Website(openerp.addons.web.controllers.main.Home):
@http.route('/sitemap-<int:page>.xml', type='http', auth="public", website=True)
def sitemap_xml(self, page):
return self.__sitemap_xml(page)
pages = list(request.website.enumerate_pages())
return self.__sitemap_xml(pages, page)
def __sitemap_xml(self, index=0):
locs = request.website.enumerate_pages()
feed = index * LOC_PER_SITEMAP
for i in xrange(feed):
locs.next()
def __sitemap_xml(self, pages, index=0):
values = {
'locs': locs,
'iter': xrange(LOC_PER_SITEMAP),
'pages': pages[index*LOC_PER_SITEMAP:(index+1)*LOC_PER_SITEMAP],
'url_root': request.httprequest.url_root.rstrip('/')
}
headers = {

View File

@ -699,8 +699,7 @@ Sitemap: <t t-esc="url_root"/>sitemap.xml
<template id="sitemap_xml">&lt;?xml version="1.0" encoding="UTF-8"?&gt;
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
<url t-foreach="iter" t-as="i">
<t t-set="page" t-value="locs.next()"/>
<url t-foreach="pages" t-as="page">
<loc><t t-esc="url_root"/><t t-esc="page['loc']"/></loc><t t-if="page.get('lastmod', False)">
<lastmod t-esc="page['lastmod']"/></t><t t-if="page.get('priority', False)">
<priority t-esc="page['priority']"/></t><t t-if="page.get('changefreq', False)">