import email.utils import math import os.path import time plugins_release = '2.4.0' mib_release = '1.0.1' release_notes = 'news/release-%s.html' % plugins_release.replace('.', '-') site_url = 'https://www.monitoring-plugins.org/' feeds = """These project news articles are also available as an [RSS feed][rss]{: rel="alternate" type="application/rss+xml" }. Additional stuff is posted to [Mastodon][mastodon], so you might want to follow us there as well. [rss]: rss.xml "RSS Feed" [mastodon]: https://fosstodon.org/@monitoringplugins "Mastodon" """ page = { "description": "Standard monitoring plugins for Nagios and compatible monitoring solutions.", "keywords": "Nagios, Icinga, Shinken, Naemon, Sensu, Monitoring, Official, Plugins, Open, Source, Free, Software" } # # RSS Feed # _RSS = """ %s %s %s en-us webmaster@monitoring-plugins.org %s %s Poole http://blogs.law.harvard.edu/tech/rss %s """ _RSS_ITEM = """ %s %s %s %s %s """ def hook_postconvert_rss(): items = [] posts = [p for p in pages if 'date' in p] posts.sort(key=lambda p: p.date, reverse=True) for p in posts: link = '%s/%s' % (site_url.rstrip('/'), p.url) desc = hx(p.html) date = time.mktime(time.strptime('%s 12' % p.date, '%Y-%m-%d %H')) date = email.utils.formatdate(date) items.append(_RSS_ITEM % (p.title, link, desc, link, date)) items = ''.join(items) title = 'Monitoring Plugins' link = '%s/news/' % site_url.rstrip('/') desc = 'Announcements published by the Monitoring Plugins Development Team.' date = email.utils.formatdate() rss = _RSS % (title, link, desc, date, date, items) with open(os.path.join(output, 'rss.xml'), 'w', encoding='utf-8') as fp: fp.write(rss) # # News # def hook_preconvert_news(): posts_per_page = 10 posts = [p for p in pages if 'date' in p] posts.sort(key=lambda p: p.date, reverse=True) n_news_pages = math.ceil(len(posts) / posts_per_page) if len(posts) % posts_per_page > 0: n_news_pages += 1 for i, chunk in enumerate(next_news_chunk(posts, posts_per_page)): content = make_news_page(chunk, i) + make_news_footer(n_news_pages, i) if i == 0: p = Page('news/index.md', virtual=content, menu=2, title='News', parent='Home') else: p = Page('news/%d.md' % (i + 1), virtual=content, title='News Page %d' % (i + 1), parent='News') pages.append(p) def make_news_page(posts, current_index): marker = '' if current_index == 0: title = 'News' teaser = ['# ' + title, feeds] else: title = 'News Page %d' % (current_index + 1) teaser = ['# ' + title] for p in posts: source = list() author = p.author timestamp = time.strptime(p.date, '%Y-%m-%d') author_date = author + ', ' + time.strftime('%B %-e, %Y', timestamp) teaser.append('## %s' % p.title) teaser.append('*%s*' % author_date) teaser.append('%s' % p.source.split(marker, 1)[0].rstrip()) teaser.append('Read more »' % p.url) source.append('# %s' % p.title) source.append('*%s*' % author_date) source.append(p.source.replace(marker, '', 1)) p.source = '\n'.join(source) p['parent'] = title return '\n'.join(teaser) + '\n\n' def make_news_footer(n_news_pages, current_index): if n_news_pages == 1: return '' footer = list() if current_index != 0: previous = 'index' if current_index == 1 else str(current_index) footer.append('[First](news/index.html)') footer.append('[Previous](news/%s.html)' % previous) if n_news_pages <= 20: for i in range(n_news_pages): if i == current_index: footer.append('%d' % (i + 1)) elif i == 0: footer.append('[1](news/index.html)') else: footer.append('[%d](news/%d.html)' % (i + 1, i + 1)) if current_index != n_news_pages - 1: footer.append('[Next](news/%d.html)' % (current_index + 2)) footer.append('[Last](news/%d.html)' % n_news_pages) return ' '.join(footer) + '\n{: #news-footer }\n' def next_news_chunk(posts, posts_per_page): index = 0 while len(posts[index:]) > 0: yield posts[index:index + posts_per_page] index += posts_per_page # # Menu and Breadcrumb Navigation # def menu(): menu_pages = [p for p in pages if 'menu' in p] menu_pages.sort(key=lambda p: int(p['menu'])) for p in menu_pages: if p.title == page.title: print('%s' % hx(p.title)) else: print('%s' % (p.url, hx(p.title))) def breadcrumb(): stable = 'Stable release: %s' \ % (release_notes, plugins_release) parents = {p.title: (p.url, p.get('parent')) for p in pages} title = page.title crumbs = hx(title) while parents[title][1] is not None: title = parents[title][1] url = parents[title][0] crumbs = '%s » %s' % (url, hx(title), crumbs) if crumbs == hx(page.title): crumbs = ' ' + stable return crumbs # # Miscellaneous # def list_kids(): kids = [(p.url, p.title) for p in pages if p.get('parent') == page.title] for kid in sorted(kids): print('* [%s](%s)' % (kid[1], kid[0])) def copyright_years(since=None): this_year = time.gmtime().tm_year if since is not None and int(since) != this_year: return str(since) + '–' + str(this_year) else: return str(this_year) # vim:set expandtab softtabstop=4 shiftwidth=4 textwidth=80: