2022-06-23 15:45:42 -06:00
# Codex Decentralized Durability Engine
2024-10-03 11:55:54 +03:00
> The Codex project aims to create a decentralized durability engine that allows persisting data in p2p networks. In other words, it allows storing files and data with predictable durability guarantees for later retrieval.
2022-06-23 15:45:42 -06:00
> WARNING: This project is under active development and is considered pre-alpha.
2022-05-10 15:41:44 -05:00
[data:image/s3,"s3://crabby-images/a516d/a516d1278a26f2cbf35ca5f2fd190bc7ae77db2c" alt="License: Apache "](https://opensource.org/licenses/Apache-2.0)
[data:image/s3,"s3://crabby-images/b1455/b1455f26652e09c18dbaaa3d95d217681d033c36" alt="License: MIT "](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/05ec7/05ec76b74ed613dfbc30c67f622716bcf4e01f5d" alt="Stability: experimental "](#stability )
2023-08-27 07:22:09 +03:00
[data:image/s3,"s3://crabby-images/c588e/c588eb7a49ae1b62f3142e4053c4c6b017c7158e" alt="CI "](https://github.com/codex-storage/nim-codex/actions/workflows/ci.yml?query=branch%3Amaster)
[data:image/s3,"s3://crabby-images/46568/465687321f5b1e295d4ef33d3be46f68e78ed460" alt="Docker "](https://github.com/codex-storage/nim-codex/actions/workflows/docker.yml?query=branch%3Amaster)
[data:image/s3,"s3://crabby-images/cca0c/cca0ca5f16cea3cbcfad51e7a04bbb04a9869450" alt="Codecov "](https://codecov.io/gh/codex-storage/nim-codex)
2022-06-23 15:45:42 -06:00
[data:image/s3,"s3://crabby-images/a9ae9/a9ae9bc6389fe87a7871960de83f4c5e90baa8a2" alt="Discord "](https://discord.gg/CaJTh24ddQ)
2023-08-27 07:22:09 +03:00
data:image/s3,"s3://crabby-images/b32e3/b32e335d1f73851f945f4fdec52e670655732ce1" alt="Docker Pulls "
2022-06-23 15:45:42 -06:00
## Build and Run
2024-09-29 17:38:57 +03:00
For detailed instructions on preparing to build nim-codex see [*Build Codex* ](https://docs.codex.storage/learn/build ).
2022-08-18 21:40:11 -05:00
2022-06-23 15:45:42 -06:00
To build the project, clone it and run:
```bash
2023-03-28 02:08:13 +02:00
make update & & make
2022-06-23 15:45:42 -06:00
```
2024-10-03 11:55:54 +03:00
The executable will be placed under the `build` directory under the project root.
2022-06-23 15:45:42 -06:00
Run the client with:
```bash
2022-08-18 21:40:11 -05:00
build/codex
2022-06-23 15:45:42 -06:00
```
2023-05-02 15:06:34 +02:00
## Configuration
It is possible to configure a Codex node in several ways:
1. CLI options
2024-10-03 11:55:54 +03:00
2. Environment variables
3. Configuration file
2023-05-02 15:06:34 +02:00
2024-10-03 11:55:54 +03:00
The order of priority is the same as above: CLI options --> Environment variables --> Configuration file.
2023-05-02 15:06:34 +02:00
2024-10-03 11:55:54 +03:00
Please check [documentation ](https://docs.codex.storage/learn/run#configuration ) for more information.
2023-05-02 15:06:34 +02:00
2024-10-03 11:55:54 +03:00
## Guides
2022-06-23 15:45:42 -06:00
2024-05-22 13:43:33 -03:00
To get acquainted with Codex, consider:
2024-10-03 11:55:54 +03:00
* running the simple [Codex Two-Client Test ](https://docs.codex.storage/learn/local-two-client-test ) for a start, and;
* if you are feeling more adventurous, try [Running a Local Codex Network with Marketplace Support ](https://docs.codex.storage/learn/local-marketplace ) using a local blockchain as well.
2022-06-23 15:45:42 -06:00
2023-03-29 14:55:17 +02:00
## API
2022-06-23 15:45:42 -06:00
2024-10-03 11:55:54 +03:00
The client exposes a REST API that can be used to interact with the clients. Overview of the API can be found on [api.codex.storage ](https://api.codex.storage ).