28 releases

0.7.7 Dec 18, 2024
0.7.5 Nov 8, 2024
0.6.8 Jul 31, 2024
0.5.0 Mar 5, 2024
0.3.1 Nov 10, 2023

#1668 in Cryptography

Download history 169/week @ 2024-09-13 85/week @ 2024-09-20 211/week @ 2024-09-27 15/week @ 2024-10-04 112/week @ 2024-10-11 133/week @ 2024-10-18 46/week @ 2024-10-25 10/week @ 2024-11-01 119/week @ 2024-11-08 8/week @ 2024-11-15 3/week @ 2024-11-22 4/week @ 2024-11-29 44/week @ 2024-12-06 242/week @ 2024-12-13 21/week @ 2024-12-20

308 downloads per month
Used in nuts-archive

MIT license

72KB
926 lines

nuts-directory: Nuts backend implementation

Introduction

The nuts-directory crate implements a nuts backend where the blocks of the container are stored in a file hierarchy. Each block is identified by an id, which is basically a 16 byte random number.

When storing a block to disks the path to the file is derived from the id:

  1. The id is converted into a hex string.
  2. The path then would be: <first two chars>/<next two chars>/<remaining chars>

The header of the container is stored in the file 00/00/0000000000000000000000000000. Nuts backend implementation where the blocks of the container are stored in a file hierarchy.

Create a new backend instance

The CreateOptions type is used to create a new backend instance, which is passed to the Container::create method. You need at least a directory where the backend put its blocks. See the CreateOptions documentation for further options.

Open an existing backend

The OpenOptions type is used to open a backend instance, which is passed to the Container::open method. You need the directory where the backend put its blocks.

License

You can check out the full license here.

This project is licensed under the terms of the MIT license.

Dependencies

~0.1–8MB
~63K SLoC