diff options
Diffstat (limited to 'app/build')
-rw-r--r-- | app/build/base.py | 281 |
1 files changed, 150 insertions, 131 deletions
diff --git a/app/build/base.py b/app/build/base.py index f6df69d..49f1989 100644 --- a/app/build/base.py +++ b/app/build/base.py @@ -10,27 +10,54 @@ from django.conf import settings class Build(): - def write_file(self, path, object): - file = open(path, 'w') + def write_file(self, path, object, ext='html',filename='index'): + """ + Given a path and object intended to be a webpage, write the page the + disc + """ + path = '%s%s' %(settings.FLATFILES_ROOT, path) + if not os.path.isdir(path): + os.makedirs(path) + fpath = '%s%s.%s' %(path, filename, ext) + file = open(fpath, 'w') file.write(object) file.close() + if ext == 'js': + import jsmin + compressed = jsmin.jsmin(object) + fpath = '%s%s.min.%s' %(path, filename, ext) + file = open(fpath, 'w') + file.write(compressed) + file.close() -class BuildSitemap(Build): - def build(self): + def build_archive_pages(self, qs=None, base_path='', paginate_by=10): + """ + Archive Page builder that actually crawls the urls + because we need to be able to pass a request object to the template + + """ + if qs == None: + qs = self.get_model_querset() c = Client() - response = c.get('/sitemap.xml') - fpath = '%ssitemap.xml' %(settings.BAKED_ROOT) - self.write_file(fpath,str(response.content)) - + pages = ceil(Decimal(qs.count())/Decimal(paginate_by)) + for page in range(int(pages)): + path = '%s%s/' %(base_path, page+1) + url = '/%s%s/' %(base_path, str(page+1)) + page_url = base_path+'%d/' + response = c.post(url, {'page_url': page_url, 'page': int(page)}) + if page == 0: + self.write_file(base_path,str(response.content)) + self.write_file(path,str(response.content)) + class BuildWriting(Build): - - def build(self): self.build_detail_pages() - self.build_archive_pages() + self.build_writing_archives() self.build_location_archive_pages() self.build_homepage() - + self.writing_year_archives() + self.writing_month_archives() + def get_model_querset(self): model = get_model('blog', 'entry') qs = model.objects.filter(status__exact=1) @@ -44,31 +71,16 @@ class BuildWriting(Build): for entry in qs: c = Context({'object':entry,'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) t = render_to_string('details/entry.html',c).encode('utf-8') - path = '%s%s/%s/' %(settings.BAKED_ROOT, entry.pub_date.strftime("%Y/%b/%d").lower(), entry.slug) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,t) + path = '%s/%s/' %(entry.pub_date.strftime("%Y/%b/%d").lower(), entry.slug) + self.write_file(path,t) + s = render_to_string('details/entry.txt',c).encode('utf-8') + self.write_file(path,s,'txt') - def build_archive_pages(self, qs=None, extra='writing/', paginate_by=10): - if qs == None: - qs = self.get_model_querset() - c = Client() - pages = ceil(Decimal(qs.count())/Decimal(paginate_by)) - print pages - for page in range(int(pages)): - base_path = '%s%s' %(settings.BAKED_ROOT, extra) - path = '%s%s/' %(base_path, page+1) - if not os.path.isdir(path): - os.makedirs(path) - url = '/%s%s/' %(extra, str(page+1)) - page_url = extra+'%d/' - response = c.post(url, {'page_url': page_url, 'page': int(page)}) - fpath = '%sindex.html' %(path) - if page == 0: - self.write_file(base_path+'/index.html',str(response.content)) - self.write_file(fpath,str(response.content)) - + + def build_writing_archives(self): + qs = self.get_model_querset() + self.build_archive_pages(qs, 'writing/') + def build_location_archive_pages(self): model = get_model('locations', 'Country') blog = get_model('blog', 'entry') @@ -77,28 +89,39 @@ class BuildWriting(Build): qs = blog.objects.filter(status__exact=1,location__state__country = c).order_by('-pub_date') path = 'writing/%s/' %(c.slug) self.build_archive_pages(qs, path) - - def build_recent_entries(self): - model = get_model('blog', 'entry') - qs = {'object_list': model.objects.filter(status__exact=1).order_by('-pub_date')[1:4]} - c = Context(qs) - t = render_to_string('bin/recent_entries.html',c).encode('utf-8') - fpath = '%s%s' %(settings.PROJ_ROOT,'templates/includes/recent_entries.html') - self.write_file(fpath,t) - - - + + def writing_year_archives(self): + entry = get_model('blog', 'entry') + years = entry.objects.dates('pub_date', 'year') + for year in years: + year = year.strftime('%Y') + qs = entry.objects.filter(status__exact=1,pub_date__year=year).order_by('-pub_date') + c = Context({'type':'year','date': year, 'object_list':qs,}) + t = render_to_string('archives/writing_date.html',c).encode('utf-8') + fpath = '%s/' %(year) + self.write_file(fpath,t) + + def writing_month_archives(self): + entry = get_model('blog', 'entry') + months = entry.objects.dates('pub_date', 'month') + for m in months: + year = m.strftime('%Y') + month = m.strftime('%m') + month_name = m.strftime('%b') + month_full_name = m.strftime('%B') + qs = entry.objects.filter(status__exact=1,pub_date__year=year,pub_date__month=month).order_by('-pub_date') + c = Context({'type':'monthly','date': '%s %s' %(month_full_name,year), 'object_list':qs,}) + t = render_to_string('archives/writing_date.html',c).encode('utf-8') + fpath = '%s/%s/' %(year,month_name) + self.write_file(fpath,t) + def build_homepage(self): - self.build_recent_entries() qs = get_model('blog', 'entry').objects.filter(status__exact=1).latest() c = Context({'featured':qs,'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) t = render_to_string('archives/homepage.html',c).encode('utf-8') - fpath = '%s%s' %(settings.BAKED_ROOT,'index.html') - self.write_file(fpath,t) - - -class BuildPhotos(BuildWriting): + self.write_file('',t) +class BuildPhotos(Build): def build(self): self.build_photo_archive_pages() self.build_detail_pages() @@ -110,76 +133,13 @@ class BuildPhotos(BuildWriting): def build_detail_pages(self): qs = get_model('photos', 'PhotoGallery').objects.all() - path = 'photos/galleries/' - ''' - Grab all the blog posts, render them to a template string and write that out to the filesystem - ''' for photo in qs: c = Context({'object':photo,'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) t = render_to_string('details/photo_galleries.html',c).encode('utf-8') - path = '%sphotos/galleries/%s/' %(settings.BAKED_ROOT, photo.set_slug) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,t) - - + path = 'photos/galleries/%s/' %(photo.set_slug) + self.write_file(path,t) -class BuildAbout(Build): - def build(self): - model = get_model('chunks', 'Chunk') - qs = model.objects.filter(key__in=['about_top','about_middle','about_bottom']) - c = Context({ - 'object_list': qs, - 'IMAGES_URL' : settings.BAKED_IMAGES_URL, - 'MEDIA_URL':settings.BAKED_MEDIA_URL - }) - t = render_to_string('details/about.html',c).encode('utf-8') - path = '%sabout/' %(settings.BAKED_ROOT) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,t) - -class BuildMap(Build): - - def build_map_templates(self): - import codecs - qs = get_model('blog', 'entry').objects.filter(status__exact=1) - cl = get_model('locations', 'Country').objects.filter(visited=True).exclude(name='default') - rl = get_model('locations', 'Region').objects.all() - rtl = get_model('locations', 'Route').objects.all() - c = Context({'object_list':qs, 'country_list':cl,'region_list':rl, 'route_list':rtl, 'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) - t = render_to_string('bin/map_entry_list.html',c).encode('utf-8') - fpath = '%s%s' %(settings.PROJ_ROOT,'media/js/mainmap.js') - self.write_file(fpath,t) - c = Context({'country_list':cl,'region_list':rl,'route_list':rtl,'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) - t = render_to_string('bin/map_sidebar.html',c).encode('utf-8') - fpath = '%s%s' %(settings.PROJ_ROOT,'templates/includes/map_sidebar.html') - self.write_file(fpath,t) - - def build(self): - self.build_map_templates() - c = Context({'MEDIA_URL':settings.BAKED_MEDIA_URL,'IMAGES_URL':settings.BAKED_IMAGES_URL}) - t = render_to_string('archives/map.html', c).encode('utf-8') - path = '%smap/' %(settings.BAKED_ROOT) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,t) - -class BuildContact(Build): - def build(self): - c = Client() - response = c.get('/contact/') - path = '%scontact/' %(settings.BAKED_ROOT) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,str(response.content)) - class BuildProjects(Build): - def build(self): self.build_project_archive() self.build_project_details() @@ -197,11 +157,7 @@ class BuildProjects(Build): qs = get_model('projects', 'Project').objects.filter(status__exact=1).order_by('-pub_date') c = Context({'object_list': qs,'MEDIA_URL':settings.BAKED_MEDIA_URL,'IMAGES_URL':settings.BAKED_IMAGES_URL}) t = render_to_string('archives/projects.html', c).encode('utf-8') - path = '%sprojects/' %(settings.BAKED_ROOT) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,t) + self.write_file('projects/',t) def build_project_details(self): projects = self.get_projects() @@ -213,11 +169,9 @@ class BuildProjects(Build): qs = model.objects.filter(status__exact=1) c = Context({'object_list': qs,'MEDIA_URL':settings.BAKED_MEDIA_URL,'IMAGES_URL':settings.BAKED_IMAGES_URL}) t = render_to_string('details/%s.html' %(proj['slug']), c).encode('utf-8') - path = '%sprojects/%s/' %(settings.BAKED_ROOT, proj['slug']) - if not os.path.isdir(path): - os.makedirs(path) - fpath = '%sindex.html' %(path) - self.write_file(fpath,t) + path = 'projects/%s/' %(proj['slug']) + self.write_file(path,t) + def build_project_data(self): from projects.shortcuts import render_to_geojson model = get_model('projects', 'NationalParks') @@ -233,9 +187,74 @@ class BuildProjects(Build): json = str(json) json ="\n".join(json.splitlines()[3:]) #print json - path = '%sprojects/data/' %(settings.BAKED_ROOT) - if not os.path.isdir(path): - os.makedirs(path) + path = 'projects/data/' fpath = '%s%s.json' %(path, park.id) self.write_file(fpath,json) +class BuildSitemap(Build): + def build(self): + c = Client() + response = c.get('/sitemap.xml') + self.write_file('',str(response.content), 'xml','sitemap') + +class BuildWritingFeed(Build): + def build(self): + qs = Entry.objects.filter(status__exact=1).order_by('-pub_date')[:20] + c = Context({'object_list':qs,'SITE_URL':settings.SITE_URL}) + t = render_to_string('feed.xml',c).encode('utf-8') + fpath = '%s' %('feed/',) + self.write_file(fpath,t,'xml') + +class BuildMap(Build): + def build(self): + qs = get_model('blog', 'entry').objects.filter(status__exact=1) + cl = get_model('locations', 'Country').objects.filter(visited=True).exclude(name='default') + rl = get_model('locations', 'Region').objects.all() + rtl = get_model('locations', 'Route').objects.all() + c = Context({'object_list':qs, 'country_list':cl,'region_list':rl, 'route_list':rtl, 'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) + t = render_to_string('archives/map_data.html',c).encode('utf-8') + self.write_file('media/js/',t, 'js','mainmap') + c = Context({'country_list':cl,'region_list':rl,'route_list':rtl,'MEDIA_URL':settings.BAKED_MEDIA_URL, 'IMAGES_URL':settings.BAKED_IMAGES_URL}) + t = render_to_string('archives/map.html',c).encode('utf-8') + self.write_file('map/',t) + +class BuildPages(Build): + def build(self): + model = get_model('pages', 'page') + pages = model.objects.all() + for page in pages: + c = Context({'object':page,'SITE_URL':settings.SITE_URL, 'MEDIA_URL':settings.BAKED_MEDIA_URL,'IMAGES_URL':settings.BAKED_IMAGES_URL}) + t = render_to_string('details/page.html',c).encode('utf-8') + s = render_to_string('details/page.txt',c).encode('utf-8') + fpath = '%s/' %(page.slug) + self.write_file(fpath,t) + self.write_file(fpath,s,'txt') + + + +class BuildContact(Build): + def build(self): + c = Client() + response = c.get('/contact/') + path = '%scontact/' %(settings.BAKED_ROOT) + if not os.path.isdir(path): + os.makedirs(path) + fpath = '%sindex.html' %(path) + self.write_file(fpath,str(response.content)) + +class BuildAbout(Build): + def build(self): + model = get_model('chunks', 'Chunk') + qs = model.objects.filter(key__in=['about_top','about_middle','about_bottom']) + c = Context({ + 'object_list': qs, + 'IMAGES_URL' : settings.BAKED_IMAGES_URL, + 'MEDIA_URL':settings.BAKED_MEDIA_URL + }) + t = render_to_string('details/about.html',c).encode('utf-8') + path = '%sabout/' %(settings.BAKED_ROOT) + if not os.path.isdir(path): + os.makedirs(path) + fpath = '%sindex.html' %(path) + self.write_file(fpath,t) + |