A simple file system based markdown flat page.
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
|
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")
| ""
| ""
|
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");
}
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");
}
We appreciate all kinds of contributions, thank you!
The README.md
file isn't meant to be changed directly. It instead generated from the crate's docs
by the [cargo-readme] command:
cargo install cargo-readme
src/lib.rs
, or wrapping text in README.tpl
cargo readme > README.md
If you have [rusty-hook] installed the changes will apply automatically on commit.
This project is licensed under the MIT license.