Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lpil/storail
https://github.com/lpil/storail
Last synced: 6 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/lpil/storail
- Owner: lpil
- Created: 2024-10-19T13:59:13.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2024-12-22T19:42:58.000Z (20 days ago)
- Last Synced: 2025-01-02T15:46:02.595Z (9 days ago)
- Language: Gleam
- Size: 18.6 KB
- Stars: 15
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-gleam - storail - [π](https://hexdocs.pm/storail/) - A simple on-disc JSON based data store (Packages / Databases)
README
# StΓ³rΓ‘il
A simple on-disc JSON based data store.
[![Package Version](https://img.shields.io/hexpm/v/storail)](https://hex.pm/packages/storail)
[![Hex Docs](https://img.shields.io/badge/hex-docs-ffaff3)](https://hexdocs.pm/storail/)A super basic on-disc data store that uses JSON files to persist data.
It doesn't have transactions, MVCC, or anything like that. It's just
writing files to disc. Useful for tiny little projects, and for fun.```sh
gleam add storail@3
```
```gleam
import storail
import my_apppub fn main() {
// Construct config to specify where your data is written to.
let config = storail.Config(
data_directory: "/data",
temporary_directory: "/tmp/storail",
)// Define a collection for a data type in your application.
let cats = storail.Collection(
name: "cats",
to_json: my_app.cat_to_json,
decoder: my_app.cat_decoder(),
config:,
)// A key points to a specific object within the collection, which
// may or may not yet exist.
let key = storail.key(collection, "nubi")// Write some data
let assert Ok(Nil) = storail.write(key, my_app.Cat("Nubi", 5))// Read some data
storail.read(key)
// -> Ok(my_app.Cat("Nubi", 5))
}
```Further documentation can be found at .