diff options
| -rw-r--r-- | src/main.rs | 33 |
1 files changed, 28 insertions, 5 deletions
diff --git a/src/main.rs b/src/main.rs index be109d0..595ce3b 100644 --- a/src/main.rs +++ b/src/main.rs | |||
| @@ -1,25 +1,48 @@ | |||
| 1 | //! # Gradecoin | 1 | //! # Services |
| 2 | //! | 2 | //! |
| 3 | //! ## Services | 3 | //! All of these endpoints will be served with the URL prefix of a given network. |
| 4 | //! ### /register | 4 | //! For example, if URL prefix is `testnet`, `/register` is found at `/testnet/register`. |
| 5 | //! | ||
| 6 | //! ## /register | ||
| 5 | //! - Student creates their own 2048 bit RSA `keypair` | 7 | //! - Student creates their own 2048 bit RSA `keypair` |
| 6 | //! - Downloads `Gradecoin`'s Public Key from Moodle | 8 | //! - Downloads `Gradecoin`'s Public Key from Moodle |
| 7 | //! - Encrypts their JSON wrapped `Public Key` and `Student ID` using Gradecoin's Public Key | 9 | //! - Encrypts their JSON wrapped `Public Key` and `Student ID` using Gradecoin's Public Key |
| 8 | //! - Their public key is now in our Db under [`block::User::public_key`] and can be used to sign their JWT's during requests | 10 | //! - Their public key is now in our Db under [`block::User::public_key`] and can be used to sign their JWT's during requests |
| 9 | //! | 11 | //! |
| 10 | //! ### /transaction | 12 | //! ## /transaction |
| 11 | //! - offer a [`block::Transaction`] - POST request | 13 | //! - offer a [`block::Transaction`] - POST request |
| 12 | //! - The request should have `Authorization` | 14 | //! - The request should have `Authorization` |
| 13 | //! - The request header should be signed by the Public Key of the `by` field in the transaction | 15 | //! - The request header should be signed by the Public Key of the `by` field in the transaction |
| 14 | //! - fetch the list of `Transaction`s - GET request | 16 | //! - fetch the list of `Transaction`s - GET request |
| 15 | //! | 17 | //! |
| 16 | //! ### /block | 18 | //! ## /block |
| 17 | //! - offer a [`block::Block`] - POST request | 19 | //! - offer a [`block::Block`] - POST request |
| 18 | //! - The request should have `Authorization` | 20 | //! - The request should have `Authorization` |
| 19 | //! - The [`block::Block::transaction_list`] of the block should be a subset of [`block::Db::pending_transactions`] | 21 | //! - The [`block::Block::transaction_list`] of the block should be a subset of [`block::Db::pending_transactions`] |
| 20 | //! - fetch the last accepted [`block::Block`] - GET request | 22 | //! - fetch the last accepted [`block::Block`] - GET request |
| 21 | //! | 23 | //! |
| 22 | //! `Authorization`: The request header should have Bearer JWT.Token signed with Student Public Key | 24 | //! `Authorization`: The request header should have Bearer JWT.Token signed with Student Public Key |
| 25 | //! | ||
| 26 | //! ## /config | ||
| 27 | //! - Get the current [`config::Config`] as JSON - GET request | ||
| 28 | //! | ||
| 29 | //! # Configuration | ||
| 30 | //! | ||
| 31 | //! The default configuration file if `config.yaml`, which will run if no command line arguments are given. | ||
| 32 | //! | ||
| 33 | //! You can give one or more configuration files as command line arguments. | ||
| 34 | //! This will run all of them at the same time. | ||
| 35 | //! Make sure that the names and URL prefixes don't clash, otherwise it will lead to undefined behavior. | ||
| 36 | //! | ||
| 37 | //! Example: | ||
| 38 | //! ```sh | ||
| 39 | //! # Run both the main network (at /) and testnet (at /testnet) | ||
| 40 | //! # For example, register for main network at `localhost:8080/register`, | ||
| 41 | //! # testnet network at `localhost:8080/testnet/register` | ||
| 42 | //! $ cargo run config.yaml testnet.yaml | ||
| 43 | //! ``` | ||
| 44 | //! | ||
| 45 | //! See [`config::Config`] struct for more information about the configurable fields. | ||
| 23 | #![warn(clippy::all, clippy::pedantic)] | 46 | #![warn(clippy::all, clippy::pedantic)] |
| 24 | #![allow(clippy::unused_async)] | 47 | #![allow(clippy::unused_async)] |
| 25 | 48 | ||
