diff --git a/aquadoggo_cli/README.md b/aquadoggo_cli/README.md index 9468895e1..e3453ba32 100644 --- a/aquadoggo_cli/README.md +++ b/aquadoggo_cli/README.md @@ -31,7 +31,8 @@ application on any computer, single-board or server. ### Pre-compiled binaries -Check out our [Releases](/releases) section where we publish binaries for Linux, RaspberryPi, MacOS and Windows. +Check out our [Releases](/releases) section where we publish binaries for +Linux, RaspberryPi, MacOS and Windows. ### Compile it yourself @@ -74,13 +75,18 @@ aquadoggo --help ## Usage -`aquadoggo` is a powerful node implementation which can run in very different setups during development and in production. It can be configured through a [`config.toml`] file, environment variables and command line arguments, depending on your needs. +`aquadoggo` is a powerful node implementation which can run in very different +setups during development and in production. It can be configured through a +[`config.toml`] file, environment variables and command line arguments, +depending on your needs. ### Common setups #### Support only certain schemas -> "I want to run a node which only replicates and serves data from a limited set of schemas. In this case it's schemas required by a mushroom sighting app." +> "I want to run a node which only replicates and serves data from a limited +> set of schemas. In this case it's schemas required by a mushroom sighting +> app." ```toml allow_schema_ids = [ @@ -91,11 +97,13 @@ allow_schema_ids = [ #### Support all schemas but restrict allowed peers -> "Me and my friends are running our own `p2panda` network supported by a couple of relay nodes, we trust each other and want to support all published data, but not allow anyone else to join the network." +> "Me and my friends are running our own `p2panda` network supported by a +> couple of relay nodes, we trust each other and want to support all published +> data, but not allow anyone else to join the network." ```toml -# I can do this by configuring `allow_schema_ids` to be a wildcard, meaning any schema -# are automatically supported! +# I can do this by configuring `allow_schema_ids` to be a wildcard, meaning any +# schema are automatically supported! allow_schema_ids = "*" # Add relay addresses to allow establishing connections over the internet @@ -107,8 +115,8 @@ relay_addresses = [ # Enable discovery using mDNS (true by default) mdns = true -# Populate an allow list which will contain the peer ids of our friends (including -# the ones acting as relays) +# Populate an allow list which will contain the peer ids of our friends +# (including the ones acting as relays) allow_peer_ids = [ "12D3KooWLxGKMgUtekXam9JsSjMa3b7M3rYEYUYUywdehHTRrLgU", "12D3KooWP1ahRHeNp6s1M9qDJD2oyqRsYFeKLYjcjmFxrq6KM8xd", @@ -117,11 +125,12 @@ allow_peer_ids = [ #### Act as a relay node -> "I want to deploy a relay which assists in connecting edge peers but doesn't persist any data itself." +> "I want to deploy a relay which assists in connecting edge peers but doesn't +> persist any data itself." ```toml -# I can do this by configuring `allow_schema_ids` an empty list, meaning this node -# does not support any schemas +# I can do this by configuring `allow_schema_ids` an empty list, meaning this +# node does not support any schemas allow_schema_ids = [] # Then set the relay flag so this node behaves as a relay for other nodes @@ -147,7 +156,8 @@ direct_node_addresses = [ #### Persist node identity and database -> "I want my node to persist it's identity and database on the filesystem and retreive them whenever it runs again." +> "I want my node to persist it's identity and database on the filesystem and +> retreive them whenever it runs again." ```toml # Persist node private key at given location (using Linux XDG paths as an example) @@ -159,7 +169,10 @@ database_url = "sqlite:$HOME/.local/share/aquadoggo/db.sqlite3" ### Configuration -Check out the [`config.toml`] file for all configurations and documentation or run `--help` to see all possible command line arguments. All values can also be defined as environment variables, written in CAMEL_CASE (for example `HTTP_PORT=3000`). +Check out the [`config.toml`] file for all configurations and documentation or +run `--help` to see all possible command line arguments. All values can also be +defined as environment variables, written in CAMEL_CASE (for example +`HTTP_PORT=3000`). ``` Usage: aquadoggo [OPTIONS] @@ -168,36 +181,57 @@ Options: -c, --config Path to an optional "config.toml" file for further configuration. - When not set the program will try to find a `config.toml` file in the same folder the program is executed in and otherwise in the regarding operation systems XDG config directory ("$HOME/.config/aquadoggo/config.toml" on Linux). + When not set the program will try to find a `config.toml` file in the + same folder the program is executed in and otherwise in the regarding + operation systems XDG config directory + ("$HOME/.config/aquadoggo/config.toml" on Linux). -s, --allow-schema-ids [...] - List of schema ids which a node will replicate, persist and expose on the GraphQL API. Separate multiple values with a whitespace. Defaults to allow _any_ schemas ("*"). + List of schema ids which a node will replicate, persist and expose on + the GraphQL API. Separate multiple values with a whitespace. Defaults + to allow _any_ schemas ("*"). - When allowing a schema you automatically opt into announcing, replicating and materializing documents connected to it, supporting applications and networks which are dependent on this data. + When allowing a schema you automatically opt into announcing, + replicating and materializing documents connected to it, supporting + applications and networks which are dependent on this data. - It is recommended to set this list to all schema ids your own application should support, including all important system schemas. + It is recommended to set this list to all schema ids your own + application should support, including all important system schemas. - WARNING: When set to wildcard "*", your node will support _any_ schemas it will encounter on the network. This is useful for experimentation and local development but _not_ recommended for production settings. + WARNING: When set to wildcard "*", your node will support _any_ + schemas it will encounter on the network. This is useful for + experimentation and local development but _not_ recommended for + production settings. -d, --database-url - URL / connection string to PostgreSQL or SQLite database. Defaults to an in-memory SQLite database. + URL / connection string to PostgreSQL or SQLite database. Defaults to + an in-memory SQLite database. - WARNING: By default your node will not persist anything after shutdown. Set a database connection url for production settings to not loose data. + WARNING: By default your node will not persist anything after + shutdown. Set a database connection url for production settings to + not loose data. -p, --http-port - HTTP port for client-node communication, serving the GraphQL API. Defaults to 2020 + HTTP port for client-node communication, serving the GraphQL API. + Defaults to 2020 -q, --quic-port - QUIC port for node-node communication and data replication. Defaults to 2022 + QUIC port for node-node communication and data replication. Defaults + to 2022 -k, --private-key - Path to persist your ed25519 private key file. Defaults to an ephemeral key only for this current session. + Path to persist your ed25519 private key file. Defaults to an + ephemeral key only for this current session. - The key is used to identify you towards other nodes during network discovery and replication. This key is _not_ used to create and sign data. + The key is used to identify you towards other nodes during network + discovery and replication. This key is _not_ used to create and sign + data. - If a path is set, a key will be generated newly and stored under this path when node starts for the first time. + If a path is set, a key will be generated newly and stored under this + path when node starts for the first time. - When no path is set, your node will generate an ephemeral private key on every start up and _not_ persist it. + When no path is set, your node will generate an ephemeral private key + on every start up and _not_ persist it. -m, --mdns [] mDNS to discover other peers on the local network. Enabled by default @@ -207,48 +241,74 @@ Options: -n, --direct-node-addresses [...] List of known node addresses we want to connect to directly. - Make sure that nodes mentioned in this list are directly reachable (they need to be hosted with a static IP Address). If you need to connect to nodes with changing, dynamic IP addresses or even with nodes behind a firewall or NAT, do not use this field but use at least one relay. + Make sure that nodes mentioned in this list are directly reachable + (they need to be hosted with a static IP Address). If you need to + connect to nodes with changing, dynamic IP addresses or even with + nodes behind a firewall or NAT, do not use this field but use at + least one relay. -a, --allow-peer-ids [...] List of peers which are allowed to connect to your node. - If set then only nodes (identified by their peer id) contained in this list will be able to connect to your node (via a relay or directly). When not set any other node can connect to yours. + If set then only nodes (identified by their peer id) contained in + this list will be able to connect to your node (via a relay or + directly). When not set any other node can connect to yours. - Peer IDs identify nodes by using their hashed public keys. They do _not_ represent authored data from clients and are only used to authenticate nodes towards each other during networking. + Peer IDs identify nodes by using their hashed public keys. They do + _not_ represent authored data from clients and are only used to + authenticate nodes towards each other during networking. - Use this list for example for setups where the identifier of the nodes you want to form a network with is known but you still need to use relays as their IP addresses change dynamically. + Use this list for example for setups where the identifier of the + nodes you want to form a network with is known but you still need to + use relays as their IP addresses change dynamically. -b, --block-peer-ids [...] List of peers which will be blocked from connecting to your node. - If set then any peers (identified by their peer id) contained in this list will be blocked from connecting to your node (via a relay or directly). When an empty list is provided then there are no restrictions on which nodes can connect to yours. + If set then any peers (identified by their peer id) contained in this + list will be blocked from connecting to your node (via a relay or + directly). When an empty list is provided then there are no + restrictions on which nodes can connect to yours. - Block lists and allow lists are exclusive, which means that you should _either_ use a block list _or_ an allow list depending on your setup. + Block lists and allow lists are exclusive, which means that you + should _either_ use a block list _or_ an allow list depending on your + setup. - Use this list for example if you want to allow _any_ node to connect to yours _except_ of a known number of excluded nodes. + Use this list for example if you want to allow _any_ node to connect + to yours _except_ of a known number of excluded nodes. -r, --relay-addresses [...] List of relay addresses. - A relay helps discover other nodes on the internet (also known as "rendesvouz" or "bootstrap" server) and helps establishing direct p2p connections when node is behind a firewall or NAT (also known as "holepunching"). + A relay helps discover other nodes on the internet (also known as + "rendesvouz" or "bootstrap" server) and helps establishing direct p2p + connections when node is behind a firewall or NAT (also known as + "holepunching"). - WARNING: This will potentially expose your IP address on the network. Do only connect to trusted relays or make sure your IP address is hidden via a VPN or proxy if you're concerned about leaking your IP. + WARNING: This will potentially expose your IP address on the network. + Do only connect to trusted relays or make sure your IP address is + hidden via a VPN or proxy if you're concerned about leaking your IP. -e, --relay-mode [] Enable if node should also function as a relay. Disabled by default. Other nodes can use relays to aid discovery and establishing connectivity. - Relays _need_ to be hosted in a way where they can be reached directly, for example with a static IP address through an VPS. + Relays _need_ to be hosted in a way where they can be reached + directly, for example with a static IP address through an VPS. [possible values: true, false] -l, --log-level - Set log verbosity. Use this for learning more about how your node behaves or for debugging. + Set log verbosity. Use this for learning more about how your node + behaves or for debugging. - Possible log levels are: ERROR, WARN, INFO, DEBUG, TRACE. They are scoped to "aquadoggo" by default. + Possible log levels are: ERROR, WARN, INFO, DEBUG, TRACE. They are + scoped to "aquadoggo" by default. - If you want to adjust the scope for deeper inspection use a filter value, for example "=TRACE" for logging _everything_ or "aquadoggo=INFO,libp2p=DEBUG" etc. + If you want to adjust the scope for deeper inspection use a filter + value, for example "=TRACE" for logging _everything_ or + "aquadoggo=INFO,libp2p=DEBUG" etc. -h, --help Print help (see a summary with '-h')