A web server mainly oriented at media serving for small websites.
In general, whisper serves static content from the location it's found - making it easy to structure your site how you want. There is special handling for certain content like Markdown files.
See the example folder for a sample site layout. In general, whisper uses conventions instead of configuration files. Conventions used by this server include:
- The
template
folder holds HTML templates, using Go'shtml/template
package. These templates are used for rendering content but never served directly. - A
sitemap.txt
can be created as a template. See the example for details. - The default page for a folder is a Markdown file called
index.md
. - An optional
whisper.cfg
file holds settings should you want to preserve them. - Files
404.md
and500.md
can be provided for custom errors.
Web pages are generally written in Markdown and use HTML templates to render into the site. The default template to use is called default
; you must have a default
template and an image
template. Templates are stored in the template
folder.
NOTE: If no
template
folder is found, then default templates are loaded nameddefault
andimage
. You probably don't want these because they are extremely basic, but it's okay for just messing around and viewing Markdown locally.
Markdown may contain front matter which is in TOML format. The front matter is delimited by +++
at the start and end. For example:
+++
# This is my front matter
title = "My glorious page"
+++
# This is my Heading
This is my [Markdown](https://en.wikipedia.org/wiki/Markdown).
Front matter may include:
Name | Type | Description |
---|---|---|
title | string | Title of page |
date | time | Publish date |
tags | array of strings | Tags for the articles (not used yet) |
template | string | Override the template to render this file |
redirect | duration | Provide redirect info (not automated) |
originalfile | string | Name of the base Markdown or image file |
Front matter is used for sorting and constructing lists of articles.
whisper uses standard Go templates from the html/template
package. Templates are passed the following data:
// FrontMatter holds data scraped from a Markdown page.
type FrontMatter struct {
Title string `toml:"title"` // Title of this page
Date time.Time `toml:"date"` // Date the article appears
Template string `toml:"template"` // The name of the template to use
Tags []string `toml:"tags"` // Tags to assign to this article
Redirect string `toml:"redirect"` // Issue a redirect to another location
OriginalFile string `toml:"originalfile"` // The original file (markdown or image)
}
// PageInfo has information about the current page.
type PageInfo struct {
Path string // path from URL
Filename string // end portion (file) from URL
}
// data is what is passed to markdown templates.
type data struct {
FrontMatter FrontMatter // front matter from Markdown file or defaults
Page PageInfo // information aboout current page
Content template.HTML // rendered Markdown
}
Page
is information about the current page, and FrontMatter
is the front-matter from the current Markdown file. Content
contains the HTML version of the Markdown file.
Functions are added to the template for your convenience.
Function | Description |
---|---|
dir(path string) []File |
Return the contents of the given folder, excluding special files and subfolders. |
sortbyname([]File) []File |
Sort by name (reverse) |
sortbytime([]File) []File |
Sort by time (reverse) |
match(string, ...string) bool |
Match string against file patterns |
filter([]File, ...string) []File |
Filter list against file patterns |
join(parts ...string) string |
The same as path.Join |
ext(path string) string |
The same as path.Ext |
prev([]File, string) *File |
Find the previous file based on Filename |
next([]File, string) *File |
Find the next file based on Filename |
reverse([]File) []File |
Reverse the list |
trimsuffix(string, string) string |
The same as strings.TrimSuffix |
trimprefix(string, string) string |
The same as strings.TrimPrefix |
trimspace(string) string |
The same as strings.TrimSpace |
markdown(string) template.HTML |
Render Markdown file into HTML |
frontmatter(string) *FrontMatter |
Read front matter from file |
now() time.Time |
Current time |
File
is defined as:
// File holds data about a page endpoint.
type File struct {
FrontMatter FrontMatter
Filename string
}
If File
is not a Markdown file, then FrontMatter.Title
is set to the file name and FrontMatter.Date
is set to the modification time. The array is sorted by reverse date (most recent items first).
Note that FrontMatter.OriginalFile
is very useful because, for image templates, it will hold the name of the image file. You probably want to use it in the template.
Folders named photos
, images
, pictures
, cartoons
, toons
, sketches
, artwork
, or drawings
use a special handler that can serve images using an HTML template called image
.
- It's not a goal to make templates reusable. I expect templates need editing for new sites.
- It's not a goal to automate creation of the menu.
- It's not a goal to be a fully-featured server. I run Caddy in front of it.