Добавление генератора Atom [closes #4]

master
Антон Касимов 2019-05-13 20:39:54 +03:00
parent 724ec1040c
commit 1ca1929e23
4 changed files with 54 additions and 10 deletions

View File

@ -0,0 +1,38 @@
<?xml version="1.0" encoding="utf-8"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:base="{{data.base_url}}">
<title type="text">{{title}}</title>
{%- if subtitle %}
<subtitle type="html">{{subtitle}}</subtitle>
{%- endif %}
<link rel="self" href="{{request.path_qs}}"/>
{%- if alternate %}
<link rel="alternate" type="text/html" hreflang="{{request.locale_name}}" href="{{alternate}}"/>
{%- endif %}
<updated>{{(pages[0][1].page['updated'] or pages[0][1].page['published']).isoformat()}}+00:00</updated>
<id>urn:uuid:{{id}}</id>
<author>
<name>{{author['name']}}</name>
</author>
{%- if category %}
<category term="{{category}}"/>
{%- endif %}
<generator uri="https://trac.radium.group/flatfilecms/" version="1.0">flatfilecms</generator>
{%- for item in pages %}
<entry>
<title>{{item[1].page['title']}}</title>
<link href="{{item[0]}}"/>
<id>urn:uuid:{{item[1].page['id']}}</id>
<updated>{{(item[1].page['updated'] or item[1].page['published']).isoformat()}}+00:00</updated>
<published>{{item[1].page['published'].isoformat()}}+00:00</published>
<summary>{{item[1].page['summary'] or item[1].page['description']}}</summary>
{%- if item[1].page['author'] %}
<author>
<name>{{item[1].page['author']['name']}}</name>
</author>
{%- endif %}
{%- if item[1].page['category'] %}
<category term="{{item[1].page['category']}}"/>
{%- endif %}
</entry>
{%- endfor %}
</feed>

View File

@ -12,6 +12,9 @@
{% if amphtml is defined -%}
<link rel="amphtml" href="{{amphtml}}">
{% endif -%}
{% for link in alternate -%}
<link rel="{{link.type}}" title="{{link.title}}" href="{{link.href}}">
{% endfor -%}
<title>{{title}}</title>
{% block links %}
{%- endblock %}

View File

@ -17,4 +17,8 @@
</div>
{% endfor %}
</div>
{% set atom_feed = alternate|selectattr('type', 'equalto', 'application/atom+xml')|first -%}
{% if atom_feed -%}
<p>Подписаться на обновления: <a href="{{atom_feed.href}}"><i class="fas fa-rss"></i></a></p>
{% endif -%}
{% endblock %}

View File

@ -19,6 +19,7 @@ def set_content_type(self, content_type):
def blog(self, options={}):
path = options.get('base', '')
format = options.get('format', 'blogposts')
root = find_root(self.context)
tree = find_resource(root, path)
postlist = []
@ -27,19 +28,17 @@ def blog(self, options={}):
postlist.append((f"{path}/{name}", item))
post = self.context.page.copy()
post['pages'] = sorted(
postlist,
key=lambda t: t[1].page['published'],
reverse=True)
postlist, key=lambda t: t[1].page['published'], reverse=True)
if 'menu' not in post:
post['menu'] = yaml.load(
AssetResolver().resolve(
str(PurePath(self.context.data_path) /
'menu/default.yaml')).stream(),
LoaderFactory(self.context.data_path))
return render_to_response(
'{0}.jinja2'.format(
post.get('template', 'blogposts')),
post,
request=self.request,
response=self.request.response
)
if format == 'atom':
set_content_type(self, 'application/atom+xml')
return render_to_response(
'{0}.jinja2'.format(post.get('template', format)),
post,
request=self.request,
response=self.request.response)