Blog Setup
Initial blog setup instructions can be found here.
Making a Post
To make a post, create a markdown file within paper/src/data/blog/<your-markdown-file-here>.md.
Posts need a bit of frontmatter to function properly, at the minimumum the following is required:
---
title: Blog Setup
description: Blog setup and quick-reference post notes.
pubDatetime: 2025-09-17T12:13:00+00
modDatetime: <null | 2025-09-22T06:25:00+00>
tags:
  - blogging
---While tags are not technically required, tagging posts is a great way to find relevant posts for given topics. More information about adding posts can be found in the upstream documentation
The following date command on Linux works to generate an acceptable timestamp for pubDatetime or modDatetime frontmatter fields:
date +%Y-%m-%dT%H:%M:%SZTesting locally
To run and verify the blog site locally, execute:
npm run dev -- --hostThis runs the development server and makes the blog available on port http://localhost:4321
Hosting
I setup initial hosting on GitHub pages. The documentation starts here
For GitHub to host an AstroJS backed blog, it must know the content that needs to be hosted. This can be in the form of files directly in the repository, or as an output of a GitHub Action. In the case of Astro, it needs to be the output of a GitHub action as the builder needs to produce the appropriate output content. There are additional details on the Astro documentation site here
Custom Domain
When configuring a custom domain for a GitHub site GitHub suggests to configure the GitHub Pages settings before the adding the DNS records to your DNS provider. This ensures your domain will not get hijacked by someone else on a GitHub page. Information about that here.
The AstroJS docs instruct to add a CNAME file to your project. But there is a note in the GitHub docs that states:
you are publishing from a custom GitHub Actions workflow, no CNAME file is created, and any existing CNAME file is ignored and is not required.
For non-apex domains (aka subdomains) GitHub prefers you use CNAME records.