License Crates.io Docs.rs

flatpage

A simple file system based markdown flat page.

Folder structure

Only characters allowed in urls are ASCII, numbers and hyphen with underscore. Urls map to files by simply substituting / to ^ and adding .md extension. I believe it should eliminate all kinds of security issues.

| url | file name | |----------------|-------------------| | / | ^.md | | /foo/bar-baz | ^foo^bar-baz.md |

Page format

File could provide title and description in a yaml-based frontmatter, if there's no frontmatter the first line would be considered the title (and cleaned from possible header marker #).

| File content | [title] | [description] | [body] | [html()] | |------------------------------------------------------|---------------------|---------------------------|--------------------|--------------------------------| | # Foo
Bar | "Foo" | None | "# Foo\nBar" | "<h1>Foo</h1>\n<p>Bar</p>\n" | | ---
description: Bar
---
# Foo | "Foo" | Some("Bar") | "# Foo" | "<h1>Foo</h1>\n" | | ---
title: Foo
description: Bar
--- | "Foo" | Some("Bar") | "" | "" |

Reading a page

rust let root_folder = "./"; if let Some(home) = flatpage::FlatPage::by_url(root_folder, "/").unwrap() { println!("title: {}", home.title); println!("description: {:?}", home.description); println!("markdown body: {}", home.body); println!("html body: {}", home.html()); } else { println!("No home page"); }

Cached metadata

It's a common for a page to have a list of related pages. To avoid reading all the files each time, you can use [FlatPageStore] to cache pages [metadata] (titles and descriptions).

rust let root_folder = "./"; let store = flatpage::FlatPageStore::read_dir(root_folder).unwrap(); if let Some(meta) = store.meta_by_url("/") { println!("title: {}", meta.title); println!("description: {:?}", meta.description); } else { println!("No home page"); }

Contributing

We appreciate all kinds of contributions, thank you!

Note on README

The README.md file isn't meant to be changed directly. It instead generated from the crate's docs by the [cargo-readme] command:

If you have [rusty-hook] installed the changes will apply automatically on commit.

License

This project is licensed under the MIT license.