πΎ Archived View for gerikson.com βΊ gemlog βΊ misc βΊ Gemlog-with-Blosxom.gmi captured on 2024-12-17 at 09:41:57. Gemini links have been rewritten to link to archived content
β¬ οΈ Previous capture (2022-07-16)
-=-=-=-=-=-=-
I've used [Bloxsom] for ages for my blog. It's a nice simple system with a lot of plugins for more powerful functionality.
You need your own Unix host connected to the internet.
You need to have a gemini server installed and working.
You need Perl installed.
Download the `blosxom.cgi` file from the site. Plunk it in a logical place. You can set it to be executable, or just call `perl ./blosxom.cgi` directly.
Open it in your favorite editor.
The configuration steps are detailed here:
http://blosxom.sourceforge.net/documentation/users/configure/
Here are the relevant parts from my personal setup. Comments with [brackets] are my clarifications.
# What's this blog's title? $blog_title = "gerikson.com gemlog"; # What's this blog's description (for outgoing RSS feed)? $blog_description = "gemlog via Blosxom"; # Where are this blog's entries kept? $datadir = "/home/gustaf/gemsite/gemlog-data"; # What's my preferred base URL for this blog (leave blank for automatic)? $url = "gemini://gerikson.com/gemlog"; # What file extension signifies a blosxom entry? # [change this to whatever you want if you prefer Markdown, for example] $file_extension = "txt"; # What is the default flavour? # [Specific for gemini, default is 'html'] $default_flavour = "gmi"; # --- Plugins (Optional) ----- # Where are my plugins kept? $plugin_dir = "/home/gustaf/gemsite/gemlog-plugins"; # Where should my plugins keep their state information? $plugin_state_dir = "$plugin_dir/state"; # --- Static Rendering ----- # Where are this blog's static files to be created? # [This is where your Gemini serve gets its content!] $static_dir = "/home/gemini/gemini/gemlog"; # What's my administrative password (you must set this for static rendering)? $static_password = "SuperSecret"; # What flavours should I generate statically? @static_flavours = qw/gmi atom/; # Should I statically generate individual entries? # 0 = no, 1 = yes $static_entries = 1;
The stuff that's different from a normal HTML blog is the flavour(s):
By default, Blosxom is a CGI application that reads from the filesystem directly. This is fine in its way but for gemini we want to keep it simple and static.
Plugins help extend Blosxom. The canonical list is here:
http://blosxom.sourceforge.net/plugins/
But not all plugin links are live! You might have to google them, or grab them from my repository:
https://github.com/gustafe/gemsite/tree/main/gemlog-plugins
Here are the ones I use:
By default, Blosxom will generate (non-semantic) HTML4. You are expected to write your posts in straight HTML. We will leverage that to serve straight gemtext.
First, we need to customize each page for the `gmi` flavour. This will override the default HTML flavour.
Create a directory `flavours` in your data dir. Create and edit the following files:
My current settings are visible here:
https://github.com/gustafe/gemsite/tree/main/gemlog-data/flavours
I use `head.gmi` for stuff like the name of the blog, links to the main page, etc. `foot.gmi` contains copyright/licensing. I leave `date.gmi` empty.
`story.gmi` looks like this
# $title $body ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ => $url$path/$fn.gmi ΒΆ $date_fullname::dw, $yr-$mo_num-$da => $url$path/ Β» more posts in the βΉ$fmtcat::fmtcatβΊ category $meta::updated About this category: β$category_desc::descriptionβ
Each story will have a 2nd level title (grabbed from the source file), the body, and then a permalink. Note that this is straight gemtext.
By default, Blosxom will present a page like this
HEAD DATE STORY STORY DATE STORY [...] FOOT
But gemlogs want to look like this
HEAD => link to DATE - TITLE => link to DATE - TITLE [...] FOOT
To enable this, we'll use the `entries_template` plugin. Its config file lives in the `flavours` subdir too. Mine looks likes this:
=> $url$path/$fn.gmi $yr-$mo_num-$da - $title
Note the permalink construction is the same as in the story template.
We're ready to start gemlogging!
Fire up an editor and write a piece of gemtext in your `$datadir`. You can use subdirectories if you want, these will essentially be categories.
Then run the following command:
$ perl ./blosxom.cgi -password='SuperSecret'
This should generate a bunch of files in the location denoted by `$static_dir`. Point your gemini browser and you should see a front page with your first post as an entry.
If you open the post again, the `entriescache` plugin should have added a `meta-created-date` line just under the first line.
By default you can get to the post via the following links:
The following URLs will show pages with links:
For example:
gemini://gerikson.com/gemlog/misc/
gemini://gerikson.com/gemlog/2021/10
gemini://gerikson.com/gemlog/2021/
Each subdirectory/date will have its own Atom feed, too.
This setup gives you flexibility in how to present your content, construct permalinks, etc.
Add the configuration `-all=1` to force a re-read of all files, not just new and edited ones. Use the `-quiet=1` option to suppress output.
This is a setting carried over from my blog. I only want a dozen or so posts on my front page, while if I navigate to a category or a year, I want to see all of the posts.
By default, Blosxom will show the number of posts defined in the `$num_entries` variable in the config, irrespective of the view chosen.
The plugins `prefs` and `pagetype` help with this. `pagetype` identifies the type of page ('chrono', 'category', or 'story'), while `prefs` allows you to dynamically change the `$blosxom::` variables.
In the top-level of my `$data_dir` I have the file `pageprefs`:
if (($pagetype::pagetype eq 'chrono') or ($pagetype::pagetype eq 'category')) { $blosxom::num_entries = 999 } else { $blosxom::num_entries = 15 };
This will show 15 entries on the front page, but 999 on date or category pages.
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Updated on Sunday, 2021-10-10
β more posts in the βΉmiscβΊ category
About this category: βWhat is says in the URL pathβ
Copyright Β© 2018 - 2021 Gustaf Erikson