change(docs): Replace doc.zebra.zfnd.org API documentation with docs.rs (#7886)

* Simple replacements of doc.zebra.zfnd.org with docs.rs

* Manual fixes for specific main/internal/external docs

* Point developer docs to doc-internal.zebra.zfnd.org

* fastmod --glob '\!.git' -- doc.zebra.zfnd.org/zebrad docs.rs/zebrad/latest/zebrad

* Manually remove any remaining doc.zfnd.zebra.org links

* Remove the external docs job

* Add changelog entry and fix links

* Fix links that were broken before this PR
This commit is contained in:
teor 2023-11-02 08:09:40 +10:00 committed by GitHub
parent daabe8b196
commit afbe807060
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
45 changed files with 96 additions and 140 deletions

View File

@ -27,13 +27,6 @@ jobs:
steps: steps:
- run: 'echo "No build required"' - run: 'echo "No build required"'
build-docs-external:
name: Build and Deploy Zebra External Docs
timeout-minutes: 45
runs-on: ubuntu-latest
steps:
- run: 'echo "No build required"'
build-docs-internal: build-docs-internal:
name: Build and Deploy Zebra Internal Docs name: Build and Deploy Zebra Internal Docs
timeout-minutes: 45 timeout-minutes: 45

View File

@ -114,62 +114,6 @@ jobs:
projectId: ${{ vars.GCP_FIREBASE_PROJECT }} projectId: ${{ vars.GCP_FIREBASE_PROJECT }}
target: docs-book target: docs-book
build-docs-external:
name: Build and Deploy Zebra External Docs
timeout-minutes: 45
runs-on: ubuntu-latest
permissions:
checks: write
contents: 'read'
id-token: 'write'
pull-requests: write
steps:
- name: Checkout the source code
uses: actions/checkout@v4.1.1
with:
persist-credentials: false
- name: Install last version of Protoc
uses: arduino/setup-protoc@v2.1.0
with:
version: '23.x'
repo-token: ${{ secrets.GITHUB_TOKEN }}
# Setup Rust with beta toolchain and default profile (to include rust-docs)
- name: Setup Rust
run: |
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --default-toolchain=beta --profile=default
- uses: Swatinem/rust-cache@v2.7.1
- name: Build external docs
run: |
# Exclude zebra-utils and zebra-test, they are not for library or app users
cargo doc --no-deps --workspace --all-features --exclude zebra-utils --exclude zebra-test --target-dir "$(pwd)"/target/external
# Setup gcloud CLI
- name: Authenticate to Google Cloud
id: auth
uses: google-github-actions/auth@v1.1.1
with:
retries: '3'
workload_identity_provider: '${{ vars.GCP_WIF }}'
service_account: '${{ vars.GCP_FIREBASE_SA }}'
# TODO: remove this step after issue https://github.com/FirebaseExtended/action-hosting-deploy/issues/174 is fixed
- name: Add $GCP_FIREBASE_SA_PATH to env
run: |
# shellcheck disable=SC2002
echo "GCP_FIREBASE_SA_PATH=$(cat ${{ steps.auth.outputs.credentials_file_path }} | tr -d '\n')" >> "$GITHUB_ENV"
- name: Deploy external docs to firebase
uses: FirebaseExtended/action-hosting-deploy@v0.7.1
with:
firebaseServiceAccount: ${{ env.GCP_FIREBASE_SA_PATH }}
channelId: ${{ env.FIREBASE_CHANNEL }}
target: docs-external
projectId: ${{ vars.GCP_FIREBASE_PROJECT }}
build-docs-internal: build-docs-internal:
name: Build and Deploy Zebra Internal Docs name: Build and Deploy Zebra Internal Docs
timeout-minutes: 45 timeout-minutes: 45

View File

@ -44,6 +44,17 @@ so it can't be used to retry failed downloads in `zebrad` 1.3.0 and earlier.
We recommend upgrading to the latest Zebra release to avoid download issues in new installs. We recommend upgrading to the latest Zebra release to avoid download issues in new installs.
### Documentation Website Change
We have replaced the API documentation on the [doc.zebra.zfnd.org](https://doc.zebra.zfnd.org)
website with [docs.rs](https://docs.rs/releases/search?query=zebra). All links have been updated.
Zebra's API documentation can be found on:
- [`docs.rs`](https://docs.rs/releases/search?query=zebra), which renders documentation for the
public API of the latest crate releases;
- [`doc-internal.zebra.zfnd.org`](https://doc-internal.zebra.zfnd.org/), which renders
documentation for the internal API on the `main` branch.
### Security ### Security
TODO: rest of changelog TODO: rest of changelog
@ -996,12 +1007,12 @@ When there are a lot of large user-generated transactions on the network, Zebra
### Configuration Changes ### Configuration Changes
- Split the checkpoint and full verification [`sync` concurrency options](https://doc.zebra.zfnd.org/zebrad/config/struct.SyncSection.html) (#4726, #4758): - Split the checkpoint and full verification [`sync` concurrency options](https://docs.rs/zebrad/latest/zebrad/components/sync/struct.Config.html) (#4726, #4758):
- Add a new `full_verify_concurrency_limit` - Add a new `full_verify_concurrency_limit`
- Rename `max_concurrent_block_requests` to `download_concurrency_limit` - Rename `max_concurrent_block_requests` to `download_concurrency_limit`
- Rename `lookahead_limit` to `checkpoint_verify_concurrency_limit` - Rename `lookahead_limit` to `checkpoint_verify_concurrency_limit`
For backwards compatibility, the old names are still accepted as aliases. For backwards compatibility, the old names are still accepted as aliases.
- Add a new `parallel_cpu_threads` [`sync` concurrency option](https://doc.zebra.zfnd.org/zebrad/config/struct.SyncSection.html) (#4776). - Add a new `parallel_cpu_threads` [`sync` concurrency option](https://docs.rs/zebrad/latest/zebrad/components/sync/struct.Config.html) (#4776).
This option sets the number of threads to use for CPU-bound tasks, such as proof and signature verification. This option sets the number of threads to use for CPU-bound tasks, such as proof and signature verification.
By default, Zebra uses all available CPU cores. By default, Zebra uses all available CPU cores.

View File

@ -27,7 +27,7 @@ consensus-compatible implementation of a Zcash node.
Zebra's network stack is interoperable with `zcashd`, and Zebra implements all Zebra's network stack is interoperable with `zcashd`, and Zebra implements all
the features required to reach Zcash network consensus, including the validation the features required to reach Zcash network consensus, including the validation
of all the consensus rules for the NU5 network upgrade. of all the consensus rules for the NU5 network upgrade.
[Here](https://doc.zebra.zfnd.org/zebrad/index.html#zebra-advantages) are some [Here](https://docs.rs/zebrad/latest/zebrad/index.html#zebra-advantages) are some
benefits of Zebra. benefits of Zebra.
Zebra validates blocks and transactions, but needs extra software to generate Zebra validates blocks and transactions, but needs extra software to generate
@ -148,8 +148,7 @@ You can combine multiple features by listing them as parameters of the `--featur
cargo install --features="<feature1> <feature2> ..." ... cargo install --features="<feature1> <feature2> ..." ...
``` ```
Our full list of experimental and developer features is in [the API Our full list of experimental and developer features is in [the API documentation](https://docs.rs/zebrad/latest/zebrad/index.html#zebra-feature-flags).
documentation](https://doc.zebra.zfnd.org/zebrad/index.html#zebra-feature-flags).
Some debugging and monitoring features are disabled in release builds to increase Some debugging and monitoring features are disabled in release builds to increase
performance. performance.
@ -176,10 +175,12 @@ We will continue to add new features as part of future network upgrades, and in
The [Zebra website](https://zebra.zfnd.org/) contains user documentation, such The [Zebra website](https://zebra.zfnd.org/) contains user documentation, such
as how to run or configure Zebra, set up metrics integrations, etc., as well as as how to run or configure Zebra, set up metrics integrations, etc., as well as
developer documentation, such as design documents. We also render [API developer documentation, such as design documents. It also renders
documentation](https://doc.zebra.zfnd.org) for the external API of our crates, [internal documentation](https://doc-internal.zebra.zfnd.org) for private APIs
as well as [internal documentation](https://doc-internal.zebra.zfnd.org) for on the `main` branch.
private APIs.
`docs.rs` renders [API documentation](https://docs.rs/releases/search?query=zebra)
for the external API of the latest releases of our crates.
## User support ## User support

View File

@ -2,5 +2,7 @@
Zebra's API documentation is generated using Rustdoc: Zebra's API documentation is generated using Rustdoc:
- [`doc.zebra.zfnd.org`](https://doc.zebra.zfnd.org/) renders documentation for the public API; - [`docs.rs`](https://docs.rs/releases/search?query=zebra) renders documentation for the public API
- [`doc-internal.zebra.zfnd.org`](https://doc-internal.zebra.zfnd.org/) renders documentation for the internal API. of the latest crate releases;
- [`doc-internal.zebra.zfnd.org`](https://doc-internal.zebra.zfnd.org/) renders documentation for
the internal API on the `main` branch.

View File

@ -3,5 +3,7 @@
This section contains the contribution guide and design documentation. It This section contains the contribution guide and design documentation. It
does not contain API documentation, which is generated using Rustdoc: does not contain API documentation, which is generated using Rustdoc:
- [`doc.zebra.zfnd.org`](https://doc.zebra.zfnd.org/) renders documentation for the public API; - [`docs.rs`](https://docs.rs/releases/search?query=zebra) renders documentation for the public API
- [`doc-internal.zebra.zfnd.org`](https://doc-internal.zebra.zfnd.org/) renders documentation for the internal API. of the latest crate releases;
- [`doc-internal.zebra.zfnd.org`](https://doc-internal.zebra.zfnd.org/) renders documentation for
the internal API on the `main` branch.

View File

@ -86,7 +86,7 @@ other functionality, without requiring a full node.
At a high level, the fullnode functionality required by `zebrad` is factored At a high level, the fullnode functionality required by `zebrad` is factored
into several components: into several components:
- [`zebra-chain`](https://doc.zebra.zfnd.org/zebra_chain/index.html), providing - [`zebra-chain`](https://docs.rs/zebra_chain), providing
definitions of core data structures for Zcash, such as blocks, transactions, definitions of core data structures for Zcash, such as blocks, transactions,
addresses, etc., and related functionality. It also contains the addresses, etc., and related functionality. It also contains the
implementation of the consensus-critical serialization formats used in Zcash. implementation of the consensus-critical serialization formats used in Zcash.
@ -100,7 +100,7 @@ into several components:
towards verifying transactions, but will be extended to support creating them towards verifying transactions, but will be extended to support creating them
in the future. in the future.
- [`zebra-network`](https://doc.zebra.zfnd.org/zebra_network/index.html), - [`zebra-network`](https://docs.rs/zebra_network),
providing an asynchronous, multithreaded implementation of the Zcash network providing an asynchronous, multithreaded implementation of the Zcash network
protocol inherited from Bitcoin. In contrast to `zcashd`, each peer protocol inherited from Bitcoin. In contrast to `zcashd`, each peer
connection has a separate state machine, and the crate translates the connection has a separate state machine, and the crate translates the
@ -113,21 +113,21 @@ into several components:
isolated from all other node state. This can be used, for instance, to isolated from all other node state. This can be used, for instance, to
safely relay data over Tor, without revealing distinguishing information. safely relay data over Tor, without revealing distinguishing information.
- [`zebra-script`](https://doc.zebra.zfnd.org/zebra_script/index.html) provides - [`zebra-script`](https://docs.rs/zebra_script) provides
script validation. Currently, this is implemented by linking to the C++ script validation. Currently, this is implemented by linking to the C++
script verification code from `zcashd`, but in the future we may implement a script verification code from `zcashd`, but in the future we may implement a
pure-Rust script implementation. pure-Rust script implementation.
- [`zebra-consensus`](https://doc.zebra.zfnd.org/zebra_consensus/index.html) - [`zebra-consensus`](https://docs.rs/zebra_consensus)
performs [*semantic validation*](https://zebra.zfnd.org/dev/rfcs/0002-parallel-verification.html#verification-stages) performs [*semantic validation*](https://zebra.zfnd.org/dev/rfcs/0002-parallel-verification.html#verification-stages)
of blocks and transactions: all consensus of blocks and transactions: all consensus
rules that can be checked independently of the chain state, such as rules that can be checked independently of the chain state, such as
verification of signatures, proofs, and scripts. Internally, the library verification of signatures, proofs, and scripts. Internally, the library
uses [`tower-batch-control`](https://doc.zebra.zfnd.org/tower_batch_control/index.html) to uses [`tower-batch-control`](https://docs.rs/tower_batch_control) to
perform automatic, transparent batch processing of contemporaneous perform automatic, transparent batch processing of contemporaneous
verification requests. verification requests.
- [`zebra-state`](https://doc.zebra.zfnd.org/zebra_state/index.html) is - [`zebra-state`](https://docs.rs/zebra_state) is
responsible for storing, updating, and querying the chain state. The state responsible for storing, updating, and querying the chain state. The state
service is responsible for [*contextual verification*](https://zebra.zfnd.org/dev/rfcs/0002-parallel-verification.html#verification-stages): service is responsible for [*contextual verification*](https://zebra.zfnd.org/dev/rfcs/0002-parallel-verification.html#verification-stages):
all consensus rules all consensus rules
@ -135,7 +135,7 @@ into several components:
such as updating the nullifier set or checking that transaction inputs remain such as updating the nullifier set or checking that transaction inputs remain
unspent. unspent.
- [`zebrad`](https://doc.zebra.zfnd.org/zebrad/index.html) contains the full - [`zebrad`](https://docs.rs/zebrad) contains the full
node, which connects these components together and implements logic to handle node, which connects these components together and implements logic to handle
inbound requests from peers and the chain sync process. inbound requests from peers and the chain sync process.

View File

@ -31,11 +31,11 @@ and in parallel on a thread pool.
- unlock script: a script satisfying the conditions of the lock script, allowing a UTXO to be spent. - unlock script: a script satisfying the conditions of the lock script, allowing a UTXO to be spent.
Stored in the [`transparent::Input::PrevOut::lock_script`][lock_script] field. Stored in the [`transparent::Input::PrevOut::lock_script`][lock_script] field.
[transout]: https://doc.zebra.zfnd.org/zebra_chain/transparent/struct.Output.html [transout]: https://doc-internal.zebra.zfnd.org/zebra_chain/transparent/struct.Output.html
[outpoint]: https://doc.zebra.zfnd.org/zebra_chain/transparent/struct.OutPoint.html [outpoint]: https://doc-internal.zebra.zfnd.org/zebra_chain/transparent/struct.OutPoint.html
[lock_script]: https://doc.zebra.zfnd.org/zebra_chain/transparent/struct.Output.html#structfield.lock_script [lock_script]: https://doc-internal.zebra.zfnd.org/zebra_chain/transparent/struct.Output.html#structfield.lock_script
[transin]: https://doc.zebra.zfnd.org/zebra_chain/transparent/enum.Input.html [transin]: https://doc-internal.zebra.zfnd.org/zebra_chain/transparent/enum.Input.html
[unlock_script]: https://doc.zebra.zfnd.org/zebra_chain/transparent/enum.Input.html#variant.PrevOut.field.unlock_script [unlock_script]: https://doc-internal.zebra.zfnd.org/zebra_chain/transparent/enum.Input.html#variant.PrevOut.field.unlock_script
# Guide-level explanation # Guide-level explanation

View File

@ -713,9 +713,9 @@ validation and the anchor calculations.)
Hypothetically, if Sapling were activated from genesis, the specification requires Hypothetically, if Sapling were activated from genesis, the specification requires
a Sapling anchor, but `zcashd` would ignore that anchor. a Sapling anchor, but `zcashd` would ignore that anchor.
[`JoinSplit`]: https://doc.zebra.zfnd.org/zebra_chain/sprout/struct.JoinSplit.html [`JoinSplit`]: https://doc-internal.zebra.zfnd.org/zebra_chain/sprout/struct.JoinSplit.html
[`Spend`]: https://doc.zebra.zfnd.org/zebra_chain/sapling/spend/struct.Spend.html [`Spend`]: https://doc-internal.zebra.zfnd.org/zebra_chain/sapling/spend/struct.Spend.html
[`Action`]: https://doc.zebra.zfnd.org/zebra_chain/orchard/struct.Action.html [`Action`]: https://doc-internal.zebra.zfnd.org/zebra_chain/orchard/struct.Action.html
These updates can be performed in a batch or without necessarily iterating These updates can be performed in a batch or without necessarily iterating
over all transactions, if the data is available by other means; they're over all transactions, if the data is available by other means; they're

View File

@ -55,7 +55,7 @@ parallel_cpu_threads = 0
``` ```
**WARNING:** This config allows multiple Zebra instances to share the same RPC port. **WARNING:** This config allows multiple Zebra instances to share the same RPC port.
See the [RPC config documentation](https://doc.zebra.zfnd.org/zebra_rpc/config/struct.Config.html) for details. See the [RPC config documentation](https://docs.rs/zebra_rpc/latest/zebra_rpc/config/struct.Config.html) for details.
## Sync Zebra ## Sync Zebra
@ -71,7 +71,7 @@ Zebra will display information about sync process:
```console ```console
... ...
zebrad::commands::start: estimated progress to chain tip sync_percent=10.783 % zebrad::commands::start: estimated progress to chain tip sync_percent=10.783 %
... ...
``` ```
@ -79,13 +79,13 @@ Until eventually it will get there:
```console ```console
... ...
zebrad::commands::start: finished initial sync to chain tip, using gossiped blocks sync_percent=100.000 % zebrad::commands::start: finished initial sync to chain tip, using gossiped blocks sync_percent=100.000 %
... ...
``` ```
You can interrupt the process at any time with `ctrl-c` and Zebra will resume the next time at around the block you were downloading when stopping the process. You can interrupt the process at any time with `ctrl-c` and Zebra will resume the next time at around the block you were downloading when stopping the process.
When deploying for production infrastructure, the above command can/should be implemented as a server service or similar configuration. When deploying for production infrastructure, the above command can be run as a service or daemon.
For implementing zebra as a service please see [here](https://github.com/ZcashFoundation/zebra/blob/main/zebrad/systemd/zebrad.service). For implementing zebra as a service please see [here](https://github.com/ZcashFoundation/zebra/blob/main/zebrad/systemd/zebrad.service).
@ -144,7 +144,7 @@ Wait until lightwalletd is in sync before connecting any wallet into it. You wil
## Run tests ## Run tests
[#run-tests]: (#run-tests) [#run-tests]: (#run-tests)
The Zebra team created tests for the interaction of `zebrad` and `lightwalletd`. The Zebra team created tests for the interaction of `zebrad` and `lightwalletd`.
To run all the Zebra `lightwalletd` tests: To run all the Zebra `lightwalletd` tests:
1. install `lightwalletd` 1. install `lightwalletd`
@ -156,7 +156,7 @@ Please refer to [acceptance](https://github.com/ZcashFoundation/zebra/blob/main/
## Connect a wallet to lightwalletd ## Connect a wallet to lightwalletd
[#connect-wallet-to-lightwalletd]: (#connect-wallet-to-lightwalletd) [#connect-wallet-to-lightwalletd]: (#connect-wallet-to-lightwalletd)
The final goal is to connect wallets to the lightwalletd service backed by Zebra. The final goal is to connect wallets to the lightwalletd service backed by Zebra.
For demo purposes we used [zecwallet-cli](https://github.com/adityapk00/zecwallet-light-cli) with the [adityapk00/lightwalletd](https://github.com/adityapk00/lightwalletd) fork. For demo purposes we used [zecwallet-cli](https://github.com/adityapk00/zecwallet-light-cli) with the [adityapk00/lightwalletd](https://github.com/adityapk00/lightwalletd) fork.
We didn't test [zecwallet-cli](https://github.com/adityapk00/zecwallet-light-cli) with [zcash/lightwalletd](https://github.com/zcash/lightwalletd) yet. We didn't test [zecwallet-cli](https://github.com/adityapk00/zecwallet-light-cli) with [zcash/lightwalletd](https://github.com/zcash/lightwalletd) yet.
@ -184,5 +184,5 @@ Lightclient connecting to http://127.0.0.1:9067/
"total_blocks_synced": 49476 "total_blocks_synced": 49476
} }
Ready! Ready!
(main) Block:1683911 (type 'help') >> (main) Block:1683911 (type 'help') >>
``` ```

View File

@ -56,4 +56,4 @@ front end that you can visualize:
![image info](grafana.png) ![image info](grafana.png)
[metrics_section]: https://doc.zebra.zfnd.org/zebrad/config/struct.MetricsSection.html [metrics_section]: https://docs.rs/zebrad/latest/zebrad/components/metrics/struct.Config.html

View File

@ -31,7 +31,7 @@ Zebra uses the following inbound and outbound TCP ports:
- 18233 on Testnet - 18233 on Testnet
If you configure Zebra with a specific If you configure Zebra with a specific
[`listen_addr`](https://doc.zebra.zfnd.org/zebra_network/struct.Config.html#structfield.listen_addr), [`listen_addr`](https://docs.rs/zebra_network/latest/zebra_network/struct.Config.html#structfield.listen_addr),
it will advertise this address to other nodes for inbound connections. Outbound it will advertise this address to other nodes for inbound connections. Outbound
connections are required to sync, inbound connections are optional. Zebra also connections are required to sync, inbound connections are optional. Zebra also
needs access to the Zcash DNS seeders, via the OS DNS resolver (usually port needs access to the Zcash DNS seeders, via the OS DNS resolver (usually port

View File

@ -7,7 +7,7 @@ changing the config.
The configuration format is the TOML encoding of the internal config The configuration format is the TOML encoding of the internal config
structure, and documentation for all of the config options can be found structure, and documentation for all of the config options can be found
[here](https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html). [here](https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html).
- `zebrad start` starts a full node. - `zebrad start` starts a full node.

View File

@ -27,7 +27,7 @@ Some important parts of the config are:
- `state.cache_dir`: where the cached state is stored on disk - `state.cache_dir`: where the cached state is stored on disk
- `rpc.listen_addr`: optional JSON-RPC listener port - `rpc.listen_addr`: optional JSON-RPC listener port
See [the full list of configuration options](https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html). See [the full list of configuration options](https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html).
``` ```
zebrad::commands::start: Starting zebrad zebrad::commands::start: Starting zebrad

View File

@ -36,10 +36,10 @@ and the [`flamegraph`][flamegraph] runtime config option.
Compile Zebra with `--features sentry` to monitor it using [Sentry][sentry] in production. Compile Zebra with `--features sentry` to monitor it using [Sentry][sentry] in production.
[tracing_section]: https://doc.zebra.zfnd.org/zebrad/components/tracing/struct.Config.html [tracing_section]: https://docs.rs/zebrad/latest/zebrad/components/tracing/struct.Config.html
[filter]: https://doc.zebra.zfnd.org/zebrad/components/tracing/struct.Config.html#structfield.filter [filter]: https://docs.rs/zebrad/latest/zebrad/components/tracing/struct.Config.html#structfield.filter
[flamegraph]: https://doc.zebra.zfnd.org/zebrad/components/tracing/struct.Config.html#structfield.flamegraph [flamegraph]: https://docs.rs/zebrad/latest/zebrad/components/tracing/struct.Config.html#structfield.flamegraph
[flamegraphs]: http://www.brendangregg.com/flamegraphs.html [flamegraphs]: http://www.brendangregg.com/flamegraphs.html
[systemd_journald]: https://www.freedesktop.org/software/systemd/man/systemd-journald.service.html [systemd_journald]: https://www.freedesktop.org/software/systemd/man/systemd-journald.service.html
[use_journald]: https://doc.zebra.zfnd.org/zebrad/components/tracing/struct.Config.html#structfield.use_journald [use_journald]: https://docs.rs/zebrad/latest/zebrad/components/tracing/struct.Config.html#structfield.use_journald
[sentry]: https://sentry.io/welcome/ [sentry]: https://sentry.io/welcome/

View File

@ -48,7 +48,7 @@ Make sure you're using a release build on your native architecture.
### Syncer Lookahead Limit ### Syncer Lookahead Limit
If your connection is slow, try If your connection is slow, try
[downloading fewer blocks at a time](https://doc.zebra.zfnd.org/zebrad/config/struct.SyncSection.html#structfield.lookahead_limit): [downloading fewer blocks at a time](https://docs.rs/zebrad/latest/zebrad/components/sync/struct.Config.html#structfield.lookahead_limit):
```toml ```toml
[sync] [sync]
@ -58,7 +58,7 @@ max_concurrent_block_requests = 25
### Peer Set Size ### Peer Set Size
If your connection is slow, try [connecting to fewer peers](https://doc.zebra.zfnd.org/zebra_network/struct.Config.html#structfield.peerset_initial_target_size): If your connection is slow, try [connecting to fewer peers](https://docs.rs/zebra-network/latest/zebra_network/struct.Config.html#structfield.peerset_initial_target_size):
```toml ```toml
[network] [network]

View File

@ -5,7 +5,7 @@
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_chain")] #![doc(html_root_url = "https://docs.rs/zebra_chain")]
// Required by bitvec! macro // Required by bitvec! macro
#![recursion_limit = "256"] #![recursion_limit = "256"]
// //

View File

@ -32,7 +32,7 @@
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_consensus")] #![doc(html_root_url = "https://docs.rs/zebra_consensus")]
// //
// Rust 1.72 has a false positive when nested generics are used inside Arc. // Rust 1.72 has a false positive when nested generics are used inside Arc.
// This makes the `arc_with_non_send_sync` lint trigger on a lot of proptest code. // This makes the `arc_with_non_send_sync` lint trigger on a lot of proptest code.

View File

@ -131,7 +131,7 @@
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_network")] #![doc(html_root_url = "https://docs.rs/zebra_network")]
// //
// Rust 1.72 has a false positive when nested generics are used inside Arc. // Rust 1.72 has a false positive when nested generics are used inside Arc.
// This makes the `arc_with_non_send_sync` lint trigger on a lot of proptest code. // This makes the `arc_with_non_send_sync` lint trigger on a lot of proptest code.

View File

@ -34,7 +34,7 @@ pub struct Config {
/// ///
/// Zebra's RPC server has a separate thread pool and a `tokio` executor for each thread. /// Zebra's RPC server has a separate thread pool and a `tokio` executor for each thread.
/// State queries are run concurrently using the shared thread pool controlled by /// State queries are run concurrently using the shared thread pool controlled by
/// the [`SyncSection.parallel_cpu_threads`](https://doc.zebra.zfnd.org/zebrad/config/struct.SyncSection.html#structfield.parallel_cpu_threads) config. /// the [`SyncSection.parallel_cpu_threads`](https://docs.rs/zebrad/latest/zebrad/components/sync/struct.Config.html#structfield.parallel_cpu_threads) config.
/// ///
/// We recommend setting both configs to `0` (automatic scaling) for the best performance. /// We recommend setting both configs to `0` (automatic scaling) for the best performance.
/// This uses one thread per available CPU core. /// This uses one thread per available CPU core.

View File

@ -2,7 +2,7 @@
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_rpc")] #![doc(html_root_url = "https://docs.rs/zebra_rpc")]
pub mod config; pub mod config;
pub mod constants; pub mod constants;

View File

@ -1,7 +1,7 @@
//! Zebra script verification wrapping zcashd's zcash_script library //! Zebra script verification wrapping zcashd's zcash_script library
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_script")] #![doc(html_root_url = "https://docs.rs/zebra_script")]
// We allow unsafe code, so we can call zcash_script // We allow unsafe code, so we can call zcash_script
#![allow(unsafe_code)] #![allow(unsafe_code)]

View File

@ -10,7 +10,7 @@
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_state")] #![doc(html_root_url = "https://docs.rs/zebra_state")]
// //
// Rust 1.72 has a false positive when nested generics are used inside Arc. // Rust 1.72 has a false positive when nested generics are used inside Arc.
// This makes the `arc_with_non_send_sync` lint trigger on a lot of proptest code. // This makes the `arc_with_non_send_sync` lint trigger on a lot of proptest code.

View File

@ -1,7 +1,7 @@
//! Miscellaneous test code for Zebra. //! Miscellaneous test code for Zebra.
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_test")] #![doc(html_root_url = "https://docs.rs/zebra_test")]
// Each lazy_static variable uses additional recursion // Each lazy_static variable uses additional recursion
#![recursion_limit = "512"] #![recursion_limit = "512"]

View File

@ -39,10 +39,10 @@ To create checkpoints, you need a synchronized instance of `zebrad` or `zcashd`.
#### Checkpoint Generation Setup #### Checkpoint Generation Setup
Make sure your `zebrad` or `zcashd` is [listening for RPC requests](https://doc.zebra.zfnd.org/zebra_rpc/config/struct.Config.html#structfield.listen_addr), Make sure your `zebrad` or `zcashd` is [listening for RPC requests](https://doc-internal.zebra.zfnd.org/zebra_rpc/config/struct.Config.html#structfield.listen_addr),
and synced to the network tip. and synced to the network tip.
If you are on a Debian system, `zcash-cli` [can be installed as a package](https://zcash.readthedocs.io/en/latest/rtd_pages/install_debian_bin_packages.html). If you are on a Debian system, `zcash-cli` [can be installed as a package](https://zcash.readthedocs.io/en/master/rtd_pages/install_debian_bin_packages.html).
`zebra-checkpoints` is a standalone rust binary, you can compile it using: `zebra-checkpoints` is a standalone rust binary, you can compile it using:
@ -81,7 +81,7 @@ For more details about checkpoint lists, see the [`zebra-checkpoints` README.](h
To update the testnet checkpoints, `zebra-checkpoints` needs to connect to a testnet node. To update the testnet checkpoints, `zebra-checkpoints` needs to connect to a testnet node.
To launch a testnet node, you can either: To launch a testnet node, you can either:
- start `zebrad` [with a `zebrad.toml` with `network.network` set to `Testnet`](https://doc.zebra.zfnd.org/zebra_network/struct.Config.html#structfield.network), or - start `zebrad` [with a `zebrad.toml` with `network.network` set to `Testnet`](https://docs.rs/zebra-network/latest/zebra_network/struct.Config.html#structfield.network), or
- run `zcashd -testnet`. - run `zcashd -testnet`.
Then use the commands above to regenerate the checkpoints. Then use the commands above to regenerate the checkpoints.

View File

@ -1,7 +1,7 @@
//! Utilities for Zebra development, not for library or application users. //! Utilities for Zebra development, not for library or application users.
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebra_utils")] #![doc(html_root_url = "https://docs.rs/zebra_utils")]
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt}; use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};

View File

@ -37,7 +37,7 @@ impl Runnable for GenerateCmd {
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -6,7 +6,10 @@
//! which implement the different components of a Zcash node //! which implement the different components of a Zcash node
//! (networking, chain structures, validation, rpc, etc). //! (networking, chain structures, validation, rpc, etc).
//! //!
//! [Rendered docs from the `main` branch](https://doc.zebra.zfnd.org). //! [Rendered docs for the latest crate releases](https://docs.rs/releases/search?query=zebra).
//!
//! [Rendered docs from the `main` branch](https://doc-internal.zebra.zfnd.org).
//!
//! [Join us on the Zcash Foundation Engineering Discord](https://discord.gg/na6QZNd). //! [Join us on the Zcash Foundation Engineering Discord](https://discord.gg/na6QZNd).
//! //!
//! ## About Zcash //! ## About Zcash
@ -102,7 +105,7 @@
#![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")] #![doc(html_favicon_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-favicon-128.png")]
#![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")] #![doc(html_logo_url = "https://zfnd.org/wp-content/uploads/2022/03/zebra-icon.png")]
#![doc(html_root_url = "https://doc.zebra.zfnd.org/zebrad")] #![doc(html_root_url = "https://docs.rs/zebrad")]
// Tracing causes false positives on this lint: // Tracing causes false positives on this lint:
// https://github.com/tokio-rs/tracing/issues/553 // https://github.com/tokio-rs/tracing/issues/553
#![allow(clippy::cognitive_complexity)] #![allow(clippy::cognitive_complexity)]

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #

View File

@ -12,7 +12,7 @@
# #
# The config format (including a complete list of sections and fields) is # The config format (including a complete list of sections and fields) is
# documented here: # documented here:
# https://doc.zebra.zfnd.org/zebrad/config/struct.ZebradConfig.html # https://docs.rs/zebrad/latest/zebrad/config/struct.ZebradConfig.html
# #
# zebrad attempts to load configs in the following order: # zebrad attempts to load configs in the following order:
# #