2021-10-19 14:00:51 +02:00
|
|
|
# This creates the static files that make up my blog from the Markdown
|
|
|
|
# files in this repository.
|
|
|
|
#
|
|
|
|
# All blog posts are rendered from Markdown by cheddar.
|
|
|
|
{ depot, lib, pkgs, ... }@args:
|
|
|
|
|
|
|
|
with depot.nix.yants;
|
|
|
|
|
|
|
|
let
|
2021-11-04 15:39:19 +01:00
|
|
|
inherit (builtins) readFile;
|
|
|
|
inherit (depot.nix) renderMarkdown;
|
|
|
|
inherit (depot.web) atom-feed;
|
|
|
|
inherit (lib) singleton;
|
|
|
|
|
2021-10-19 14:00:51 +02:00
|
|
|
# Type definition for a single blog post.
|
|
|
|
post = struct "blog-post" {
|
2021-11-02 14:34:20 +01:00
|
|
|
key = string;
|
2021-10-19 14:00:51 +02:00
|
|
|
title = string;
|
|
|
|
date = int;
|
|
|
|
|
|
|
|
# Optional time at which this post was last updated.
|
|
|
|
updated = option int;
|
|
|
|
|
|
|
|
# Path to the Markdown file containing the post content.
|
|
|
|
content = path;
|
|
|
|
|
2023-09-08 14:50:05 +02:00
|
|
|
# Whether dangerous HTML tags should be filtered in this post. Can
|
|
|
|
# be disabled to, for example, embed videos in a post.
|
|
|
|
tagfilter = option bool;
|
|
|
|
|
2022-09-13 14:14:37 +02:00
|
|
|
# Optional name of the author to display.
|
|
|
|
author = option string;
|
|
|
|
|
2021-10-19 14:00:51 +02:00
|
|
|
# Should this post be included in the index? (defaults to true)
|
|
|
|
listed = option bool;
|
|
|
|
|
|
|
|
# Is this a draft? (adds a banner indicating that the link should
|
|
|
|
# not be shared)
|
|
|
|
draft = option bool;
|
|
|
|
|
|
|
|
# Previously each post title had a numeric ID. For these numeric
|
|
|
|
# IDs, redirects are generated so that old URLs stay compatible.
|
|
|
|
oldKey = option string;
|
|
|
|
};
|
|
|
|
|
2021-11-04 15:39:19 +01:00
|
|
|
# Rendering fragments for the HTML version of the blog.
|
2021-10-19 14:00:51 +02:00
|
|
|
fragments = import ./fragments.nix args;
|
2021-11-04 15:39:19 +01:00
|
|
|
|
|
|
|
# Functions for generating feeds for these blogs using //web/atom-feed.
|
2021-11-05 14:19:06 +01:00
|
|
|
toFeedEntry = { baseUrl, ... }: defun [ post atom-feed.entry ] (post: rec {
|
|
|
|
id = "${baseUrl}/${post.key}";
|
2021-11-04 15:39:19 +01:00
|
|
|
title = post.title;
|
|
|
|
content = readFile (renderMarkdown post.content);
|
|
|
|
published = post.date;
|
|
|
|
updated = post.updated or post.date;
|
|
|
|
|
|
|
|
links = singleton {
|
|
|
|
rel = "alternate";
|
|
|
|
href = id;
|
|
|
|
};
|
|
|
|
});
|
2021-10-19 14:00:51 +02:00
|
|
|
in
|
|
|
|
{
|
2021-11-04 15:39:19 +01:00
|
|
|
inherit post toFeedEntry;
|
2021-10-19 14:00:51 +02:00
|
|
|
inherit (fragments) renderPost;
|
2021-12-01 10:32:53 +01:00
|
|
|
|
|
|
|
# Helper function to determine whether a post should be included in
|
|
|
|
# listings (on homepages, feeds, ...)
|
2021-11-02 14:34:20 +01:00
|
|
|
includePost = post: !(fragments.isDraft post) && !(fragments.isUnlisted post);
|
2021-10-19 14:00:51 +02:00
|
|
|
}
|