From 342580d299108e2a2d72b950525829d69db8a48e Mon Sep 17 00:00:00 2001 From: jcstein Date: Thu, 28 Nov 2024 07:05:23 +0000 Subject: [PATCH] =?UTF-8?q?Deploy=20preview=20for=20PR=201815=20?= =?UTF-8?q?=F0=9F=9B=AB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pr-1815/404.html | 4 +- pr-1815/README.html | 10 ++-- ...E.md.cdbe601e.js => README.md.4cad7400.js} | 2 +- ...01e.lean.js => README.md.4cad7400.lean.js} | 2 +- .../{app.654e7bad.js => app.d97c7bc6.js} | 2 +- .../chunks/@localSearchIndexroot.4cbbec6e.js | 1 + .../chunks/@localSearchIndexroot.ad8eddd0.js | 1 - ...80d22f.js => VPLocalSearchBox.a2ac4698.js} | 2 +- .../{theme.7287e00e.js => theme.b7c4765b.js} | 2 +- ...e8f6e5.js => community_coc.md.59c70f94.js} | 2 +- ...n.js => community_coc.md.59c70f94.lean.js} | 2 +- ...ndation-delegation-program.md.6742c73d.js} | 2 +- ...on-delegation-program.md.6742c73d.lean.js} | 2 +- ...unity_modular-meetup-guide.md.67b2cbce.js} | 2 +- ..._modular-meetup-guide.md.67b2cbce.lean.js} | 2 +- ...unity_modular-meetup-intro.md.3fda013b.js} | 2 +- ..._modular-meetup-intro.md.3fda013b.lean.js} | 2 +- ...ity_modular-meetup-toolkit.md.ac790481.js} | 2 +- ...odular-meetup-toolkit.md.ac790481.lean.js} | 2 +- ... => community_speaker-list.md.d01ce1fd.js} | 2 +- ...ommunity_speaker-list.md.d01ce1fd.lean.js} | 2 +- ...w-to-guides_arabica-devnet.md.a7bda01d.js} | 2 +- ...guides_arabica-devnet.md.a7bda01d.lean.js} | 2 +- ...-to-guides_arbitrum-bridge.md.fc2c9c1e.js} | 2 +- ...uides_arbitrum-bridge.md.fc2c9c1e.lean.js} | 2 +- ...-to-guides_arbitrum-deploy.md.f0ee059a.js} | 2 +- ...uides_arbitrum-deploy.md.f0ee059a.lean.js} | 2 +- ...-guides_arbitrum-full-node.md.59ec28dd.js} | 2 +- ...es_arbitrum-full-node.md.59ec28dd.lean.js} | 2 +- ...uides_arbitrum-integration.md.6c060e19.js} | 2 +- ..._arbitrum-integration.md.6c060e19.lean.js} | 2 +- ...uides_blobstream-contracts.md.72c1a84f.js} | 2 +- ..._blobstream-contracts.md.72c1a84f.lean.js} | 2 +- ...guides_blobstream-offchain.md.b3a72b46.js} | 2 +- ...s_blobstream-offchain.md.b3a72b46.lean.js} | 2 +- ...s_blobstream-proof-queries.md.b36c2659.js} | 12 ++-- ...bstream-proof-queries.md.b36c2659.lean.js} | 2 +- ...-guides_blobstream-rollups.md.5bb93b32.js} | 2 +- ...es_blobstream-rollups.md.5bb93b32.lean.js} | 2 +- ...guides_blobstream-x-deploy.md.c70d2786.js} | 2 +- ...s_blobstream-x-deploy.md.c70d2786.lean.js} | 2 +- ...ing-data-commitment-ranges.md.1e42197f.js} | 2 +- ...ata-commitment-ranges.md.1e42197f.lean.js} | 2 +- ...> how-to-guides_blobstream.md.3a35dd4c.js} | 2 +- ...-to-guides_blobstream.md.3a35dd4c.lean.js} | 2 +- ... how-to-guides_blobstreamx.md.1dcae78a.js} | 2 +- ...to-guides_blobstreamx.md.1dcae78a.lean.js} | 2 +- ... how-to-guides_bridge-node.md.51e7c8f0.js} | 6 +- ...to-guides_bridge-node.md.51e7c8f0.lean.js} | 2 +- ...how-to-guides_bubs-testnet.md.7c4ccf62.js} | 2 +- ...o-guides_bubs-testnet.md.7c4ccf62.lean.js} | 2 +- ...ides_celestia-app-commands.md.cf34f1c2.js} | 2 +- ...celestia-app-commands.md.cf34f1c2.lean.js} | 2 +- ...uides_celestia-app-metrics.md.120ee0a3.js} | 2 +- ..._celestia-app-metrics.md.120ee0a3.lean.js} | 2 +- ...ides_celestia-app-multisig.md.e890db6c.js} | 2 +- ...celestia-app-multisig.md.e890db6c.lean.js} | 2 +- ...ides_celestia-app-slashing.md.4d08bcea.js} | 2 +- ...celestia-app-slashing.md.4d08bcea.lean.js} | 2 +- ...lestia-app-upgrade-monitor.md.2dd4f678.js} | 2 +- ...a-app-upgrade-monitor.md.2dd4f678.lean.js} | 2 +- ...uides_celestia-app-vesting.md.b9f23b75.js} | 2 +- ..._celestia-app-vesting.md.b9f23b75.lean.js} | 2 +- ...guides_celestia-app-wallet.md.81ff3a65.js} | 2 +- ...s_celestia-app-wallet.md.81ff3a65.lean.js} | 2 +- ...how-to-guides_celestia-app.md.e81846ef.js} | 2 +- ...o-guides_celestia-app.md.e81846ef.lean.js} | 2 +- ...estia-node-custom-networks.md.3d44971b.js} | 2 +- ...-node-custom-networks.md.3d44971b.lean.js} | 2 +- ...ides_celestia-node-metrics.md.6a48093e.js} | 2 +- ...celestia-node-metrics.md.6a48093e.lean.js} | 2 +- ...estia-node-store-structure.md.63b1cd30.js} | 2 +- ...-node-store-structure.md.63b1cd30.lean.js} | 2 +- ...estia-node-troubleshooting.md.3ef61dbb.js} | 2 +- ...-node-troubleshooting.md.3ef61dbb.lean.js} | 2 +- ...celestia-node-trusted-hash.md.4e90c5a9.js} | 2 +- ...tia-node-trusted-hash.md.4e90c5a9.lean.js} | 2 +- ...ow-to-guides_celestia-node.md.e06533d5.js} | 8 +-- ...-guides_celestia-node.md.e06533d5.lean.js} | 8 +-- ... how-to-guides_config-toml.md.c55b64b5.js} | 2 +- ...to-guides_config-toml.md.c55b64b5.lean.js} | 2 +- ...w-to-guides_consensus-node.md.a59f3838.js} | 36 +++++------ ...guides_consensus-node.md.a59f3838.lean.js} | 32 +++++----- ... how-to-guides_decide-node.md.29d9cc16.js} | 2 +- ...to-guides_decide-node.md.29d9cc16.lean.js} | 2 +- ...ow-to-guides_docker-images.md.23a48650.js} | 60 +++++++++---------- ...-guides_docker-images.md.23a48650.lean.js} | 54 ++++++++--------- ... how-to-guides_environment.md.0bd51cab.js} | 8 +-- ...to-guides_environment.md.0bd51cab.lean.js} | 2 +- ...o-guides_ethereum-fallback.md.7b275d7a.js} | 2 +- ...des_ethereum-fallback.md.7b275d7a.lean.js} | 2 +- ...-guides_feegrant-for-blobs.md.716309b7.js} | 2 +- ...es_feegrant-for-blobs.md.716309b7.lean.js} | 2 +- ...o-guides_full-storage-node.md.12f43165.js} | 2 +- ...des_full-storage-node.md.12f43165.lean.js} | 2 +- ... how-to-guides_ibc-relayer.md.54b5d7e7.js} | 2 +- ...to-guides_ibc-relayer.md.54b5d7e7.lean.js} | 2 +- ...guides_instantiate-testnet.md.6d6bb2c0.js} | 2 +- ...s_instantiate-testnet.md.6d6bb2c0.lean.js} | 2 +- ...o-guides_intro-to-op-stack.md.41b9814c.js} | 2 +- ...des_intro-to-op-stack.md.41b9814c.lean.js} | 2 +- ...> how-to-guides_light-node.md.edb7fb97.js} | 8 +-- ...-to-guides_light-node.md.edb7fb97.lean.js} | 2 +- ...ow-to-guides_local-testnet.md.d47ac3d0.js} | 10 ++-- ...-guides_local-testnet.md.d47ac3d0.lean.js} | 2 +- ...s => how-to-guides_mainnet.md.8c474549.js} | 2 +- ...how-to-guides_mainnet.md.8c474549.lean.js} | 2 +- ...ow-to-guides_mocha-testnet.md.4fde7245.js} | 2 +- ...-guides_mocha-testnet.md.4fde7245.lean.js} | 2 +- ...ow-to-guides_multiaccounts.md.54e5cfc9.js} | 2 +- ...-guides_multiaccounts.md.54e5cfc9.lean.js} | 2 +- ...es_network-upgrade-process.md.1493429a.js} | 2 +- ...twork-upgrade-process.md.1493429a.lean.js} | 2 +- ...w-to-guides_nodes-overview.md.082b2343.js} | 2 +- ...guides_nodes-overview.md.082b2343.lean.js} | 2 +- ...-to-guides_optimism-devnet.md.ea2a7388.js} | 2 +- ...uides_optimism-devnet.md.ea2a7388.lean.js} | 2 +- ... => how-to-guides_optimism.md.b6848def.js} | 4 +- ...ow-to-guides_optimism.md.b6848def.lean.js} | 2 +- ... how-to-guides_participate.md.7ccb450b.js} | 2 +- ...to-guides_participate.md.7ccb450b.lean.js} | 2 +- ... how-to-guides_quick-start.md.869e21a3.js} | 2 +- ...to-guides_quick-start.md.869e21a3.lean.js} | 2 +- ...ow-to-guides_rollup-stacks.md.ac8fa6e2.js} | 2 +- ...-guides_rollup-stacks.md.ac8fa6e2.lean.js} | 2 +- ...ides_sp1-blobstream-deploy.md.d5e590db.js} | 2 +- ...sp1-blobstream-deploy.md.d5e590db.lean.js} | 2 +- ... how-to-guides_submit-data.md.dfcce169.js} | 2 +- ...to-guides_submit-data.md.dfcce169.lean.js} | 2 +- ...s => how-to-guides_systemd.md.def256dc.js} | 2 +- ...how-to-guides_systemd.md.def256dc.lean.js} | 2 +- ...s_transaction-resubmission.md.075e6fb0.js} | 2 +- ...nsaction-resubmission.md.075e6fb0.lean.js} | 2 +- ...w-to-guides_validator-node.md.5e3cb47d.js} | 26 ++++---- ...guides_validator-node.md.5e3cb47d.lean.js} | 22 +++---- ...ex.md.301f8cf4.js => index.md.5f15dd4a.js} | 2 +- ...8cf4.lean.js => index.md.5f15dd4a.lean.js} | 2 +- ...orks_data-availability-faq.md.7e26d360.js} | 2 +- ...data-availability-faq.md.7e26d360.lean.js} | 2 +- ...ks_data-availability-layer.md.4b8bfd66.js} | 2 +- ...ta-availability-layer.md.4b8bfd66.lean.js} | 2 +- ...orks_monolithic-vs-modular.md.ee4811c6.js} | 2 +- ...monolithic-vs-modular.md.ee4811c6.lean.js} | 2 +- ...ow-celestia-works_overview.md.ed78821c.js} | 2 +- ...lestia-works_overview.md.ed78821c.lean.js} | 2 +- ...orks_transaction-lifecycle.md.dbc95259.js} | 2 +- ...transaction-lifecycle.md.dbc95259.lean.js} | 2 +- ... => learn_how-to-stake-tia.md.961588e1.js} | 2 +- ...earn_how-to-stake-tia.md.961588e1.lean.js} | 2 +- ...learn_paying-for-blobspace.md.119c2d85.js} | 2 +- ..._paying-for-blobspace.md.119c2d85.lean.js} | 2 +- ...js => learn_retrievability.md.d172ae26.js} | 2 +- ... learn_retrievability.md.d172ae26.lean.js} | 2 +- ..._staking-governance-supply.md.315bdc22.js} | 2 +- ...ing-governance-supply.md.315bdc22.lean.js} | 2 +- ...08d6a2.js => learn_staking.md.4211cf86.js} | 2 +- ...n.js => learn_staking.md.4211cf86.lean.js} | 2 +- ...d.e94f8580.js => learn_tia.md.8cf214a7.js} | 2 +- ....lean.js => learn_tia.md.8cf214a7.lean.js} | 2 +- ...utorials_celestia-node-key.md.30b8a442.js} | 8 +-- ...als_celestia-node-key.md.30b8a442.lean.js} | 2 +- ...als_golang-client-tutorial.md.24f89eb7.js} | 2 +- ...olang-client-tutorial.md.24f89eb7.lean.js} | 2 +- ...torials_integrate-celestia.md.2c9ea427.js} | 2 +- ...ls_integrate-celestia.md.2c9ea427.lean.js} | 2 +- ...f.js => tutorials_node-api.md.42cef958.js} | 2 +- ...=> tutorials_node-api.md.42cef958.lean.js} | 2 +- ...=> tutorials_node-tutorial.md.bebac79b.js} | 6 +- ...torials_node-tutorial.md.bebac79b.lean.js} | 2 +- ...tutorials_prompt-scavenger.md.65befca9.js} | 2 +- ...ials_prompt-scavenger.md.65befca9.lean.js} | 2 +- ...rials_rust-client-tutorial.md.a22c75a7.js} | 2 +- ..._rust-client-tutorial.md.a22c75a7.lean.js} | 2 +- ...78.js => tutorials_wallets.md.8dad253d.js} | 48 +++++++-------- ... => tutorials_wallets.md.8dad253d.lean.js} | 46 +++++++------- pr-1815/community/coc.html | 10 ++-- .../foundation-delegation-program.html | 10 ++-- pr-1815/community/modular-meetup-guide.html | 10 ++-- pr-1815/community/modular-meetup-intro.html | 10 ++-- pr-1815/community/modular-meetup-toolkit.html | 10 ++-- pr-1815/community/speaker-list.html | 10 ++-- pr-1815/hashmap.json | 2 +- pr-1815/how-to-guides/arabica-devnet.html | 10 ++-- pr-1815/how-to-guides/arbitrum-bridge.html | 10 ++-- pr-1815/how-to-guides/arbitrum-deploy.html | 10 ++-- pr-1815/how-to-guides/arbitrum-full-node.html | 10 ++-- .../how-to-guides/arbitrum-integration.html | 10 ++-- .../how-to-guides/blobstream-contracts.html | 10 ++-- .../how-to-guides/blobstream-offchain.html | 10 ++-- .../blobstream-proof-queries.html | 20 +++---- pr-1815/how-to-guides/blobstream-rollups.html | 10 ++-- .../how-to-guides/blobstream-x-deploy.html | 10 ++-- ...m-x-requesting-data-commitment-ranges.html | 10 ++-- pr-1815/how-to-guides/blobstream.html | 10 ++-- pr-1815/how-to-guides/blobstreamx.html | 10 ++-- pr-1815/how-to-guides/bridge-node.html | 14 ++--- pr-1815/how-to-guides/bubs-testnet.html | 10 ++-- .../how-to-guides/celestia-app-commands.html | 10 ++-- .../how-to-guides/celestia-app-metrics.html | 10 ++-- .../how-to-guides/celestia-app-multisig.html | 10 ++-- .../how-to-guides/celestia-app-slashing.html | 10 ++-- .../celestia-app-upgrade-monitor.html | 10 ++-- .../how-to-guides/celestia-app-vesting.html | 10 ++-- .../how-to-guides/celestia-app-wallet.html | 10 ++-- pr-1815/how-to-guides/celestia-app.html | 10 ++-- .../celestia-node-custom-networks.html | 10 ++-- .../how-to-guides/celestia-node-metrics.html | 10 ++-- .../celestia-node-store-structure.html | 10 ++-- .../celestia-node-troubleshooting.html | 10 ++-- .../celestia-node-trusted-hash.html | 10 ++-- pr-1815/how-to-guides/celestia-node.html | 12 ++-- pr-1815/how-to-guides/config-toml.html | 10 ++-- pr-1815/how-to-guides/consensus-node.html | 18 +++--- pr-1815/how-to-guides/decide-node.html | 10 ++-- pr-1815/how-to-guides/docker-images.html | 18 +++--- pr-1815/how-to-guides/environment.html | 16 ++--- pr-1815/how-to-guides/ethereum-fallback.html | 10 ++-- pr-1815/how-to-guides/feegrant-for-blobs.html | 10 ++-- pr-1815/how-to-guides/full-storage-node.html | 12 ++-- pr-1815/how-to-guides/ibc-relayer.html | 10 ++-- .../how-to-guides/instantiate-testnet.html | 10 ++-- pr-1815/how-to-guides/intro-to-op-stack.html | 10 ++-- pr-1815/how-to-guides/light-node.html | 16 ++--- pr-1815/how-to-guides/local-testnet.html | 18 +++--- pr-1815/how-to-guides/mainnet.html | 10 ++-- pr-1815/how-to-guides/mocha-testnet.html | 10 ++-- pr-1815/how-to-guides/multiaccounts.html | 10 ++-- .../network-upgrade-process.html | 10 ++-- pr-1815/how-to-guides/nodes-overview.html | 10 ++-- pr-1815/how-to-guides/optimism-devnet.html | 10 ++-- pr-1815/how-to-guides/optimism.html | 12 ++-- pr-1815/how-to-guides/participate.html | 10 ++-- pr-1815/how-to-guides/quick-start.html | 10 ++-- pr-1815/how-to-guides/rollup-stacks.html | 10 ++-- .../how-to-guides/sp1-blobstream-deploy.html | 10 ++-- pr-1815/how-to-guides/submit-data.html | 10 ++-- pr-1815/how-to-guides/systemd.html | 10 ++-- .../transaction-resubmission.html | 10 ++-- pr-1815/how-to-guides/validator-node.html | 12 ++-- pr-1815/index.html | 8 +-- .../data-availability-faq.html | 10 ++-- .../data-availability-layer.html | 10 ++-- .../monolithic-vs-modular.html | 10 ++-- .../learn/how-celestia-works/overview.html | 10 ++-- .../transaction-lifecycle.html | 10 ++-- pr-1815/learn/how-to-stake-tia.html | 10 ++-- pr-1815/learn/paying-for-blobspace.html | 10 ++-- pr-1815/learn/retrievability.html | 10 ++-- pr-1815/learn/staking-governance-supply.html | 10 ++-- pr-1815/learn/staking.html | 10 ++-- pr-1815/learn/tia.html | 10 ++-- pr-1815/sitemap.xml | 2 +- pr-1815/start-local.sh | 3 - pr-1815/tutorials/celestia-node-key.html | 16 ++--- pr-1815/tutorials/golang-client-tutorial.html | 10 ++-- pr-1815/tutorials/integrate-celestia.html | 10 ++-- pr-1815/tutorials/node-api.html | 10 ++-- pr-1815/tutorials/node-tutorial.html | 14 ++--- pr-1815/tutorials/prompt-scavenger.html | 10 ++-- pr-1815/tutorials/rust-client-tutorial.html | 10 ++-- pr-1815/tutorials/wallets.html | 14 ++--- 261 files changed, 814 insertions(+), 817 deletions(-) rename pr-1815/assets/{README.md.cdbe601e.js => README.md.4cad7400.js} (98%) rename pr-1815/assets/{README.md.cdbe601e.lean.js => README.md.4cad7400.lean.js} (89%) rename pr-1815/assets/{app.654e7bad.js => app.d97c7bc6.js} (95%) create mode 100644 pr-1815/assets/chunks/@localSearchIndexroot.4cbbec6e.js delete mode 100644 pr-1815/assets/chunks/@localSearchIndexroot.ad8eddd0.js rename pr-1815/assets/chunks/{VPLocalSearchBox.0e80d22f.js => VPLocalSearchBox.a2ac4698.js} (99%) rename pr-1815/assets/chunks/{theme.7287e00e.js => theme.b7c4765b.js} (99%) rename pr-1815/assets/{community_coc.md.24e8f6e5.js => community_coc.md.59c70f94.js} (99%) rename pr-1815/assets/{community_coc.md.24e8f6e5.lean.js => community_coc.md.59c70f94.lean.js} (92%) rename pr-1815/assets/{community_foundation-delegation-program.md.4ddabdc6.js => community_foundation-delegation-program.md.6742c73d.js} (99%) rename pr-1815/assets/{community_foundation-delegation-program.md.4ddabdc6.lean.js => community_foundation-delegation-program.md.6742c73d.lean.js} (92%) rename pr-1815/assets/{community_modular-meetup-guide.md.b2c75b9f.js => community_modular-meetup-guide.md.67b2cbce.js} (99%) rename pr-1815/assets/{community_modular-meetup-guide.md.b2c75b9f.lean.js => community_modular-meetup-guide.md.67b2cbce.lean.js} (92%) rename pr-1815/assets/{community_modular-meetup-intro.md.3c6093e3.js => community_modular-meetup-intro.md.3fda013b.js} (98%) rename pr-1815/assets/{community_modular-meetup-intro.md.3c6093e3.lean.js => community_modular-meetup-intro.md.3fda013b.lean.js} (92%) rename pr-1815/assets/{community_modular-meetup-toolkit.md.67ff3975.js => community_modular-meetup-toolkit.md.ac790481.js} (98%) rename pr-1815/assets/{community_modular-meetup-toolkit.md.67ff3975.lean.js => community_modular-meetup-toolkit.md.ac790481.lean.js} (91%) rename pr-1815/assets/{community_speaker-list.md.43e3f62d.js => community_speaker-list.md.d01ce1fd.js} (97%) rename pr-1815/assets/{community_speaker-list.md.43e3f62d.lean.js => community_speaker-list.md.d01ce1fd.lean.js} (97%) rename pr-1815/assets/{how-to-guides_arabica-devnet.md.99c9281a.js => how-to-guides_arabica-devnet.md.a7bda01d.js} (99%) rename pr-1815/assets/{how-to-guides_arabica-devnet.md.99c9281a.lean.js => how-to-guides_arabica-devnet.md.a7bda01d.lean.js} (97%) rename pr-1815/assets/{how-to-guides_arbitrum-bridge.md.67821b72.js => how-to-guides_arbitrum-bridge.md.fc2c9c1e.js} (99%) rename pr-1815/assets/{how-to-guides_arbitrum-bridge.md.67821b72.lean.js => how-to-guides_arbitrum-bridge.md.fc2c9c1e.lean.js} (97%) rename pr-1815/assets/{how-to-guides_arbitrum-deploy.md.ab7e5910.js => how-to-guides_arbitrum-deploy.md.f0ee059a.js} (99%) rename pr-1815/assets/{how-to-guides_arbitrum-deploy.md.ab7e5910.lean.js => how-to-guides_arbitrum-deploy.md.f0ee059a.lean.js} (95%) rename pr-1815/assets/{how-to-guides_arbitrum-full-node.md.db590a7b.js => how-to-guides_arbitrum-full-node.md.59ec28dd.js} (98%) rename pr-1815/assets/{how-to-guides_arbitrum-full-node.md.db590a7b.lean.js => how-to-guides_arbitrum-full-node.md.59ec28dd.lean.js} (92%) rename pr-1815/assets/{how-to-guides_arbitrum-integration.md.eea707b4.js => how-to-guides_arbitrum-integration.md.6c060e19.js} (99%) rename pr-1815/assets/{how-to-guides_arbitrum-integration.md.eea707b4.lean.js => how-to-guides_arbitrum-integration.md.6c060e19.lean.js} (94%) rename pr-1815/assets/{how-to-guides_blobstream-contracts.md.f87f3793.js => how-to-guides_blobstream-contracts.md.72c1a84f.js} (99%) rename pr-1815/assets/{how-to-guides_blobstream-contracts.md.f87f3793.lean.js => how-to-guides_blobstream-contracts.md.72c1a84f.lean.js} (93%) rename pr-1815/assets/{how-to-guides_blobstream-offchain.md.a1784f7d.js => how-to-guides_blobstream-offchain.md.b3a72b46.js} (99%) rename pr-1815/assets/{how-to-guides_blobstream-offchain.md.a1784f7d.lean.js => how-to-guides_blobstream-offchain.md.b3a72b46.lean.js} (92%) rename pr-1815/assets/{how-to-guides_blobstream-proof-queries.md.4afa5c35.js => how-to-guides_blobstream-proof-queries.md.b36c2659.js} (99%) rename pr-1815/assets/{how-to-guides_blobstream-proof-queries.md.4afa5c35.lean.js => how-to-guides_blobstream-proof-queries.md.b36c2659.lean.js} (93%) rename pr-1815/assets/{how-to-guides_blobstream-rollups.md.dc1ba5fc.js => how-to-guides_blobstream-rollups.md.5bb93b32.js} (99%) rename pr-1815/assets/{how-to-guides_blobstream-rollups.md.dc1ba5fc.lean.js => how-to-guides_blobstream-rollups.md.5bb93b32.lean.js} (93%) rename pr-1815/assets/{how-to-guides_blobstream-x-deploy.md.230cb897.js => how-to-guides_blobstream-x-deploy.md.c70d2786.js} (99%) rename pr-1815/assets/{how-to-guides_blobstream-x-deploy.md.230cb897.lean.js => how-to-guides_blobstream-x-deploy.md.c70d2786.lean.js} (91%) rename pr-1815/assets/{how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.js => how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.js} (98%) rename pr-1815/assets/{how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.lean.js => how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.lean.js} (92%) rename pr-1815/assets/{how-to-guides_blobstream.md.2b135046.js => how-to-guides_blobstream.md.3a35dd4c.js} (99%) rename pr-1815/assets/{how-to-guides_blobstream.md.2b135046.lean.js => how-to-guides_blobstream.md.3a35dd4c.lean.js} (92%) rename pr-1815/assets/{how-to-guides_blobstreamx.md.139d5ab9.js => how-to-guides_blobstreamx.md.1dcae78a.js} (99%) rename pr-1815/assets/{how-to-guides_blobstreamx.md.139d5ab9.lean.js => how-to-guides_blobstreamx.md.1dcae78a.lean.js} (93%) rename pr-1815/assets/{how-to-guides_bridge-node.md.f12e478d.js => how-to-guides_bridge-node.md.51e7c8f0.js} (97%) rename pr-1815/assets/{how-to-guides_bridge-node.md.f12e478d.lean.js => how-to-guides_bridge-node.md.51e7c8f0.lean.js} (83%) rename pr-1815/assets/{how-to-guides_bubs-testnet.md.b721ea5a.js => how-to-guides_bubs-testnet.md.7c4ccf62.js} (98%) rename pr-1815/assets/{how-to-guides_bubs-testnet.md.b721ea5a.lean.js => how-to-guides_bubs-testnet.md.7c4ccf62.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-app-commands.md.e2443b6e.js => how-to-guides_celestia-app-commands.md.cf34f1c2.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-app-commands.md.e2443b6e.lean.js => how-to-guides_celestia-app-commands.md.cf34f1c2.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-app-metrics.md.c57e7d35.js => how-to-guides_celestia-app-metrics.md.120ee0a3.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-app-metrics.md.c57e7d35.lean.js => how-to-guides_celestia-app-metrics.md.120ee0a3.lean.js} (93%) rename pr-1815/assets/{how-to-guides_celestia-app-multisig.md.0242053f.js => how-to-guides_celestia-app-multisig.md.e890db6c.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-app-multisig.md.0242053f.lean.js => how-to-guides_celestia-app-multisig.md.e890db6c.lean.js} (90%) rename pr-1815/assets/{how-to-guides_celestia-app-slashing.md.d65d1c8a.js => how-to-guides_celestia-app-slashing.md.4d08bcea.js} (97%) rename pr-1815/assets/{how-to-guides_celestia-app-slashing.md.d65d1c8a.lean.js => how-to-guides_celestia-app-slashing.md.4d08bcea.lean.js} (93%) rename pr-1815/assets/{how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.js => how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.js} (95%) rename pr-1815/assets/{how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.lean.js => how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.lean.js} (95%) rename pr-1815/assets/{how-to-guides_celestia-app-vesting.md.b7b33049.js => how-to-guides_celestia-app-vesting.md.b9f23b75.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-app-vesting.md.b7b33049.lean.js => how-to-guides_celestia-app-vesting.md.b9f23b75.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-app-wallet.md.98ae1a8e.js => how-to-guides_celestia-app-wallet.md.81ff3a65.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-app-wallet.md.98ae1a8e.lean.js => how-to-guides_celestia-app-wallet.md.81ff3a65.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-app.md.a9e559b1.js => how-to-guides_celestia-app.md.e81846ef.js} (90%) rename pr-1815/assets/{how-to-guides_celestia-app.md.a9e559b1.lean.js => how-to-guides_celestia-app.md.e81846ef.lean.js} (73%) rename pr-1815/assets/{how-to-guides_celestia-node-custom-networks.md.a43d9768.js => how-to-guides_celestia-node-custom-networks.md.3d44971b.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-node-custom-networks.md.a43d9768.lean.js => how-to-guides_celestia-node-custom-networks.md.3d44971b.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-node-metrics.md.6be6e0bb.js => how-to-guides_celestia-node-metrics.md.6a48093e.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-node-metrics.md.6be6e0bb.lean.js => how-to-guides_celestia-node-metrics.md.6a48093e.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-node-store-structure.md.f13dec0a.js => how-to-guides_celestia-node-store-structure.md.63b1cd30.js} (98%) rename pr-1815/assets/{how-to-guides_celestia-node-store-structure.md.f13dec0a.lean.js => how-to-guides_celestia-node-store-structure.md.63b1cd30.lean.js} (93%) rename pr-1815/assets/{how-to-guides_celestia-node-troubleshooting.md.28daa8cd.js => how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-node-troubleshooting.md.28daa8cd.lean.js => how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.lean.js} (96%) rename pr-1815/assets/{how-to-guides_celestia-node-trusted-hash.md.dcfb937e.js => how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.js} (99%) rename pr-1815/assets/{how-to-guides_celestia-node-trusted-hash.md.dcfb937e.lean.js => how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.lean.js} (92%) rename pr-1815/assets/{how-to-guides_celestia-node.md.a33fa5a8.js => how-to-guides_celestia-node.md.e06533d5.js} (86%) rename pr-1815/assets/{how-to-guides_celestia-node.md.a33fa5a8.lean.js => how-to-guides_celestia-node.md.e06533d5.lean.js} (60%) rename pr-1815/assets/{how-to-guides_config-toml.md.e0e7af97.js => how-to-guides_config-toml.md.c55b64b5.js} (98%) rename pr-1815/assets/{how-to-guides_config-toml.md.e0e7af97.lean.js => how-to-guides_config-toml.md.c55b64b5.lean.js} (91%) rename pr-1815/assets/{how-to-guides_consensus-node.md.26d064fd.js => how-to-guides_consensus-node.md.a59f3838.js} (92%) rename pr-1815/assets/{how-to-guides_consensus-node.md.26d064fd.lean.js => how-to-guides_consensus-node.md.a59f3838.lean.js} (76%) rename pr-1815/assets/{how-to-guides_decide-node.md.985bb243.js => how-to-guides_decide-node.md.29d9cc16.js} (97%) rename pr-1815/assets/{how-to-guides_decide-node.md.985bb243.lean.js => how-to-guides_decide-node.md.29d9cc16.lean.js} (91%) rename pr-1815/assets/{how-to-guides_docker-images.md.72749f80.js => how-to-guides_docker-images.md.23a48650.js} (86%) rename pr-1815/assets/{how-to-guides_docker-images.md.72749f80.lean.js => how-to-guides_docker-images.md.23a48650.lean.js} (61%) rename pr-1815/assets/{how-to-guides_environment.md.33880087.js => how-to-guides_environment.md.0bd51cab.js} (91%) rename pr-1815/assets/{how-to-guides_environment.md.33880087.lean.js => how-to-guides_environment.md.0bd51cab.lean.js} (57%) rename pr-1815/assets/{how-to-guides_ethereum-fallback.md.353433f7.js => how-to-guides_ethereum-fallback.md.7b275d7a.js} (97%) rename pr-1815/assets/{how-to-guides_ethereum-fallback.md.353433f7.lean.js => how-to-guides_ethereum-fallback.md.7b275d7a.lean.js} (97%) rename pr-1815/assets/{how-to-guides_feegrant-for-blobs.md.b58bc74e.js => how-to-guides_feegrant-for-blobs.md.716309b7.js} (99%) rename pr-1815/assets/{how-to-guides_feegrant-for-blobs.md.b58bc74e.lean.js => how-to-guides_feegrant-for-blobs.md.716309b7.lean.js} (90%) rename pr-1815/assets/{how-to-guides_full-storage-node.md.35341887.js => how-to-guides_full-storage-node.md.12f43165.js} (96%) rename pr-1815/assets/{how-to-guides_full-storage-node.md.35341887.lean.js => how-to-guides_full-storage-node.md.12f43165.lean.js} (92%) rename pr-1815/assets/{how-to-guides_ibc-relayer.md.f1a48ea7.js => how-to-guides_ibc-relayer.md.54b5d7e7.js} (99%) rename pr-1815/assets/{how-to-guides_ibc-relayer.md.f1a48ea7.lean.js => how-to-guides_ibc-relayer.md.54b5d7e7.lean.js} (92%) rename pr-1815/assets/{how-to-guides_instantiate-testnet.md.e040791e.js => how-to-guides_instantiate-testnet.md.6d6bb2c0.js} (99%) rename pr-1815/assets/{how-to-guides_instantiate-testnet.md.e040791e.lean.js => how-to-guides_instantiate-testnet.md.6d6bb2c0.lean.js} (92%) rename pr-1815/assets/{how-to-guides_intro-to-op-stack.md.fc0653f2.js => how-to-guides_intro-to-op-stack.md.41b9814c.js} (98%) rename pr-1815/assets/{how-to-guides_intro-to-op-stack.md.fc0653f2.lean.js => how-to-guides_intro-to-op-stack.md.41b9814c.lean.js} (93%) rename pr-1815/assets/{how-to-guides_light-node.md.faf1d5ee.js => how-to-guides_light-node.md.edb7fb97.js} (95%) rename pr-1815/assets/{how-to-guides_light-node.md.faf1d5ee.lean.js => how-to-guides_light-node.md.edb7fb97.lean.js} (65%) rename pr-1815/assets/{how-to-guides_local-testnet.md.b7413a1e.js => how-to-guides_local-testnet.md.d47ac3d0.js} (91%) rename pr-1815/assets/{how-to-guides_local-testnet.md.b7413a1e.lean.js => how-to-guides_local-testnet.md.d47ac3d0.lean.js} (81%) rename pr-1815/assets/{how-to-guides_mainnet.md.1539ba72.js => how-to-guides_mainnet.md.8c474549.js} (99%) rename pr-1815/assets/{how-to-guides_mainnet.md.1539ba72.lean.js => how-to-guides_mainnet.md.8c474549.lean.js} (99%) rename pr-1815/assets/{how-to-guides_mocha-testnet.md.94189cf4.js => how-to-guides_mocha-testnet.md.4fde7245.js} (99%) rename pr-1815/assets/{how-to-guides_mocha-testnet.md.94189cf4.lean.js => how-to-guides_mocha-testnet.md.4fde7245.lean.js} (97%) rename pr-1815/assets/{how-to-guides_multiaccounts.md.c40b388b.js => how-to-guides_multiaccounts.md.54e5cfc9.js} (99%) rename pr-1815/assets/{how-to-guides_multiaccounts.md.c40b388b.lean.js => how-to-guides_multiaccounts.md.54e5cfc9.lean.js} (90%) rename pr-1815/assets/{how-to-guides_network-upgrade-process.md.0db1d530.js => how-to-guides_network-upgrade-process.md.1493429a.js} (99%) rename pr-1815/assets/{how-to-guides_network-upgrade-process.md.0db1d530.lean.js => how-to-guides_network-upgrade-process.md.1493429a.lean.js} (92%) rename pr-1815/assets/{how-to-guides_nodes-overview.md.e7d3307b.js => how-to-guides_nodes-overview.md.082b2343.js} (98%) rename pr-1815/assets/{how-to-guides_nodes-overview.md.e7d3307b.lean.js => how-to-guides_nodes-overview.md.082b2343.lean.js} (92%) rename pr-1815/assets/{how-to-guides_optimism-devnet.md.ef6600cc.js => how-to-guides_optimism-devnet.md.ea2a7388.js} (99%) rename pr-1815/assets/{how-to-guides_optimism-devnet.md.ef6600cc.lean.js => how-to-guides_optimism-devnet.md.ea2a7388.lean.js} (90%) rename pr-1815/assets/{how-to-guides_optimism.md.50d1f609.js => how-to-guides_optimism.md.b6848def.js} (95%) rename pr-1815/assets/{how-to-guides_optimism.md.50d1f609.lean.js => how-to-guides_optimism.md.b6848def.lean.js} (78%) rename pr-1815/assets/{how-to-guides_participate.md.090651cf.js => how-to-guides_participate.md.7ccb450b.js} (98%) rename pr-1815/assets/{how-to-guides_participate.md.090651cf.lean.js => how-to-guides_participate.md.7ccb450b.lean.js} (93%) rename pr-1815/assets/{how-to-guides_quick-start.md.75f45a26.js => how-to-guides_quick-start.md.869e21a3.js} (99%) rename pr-1815/assets/{how-to-guides_quick-start.md.75f45a26.lean.js => how-to-guides_quick-start.md.869e21a3.lean.js} (99%) rename pr-1815/assets/{how-to-guides_rollup-stacks.md.7b355d9c.js => how-to-guides_rollup-stacks.md.ac8fa6e2.js} (99%) rename pr-1815/assets/{how-to-guides_rollup-stacks.md.7b355d9c.lean.js => how-to-guides_rollup-stacks.md.ac8fa6e2.lean.js} (98%) rename pr-1815/assets/{how-to-guides_sp1-blobstream-deploy.md.28f2de08.js => how-to-guides_sp1-blobstream-deploy.md.d5e590db.js} (98%) rename pr-1815/assets/{how-to-guides_sp1-blobstream-deploy.md.28f2de08.lean.js => how-to-guides_sp1-blobstream-deploy.md.d5e590db.lean.js} (91%) rename pr-1815/assets/{how-to-guides_submit-data.md.706c0143.js => how-to-guides_submit-data.md.dfcce169.js} (99%) rename pr-1815/assets/{how-to-guides_submit-data.md.706c0143.lean.js => how-to-guides_submit-data.md.dfcce169.lean.js} (99%) rename pr-1815/assets/{how-to-guides_systemd.md.32f00e62.js => how-to-guides_systemd.md.def256dc.js} (99%) rename pr-1815/assets/{how-to-guides_systemd.md.32f00e62.lean.js => how-to-guides_systemd.md.def256dc.lean.js} (85%) rename pr-1815/assets/{how-to-guides_transaction-resubmission.md.c43abb47.js => how-to-guides_transaction-resubmission.md.075e6fb0.js} (97%) rename pr-1815/assets/{how-to-guides_transaction-resubmission.md.c43abb47.lean.js => how-to-guides_transaction-resubmission.md.075e6fb0.lean.js} (92%) rename pr-1815/assets/{how-to-guides_validator-node.md.e6b62962.js => how-to-guides_validator-node.md.5e3cb47d.js} (96%) rename pr-1815/assets/{how-to-guides_validator-node.md.e6b62962.lean.js => how-to-guides_validator-node.md.5e3cb47d.lean.js} (76%) rename pr-1815/assets/{index.md.301f8cf4.js => index.md.5f15dd4a.js} (96%) rename pr-1815/assets/{index.md.301f8cf4.lean.js => index.md.5f15dd4a.lean.js} (96%) rename pr-1815/assets/{learn_how-celestia-works_data-availability-faq.md.05200684.js => learn_how-celestia-works_data-availability-faq.md.7e26d360.js} (99%) rename pr-1815/assets/{learn_how-celestia-works_data-availability-faq.md.05200684.lean.js => learn_how-celestia-works_data-availability-faq.md.7e26d360.lean.js} (93%) rename pr-1815/assets/{learn_how-celestia-works_data-availability-layer.md.95575ef0.js => learn_how-celestia-works_data-availability-layer.md.4b8bfd66.js} (99%) rename pr-1815/assets/{learn_how-celestia-works_data-availability-layer.md.95575ef0.lean.js => learn_how-celestia-works_data-availability-layer.md.4b8bfd66.lean.js} (99%) rename pr-1815/assets/{learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.js => learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.js} (98%) rename pr-1815/assets/{learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.lean.js => learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.lean.js} (93%) rename pr-1815/assets/{learn_how-celestia-works_overview.md.91ddd823.js => learn_how-celestia-works_overview.md.ed78821c.js} (97%) rename pr-1815/assets/{learn_how-celestia-works_overview.md.91ddd823.lean.js => learn_how-celestia-works_overview.md.ed78821c.lean.js} (90%) rename pr-1815/assets/{learn_how-celestia-works_transaction-lifecycle.md.c8f48715.js => learn_how-celestia-works_transaction-lifecycle.md.dbc95259.js} (99%) rename pr-1815/assets/{learn_how-celestia-works_transaction-lifecycle.md.c8f48715.lean.js => learn_how-celestia-works_transaction-lifecycle.md.dbc95259.lean.js} (99%) rename pr-1815/assets/{learn_how-to-stake-tia.md.0f1811ff.js => learn_how-to-stake-tia.md.961588e1.js} (98%) rename pr-1815/assets/{learn_how-to-stake-tia.md.0f1811ff.lean.js => learn_how-to-stake-tia.md.961588e1.lean.js} (91%) rename pr-1815/assets/{learn_paying-for-blobspace.md.c34353bd.js => learn_paying-for-blobspace.md.119c2d85.js} (97%) rename pr-1815/assets/{learn_paying-for-blobspace.md.c34353bd.lean.js => learn_paying-for-blobspace.md.119c2d85.lean.js} (90%) rename pr-1815/assets/{learn_retrievability.md.2e5aa538.js => learn_retrievability.md.d172ae26.js} (98%) rename pr-1815/assets/{learn_retrievability.md.2e5aa538.lean.js => learn_retrievability.md.d172ae26.lean.js} (92%) rename pr-1815/assets/{learn_staking-governance-supply.md.8e42e486.js => learn_staking-governance-supply.md.315bdc22.js} (99%) rename pr-1815/assets/{learn_staking-governance-supply.md.8e42e486.lean.js => learn_staking-governance-supply.md.315bdc22.lean.js} (93%) rename pr-1815/assets/{learn_staking.md.7608d6a2.js => learn_staking.md.4211cf86.js} (97%) rename pr-1815/assets/{learn_staking.md.7608d6a2.lean.js => learn_staking.md.4211cf86.lean.js} (91%) rename pr-1815/assets/{learn_tia.md.e94f8580.js => learn_tia.md.8cf214a7.js} (99%) rename pr-1815/assets/{learn_tia.md.e94f8580.lean.js => learn_tia.md.8cf214a7.lean.js} (97%) rename pr-1815/assets/{tutorials_celestia-node-key.md.369cf494.js => tutorials_celestia-node-key.md.30b8a442.js} (98%) rename pr-1815/assets/{tutorials_celestia-node-key.md.369cf494.lean.js => tutorials_celestia-node-key.md.30b8a442.lean.js} (96%) rename pr-1815/assets/{tutorials_golang-client-tutorial.md.7cc06461.js => tutorials_golang-client-tutorial.md.24f89eb7.js} (99%) rename pr-1815/assets/{tutorials_golang-client-tutorial.md.7cc06461.lean.js => tutorials_golang-client-tutorial.md.24f89eb7.lean.js} (90%) rename pr-1815/assets/{tutorials_integrate-celestia.md.5881eeca.js => tutorials_integrate-celestia.md.2c9ea427.js} (98%) rename pr-1815/assets/{tutorials_integrate-celestia.md.5881eeca.lean.js => tutorials_integrate-celestia.md.2c9ea427.lean.js} (93%) rename pr-1815/assets/{tutorials_node-api.md.60c7bf4f.js => tutorials_node-api.md.42cef958.js} (96%) rename pr-1815/assets/{tutorials_node-api.md.60c7bf4f.lean.js => tutorials_node-api.md.42cef958.lean.js} (81%) rename pr-1815/assets/{tutorials_node-tutorial.md.577dbc08.js => tutorials_node-tutorial.md.bebac79b.js} (99%) rename pr-1815/assets/{tutorials_node-tutorial.md.577dbc08.lean.js => tutorials_node-tutorial.md.bebac79b.lean.js} (94%) rename pr-1815/assets/{tutorials_prompt-scavenger.md.40cac2ec.js => tutorials_prompt-scavenger.md.65befca9.js} (99%) rename pr-1815/assets/{tutorials_prompt-scavenger.md.40cac2ec.lean.js => tutorials_prompt-scavenger.md.65befca9.lean.js} (92%) rename pr-1815/assets/{tutorials_rust-client-tutorial.md.17a60e73.js => tutorials_rust-client-tutorial.md.a22c75a7.js} (99%) rename pr-1815/assets/{tutorials_rust-client-tutorial.md.17a60e73.lean.js => tutorials_rust-client-tutorial.md.a22c75a7.lean.js} (91%) rename pr-1815/assets/{tutorials_wallets.md.a064e878.js => tutorials_wallets.md.8dad253d.js} (92%) rename pr-1815/assets/{tutorials_wallets.md.a064e878.lean.js => tutorials_wallets.md.8dad253d.lean.js} (67%) diff --git a/pr-1815/404.html b/pr-1815/404.html index b7d2cf725..9f070db27 100644 --- a/pr-1815/404.html +++ b/pr-1815/404.html @@ -7,7 +7,7 @@ - + @@ -43,7 +43,7 @@

404

PAGE NOT FOUND

But if you don't change your direction, and if you keep looking, you may end up where you are heading.
- + \ No newline at end of file diff --git a/pr-1815/README.html b/pr-1815/README.html index 2d35b17b2..0aaf5377c 100644 --- a/pr-1815/README.html +++ b/pr-1815/README.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

Deploy

Celestia Documentation Site

Welcome to the official documentation repository for Celestia.

Here you'll find comprehensive guides, tutorials, and reference materials to help you make the most out of Celestia.

Building the site

To get started, clone the repository and run the following:

bash
yarn && yarn dev
yarn && yarn dev

This documentation site is built with VitePress

Contribution Guidelines

We love contributions from the community! Whether you're fixing typos, improving content clarity, or adding new topics, every contribution helps.

  • Fork & clone: Fork this repository and clone it to your local machine.
  • Branch: Always create a new branch for your changes. Naming it relevantly.
  • Commit Changes: Make your changes and commit them with a clear and concise commit message.
  • Push & Create PR: Push your changes to your fork and create a pull request to the main branch of this repository.

Please ensure to review the detailed Contribution Guidelines above before making a pull request.

Directory Structure

  • /learn: A category for learning about Celestia.
  • /how-to guides: A category with guides for running a node, deploying rollups, and building on Celestia.
  • /tutorials: A category with tutorials on interacting with celestia-node.
  • /community: A category for the Celestia community.
  • /public: Images, diagrams, and other media files used in the documentation.

Feedback & Suggestions

We value feedback from the community. If you have suggestions for improvements or find any discrepancies in the documentation, please raise an issue in this repository.

- +

Deploy

Celestia Documentation Site

Welcome to the official documentation repository for Celestia.

Here you'll find comprehensive guides, tutorials, and reference materials to help you make the most out of Celestia.

Building the site

To get started, clone the repository and run the following:

bash
yarn && yarn dev
yarn && yarn dev

This documentation site is built with VitePress

Contribution Guidelines

We love contributions from the community! Whether you're fixing typos, improving content clarity, or adding new topics, every contribution helps.

  • Fork & clone: Fork this repository and clone it to your local machine.
  • Branch: Always create a new branch for your changes. Naming it relevantly.
  • Commit Changes: Make your changes and commit them with a clear and concise commit message.
  • Push & Create PR: Push your changes to your fork and create a pull request to the main branch of this repository.

Please ensure to review the detailed Contribution Guidelines above before making a pull request.

Directory Structure

  • /learn: A category for learning about Celestia.
  • /how-to guides: A category with guides for running a node, deploying rollups, and building on Celestia.
  • /tutorials: A category with tutorials on interacting with celestia-node.
  • /community: A category for the Celestia community.
  • /public: Images, diagrams, and other media files used in the documentation.

Feedback & Suggestions

We value feedback from the community. If you have suggestions for improvements or find any discrepancies in the documentation, please raise an issue in this repository.

+ \ No newline at end of file diff --git a/pr-1815/assets/README.md.cdbe601e.js b/pr-1815/assets/README.md.4cad7400.js similarity index 98% rename from pr-1815/assets/README.md.cdbe601e.js rename to pr-1815/assets/README.md.4cad7400.js index 7d18ed4e4..3cd2a7172 100644 --- a/pr-1815/assets/README.md.cdbe601e.js +++ b/pr-1815/assets/README.md.4cad7400.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia Documentation Site | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1732776394000}'),i={name:"README.md"},s=o('

Deploy

Celestia Documentation Site

Welcome to the official documentation repository for Celestia.

Here you'll find comprehensive guides, tutorials, and reference materials to help you make the most out of Celestia.

Building the site

To get started, clone the repository and run the following:

bash
yarn && yarn dev
yarn && yarn dev

This documentation site is built with VitePress

Contribution Guidelines

We love contributions from the community! Whether you're fixing typos, improving content clarity, or adding new topics, every contribution helps.

Please ensure to review the detailed Contribution Guidelines above before making a pull request.

Directory Structure

Feedback & Suggestions

We value feedback from the community. If you have suggestions for improvements or find any discrepancies in the documentation, please raise an issue in this repository.

',17),n=[s];function r(l,c,u,p,d,h){return t(),a("div",null,n)}const y=e(i,[["render",r]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia Documentation Site | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1732777479000}'),i={name:"README.md"},s=o('

Deploy

Celestia Documentation Site

Welcome to the official documentation repository for Celestia.

Here you'll find comprehensive guides, tutorials, and reference materials to help you make the most out of Celestia.

Building the site

To get started, clone the repository and run the following:

bash
yarn && yarn dev
yarn && yarn dev

This documentation site is built with VitePress

Contribution Guidelines

We love contributions from the community! Whether you're fixing typos, improving content clarity, or adding new topics, every contribution helps.

Please ensure to review the detailed Contribution Guidelines above before making a pull request.

Directory Structure

Feedback & Suggestions

We value feedback from the community. If you have suggestions for improvements or find any discrepancies in the documentation, please raise an issue in this repository.

',17),n=[s];function r(l,c,u,p,d,h){return t(),a("div",null,n)}const y=e(i,[["render",r]]);export{g as __pageData,y as default}; diff --git a/pr-1815/assets/README.md.cdbe601e.lean.js b/pr-1815/assets/README.md.4cad7400.lean.js similarity index 89% rename from pr-1815/assets/README.md.cdbe601e.lean.js rename to pr-1815/assets/README.md.4cad7400.lean.js index b3ed58501..0436d1d5a 100644 --- a/pr-1815/assets/README.md.cdbe601e.lean.js +++ b/pr-1815/assets/README.md.4cad7400.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia Documentation Site | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1732776394000}'),i={name:"README.md"},s=o("",17),n=[s];function r(l,c,u,p,d,h){return t(),a("div",null,n)}const y=e(i,[["render",r]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia Documentation Site | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1732777479000}'),i={name:"README.md"},s=o("",17),n=[s];function r(l,c,u,p,d,h){return t(),a("div",null,n)}const y=e(i,[["render",r]]);export{g as __pageData,y as default}; diff --git a/pr-1815/assets/app.654e7bad.js b/pr-1815/assets/app.d97c7bc6.js similarity index 95% rename from pr-1815/assets/app.654e7bad.js rename to pr-1815/assets/app.d97c7bc6.js index 32b4889f0..51ec71b14 100644 --- a/pr-1815/assets/app.654e7bad.js +++ b/pr-1815/assets/app.d97c7bc6.js @@ -1 +1 @@ -import{a3 as i,s,a4 as c,a5 as l,a6 as d,a7 as f,a8 as m,a9 as h,aa as A,ab as g,ac as y,ad as P,X as v,d as w,u as C,j as R,y as _,ae as b,af as D,ag as E}from"./chunks/framework.2959b752.js";import{t as p}from"./chunks/theme.7287e00e.js";const L={extends:p,Layout:()=>i(p.Layout,null,{}),enhanceApp({app:e,router:a,siteData:t}){}};function u(e){if(e.extends){const a=u(e.extends);return{...a,...e,async enhanceApp(t){a.enhanceApp&&await a.enhanceApp(t),e.enhanceApp&&await e.enhanceApp(t)}}}return e}const o=u(L),T=w({name:"VitePressApp",setup(){const{site:e}=C();return R(()=>{_(()=>{document.documentElement.lang=e.value.lang,document.documentElement.dir=e.value.dir})}),b(),D(),E(),o.setup&&o.setup(),()=>i(o.Layout)}});async function j(){const e=O(),a=x();a.provide(l,e);const t=d(e.route);return a.provide(f,t),a.component("Content",m),a.component("ClientOnly",h),Object.defineProperties(a.config.globalProperties,{$frontmatter:{get(){return t.frontmatter.value}},$params:{get(){return t.page.value.params}}}),o.enhanceApp&&await o.enhanceApp({app:a,router:e,siteData:A}),{app:a,router:e,data:t}}function x(){return g(T)}function O(){let e=s,a;return y(t=>{let n=P(t),r=null;return n&&(e&&(a=n),(e||a===n)&&(n=n.replace(/\.js$/,".lean.js")),r=v(()=>import(n),[])),s&&(e=!1),r},o.NotFound)}s&&j().then(({app:e,router:a,data:t})=>{a.go().then(()=>{c(a.route,t.site),e.mount("#app")})});export{j as createApp}; +import{a3 as i,s,a4 as c,a5 as l,a6 as d,a7 as f,a8 as m,a9 as h,aa as A,ab as g,ac as y,ad as P,X as v,d as w,u as C,j as R,y as _,ae as b,af as D,ag as E}from"./chunks/framework.2959b752.js";import{t as p}from"./chunks/theme.b7c4765b.js";const L={extends:p,Layout:()=>i(p.Layout,null,{}),enhanceApp({app:e,router:a,siteData:t}){}};function u(e){if(e.extends){const a=u(e.extends);return{...a,...e,async enhanceApp(t){a.enhanceApp&&await a.enhanceApp(t),e.enhanceApp&&await e.enhanceApp(t)}}}return e}const o=u(L),T=w({name:"VitePressApp",setup(){const{site:e}=C();return R(()=>{_(()=>{document.documentElement.lang=e.value.lang,document.documentElement.dir=e.value.dir})}),b(),D(),E(),o.setup&&o.setup(),()=>i(o.Layout)}});async function j(){const e=O(),a=x();a.provide(l,e);const t=d(e.route);return a.provide(f,t),a.component("Content",m),a.component("ClientOnly",h),Object.defineProperties(a.config.globalProperties,{$frontmatter:{get(){return t.frontmatter.value}},$params:{get(){return t.page.value.params}}}),o.enhanceApp&&await o.enhanceApp({app:a,router:e,siteData:A}),{app:a,router:e,data:t}}function x(){return g(T)}function O(){let e=s,a;return y(t=>{let n=P(t),r=null;return n&&(e&&(a=n),(e||a===n)&&(n=n.replace(/\.js$/,".lean.js")),r=v(()=>import(n),[])),s&&(e=!1),r},o.NotFound)}s&&j().then(({app:e,router:a,data:t})=>{a.go().then(()=>{c(a.route,t.site),e.mount("#app")})});export{j as createApp}; diff --git a/pr-1815/assets/chunks/@localSearchIndexroot.4cbbec6e.js b/pr-1815/assets/chunks/@localSearchIndexroot.4cbbec6e.js new file mode 100644 index 000000000..98d9a6d65 --- /dev/null +++ b/pr-1815/assets/chunks/@localSearchIndexroot.4cbbec6e.js @@ -0,0 +1 @@ +const e='{"documentCount":787,"nextId":787,"documentIds":{"0":"/docs-preview/pr-1815/README#celestia-documentation-site","1":"/docs-preview/pr-1815/README#building-the-site","2":"/docs-preview/pr-1815/README#contribution-guidelines","3":"/docs-preview/pr-1815/README#directory-structure","4":"/docs-preview/pr-1815/README#feedback-suggestions","5":"/docs-preview/pr-1815/community/coc#celestia-org-code-of-conduct","6":"/docs-preview/pr-1815/community/coc#our-pledge","7":"/docs-preview/pr-1815/community/coc#our-standards","8":"/docs-preview/pr-1815/community/coc#enforcement-responsibilities","9":"/docs-preview/pr-1815/community/coc#scope","10":"/docs-preview/pr-1815/community/coc#enforcement","11":"/docs-preview/pr-1815/community/coc#enforcement-guidelines","12":"/docs-preview/pr-1815/community/coc#_1-correction","13":"/docs-preview/pr-1815/community/coc#_2-warning","14":"/docs-preview/pr-1815/community/coc#_3-temporary-ban","15":"/docs-preview/pr-1815/community/coc#_4-permanent-ban","16":"/docs-preview/pr-1815/community/coc#attribution","17":"/docs-preview/pr-1815/community/foundation-delegation-program#the-celestia-foundation-delegation-program","18":"/docs-preview/pr-1815/community/foundation-delegation-program#objectives-of-the-program","19":"/docs-preview/pr-1815/community/foundation-delegation-program#foundation-delegation-process","20":"/docs-preview/pr-1815/community/foundation-delegation-program#program-launch","21":"/docs-preview/pr-1815/community/foundation-delegation-program#cohort-process","22":"/docs-preview/pr-1815/community/foundation-delegation-program#key-points","23":"/docs-preview/pr-1815/community/foundation-delegation-program#eligibility-criteria","24":"/docs-preview/pr-1815/community/foundation-delegation-program#undelegation-criteria","25":"/docs-preview/pr-1815/community/foundation-delegation-program#application","26":"/docs-preview/pr-1815/community/foundation-delegation-program#application-details","27":"/docs-preview/pr-1815/community/foundation-delegation-program#cohort-information","28":"/docs-preview/pr-1815/community/foundation-delegation-program#feedback-process","29":"/docs-preview/pr-1815/community/modular-meetup-guide#modular-meetup-guide","30":"/docs-preview/pr-1815/community/modular-meetup-guide#before-the-meetup","31":"/docs-preview/pr-1815/community/modular-meetup-guide#during-the-meetup","32":"/docs-preview/pr-1815/community/modular-meetup-guide#after-the-meetup","33":"/docs-preview/pr-1815/community/modular-meetup-guide#logistics-and-guidance","34":"/docs-preview/pr-1815/community/modular-meetup-guide#venue","35":"/docs-preview/pr-1815/community/modular-meetup-guide#catering-and-refreshments","36":"/docs-preview/pr-1815/community/modular-meetup-guide#audience","37":"/docs-preview/pr-1815/community/modular-meetup-guide#speakers","38":"/docs-preview/pr-1815/community/modular-meetup-guide#sponsors","39":"/docs-preview/pr-1815/community/modular-meetup-guide#communications-and-marketing","40":"/docs-preview/pr-1815/community/modular-meetup-guide#recording","41":"/docs-preview/pr-1815/community/modular-meetup-guide#utilizing-meetup-com-platform","42":"/docs-preview/pr-1815/community/modular-meetup-guide#onboarding-questions-for-community-members-joining-a-modular-meetup","43":"/docs-preview/pr-1815/community/modular-meetup-intro#celestia-modular-meetup-program","44":"/docs-preview/pr-1815/community/modular-meetup-intro#program-description","45":"/docs-preview/pr-1815/community/modular-meetup-intro#important-info","46":"/docs-preview/pr-1815/community/modular-meetup-intro#celestia-org-community-code-of-conduct","47":"/docs-preview/pr-1815/community/modular-meetup-intro#signup-form","48":"/docs-preview/pr-1815/community/modular-meetup-intro#emails","49":"/docs-preview/pr-1815/community/modular-meetup-intro#discord","50":"/docs-preview/pr-1815/community/modular-meetup-intro#materials","51":"/docs-preview/pr-1815/community/modular-meetup-toolkit#modular-meetup-toolkit","52":"/docs-preview/pr-1815/community/modular-meetup-toolkit#celestia-branding-guidelines","53":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-introduction-to-modularity-workshop-presentation","54":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-run-a-celestia-light-node-workshop-presentation","55":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-deploy-a-sovereign-rollup-workshop-presentation","56":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-modular-meetup-introduction-workshop-presentation","57":"/docs-preview/pr-1815/community/modular-meetup-toolkit#swag-logistics","58":"/docs-preview/pr-1815/community/speaker-list#speaker-list","59":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#arabica-devnet","60":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#network-stability-and-upgrades","61":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#network-details","62":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#software-version-numbers","63":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#integrations","64":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#production-rpc-endpoints","65":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#community-rpc-endpoints","66":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#using-consensus-endpoints-with-da-nodes","67":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#data-availability-da-rpc-endpoints-for-bridge-node-sync","68":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#data-availability-da-grpc-endpoints-for-state-access","69":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#arabica-devnet-faucet","70":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#discord","71":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#web","72":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#explorers","73":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#network-upgrades","74":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#bridging-in-and-out-of-your-orbit-rollup","75":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#bridge-in-deposit-to-your-rollup","76":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-1-add-your-custom-chain-config","77":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-2-deposit-to-your-orbit-rollup","78":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#bridge-out-withdrawal-from-your-rollup","79":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-1-choose-an-amount-to-withdraw-from-your-rollup","80":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-2-claim-your-withdrawal","81":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#quickstart-deploy-an-arbitrum-orbit-rollup","82":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#prerequisites","83":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#setup","84":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-1-acquire-arbitrum-sepolia-eth","85":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-2-pick-your-deployment-type","86":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-3-configure-your-orbit-chain-s-deployment","87":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-4-review-deploy-your-orbit-chain","88":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-5-download-your-chain-s-configuration-files-and-launch-your-chain","89":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-6-clone-the-setup-script-repository-and-add-your-configuration-files","90":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-7-pick-an-l2-rpc-url-for-the-batch-poster","91":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-8-run-your-light-node-for-mocha-testnet","92":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-9-run-your-chain-s-node-and-block-explorer","93":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-10-finish-setting-up-your-chain","94":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#congratulations-with-celestia-underneath","95":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#appendix","96":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#compatibility-matrix","97":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#blobstream-x-contract-deployments","98":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#arbitrum-sepolia","99":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#base-sepolia","100":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#arbitrum-sepolia-additional-deployments","101":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#base-sepolia-additional-deployments","102":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#running-a-full-node-and-or-validator","103":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#prerequisites","104":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#running-a-full-node","105":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#running-a-full-node-with-validation","106":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#introduction-to-arbitrum-rollups-with-celestia-as-da","107":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#overview","108":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#key-components","109":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#da-provider-implementation","110":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#preimage-oracle-implementation","111":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#blobstream-x-implementation","112":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#ethereum-fallback-mechanism-in-nitro","113":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#next-steps","114":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#integrate-with-blobstream-contracts","115":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#getting-started","116":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#prerequisites","117":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#installing-blobstream-contracts","118":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#example-usage","119":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#data-structures","120":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#interface","121":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#querying-the-proof","122":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#verifying-data-inclusion-for-fraud-proofs","123":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#integrate-with-blobstream-client","124":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#blobstream-demo-rollup","125":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#defining-a-chain","126":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#rollup-sequencer","127":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#committing-to-data","128":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#creating-blocks","129":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#rollup-full-node","130":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#downloading-the-block","131":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#more-documentation","132":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#proving-inclusion-via-blobstream","133":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#submitting-block-data-to-celestia-via-light-node","134":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#posting-headers-to-ethereum","135":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#blobstream-proofs-queries","136":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#prerequisites","137":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#overview-of-the-proof-queries","138":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#the-celestia-square","139":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#the-commitment-scheme","140":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#hands-on-demonstration","141":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#_1-data-root-inclusion-proof","142":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#http-query","143":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client","144":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#full-example-of-proving-that-a-celestia-block-was-committed-to-by-blobstream-contract","145":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#_2-transaction-inclusion-proof","146":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#transaction-inclusion-proof-using-the-transaction-hash","147":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#http-request","148":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client-1","149":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#blob-inclusion-proof-using-the-corresponding-pfb-transaction-hash","150":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client-2","151":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#specific-share-range-inclusion-proof","152":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#http-request-1","153":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client-3","154":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#converting-the-proofs-to-be-usable-in-the-daverifier-library","155":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#data","156":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#shareproofs","157":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#namespace","158":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#rowroots","159":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#rowproofs","160":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#attestationproof","161":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#querying-the-proof-s-tuplerootnonce","162":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#listening-for-new-data-commitments","163":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#example-rollup-that-uses-the-daverifier","164":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#conclusion","165":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#introduction-to-blobstream-rollups","166":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#concepts","167":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment","168":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-proof-details","169":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-compact-proofs","170":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-pros","171":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-cons","172":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans","173":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-proof-details","174":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-proving-unavailable-data","175":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-proving-inclusion-of-some-data","176":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-pros","177":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-cons","178":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups","179":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans","180":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-pros","181":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-cons","182":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-example","183":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments","184":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-pros","185":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-cons","186":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups","187":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-sequence-of-spans","188":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-pros","189":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-cons","190":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-blob-share-commitments","191":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#protobuf-deserialization-inside-a-zk-circuit","192":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-pros","193":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-cons","194":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#heavy-merkle-proofs-usage","195":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#heavy-merkle-proofs-usage-pros","196":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#heavy-merkle-proofs-usage-cons","197":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#conclusion","198":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#faq","199":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#should-i-use-the-celestia-transaction-hash-to-reference-the-rollup-data","200":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#new-blobstream-x-deployments","201":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploying-the-contracts","202":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploy-a-new-succinctgateway","203":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploy-the-function-verifiers","204":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#register-the-function-verifier-in-the-deployed-succinctgateway","205":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#enable-prover-whitelisting","206":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#set-whitelist-status","207":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#add-custom-prover","208":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploy-the-blobstreamx-contract","209":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#querying-the-trusted-hash","210":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deployment-instructions","211":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#run-a-local-prover","212":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#run-a-proof-replayer-from-an-existing-deployment","213":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#optional-regenerating-the-downloaded-artifacts","214":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#regenerate-the-verifier-build","215":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#build-the-circuits-and-function-verifiers","216":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#requesting-data-commitment-ranges","217":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#local-proving","218":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#request-proofs-from-the-succinct-platform","219":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#request-proofs-onchain","220":"/docs-preview/pr-1815/how-to-guides/blobstream#blobstream-streaming-modular-da-to-ethereum","221":"/docs-preview/pr-1815/how-to-guides/blobstream#what-is-blobstream","222":"/docs-preview/pr-1815/how-to-guides/blobstream#implementations-of-blobstream","223":"/docs-preview/pr-1815/how-to-guides/blobstream#blobstream-vs-data-availability-committees-dacs","224":"/docs-preview/pr-1815/how-to-guides/blobstream#decentralization-and-security","225":"/docs-preview/pr-1815/how-to-guides/blobstream#mechanism-of-verification","226":"/docs-preview/pr-1815/how-to-guides/blobstream#flexibility-and-scalability","227":"/docs-preview/pr-1815/how-to-guides/blobstream#what-is-sp1-blobstream","228":"/docs-preview/pr-1815/how-to-guides/blobstream#integrate-with-sp1-blobstream","229":"/docs-preview/pr-1815/how-to-guides/blobstream#how-to-integrate-with-blobstream","230":"/docs-preview/pr-1815/how-to-guides/blobstream#blobstream-rollups","231":"/docs-preview/pr-1815/how-to-guides/blobstream#deployed-contracts","232":"/docs-preview/pr-1815/how-to-guides/blobstreamx#blobstream-x-the-previous-zk-implementation-of-blobstream","233":"/docs-preview/pr-1815/how-to-guides/blobstreamx#what-is-blobstream-x","234":"/docs-preview/pr-1815/how-to-guides/blobstreamx#how-blobstream-x-works","235":"/docs-preview/pr-1815/how-to-guides/blobstreamx#deploy-blobstream-x","236":"/docs-preview/pr-1815/how-to-guides/blobstreamx#community-implementations","237":"/docs-preview/pr-1815/how-to-guides/bridge-node#setting-up-a-celestia-bridge-node","238":"/docs-preview/pr-1815/how-to-guides/bridge-node#overview-of-bridge-nodes","239":"/docs-preview/pr-1815/how-to-guides/bridge-node#hardware-requirements","240":"/docs-preview/pr-1815/how-to-guides/bridge-node#setting-up-your-bridge-node","241":"/docs-preview/pr-1815/how-to-guides/bridge-node#setup-the-dependencies","242":"/docs-preview/pr-1815/how-to-guides/bridge-node#deploy-the-celestia-bridge-node","243":"/docs-preview/pr-1815/how-to-guides/bridge-node#install-celestia-node","244":"/docs-preview/pr-1815/how-to-guides/bridge-node#initialize-the-bridge-node","245":"/docs-preview/pr-1815/how-to-guides/bridge-node#run-the-bridge-node","246":"/docs-preview/pr-1815/how-to-guides/bridge-node#optional-run-the-bridge-node-with-a-custom-key","247":"/docs-preview/pr-1815/how-to-guides/bridge-node#optional-migrate-node-id-to-another-server","248":"/docs-preview/pr-1815/how-to-guides/bridge-node#optional-start-the-bridge-node-with-systemd","249":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#bubs-testnet","250":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#built-with-the-op-stack-and-celestia","251":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#building-on-bubs","252":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#rpc-urls","253":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#https","254":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#wss","255":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#bridge","256":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#faucet","257":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#explorer","258":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#status","259":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#next-steps","260":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#helpful-cli-commands","261":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#creating-a-wallet","262":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#key-management","263":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#importing-and-exporting-keys","264":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#querying-subcommands","265":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#token-management","266":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#governance","267":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#community-pool","268":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#claim-validator-rewards","269":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#delegate-undelegate-tokens","270":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#unjailing-the-validator","271":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#how-to-export-logs-with-systemd","272":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#signing-genesis-for-a-new-network","273":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#metrics","274":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#setup","275":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#visualization","276":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#node-exporter","277":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#alerts","278":"/docs-preview/pr-1815/how-to-guides/celestia-app-multisig#multisig","279":"/docs-preview/pr-1815/how-to-guides/celestia-app-multisig#command-line","280":"/docs-preview/pr-1815/how-to-guides/celestia-app-multisig#resources","281":"/docs-preview/pr-1815/how-to-guides/celestia-app-slashing#jailing-and-slashing-on-celestia","282":"/docs-preview/pr-1815/how-to-guides/celestia-app-upgrade-monitor#upgrade-monitor","283":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#how-to-create-a-vesting-account-with-celestia-app","284":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#local-devnet","285":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#setting-up-the-local-devnet","286":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#run-the-devnet","287":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#save-the-home-directory-path","288":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#check-the-version-of-the-devnet","289":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#next-steps","290":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#setting-up-vesting-account-on-devnet","291":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-a-new-key","292":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#list-your-keys","293":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#set-variables","294":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-your-devnet-vesting-account","295":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#query-the-devnet-vesting-account-details","296":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#query-the-devnet-base-account-details","297":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#query-the-balances-of-the-devnet-accounts","298":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#mocha","299":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-a-wallet","300":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#fund-your-account","301":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-a-vesting-account-on-mocha","302":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#optional-set-up-a-consensus-node-or-validator","303":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#optional-change-your-client-toml","304":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#notes","305":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#conclusion","306":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#create-a-wallet-with-celestia-app","307":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#prerequisites","308":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#create-a-wallet","309":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#fund-a-wallet","310":"/docs-preview/pr-1815/how-to-guides/celestia-app#install-celestia-app","311":"/docs-preview/pr-1815/how-to-guides/celestia-app#building-binary-from-source","312":"/docs-preview/pr-1815/how-to-guides/celestia-app#installing-a-pre-built-binary","313":"/docs-preview/pr-1815/how-to-guides/celestia-app#ports","314":"/docs-preview/pr-1815/how-to-guides/celestia-node-custom-networks#custom-networks-and-values","315":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#celestia-node-metrics","316":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#running-metrics-flags","317":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#mainnet-beta","318":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#mocha-testnet","319":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#arabica-devnet","320":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#tls-connections","321":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#metrics-endpoint-design-considerations","322":"/docs-preview/pr-1815/how-to-guides/celestia-node-store-structure#celestia-node-datastore","323":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#troubleshooting","324":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#network-selection","325":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#chain-id","326":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#ports","327":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#changing-the-location-of-your-node-store","328":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#background","329":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#demonstration","330":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#examples","331":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#mainnet-beta-full-and-mocha-light","332":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#mocha-full-and-arabica-light","333":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#using-a-custom-rpc-config-address","334":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#resetting-your-config","335":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#clearing-the-data-store","336":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#fatal-headers-given-to-the-heightsub-are-in-the-wrong-order","337":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#error-too-many-open-files","338":"/docs-preview/pr-1815/how-to-guides/celestia-node-trusted-hash#syncing-a-light-node-from-a-trusted-hash","339":"/docs-preview/pr-1815/how-to-guides/celestia-node-trusted-hash#for-service-operators","340":"/docs-preview/pr-1815/how-to-guides/celestia-node#install-celestia-node","341":"/docs-preview/pr-1815/how-to-guides/celestia-node#installing-from-source","342":"/docs-preview/pr-1815/how-to-guides/celestia-node#installing-a-pre-built-binary","343":"/docs-preview/pr-1815/how-to-guides/celestia-node#installation-options","344":"/docs-preview/pr-1815/how-to-guides/celestia-node#next-steps","345":"/docs-preview/pr-1815/how-to-guides/celestia-node#upgrading-your-binary","346":"/docs-preview/pr-1815/how-to-guides/config-toml#config-toml-guide","347":"/docs-preview/pr-1815/how-to-guides/config-toml#pre-requisites","348":"/docs-preview/pr-1815/how-to-guides/config-toml#viewing-the-help-menu","349":"/docs-preview/pr-1815/how-to-guides/config-toml#understanding-config-toml","350":"/docs-preview/pr-1815/how-to-guides/config-toml#core","351":"/docs-preview/pr-1815/how-to-guides/config-toml#p2p","352":"/docs-preview/pr-1815/how-to-guides/config-toml#bootstrap","353":"/docs-preview/pr-1815/how-to-guides/config-toml#mutual-peers","354":"/docs-preview/pr-1815/how-to-guides/config-toml#services","355":"/docs-preview/pr-1815/how-to-guides/config-toml#trustedhash-and-trustedpeer","356":"/docs-preview/pr-1815/how-to-guides/consensus-node#consensus-node","357":"/docs-preview/pr-1815/how-to-guides/consensus-node#minimum-hardware-requirements","358":"/docs-preview/pr-1815/how-to-guides/consensus-node#set-up-a-consensus-node","359":"/docs-preview/pr-1815/how-to-guides/consensus-node#set-up-the-dependencies","360":"/docs-preview/pr-1815/how-to-guides/consensus-node#install-celestia-app","361":"/docs-preview/pr-1815/how-to-guides/consensus-node#set-up-the-p2p-networks","362":"/docs-preview/pr-1815/how-to-guides/consensus-node#storage-and-pruning-configurations","363":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-connect-a-consensus-node-to-a-bridge-node","364":"/docs-preview/pr-1815/how-to-guides/consensus-node#enable-transaction-indexing","365":"/docs-preview/pr-1815/how-to-guides/consensus-node#retain-all-block-data","366":"/docs-preview/pr-1815/how-to-guides/consensus-node#query-transactions-by-hash","367":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-access-historical-state","368":"/docs-preview/pr-1815/how-to-guides/consensus-node#save-on-storage-requirements","369":"/docs-preview/pr-1815/how-to-guides/consensus-node#sync-types","370":"/docs-preview/pr-1815/how-to-guides/consensus-node#option-1-block-sync","371":"/docs-preview/pr-1815/how-to-guides/consensus-node#option-2-state-sync","372":"/docs-preview/pr-1815/how-to-guides/consensus-node#option-3-quick-sync","373":"/docs-preview/pr-1815/how-to-guides/consensus-node#start-the-consensus-node","374":"/docs-preview/pr-1815/how-to-guides/consensus-node#extra-resources-for-consensus-nodes","375":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-reset-network","376":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-configure-an-rpc-endpoint","377":"/docs-preview/pr-1815/how-to-guides/consensus-node#expose-rpc","378":"/docs-preview/pr-1815/how-to-guides/consensus-node#note-on-external-address","379":"/docs-preview/pr-1815/how-to-guides/consensus-node#restart-the-node","380":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-transaction-indexer-configuration-options","381":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-discard-abci-responses-configuration","382":"/docs-preview/pr-1815/how-to-guides/consensus-node#faq","383":"/docs-preview/pr-1815/how-to-guides/consensus-node#_2-3-committed-an-invalid-block-wrong-block-header-version","384":"/docs-preview/pr-1815/how-to-guides/decide-node#deciding-which-node-to-run","385":"/docs-preview/pr-1815/how-to-guides/decide-node#light-node","386":"/docs-preview/pr-1815/how-to-guides/decide-node#other-da-nodes","387":"/docs-preview/pr-1815/how-to-guides/decide-node#consensus-node","388":"/docs-preview/pr-1815/how-to-guides/docker-images#🐳-docker-setup","389":"/docs-preview/pr-1815/how-to-guides/docker-images#prerequisites","390":"/docs-preview/pr-1815/how-to-guides/docker-images#quick-start","391":"/docs-preview/pr-1815/how-to-guides/docker-images#light-node-setup-with-persistent-storage","392":"/docs-preview/pr-1815/how-to-guides/docker-images#initialize-the-node-store-and-key","393":"/docs-preview/pr-1815/how-to-guides/docker-images#start-the-node","394":"/docs-preview/pr-1815/how-to-guides/docker-images#video-walkthrough","395":"/docs-preview/pr-1815/how-to-guides/docker-images#_2-5-minute-version","396":"/docs-preview/pr-1815/how-to-guides/docker-images#troubleshooting","397":"/docs-preview/pr-1815/how-to-guides/environment#development-environment","398":"/docs-preview/pr-1815/how-to-guides/environment#install-dependencies","399":"/docs-preview/pr-1815/how-to-guides/environment#install-golang","400":"/docs-preview/pr-1815/how-to-guides/ethereum-fallback#ethereum-fallback","401":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#feegrant-module-for-blobs-submission","402":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#overview","403":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#pre-requisites","404":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#introduction","405":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#granting-fee-allowances-using-celestia-node","406":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#feegrant-module-implementation-in-celestia-node","407":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#grant-permission-for-an-allowance-as-a-granter","408":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#using-a-feegrant-allowance-as-a-grantee-in-celestia-node","409":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#checking-account-balances-after-submission","410":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-revoke-permission-for-a-feegrant-allowance-as-a-granter","411":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-submitting-a-blob-from-file-input","412":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-granting-fee-allowances-using-celestia-appd","413":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-checking-the-granter-s-account","414":"/docs-preview/pr-1815/how-to-guides/full-storage-node#setting-up-a-celestia-full-storage-node","415":"/docs-preview/pr-1815/how-to-guides/full-storage-node#overview-of-full-storage-nodes","416":"/docs-preview/pr-1815/how-to-guides/full-storage-node#hardware-requirements","417":"/docs-preview/pr-1815/how-to-guides/full-storage-node#setting-up-your-full-storage-node","418":"/docs-preview/pr-1815/how-to-guides/full-storage-node#setup-the-dependencies","419":"/docs-preview/pr-1815/how-to-guides/full-storage-node#install-celestia-node","420":"/docs-preview/pr-1815/how-to-guides/full-storage-node#run-the-full-storage-node","421":"/docs-preview/pr-1815/how-to-guides/full-storage-node#initialize-the-full-storage-node","422":"/docs-preview/pr-1815/how-to-guides/full-storage-node#start-the-full-storage-node","423":"/docs-preview/pr-1815/how-to-guides/full-storage-node#optional-run-the-full-storage-node-with-a-custom-key","424":"/docs-preview/pr-1815/how-to-guides/full-storage-node#optional-migrate-node-id-to-another-server","425":"/docs-preview/pr-1815/how-to-guides/full-storage-node#optional-start-the-full-storage-node-with-systemd","426":"/docs-preview/pr-1815/how-to-guides/full-storage-node#stop-the-full-storage-node","427":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#ibc-relaying-guide","428":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#hermes","429":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#configuration","430":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#add-relayer-wallets","431":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#verify-configuration-files","432":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#create-a-connection-between-2-chains","433":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#create-clients","434":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#open-connection-over-new-clients","435":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#configure-channels-in-hermes","436":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#start-the-relayer","437":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#transfer","438":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#token-filter","439":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#celestia-app-network-instantiation-guide","440":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#hardware-requirements","441":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#setup-dependencies","442":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#celestia-app-installation","443":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#spin-up-a-celestia-testnet","444":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#optional-reset-working-directory","445":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#initialize-a-working-directory","446":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#create-a-new-key","447":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#add-genesis-account-keyname","448":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#optional-adding-other-validators","449":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#create-the-genesis-transaction-for-new-chain","450":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#creating-the-genesis-json-file","451":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#modify-your-config-file","452":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#add-your-node-as-a-persistent-peer","453":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#instantiate-the-network","454":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#introduction-to-op-stack-integration","455":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#about-the-integration","456":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#github-repository","457":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#next-steps","458":"/docs-preview/pr-1815/how-to-guides/light-node#setting-up-a-celestia-light-node","459":"/docs-preview/pr-1815/how-to-guides/light-node#overview-of-light-nodes","460":"/docs-preview/pr-1815/how-to-guides/light-node#hardware-requirements","461":"/docs-preview/pr-1815/how-to-guides/light-node#quickstart-run-a-light-node-in-your-browser","462":"/docs-preview/pr-1815/how-to-guides/light-node#setting-up-your-light-node","463":"/docs-preview/pr-1815/how-to-guides/light-node#install-celestia-node","464":"/docs-preview/pr-1815/how-to-guides/light-node#initialize-the-light-node","465":"/docs-preview/pr-1815/how-to-guides/light-node#start-the-light-node","466":"/docs-preview/pr-1815/how-to-guides/light-node#keys-and-wallets","467":"/docs-preview/pr-1815/how-to-guides/light-node#testnet-tokens","468":"/docs-preview/pr-1815/how-to-guides/light-node#optional-run-the-light-node-with-a-custom-key","469":"/docs-preview/pr-1815/how-to-guides/light-node#optional-migrate-node-id-to-another-server","470":"/docs-preview/pr-1815/how-to-guides/light-node#optional-start-light-node-with-systemd","471":"/docs-preview/pr-1815/how-to-guides/light-node#data-availability-sampling","472":"/docs-preview/pr-1815/how-to-guides/local-testnet#setting-up-a-celestia-local-testnet","473":"/docs-preview/pr-1815/how-to-guides/local-testnet#prerequisites","474":"/docs-preview/pr-1815/how-to-guides/local-testnet#bash-script","475":"/docs-preview/pr-1815/how-to-guides/local-testnet#manual-setup","476":"/docs-preview/pr-1815/how-to-guides/local-testnet#starting-the-validator-node","477":"/docs-preview/pr-1815/how-to-guides/local-testnet#setting-up-the-bridge-node","478":"/docs-preview/pr-1815/how-to-guides/local-testnet#setting-up-the-light-node","479":"/docs-preview/pr-1815/how-to-guides/local-testnet#funding-and-testing","480":"/docs-preview/pr-1815/how-to-guides/mainnet#mainnet-beta","481":"/docs-preview/pr-1815/how-to-guides/mainnet#network-stability-and-upgrades","482":"/docs-preview/pr-1815/how-to-guides/mainnet#network-details","483":"/docs-preview/pr-1815/how-to-guides/mainnet#software-version-numbers","484":"/docs-preview/pr-1815/how-to-guides/mainnet#network-parameters","485":"/docs-preview/pr-1815/how-to-guides/mainnet#maximum-bytes","486":"/docs-preview/pr-1815/how-to-guides/mainnet#integrations","487":"/docs-preview/pr-1815/how-to-guides/mainnet#production-rpc-endpoints","488":"/docs-preview/pr-1815/how-to-guides/mainnet#consensus-nodes","489":"/docs-preview/pr-1815/how-to-guides/mainnet#community-consensus-rpc-endpoints","490":"/docs-preview/pr-1815/how-to-guides/mainnet#community-api-endpoints","491":"/docs-preview/pr-1815/how-to-guides/mainnet#community-grpc-endpoints","492":"/docs-preview/pr-1815/how-to-guides/mainnet#community-websocket-endpoints","493":"/docs-preview/pr-1815/how-to-guides/mainnet#data-availability-nodes","494":"/docs-preview/pr-1815/how-to-guides/mainnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","495":"/docs-preview/pr-1815/how-to-guides/mainnet#community-data-availability-da-grpc-endpoints-for-state-access","496":"/docs-preview/pr-1815/how-to-guides/mainnet#archival-da-rpc-endpoints","497":"/docs-preview/pr-1815/how-to-guides/mainnet#grove-archival-endpoints","498":"/docs-preview/pr-1815/how-to-guides/mainnet#explorers","499":"/docs-preview/pr-1815/how-to-guides/mainnet#analytics","500":"/docs-preview/pr-1815/how-to-guides/mainnet#network-upgrades","501":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#mocha-testnet","502":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#network-details","503":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#software-version-numbers","504":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#rpc-for-da-bridge-full-and-light-nodes","505":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#production-rpc-endpoints","506":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","507":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-data-availability-da-grpc-endpoints-for-state-access","508":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-rpc-endpoints","509":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-api-endpoints","510":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-grpc-endpoints","511":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-bridge-and-full-node-endpoints","512":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#mocha-testnet-faucet","513":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#analytics","514":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#explorers","515":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#network-upgrades","516":"/docs-preview/pr-1815/how-to-guides/multiaccounts#multiaccounts-feature-for-blobs-submission","517":"/docs-preview/pr-1815/how-to-guides/multiaccounts#overview","518":"/docs-preview/pr-1815/how-to-guides/multiaccounts#running-a-node-with-a-different-default-key-name","519":"/docs-preview/pr-1815/how-to-guides/multiaccounts#submitting-blobs-with-a-different-signer-key-name","520":"/docs-preview/pr-1815/how-to-guides/multiaccounts#option-1-submit-passing-key-name","521":"/docs-preview/pr-1815/how-to-guides/multiaccounts#option-2-submit-passing-signer-address","522":"/docs-preview/pr-1815/how-to-guides/multiaccounts#key-management","523":"/docs-preview/pr-1815/how-to-guides/multiaccounts#creating-a-new-key","524":"/docs-preview/pr-1815/how-to-guides/multiaccounts#importing-an-existing-key","525":"/docs-preview/pr-1815/how-to-guides/multiaccounts#optional-flags-for-write-transactions","526":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#celestia-network-upgrade-process","527":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#network-upgrade-coordination","528":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#upgrade-process","529":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#upcoming-upgrade","530":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#ginger-network-upgrade","531":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#past-upgrades","532":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#lemongrass-network-upgrade","533":"/docs-preview/pr-1815/how-to-guides/nodes-overview#overview-to-running-nodes-on-celestia","534":"/docs-preview/pr-1815/how-to-guides/nodes-overview#recommended-celestia-node-requirements","535":"/docs-preview/pr-1815/how-to-guides/nodes-overview#data-availability-nodes","536":"/docs-preview/pr-1815/how-to-guides/nodes-overview#consensus-nodes","537":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#optimism-devnet-deep-dive","538":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#find-a-transaction","539":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#read-the-transaction-call-data","540":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#find-the-data-on-celestia","541":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#span-batches","542":"/docs-preview/pr-1815/how-to-guides/optimism#run-an-op-stack-rollup-with-celestia-underneath","543":"/docs-preview/pr-1815/how-to-guides/optimism#dependency-setup","544":"/docs-preview/pr-1815/how-to-guides/optimism#setting-up-your-light-node","545":"/docs-preview/pr-1815/how-to-guides/optimism#deploying-a-devnet-to-mocha","546":"/docs-preview/pr-1815/how-to-guides/optimism#deploying-a-testnet-to-an-l1-or-l2-and-mocha","547":"/docs-preview/pr-1815/how-to-guides/optimism#congratulations","548":"/docs-preview/pr-1815/how-to-guides/participate#participate-in-the-celestia-networks","549":"/docs-preview/pr-1815/how-to-guides/participate#mainnet-beta","550":"/docs-preview/pr-1815/how-to-guides/participate#compatible-software-versions-for-mainnet-beta","551":"/docs-preview/pr-1815/how-to-guides/participate#testnets","552":"/docs-preview/pr-1815/how-to-guides/participate#arabica-devnet","553":"/docs-preview/pr-1815/how-to-guides/participate#compatible-software-versions-for-arabica-devnet","554":"/docs-preview/pr-1815/how-to-guides/participate#mocha-testnet","555":"/docs-preview/pr-1815/how-to-guides/participate#compatible-software-versions-for-mocha-testnet","556":"/docs-preview/pr-1815/how-to-guides/participate#network-upgrades","557":"/docs-preview/pr-1815/how-to-guides/quick-start#quick-start-guide","558":"/docs-preview/pr-1815/how-to-guides/quick-start#run-a-light-node","559":"/docs-preview/pr-1815/how-to-guides/quick-start#initialize-the-light-node","560":"/docs-preview/pr-1815/how-to-guides/quick-start#set-the-trusted-hash","561":"/docs-preview/pr-1815/how-to-guides/quick-start#start-the-light-node","562":"/docs-preview/pr-1815/how-to-guides/quick-start#post-and-retrieve-data-with-your-light-node","563":"/docs-preview/pr-1815/how-to-guides/quick-start#funding-your-light-node","564":"/docs-preview/pr-1815/how-to-guides/quick-start#posting-data","565":"/docs-preview/pr-1815/how-to-guides/quick-start#retrieving-data","566":"/docs-preview/pr-1815/how-to-guides/quick-start#diving-deeper-into-the-stack","567":"/docs-preview/pr-1815/how-to-guides/quick-start#get-your-auth-token","568":"/docs-preview/pr-1815/how-to-guides/quick-start#key-management-with-cel-key","569":"/docs-preview/pr-1815/how-to-guides/quick-start#rust-client-tutorial","570":"/docs-preview/pr-1815/how-to-guides/quick-start#golang-client-tutorial","571":"/docs-preview/pr-1815/how-to-guides/quick-start#node-store-contents","572":"/docs-preview/pr-1815/how-to-guides/quick-start#troubleshooting","573":"/docs-preview/pr-1815/how-to-guides/quick-start#next-steps","574":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#rollup-stacks","575":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#quickstart-building-on-celestia","576":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#choose-a-framework","577":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#rollups-as-a-service","578":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#smart-contracts","579":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#what-is-a-rollup","580":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#what-is-a-modular-blockchain","581":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#benefits-of-modular-blockchains","582":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#ease-of-deploying-a-chain","583":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#scaling","584":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#customizability","585":"/docs-preview/pr-1815/how-to-guides/sp1-blobstream-deploy#new-sp1-blobstream-deployments","586":"/docs-preview/pr-1815/how-to-guides/sp1-blobstream-deploy#deploying-the-contracts","587":"/docs-preview/pr-1815/how-to-guides/submit-data#submitting-data-blobs-to-celestia","588":"/docs-preview/pr-1815/how-to-guides/submit-data#maximum-blob-size","589":"/docs-preview/pr-1815/how-to-guides/submit-data#fee-market-and-mempool","590":"/docs-preview/pr-1815/how-to-guides/submit-data#fees-and-gas-limits","591":"/docs-preview/pr-1815/how-to-guides/submit-data#estimating-pfb-gas","592":"/docs-preview/pr-1815/how-to-guides/submit-data#gas-fee-calculation","593":"/docs-preview/pr-1815/how-to-guides/submit-data#estimating-gas-programmatically","594":"/docs-preview/pr-1815/how-to-guides/submit-data#submitting-multiple-transactions-in-one-block-from-the-same-account","595":"/docs-preview/pr-1815/how-to-guides/submit-data#api","596":"/docs-preview/pr-1815/how-to-guides/submit-data#the-celestia-app-consensus-node-cli","597":"/docs-preview/pr-1815/how-to-guides/submit-data#the-celestia-node-light-node-cli","598":"/docs-preview/pr-1815/how-to-guides/submit-data#the-celestia-node-api-golang-client","599":"/docs-preview/pr-1815/how-to-guides/submit-data#grpc-to-a-consensus-node-via-the-user-package","600":"/docs-preview/pr-1815/how-to-guides/submit-data#rpc-to-a-celestia-node","601":"/docs-preview/pr-1815/how-to-guides/submit-data#post-a-blob-directly-from-celenium","602":"/docs-preview/pr-1815/how-to-guides/systemd#setting-up-your-node-as-a-background-process-with-systemd","603":"/docs-preview/pr-1815/how-to-guides/systemd#consensus-nodes","604":"/docs-preview/pr-1815/how-to-guides/systemd#start-the-celestia-app-with-systemd","605":"/docs-preview/pr-1815/how-to-guides/systemd#data-availability-nodes","606":"/docs-preview/pr-1815/how-to-guides/systemd#celestia-full-storage-node","607":"/docs-preview/pr-1815/how-to-guides/systemd#celestia-bridge-node","608":"/docs-preview/pr-1815/how-to-guides/systemd#celestia-light-node","609":"/docs-preview/pr-1815/how-to-guides/transaction-resubmission#transaction-resubmission","610":"/docs-preview/pr-1815/how-to-guides/transaction-resubmission#monitoring-and-resubmission","611":"/docs-preview/pr-1815/how-to-guides/transaction-resubmission#notes","612":"/docs-preview/pr-1815/how-to-guides/validator-node#setting-up-a-celestia-validator-node","613":"/docs-preview/pr-1815/how-to-guides/validator-node#hardware-requirements","614":"/docs-preview/pr-1815/how-to-guides/validator-node#setting-up-a-validator-node","615":"/docs-preview/pr-1815/how-to-guides/validator-node#wallet","616":"/docs-preview/pr-1815/how-to-guides/validator-node#delegate-stake-to-a-validator","617":"/docs-preview/pr-1815/how-to-guides/validator-node#optional-deploy-the-celestia-node","618":"/docs-preview/pr-1815/how-to-guides/validator-node#install-celestia-node","619":"/docs-preview/pr-1815/how-to-guides/validator-node#initialize-the-bridge-node","620":"/docs-preview/pr-1815/how-to-guides/validator-node#run-the-bridge-node","621":"/docs-preview/pr-1815/how-to-guides/validator-node#optional-start-the-bridge-node-with-systemd","622":"/docs-preview/pr-1815/how-to-guides/validator-node#run-the-validator-node","623":"/docs-preview/pr-1815/how-to-guides/validator-node#submit-your-validator-information","624":"/docs-preview/pr-1815/how-to-guides/validator-node#optional-transaction-indexer-configuration-options","625":"/docs-preview/pr-1815/how-to-guides/validator-node#additional-resources","626":"/docs-preview/pr-1815/how-to-guides/validator-node#faq","627":"/docs-preview/pr-1815/how-to-guides/validator-node#_2-3-committed-an-invalid-block-wrong-block-header-version","628":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#data-availability-faq","629":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-data-availability","630":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-the-data-availability-problem","631":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#how-do-nodes-verify-data-availability-in-celestia","632":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-data-availability-sampling","633":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-are-some-of-the-security-assumptions-that-celestia-makes-for-data-availability-sampling","634":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#why-is-block-reconstruction-necessary-for-security","635":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-data-storage","636":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-the-problem-around-data-storage","637":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-the-difference-between-data-availability-and-data-storage","638":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#where-does-blockchain-state-fit-into-this","639":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#why-doesn-t-celestia-incentivize-storage-of-historical-data","640":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#who-may-store-historical-data-if-there-is-no-reward","641":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-are-some-things-blockchains-can-do-to-provide-stronger-assurances-of-data-retrievability","642":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#celestia-s-data-availability-layer","643":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#data-availability-sampling-das","644":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#scalability","645":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#fraud-proofs-of-incorrectly-extended-data","646":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#namespaced-merkle-trees-nmts","647":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#building-a-pos-blockchain-for-da","648":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#providing-data-availability","649":"/docs-preview/pr-1815/learn/how-celestia-works/monolithic-vs-modular#monolithic-vs-modular-blockchains","650":"/docs-preview/pr-1815/learn/how-celestia-works/overview#introduction","651":"/docs-preview/pr-1815/learn/how-celestia-works/transaction-lifecycle#the-lifecycle-of-a-celestia-app-transaction","652":"/docs-preview/pr-1815/learn/how-celestia-works/transaction-lifecycle#checking-data-availability","653":"/docs-preview/pr-1815/learn/how-to-stake-tia#how-to-stake-tia","654":"/docs-preview/pr-1815/learn/how-to-stake-tia#select-your-preferred-wallet","655":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-tia-with-keplr-wallet","656":"/docs-preview/pr-1815/learn/how-to-stake-tia#open-your-keplr-browser-extension","657":"/docs-preview/pr-1815/learn/how-to-stake-tia#select-celestia-network-and-search-for-a-validator","658":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-your-tia-tokens","659":"/docs-preview/pr-1815/learn/how-to-stake-tia#confirm-and-manage-your-tia","660":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-tia-with-leap-wallet","661":"/docs-preview/pr-1815/learn/how-to-stake-tia#open-your-leap-browser-extension","662":"/docs-preview/pr-1815/learn/how-to-stake-tia#select-a-validator-and-stake-tia","663":"/docs-preview/pr-1815/learn/how-to-stake-tia#confirm-and-manage-your-tia-1","664":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-tia-with-gem-wallet","665":"/docs-preview/pr-1815/learn/how-to-stake-tia#open-your-gem-wallet-app","666":"/docs-preview/pr-1815/learn/how-to-stake-tia#choose-the-amount-of-celestia-and-search-for-a-validator","667":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-your-tia-tokens-1","668":"/docs-preview/pr-1815/learn/how-to-stake-tia#manage-your-tia","669":"/docs-preview/pr-1815/learn/paying-for-blobspace#paying-for-blobspace","670":"/docs-preview/pr-1815/learn/paying-for-blobspace#payforblobs-transactions","671":"/docs-preview/pr-1815/learn/paying-for-blobspace#fee-market-overview","672":"/docs-preview/pr-1815/learn/retrievability#data-retrievability-and-pruning","673":"/docs-preview/pr-1815/learn/retrievability#data-retrievability-and-pruning-in-celestia-node","674":"/docs-preview/pr-1815/learn/retrievability#suggested-practices-for-rollups","675":"/docs-preview/pr-1815/learn/staking-governance-supply#staking-governance-supply","676":"/docs-preview/pr-1815/learn/staking-governance-supply#proof-of-stake-on-celestia","677":"/docs-preview/pr-1815/learn/staking-governance-supply#inflation","678":"/docs-preview/pr-1815/learn/staking-governance-supply#decentralised-governance","679":"/docs-preview/pr-1815/learn/staking-governance-supply#network-parameters","680":"/docs-preview/pr-1815/learn/staking-governance-supply#community-pool","681":"/docs-preview/pr-1815/learn/staking-governance-supply#tia-allocation-at-genesis","682":"/docs-preview/pr-1815/learn/staking-governance-supply#unlocks","683":"/docs-preview/pr-1815/learn/staking#staking-on-celestia","684":"/docs-preview/pr-1815/learn/staking#mainnet-beta","685":"/docs-preview/pr-1815/learn/staking#mocha-testnet","686":"/docs-preview/pr-1815/learn/tia#overview-of-tia","687":"/docs-preview/pr-1815/learn/tia#tia-at-a-glance","688":"/docs-preview/pr-1815/learn/tia#role-of-tia","689":"/docs-preview/pr-1815/learn/tia#paying-for-blobspace","690":"/docs-preview/pr-1815/learn/tia#bootstrapping-new-rollups","691":"/docs-preview/pr-1815/learn/tia#proof-of-stake","692":"/docs-preview/pr-1815/learn/tia#decentralised-governance","693":"/docs-preview/pr-1815/learn/tia#denominations","694":"/docs-preview/pr-1815/learn/tia#tia-display-token","695":"/docs-preview/pr-1815/learn/tia#utia-staking-denomination","696":"/docs-preview/pr-1815/learn/tia#microtia-staking-denomination-alias","697":"/docs-preview/pr-1815/tutorials/celestia-node-key#create-a-wallet-with-celestia-node","698":"/docs-preview/pr-1815/tutorials/celestia-node-key#using-the-cel-key-utility","699":"/docs-preview/pr-1815/tutorials/celestia-node-key#installation","700":"/docs-preview/pr-1815/tutorials/celestia-node-key#steps-for-generating-node-keys","701":"/docs-preview/pr-1815/tutorials/celestia-node-key#steps-for-exporting-node-keys","702":"/docs-preview/pr-1815/tutorials/celestia-node-key#steps-for-importing-node-keys","703":"/docs-preview/pr-1815/tutorials/celestia-node-key#view-all-options-for-cel-key","704":"/docs-preview/pr-1815/tutorials/celestia-node-key#docker-and-cel-key","705":"/docs-preview/pr-1815/tutorials/celestia-node-key#prerequisites","706":"/docs-preview/pr-1815/tutorials/celestia-node-key#running-your-node","707":"/docs-preview/pr-1815/tutorials/celestia-node-key#mounting-existing-keys-to-container","708":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#golang-client-library","709":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#project-setup","710":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#submitting-and-retrieving-blobs","711":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#subscribing-to-new-blobs","712":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#subscribing-to-new-headers","713":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#fetching-an-extended-data-square-eds","714":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#api-documentation","715":"/docs-preview/pr-1815/tutorials/integrate-celestia#integrate-celestia-for-service-providers","716":"/docs-preview/pr-1815/tutorials/integrate-celestia#getting-started","717":"/docs-preview/pr-1815/tutorials/integrate-celestia#celestia-service-provider-notes","718":"/docs-preview/pr-1815/tutorials/integrate-celestia#custody-and-key-management","719":"/docs-preview/pr-1815/tutorials/integrate-celestia#rpc-and-querying","720":"/docs-preview/pr-1815/tutorials/integrate-celestia#compatibility","721":"/docs-preview/pr-1815/tutorials/integrate-celestia#syncing","722":"/docs-preview/pr-1815/tutorials/integrate-celestia#notable-exceptions-relative-to-other-blockchains","723":"/docs-preview/pr-1815/tutorials/node-api#node-api","724":"/docs-preview/pr-1815/tutorials/node-api#rpc-api","725":"/docs-preview/pr-1815/tutorials/node-api#library","726":"/docs-preview/pr-1815/tutorials/node-api#rpc","727":"/docs-preview/pr-1815/tutorials/node-api#rpc-api-tutorial","728":"/docs-preview/pr-1815/tutorials/node-api#gateway-api","729":"/docs-preview/pr-1815/tutorials/node-api#gateway-api-tutorial","730":"/docs-preview/pr-1815/tutorials/node-tutorial#celestia-node-rpc-cli-tutorial","731":"/docs-preview/pr-1815/tutorials/node-tutorial#introduction","732":"/docs-preview/pr-1815/tutorials/node-tutorial#blobs","733":"/docs-preview/pr-1815/tutorials/node-tutorial#namespaces","734":"/docs-preview/pr-1815/tutorials/node-tutorial#hardware-requirements","735":"/docs-preview/pr-1815/tutorials/node-tutorial#setting-up-dependencies","736":"/docs-preview/pr-1815/tutorials/node-tutorial#instantiate-a-celestia-light-node","737":"/docs-preview/pr-1815/tutorials/node-tutorial#connect-to-a-core-endpoint","738":"/docs-preview/pr-1815/tutorials/node-tutorial#keys-and-wallets","739":"/docs-preview/pr-1815/tutorials/node-tutorial#rpc-cli-guide","740":"/docs-preview/pr-1815/tutorials/node-tutorial#command-formatting","741":"/docs-preview/pr-1815/tutorials/node-tutorial#basic-flags","742":"/docs-preview/pr-1815/tutorials/node-tutorial#auth-token","743":"/docs-preview/pr-1815/tutorials/node-tutorial#node-store","744":"/docs-preview/pr-1815/tutorials/node-tutorial#auth-token-on-custom-or-private-network","745":"/docs-preview/pr-1815/tutorials/node-tutorial#submitting-data","746":"/docs-preview/pr-1815/tutorials/node-tutorial#optional-submit-with-curl","747":"/docs-preview/pr-1815/tutorials/node-tutorial#retrieving-data","748":"/docs-preview/pr-1815/tutorials/node-tutorial#setting-the-gas-price","749":"/docs-preview/pr-1815/tutorials/node-tutorial#examples","750":"/docs-preview/pr-1815/tutorials/node-tutorial#check-your-balance","751":"/docs-preview/pr-1815/tutorials/node-tutorial#check-the-balance-of-another-address","752":"/docs-preview/pr-1815/tutorials/node-tutorial#get-your-node-id","753":"/docs-preview/pr-1815/tutorials/node-tutorial#get-your-account-address","754":"/docs-preview/pr-1815/tutorials/node-tutorial#get-block-header-by-height","755":"/docs-preview/pr-1815/tutorials/node-tutorial#combined-commands","756":"/docs-preview/pr-1815/tutorials/node-tutorial#get-data-availability-sampler-stats","757":"/docs-preview/pr-1815/tutorials/node-tutorial#transfer-balance-of-utia-to-another-account","758":"/docs-preview/pr-1815/tutorials/node-tutorial#api-version","759":"/docs-preview/pr-1815/tutorials/node-tutorial#help","760":"/docs-preview/pr-1815/tutorials/node-tutorial#advanced-example","761":"/docs-preview/pr-1815/tutorials/node-tutorial#additional-resources","762":"/docs-preview/pr-1815/tutorials/node-tutorial#submitting-a-blob-using-curl","763":"/docs-preview/pr-1815/tutorials/node-tutorial#post-an-svg-as-a-pfb","764":"/docs-preview/pr-1815/tutorials/node-tutorial#troubleshooting","765":"/docs-preview/pr-1815/tutorials/prompt-scavenger#prompt-scavenger","766":"/docs-preview/pr-1815/tutorials/prompt-scavenger#dependencies","767":"/docs-preview/pr-1815/tutorials/prompt-scavenger#install-celestia-node-and-run-a-light-node","768":"/docs-preview/pr-1815/tutorials/prompt-scavenger#openai-key","769":"/docs-preview/pr-1815/tutorials/prompt-scavenger#building-the-prompt-scavenger","770":"/docs-preview/pr-1815/tutorials/prompt-scavenger#initialize-your-go-project","771":"/docs-preview/pr-1815/tutorials/prompt-scavenger#build-your-import-statements","772":"/docs-preview/pr-1815/tutorials/prompt-scavenger#main-function","773":"/docs-preview/pr-1815/tutorials/prompt-scavenger#utility-functions","774":"/docs-preview/pr-1815/tutorials/prompt-scavenger#prompting-chatgpt","775":"/docs-preview/pr-1815/tutorials/prompt-scavenger#wrapping-things-up","776":"/docs-preview/pr-1815/tutorials/prompt-scavenger#next-steps","777":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#rust-client-library","778":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#project-setup","779":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#submitting-and-retrieving-blobs","780":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#subscribing-to-new-headers","781":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#fetching-an-extended-data-square-eds","782":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#api-documentation","783":"/docs-preview/pr-1815/tutorials/wallets#wallet-integrations-with-celestia","784":"/docs-preview/pr-1815/tutorials/wallets#add-celestia-network-parameters-to-keplr-with-react","785":"/docs-preview/pr-1815/tutorials/wallets#adding-a-custom-chain-to-leap","786":"/docs-preview/pr-1815/tutorials/wallets#adding-a-custom-chain-to-cosmostation"},"fieldIds":{"title":0,"titles":1,"text":2},"fieldLength":{"0":[3,1,24],"1":[3,3,22],"2":[2,3,68],"3":[2,3,34],"4":[3,3,25],"5":[5,1,1],"6":[2,5,62],"7":[2,5,114],"8":[2,5,57],"9":[1,5,43],"10":[1,5,39],"11":[2,5,22],"12":[2,7,38],"13":[2,7,57],"14":[3,7,50],"15":[3,7,34],"16":[1,5,47],"17":[5,1,1],"18":[4,5,57],"19":[3,5,1],"20":[2,7,53],"21":[2,7,41],"22":[2,7,110],"23":[2,7,173],"24":[2,7,62],"25":[1,5,45],"26":[2,6,147],"27":[2,5,53],"28":[2,5,17],"29":[3,1,31],"30":[3,3,129],"31":[3,3,69],"32":[3,3,72],"33":[3,3,39],"34":[1,6,164],"35":[3,6,124],"36":[1,6,150],"37":[1,6,190],"38":[1,6,170],"39":[3,6,159],"40":[1,6,132],"41":[4,6,145],"42":[9,6,167],"43":[4,1,28],"44":[2,4,64],"45":[2,4,1],"46":[6,6,71],"47":[2,6,70],"48":[1,6,35],"49":[1,6,28],"50":[1,6,48],"51":[3,1,37],"52":[3,3,12],"53":[6,3,44],"54":[8,3,58],"55":[7,3,48],"56":[6,3,23],"57":[2,3,37],"58":[2,1,143],"59":[2,1,45],"60":[4,2,64],"61":[2,2,1],"62":[3,4,1],"63":[1,2,49],"64":[3,3,37],"65":[3,3,95],"66":[6,3,1],"67":[9,9,39],"68":[8,9,111],"69":[3,2,24],"70":[1,3,41],"71":[1,3,12],"72":[1,2,19],"73":[2,2,21],"74":[8,1,29],"75":[6,8,1],"76":[7,11,47],"77":[7,11,68],"78":[6,8,1],"79":[10,11,81],"80":[5,11,40],"81":[6,1,77],"82":[1,6,52],"83":[1,6,10],"84":[6,7,63],"85":[6,7,58],"86":[8,7,238],"87":[8,7,115],"88":[10,7,74],"89":[12,7,39],"90":[11,7,129],"91":[9,7,238],"92":[10,7,56],"93":[7,7,231],"94":[4,7,49],"95":[1,6,17],"96":[2,7,75],"97":[4,7,32],"98":[2,11,13],"99":[2,11,13],"100":[4,7,48],"101":[4,7,48],"102":[7,1,1],"103":[1,7,20],"104":[4,7,71],"105":[6,7,34],"106":[8,1,1],"107":[1,8,51],"108":[2,8,41],"109":[3,10,174],"110":[3,10,128],"111":[3,10,77],"112":[5,10,86],"113":[2,8,17],"114":[4,1,1],"115":[2,4,1],"116":[1,6,9],"117":[3,6,57],"118":[2,6,93],"119":[2,4,43],"120":[1,4,50],"121":[3,4,31],"122":[6,4,124],"123":[4,1,1],"124":[3,4,74],"125":[3,4,149],"126":[2,4,168],"127":[3,6,101],"128":[2,6,114],"129":[3,4,1],"130":[3,7,164],"131":[2,7,1],"132":[4,9,10],"133":[8,9,13],"134":[4,9,39],"135":[3,1,1],"136":[1,3,118],"137":[5,3,101],"138":[3,7,1],"139":[3,7,130],"140":[3,3,72],"141":[5,6,50],"142":[2,11,78],"143":[2,11,56],"144":[14,6,237],"145":[4,6,44],"146":[7,6,13],"147":[2,13,163],"148":[2,13,31],"149":[9,6,35],"150":[2,15,89],"151":[5,6,60],"152":[2,11,108],"153":[2,11,50],"154":[9,3,86],"155":[1,11,54],"156":[1,11,198],"157":[1,11,94],"158":[1,11,47],"159":[1,11,113],"160":[1,11,185],"161":[5,11,136],"162":[5,11,94],"163":[6,11,379],"164":[1,3,58],"165":[4,1,47],"166":[1,4,53],"167":[3,5,23],"168":[5,8,92],"169":[5,8,83],"170":[4,8,41],"171":[4,8,63],"172":[3,5,85],"173":[5,8,31],"174":[6,8,119],"175":[7,8,119],"176":[4,8,15],"177":[4,8,2],"178":[2,4,57],"179":[8,5,70],"180":[9,11,50],"181":[9,11,2],"182":[9,11,42],"183":[7,5,107],"184":[8,10,18],"185":[8,10,27],"186":[2,4,66],"187":[7,5,88],"188":[8,10,36],"189":[8,10,2],"190":[7,5,30],"191":[6,10,82],"192":[8,10,2],"193":[8,10,26],"194":[4,5,79],"195":[5,9,2],"196":[5,9,13],"197":[1,4,48],"198":[1,4,1],"199":[12,5,104],"200":[4,1,14],"201":[3,4,34],"202":[4,7,232],"203":[4,7,104],"204":[7,7,113],"205":[3,13,59],"206":[3,13,61],"207":[3,13,22],"208":[4,7,116],"209":[4,10,40],"210":[2,10,180],"211":[4,7,186],"212":[8,7,36],"213":[5,4,34],"214":[4,9,175],"215":[6,9,176],"216":[4,1,89],"217":[2,4,75],"218":[6,4,92],"219":[3,4,63],"220":[6,1,1],"221":[4,6,119],"222":[3,9,7],"223":[7,6,1],"224":[3,12,40],"225":[3,12,42],"226":[3,12,69],"227":[5,6,126],"228":[4,6,67],"229":[5,9,30],"230":[2,9,17],"231":[2,9,43],"232":[7,1,1],"233":[5,7,86],"234":[4,7,58],"235":[3,7,57],"236":[2,7,12],"237":[6,1,23],"238":[4,6,108],"239":[2,6,30],"240":[5,6,16],"241":[3,7,7],"242":[5,6,1],"243":[3,8,17],"244":[4,8,102],"245":[4,8,112],"246":[9,9,49],"247":[7,9,30],"248":[7,8,23],"249":[2,1,32],"250":[7,2,56],"251":[3,2,49],"252":[2,4,34],"253":[1,6,8],"254":[1,6,40],"255":[1,4,22],"256":[1,4,20],"257":[1,4,12],"258":[1,4,12],"259":[2,2,22],"260":[3,1,102],"261":[3,3,27],"262":[2,3,19],"263":[4,5,52],"264":[2,3,19],"265":[2,3,47],"266":[1,3,175],"267":[2,4,89],"268":[3,3,28],"269":[4,3,28],"270":[3,3,24],"271":[6,3,38],"272":[6,3,93],"273":[1,1,41],"274":[1,1,80],"275":[1,1,243],"276":[2,1,52],"277":[1,1,63],"278":[1,1,40],"279":[2,1,97],"280":[1,1,29],"281":[5,1,135],"282":[2,1,24],"283":[9,1,42],"284":[2,9,18],"285":[5,11,1],"286":[3,15,20],"287":[5,15,80],"288":[5,15,22],"289":[2,15,53],"290":[6,11,17],"291":[4,14,89],"292":[3,14,32],"293":[2,14,20],"294":[5,14,144],"295":[6,14,62],"296":[6,14,42],"297":[6,14,62],"298":[1,9,41],"299":[3,10,50],"300":[3,10,10],"301":[6,10,96],"302":[8,10,39],"303":[5,10,88],"304":[1,9,25],"305":[1,9,20],"306":[6,1,18],"307":[1,6,20],"308":[3,6,57],"309":[3,6,75],"310":[3,1,32],"311":[4,3,110],"312":[5,3,108],"313":[1,3,90],"314":[4,1,82],"315":[3,1,28],"316":[3,3,58],"317":[2,5,23],"318":[2,5,27],"319":[2,5,27],"320":[2,5,78],"321":[4,3,80],"322":[3,1,120],"323":[1,1,1],"324":[2,1,64],"325":[2,3,48],"326":[1,1,106],"327":[7,1,1],"328":[1,8,100],"329":[1,8,81],"330":[1,8,1],"331":[6,9,58],"332":[5,9,42],"333":[6,9,47],"334":[3,1,81],"335":[4,1,26],"336":[10,1,71],"337":[7,1,109],"338":[7,1,92],"339":[3,7,27],"340":[3,1,1],"341":[3,3,126],"342":[5,3,67],"343":[2,8,104],"344":[2,3,39],"345":[3,3,26],"346":[3,1,1],"347":[2,3,12],"348":[4,3,16],"349":[3,3,34],"350":[1,4,35],"351":[1,4,1],"352":[1,5,45],"353":[2,5,31],"354":[1,4,1],"355":[3,5,61],"356":[2,1,24],"357":[3,2,30],"358":[5,2,16],"359":[4,6,7],"360":[3,6,8],"361":[5,6,140],"362":[4,2,1],"363":[7,6,34],"364":[3,12,6],"365":[4,12,25],"366":[4,6,25],"367":[4,6,49],"368":[4,6,54],"369":[2,2,50],"370":[4,4,41],"371":[4,4,165],"372":[4,4,72],"373":[4,2,78],"374":[5,2,1],"375":[3,7,22],"376":[5,7,28],"377":[2,12,65],"378":[4,12,56],"379":[3,12,13],"380":[5,7,94],"381":[5,7,90],"382":[1,2,1],"383":[10,3,159],"384":[5,1,16],"385":[2,5,31],"386":[3,6,18],"387":[2,5,29],"388":[3,1,71],"389":[1,3,14],"390":[2,3,105],"391":[6,3,77],"392":[6,8,79],"393":[3,8,67],"394":[2,3,1],"395":[4,5,1],"396":[1,3,54],"397":[2,1,24],"398":[2,2,80],"399":[2,2,108],"400":[2,1,93],"401":[5,1,1],"402":[1,5,37],"403":[2,5,32],"404":[1,5,60],"405":[6,5,52],"406":[6,11,36],"407":[8,11,42],"408":[9,5,69],"409":[5,5,37],"410":[9,5,13],"411":[7,12,11],"412":[7,5,88],"413":[6,12,48],"414":[7,1,31],"415":[5,7,26],"416":[2,7,31],"417":[6,7,16],"418":[3,9,11],"419":[3,7,10],"420":[5,10,1],"421":[5,12,17],"422":[5,12,141],"423":[10,10,50],"424":[7,16,31],"425":[8,10,24],"426":[5,10,32],"427":[3,1,93],"428":[1,3,85],"429":[1,4,180],"430":[3,4,84],"431":[3,4,49],"432":[6,3,52],"433":[2,3,31],"434":[5,5,85],"435":[4,5,44],"436":[3,3,7],"437":[1,3,41],"438":[2,4,37],"439":[5,1,42],"440":[2,5,8],"441":[2,5,11],"442":[3,5,12],"443":[5,5,32],"444":[4,9,38],"445":[4,9,44],"446":[4,9,49],"447":[4,9,29],"448":[4,9,48],"449":[7,9,76],"450":[5,9,74],"451":[4,9,38],"452":[7,9,66],"453":[3,9,42],"454":[5,1,43],"455":[3,5,109],"456":[2,7,26],"457":[2,5,35],"458":[6,1,25],"459":[4,6,42],"460":[2,6,30],"461":[8,6,27],"462":[5,6,22],"463":[3,7,10],"464":[4,6,37],"465":[4,6,87],"466":[3,8,80],"467":[2,11,38],"468":[9,8,49],"469":[7,13,30],"470":[6,8,15],"471":[3,6,16],"472":[6,1,17],"473":[1,6,13],"474":[2,6,46],"475":[2,6,1],"476":[4,8,18],"477":[5,8,63],"478":[5,8,86],"479":[3,8,56],"480":[2,1,48],"481":[4,2,66],"482":[2,2,1],"483":[3,2,1],"484":[2,2,31],"485":[2,4,109],"486":[1,2,56],"487":[3,3,59],"488":[2,3,4],"489":[4,5,58],"490":[3,5,42],"491":[3,5,41],"492":[3,5,18],"493":[3,3,6],"494":[10,6,39],"495":[9,6,119],"496":[4,6,37],"497":[3,10,31],"498":[1,2,30],"499":[1,2,26],"500":[2,2,30],"501":[2,1,106],"502":[2,2,1],"503":[3,2,1],"504":[8,2,1],"505":[3,10,59],"506":[10,10,39],"507":[9,10,92],"508":[3,2,60],"509":[3,2,71],"510":[3,2,76],"511":[6,2,33],"512":[3,2,63],"513":[1,2,14],"514":[1,2,31],"515":[2,2,30],"516":[5,1,1],"517":[1,5,27],"518":[8,5,39],"519":[8,5,1],"520":[6,12,26],"521":[6,12,36],"522":[2,5,19],"523":[4,7,15],"524":[4,7,16],"525":[5,5,56],"526":[4,1,62],"527":[3,4,57],"528":[2,4,88],"529":[2,5,1],"530":[3,6,105],"531":[2,5,1],"532":[3,7,60],"533":[6,1,71],"534":[4,6,1],"535":[3,6,31],"536":[2,6,47],"537":[4,1,21],"538":[3,4,83],"539":[5,4,84],"540":[5,4,51],"541":[2,4,57],"542":[8,1,120],"543":[2,8,3],"544":[5,10,73],"545":[5,8,48],"546":[10,8,115],"547":[1,8,22],"548":[5,1,1],"549":[2,5,39],"550":[6,7,1],"551":[1,5,12],"552":[2,6,45],"553":[6,8,1],"554":[2,6,48],"555":[6,6,1],"556":[2,5,30],"557":[3,1,61],"558":[4,3,84],"559":[4,7,142],"560":[4,9,121],"561":[4,7,112],"562":[8,3,1],"563":[4,11,55],"564":[2,11,107],"565":[2,11,87],"566":[5,3,21],"567":[4,8,41],"568":[5,8,60],"569":[3,8,22],"570":[3,8,22],"571":[3,8,73],"572":[1,3,16],"573":[2,3,29],"574":[2,1,43],"575":[4,2,1],"576":[3,6,22],"577":[4,6,9],"578":[2,6,10],"579":[5,2,41],"580":[6,2,100],"581":[4,2,1],"582":[5,6,81],"583":[1,6,123],"584":[1,6,107],"585":[4,1,22],"586":[3,4,106],"587":[5,1,27],"588":[3,5,94],"589":[4,5,26],"590":[4,9,103],"591":[3,12,141],"592":[3,12,152],"593":[3,12,78],"594":[10,9,118],"595":[1,5,11],"596":[6,6,14],"597":[5,6,19],"598":[6,6,100],"599":[9,6,199],"600":[5,6,21],"601":[6,6,83],"602":[10,1,13],"603":[2,10,21],"604":[6,12,113],"605":[3,10,1],"606":[4,13,72],"607":[3,13,106],"608":[3,13,93],"609":[2,1,73],"610":[3,2,42],"611":[1,2,37],"612":[6,1,23],"613":[2,6,30],"614":[5,6,25],"615":[1,6,8],"616":[5,6,113],"617":[5,6,48],"618":[3,10,10],"619":[4,10,46],"620":[4,10,8],"621":[7,12,23],"622":[4,6,192],"623":[4,6,16],"624":[5,6,19],"625":[2,6,14],"626":[1,6,1],"627":[10,7,182],"628":[3,1,1],"629":[5,3,82],"630":[7,3,73],"631":[9,3,41],"632":[6,3,62],"633":[15,3,80],"634":[8,3,65],"635":[5,3,33],"636":[8,3,70],"637":[10,3,26],"638":[8,3,51],"639":[10,3,73],"640":[11,3,42],"641":[15,3,34],"642":[5,1,69],"643":[5,5,122],"644":[1,9,86],"645":[6,9,122],"646":[5,5,130],"647":[6,5,1],"648":[3,11,120],"649":[4,1,172],"650":[1,1,90],"651":[7,1,158],"652":[3,7,163],"653":[4,1,44],"654":[4,4,1],"655":[5,4,1],"656":[6,8,20],"657":[9,8,15],"658":[5,8,25],"659":[6,8,22],"660":[5,4,1],"661":[6,8,17],"662":[7,8,29],"663":[6,8,22],"664":[5,4,1],"665":[6,8,7],"666":[12,8,13],"667":[5,8,12],"668":[4,8,24],"669":[3,1,1],"670":[2,3,70],"671":[3,3,44],"672":[4,1,60],"673":[7,4,93],"674":[4,4,143],"675":[4,1,1],"676":[5,4,68],"677":[1,4,73],"678":[2,4,1],"679":[2,5,35],"680":[2,5,37],"681":[4,4,85],"682":[1,8,127],"683":[3,1,30],"684":[2,3,34],"685":[2,3,31],"686":[3,1,1],"687":[4,3,33],"688":[3,3,1],"689":[3,4,33],"690":[3,4,68],"691":[3,4,41],"692":[2,4,41],"693":[1,4,1],"694":[3,5,15],"695":[3,5,27],"696":[4,5,9],"697":[6,1,42],"698":[5,6,42],"699":[1,11,56],"700":[5,11,106],"701":[5,11,32],"702":[5,11,33],"703":[6,11,5],"704":[4,6,1],"705":[1,10,16],"706":[3,10,144],"707":[5,10,147],"708":[4,1,27],"709":[2,4,66],"710":[4,4,132],"711":[4,4,86],"712":[4,4,101],"713":[7,4,59],"714":[2,4,11],"715":[5,1,18],"716":[2,5,29],"717":[4,5,84],"718":[4,7,27],"719":[3,7,62],"720":[1,7,36],"721":[1,7,28],"722":[6,7,81],"723":[2,1,28],"724":[2,2,46],"725":[1,3,16],"726":[1,3,48],"727":[3,3,33],"728":[2,2,66],"729":[3,3,12],"730":[5,1,26],"731":[1,5,1],"732":[1,6,19],"733":[1,6,73],"734":[2,5,30],"735":[3,5,11],"736":[5,8,55],"737":[5,8,123],"738":[3,8,107],"739":[3,5,39],"740":[2,6,124],"741":[2,6,77],"742":[3,8,67],"743":[2,8,65],"744":[7,10,70],"745":[2,6,118],"746":[4,8,10],"747":[2,6,113],"748":[4,6,74],"749":[1,6,1],"750":[3,7,46],"751":[6,7,43],"752":[4,7,49],"753":[4,7,28],"754":[5,7,107],"755":[2,7,20],"756":[5,7,6],"757":[7,7,72],"758":[2,7,17],"759":[1,7,21],"760":[2,6,35],"761":[2,5,1],"762":[5,7,124],"763":[6,7,21],"764":[1,7,46],"765":[2,1,80],"766":[1,2,28],"767":[8,3,145],"768":[2,3,43],"769":[4,2,1],"770":[4,5,38],"771":[4,5,100],"772":[2,5,110],"773":[2,5,232],"774":[2,5,84],"775":[3,5,160],"776":[2,2,60],"777":[4,1,29],"778":[2,4,63],"779":[4,4,107],"780":[4,4,87],"781":[7,4,57],"782":[2,4,11],"783":[4,1,21],"784":[8,4,181],"785":[6,4,82],"786":[6,4,100]},"averageFieldLength":[3.9034307496823386,5.673443456162645,55.289707750952985],"storedFields":{"0":{"title":"Celestia Documentation Site","titles":[]},"1":{"title":"Building the site","titles":["Celestia Documentation Site"]},"2":{"title":"Contribution Guidelines","titles":["Celestia Documentation Site"]},"3":{"title":"Directory Structure","titles":["Celestia Documentation Site"]},"4":{"title":"Feedback & Suggestions","titles":["Celestia Documentation Site"]},"5":{"title":"Celestia.org Code of Conduct","titles":[]},"6":{"title":"Our Pledge","titles":["Celestia.org Code of Conduct"]},"7":{"title":"Our Standards","titles":["Celestia.org Code of Conduct"]},"8":{"title":"Enforcement Responsibilities","titles":["Celestia.org Code of Conduct"]},"9":{"title":"Scope","titles":["Celestia.org Code of Conduct"]},"10":{"title":"Enforcement","titles":["Celestia.org Code of Conduct"]},"11":{"title":"Enforcement Guidelines","titles":["Celestia.org Code of Conduct"]},"12":{"title":"1. Correction","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"13":{"title":"2. Warning","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"14":{"title":"3. Temporary Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"15":{"title":"4. Permanent Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"16":{"title":"Attribution","titles":["Celestia.org Code of Conduct"]},"17":{"title":"The Celestia Foundation Delegation Program","titles":[]},"18":{"title":"Objectives of the program","titles":["The Celestia Foundation Delegation Program"]},"19":{"title":"Foundation delegation process","titles":["The Celestia Foundation Delegation Program"]},"20":{"title":"Program launch","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"21":{"title":"Cohort process","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"22":{"title":"Key Points","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"23":{"title":"Eligibility criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"24":{"title":"Undelegation criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"25":{"title":"Application","titles":["The Celestia Foundation Delegation Program"]},"26":{"title":"Application details","titles":["The Celestia Foundation Delegation Program","Application"]},"27":{"title":"Cohort information","titles":["The Celestia Foundation Delegation Program"]},"28":{"title":"Feedback process","titles":["The Celestia Foundation Delegation Program"]},"29":{"title":"Modular Meetup guide","titles":[]},"30":{"title":"Before the Meetup","titles":["Modular Meetup guide"]},"31":{"title":"During the Meetup","titles":["Modular Meetup guide"]},"32":{"title":"After the Meetup","titles":["Modular Meetup guide"]},"33":{"title":"Logistics and guidance","titles":["Modular Meetup guide"]},"34":{"title":"Venue","titles":["Modular Meetup guide","Logistics and guidance"]},"35":{"title":"Catering and refreshments","titles":["Modular Meetup guide","Logistics and guidance"]},"36":{"title":"Audience","titles":["Modular Meetup guide","Logistics and guidance"]},"37":{"title":"Speakers","titles":["Modular Meetup guide","Logistics and guidance"]},"38":{"title":"Sponsors","titles":["Modular Meetup guide","Logistics and guidance"]},"39":{"title":"Communications and marketing","titles":["Modular Meetup guide","Logistics and guidance"]},"40":{"title":"Recording","titles":["Modular Meetup guide","Logistics and guidance"]},"41":{"title":"Utilizing Meetup.com platform","titles":["Modular Meetup guide","Logistics and guidance"]},"42":{"title":"Onboarding questions for community members joining a Modular Meetup","titles":["Modular Meetup guide","Logistics and guidance"]},"43":{"title":"Celestia Modular Meetup program","titles":[]},"44":{"title":"Program description","titles":["Celestia Modular Meetup program"]},"45":{"title":"Important info","titles":["Celestia Modular Meetup program"]},"46":{"title":"Celestia.org Community Code of Conduct","titles":["Celestia Modular Meetup program","Important info"]},"47":{"title":"Signup form","titles":["Celestia Modular Meetup program","Important info"]},"48":{"title":"Emails","titles":["Celestia Modular Meetup program","Important info"]},"49":{"title":"Discord","titles":["Celestia Modular Meetup program","Important info"]},"50":{"title":"Materials","titles":["Celestia Modular Meetup program","Important info"]},"51":{"title":"Modular Meetup Toolkit","titles":[]},"52":{"title":"Celestia branding guidelines","titles":["Modular Meetup Toolkit"]},"53":{"title":"Sample “Introduction to Modularity” workshop presentation","titles":["Modular Meetup Toolkit"]},"54":{"title":"Sample “Run a Celestia light node” workshop presentation","titles":["Modular Meetup Toolkit"]},"55":{"title":"Sample “Deploy a Sovereign Rollup” workshop presentation","titles":["Modular Meetup Toolkit"]},"56":{"title":"Sample “Modular Meetup Introduction” workshop presentation","titles":["Modular Meetup Toolkit"]},"57":{"title":"Swag logistics","titles":["Modular Meetup Toolkit"]},"58":{"title":"Speaker list","titles":[]},"59":{"title":"Arabica devnet","titles":[]},"60":{"title":"Network stability and upgrades","titles":["Arabica devnet"]},"61":{"title":"Network details","titles":["Arabica devnet"]},"62":{"title":"Software version numbers","titles":["Arabica devnet","Network details"]},"63":{"title":"Integrations","titles":["Arabica devnet"]},"64":{"title":"Production RPC endpoints","titles":["Arabica devnet","Integrations"]},"65":{"title":"Community RPC endpoints","titles":["Arabica devnet","Integrations"]},"66":{"title":"Using consensus endpoints with DA nodes","titles":["Arabica devnet","Integrations"]},"67":{"title":"Data availability (DA) RPC endpoints for bridge node sync","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"68":{"title":"Data availability (DA) gRPC endpoints for state access","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"69":{"title":"Arabica devnet faucet","titles":["Arabica devnet"]},"70":{"title":"Discord","titles":["Arabica devnet","Arabica devnet faucet"]},"71":{"title":"Web","titles":["Arabica devnet","Arabica devnet faucet"]},"72":{"title":"Explorers","titles":["Arabica devnet"]},"73":{"title":"Network upgrades","titles":["Arabica devnet"]},"74":{"title":"Bridging in and out of your Orbit rollup","titles":[]},"75":{"title":"Bridge in (deposit) to your rollup","titles":["Bridging in and out of your Orbit rollup"]},"76":{"title":"Step 1: Add your custom chain config","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"77":{"title":"Step 2: Deposit to your Orbit rollup","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"78":{"title":"Bridge out (withdrawal) from your rollup","titles":["Bridging in and out of your Orbit rollup"]},"79":{"title":"Step 1: Choose an amount to withdraw from your rollup","titles":["Bridging in and out of your Orbit rollup","Bridge out (withdrawal) from your rollup"]},"80":{"title":"Step 2: Claim your withdrawal","titles":["Bridging in and out of your Orbit rollup","Bridge out (withdrawal) from your rollup"]},"81":{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","titles":[]},"82":{"title":"Prerequisites","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"83":{"title":"Setup","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"84":{"title":"Step 1: Acquire Arbitrum Sepolia ETH","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"85":{"title":"Step 2: Pick your deployment type","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"86":{"title":"Step 3: Configure your Orbit chain\'s deployment","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"87":{"title":"Step 4: Review & Deploy your Orbit chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"88":{"title":"Step 5: Download your chain\'s configuration files and launch your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"89":{"title":"Step 6: Clone the setup script repository and add your configuration files","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"90":{"title":"Step 7: Pick an L2 RPC URL for the Batch Poster","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"91":{"title":"Step 8: Run your light node for Mocha testnet","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"92":{"title":"Step 9: Run your chain\'s node and block explorer","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"93":{"title":"Step 10: Finish setting up your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"94":{"title":"Congratulations with Celestia underneath","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"95":{"title":"Appendix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"96":{"title":"Compatibility matrix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"97":{"title":"Blobstream X contract deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"98":{"title":"Arbitrum Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"99":{"title":"Base Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"100":{"title":"Arbitrum Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"101":{"title":"Base Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"102":{"title":"Running a full node and/or validator","titles":[]},"103":{"title":"Prerequisites","titles":["Running a full node and/or validator"]},"104":{"title":"Running a full node","titles":["Running a full node and/or validator"]},"105":{"title":"Running a full node with validation","titles":["Running a full node and/or validator"]},"106":{"title":"Introduction to Arbitrum rollups with Celestia as DA","titles":[]},"107":{"title":"Overview","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"108":{"title":"Key components","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"109":{"title":"DA provider implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"110":{"title":"Preimage Oracle Implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"111":{"title":"Blobstream X implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"112":{"title":"Ethereum fallback mechanism in Nitro","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"113":{"title":"Next steps","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"114":{"title":"Integrate with Blobstream contracts","titles":[]},"115":{"title":"Getting started","titles":["Integrate with Blobstream contracts"]},"116":{"title":"Prerequisites","titles":["Integrate with Blobstream contracts","Getting started"]},"117":{"title":"Installing Blobstream contracts","titles":["Integrate with Blobstream contracts","Getting started"]},"118":{"title":"Example usage","titles":["Integrate with Blobstream contracts","Getting started"]},"119":{"title":"Data structures","titles":["Integrate with Blobstream contracts"]},"120":{"title":"Interface","titles":["Integrate with Blobstream contracts"]},"121":{"title":"Querying the proof","titles":["Integrate with Blobstream contracts"]},"122":{"title":"Verifying data inclusion for fraud proofs","titles":["Integrate with Blobstream contracts"]},"123":{"title":"Integrate with Blobstream client","titles":[]},"124":{"title":"Blobstream demo rollup","titles":["Integrate with Blobstream client"]},"125":{"title":"Defining a chain","titles":["Integrate with Blobstream client"]},"126":{"title":"Rollup sequencer","titles":["Integrate with Blobstream client"]},"127":{"title":"Committing to data","titles":["Integrate with Blobstream client","Rollup sequencer"]},"128":{"title":"Creating blocks","titles":["Integrate with Blobstream client","Rollup sequencer"]},"129":{"title":"Rollup full node","titles":["Integrate with Blobstream client"]},"130":{"title":"Downloading the block","titles":["Integrate with Blobstream client","Rollup full node"]},"131":{"title":"More documentation","titles":["Integrate with Blobstream client","Rollup full node"]},"132":{"title":"Proving inclusion via Blobstream","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"133":{"title":"Submitting block data to Celestia via light node","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"134":{"title":"Posting headers to Ethereum","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"135":{"title":"Blobstream proofs queries","titles":[]},"136":{"title":"Prerequisites","titles":["Blobstream proofs queries"]},"137":{"title":"Overview of the proof queries","titles":["Blobstream proofs queries"]},"138":{"title":"The Celestia square","titles":["Blobstream proofs queries","Overview of the proof queries"]},"139":{"title":"The commitment scheme","titles":["Blobstream proofs queries","Overview of the proof queries"]},"140":{"title":"Hands-on demonstration","titles":["Blobstream proofs queries"]},"141":{"title":"1. Data root inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"142":{"title":"HTTP query","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"143":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"144":{"title":"Full example of proving that a Celestia block was committed to by Blobstream contract","titles":["Blobstream proofs queries","Hands-on demonstration"]},"145":{"title":"2. Transaction inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"146":{"title":"Transaction inclusion proof using the transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"147":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"148":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"149":{"title":"Blob inclusion proof using the corresponding PFB transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"150":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Blob inclusion proof using the corresponding PFB transaction hash"]},"151":{"title":"Specific share range inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"152":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"153":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"154":{"title":"Converting the proofs to be usable in the DAVerifier library","titles":["Blobstream proofs queries"]},"155":{"title":"data","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"156":{"title":"shareProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"157":{"title":"namespace","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"158":{"title":"rowRoots","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"159":{"title":"rowProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"160":{"title":"attestationProof","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"161":{"title":"Querying the proof\'s tupleRootNonce","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"162":{"title":"Listening for new data commitments","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"163":{"title":"Example rollup that uses the DAVerifier","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"164":{"title":"Conclusion","titles":["Blobstream proofs queries"]},"165":{"title":"Introduction to Blobstream rollups","titles":[]},"166":{"title":"Concepts","titles":["Introduction to Blobstream rollups"]},"167":{"title":"Blob share commitment","titles":["Introduction to Blobstream rollups","Concepts"]},"168":{"title":"Blob share commitment: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"169":{"title":"Blob share commitment: Compact proofs","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"170":{"title":"Blob share commitment: Pros","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"171":{"title":"Blob share commitment: Cons","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"172":{"title":"Sequence of spans","titles":["Introduction to Blobstream rollups","Concepts"]},"173":{"title":"Sequence of spans: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"174":{"title":"Sequence of spans: Proving unavailable data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"175":{"title":"Sequence of spans: Proving inclusion of some data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"176":{"title":"Sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"177":{"title":"Sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"178":{"title":"Optimistic rollups","titles":["Introduction to Blobstream rollups"]},"179":{"title":"Optimistic rollups that use a sequence of spans","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"180":{"title":"Optimistic rollups that use a sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use a sequence of spans"]},"181":{"title":"Optimistic rollups that use a sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use a sequence of spans"]},"182":{"title":"Optimistic rollups that use a sequence of spans: Example","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use a sequence of spans"]},"183":{"title":"Optimistic rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"184":{"title":"Optimistic rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"185":{"title":"Optimistic rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"186":{"title":"Zk-rollups","titles":["Introduction to Blobstream rollups"]},"187":{"title":"Zk-rollups that use sequence of spans","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"188":{"title":"Zk-rollups that use sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"189":{"title":"Zk-rollups that use sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"190":{"title":"Zk-rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"191":{"title":"Protobuf deserialization inside a zk-circuit","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"192":{"title":"Zk-rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"193":{"title":"Zk-rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"194":{"title":"Heavy merkle proofs usage","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"195":{"title":"heavy merkle proofs usage: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"196":{"title":"heavy merkle proofs usage: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"197":{"title":"Conclusion","titles":["Introduction to Blobstream rollups"]},"198":{"title":"FAQ","titles":["Introduction to Blobstream rollups"]},"199":{"title":"Should I use the Celestia transaction hash to reference the rollup data?","titles":["Introduction to Blobstream rollups","FAQ"]},"200":{"title":"New Blobstream X deployments","titles":[]},"201":{"title":"Deploying the contracts","titles":["New Blobstream X deployments"]},"202":{"title":"Deploy a new SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"203":{"title":"Deploy the function verifiers","titles":["New Blobstream X deployments","Deploying the contracts"]},"204":{"title":"Register the function verifier in the deployed SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"205":{"title":"Enable prover whitelisting","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"206":{"title":"Set Whitelist Status","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"207":{"title":"Add Custom Prover","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"208":{"title":"Deploy the BlobstreamX contract","titles":["New Blobstream X deployments","Deploying the contracts"]},"209":{"title":"Querying the trusted hash","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"210":{"title":"Deployment instructions","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"211":{"title":"Run a local prover","titles":["New Blobstream X deployments","Deploying the contracts"]},"212":{"title":"Run a proof replayer from an existing deployment","titles":["New Blobstream X deployments","Deploying the contracts"]},"213":{"title":"Optional: Regenerating the downloaded artifacts","titles":["New Blobstream X deployments"]},"214":{"title":"Regenerate the verifier-build","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"215":{"title":"Build the circuits and function verifiers","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"216":{"title":"Requesting data commitment ranges","titles":[]},"217":{"title":"Local proving","titles":["Requesting data commitment ranges"]},"218":{"title":"Request proofs from the Succinct platform","titles":["Requesting data commitment ranges"]},"219":{"title":"Request proofs onchain","titles":["Requesting data commitment ranges"]},"220":{"title":"Blobstream: Streaming modular DA to Ethereum","titles":[]},"221":{"title":"What is Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"222":{"title":"Implementations of Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","What is Blobstream?"]},"223":{"title":"Blobstream vs. data availability committees (DACs)","titles":["Blobstream: Streaming modular DA to Ethereum"]},"224":{"title":"Decentralization and security","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"225":{"title":"Mechanism of verification","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"226":{"title":"Flexibility and scalability","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"227":{"title":"What is SP1 Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"228":{"title":"Integrate with SP1 Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum"]},"229":{"title":"How to integrate with Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"230":{"title":"Blobstream rollups","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"231":{"title":"Deployed contracts","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"232":{"title":"Blobstream X: the previous zk implementation of Blobstream","titles":[]},"233":{"title":"What is Blobstream X?","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"234":{"title":"How Blobstream X works","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"235":{"title":"Deploy Blobstream X","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"236":{"title":"Community implementations","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"237":{"title":"Setting up a Celestia bridge node","titles":[]},"238":{"title":"Overview of bridge nodes","titles":["Setting up a Celestia bridge node"]},"239":{"title":"Hardware requirements","titles":["Setting up a Celestia bridge node"]},"240":{"title":"Setting up your bridge node","titles":["Setting up a Celestia bridge node"]},"241":{"title":"Setup the dependencies","titles":["Setting up a Celestia bridge node","Setting up your bridge node"]},"242":{"title":"Deploy the Celestia bridge node","titles":["Setting up a Celestia bridge node"]},"243":{"title":"Install Celestia Node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"244":{"title":"Initialize the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"245":{"title":"Run the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"246":{"title":"Optional: run the bridge node with a custom key","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node","Run the bridge node"]},"247":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node","Run the bridge node"]},"248":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"249":{"title":"Bubs testnet","titles":[]},"250":{"title":"Built with the OP Stack and Celestia","titles":["Bubs testnet"]},"251":{"title":"Building on Bubs","titles":["Bubs testnet"]},"252":{"title":"RPC URLs","titles":["Bubs testnet","Building on Bubs"]},"253":{"title":"HTTPS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"254":{"title":"WSS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"255":{"title":"Bridge","titles":["Bubs testnet","Building on Bubs"]},"256":{"title":"Faucet","titles":["Bubs testnet","Building on Bubs"]},"257":{"title":"Explorer","titles":["Bubs testnet","Building on Bubs"]},"258":{"title":"Status","titles":["Bubs testnet","Building on Bubs"]},"259":{"title":"Next steps","titles":["Bubs testnet"]},"260":{"title":"Helpful CLI commands","titles":[]},"261":{"title":"Creating a wallet","titles":["Helpful CLI commands"]},"262":{"title":"Key management","titles":["Helpful CLI commands"]},"263":{"title":"Importing and exporting keys","titles":["Helpful CLI commands","Key management"]},"264":{"title":"Querying subcommands","titles":["Helpful CLI commands"]},"265":{"title":"Token management","titles":["Helpful CLI commands"]},"266":{"title":"Governance","titles":["Helpful CLI commands"]},"267":{"title":"Community Pool","titles":["Helpful CLI commands","Governance"]},"268":{"title":"Claim validator rewards","titles":["Helpful CLI commands"]},"269":{"title":"Delegate & undelegate tokens","titles":["Helpful CLI commands"]},"270":{"title":"Unjailing the validator","titles":["Helpful CLI commands"]},"271":{"title":"How to export logs with SystemD","titles":["Helpful CLI commands"]},"272":{"title":"Signing genesis for a new network","titles":["Helpful CLI commands"]},"273":{"title":"Metrics","titles":[]},"274":{"title":"Setup","titles":["Metrics"]},"275":{"title":"Visualization","titles":["Metrics"]},"276":{"title":"Node exporter","titles":["Metrics"]},"277":{"title":"Alerts","titles":["Metrics"]},"278":{"title":"Multisig","titles":[]},"279":{"title":"Command line","titles":["Multisig"]},"280":{"title":"Resources","titles":["Multisig"]},"281":{"title":"Jailing and slashing on Celestia","titles":[]},"282":{"title":"Upgrade Monitor","titles":[]},"283":{"title":"How to create a vesting account with celestia-app","titles":[]},"284":{"title":"Local devnet","titles":["How to create a vesting account with celestia-app"]},"285":{"title":"Setting up the local devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"286":{"title":"Run the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"287":{"title":"Save the home directory path","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"288":{"title":"Check the version of the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"289":{"title":"Next steps","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"290":{"title":"Setting up vesting account on devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"291":{"title":"Create a new key","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"292":{"title":"List your keys","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"293":{"title":"Set variables","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"294":{"title":"Create your devnet vesting account","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"295":{"title":"Query the devnet vesting account details","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"296":{"title":"Query the devnet base account details","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"297":{"title":"Query the balances of the devnet accounts","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"298":{"title":"Mocha","titles":["How to create a vesting account with celestia-app"]},"299":{"title":"Create a wallet","titles":["How to create a vesting account with celestia-app","Mocha"]},"300":{"title":"Fund your account","titles":["How to create a vesting account with celestia-app","Mocha"]},"301":{"title":"Create a vesting account on Mocha","titles":["How to create a vesting account with celestia-app","Mocha"]},"302":{"title":"Optional: Set up a consensus node or validator","titles":["How to create a vesting account with celestia-app","Mocha"]},"303":{"title":"Optional: Change your client.toml","titles":["How to create a vesting account with celestia-app","Mocha"]},"304":{"title":"Notes","titles":["How to create a vesting account with celestia-app"]},"305":{"title":"Conclusion","titles":["How to create a vesting account with celestia-app"]},"306":{"title":"Create a wallet with celestia-app","titles":[]},"307":{"title":"Prerequisites","titles":["Create a wallet with celestia-app"]},"308":{"title":"Create a wallet","titles":["Create a wallet with celestia-app"]},"309":{"title":"Fund a wallet","titles":["Create a wallet with celestia-app"]},"310":{"title":"Install celestia-app","titles":[]},"311":{"title":"Building binary from source","titles":["Install celestia-app"]},"312":{"title":"Installing a pre-built binary","titles":["Install celestia-app"]},"313":{"title":"Ports","titles":["Install celestia-app"]},"314":{"title":"Custom networks and values","titles":[]},"315":{"title":"celestia-node metrics","titles":[]},"316":{"title":"Running metrics flags","titles":["celestia-node metrics"]},"317":{"title":"Mainnet Beta","titles":["celestia-node metrics","Running metrics flags"]},"318":{"title":"Mocha testnet","titles":["celestia-node metrics","Running metrics flags"]},"319":{"title":"Arabica devnet","titles":["celestia-node metrics","Running metrics flags"]},"320":{"title":"TLS connections","titles":["celestia-node metrics","Running metrics flags"]},"321":{"title":"Metrics endpoint design considerations","titles":["celestia-node metrics"]},"322":{"title":"celestia-node datastore","titles":[]},"323":{"title":"Troubleshooting","titles":[]},"324":{"title":"Network selection","titles":["Troubleshooting"]},"325":{"title":"Chain ID","titles":["Troubleshooting","Network selection"]},"326":{"title":"Ports","titles":["Troubleshooting"]},"327":{"title":"Changing the location of your node store","titles":["Troubleshooting"]},"328":{"title":"Background","titles":["Troubleshooting","Changing the location of your node store"]},"329":{"title":"Demonstration","titles":["Troubleshooting","Changing the location of your node store"]},"330":{"title":"Examples","titles":["Troubleshooting","Changing the location of your node store"]},"331":{"title":"Mainnet Beta full and Mocha light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"332":{"title":"Mocha full and Arabica light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"333":{"title":"Using a custom rpc.config address","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"334":{"title":"Resetting your config","titles":["Troubleshooting"]},"335":{"title":"Clearing the data store","titles":["Troubleshooting"]},"336":{"title":"FATAL headers given to the heightSub are in the wrong order","titles":["Troubleshooting"]},"337":{"title":"Error: "too many open files"","titles":["Troubleshooting"]},"338":{"title":"Syncing a light node from a trusted hash","titles":[]},"339":{"title":"For service operators","titles":["Syncing a light node from a trusted hash"]},"340":{"title":"Install celestia-node","titles":[]},"341":{"title":"Installing from source","titles":["Install celestia-node"]},"342":{"title":"Installing a pre-built binary","titles":["Install celestia-node"]},"343":{"title":"Installation Options","titles":["Install celestia-node","Installing a pre-built binary"]},"344":{"title":"Next steps","titles":["Install celestia-node"]},"345":{"title":"Upgrading your binary","titles":["Install celestia-node"]},"346":{"title":"config.toml guide","titles":[]},"347":{"title":"Pre-requisites","titles":["config.toml guide"]},"348":{"title":"Viewing the help menu","titles":["config.toml guide"]},"349":{"title":"Understanding config.toml","titles":["config.toml guide"]},"350":{"title":"Core","titles":["config.toml guide","Understanding config.toml"]},"351":{"title":"P2P","titles":["config.toml guide","Understanding config.toml"]},"352":{"title":"Bootstrap","titles":["config.toml guide","Understanding config.toml","P2P"]},"353":{"title":"Mutual peers","titles":["config.toml guide","Understanding config.toml","P2P"]},"354":{"title":"Services","titles":["config.toml guide","Understanding config.toml"]},"355":{"title":"TrustedHash and TrustedPeer","titles":["config.toml guide","Understanding config.toml","Services"]},"356":{"title":"Consensus node","titles":[]},"357":{"title":"Minimum hardware requirements","titles":["Consensus node"]},"358":{"title":"Set up a consensus node","titles":["Consensus node"]},"359":{"title":"Set up the dependencies","titles":["Consensus node","Set up a consensus node"]},"360":{"title":"Install celestia-app","titles":["Consensus node","Set up a consensus node"]},"361":{"title":"Set up the P2P networks","titles":["Consensus node","Set up a consensus node"]},"362":{"title":"Storage and pruning configurations","titles":["Consensus node"]},"363":{"title":"Optional: Connect a consensus node to a bridge node","titles":["Consensus node","Storage and pruning configurations"]},"364":{"title":"Enable transaction indexing","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"365":{"title":"Retain all block data","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"366":{"title":"Query transactions by hash","titles":["Consensus node","Storage and pruning configurations"]},"367":{"title":"Optional: Access historical state","titles":["Consensus node","Storage and pruning configurations"]},"368":{"title":"Save on storage requirements","titles":["Consensus node","Storage and pruning configurations"]},"369":{"title":"Sync types","titles":["Consensus node"]},"370":{"title":"Option 1: Block sync","titles":["Consensus node","Sync types"]},"371":{"title":"Option 2: State sync","titles":["Consensus node","Sync types"]},"372":{"title":"Option 3: Quick sync","titles":["Consensus node","Sync types"]},"373":{"title":"Start the consensus node","titles":["Consensus node"]},"374":{"title":"Extra resources for consensus nodes","titles":["Consensus node"]},"375":{"title":"Optional: Reset network","titles":["Consensus node","Extra resources for consensus nodes"]},"376":{"title":"Optional: Configure an RPC endpoint","titles":["Consensus node","Extra resources for consensus nodes"]},"377":{"title":"Expose RPC","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"378":{"title":"Note on external-address","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"379":{"title":"Restart the node","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"380":{"title":"Optional: Transaction indexer configuration options","titles":["Consensus node","Extra resources for consensus nodes"]},"381":{"title":"Optional: Discard ABCI responses configuration","titles":["Consensus node","Extra resources for consensus nodes"]},"382":{"title":"FAQ","titles":["Consensus node"]},"383":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Consensus node","FAQ"]},"384":{"title":"Deciding which node to run","titles":[]},"385":{"title":"Light node","titles":["Deciding which node to run"]},"386":{"title":"Other DA nodes","titles":["Deciding which node to run","Light node"]},"387":{"title":"Consensus node","titles":["Deciding which node to run"]},"388":{"title":"🐳 Docker setup","titles":[]},"389":{"title":"Prerequisites","titles":["🐳 Docker setup"]},"390":{"title":"Quick start","titles":["🐳 Docker setup"]},"391":{"title":"Light node setup with persistent storage","titles":["🐳 Docker setup"]},"392":{"title":"Initialize the node store and key","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"393":{"title":"Start the node","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"394":{"title":"Video walkthrough","titles":["🐳 Docker setup"]},"395":{"title":"2.5 minute version","titles":["🐳 Docker setup","Video walkthrough"]},"396":{"title":"Troubleshooting","titles":["🐳 Docker setup"]},"397":{"title":"Development environment","titles":[]},"398":{"title":"Install dependencies","titles":["Development environment"]},"399":{"title":"Install Golang","titles":["Development environment"]},"400":{"title":"Ethereum fallback","titles":[]},"401":{"title":"FeeGrant module for blobs submission","titles":[]},"402":{"title":"Overview","titles":["FeeGrant module for blobs submission"]},"403":{"title":"Pre-requisites","titles":["FeeGrant module for blobs submission"]},"404":{"title":"Introduction","titles":["FeeGrant module for blobs submission"]},"405":{"title":"Granting fee allowances using celestia-node","titles":["FeeGrant module for blobs submission"]},"406":{"title":"FeeGrant module implementation in celestia-node","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"407":{"title":"Grant permission for an allowance as a granter","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"408":{"title":"Using a FeeGrant allowance as a grantee in celestia-node","titles":["FeeGrant module for blobs submission"]},"409":{"title":"Checking account balances after submission","titles":["FeeGrant module for blobs submission"]},"410":{"title":"Optional: Revoke permission for a FeeGrant allowance as a granter","titles":["FeeGrant module for blobs submission"]},"411":{"title":"Optional: Submitting a blob from file input","titles":["FeeGrant module for blobs submission","Optional: Revoke permission for a FeeGrant allowance as a granter"]},"412":{"title":"Optional: Granting fee allowances using celestia-appd","titles":["FeeGrant module for blobs submission"]},"413":{"title":"Optional: Checking the granter\'s account","titles":["FeeGrant module for blobs submission","Optional: Granting fee allowances using celestia-appd"]},"414":{"title":"Setting up a Celestia full storage Node","titles":[]},"415":{"title":"Overview of full storage nodes","titles":["Setting up a Celestia full storage Node"]},"416":{"title":"Hardware requirements","titles":["Setting up a Celestia full storage Node"]},"417":{"title":"Setting up your full storage node","titles":["Setting up a Celestia full storage Node"]},"418":{"title":"Setup the dependencies","titles":["Setting up a Celestia full storage Node","Setting up your full storage node"]},"419":{"title":"Install celestia-node","titles":["Setting up a Celestia full storage Node"]},"420":{"title":"Run the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"421":{"title":"Initialize the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"422":{"title":"Start the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"423":{"title":"Optional: run the full storage node with a custom key","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"424":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia full storage Node","Install celestia-node","Optional: run the full storage node with a custom key"]},"425":{"title":"Optional: start the full storage node with SystemD","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"426":{"title":"Stop the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"427":{"title":"IBC relaying guide","titles":[]},"428":{"title":"Hermes","titles":["IBC relaying guide"]},"429":{"title":"Configuration","titles":["IBC relaying guide","Hermes"]},"430":{"title":"Add relayer wallets","titles":["IBC relaying guide","Hermes"]},"431":{"title":"Verify configuration files","titles":["IBC relaying guide","Hermes"]},"432":{"title":"Create a connection between 2 chains","titles":["IBC relaying guide"]},"433":{"title":"Create clients","titles":["IBC relaying guide"]},"434":{"title":"Open connection over new clients","titles":["IBC relaying guide","Create clients"]},"435":{"title":"Configure channels in Hermes","titles":["IBC relaying guide","Create clients"]},"436":{"title":"Start the relayer","titles":["IBC relaying guide"]},"437":{"title":"Transfer","titles":["IBC relaying guide"]},"438":{"title":"Token filter","titles":["IBC relaying guide","Transfer"]},"439":{"title":"Celestia App network instantiation guide","titles":[]},"440":{"title":"Hardware requirements","titles":["Celestia App network instantiation guide"]},"441":{"title":"Setup dependencies","titles":["Celestia App network instantiation guide"]},"442":{"title":"celestia-app installation","titles":["Celestia App network instantiation guide"]},"443":{"title":"Spin up a Celestia testnet","titles":["Celestia App network instantiation guide"]},"444":{"title":"Optional: Reset working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"445":{"title":"Initialize a working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"446":{"title":"Create a new key","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"447":{"title":"Add genesis account KeyName","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"448":{"title":"Optional: Adding other validators","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"449":{"title":"Create the genesis transaction for new chain","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"450":{"title":"Creating the genesis JSON file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"451":{"title":"Modify your config file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"452":{"title":"Add your node as a persistent peer","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"453":{"title":"Instantiate the network","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"454":{"title":"Introduction to OP Stack integration","titles":[]},"455":{"title":"About the integration","titles":["Introduction to OP Stack integration"]},"456":{"title":"GitHub repository","titles":["Introduction to OP Stack integration","About the integration"]},"457":{"title":"Next steps","titles":["Introduction to OP Stack integration"]},"458":{"title":"Setting up a Celestia light node","titles":[]},"459":{"title":"Overview of light nodes","titles":["Setting up a Celestia light node"]},"460":{"title":"Hardware requirements","titles":["Setting up a Celestia light node"]},"461":{"title":"Quickstart: Run a light node in your browser","titles":["Setting up a Celestia light node"]},"462":{"title":"Setting up your light node","titles":["Setting up a Celestia light node"]},"463":{"title":"Install celestia-node","titles":["Setting up a Celestia light node","Setting up your light node"]},"464":{"title":"Initialize the light node","titles":["Setting up a Celestia light node"]},"465":{"title":"Start the light node","titles":["Setting up a Celestia light node"]},"466":{"title":"Keys and wallets","titles":["Setting up a Celestia light node","Start the light node"]},"467":{"title":"Testnet tokens","titles":["Setting up a Celestia light node","Start the light node","Keys and wallets"]},"468":{"title":"Optional: run the light node with a custom key","titles":["Setting up a Celestia light node","Start the light node"]},"469":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia light node","Start the light node","Optional: run the light node with a custom key"]},"470":{"title":"Optional: start light node with SystemD","titles":["Setting up a Celestia light node","Start the light node"]},"471":{"title":"Data availability sampling","titles":["Setting up a Celestia light node"]},"472":{"title":"Setting up a Celestia local testnet","titles":[]},"473":{"title":"Prerequisites","titles":["Setting up a Celestia local testnet"]},"474":{"title":"Bash script","titles":["Setting up a Celestia local testnet"]},"475":{"title":"Manual setup","titles":["Setting up a Celestia local testnet"]},"476":{"title":"Starting the validator node","titles":["Setting up a Celestia local testnet","Manual setup"]},"477":{"title":"Setting up the bridge node","titles":["Setting up a Celestia local testnet","Manual setup"]},"478":{"title":"Setting up the light node","titles":["Setting up a Celestia local testnet","Manual setup"]},"479":{"title":"Funding and testing","titles":["Setting up a Celestia local testnet","Manual setup"]},"480":{"title":"Mainnet Beta","titles":[]},"481":{"title":"Network stability and upgrades","titles":["Mainnet Beta"]},"482":{"title":"Network details","titles":["Mainnet Beta"]},"483":{"title":"Software version numbers","titles":["Mainnet Beta"]},"484":{"title":"Network parameters","titles":["Mainnet Beta"]},"485":{"title":"Maximum bytes","titles":["Mainnet Beta","Network parameters"]},"486":{"title":"Integrations","titles":["Mainnet Beta"]},"487":{"title":"Production RPC endpoints","titles":["Mainnet Beta","Integrations"]},"488":{"title":"Consensus nodes","titles":["Mainnet Beta","Integrations"]},"489":{"title":"Community consensus RPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"490":{"title":"Community API endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"491":{"title":"Community gRPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"492":{"title":"Community WebSocket endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"493":{"title":"Data availability nodes","titles":["Mainnet Beta","Integrations"]},"494":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"495":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"496":{"title":"Archival DA RPC endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"497":{"title":"Grove archival endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes","Archival DA RPC endpoints"]},"498":{"title":"Explorers","titles":["Mainnet Beta"]},"499":{"title":"Analytics","titles":["Mainnet Beta"]},"500":{"title":"Network upgrades","titles":["Mainnet Beta"]},"501":{"title":"Mocha testnet","titles":[]},"502":{"title":"Network details","titles":["Mocha testnet"]},"503":{"title":"Software version numbers","titles":["Mocha testnet"]},"504":{"title":"RPC for DA bridge, full, and light nodes","titles":["Mocha testnet"]},"505":{"title":"Production RPC endpoints","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"506":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"507":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"508":{"title":"Community RPC endpoints","titles":["Mocha testnet"]},"509":{"title":"Community API endpoints","titles":["Mocha testnet"]},"510":{"title":"Community gRPC endpoints","titles":["Mocha testnet"]},"511":{"title":"Community bridge and full node endpoints","titles":["Mocha testnet"]},"512":{"title":"Mocha testnet faucet","titles":["Mocha testnet"]},"513":{"title":"Analytics","titles":["Mocha testnet"]},"514":{"title":"Explorers","titles":["Mocha testnet"]},"515":{"title":"Network upgrades","titles":["Mocha testnet"]},"516":{"title":"MultiAccounts feature for blobs submission","titles":[]},"517":{"title":"Overview","titles":["MultiAccounts feature for blobs submission"]},"518":{"title":"Running a node with a different default key name","titles":["MultiAccounts feature for blobs submission"]},"519":{"title":"Submitting blobs with a different signer/key name","titles":["MultiAccounts feature for blobs submission"]},"520":{"title":"Option 1: Submit passing key name","titles":["MultiAccounts feature for blobs submission","Submitting blobs with a different signer/key name"]},"521":{"title":"Option 2: Submit passing signer address","titles":["MultiAccounts feature for blobs submission","Submitting blobs with a different signer/key name"]},"522":{"title":"Key management","titles":["MultiAccounts feature for blobs submission"]},"523":{"title":"Creating a new key","titles":["MultiAccounts feature for blobs submission","Key management"]},"524":{"title":"Importing an existing key","titles":["MultiAccounts feature for blobs submission","Key management"]},"525":{"title":"Optional flags for write transactions","titles":["MultiAccounts feature for blobs submission"]},"526":{"title":"Celestia network upgrade process","titles":[]},"527":{"title":"Network upgrade coordination","titles":["Celestia network upgrade process"]},"528":{"title":"Upgrade process","titles":["Celestia network upgrade process"]},"529":{"title":"Upcoming upgrade","titles":["Celestia network upgrade process","Upgrade process"]},"530":{"title":"Ginger network upgrade","titles":["Celestia network upgrade process","Upgrade process","Upcoming upgrade"]},"531":{"title":"Past Upgrades","titles":["Celestia network upgrade process","Upgrade process"]},"532":{"title":"Lemongrass network upgrade","titles":["Celestia network upgrade process","Upgrade process","Past Upgrades"]},"533":{"title":"Overview to running nodes on Celestia","titles":[]},"534":{"title":"Recommended Celestia node requirements","titles":["Overview to running nodes on Celestia"]},"535":{"title":"Data availability nodes","titles":["Overview to running nodes on Celestia"]},"536":{"title":"Consensus nodes","titles":["Overview to running nodes on Celestia"]},"537":{"title":"Optimism devnet deep dive","titles":[]},"538":{"title":"Find a transaction","titles":["Optimism devnet deep dive"]},"539":{"title":"Read the transaction call data","titles":["Optimism devnet deep dive"]},"540":{"title":"Find the data on Celestia","titles":["Optimism devnet deep dive"]},"541":{"title":"Span batches","titles":["Optimism devnet deep dive"]},"542":{"title":"Run an OP Stack rollup with Celestia underneath","titles":[]},"543":{"title":"Dependency setup","titles":["Run an OP Stack rollup with Celestia underneath"]},"544":{"title":"Setting up your light node","titles":["Run an OP Stack rollup with Celestia underneath","Dependency setup"]},"545":{"title":"Deploying a devnet to Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"546":{"title":"Deploying a testnet to an L1 (or L2) and Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"547":{"title":"Congratulations","titles":["Run an OP Stack rollup with Celestia underneath"]},"548":{"title":"Participate in the Celestia networks","titles":[]},"549":{"title":"Mainnet Beta","titles":["Participate in the Celestia networks"]},"550":{"title":"Compatible software versions for Mainnet Beta","titles":["Participate in the Celestia networks","Mainnet Beta"]},"551":{"title":"Testnets","titles":["Participate in the Celestia networks"]},"552":{"title":"Arabica Devnet","titles":["Participate in the Celestia networks","Testnets"]},"553":{"title":"Compatible software versions for Arabica devnet","titles":["Participate in the Celestia networks","Testnets","Arabica Devnet"]},"554":{"title":"Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"555":{"title":"Compatible software versions for Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"556":{"title":"Network upgrades","titles":["Participate in the Celestia networks"]},"557":{"title":"Quick-start guide","titles":[]},"558":{"title":"Run a light node","titles":["Quick-start guide"]},"559":{"title":"Initialize the light node","titles":["Quick-start guide","Run a light node"]},"560":{"title":"Set the trusted hash","titles":["Quick-start guide","Run a light node","Initialize the light node"]},"561":{"title":"Start the light node","titles":["Quick-start guide","Run a light node"]},"562":{"title":"Post and retrieve data with your light node","titles":["Quick-start guide"]},"563":{"title":"Funding your light node","titles":["Quick-start guide","Post and retrieve data with your light node"]},"564":{"title":"Posting data","titles":["Quick-start guide","Post and retrieve data with your light node"]},"565":{"title":"Retrieving data","titles":["Quick-start guide","Post and retrieve data with your light node"]},"566":{"title":"Diving deeper into the stack","titles":["Quick-start guide"]},"567":{"title":"Get your auth token","titles":["Quick-start guide","Diving deeper into the stack"]},"568":{"title":"Key management with cel-key","titles":["Quick-start guide","Diving deeper into the stack"]},"569":{"title":"Rust client tutorial","titles":["Quick-start guide","Diving deeper into the stack"]},"570":{"title":"Golang client tutorial","titles":["Quick-start guide","Diving deeper into the stack"]},"571":{"title":"Node store contents","titles":["Quick-start guide","Diving deeper into the stack"]},"572":{"title":"Troubleshooting","titles":["Quick-start guide"]},"573":{"title":"Next steps","titles":["Quick-start guide"]},"574":{"title":"Rollup stacks","titles":[]},"575":{"title":"Quickstart - Building on Celestia","titles":["Rollup stacks"]},"576":{"title":"Choose a framework","titles":["Rollup stacks","Quickstart - Building on Celestia"]},"577":{"title":"Rollups as a Service","titles":["Rollup stacks","Quickstart - Building on Celestia"]},"578":{"title":"Smart contracts","titles":["Rollup stacks","Quickstart - Building on Celestia"]},"579":{"title":"What is a rollup?","titles":["Rollup stacks"]},"580":{"title":"What is a modular blockchain?","titles":["Rollup stacks"]},"581":{"title":"Benefits of modular blockchains","titles":["Rollup stacks"]},"582":{"title":"Ease of deploying a chain","titles":["Rollup stacks","Benefits of modular blockchains"]},"583":{"title":"Scaling","titles":["Rollup stacks","Benefits of modular blockchains"]},"584":{"title":"Customizability","titles":["Rollup stacks","Benefits of modular blockchains"]},"585":{"title":"New SP1 Blobstream deployments","titles":[]},"586":{"title":"Deploying the contracts","titles":["New SP1 Blobstream deployments"]},"587":{"title":"Submitting data blobs to Celestia","titles":[]},"588":{"title":"Maximum blob size","titles":["Submitting data blobs to Celestia"]},"589":{"title":"Fee market and mempool","titles":["Submitting data blobs to Celestia"]},"590":{"title":"Fees and gas limits","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"591":{"title":"Estimating PFB gas","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"592":{"title":"Gas fee calculation","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"593":{"title":"Estimating gas programmatically","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"594":{"title":"Submitting multiple transactions in one block from the same account","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"595":{"title":"API","titles":["Submitting data blobs to Celestia"]},"596":{"title":"The celestia-app consensus node CLI","titles":["Submitting data blobs to Celestia","API"]},"597":{"title":"The celestia-node light node CLI","titles":["Submitting data blobs to Celestia","API"]},"598":{"title":"The celestia-node API golang client","titles":["Submitting data blobs to Celestia","API"]},"599":{"title":"GRPC to a consensus node via the user package","titles":["Submitting data blobs to Celestia","API"]},"600":{"title":"RPC to a celestia-node","titles":["Submitting data blobs to Celestia","API"]},"601":{"title":"Post a blob directly from Celenium","titles":["Submitting data blobs to Celestia","API"]},"602":{"title":"Setting up your node as a background process with SystemD","titles":[]},"603":{"title":"Consensus nodes","titles":["Setting up your node as a background process with SystemD"]},"604":{"title":"Start the celestia-app with SystemD","titles":["Setting up your node as a background process with SystemD","Consensus nodes"]},"605":{"title":"Data availability nodes","titles":["Setting up your node as a background process with SystemD"]},"606":{"title":"Celestia full storage node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"607":{"title":"Celestia bridge node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"608":{"title":"Celestia light node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"609":{"title":"Transaction resubmission","titles":[]},"610":{"title":"Monitoring and resubmission","titles":["Transaction resubmission"]},"611":{"title":"Notes","titles":["Transaction resubmission"]},"612":{"title":"Setting up a Celestia validator node","titles":[]},"613":{"title":"Hardware requirements","titles":["Setting up a Celestia validator node"]},"614":{"title":"Setting up a validator node","titles":["Setting up a Celestia validator node"]},"615":{"title":"Wallet","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"616":{"title":"Delegate stake to a validator","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"617":{"title":"Optional: Deploy the celestia-node","titles":["Setting up a Celestia validator node"]},"618":{"title":"Install celestia-node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"619":{"title":"Initialize the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"620":{"title":"Run the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"621":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node","Run the bridge node"]},"622":{"title":"Run the validator node","titles":["Setting up a Celestia validator node"]},"623":{"title":"Submit your validator information","titles":["Setting up a Celestia validator node"]},"624":{"title":"Optional: Transaction indexer configuration options","titles":["Setting up a Celestia validator node"]},"625":{"title":"Additional resources","titles":["Setting up a Celestia validator node"]},"626":{"title":"FAQ","titles":["Setting up a Celestia validator node"]},"627":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Setting up a Celestia validator node","FAQ"]},"628":{"title":"Data availability FAQ","titles":[]},"629":{"title":"What is data availability?","titles":["Data availability FAQ"]},"630":{"title":"What is the data availability problem?","titles":["Data availability FAQ"]},"631":{"title":"How do nodes verify data availability in Celestia?","titles":["Data availability FAQ"]},"632":{"title":"What is data availability sampling?","titles":["Data availability FAQ"]},"633":{"title":"What are some of the security assumptions that Celestia makes for data availability sampling?","titles":["Data availability FAQ"]},"634":{"title":"Why is block reconstruction necessary for security?","titles":["Data availability FAQ"]},"635":{"title":"What is data storage?","titles":["Data availability FAQ"]},"636":{"title":"What is the problem around data storage?","titles":["Data availability FAQ"]},"637":{"title":"What is the difference between data availability and data storage?","titles":["Data availability FAQ"]},"638":{"title":"Where does blockchain state fit into this?","titles":["Data availability FAQ"]},"639":{"title":"Why doesn’t Celestia incentivize storage of historical data?","titles":["Data availability FAQ"]},"640":{"title":"Who may store historical data if there is no reward?","titles":["Data availability FAQ"]},"641":{"title":"What are some things blockchains can do to provide stronger assurances of data retrievability?","titles":["Data availability FAQ"]},"642":{"title":"Celestia\'s data availability layer","titles":[]},"643":{"title":"Data availability sampling (DAS)","titles":["Celestia\'s data availability layer"]},"644":{"title":"Scalability","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"645":{"title":"Fraud proofs of incorrectly extended data","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"646":{"title":"Namespaced Merkle trees (NMTs)","titles":["Celestia\'s data availability layer"]},"647":{"title":"Building a PoS blockchain for DA","titles":["Celestia\'s data availability layer"]},"648":{"title":"Providing data availability","titles":["Celestia\'s data availability layer","Building a PoS blockchain for DA"]},"649":{"title":"Monolithic vs. modular blockchains","titles":[]},"650":{"title":"Introduction","titles":[]},"651":{"title":"The lifecycle of a celestia-app transaction","titles":[]},"652":{"title":"Checking data availability","titles":["The lifecycle of a celestia-app transaction"]},"653":{"title":"How to stake TIA","titles":[]},"654":{"title":"Select your preferred wallet","titles":["How to stake TIA"]},"655":{"title":"Stake TIA with Keplr wallet","titles":["How to stake TIA"]},"656":{"title":"1️⃣ Open your Keplr browser extension","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"657":{"title":"2️⃣ Select Celestia network and search for a validator","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"658":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"659":{"title":"4️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"660":{"title":"Stake TIA with Leap wallet","titles":["How to stake TIA"]},"661":{"title":"1️⃣ Open your Leap browser extension","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"662":{"title":"2️⃣ Select a validator and stake TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"663":{"title":"3️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"664":{"title":"Stake TIA with Gem wallet","titles":["How to stake TIA"]},"665":{"title":"1️⃣ Open your Gem Wallet app","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"666":{"title":"2️⃣ Choose the amount of Celestia and search for a validator.","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"667":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"668":{"title":"4️⃣ Manage your TIA","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"669":{"title":"Paying for blobspace","titles":[]},"670":{"title":"PayForBlobs transactions","titles":["Paying for blobspace"]},"671":{"title":"Fee market overview","titles":["Paying for blobspace"]},"672":{"title":"Data retrievability and pruning","titles":[]},"673":{"title":"Data retrievability and pruning in celestia-node","titles":["Data retrievability and pruning"]},"674":{"title":"Suggested practices for rollups","titles":["Data retrievability and pruning"]},"675":{"title":"Staking, governance, & supply","titles":[]},"676":{"title":"Proof-of-stake on Celestia","titles":["Staking, governance, & supply"]},"677":{"title":"Inflation","titles":["Staking, governance, & supply"]},"678":{"title":"Decentralised governance","titles":["Staking, governance, & supply"]},"679":{"title":"Network parameters","titles":["Staking, governance, & supply","Decentralised governance"]},"680":{"title":"Community pool","titles":["Staking, governance, & supply","Decentralised governance"]},"681":{"title":"TIA allocation at genesis","titles":["Staking, governance, & supply"]},"682":{"title":"Unlocks","titles":["Staking, governance, & supply","TIA allocation at genesis"]},"683":{"title":"Staking on Celestia","titles":[]},"684":{"title":"Mainnet Beta","titles":["Staking on Celestia"]},"685":{"title":"Mocha testnet","titles":["Staking on Celestia"]},"686":{"title":"Overview of TIA","titles":[]},"687":{"title":"TIA at a glance","titles":["Overview of TIA"]},"688":{"title":"Role of TIA","titles":["Overview of TIA"]},"689":{"title":"Paying for blobspace","titles":["Overview of TIA","Role of TIA"]},"690":{"title":"Bootstrapping new rollups","titles":["Overview of TIA","Role of TIA"]},"691":{"title":"Proof-of-stake","titles":["Overview of TIA","Role of TIA"]},"692":{"title":"Decentralised governance","titles":["Overview of TIA","Role of TIA"]},"693":{"title":"Denominations","titles":["Overview of TIA","Role of TIA"]},"694":{"title":"TIA: display token","titles":["Overview of TIA","Role of TIA","Denominations"]},"695":{"title":"utia: staking denomination","titles":["Overview of TIA","Role of TIA","Denominations"]},"696":{"title":"microtia: staking denomination alias","titles":["Overview of TIA","Role of TIA","Denominations"]},"697":{"title":"Create a wallet with celestia-node","titles":[]},"698":{"title":"Using the cel-key utility","titles":["Create a wallet with celestia-node"]},"699":{"title":"Installation","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"700":{"title":"Steps for generating node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"701":{"title":"Steps for exporting node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"702":{"title":"Steps for importing node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"703":{"title":"View all options for cel-key","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"704":{"title":"Docker and cel-key","titles":["Create a wallet with celestia-node"]},"705":{"title":"Prerequisites","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"706":{"title":"Running your node","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"707":{"title":"Mounting existing keys to container","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"708":{"title":"Golang client library tutorial","titles":[]},"709":{"title":"Project setup","titles":["Golang client library tutorial"]},"710":{"title":"Submitting and retrieving blobs","titles":["Golang client library tutorial"]},"711":{"title":"Subscribing to new blobs","titles":["Golang client library tutorial"]},"712":{"title":"Subscribing to new headers","titles":["Golang client library tutorial"]},"713":{"title":"Fetching an Extended Data Square (EDS)","titles":["Golang client library tutorial"]},"714":{"title":"API documentation","titles":["Golang client library tutorial"]},"715":{"title":"Integrate Celestia for service providers","titles":[]},"716":{"title":"Getting started","titles":["Integrate Celestia for service providers"]},"717":{"title":"Celestia service provider notes","titles":["Integrate Celestia for service providers"]},"718":{"title":"Custody and key management","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"719":{"title":"RPC and querying","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"720":{"title":"Compatibility","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"721":{"title":"Syncing","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"722":{"title":"Notable exceptions relative to other blockchains","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"723":{"title":"Node API","titles":[]},"724":{"title":"RPC API","titles":["Node API"]},"725":{"title":"Library","titles":["Node API","RPC API"]},"726":{"title":"RPC","titles":["Node API","RPC API"]},"727":{"title":"RPC API tutorial","titles":["Node API","RPC API"]},"728":{"title":"Gateway API","titles":["Node API"]},"729":{"title":"Gateway API tutorial","titles":["Node API","Gateway API"]},"730":{"title":"Celestia-node RPC CLI tutorial","titles":[]},"731":{"title":"Introduction","titles":["Celestia-node RPC CLI tutorial"]},"732":{"title":"Blobs","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"733":{"title":"Namespaces","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"734":{"title":"Hardware requirements","titles":["Celestia-node RPC CLI tutorial"]},"735":{"title":"Setting up dependencies","titles":["Celestia-node RPC CLI tutorial"]},"736":{"title":"Instantiate a Celestia light node","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"737":{"title":"Connect to a core endpoint","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"738":{"title":"Keys and wallets","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"739":{"title":"RPC CLI guide","titles":["Celestia-node RPC CLI tutorial"]},"740":{"title":"Command formatting","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"741":{"title":"Basic flags","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"742":{"title":"Auth token 🔐","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"743":{"title":"Node store","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"744":{"title":"Auth token on custom or private network","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags","Node store"]},"745":{"title":"Submitting data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"746":{"title":"Optional: Submit with curl","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Submitting data"]},"747":{"title":"Retrieving data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"748":{"title":"Setting the gas price","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"749":{"title":"Examples","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"750":{"title":"Check your balance","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"751":{"title":"Check the balance of another address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"752":{"title":"Get your node ID","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"753":{"title":"Get your account address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"754":{"title":"Get block header by height","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"755":{"title":"Combined commands","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"756":{"title":"Get data availability sampler stats","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"757":{"title":"Transfer balance of utia to another account","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"758":{"title":"API version","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"759":{"title":"Help","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"760":{"title":"Advanced example","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"761":{"title":"Additional resources","titles":["Celestia-node RPC CLI tutorial"]},"762":{"title":"Submitting a blob using curl","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"763":{"title":"Post an SVG as a PFB","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"764":{"title":"Troubleshooting","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"765":{"title":"Prompt scavenger","titles":[]},"766":{"title":"Dependencies","titles":["Prompt scavenger"]},"767":{"title":"Install Celestia Node and run a light node","titles":["Prompt scavenger","Dependencies"]},"768":{"title":"OpenAI key","titles":["Prompt scavenger","Dependencies"]},"769":{"title":"Building the Prompt Scavenger","titles":["Prompt scavenger"]},"770":{"title":"Initialize your Go project","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"771":{"title":"Build your import statements","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"772":{"title":"Main function","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"773":{"title":"Utility functions","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"774":{"title":"Prompting ChatGPT","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"775":{"title":"Wrapping things up","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"776":{"title":"Next steps","titles":["Prompt scavenger"]},"777":{"title":"Rust client library tutorial","titles":[]},"778":{"title":"Project setup","titles":["Rust client library tutorial"]},"779":{"title":"Submitting and retrieving blobs","titles":["Rust client library tutorial"]},"780":{"title":"Subscribing to new headers","titles":["Rust client library tutorial"]},"781":{"title":"Fetching an Extended Data Square (EDS)","titles":["Rust client library tutorial"]},"782":{"title":"API documentation","titles":["Rust client library tutorial"]},"783":{"title":"Wallet integrations with Celestia","titles":[]},"784":{"title":"Add Celestia network parameters to Keplr with React","titles":["Wallet integrations with Celestia"]},"785":{"title":"Adding a custom chain to Leap","titles":["Wallet integrations with Celestia"]},"786":{"title":"Adding a custom chain to Cosmostation","titles":["Wallet integrations with Celestia"]}},"dirtCount":0,"index":[["∑i=1nssn",{"2":{"592":1}}],["×ss×gcpbb",{"2":{"592":1}}],[">",{"2":{"577":3}}],["||",{"2":{"698":2}}],["|",{"2":{"264":4,"361":14,"372":12,"477":2,"539":4,"541":1,"560":4,"604":4,"745":4,"747":2,"755":2,"757":2,"760":2}}],["~2",{"2":{"485":1}}],["~20",{"2":{"214":1}}],["~5",{"2":{"369":1}}],["~",{"2":{"246":1,"247":1,"336":4,"372":18,"377":2,"423":1,"424":1,"468":1,"469":1,"559":1,"571":2,"707":2,"767":2}}],["~1",{"2":{"369":1}}],["~10",{"2":{"215":1}}],["~1hr",{"2":{"215":1}}],["~30",{"2":{"217":1}}],["~3",{"2":{"215":1,"369":1}}],["^external",{"2":{"378":2}}],["^persistent",{"2":{"361":6}}],["^seeds",{"2":{"361":4}}],["^",{"2":{"203":2,"214":4,"215":4}}],["^0",{"2":{"118":2,"163":2}}],["\\tpromptanswer",{"2":{"775":2}}],["\\tproof",{"2":{"144":2}}],["\\tpayload",{"2":{"773":2}}],["\\theader",{"2":{"713":2}}],["\\theaderchan",{"2":{"712":2}}],["\\thelloworldblob",{"2":{"598":2,"710":2}}],["\\theight",{"2":{"144":2,"160":2,"163":4,"598":2,"710":2,"773":2}}],["\\tns",{"2":{"773":2}}],["\\tnodeip",{"2":{"772":2,"773":2,"775":2}}],["\\tnodeclient",{"2":{"771":2}}],["\\tnonce",{"2":{"144":2,"160":2,"163":4}}],["\\tnamespaceid",{"2":{"773":2,"775":2}}],["\\tnamespacebytes",{"2":{"773":2}}],["\\tnamespace",{"2":{"598":2,"710":2,"711":2,"712":2}}],["\\tlog",{"2":{"773":6,"775":4}}],["\\tlight",{"2":{"561":2}}],["\\tlatestblocknumber",{"2":{"144":2,"161":2}}],["\\tretrievedblobs",{"2":{"598":2,"710":2}}],["\\treturn",{"2":{"144":4,"156":8,"157":2,"158":2,"159":2,"160":2,"163":18,"598":2,"710":2,"713":2,"773":4,"774":4}}],["\\trowproofs",{"2":{"159":2,"163":2}}],["\\trowroots",{"2":{"158":2,"163":2}}],["\\tmaxns",{"2":{"156":2,"163":2}}],["\\tmaxsquaresize",{"2":{"150":2}}],["\\tminns",{"2":{"156":2,"163":2}}],["\\tsimplerollup",{"2":{"163":2}}],["\\tsimplerollupwrapper",{"2":{"163":2}}],["\\tsidenodes",{"2":{"144":2,"160":2,"163":2}}],["\\tshareproofs",{"2":{"156":2,"163":2}}],["\\tsharesproof",{"2":{"153":1,"163":4}}],["\\tsubtreerootthreshold",{"2":{"150":2}}],["\\tversion",{"2":{"150":2,"156":4,"163":6}}],["\\tvalid",{"2":{"144":2}}],["\\tvar",{"2":{"144":2,"156":6,"157":2,"161":2,"163":10}}],["\\twrappedproof",{"2":{"144":2}}],["\\twrapper",{"2":{"144":2,"161":2}}],["\\tcreatedblob",{"2":{"773":4,"775":2}}],["\\tclient",{"2":{"598":4,"710":4,"711":2,"712":2,"713":2,"772":2,"773":4,"775":2}}],["\\tcopy",{"2":{"156":6,"157":2,"163":2}}],["\\tcommitted",{"2":{"144":2}}],["\\tctx",{"2":{"143":2,"144":2,"163":4,"772":2,"773":4,"775":2}}],["\\tfetchedblob",{"2":{"773":2,"775":2}}],["\\tfor",{"2":{"144":4,"156":2,"158":2,"159":2,"160":2,"161":2,"163":16,"711":2,"712":2}}],["\\tfmt",{"2":{"143":2,"598":4,"710":4}}],["\\tblobchan",{"2":{"711":2}}],["\\tblobsharerange",{"2":{"150":2}}],["\\tblobstreamxwrapper",{"2":{"144":4,"163":2}}],["\\tblockdataroot",{"2":{"160":2,"163":2}}],["\\tblockres",{"2":{"144":2,"150":2}}],["\\ttmproto",{"2":{"163":2}}],["\\ttuple",{"2":{"144":2}}],["\\ttxhash",{"2":{"150":2}}],["\\ttx",{"2":{"144":2,"150":2,"163":2}}],["\\ttrpc",{"2":{"143":2,"144":2}}],["\\teventsiterator",{"2":{"144":2,"161":2}}],["\\tethclient",{"2":{"144":2,"161":2,"163":2}}],["\\tethcmn",{"2":{"144":2,"163":2}}],["\\terr",{"2":{"136":2,"143":2,"144":6,"161":2,"163":4}}],["\\tdatarootinclusionproof",{"2":{"160":2,"163":4}}],["\\tdataroot",{"2":{"144":2,"163":2}}],["\\tdcproof",{"2":{"143":2,"144":2}}],["\\tdefer",{"2":{"136":2,"144":2,"161":2,"163":2,"772":4,"773":4,"775":4}}],["\\t",{"2":{"136":6,"143":14,"144":90,"148":2,"150":22,"153":2,"156":8,"157":2,"158":2,"159":2,"160":4,"161":27,"162":24,"163":98,"559":2,"561":4,"598":28,"710":28,"711":12,"712":12,"713":8,"771":28,"772":24,"773":54,"775":26}}],["\\t\\tlog",{"2":{"772":4,"773":10,"775":12}}],["\\t\\tuint64",{"2":{"163":2}}],["\\t\\tclient",{"2":{"163":2}}],["\\t\\tctx",{"2":{"163":2,"774":2}}],["\\t\\tcase",{"2":{"162":4,"711":4,"712":4}}],["\\t\\tcopy",{"2":{"160":2}}],["\\t\\tproof",{"2":{"160":2,"163":2}}],["\\t\\tvar",{"2":{"160":2,"163":2}}],["\\t\\tversion",{"2":{"156":4,"157":2,"163":6}}],["\\t\\trowproofs",{"2":{"159":2,"163":2}}],["\\t\\trowroots",{"2":{"158":2,"163":2}}],["\\t\\treturn",{"2":{"136":2,"144":30,"150":8,"161":14,"163":8,"598":10,"710":10,"711":6,"712":6,"713":4,"773":6}}],["\\t\\tdcproof",{"2":{"163":2}}],["\\t\\tdigest",{"2":{"156":2,"163":4}}],["\\t\\tdataroot",{"2":{"144":2}}],["\\t\\tmax",{"2":{"156":2,"163":2}}],["\\t\\tmaxsquaresize",{"2":{"150":2}}],["\\t\\tmin",{"2":{"156":2,"163":2}}],["\\t\\tfor",{"2":{"156":2,"159":2,"163":6}}],["\\t\\tfmt",{"2":{"143":6,"144":6,"163":2}}],["\\t\\tselect",{"2":{"711":2,"712":2}}],["\\t\\tsharesproof",{"2":{"163":2}}],["\\t\\tshareproofs",{"2":{"156":2,"163":2}}],["\\t\\tsimplerollupwrapper",{"2":{"163":2}}],["\\t\\tsidenodes",{"2":{"144":4,"156":2,"159":2,"160":2,"163":6}}],["\\t\\tsubtreerootthreshold",{"2":{"150":2}}],["\\t\\tid",{"2":{"156":4,"157":2,"163":12}}],["\\t\\tint",{"2":{"150":2}}],["\\t\\tif",{"2":{"136":2,"144":2,"161":2}}],["\\t\\tblockdataroot",{"2":{"163":2}}],["\\t\\tblockres",{"2":{"150":2,"163":2}}],["\\t\\tbig",{"2":{"144":2}}],["\\t\\twrappedproof",{"2":{"144":2}}],["\\t\\ttuplerootnonce",{"2":{"160":2,"163":2}}],["\\t\\ttuple",{"2":{"144":2,"160":2,"163":2}}],["\\t\\tnumleaves",{"2":{"144":2}}],["\\t\\tnil",{"2":{"144":6,"161":6}}],["\\t\\tkey",{"2":{"144":2}}],["\\t\\theight",{"2":{"144":2}}],["\\t\\tevent",{"2":{"163":2}}],["\\t\\te",{"2":{"144":2,"161":2}}],["\\t\\terr",{"2":{"136":2}}],["\\t\\tos",{"2":{"143":6,"144":2,"163":2}}],["\\t\\t\\tif",{"2":{"712":2}}],["\\t\\t\\tfmt",{"2":{"711":2,"712":2}}],["\\t\\t\\tfor",{"2":{"163":2}}],["\\t\\t\\tattestationproof",{"2":{"163":2}}],["\\t\\t\\trowproofs",{"2":{"163":2}}],["\\t\\t\\trowroots",{"2":{"163":2}}],["\\t\\t\\treturn",{"2":{"162":2,"711":2,"712":2}}],["\\t\\t\\tnamespace",{"2":{"163":2}}],["\\t\\t\\tnumleaves",{"2":{"159":2,"160":2,"163":4}}],["\\t\\t\\tdata",{"2":{"163":2}}],["\\t\\t\\tdataroot",{"2":{"160":2,"163":2}}],["\\t\\t\\theight",{"2":{"160":2,"163":2}}],["\\t\\t\\tkey",{"2":{"159":2,"160":2,"163":4}}],["\\t\\t\\tcopy",{"2":{"159":2}}],["\\t\\t\\tcontext",{"2":{"144":2,"161":2,"162":2,"163":2}}],["\\t\\t\\tvar",{"2":{"159":2,"163":2}}],["\\t\\t\\tblobs",{"2":{"712":2}}],["\\t\\t\\tbzsidenode",{"2":{"163":2}}],["\\t\\t\\tbeginkey",{"2":{"156":2,"163":2}}],["\\t\\t\\tbreak",{"2":{"144":2,"161":2}}],["\\t\\t\\tshareproofs",{"2":{"163":2}}],["\\t\\t\\tsidenodes",{"2":{"156":4,"159":4,"160":2,"163":10}}],["\\t\\t\\tstart",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tfmt",{"2":{"712":2}}],["\\t\\t\\t\\tbzsidenode",{"2":{"163":2}}],["\\t\\t\\t\\tdatacommitment",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tendblock",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tstartblock",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tproofnonce",{"2":{"144":2,"161":2}}],["\\t\\t\\tevent",{"2":{"144":2,"161":2}}],["\\t\\t\\tendkey",{"2":{"156":2,"163":2}}],["\\t\\t\\tend",{"2":{"144":2,"161":2}}],["\\t\\t\\t",{"2":{"136":2,"144":2,"161":2,"162":2,"163":2,"712":4}}],["\\t\\t",{"2":{"136":4,"144":8,"148":4,"150":2,"153":2,"156":4,"159":4,"160":4,"161":6,"162":4,"163":20,"711":2,"712":2}}],["\\tif",{"2":{"136":4,"143":6,"144":32,"150":8,"153":2,"161":14,"163":10,"598":10,"710":10,"711":6,"712":6,"713":4,"772":4,"773":16,"774":2,"775":12}}],["🤪",{"2":{"126":1}}],["```json",{"2":{"754":2}}],["```",{"2":{"754":2}}],["`cel",{"2":{"699":2}}],["`celestia",{"2":{"599":4}}],["`file`",{"2":{"559":2}}],["`$home",{"2":{"361":2}}],["`job=",{"2":{"275":2}}],["`json",{"2":{"125":22}}],["`private",{"2":{"202":2}}],["`mnemonic",{"2":{"202":2}}],["`wallet",{"2":{"202":4}}],["`trpc",{"2":{"163":4}}],["`blobstreamdatacommitmentstored`",{"2":{"161":2,"162":2,"163":2}}],["`availabledataroot`",{"2":{"160":2}}],["`",{"2":{"125":22,"275":2,"699":2,"784":12}}],["=1",{"2":{"485":1}}],["==",{"2":{"144":2,"156":6,"159":3,"161":2,"392":2,"393":2,"591":1,"774":2}}],["=",{"2":{"118":2,"128":28,"130":14,"136":12,"140":8,"143":14,"144":74,"148":8,"150":22,"153":4,"156":20,"158":6,"159":12,"160":10,"161":30,"162":18,"163":96,"175":4,"215":2,"216":1,"218":1,"233":1,"274":8,"303":10,"338":1,"350":1,"352":2,"361":22,"364":2,"365":2,"366":2,"367":3,"368":6,"371":8,"373":1,"378":4,"380":2,"381":2,"429":170,"435":8,"451":2,"546":29,"560":1,"590":1,"592":4,"593":2,"598":20,"599":44,"622":1,"695":1,"710":20,"711":14,"712":18,"713":8,"764":4,"772":10,"773":34,"774":8,"775":26,"779":10,"780":20,"781":4,"784":8}}],["z20=",{"2":{"747":2}}],["zshrcecho",{"2":{"399":1}}],["zshrc",{"2":{"399":3}}],["zxrxj96",{"2":{"147":2}}],["zhsjrh",{"2":{"142":2}}],["zero",{"2":{"118":2,"124":1,"221":1}}],["zkvm",{"2":{"221":1,"227":1,"585":1}}],["zkp",{"2":{"118":2}}],["zk",{"0":{"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"232":1},"1":{"187":1,"188":2,"189":2,"190":1,"191":2,"192":2,"193":2,"194":1,"195":1,"196":1,"233":1,"234":1,"235":1,"236":1},"2":{"118":7,"127":2,"139":2,"165":1,"169":1,"186":1,"187":2,"188":1,"190":2,"191":4,"193":1,"194":5,"196":1,"197":1,"221":1,"227":4}}],["zip",{"2":{"88":2}}],["$address",{"2":{"757":6}}],["$auth",{"2":{"740":2}}],["$input",{"2":{"539":2}}],["$ip",{"2":{"452":2}}],["$trusted",{"2":{"560":4,"561":2}}],["$tx",{"2":{"539":2}}],["$tia",{"2":{"447":2}}],["$to",{"2":{"294":6,"295":2,"297":2,"301":2}}],["$granter",{"2":{"408":2,"412":2,"413":2}}],["$grantee",{"2":{"407":2,"410":2,"412":2}}],["$gopath",{"2":{"342":1,"343":1}}],["$network",{"2":{"390":3,"392":3,"393":3}}],["$networkdocker",{"2":{"390":3,"392":3,"393":3}}],["$node",{"2":{"390":6,"392":2,"452":2,"607":2,"743":3}}],["$encoded",{"2":{"540":2}}],["$external",{"2":{"378":2}}],["$etherscan",{"2":{"210":2}}],["$peer",{"2":{"452":1}}],["$peerpeer=",{"2":{"452":1}}],["$persistent",{"2":{"361":12}}],["$port",{"2":{"452":2}}],["$path",{"2":{"399":1}}],["$private",{"2":{"210":2}}],["$signer",{"2":{"521":2}}],["$shell",{"2":{"399":1}}],["$seeds",{"2":{"361":8}}],["$staking",{"2":{"272":2,"449":3}}],["$",{"2":{"312":2,"314":12,"343":4,"361":2,"372":6,"398":2,"474":2,"558":2,"707":2,"755":2,"760":2}}],["$from",{"2":{"294":6,"296":2,"297":2,"301":2}}],["$broadcast",{"2":{"279":2}}],["$multisig",{"2":{"279":10}}],["$celestia",{"2":{"291":2,"292":2,"294":6,"295":2,"296":2,"297":4,"540":2,"762":2}}],["$celes",{"2":{"272":2}}],["$chain",{"2":{"272":4,"279":10,"445":4,"449":2}}],["$keyring",{"2":{"279":4}}],["$key",{"2":{"272":6,"446":3,"447":3,"449":3}}],["$validator",{"2":{"272":2,"279":6,"445":3,"616":2}}],["$rpc",{"2":{"210":2,"301":2,"390":6,"393":6,"407":2,"408":2,"412":2}}],["$request",{"2":{"70":1,"467":1,"512":1,"738":1}}],["$home",{"2":{"104":2,"203":2,"208":2,"211":2,"214":2,"215":2,"275":3,"286":3,"287":1,"288":2,"291":2,"311":3,"312":1,"341":2,"342":1,"343":1,"349":3,"361":11,"371":1,"372":6,"375":2,"378":2,"391":4,"392":8,"393":8,"399":20,"429":2,"444":2,"448":1,"449":1,"450":4,"451":1,"477":4,"478":6,"479":6,"544":2,"545":2,"744":4}}],["🌉🌉🌉🌉🌉",{"2":{"93":2}}],["⏰⏰⏰⏰⏰⏰",{"2":{"93":2}}],["🔐",{"0":{"742":1}}],["😜",{"2":{"559":1}}],["😎",{"2":{"391":2,"544":1}}],["🐳",{"0":{"388":1},"1":{"389":1,"390":1,"391":1,"392":1,"393":1,"394":1,"395":1,"396":1}}],["🙂",{"2":{"124":1}}],["🔃🔃🔃",{"2":{"93":2}}],["🚀🚀🚀🚀",{"2":{"93":2}}],["📝📝📝📝📝",{"2":{"93":2}}],["💰💰💰💰💰💰",{"2":{"93":2}}],["😁",{"2":{"91":1}}],["9anbaxno1b4x5lr2qy5qwqwrmnozejkctxwzq9bexsg=",{"2":{"754":4}}],["91e04695cf9cf531bc0891e7b1d602b3e8022c86",{"2":{"754":8}}],["99",{"2":{"632":1}}],["999994999800000",{"2":{"297":2}}],["94721",{"2":{"560":1}}],["9390",{"2":{"510":1}}],["973",{"2":{"485":2,"588":1}}],["96112",{"2":{"294":4}}],["90",{"2":{"681":1}}],["9099",{"2":{"510":1}}],["9095",{"2":{"491":1}}],["9090",{"2":{"65":1,"68":1,"244":1,"245":1,"275":2,"313":2,"326":1,"422":1,"465":1,"477":4,"491":2,"495":6,"507":2,"510":5,"737":1,"762":1}}],["9000000utia",{"2":{"449":1}}],["90000",{"2":{"144":2,"161":4}}],["9",{"0":{"92":1}}],["xxd",{"2":{"539":2}}],["xxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"768":1}}],["xxxxxxxxxxxxxxxxxxxxxxxxexport",{"2":{"768":1}}],["xxxxxxxxxxxxx",{"2":{"287":4}}],["xzf",{"2":{"399":8}}],["xf",{"2":{"372":6}}],["x86",{"2":{"312":1,"342":1}}],["xv92a3qxexport",{"2":{"287":1}}],["xv92a3qx",{"2":{"287":3}}],["x64",{"2":{"240":1,"358":1,"417":1,"462":1,"614":1}}],["xthp6xws=",{"2":{"152":2}}],["xiijl+gqm0fqxiw0z0o",{"2":{"152":2}}],["x",{"0":{"97":1,"111":1,"200":1,"232":1,"233":1,"234":1,"235":1},"1":{"98":1,"99":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"233":1,"234":1,"235":1,"236":1},"2":{"91":4,"96":1,"97":1,"108":1,"121":1,"122":7,"163":4,"164":1,"201":1,"203":2,"216":3,"217":1,"218":4,"219":2,"221":3,"222":2,"233":6,"234":3,"235":3,"266":1,"281":1,"372":6,"373":2,"477":2,"540":2,"545":1,"546":1,"593":2,"599":2,"622":2,"710":1,"762":2,"772":4,"773":10}}],["xyz",{"2":{"64":3,"218":1,"251":1,"253":1,"254":1,"256":1,"257":1,"429":6,"487":3,"489":1,"490":2,"491":2,"495":1,"505":3,"507":2,"508":2,"510":2}}],["7a5fabb19713d732d967b1da84fa0df5e87a7b62302d783f78743e216c1a3550",{"2":{"754":2}}],["741743z",{"2":{"754":2}}],["746",{"2":{"383":2,"627":2}}],["79",{"2":{"681":1}}],["75",{"2":{"609":1,"610":1,"611":1,"682":1}}],["73\\tnode",{"2":{"559":2}}],["767",{"2":{"538":2}}],["76au8rj4vsyvasph5lgqq2kg",{"2":{"147":2}}],["786bytes",{"2":{"485":1}}],["786",{"2":{"485":1,"588":1}}],["782",{"2":{"383":2,"627":2}}],["71",{"2":{"478":4,"752":4}}],["770",{"2":{"383":2,"627":2}}],["7",{"0":{"90":1},"2":{"147":2,"295":2,"428":1,"538":2,"681":1,"754":4}}],["554+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"767":2}}],["5iieerohbmff+ser3jpvroieejzjby+tre0ntadqll3",{"2":{"754":4}}],["59",{"2":{"681":1}}],["564+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"767":2}}],["56",{"2":{"460":2,"535":1,"734":2}}],["5s",{"2":{"275":2,"429":4}}],["512gb",{"2":{"217":1}}],["5158076079",{"2":{"93":2}}],["53",{"2":{"214":2}}],["57",{"2":{"163":2}}],["58",{"2":{"93":2,"156":4,"163":2,"214":2}}],["5",{"0":{"88":1,"395":1},"2":{"142":2,"147":2,"163":2,"275":2,"281":1,"429":4,"527":1,"528":1,"530":1,"594":2,"677":1,"687":1,"765":2,"766":1,"774":1,"776":2,"786":1}}],["500000000",{"2":{"754":4}}],["5000100000000utia",{"2":{"272":2}}],["500utia",{"2":{"479":1}}],["500utiacelestia",{"2":{"479":1}}],["500ms",{"2":{"429":4}}],["500",{"2":{"429":2,"460":1,"535":1,"588":1,"734":1}}],["504g",{"2":{"214":1,"215":1}}],["50",{"2":{"20":1,"22":2,"27":1,"734":1}}],["✨",{"2":{"85":1,"93":2}}],["02",{"2":{"754":2,"784":2}}],["025",{"2":{"429":2}}],["06",{"2":{"754":4}}],["0blockhash",{"2":{"539":1}}],["09",{"2":{"532":1}}],["08",{"2":{"532":2,"757":1}}],["07",{"2":{"434":8}}],["0ns",{"2":{"434":4}}],["0mfhykqui2bu+u1jxpzg7qy2bvv1lb3kiu+zak7nuiy=",{"2":{"331":2,"332":4,"333":2,"745":2}}],["0+",{"2":{"328":1,"428":1,"740":1}}],["010",{"2":{"321":1}}],["01",{"2":{"272":2,"429":6,"489":1,"490":1,"491":1,"508":1,"509":1,"510":1,"622":2,"784":2}}],["011",{"2":{"169":1}}],["03",{"2":{"214":2}}],["05",{"2":{"214":2,"767":4}}],["008",{"2":{"757":1}}],["004celestia",{"2":{"748":1}}],["004",{"2":{"748":3}}],["002",{"2":{"748":1,"762":2}}],["001hermes",{"2":{"433":2,"434":1}}],["001",{"2":{"429":3,"430":2,"432":1,"433":4,"434":7,"435":3}}],["003442",{"2":{"337":4}}],["000",{"2":{"281":1,"591":2,"592":1,"681":3,"687":3,"695":2}}],["000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000121312324243243288993946154604701154f739f3d1b5475786ddd960f06d8708d4e870da6501c51750",{"2":{"152":2}}],["00000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000584cb53884b394593052df4039e58c7d51f0e45cace7dd584125f62f9261b7900ac1eeef5e82349",{"2":{"147":2}}],["00",{"2":{"214":2,"532":3,"681":1,"682":2}}],["048091bc7ddc283f77bfbf91d73c44da58c3df8a9cbc867405d8b7f3daada22f",{"2":{"754":2}}],["04",{"2":{"214":16,"240":1,"358":1,"383":2,"417":1,"462":1,"614":1,"627":2,"720":1}}],["0xbe",{"2":{"598":2,"710":2,"711":2,"712":2,"779":2,"780":2}}],["0xb6052122545aacd2bdda0ca9fa56416bd968cdbc",{"2":{"101":1}}],["0x",{"2":{"210":1,"745":2}}],["0x0",{"2":{"383":2,"541":1,"627":2}}],["0x0000000000000000",{"2":{"538":2}}],["0x0000000000000000000000000000000000000000",{"2":{"538":2}}],["0x0000000000000000000000000000000000000000000000000000000000000000",{"2":{"538":2}}],["0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",{"2":{"538":2}}],["0x0000000000000000000000000000000000000000000000000000000000000001",{"2":{"202":2}}],["0x0000000000000000000000000000000000000001",{"2":{"202":2}}],["0x007d0b2a2e2b013612e8",{"2":{"215":2}}],["0x0c",{"2":{"109":1}}],["0x04cae899fc0b7ef45c529f8bf075d54f6fb70ed9",{"2":{"101":1}}],["0x03b43f7b61fa100611191f481ef48aa1fc98f434",{"2":{"101":1}}],["0x01b5905b154f21a393f5b5a0c6d15b53a493c05e",{"2":{"100":1}}],["0x019850732270d8c436585c7921219252422228b5d0f559da0da219f0fa2b7216",{"2":{"93":2}}],["0x8e1ede4ce0865b41d714",{"2":{"215":2}}],["0x89b7c7970c13bb587893a70697ad6d2a335b6a15",{"2":{"101":1}}],["0x8f97cb7c643acd7f79f3b13841b24a243da51242",{"2":{"101":1}}],["0x8dee6e88d3b62b258c1574cbb7005e1c3cf193b60a99b5c2fcfae00819b7ed82",{"2":{"93":2}}],["0xde",{"2":{"598":2,"710":2,"711":2,"712":2,"779":2,"780":2}}],["0xdeadbeef",{"2":{"598":4,"710":4,"711":3,"712":5,"780":3}}],["0xd4b998a35d20d98ed3488221f0c161a0a9572d3de66399482553c8e3d2fae751",{"2":{"538":2}}],["0xd883010d04846765746888676f312e32312e33856c696e7578000000000000006b3afa42dce1f87f1f07a1ef569c4d43e41738ef93c865098bfa1458645f384e2e4498bcfe4ad9353ff1913a2e16162f496fafe5b0939a6c78fb5b503248d6da01",{"2":{"538":2}}],["0xd2d353916b34a877793628049c99858f04123ee1",{"2":{"100":1}}],["0xd0a6699fc7519966685181c80bf98d35afa1fc95",{"2":{"100":1}}],["0xef",{"2":{"598":2,"710":2,"711":2,"712":2,"779":2,"780":2}}],["0xe2662ff9b41f39e63a850e50e013ea66e60a4f37",{"2":{"100":1}}],["0xe24a60b758b51b0a3da5e8f4f6ddf1cd0aff646c",{"2":{"100":1}}],["0xe371afcb8437bf61bd831ef57be7a2496d88488b",{"2":{"100":1}}],["0x383ed2debf9f9055920cd7340418dda7e2bca6b989eb6992d83d123d4e322f2a",{"2":{"539":2}}],["0x3c44cdddb6a900fa2b585dd299e03d12fa4293bc",{"2":{"539":2}}],["0x3",{"2":{"383":6,"627":6}}],["0x3b6e845fb9f0c8ee4e9f6d44781f6547d9c6359a",{"2":{"101":1}}],["0x3bc040eaca40b91fa06cf55ea91842fac88b1af4",{"2":{"100":1}}],["0x3681cbb0e95ab50b63f2fc524fbbcc78adefbd33",{"2":{"100":1}}],["0xad",{"2":{"598":2,"710":2,"711":2,"712":2,"779":2,"780":2}}],["0xaddress",{"2":{"546":11}}],["0xadd3a5dc0b8c605aeac891098e87cbaff43bb642896ebbf74f964c0690e46df2",{"2":{"539":2}}],["0xaf5c1505c7dfcebca94d9a6a8c0caf99b6c87a8ed6d6c0b3161c9026f270a84f",{"2":{"539":2}}],["0xaf8ff6af1180c8be9e4e8f3a5f882b3b227233f4abbefa479836d3721682a389",{"2":{"538":2}}],["0xa83ca7775bc2889825bcdedffa5b758cf69e8794",{"2":{"231":2}}],["0xa2140c9bde000dc5e21e",{"2":{"215":2}}],["0xac3427e621c6f10dc2abdab00188d92690503914",{"2":{"100":1}}],["0xa773e19dc9e822933a7e72df9c87ed1578701d29",{"2":{"100":1}}],["0xaa",{"2":{"210":1}}],["0xaa3b8b63ccca3c98b948fd1d6ed875d378de2c6c",{"2":{"99":1}}],["0xaae3a04931345df5ac6e784bb6bdeb29b1ff0286",{"2":{"98":1}}],["0x28",{"2":{"383":2,"627":2}}],["0x2b30a00",{"2":{"383":2,"627":2}}],["0x20d8153aacc4e6d29558fa3916bff422bede9b5e",{"2":{"101":1}}],["0x2588867f19e2de51f90f0ab852c7ad11228e3d83",{"2":{"100":1}}],["0x22a6580faeca49cf86cbb2f18f2b7f98031fc6ad",{"2":{"98":1}}],["0x55527d53fda37dbf1924482b40acf8625e1caa5b",{"2":{"101":1}}],["0x5a48adf22f526ebd06e3e8856cfea2490923cc55",{"2":{"101":1}}],["0x51d196e07a27dba0f4461dd6cc26108424f196f7",{"2":{"101":1}}],["0x5187a92539bb4a2befe1fc078745c84ab6d37171",{"2":{"100":1}}],["0x53dea3a90fd6c82840a1f7224f799d622f142df4",{"2":{"100":1}}],["0x5810f0916bae1067ca1efcc00aaaf30301af001c",{"2":{"100":1}}],["0x59d2db6c5095b9e329c80211b7a761d20064379e3382d156b69e5cf3b5fe2fc7",{"2":{"93":2}}],["0x664bf4bb4a57dd5768a0a98991d77c58fb7a4e164c2581c79fb33ce9c3d4c250",{"2":{"538":2}}],["0x676d",{"2":{"332":2,"745":3}}],["0x61254e43e5c1e9e801f9c56b47a9ac3eadf6d1e9",{"2":{"101":1}}],["0x61e154128b6a1400ea8090b4431b4aa1dbb80cc4",{"2":{"100":1}}],["0x630093954cbf19fe4532a2edd0bd3b10deca7a4d",{"2":{"100":1}}],["0x6cb49605f10831749c6090ad09918bc61439bace",{"2":{"100":1}}],["0x6c7360a96165c570dcb7ce609d748d612c5fa5b76e229cd81ba5f5c93c00f805",{"2":{"93":2}}],["0x9f4dfae061b5ddd86f95a81be5daa0d7fe32e7f7f770f86dc375e0007d249bd2",{"2":{"539":2}}],["0x9039e58b2089e5f9abbb",{"2":{"215":2}}],["0x9c3f372a2aacc0d7272f56a4664311b7647b0031",{"2":{"214":32}}],["0x99e9d2f04352b42c18f1da5dd93a970f82c08afe",{"2":{"101":1}}],["0x9abc41fefae7e7543a01fa837aec909f96147280",{"2":{"101":1}}],["0x95cbda89325db5529eaf1813e181f66b83a7d65a",{"2":{"100":1}}],["0x95fea00e689e8d1cba909836e1ef1b941d5f21b1",{"2":{"100":1}}],["0x97b50f60b60d0e658fdbf185969db0a0327bd0ae9e57cd65af2a7f9be0eeb5b0",{"2":{"93":2}}],["0x4772756763686174",{"2":{"479":2}}],["0x40002a61b0",{"2":{"383":2,"627":2}}],["0x400065ea88",{"2":{"383":10,"627":10}}],["0x400143e048",{"2":{"383":2,"627":2}}],["0x400153b240",{"2":{"383":2,"627":2}}],["0x40f8c63e0a20b399bcd9631a22e57bb988a9400e",{"2":{"101":1}}],["0x42690c204d39600fddd3celestia",{"2":{"747":1,"755":1,"760":1}}],["0x42690c204d39600fddd3",{"2":{"331":2,"332":2,"333":2,"408":2,"520":2,"521":2,"740":4,"745":5,"747":7,"748":2,"755":1,"760":1}}],["0x4270889adcb82338c5ff5e64b45c0a3d31cfd08c",{"2":{"99":1}}],["0x44b412b291fef00398501b2ca353ea912ad0fe13",{"2":{"101":1}}],["0x4888fdf44251d456bbfca92bfc6e180cfe0b096ffbea2f6da2a203a16902214f",{"2":{"93":2}}],["0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",{"2":{"538":2}}],["0x1cb54d2369752ef73511c202ff9cdfd0eadf3a77b7aef0092bea63f2b5d57659",{"2":{"538":2}}],["0x1cc4551922c069a9ade06756bf14bf0410ea44ff",{"2":{"101":1}}],["0x1b91180",{"2":{"383":2,"627":2}}],["0x1bb8add5e878b12fa37756392642eb94c53a1cf4",{"2":{"99":1,"101":1}}],["0x1ae3a8dc1e7efd37f418b2987d3df74c5a917a8b",{"2":{"101":1}}],["0x10c65b27d5031ce2351c719072e58f3153228887f027f9f6d65300d2b5b30152",{"2":{"96":1}}],["0x715ab246772c923104c556dc28d5d4fcfca0398b0a252bcd19dd5705495756accelestia",{"2":{"565":1}}],["0x715ab246772c923104c556dc28d5d4fcfca0398b0a252bcd19dd5705495756ac",{"2":{"564":2,"565":3}}],["0x71756f746573",{"2":{"564":3,"565":4}}],["0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"538":2}}],["0x7973d0b475e898082df25c1617cbce1917cfed17",{"2":{"100":1}}],["0x79751b011bcc20f413a2c4e3af019b6e2a9738b9",{"2":{"98":1,"100":1}}],["0x7cf3876f681dbb6eda8f6ffc45d66b996df08fae",{"2":{"231":1}}],["0x78f8b2941dde5a8a312814ebd29c2e2a36f25e91",{"2":{"101":1}}],["0x7fc4d9a24949680fad666feee7cd6a100e39c4f0",{"2":{"100":1}}],["0x7fbeb5bc73a11b438891022786feb2c624f275f0",{"2":{"93":2}}],["0xff00000000000000000000000000000000000901",{"2":{"539":3}}],["0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1e",{"2":{"231":1}}],["0xf6759ff933786ddacb92",{"2":{"215":2}}],["0xfill",{"2":{"211":4}}],["0xf889a3174fddd9f78e6cd250ebf4c16f1bdd1b6a",{"2":{"101":1}}],["0xfb612fb83959b8acd3e49540b29c93c5a67e05f1",{"2":{"100":1}}],["0xf47dc66514fd78e4666e35abd12df7d1ae2c79f69f7dfedb8d98e4106142ab7c",{"2":{"93":2}}],["0xf2ddc2dad90e7e2b20a772bf89f989224165659d50824b98d7340e12265abf01",{"2":{"93":2}}],["0xf31fd34f8a9d9057198d8b13e755e583766bd528459733d948d9ffbc980c9506",{"2":{"93":2}}],["0xce",{"2":{"539":2}}],["0xce3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"539":2}}],["0xce1636cfaf2bd5497c11",{"2":{"215":2}}],["0xcryptovestor",{"2":{"489":1}}],["0xc7535f078cb3880a0fd5e54fa7a3b4eaf09b3924",{"2":{"101":1}}],["0xc99eea0b8e67d5b2226ab6d37882daaf6dd7593b",{"2":{"101":1}}],["0xcd9fca5015b5ce2b06a2266e4a5dd54d9ca39f1a",{"2":{"101":1}}],["0xc61382d5609ab0ece36b2776349c8bdceeafdd13dde9624cdf3d746fb4cf7d79",{"2":{"93":2}}],["0xc3e209eb245fd59c8586777b499d6a665df3abd2",{"2":{"91":2,"97":1,"231":2}}],["0",{"2":{"82":2,"84":2,"91":6,"93":6,"96":1,"117":1,"118":2,"128":2,"139":1,"140":6,"142":2,"147":16,"152":12,"153":3,"156":2,"160":2,"163":6,"174":1,"175":6,"206":1,"274":2,"275":4,"294":10,"295":2,"296":2,"297":4,"312":1,"313":4,"332":2,"333":15,"365":3,"368":4,"371":2,"373":2,"377":20,"383":14,"408":2,"409":2,"429":14,"434":14,"435":2,"478":16,"530":2,"539":7,"540":8,"561":2,"565":2,"590":4,"591":1,"594":2,"598":2,"599":8,"616":8,"622":10,"627":14,"673":2,"710":2,"726":1,"747":8,"748":5,"750":2,"751":2,"752":10,"753":2,"754":10,"757":3,"762":14,"767":1,"773":4,"774":2,"779":4,"784":6,"786":3}}],["qo",{"2":{"378":2}}],["qgb",{"2":{"163":2,"221":1}}],["qmaezrnbtgexcryc8pcvgrbs+umukniborae4qye7osgwcrwbvys",{"2":{"754":2}}],["qm",{"2":{"147":2}}],["q5",{"2":{"42":1}}],["q4",{"2":{"42":1}}],["q3",{"2":{"42":1}}],["q2",{"2":{"42":1}}],["q1",{"2":{"42":1}}],["q",{"2":{"38":1,"53":1,"54":1,"55":1,"58":1,"264":6,"265":4,"266":4,"267":2}}],["quic",{"2":{"752":6}}],["quickly",{"2":{"371":2,"560":1,"588":1,"690":1}}],["quicker",{"2":{"370":1}}],["quick",{"0":{"372":1,"390":1,"557":1},"1":{"558":1,"559":1,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1},"2":{"307":1,"369":1,"372":2,"392":1,"428":1,"443":1,"557":1,"560":2,"721":1,"727":1}}],["quickstart",{"0":{"81":1,"461":1,"575":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"576":1,"577":1,"578":1},"2":{"83":1,"103":1,"568":1}}],["qubelabs",{"2":{"372":12}}],["quorum",{"2":{"266":1,"527":1}}],["quote",{"2":{"564":2}}],["quotes",{"2":{"564":2}}],["quot",{"0":{"337":2},"2":{"41":2,"47":2,"65":2,"68":2,"87":2,"90":2,"91":72,"93":12,"104":4,"110":4,"118":12,"125":44,"130":8,"136":8,"142":64,"143":24,"144":80,"147":356,"148":4,"150":24,"152":120,"161":16,"162":12,"163":84,"202":8,"204":12,"206":4,"207":4,"214":4,"256":2,"266":156,"267":40,"272":4,"274":8,"275":36,"279":16,"287":2,"291":16,"292":32,"294":66,"295":20,"296":8,"297":16,"303":20,"308":2,"312":4,"314":16,"331":8,"332":36,"333":12,"336":2,"343":8,"361":58,"364":4,"366":6,"367":6,"368":10,"371":8,"372":36,"377":8,"378":12,"380":4,"383":8,"398":4,"399":68,"403":4,"408":36,"409":20,"412":4,"429":188,"431":4,"434":64,"447":4,"451":4,"452":4,"474":4,"477":4,"478":44,"479":4,"539":4,"540":60,"541":4,"546":44,"558":4,"559":16,"560":20,"561":28,"564":24,"565":40,"588":2,"593":4,"598":40,"599":64,"601":6,"604":2,"616":28,"622":36,"627":8,"651":2,"674":2,"695":2,"706":4,"707":24,"710":40,"711":4,"712":8,"745":36,"747":128,"748":16,"750":32,"751":32,"752":52,"753":20,"754":364,"755":4,"760":4,"762":76,"764":4,"767":2,"771":36,"772":12,"773":44,"774":24,"775":32,"779":32,"780":24,"781":12,"784":96,"785":2,"786":4}}],["queried",{"2":{"136":1,"143":1,"146":1,"153":1,"154":1,"160":2,"172":1,"210":2,"751":1}}],["queries",{"0":{"135":1,"137":1},"1":{"136":1,"137":1,"138":2,"139":2,"140":1,"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"154":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"164":1},"2":{"121":1,"136":1,"140":1,"142":1,"147":1,"152":2,"153":1,"163":1,"182":1,"244":2,"322":1,"380":2,"381":3,"422":2,"510":1,"640":1,"643":1,"652":3,"737":2}}],["queryable",{"2":{"160":2}}],["querysharerange",{"2":{"150":2}}],["query",{"0":{"142":1,"295":1,"296":1,"297":1,"366":1},"2":{"120":1,"121":1,"137":1,"139":1,"141":1,"144":2,"146":1,"151":2,"155":1,"156":4,"157":1,"159":4,"160":1,"161":2,"163":2,"172":1,"175":2,"183":1,"209":1,"260":6,"264":2,"266":1,"295":2,"296":2,"297":4,"309":2,"314":1,"366":1,"367":1,"380":1,"413":2,"422":1,"433":2,"465":1,"599":2,"643":1,"673":1,"750":1,"751":1,"758":1}}],["querying",{"0":{"121":1,"161":1,"209":1,"264":1,"719":1},"2":{"68":1,"126":2,"141":1,"149":1,"151":1,"160":1,"182":1,"208":1,"209":1,"210":2,"229":1,"252":1,"260":2,"295":1,"371":1,"495":1,"507":1,"508":1,"719":1}}],["question",{"2":{"42":3,"432":1,"616":1,"629":1}}],["questions",{"0":{"42":1},"2":{"16":1,"41":2}}],["quadratic",{"2":{"644":1}}],["quad",{"2":{"357":1,"535":1,"536":1}}],["quantum",{"2":{"221":1}}],["quarterly",{"2":{"36":1}}],["quarter",{"2":{"28":1}}],["quality",{"2":{"23":1,"40":1,"41":1,"58":1}}],["+stake",{"2":{"661":1}}],["+sgf6mfzmmtdkz5mllh+y7mpv9moo2x5rljle3gbfqo=",{"2":{"142":2}}],["+0x110",{"2":{"383":2,"627":2}}],["+0x1c8",{"2":{"383":2,"627":2}}],["+0x124",{"2":{"383":2,"627":2}}],["+0x2c4",{"2":{"383":2,"627":2}}],["+0x2d8",{"2":{"383":2,"627":2}}],["+0x26c",{"2":{"383":2,"627":2}}],["+0xd30",{"2":{"383":2,"627":2}}],["+0x44",{"2":{"383":2,"627":2}}],["+0x64",{"2":{"383":2,"627":2}}],["+2",{"0":{"383":1,"627":1},"2":{"383":2,"627":2}}],["+mhkrh9borgjn3oqt",{"2":{"147":2}}],["+1",{"2":{"128":2,"130":4}}],["+",{"2":{"26":2,"104":1,"128":2,"130":2,"174":1,"175":2,"329":1,"426":1,"485":1,"726":1,"784":10}}],["8545",{"2":{"538":1,"539":1}}],["8545cast",{"2":{"538":1,"539":1}}],["856",{"2":{"383":2,"627":2}}],["87",{"2":{"336":2}}],["80000",{"2":{"757":3}}],["80000celestia",{"2":{"757":1}}],["8000",{"2":{"275":1,"757":4}}],["8dxemrbwrpwj6hi+3uesz+0p5vrf3v8ssaqeabelorfgaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"152":2}}],["8woyobnjs3mt1dkfrqid8vc75oja2jnf3wn",{"2":{"147":2}}],["8449",{"2":{"93":3}}],["8",{"0":{"91":1},"2":{"22":2,"96":2,"117":1,"118":2,"152":2,"163":2,"287":4,"536":1,"588":2,"613":1,"677":1,"687":1,"707":2}}],["k×k",{"2":{"643":3,"645":1,"651":1}}],["kr",{"2":{"599":6}}],["kjnodes",{"2":{"489":1,"490":1,"491":1,"499":1,"685":1}}],["kbps",{"2":{"460":2,"535":1,"734":2}}],["kv",{"2":{"364":2,"366":3,"380":5}}],["k",{"2":{"147":2,"163":8,"557":1,"645":3}}],["kqkhkpjxmiby",{"2":{"147":2}}],["known",{"2":{"151":1,"221":1,"227":1}}],["knowing",{"2":{"42":1}}],["know",{"2":{"38":1,"39":1,"41":2,"109":1,"219":1,"367":1,"574":1,"580":1,"672":1}}],["knowledge",{"2":{"37":1,"40":1,"58":1,"118":2,"124":1,"221":1,"402":1}}],["knowledgeable",{"2":{"36":1,"37":1}}],["kept",{"2":{"630":1}}],["keplrbutton",{"2":{"784":2}}],["keplr",{"0":{"655":1,"656":1,"784":1},"1":{"656":1,"657":1,"658":1,"659":1},"2":{"278":1,"653":1,"656":2,"657":1,"658":1,"684":1,"685":1,"783":1,"784":18}}],["keeping",{"2":{"644":1}}],["keeps",{"2":{"110":1,"139":1}}],["keep",{"2":{"35":1,"36":1,"60":1,"127":1,"212":1,"276":1,"343":2,"361":1,"368":3,"451":2,"546":1,"622":1,"700":2}}],["keypair",{"2":{"559":2}}],["keymake",{"2":{"341":1}}],["keyregistry",{"2":{"322":1,"571":1}}],["keyring",{"2":{"245":2,"246":7,"261":4,"263":1,"279":6,"299":3,"303":4,"308":2,"329":3,"412":2,"422":2,"423":7,"446":2,"447":2,"449":2,"466":10,"468":7,"479":2,"518":2,"523":2,"559":6,"571":2,"599":10,"616":2,"622":2,"700":6,"701":7,"702":6,"706":2,"707":4,"724":1,"738":10}}],["keyfile",{"2":{"263":2}}],["keyforge",{"2":{"210":1}}],["keybase",{"2":{"263":1}}],["keyname",{"0":{"447":1},"2":{"246":6,"423":6,"466":6,"468":6,"518":2,"707":2,"738":6}}],["key`",{"2":{"202":4,"699":4}}],["key=sk",{"2":{"768":2}}],["key=",{"2":{"93":2,"202":2}}],["keys`",{"2":{"599":4}}],["keystore",{"2":{"521":1,"522":1}}],["keys",{"0":{"263":1,"292":1,"466":1,"700":1,"701":1,"702":1,"707":1,"738":1},"1":{"467":1},"2":{"26":1,"88":1,"202":2,"246":1,"247":1,"260":4,"261":1,"262":16,"263":6,"272":2,"279":10,"291":2,"292":2,"293":1,"299":8,"303":2,"308":4,"322":2,"329":3,"396":1,"405":1,"423":1,"424":1,"430":6,"431":1,"446":2,"448":1,"468":1,"469":1,"522":1,"542":1,"546":2,"559":2,"568":1,"571":2,"616":2,"627":1,"698":2,"700":2,"706":1,"707":8,"717":1,"736":1}}],["key",{"0":{"22":1,"108":1,"246":1,"262":1,"291":1,"392":1,"423":1,"446":1,"468":1,"518":1,"519":1,"520":1,"522":1,"523":1,"524":1,"568":2,"698":1,"703":1,"704":1,"718":1,"768":1},"1":{"109":1,"110":1,"111":1,"112":1,"263":1,"424":1,"469":1,"520":1,"521":1,"523":1,"524":1,"699":1,"700":1,"701":1,"702":1,"703":1,"705":1,"706":1,"707":1},"2":{"32":2,"37":1,"49":1,"86":3,"90":1,"93":2,"108":2,"128":2,"147":8,"156":4,"159":5,"175":3,"202":14,"203":8,"204":8,"210":10,"211":2,"218":2,"245":5,"246":9,"262":8,"263":13,"266":4,"279":2,"289":1,"290":1,"291":8,"292":6,"293":1,"295":2,"296":4,"297":4,"299":1,"322":1,"328":2,"329":3,"341":2,"380":1,"388":2,"392":1,"404":1,"422":5,"423":9,"429":12,"446":2,"447":1,"466":16,"468":9,"517":3,"518":2,"520":3,"522":2,"523":2,"524":2,"530":1,"544":1,"546":11,"559":8,"568":7,"571":1,"599":2,"642":1,"692":1,"697":2,"698":2,"699":5,"700":18,"701":13,"702":12,"703":2,"706":5,"707":11,"718":1,"738":15,"750":1,"754":4,"766":1,"767":8,"768":5,"774":5}}],["kib",{"2":{"588":1}}],["kit",{"2":{"51":2,"52":1,"57":1}}],["kickstarting",{"2":{"33":1}}],["kinds",{"2":{"182":1}}],["kindly",{"2":{"46":1}}],["kind",{"2":{"7":1}}],["kindness",{"2":{"7":1}}],["6363c68770c200fd794445668f9b18f5b1dd1125180d6e8d5ab004f7dd7a0f48",{"2":{"754":4}}],["62562",{"2":{"748":2}}],["66",{"2":{"682":3}}],["66\\taccessing",{"2":{"559":2}}],["67",{"2":{"681":1,"682":3}}],["65",{"2":{"478":4,"591":1,"592":1,"752":4}}],["64\\tsaved",{"2":{"559":2}}],["64x64",{"2":{"485":1,"588":1}}],["64",{"2":{"312":1,"342":1,"485":1,"586":1,"681":1}}],["64cpu",{"2":{"214":1,"215":1,"217":1}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2",{"2":{"294":1}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2gas",{"2":{"294":1}}],["60",{"2":{"211":1}}],["6962",{"2":{"119":1}}],["6",{"0":{"89":1},"2":{"20":1,"23":1,"26":1,"82":1,"84":1,"239":1,"383":2,"416":1,"527":1,"528":1,"530":1,"535":1,"627":2,"687":1,"784":6,"785":1,"786":1}}],["jwt",{"2":{"772":2,"773":2,"775":2}}],["jsimport",{"2":{"784":3}}],["jsx",{"2":{"784":1}}],["js",{"2":{"559":6,"784":2}}],["jsoncelestia",{"2":{"411":1}}],["jsonrpc",{"2":{"142":2,"147":2,"152":2,"540":4,"750":2,"751":2,"752":2,"753":2,"754":2,"762":4}}],["jsondocker",{"2":{"104":2}}],["json",{"0":{"450":1},"2":{"76":1,"86":2,"88":2,"89":2,"90":1,"91":1,"93":2,"94":1,"104":6,"125":2,"128":2,"142":1,"147":1,"152":1,"260":6,"266":9,"267":5,"272":1,"279":18,"361":3,"408":2,"409":1,"411":1,"448":3,"449":3,"450":6,"478":1,"540":2,"541":1,"600":1,"627":1,"719":1,"726":1,"745":2,"747":4,"748":1,"750":1,"751":1,"752":1,"753":1,"762":2}}],["jq",{"2":{"361":2,"398":10,"473":1,"477":2,"560":4,"604":4,"755":2,"757":3,"760":3}}],["jemalloc",{"2":{"341":2}}],["jemallocmake",{"2":{"341":1}}],["jail",{"2":{"281":1}}],["jailing",{"0":{"281":1},"2":{"281":1}}],["jailed",{"2":{"23":2,"24":1,"26":1,"281":2}}],["j",{"2":{"156":4,"159":4,"163":8}}],["j2pyclt4khpiqvh7b6wp9kcdmghlct9edfydr7zaq9o=",{"2":{"147":2}}],["jh0tyrmtrdtha",{"2":{"147":2}}],["journalctl",{"2":{"271":6,"604":2,"606":2,"607":2,"608":2}}],["journey",{"2":{"29":1,"44":1}}],["jotzla2v3g2q7y+18ih5j0uxk",{"2":{"152":2}}],["job",{"2":{"42":1,"275":8,"579":1,"639":1}}],["joining",{"0":{"42":1},"2":{"36":1,"41":1,"47":1,"58":1}}],["join",{"2":{"18":1,"44":1,"73":1}}],["june",{"2":{"27":1}}],["jurisdiction",{"2":{"23":1}}],["just",{"2":{"7":1,"60":1,"87":1,"93":2,"104":1,"117":1,"126":1,"275":1,"283":1,"422":1,"554":1,"558":1,"588":1,"652":1,"679":1,"684":1,"685":1,"698":1,"757":1}}],["4️⃣",{"0":{"659":1,"668":1}}],["4k",{"2":{"643":1,"644":1,"645":1,"651":1,"652":1}}],["42069",{"2":{"478":1,"479":2}}],["42069celestia",{"2":{"478":1,"479":2}}],["4hermes",{"2":{"433":1}}],["4hr",{"2":{"215":1}}],["482",{"2":{"485":1,"588":1}}],["48pm",{"2":{"383":2,"627":2}}],["48",{"2":{"383":2,"627":2}}],["478",{"2":{"485":1,"588":1}}],["47",{"2":{"214":2}}],["41",{"2":{"214":2,"681":1}}],["46",{"2":{"140":2}}],["49",{"2":{"767":4}}],["49s",{"2":{"93":2}}],["4989526079",{"2":{"93":2}}],["443export",{"2":{"301":1,"412":1}}],["443celestia",{"2":{"265":1}}],["443",{"2":{"65":1,"265":3,"301":1,"303":2,"403":1,"412":1,"413":2,"429":2,"489":1,"490":1,"491":7,"492":3,"507":1,"508":2,"510":5}}],["4094",{"2":{"588":1}}],["4094×482bytes",{"2":{"485":1}}],["4095",{"2":{"485":1,"588":1}}],["4096",{"2":{"485":1,"588":1}}],["400000",{"2":{"429":4}}],["401",{"2":{"331":4}}],["40",{"2":{"37":1,"754":2}}],["4",{"0":{"15":1,"87":1},"2":{"21":1,"22":3,"25":1,"26":1,"27":1,"65":2,"82":1,"84":1,"87":1,"91":2,"93":2,"97":1,"147":2,"163":2,"174":1,"216":1,"228":1,"412":2,"429":3,"430":2,"432":1,"433":5,"434":10,"435":3,"507":3,"508":1,"510":3,"511":8,"532":1,"539":2,"673":1,"682":1,"685":1,"707":4,"772":2,"773":2,"775":2}}],["3d96b7d238e7e0456f6af8e7cdf0a67bd6cf9c2089ecb559c659dcaa1f880353",{"2":{"754":2}}],["3dmfzfawzmtzvxhphf5txlcj+ct3evmmfopixfh+id4=",{"2":{"152":2}}],["3️⃣",{"0":{"658":1,"663":1,"667":1}}],["31\\tinitializing",{"2":{"559":2}}],["3152",{"2":{"434":2}}],["3108",{"2":{"429":2,"435":2}}],["33373",{"2":{"489":1,"492":1}}],["33554432",{"2":{"429":4}}],["33",{"2":{"314":2,"682":6}}],["3+fuhlzufkjnzd8yg",{"2":{"152":2}}],["3wl9cwxs8rqbddgupu9p8jcfj+jc77zsswdcf6pm=",{"2":{"147":2}}],["34",{"2":{"140":2,"383":14,"428":1,"627":14}}],["32cpu",{"2":{"211":1}}],["32",{"2":{"140":2,"144":6,"156":3,"159":4,"160":6,"163":14,"202":2,"204":4}}],["391",{"2":{"383":2,"627":2}}],["39",{"2":{"130":2,"144":2,"161":2,"163":2,"202":10,"260":2,"275":2,"291":4,"292":8,"294":8,"295":4,"296":8,"303":2,"361":48,"377":4,"391":2,"408":4,"435":24,"477":4,"479":4,"520":4,"521":4,"540":4,"559":4,"560":8,"564":4,"598":2,"599":8,"616":4,"622":4,"707":4,"710":2,"740":8,"745":8,"748":4,"754":2,"755":4,"760":4,"762":4,"773":2,"775":4,"779":2,"784":62}}],["30t08",{"2":{"754":2}}],["30th",{"2":{"682":1}}],["30s",{"2":{"429":4}}],["3001",{"2":{"429":2}}],["30000000",{"2":{"538":2}}],["30000",{"2":{"429":2}}],["3000",{"2":{"275":1,"429":2}}],["300xzo8tilwpnurey6ojcrkzthq4y6yy6qh0waummrc=",{"2":{"152":2}}],["30",{"2":{"93":2,"156":2,"163":2,"429":4,"673":4,"682":1}}],["362101",{"2":{"762":2}}],["3623",{"2":{"428":1}}],["3663",{"2":{"428":1}}],["36",{"2":{"22":1,"214":2}}],["35",{"2":{"22":1,"214":14,"383":14,"627":14}}],["3",{"0":{"14":1,"86":1,"372":1,"383":1,"627":1},"2":{"22":1,"27":1,"37":1,"65":2,"91":2,"93":4,"96":1,"104":2,"108":1,"139":1,"140":6,"163":2,"266":1,"274":2,"279":4,"312":1,"342":1,"383":2,"429":4,"627":2,"682":1,"707":2,"765":2,"766":1,"772":2,"773":2,"774":4,"775":6,"776":2}}],["2️⃣",{"0":{"657":1,"662":1,"666":1}}],["2k",{"2":{"645":1}}],["2k×2k",{"2":{"643":2,"651":1}}],["2s",{"2":{"580":1}}],["27t13",{"2":{"754":2}}],["27",{"2":{"530":1}}],["2727",{"2":{"434":6}}],["26",{"2":{"530":1,"681":1}}],["26660",{"2":{"274":4,"275":2}}],["26659version",{"2":{"707":1}}],["26659",{"2":{"326":1,"706":4,"707":3}}],["26658curl",{"2":{"540":1,"762":1}}],["26658",{"2":{"91":3,"326":1,"540":1,"709":2,"741":1,"762":1,"775":2,"778":2}}],["26657",{"2":{"65":1,"67":1,"91":2,"143":2,"144":2,"245":2,"313":2,"326":1,"377":4,"429":4,"477":6,"478":4,"494":1,"495":5,"506":1,"507":1,"508":3,"604":2,"762":1}}],["26656",{"2":{"65":1,"378":2,"452":1}}],["2382",{"2":{"434":4}}],["2371495",{"2":{"373":1,"532":1,"622":1}}],["2371495celestia",{"2":{"373":1,"622":1}}],["23",{"2":{"332":2}}],["25630",{"2":{"752":4}}],["256gb",{"2":{"211":1}}],["252614",{"2":{"745":3,"747":9,"760":2}}],["252607",{"2":{"745":2}}],["25231",{"2":{"333":5}}],["2585031",{"2":{"373":1,"532":1,"622":1}}],["2585031celestia",{"2":{"373":1,"622":1}}],["25",{"2":{"281":1,"383":2,"530":1,"627":2,"682":1,"786":1}}],["22t14",{"2":{"767":4}}],["2283",{"2":{"538":2}}],["22",{"2":{"163":2,"706":2,"707":2,"744":4}}],["28",{"2":{"156":5,"157":3,"163":8,"530":1,"532":1}}],["28217653",{"2":{"93":2}}],["28217647",{"2":{"93":2}}],["2zdir",{"2":{"147":2}}],["299137127z",{"2":{"754":2}}],["2990556",{"2":{"564":2,"565":2}}],["2990507",{"2":{"561":6}}],["2983850",{"2":{"560":1}}],["29",{"2":{"140":2,"156":7,"157":1,"163":2,"383":14,"565":2,"627":14}}],["2f",{"2":{"77":1}}],["2e",{"2":{"77":1}}],["2d",{"2":{"77":1}}],["2c",{"2":{"77":1,"80":1}}],["2b",{"2":{"77":1,"80":1}}],["2ae1ddf74ef7",{"2":{"140":2}}],["2a",{"2":{"77":1,"80":1}}],["24",{"2":{"24":1,"383":4,"530":1,"539":2,"627":4}}],["216\\tnew",{"2":{"559":2,"767":2}}],["211\\tno",{"2":{"559":2,"767":2}}],["21572",{"2":{"539":2}}],["21568",{"2":{"538":2}}],["214",{"2":{"383":2,"627":2}}],["2121",{"2":{"65":4,"313":2,"314":4,"326":2,"478":12,"607":2,"706":2,"707":2,"752":8}}],["21",{"2":{"22":1,"281":1,"530":1,"706":2,"707":2}}],["2019",{"2":{"480":1}}],["200",{"2":{"478":4,"752":4}}],["20000",{"2":{"429":2}}],["20000utia",{"2":{"412":2}}],["2000",{"2":{"407":1}}],["2000celestia",{"2":{"407":1}}],["2001",{"2":{"383":2,"627":2}}],["2048",{"2":{"215":4}}],["20ignition",{"2":{"214":16}}],["2023",{"2":{"754":4}}],["20210819022825",{"2":{"140":2}}],["2025",{"2":{"27":1}}],["2024",{"2":{"20":1,"27":2,"214":14,"383":1,"527":1,"532":3,"627":1,"682":2,"767":4}}],["20",{"2":{"22":1,"27":1,"37":1,"142":1,"143":2,"240":1,"358":1,"417":1,"462":1,"614":1,"681":1,"720":1}}],["2",{"0":{"13":1,"77":1,"80":1,"85":1,"145":1,"371":1,"395":1,"432":1,"521":1},"2":{"16":2,"22":2,"23":1,"26":1,"27":1,"35":1,"37":1,"42":1,"65":2,"79":1,"80":1,"82":1,"93":2,"96":4,"118":2,"139":1,"142":2,"145":1,"147":2,"152":2,"163":3,"175":1,"187":1,"206":1,"239":1,"272":2,"279":4,"281":1,"296":2,"357":1,"373":1,"383":2,"416":1,"508":1,"509":1,"510":1,"511":6,"535":2,"536":2,"538":2,"540":4,"588":1,"613":1,"617":1,"622":3,"627":2,"643":1,"645":3,"646":3,"648":1,"651":1,"680":1,"682":2,"692":1,"726":1,"750":2,"751":2,"752":2,"753":2,"754":4,"762":4,"772":2,"773":2,"775":2}}],["1️⃣",{"0":{"656":1,"661":1,"665":1}}],["1s",{"2":{"579":1,"580":1}}],["171",{"2":{"752":4}}],["172118057",{"2":{"750":2}}],["17",{"2":{"532":1,"681":1}}],["1751707",{"2":{"373":1,"532":1,"622":1}}],["1751707celestia",{"2":{"373":1,"622":1}}],["1×478bytes",{"2":{"485":1}}],["1utia",{"2":{"279":2,"599":2}}],["1usgft4=",{"2":{"147":2}}],["1hr",{"2":{"211":2}}],["19l",{"2":{"408":2}}],["19000000utia",{"2":{"265":2}}],["196\\tdetected",{"2":{"559":2}}],["196",{"2":{"214":32}}],["19",{"2":{"117":1,"118":2,"214":16,"532":1,"681":1,"754":2}}],["16002",{"2":{"510":1}}],["1606",{"2":{"383":2,"627":2}}],["16279",{"2":{"478":4}}],["1639397",{"2":{"408":2}}],["1637",{"2":{"383":2,"627":2}}],["1699638350",{"2":{"538":2}}],["169",{"2":{"383":2,"627":2}}],["1687908352",{"2":{"295":2}}],["1686748051",{"2":{"294":8,"295":2,"301":2}}],["16xlarge",{"2":{"217":1}}],["16",{"2":{"93":2,"163":2,"239":1,"357":1,"372":12,"416":1,"535":2,"536":2,"613":1}}],["147105",{"2":{"755":2}}],["1400000",{"2":{"337":1}}],["14",{"2":{"93":2,"140":2,"314":2,"328":1,"383":2,"532":3,"627":2,"740":1}}],["180000",{"2":{"429":4}}],["18",{"2":{"86":1,"140":2,"532":1}}],["1318129",{"2":{"331":2,"332":2,"333":2}}],["1317",{"2":{"65":1,"509":1}}],["1350632",{"2":{"147":2}}],["13",{"2":{"82":1,"93":2,"96":2,"342":1,"484":1,"673":2}}],["1g",{"2":{"79":1}}],["1f",{"2":{"79":1}}],["1e",{"2":{"79":1}}],["1d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af595",{"2":{"477":1,"478":1}}],["1d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af595export",{"2":{"477":1,"478":1}}],["1d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af5951d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af595",{"2":{"477":1}}],["1d",{"2":{"79":1}}],["1container",{"2":{"706":1,"707":1}}],["1c",{"2":{"76":1,"79":1}}],["1b",{"2":{"76":1,"79":1}}],["1a",{"2":{"76":1,"79":1}}],["118",{"2":{"784":2,"785":1,"786":1}}],["11celestia",{"2":{"767":1}}],["11155111",{"2":{"546":2}}],["1117733",{"2":{"546":2}}],["1141",{"2":{"538":2}}],["115",{"2":{"314":2}}],["11036",{"2":{"275":1}}],["11",{"2":{"65":11,"68":2,"71":1,"72":1,"214":2,"245":2,"383":4,"465":2,"466":2,"518":2,"532":1,"627":4,"737":2,"754":4,"767":3,"785":2}}],["1559",{"2":{"590":1}}],["151",{"2":{"314":2}}],["15s",{"2":{"275":2}}],["15",{"2":{"27":2,"93":2,"142":1,"143":2,"152":1,"153":2,"160":1,"214":16,"275":2,"681":1,"767":4}}],["15002",{"2":{"491":1}}],["1500",{"2":{"26":1}}],["1089",{"2":{"610":1}}],["1080694",{"2":{"147":2}}],["1040676758",{"2":{"539":2}}],["10790",{"2":{"510":2}}],["106",{"2":{"478":4,"752":4}}],["10s",{"2":{"429":4}}],["103",{"2":{"266":2}}],["105",{"2":{"266":3}}],["1024cd",{"2":{"215":1}}],["1024",{"2":{"215":14}}],["1095604",{"2":{"147":2}}],["10+",{"2":{"34":1}}],["10",{"0":{"93":1},"2":{"23":3,"70":1,"91":4,"142":3,"143":2,"152":1,"153":1,"163":2,"429":4,"478":6,"512":1,"527":1,"530":1,"532":1,"546":1,"591":1,"677":1,"687":1,"745":1,"752":4,"785":1}}],["1000",{"2":{"429":2}}],["10001",{"2":{"391":4}}],["1000utia",{"2":{"279":4}}],["100000",{"2":{"294":4,"295":2,"297":2,"301":2,"429":4,"757":4}}],["100000utia",{"2":{"279":2,"294":12,"301":4}}],["10000000utia",{"2":{"447":2,"479":2}}],["100000000000utia",{"2":{"267":2}}],["1000000000",{"2":{"266":2}}],["1000000000utia",{"2":{"266":2,"267":2}}],["1000000utia",{"2":{"412":2,"616":2}}],["1000000",{"2":{"271":2,"751":2}}],["100",{"2":{"20":1,"91":2,"162":2,"429":2,"460":1,"535":1,"676":2}}],["125",{"2":{"478":6}}],["127",{"2":{"377":2,"429":4,"478":2,"540":2,"762":3}}],["1234",{"2":{"202":3}}],["1234567890",{"2":{"599":2}}],["123456",{"2":{"338":1,"560":1}}],["12345=",{"2":{"202":6}}],["12345",{"2":{"202":9}}],["128gb",{"2":{"586":1}}],["128",{"2":{"147":2}}],["120000",{"2":{"147":2}}],["12d3koowffhcaaqy56oeqy3plzudlsv4ryafvwkatzrepupdoslp",{"2":{"752":2}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22",{"2":{"607":1}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22node",{"2":{"607":1}}],["12d3koowavsz36cdczaexnnndpspcvyanbebe5epg7ajttrgfux7",{"2":{"478":4}}],["12d3koowkeertzvmpudxyszo2edqps6ms67n6lt5mpdulskpsxbq",{"2":{"314":2}}],["12d3koowlt1yssrd7xwsbjh7tu1hqanf5m64dhv6aum6cyejxmpk",{"2":{"65":1}}],["12d3koowewuqrjulanpukdfgvohw3roeuu53ec9t9v5cww3mkvdq",{"2":{"65":1}}],["12d3koowcmgm5ezwvfcn9zlavigfluwafxp5pcm78nfkb9jpbtua",{"2":{"65":1}}],["12d3koowgqwzdeqm54dce6lxzffr97bnhvm6rn7km7mfwdomfm4s",{"2":{"65":1}}],["12",{"2":{"22":2,"681":1,"722":1}}],["1",{"0":{"12":1,"76":1,"79":1,"84":1,"141":1,"370":1,"520":1},"1":{"142":1,"143":1},"2":{"16":2,"21":1,"22":7,"23":1,"24":1,"25":1,"27":4,"35":1,"42":1,"65":2,"68":2,"82":1,"84":1,"85":1,"93":4,"96":6,"104":4,"128":4,"130":2,"139":1,"140":4,"142":2,"143":6,"144":2,"145":1,"147":2,"152":5,"153":2,"156":6,"157":2,"160":2,"163":14,"206":1,"216":1,"228":2,"239":2,"245":2,"266":1,"271":2,"272":2,"281":1,"333":5,"357":2,"369":1,"373":1,"377":2,"383":2,"416":2,"429":14,"465":2,"466":2,"478":6,"485":1,"508":1,"509":1,"510":1,"511":4,"535":2,"536":2,"540":6,"541":1,"561":2,"579":2,"580":1,"588":4,"594":1,"599":2,"613":2,"622":3,"627":2,"636":1,"645":1,"677":1,"681":1,"682":9,"687":3,"695":2,"706":1,"707":1,"737":2,"750":2,"751":2,"752":6,"753":2,"754":13,"757":1,"762":7,"767":2,"772":2,"773":2,"775":2,"779":2,"784":2,"786":1}}],["ua",{"2":{"507":2,"508":1,"509":1,"510":1,"514":1}}],["uatom",{"2":{"429":2}}],["ueibxdywh1mcbslm2aec3sdvauhq2zq0rugbjgtvxmqm7la",{"2":{"478":10}}],["udp",{"2":{"313":1,"326":1,"478":10,"752":6}}],["u",{"2":{"271":6,"604":2,"606":2,"607":2,"608":2}}],["uri",{"2":{"244":8,"245":2,"246":6,"265":4,"316":4,"317":2,"318":2,"319":2,"320":8,"324":2,"422":2,"423":6,"468":6,"607":2,"608":2,"619":2,"737":6,"738":6}}],["urlcelestia",{"2":{"407":1}}],["url=rpc",{"2":{"405":2}}],["url=this",{"2":{"390":2}}],["url=https",{"2":{"301":2,"412":2}}],["url=",{"2":{"93":4,"209":2}}],["url",{"0":{"90":1},"2":{"41":2,"64":1,"67":1,"68":3,"90":5,"91":4,"93":1,"203":4,"204":12,"210":5,"211":2,"218":2,"254":1,"275":2,"301":5,"303":1,"390":9,"393":6,"407":1,"408":2,"412":3,"429":4,"479":4,"487":1,"494":1,"495":3,"505":1,"506":1,"507":1,"538":2,"539":2,"542":1,"546":2,"598":4,"709":2,"710":4,"711":4,"712":4,"713":4,"740":1,"741":1,"778":2,"779":4,"780":4,"781":4,"785":3,"786":4}}],["urls",{"0":{"252":1},"1":{"253":1,"254":1},"2":{"41":2,"90":1,"202":2,"211":1,"252":2}}],["ubuntu",{"2":{"240":1,"358":1,"388":1,"398":1,"399":2,"417":1,"462":1,"614":1,"720":1}}],["ugp0sv9ynei5poiyr7rdodswwlfbh2o3xirsmmnmbks=",{"2":{"152":2}}],["uhlbgdgo=",{"2":{"147":2}}],["uhhb3u6dpayj1pjnefrwq5he=",{"2":{"142":2}}],["utc",{"2":{"532":3}}],["ut8sjtguh+akimnqtkuuu",{"2":{"147":2}}],["utility",{"0":{"698":1,"773":1},"1":{"699":1,"700":1,"701":1,"702":1,"703":1},"2":{"341":1,"466":1,"568":1,"697":1,"698":3,"700":1,"772":1,"773":2,"774":1}}],["utilizing",{"0":{"41":1}}],["utilize",{"2":{"37":1,"39":2,"40":1,"721":1}}],["utia=tia×10−6",{"2":{"687":1}}],["utiacelestia",{"2":{"413":1}}],["utia",{"0":{"695":1,"757":1},"2":{"91":1,"266":2,"294":4,"295":2,"297":4,"407":1,"408":2,"409":2,"413":1,"429":2,"695":3,"696":1,"748":1,"750":2,"751":2,"757":6,"784":6,"785":1,"786":1}}],["uint32",{"2":{"593":4,"599":4}}],["uint8",{"2":{"157":2,"206":2}}],["uint64",{"2":{"125":8,"126":4,"128":4,"130":4,"144":10,"160":4,"163":14,"219":3,"713":2,"773":2}}],["uint256",{"2":{"118":2,"154":2,"156":4,"159":4,"160":4,"175":3,"219":1}}],["ui",{"2":{"76":1,"79":1,"80":2,"86":1}}],["ultimate",{"2":{"43":1,"479":2,"564":2,"565":2}}],["updocker",{"2":{"707":1}}],["updating",{"2":{"171":1,"210":3,"216":1,"287":2}}],["updateheaders",{"2":{"128":2}}],["update",{"2":{"86":1,"140":1,"171":1,"202":2,"210":5,"216":1,"227":3,"228":1,"234":1,"266":2,"334":4,"398":4,"450":1,"580":1,"594":1,"627":1,"630":1,"649":1,"673":1,"775":1}}],["updated",{"2":{"60":1,"93":2,"128":1,"202":1,"216":2,"228":1,"552":1,"773":1}}],["updatesudo",{"2":{"398":1}}],["updates",{"2":{"60":1,"210":1,"234":1,"481":1,"549":1,"552":1}}],["upper",{"2":{"485":1}}],["upload",{"2":{"239":1,"247":1,"357":1,"416":1,"424":1,"430":1,"460":1,"469":1,"601":1,"613":1,"722":1,"734":1}}],["upgrading",{"0":{"345":1},"2":{"210":2}}],["upgraded",{"2":{"373":1,"383":1,"622":1,"627":1}}],["upgradeexecutor",{"2":{"93":2}}],["upgrade",{"0":{"282":1,"526":1,"527":1,"528":1,"529":1,"530":1,"532":1},"1":{"527":1,"528":1,"529":2,"530":3,"531":2,"532":2},"2":{"24":1,"73":2,"93":4,"96":1,"210":2,"282":1,"345":1,"373":10,"383":2,"398":3,"500":2,"515":2,"526":4,"527":3,"528":3,"530":8,"532":3,"556":2,"622":10,"627":3,"717":1}}],["upgrades",{"0":{"60":1,"73":1,"481":1,"500":1,"515":1,"531":1,"556":1},"1":{"532":1},"2":{"23":1,"59":1,"60":1,"73":2,"266":1,"282":1,"480":1,"481":1,"500":2,"515":2,"526":4,"527":2,"528":2,"532":1,"554":2,"556":2}}],["upon",{"2":{"50":1,"128":1,"134":1,"246":1,"423":1,"468":1,"682":1,"747":1,"762":1}}],["upcoming",{"0":{"529":1},"1":{"530":1},"2":{"47":1,"152":1,"153":1,"166":1,"168":1,"221":1,"526":1}}],["ups",{"2":{"33":1}}],["up",{"0":{"93":1,"237":1,"240":1,"285":1,"290":1,"302":1,"358":1,"359":1,"361":1,"414":1,"417":1,"443":1,"458":1,"462":1,"472":1,"477":1,"478":1,"544":1,"602":1,"612":1,"614":1,"735":1,"775":1},"1":{"238":1,"239":1,"240":1,"241":2,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"286":1,"287":1,"288":1,"289":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"359":1,"360":1,"361":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1,"613":1,"614":1,"615":2,"616":2,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"626":1,"627":1,"736":1,"737":1,"738":1},"2":{"20":1,"22":1,"25":1,"30":1,"31":1,"32":1,"41":3,"42":1,"48":1,"54":1,"55":1,"90":2,"92":1,"168":2,"199":1,"237":1,"247":1,"248":2,"273":1,"275":1,"276":1,"289":1,"298":2,"301":1,"302":1,"311":1,"320":1,"338":1,"341":1,"353":1,"356":1,"370":2,"397":1,"414":1,"418":1,"424":1,"431":1,"443":1,"444":1,"455":3,"458":1,"462":2,"469":1,"470":1,"472":1,"474":1,"533":1,"536":1,"542":2,"559":4,"561":2,"580":1,"603":1,"604":1,"609":1,"612":1,"614":1,"621":2,"622":1,"627":2,"638":1,"639":1,"697":1,"700":1,"706":2,"707":3,"736":1,"744":1,"766":1,"768":2,"770":1,"771":2,"776":1}}],["uptime",{"2":{"20":1,"22":1,"26":2,"258":1,"316":1,"495":1}}],["untested",{"2":{"720":1}}],["until",{"2":{"60":1,"109":1,"130":1,"428":1,"594":1,"599":2,"604":1,"638":1,"677":1,"687":1}}],["unused",{"2":{"590":1,"592":1,"771":1}}],["unexplored",{"2":{"481":1}}],["unexpectedly",{"2":{"60":1}}],["unordered",{"2":{"434":2}}],["unmarshaling",{"2":{"331":2}}],["unjail",{"2":{"270":3,"281":2}}],["unjailing",{"0":{"270":1}}],["unbonded",{"2":{"281":1}}],["unbond",{"2":{"269":3}}],["unbonding",{"2":{"208":1,"281":1}}],["unstake",{"2":{"659":1,"663":1,"668":1}}],["unstable",{"2":{"552":1}}],["unsafe",{"2":{"335":4,"375":2,"444":2}}],["unsignedtx",{"2":{"279":8}}],["unsubscribe",{"2":{"162":2}}],["unsolicited",{"2":{"13":1,"14":1}}],["unknown",{"2":{"160":1}}],["unaffected",{"2":{"583":1}}],["unavailability",{"2":{"400":1}}],["unavailable",{"0":{"174":1},"2":{"130":1,"179":1}}],["unauthorized",{"2":{"331":2}}],["unable",{"2":{"281":1,"594":1,"636":1}}],["unacceptable",{"2":{"7":1,"10":1}}],["unpacked",{"2":{"111":1}}],["unpeeled",{"2":{"110":2}}],["unprofessional",{"2":{"12":1}}],["unlocked",{"2":{"682":9}}],["unlock",{"2":{"682":4,"784":2}}],["unlocks",{"0":{"682":1},"2":{"682":5}}],["unlocking",{"2":{"49":1}}],["unlimited",{"2":{"274":2}}],["unlike",{"2":{"127":1,"169":1,"219":1,"530":1,"724":1}}],["unless",{"2":{"23":1,"199":1,"443":1,"544":1,"762":1}}],["unit",{"2":{"599":2,"604":2,"606":2,"607":2,"608":2}}],["unify",{"2":{"404":1}}],["unified",{"2":{"139":1}}],["unix",{"2":{"328":1}}],["universal",{"2":{"214":1}}],["university",{"2":{"34":1}}],["universities",{"2":{"34":2,"38":1}}],["unique",{"2":{"41":1,"86":2,"287":1,"582":1,"643":2,"645":1}}],["undelegate",{"0":{"269":1},"2":{"269":1}}],["undelegation",{"0":{"24":1}}],["underneath",{"0":{"94":1,"542":1},"1":{"543":1,"544":1,"545":1,"546":1,"547":1},"2":{"109":2,"110":1,"249":1,"455":1,"547":1,"573":1}}],["underlying",{"2":{"86":1,"93":1,"109":1,"112":1}}],["undergoes",{"2":{"60":1}}],["understand",{"2":{"41":1,"42":3,"58":1,"91":1,"121":1,"301":1,"457":1,"671":1}}],["understanding",{"0":{"349":1},"1":{"350":1,"351":1,"352":1,"353":1,"354":1,"355":1},"2":{"36":1,"58":1,"259":1,"389":2,"580":1,"677":1,"705":1}}],["under",{"2":{"23":1,"26":1,"76":2,"80":1,"90":1,"96":1,"120":1,"148":1,"194":1,"208":1,"210":1,"214":2,"215":1,"274":2,"337":1,"371":1,"527":1,"588":2,"590":1,"624":1,"698":1,"700":1,"776":1}}],["unwelcome",{"2":{"12":1}}],["usr",{"2":{"312":1,"342":1,"343":2,"383":4,"399":21,"627":4}}],["usual",{"2":{"175":1}}],["usually",{"2":{"86":1,"245":1,"353":1,"422":1,"465":1}}],["usable",{"0":{"154":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1},"2":{"121":1,"142":1,"147":1,"152":1}}],["usage",{"0":{"118":1,"194":1,"195":1,"196":1},"1":{"195":1,"196":1},"2":{"196":1,"260":2,"263":1,"264":1,"265":2,"276":1,"341":1,"772":2,"773":2,"775":2}}],["using",{"0":{"66":1,"146":1,"149":1,"333":1,"405":1,"408":1,"412":1,"698":1,"762":1},"1":{"67":1,"68":1,"147":1,"148":1,"150":1,"406":1,"407":1,"413":1,"699":1,"700":1,"701":1,"702":1,"703":1},"2":{"9":1,"30":1,"31":1,"42":1,"68":1,"69":1,"81":1,"84":1,"86":1,"90":1,"91":6,"93":1,"110":1,"112":1,"113":1,"117":3,"122":3,"126":1,"127":2,"130":1,"136":1,"137":1,"139":2,"141":1,"143":1,"145":1,"148":1,"149":2,"150":1,"153":1,"155":2,"160":2,"162":1,"163":3,"168":1,"169":1,"170":2,"172":3,"173":2,"175":6,"176":1,"178":1,"179":2,"184":1,"186":1,"188":1,"191":3,"194":1,"197":1,"199":4,"202":7,"204":1,"208":1,"209":1,"214":1,"215":1,"218":2,"221":2,"227":1,"233":1,"244":1,"246":1,"266":1,"267":1,"277":1,"278":1,"283":1,"293":1,"301":1,"306":1,"311":1,"314":1,"329":3,"333":1,"334":1,"339":2,"366":1,"368":1,"370":1,"388":3,"390":1,"392":2,"396":1,"399":1,"400":1,"406":1,"408":1,"422":1,"423":1,"427":1,"429":1,"455":2,"466":1,"467":1,"468":1,"509":2,"510":1,"512":1,"517":1,"528":2,"542":1,"546":1,"558":1,"559":3,"563":1,"568":2,"584":1,"585":1,"586":1,"593":2,"597":1,"599":4,"600":2,"616":1,"619":1,"645":1,"646":2,"648":3,"651":2,"670":1,"674":2,"690":1,"697":1,"699":1,"706":1,"707":3,"708":1,"711":3,"712":3,"713":1,"717":1,"732":1,"738":1,"739":1,"741":1,"742":1,"743":2,"744":2,"746":1,"760":1,"762":2,"765":3,"767":1,"773":8,"774":2,"775":2,"777":1,"780":1,"781":1,"784":2}}],["useful",{"2":{"42":1,"51":1,"60":1,"92":1,"361":1,"509":1,"560":1,"566":1,"567":1,"602":1,"604":1}}],["user=$user",{"2":{"604":2,"606":2,"607":2,"608":2}}],["user",{"0":{"599":1},"2":{"36":1,"41":2,"42":1,"122":2,"124":1,"275":1,"280":1,"329":8,"355":1,"391":1,"400":1,"438":2,"528":1,"579":1,"590":2,"592":3,"594":1,"599":8,"601":1,"604":2,"606":2,"607":2,"608":2,"611":1,"691":1,"694":1,"717":1,"723":1,"724":1,"741":2,"745":1,"784":4}}],["users",{"2":{"18":1,"67":1,"68":1,"86":1,"165":1,"183":1,"221":2,"388":1,"396":1,"400":1,"481":1,"494":1,"495":1,"506":1,"507":1,"508":1,"509":1,"510":1,"545":1,"549":1,"559":6,"583":1,"587":1,"590":3,"592":3,"593":1,"594":2,"595":1,"629":2,"636":2,"639":2,"640":1,"650":1,"651":1,"674":1,"683":1,"726":1,"728":1,"744":1}}],["uses",{"0":{"163":1},"2":{"34":1,"96":1,"107":1,"112":1,"126":4,"130":1,"163":4,"178":1,"182":1,"188":1,"197":1,"224":1,"225":1,"227":1,"233":1,"250":1,"274":1,"281":1,"331":1,"332":1,"371":1,"427":1,"438":1,"455":1,"590":1,"592":1,"593":1,"594":1,"598":2,"634":1,"643":1,"671":1,"677":1,"691":1,"698":1,"710":2,"727":1,"774":2}}],["use",{"0":{"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"187":1,"188":1,"189":1,"190":1,"192":1,"193":1,"199":1},"1":{"180":1,"181":1,"182":1,"184":1,"185":1,"188":1,"189":1,"191":1,"192":1,"193":1},"2":{"7":1,"12":1,"18":1,"39":1,"41":1,"42":2,"72":1,"84":1,"90":2,"91":3,"104":2,"109":1,"124":1,"125":2,"127":2,"128":1,"133":1,"137":1,"139":1,"144":2,"152":1,"153":1,"154":1,"156":2,"161":4,"162":3,"163":4,"165":1,"174":2,"175":2,"186":1,"190":1,"197":1,"199":1,"202":4,"204":3,"210":1,"211":1,"213":1,"215":1,"221":1,"227":3,"233":1,"244":1,"254":1,"266":2,"267":1,"275":2,"282":1,"284":1,"287":1,"288":1,"294":1,"299":1,"301":3,"302":1,"303":1,"311":1,"320":1,"326":1,"328":1,"339":1,"341":1,"348":1,"350":1,"371":3,"386":1,"388":1,"399":1,"402":1,"405":1,"408":1,"412":1,"422":1,"426":1,"428":1,"430":1,"432":1,"433":2,"434":1,"435":1,"445":2,"450":1,"474":2,"498":1,"514":1,"518":1,"521":1,"522":1,"530":2,"542":2,"557":1,"558":2,"559":2,"560":1,"561":2,"564":2,"565":2,"567":1,"583":1,"586":1,"589":1,"590":1,"591":1,"599":6,"601":2,"609":1,"648":1,"649":1,"674":1,"689":1,"699":1,"700":1,"702":1,"709":4,"710":2,"717":2,"719":1,"728":1,"730":1,"733":2,"737":2,"740":4,"741":1,"742":1,"743":2,"745":4,"747":5,"748":2,"757":1,"758":1,"759":2,"762":1,"771":3,"773":3,"778":4,"779":5,"783":1,"784":1}}],["used",{"2":{"3":1,"59":1,"64":1,"86":2,"90":1,"91":4,"93":1,"109":3,"110":1,"125":2,"127":1,"128":2,"130":1,"136":2,"147":2,"149":1,"151":1,"156":1,"157":1,"166":2,"174":1,"187":2,"199":2,"202":5,"213":2,"214":3,"215":3,"216":1,"221":1,"227":1,"234":1,"243":1,"245":1,"266":1,"273":1,"281":1,"294":2,"308":1,"311":1,"313":1,"322":4,"326":1,"349":1,"378":1,"381":1,"391":1,"397":1,"404":1,"406":1,"422":2,"427":1,"430":1,"487":1,"505":1,"510":1,"511":1,"527":2,"542":1,"559":1,"561":1,"565":1,"590":1,"591":2,"592":1,"593":2,"616":2,"622":2,"643":1,"648":1,"651":1,"698":1,"717":1,"720":1,"722":1,"725":1,"741":2,"748":1,"760":1,"773":1}}],["us",{"2":{"7":1,"23":1,"26":1,"42":6,"111":3,"485":2,"583":1,"760":1,"772":1,"774":1,"784":1}}],["vghpcybpcybhbiblegftcgxlig9mihnvbwugymxvyibkyxrh",{"2":{"762":2}}],["vcpu",{"2":{"586":1}}],["vms",{"2":{"584":1}}],["vm",{"2":{"583":1,"584":4}}],["v3",{"2":{"530":4}}],["v3+",{"2":{"527":1,"528":1}}],["vlog",{"2":{"337":4,"571":1}}],["vs",{"0":{"223":1,"649":1},"1":{"224":1,"225":1,"226":1},"2":{"496":1}}],["vk",{"2":{"214":2}}],["vkrarg7fgtz",{"2":{"142":2}}],["v",{"2":{"104":2,"343":2,"392":11,"393":10,"539":2,"558":2,"598":2,"710":2,"712":2,"716":1,"772":2,"773":8,"775":8}}],["v1beta1",{"2":{"266":4,"294":2,"295":2,"296":2,"412":2}}],["v1",{"2":{"96":2,"140":8,"147":4,"152":1,"153":1,"163":2,"312":1,"373":1,"383":14,"412":2,"428":1,"590":2,"594":1,"622":1,"627":14,"752":6}}],["v2",{"2":{"96":1,"104":2,"150":2,"152":1,"373":10,"383":1,"527":1,"528":1,"532":1,"622":10,"627":2}}],["vulnerability",{"2":{"86":1}}],["v0",{"2":{"82":1,"96":3,"140":4,"328":1,"342":1,"383":14,"428":1,"627":14,"673":2,"740":1,"779":3,"780":2}}],["volumes",{"2":{"707":2}}],["volume",{"2":{"391":2,"392":6,"393":2,"396":1}}],["volunteer",{"2":{"30":1}}],["volunteers",{"2":{"30":1,"32":1,"46":1}}],["void",{"2":{"291":2}}],["voice",{"2":{"34":1}}],["vote",{"2":{"266":5,"267":1,"653":1,"679":2,"680":1}}],["voting",{"2":{"266":1,"528":1,"530":1,"533":1,"692":1,"754":4}}],["vouch",{"2":{"224":1}}],["vec",{"2":{"779":2}}],["venv",{"2":{"545":7}}],["venue",{"0":{"34":1},"2":{"30":2,"31":1,"34":4,"38":2,"39":2}}],["vest",{"2":{"294":1}}],["vestingcelestia",{"2":{"299":1}}],["vesting",{"0":{"283":1,"290":1,"294":1,"295":1,"301":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":2,"292":2,"293":2,"294":2,"295":2,"296":2,"297":2,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1},"2":{"283":4,"289":1,"290":1,"291":5,"292":2,"293":1,"294":19,"295":8,"297":3,"298":2,"299":4,"301":10,"304":1,"305":2,"591":1,"717":1}}],["veto",{"2":{"266":2}}],["ver=",{"2":{"399":3}}],["very",{"2":{"124":1,"217":2,"371":1,"722":1}}],["verifiable",{"2":{"227":1}}],["verified",{"2":{"137":1,"163":2,"168":1,"180":1,"183":1,"186":1,"190":1,"194":1,"202":1,"206":1,"530":1,"629":1,"630":1,"631":1,"639":1}}],["verifiercd",{"2":{"203":1}}],["verifiers",{"0":{"203":1,"215":1},"2":{"202":2,"203":5,"204":4,"214":1}}],["verifier",{"0":{"204":1,"214":1},"1":{"205":1,"206":1,"207":1},"2":{"121":1,"122":1,"132":1,"163":2,"191":1,"194":1,"202":2,"203":7,"204":10,"205":4,"206":1,"210":6,"211":5,"213":1,"214":22,"215":13,"234":1,"586":4}}],["verifies",{"2":{"120":2,"122":3,"227":2,"234":1}}],["verification",{"0":{"225":1},"2":{"91":1,"109":1,"122":1,"139":1,"160":1,"187":2,"191":1,"194":1,"199":3,"202":1,"214":1,"371":1,"591":1}}],["verifydatarootinclusion",{"2":{"144":4}}],["verifymultirowrootstodataroottupleroot",{"2":{"122":1}}],["verifyrowroottodataroottupleroot",{"2":{"122":2}}],["verifysharestodataroottupleroot",{"2":{"122":2,"163":2}}],["verifying",{"0":{"122":1},"2":{"119":2,"126":2,"127":1,"139":1,"164":1,"168":2,"179":1,"631":1,"637":1,"645":1,"717":1,"718":1}}],["verifyzkp",{"2":{"118":4}}],["verifyattestation",{"2":{"112":1,"118":2,"120":1,"144":2}}],["verify",{"0":{"431":1,"631":1},"2":{"91":2,"117":1,"118":4,"122":4,"127":1,"136":1,"144":6,"154":2,"156":6,"159":4,"160":2,"163":10,"164":1,"172":1,"175":1,"178":1,"179":1,"180":1,"182":1,"183":1,"186":1,"187":2,"191":2,"194":3,"199":2,"202":1,"203":4,"204":2,"210":2,"213":1,"233":1,"291":2,"294":1,"341":1,"343":2,"371":1,"399":1,"409":1,"428":1,"432":1,"583":2,"629":5,"631":2,"632":1,"633":1,"634":1,"639":1,"642":1,"643":1,"645":1,"646":1,"649":1,"650":2}}],["versed",{"2":{"58":1}}],["versioned",{"2":{"485":1,"530":2}}],["versiongo",{"2":{"399":1}}],["versioncelestia",{"2":{"341":1,"558":1}}],["versioncd",{"2":{"288":1}}],["versions",{"0":{"550":1,"553":1,"555":1},"2":{"91":1,"96":1,"140":2,"473":1,"526":1}}],["version",{"0":{"62":1,"288":1,"383":1,"395":1,"483":1,"503":1,"627":1,"758":1},"2":{"16":2,"96":2,"117":1,"147":2,"150":6,"152":2,"156":11,"157":11,"163":6,"215":2,"250":1,"260":6,"284":1,"288":2,"298":1,"301":1,"311":1,"332":2,"341":6,"343":9,"345":1,"371":1,"373":1,"383":3,"399":4,"427":1,"428":1,"434":12,"527":2,"528":1,"530":2,"558":3,"561":2,"565":4,"586":1,"590":2,"622":1,"627":4,"648":1,"673":1,"674":1,"717":1,"745":1,"747":8,"754":2,"758":1,"762":2,"775":1}}],["ve",{"2":{"39":1,"58":1,"297":1,"305":1,"344":1,"558":1,"559":1,"563":1,"565":1,"574":1,"580":1,"765":1,"773":2}}],["vanilla",{"2":{"648":1}}],["vastly",{"2":{"583":1}}],["vault",{"2":{"202":6}}],["var",{"2":{"128":2,"287":4}}],["vary",{"2":{"35":1,"485":1,"591":1,"677":1}}],["variable",{"2":{"93":1,"155":1,"202":2,"211":3,"287":1,"477":1,"478":1,"538":1,"539":1,"561":1,"592":1,"616":1,"671":1,"743":1,"757":1,"768":1,"774":3}}],["variablescd",{"2":{"210":1}}],["variables",{"0":{"293":1},"2":{"91":1,"202":1,"210":3,"211":1,"218":1,"293":1,"299":1,"392":1,"405":1,"530":1,"592":1}}],["variety",{"2":{"35":1,"584":1}}],["varies",{"2":{"22":1}}],["various",{"2":{"30":1,"41":1,"58":1,"322":1,"574":1}}],["valconspub",{"2":{"784":2}}],["valcons",{"2":{"784":2}}],["val",{"2":{"616":2}}],["valoperpub",{"2":{"784":2}}],["valopers",{"2":{"498":1,"514":1}}],["valoper",{"2":{"268":2,"269":4,"784":2}}],["validiums",{"2":{"630":1}}],["validity",{"2":{"186":1,"221":1,"583":3}}],["valid",{"2":{"122":2,"144":2,"168":2,"178":1,"179":1,"183":1,"187":2,"191":2,"194":2,"202":1,"210":1,"431":2,"583":1,"643":1,"649":2,"652":1}}],["validating",{"2":{"94":1,"105":1,"136":1,"526":1}}],["validation",{"0":{"105":1},"2":{"86":2,"130":2}}],["validatehermes",{"2":{"431":1}}],["validates",{"2":{"260":2,"648":1}}],["validated",{"2":{"26":1}}],["validate",{"2":{"26":1,"183":1,"238":1,"260":2,"370":1,"431":1,"552":1,"644":1,"645":1}}],["validator1",{"2":{"445":1}}],["validatorwalletcreator",{"2":{"100":1,"101":1}}],["validatorutils",{"2":{"100":1,"101":1}}],["validators",{"0":{"448":1},"2":{"18":1,"20":1,"21":1,"23":1,"25":1,"26":1,"28":1,"60":1,"86":9,"87":1,"110":1,"124":1,"125":1,"208":1,"227":2,"266":3,"448":3,"449":1,"452":1,"501":1,"526":2,"527":2,"528":1,"530":2,"552":2,"554":1,"582":1,"589":1,"634":1,"671":1,"676":1,"722":1,"754":6}}],["validator",{"0":{"102":1,"268":1,"270":1,"302":1,"476":1,"612":1,"614":1,"616":1,"622":1,"623":1,"657":1,"662":1,"666":1},"1":{"103":1,"104":1,"105":1,"613":1,"614":1,"615":2,"616":2,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"626":1,"627":1},"2":{"18":2,"20":2,"22":2,"23":4,"26":7,"27":5,"59":3,"65":4,"68":2,"86":2,"88":1,"93":1,"105":1,"110":1,"128":1,"238":1,"245":5,"260":2,"268":5,"269":6,"270":3,"272":2,"279":6,"281":15,"289":2,"292":2,"293":1,"297":1,"301":1,"302":2,"308":4,"310":1,"313":1,"326":1,"387":1,"422":3,"446":1,"451":4,"452":2,"465":4,"466":2,"472":1,"477":1,"479":2,"488":1,"501":1,"533":1,"536":1,"554":1,"582":1,"603":1,"612":2,"613":1,"616":7,"617":2,"622":16,"627":2,"638":1,"657":1,"662":1,"666":1,"676":3,"683":1,"691":2,"737":2,"754":4,"767":2}}],["valuable",{"2":{"34":1,"37":2,"42":1,"58":1}}],["valuelog",{"2":{"337":2}}],["values",{"0":{"314":1},"2":{"23":1,"87":1,"142":1,"147":1,"152":1,"156":1,"218":1,"314":2,"334":3,"679":1,"700":1,"745":1}}],["value",{"2":{"4":1,"38":1,"91":2,"147":8,"156":6,"157":1,"187":1,"204":1,"210":3,"266":4,"320":1,"337":3,"368":2,"380":2,"381":1,"445":2,"446":1,"539":2,"571":1,"590":1,"591":1,"592":1,"745":2,"748":1,"752":1,"754":4,"780":2}}],["vinci",{"2":{"479":2,"564":3,"565":2}}],["visualize",{"2":{"275":1}}],["visualizer",{"2":{"275":1}}],["visualization",{"0":{"275":1}}],["vision",{"2":{"690":1}}],["visited",{"2":{"784":2}}],["visit",{"2":{"81":1,"85":1,"86":1,"90":1,"92":1,"255":1,"256":1,"257":1,"258":1,"388":1,"768":1}}],["visibility",{"2":{"39":1}}],["visible",{"2":{"6":1}}],["virtual",{"2":{"251":1}}],["virtually",{"2":{"58":1}}],["vim",{"2":{"210":2,"211":2}}],["viewed",{"2":{"321":1}}],["viewing",{"0":{"348":1},"2":{"266":1}}],["view",{"0":{"703":1},"2":{"77":1,"79":1,"92":1,"250":1,"260":1,"267":1,"301":1,"312":1,"343":1,"348":1,"601":2,"723":1,"759":2,"785":1,"786":1}}],["viewpoints",{"2":{"7":1}}],["vibrant",{"2":{"49":1}}],["video",{"0":{"394":1},"1":{"395":1},"2":{"34":1,"40":1,"54":1,"55":1,"542":1}}],["videos",{"2":{"31":1,"40":1}}],["violate",{"2":{"22":1}}],["violating",{"2":{"13":1,"14":1,"23":1,"24":1}}],["violation",{"2":{"11":1,"12":1,"13":1,"14":1,"15":1}}],["via",{"0":{"132":1,"133":1,"599":1},"2":{"9":1,"39":2,"125":1,"127":1,"130":1,"137":1,"139":1,"145":1,"156":1,"157":1,"160":1,"174":1,"175":1,"191":1,"203":1,"208":1,"209":1,"219":1,"266":1,"309":1,"324":1,"383":1,"430":1,"436":1,"437":1,"554":1,"599":2,"627":1,"651":1,"653":1,"699":4,"700":1}}],["vitepress",{"2":{"1":1}}],["huzwottdmd36n1f75a9bshxnlrascnnpqiwqihdvhcu",{"2":{"754":4}}],["hub",{"2":{"251":1,"256":1,"427":1,"429":1,"430":1}}],["h",{"2":{"540":4,"762":4}}],["hzfy",{"2":{"147":2}}],["historic",{"2":{"673":1,"674":2}}],["historical",{"0":{"367":1,"639":1,"640":1},"2":{"367":1,"371":2,"636":2,"639":2,"640":2,"641":1,"672":1,"674":10}}],["history",{"2":{"68":1,"338":1,"356":1,"495":1,"496":1,"533":1,"636":1,"640":1}}],["hidden",{"2":{"126":1,"765":1}}],["hiring",{"2":{"38":1}}],["highly",{"2":{"245":1,"385":1,"422":1}}],["highlighted",{"2":{"137":1}}],["highlight",{"2":{"38":1}}],["highlights",{"2":{"32":1}}],["higher",{"2":{"86":1,"583":1,"588":1,"589":1,"594":1,"671":1,"677":1,"748":1}}],["high",{"2":{"22":1,"40":1,"58":1,"86":1,"110":1,"111":2,"122":1,"124":1,"221":1,"226":1,"227":1,"337":1,"510":1,"546":1,"609":1,"643":1,"784":2}}],["hollow",{"2":{"291":2}}],["holders",{"2":{"267":1,"679":1}}],["holds",{"2":{"88":1}}],["hold",{"2":{"36":1}}],["homebrew",{"2":{"398":4}}],["homecd",{"2":{"291":1}}],["home=",{"2":{"287":2}}],["home",{"0":{"287":1},"2":{"287":4,"291":3,"292":4,"294":12,"295":4,"296":4,"297":8,"313":1,"326":1,"329":8,"375":2,"383":2,"392":8,"393":8,"444":2,"627":3,"700":1,"741":1}}],["hood",{"2":{"96":1,"590":1,"698":1}}],["hosted",{"2":{"218":1,"249":1,"250":1,"320":1}}],["hosts",{"2":{"91":2}}],["host",{"2":{"91":8,"104":2,"303":2,"333":2,"391":3,"429":4,"433":6,"579":1,"580":1}}],["hosting",{"2":{"26":1,"37":1,"40":1,"42":2,"81":1}}],["honesty",{"2":{"636":1}}],["honest",{"2":{"86":1,"633":2,"643":1,"645":1,"652":2}}],["hour",{"2":{"42":1,"216":1,"228":2,"369":1}}],["hours",{"2":{"24":1,"79":1,"80":1,"171":1,"216":1,"228":1,"369":1}}],["hope",{"2":{"42":2}}],["however",{"2":{"38":1,"41":1,"126":1,"130":1,"175":1,"186":1,"197":1,"199":1,"266":1,"320":1,"355":1,"381":1,"560":1,"590":1,"591":1,"634":1,"644":1,"646":1,"648":1,"741":1}}],["how",{"0":{"229":1,"234":1,"271":1,"283":1,"631":1,"653":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1,"662":1,"663":1,"664":1,"665":1,"666":1,"667":1,"668":1},"2":{"3":1,"21":1,"35":1,"36":1,"38":2,"41":1,"42":1,"54":1,"63":2,"74":1,"86":1,"91":1,"94":1,"111":1,"113":1,"121":1,"122":1,"124":1,"126":1,"127":1,"134":2,"137":1,"139":2,"172":1,"182":1,"216":1,"228":1,"235":1,"273":2,"280":1,"282":1,"283":1,"297":1,"298":2,"302":1,"305":2,"306":1,"320":1,"338":1,"356":1,"380":1,"381":1,"427":2,"486":2,"501":3,"517":2,"533":1,"542":1,"545":1,"546":1,"557":1,"565":1,"584":1,"591":2,"592":1,"593":2,"599":2,"632":1,"653":1,"670":1,"671":1,"673":1,"676":2,"677":1,"679":1,"680":1,"689":1,"691":1,"705":1,"706":1,"719":1,"730":1,"739":1,"740":2,"742":1,"765":1,"783":2,"784":2}}],["http2",{"2":{"509":1}}],["http",{"0":{"142":1,"147":1,"152":1},"2":{"90":1,"91":4,"92":1,"93":3,"136":6,"142":1,"143":4,"144":4,"150":2,"155":1,"156":1,"163":2,"253":1,"313":1,"326":2,"331":2,"333":2,"390":1,"479":4,"540":2,"709":2,"728":1,"741":1,"778":2}}],["https",{"0":{"253":1},"2":{"16":3,"64":4,"65":2,"71":1,"72":3,"89":2,"93":2,"156":2,"157":2,"160":2,"202":2,"203":2,"208":2,"211":2,"214":18,"215":2,"218":1,"251":1,"253":1,"256":1,"257":1,"265":4,"280":4,"303":2,"311":2,"312":2,"341":2,"343":4,"361":10,"371":4,"372":12,"390":1,"398":2,"399":8,"403":1,"413":2,"429":8,"430":2,"456":1,"474":2,"487":4,"498":9,"499":5,"505":4,"509":12,"513":1,"514":9,"546":2,"558":2,"560":4,"586":2,"684":3,"685":3,"699":2,"773":2,"785":3,"786":4}}],["html",{"2":{"16":1,"156":2,"157":2}}],["hamburger",{"2":{"786":1}}],["halting",{"2":{"630":1}}],["halo",{"2":{"238":1}}],["had",{"2":{"163":2,"740":1}}],["handpicking",{"2":{"275":1}}],["hand",{"2":{"226":1}}],["hands",{"0":{"140":1},"1":{"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1}}],["handled",{"2":{"590":1}}],["handlemsg",{"2":{"383":2,"627":2}}],["handlecompleteproposal",{"2":{"383":2,"627":2}}],["handle",{"2":{"322":1,"525":1,"599":4,"650":1}}],["handles",{"2":{"93":1,"219":1,"455":1,"741":1}}],["handling",{"2":{"112":1,"455":1}}],["happen",{"2":{"652":1}}],["happens",{"2":{"109":1}}],["happened",{"2":{"87":1}}],["happy",{"2":{"41":1,"57":1}}],["having",{"2":{"34":2,"35":1,"86":1,"170":1,"171":1,"183":1,"193":1,"211":1,"218":1,"388":1,"632":2}}],["haven",{"2":{"344":1,"784":2}}],["have",{"2":{"4":1,"8":1,"23":3,"26":1,"34":4,"35":1,"36":1,"37":1,"39":1,"40":2,"41":1,"57":1,"80":1,"81":1,"87":1,"91":1,"92":1,"93":2,"110":2,"116":1,"124":1,"126":1,"140":1,"154":4,"169":1,"183":2,"193":1,"202":4,"208":1,"209":1,"210":1,"211":1,"214":2,"215":1,"216":1,"227":1,"235":1,"238":1,"248":1,"259":1,"281":3,"289":1,"290":1,"298":1,"309":2,"312":1,"314":1,"315":1,"326":1,"342":1,"347":1,"384":1,"390":1,"393":1,"399":1,"407":1,"408":1,"409":1,"413":2,"429":2,"430":1,"432":1,"434":1,"435":1,"444":1,"449":1,"450":1,"453":1,"459":1,"467":1,"474":1,"485":1,"495":1,"501":1,"525":1,"527":1,"530":1,"542":1,"544":2,"546":1,"547":1,"559":1,"563":1,"564":1,"568":1,"584":1,"594":1,"604":1,"621":1,"622":1,"630":1,"631":2,"634":1,"640":1,"646":1,"652":2,"668":1,"674":1,"681":1,"700":1,"708":1,"722":2,"728":1,"733":2,"735":1,"739":1,"741":1,"764":1,"767":1,"768":1,"775":1,"777":1,"779":1}}],["hash=$",{"2":{"560":2}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"538":1}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7export",{"2":{"538":1}}],["hash=0xef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"147":1}}],["hash=580b3dff8a7c716968161d91116a1e171f486298d582874e93714e489c9e6e88",{"2":{"314":2}}],["hash=",{"2":{"314":2}}],["hashing",{"2":{"110":1}}],["hashes",{"2":{"110":2,"118":4,"227":1}}],["hash",{"0":{"146":1,"149":1,"199":1,"209":1,"338":1,"366":1,"560":1},"1":{"147":1,"148":1,"150":1,"339":1},"2":{"93":6,"110":2,"118":10,"125":2,"128":2,"142":2,"144":2,"146":1,"147":5,"148":2,"149":1,"150":4,"152":2,"160":1,"172":1,"199":8,"209":3,"210":5,"314":6,"338":10,"339":1,"341":1,"355":2,"366":1,"371":3,"380":2,"477":4,"538":4,"539":4,"560":13,"561":9,"601":2,"616":3,"622":2,"646":1,"733":1,"754":24,"757":1}}],["hashtags",{"2":{"39":1}}],["has",{"2":{"27":1,"41":1,"44":1,"60":1,"70":1,"86":1,"91":1,"93":3,"96":1,"109":2,"110":1,"112":2,"118":3,"168":1,"169":1,"170":1,"197":1,"199":1,"219":1,"238":1,"275":1,"277":1,"295":1,"328":2,"372":1,"373":1,"383":1,"388":1,"400":1,"422":1,"434":1,"464":1,"484":1,"485":1,"512":1,"527":1,"528":1,"551":1,"564":1,"588":1,"591":2,"604":1,"608":1,"622":1,"627":1,"629":1,"639":1,"644":1,"646":1,"673":1,"674":1,"710":1,"728":1,"740":1,"764":1,"767":2}}],["hard",{"2":{"485":2}}],["hardhat",{"2":{"93":1}}],["hardware",{"0":{"239":1,"357":1,"416":1,"440":1,"460":1,"613":1,"734":1},"2":{"26":1,"54":1,"55":1,"239":1,"357":1,"416":1,"440":1,"460":1,"613":1,"734":1}}],["harassing",{"2":{"10":1}}],["harassment",{"2":{"6":1,"7":1,"15":1}}],["harmfully",{"2":{"281":1}}],["harmful",{"2":{"8":1,"24":1}}],["helloworldblob",{"2":{"598":4,"710":4}}],["hello",{"2":{"598":4,"710":4,"745":1,"779":4}}],["helpcelestia",{"2":{"264":1,"265":1,"301":1,"311":1,"343":1,"348":1,"437":1,"759":2}}],["helpful",{"0":{"260":1},"1":{"261":1,"262":1,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1},"2":{"311":1,"312":1}}],["helper",{"2":{"132":1,"156":1,"159":1,"160":1}}],["helping",{"2":{"41":1,"260":2,"400":1,"439":1}}],["helps",{"2":{"2":1,"37":1,"40":1,"42":4,"86":1}}],["help",{"0":{"348":1,"759":1},"2":{"0":1,"29":2,"30":1,"33":1,"34":1,"35":1,"36":3,"37":2,"38":1,"39":2,"40":2,"41":3,"42":2,"51":2,"122":1,"260":6,"264":1,"265":1,"301":2,"311":2,"321":1,"343":1,"348":1,"352":1,"437":2,"501":1,"558":1,"567":1,"583":1,"691":1,"703":2,"759":4,"772":1,"774":1}}],["hermes",{"0":{"428":1,"435":1},"1":{"429":1,"430":1,"431":1},"2":{"427":2,"428":9,"429":4,"430":4,"431":2,"432":1,"436":1}}],["here",{"2":{"0":1,"21":1,"46":1,"54":1,"55":1,"110":1,"111":1,"125":1,"126":1,"128":1,"130":1,"218":1,"244":1,"245":1,"266":1,"275":2,"301":1,"317":1,"318":1,"319":1,"320":1,"321":1,"371":1,"446":2,"447":1,"449":1,"486":1,"546":1,"576":1,"599":4,"603":1,"622":1,"742":1,"745":2,"747":3,"751":1,"754":2,"757":1,"771":1,"773":2}}],["hence",{"2":{"414":1,"591":1}}],["height=$",{"2":{"560":2}}],["height=1",{"2":{"477":2}}],["height=15",{"2":{"142":1,"152":1,"160":1}}],["height=",{"2":{"209":1}}],["heightsub",{"0":{"336":1},"2":{"336":4}}],["heights",{"2":{"208":1,"217":1,"322":1}}],["height",{"0":{"754":1},"2":{"109":2,"119":1,"125":8,"126":4,"128":2,"130":6,"139":3,"141":2,"142":1,"144":16,"147":2,"150":2,"151":1,"160":17,"161":8,"163":8,"168":1,"172":2,"183":2,"187":1,"208":1,"209":4,"210":2,"212":1,"233":1,"260":4,"294":4,"338":3,"339":2,"367":1,"370":1,"371":3,"373":9,"380":2,"383":1,"408":3,"527":1,"528":1,"530":1,"532":1,"560":11,"561":3,"564":3,"565":3,"598":6,"616":2,"622":11,"627":2,"646":1,"677":1,"710":8,"711":4,"712":11,"713":7,"733":1,"745":5,"747":6,"748":3,"754":10,"755":2,"760":3,"762":1,"773":17,"775":4,"779":10,"780":13,"781":1}}],["hexadecimal",{"2":{"745":1,"773":1}}],["hexbytes",{"2":{"158":2,"163":2}}],["hextoaddress",{"2":{"144":2,"161":2,"162":2,"163":2}}],["hex",{"2":{"91":1,"148":2,"150":4,"155":1,"156":1,"157":1,"202":2,"210":1,"564":1,"596":4,"597":4,"601":1,"745":8,"747":2,"771":2,"773":11,"775":2}}],["health",{"2":{"273":1,"431":4,"495":1}}],["healthy",{"2":{"6":1,"431":1}}],["heavy",{"0":{"194":1,"195":1,"196":1},"1":{"195":1,"196":1},"2":{"196":1}}],["headerclient",{"2":{"779":2}}],["headerchan",{"2":{"712":2}}],["headerrangefunctionid",{"2":{"218":1}}],["header",{"0":{"383":1,"627":1,"754":1},"2":{"91":1,"109":2,"110":1,"118":2,"119":1,"120":1,"125":11,"126":9,"127":1,"128":18,"130":19,"150":2,"160":2,"174":1,"204":2,"208":5,"210":8,"211":10,"215":16,"217":1,"218":2,"227":2,"336":2,"371":1,"383":2,"560":9,"627":2,"643":1,"646":1,"651":1,"652":4,"670":1,"712":16,"713":7,"754":8,"755":2,"760":4,"774":2,"780":22,"781":13}}],["headers",{"0":{"134":1,"336":1,"712":1,"780":1},"2":{"91":1,"97":1,"109":1,"124":1,"128":1,"130":5,"134":1,"139":1,"221":1,"238":2,"322":1,"336":3,"338":2,"415":2,"459":3,"478":2,"561":3,"607":1,"608":1,"643":1,"644":1,"645":1,"652":5,"712":6,"780":6}}],["head",{"2":{"80":1,"122":1,"126":1,"277":1,"300":1,"370":1,"398":2,"561":6,"563":1,"573":1,"580":1,"738":1,"781":2}}],["heard",{"2":{"580":1}}],["hear",{"2":{"42":2}}],["hesitate",{"2":{"34":1,"39":1}}],["hetzner",{"2":{"23":1}}],["eprintln",{"2":{"780":4}}],["ephemeral",{"2":{"583":1}}],["eq",{"2":{"779":6}}],["equally",{"2":{"650":1}}],["equal",{"2":{"598":4,"710":4}}],["equipments",{"2":{"34":1}}],["equipment",{"2":{"30":2,"31":1,"34":2,"40":1}}],["e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",{"2":{"754":8}}],["egrep",{"2":{"372":6}}],["egg",{"2":{"291":2}}],["egeiggrjtkryaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"147":2}}],["eye",{"2":{"276":1}}],["eclipse",{"2":{"633":1}}],["ecfg",{"2":{"599":4}}],["echo",{"2":{"361":10,"399":1,"452":2,"539":2,"560":4}}],["ec2",{"2":{"217":1}}],["ecosystem",{"2":{"7":1,"20":1,"26":3,"37":3,"42":1,"44":1,"47":1,"54":1,"55":1,"58":3,"221":1,"275":1,"480":1,"680":1,"681":2,"682":2}}],["economic",{"2":{"6":1,"23":1}}],["eofsudo",{"2":{"604":1,"606":1,"607":1,"608":1}}],["eof",{"2":{"331":2,"604":3,"606":3,"607":3,"608":3}}],["eoa",{"2":{"202":2}}],["eoujy0=",{"2":{"147":2}}],["ef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"147":3}}],["efficient",{"2":{"322":1,"583":1,"593":1,"650":1}}],["efficiently",{"2":{"167":1,"629":1}}],["efficiency",{"2":{"221":1}}],["effect",{"2":{"644":1}}],["effects",{"2":{"163":2}}],["effectively",{"2":{"39":1,"51":1,"372":1}}],["effective",{"2":{"38":1,"42":1,"485":1}}],["efforts",{"2":{"41":1}}],["eight",{"2":{"646":1}}],["eip",{"2":{"590":1}}],["eip4844",{"2":{"109":1}}],["eiokkc9jzwxlc3rpys5ibg9ilnyxlk1zz1bheuzvckjsb2jzumvzcg9uc2u=",{"2":{"147":2}}],["either",{"2":{"58":1,"104":1,"169":1,"186":1,"203":2,"204":1,"211":2,"215":1,"275":3,"309":1,"312":1,"390":1,"558":1,"560":1,"590":1,"652":1,"682":1,"699":1,"738":1,"741":1,"762":1}}],["era",{"2":{"690":1}}],["erasure",{"2":{"137":1,"238":2,"633":1,"634":3,"648":1,"651":1,"670":1,"720":1}}],["err=",{"2":{"383":2,"627":2}}],["err",{"2":{"128":18,"130":12,"136":10,"143":16,"144":78,"148":8,"150":24,"153":4,"161":34,"162":26,"163":30,"383":2,"598":30,"599":50,"627":2,"710":30,"711":18,"712":24,"713":12,"772":6,"773":42,"774":6,"775":30,"780":4}}],["errorcodes",{"2":{"163":2}}],["errorf",{"2":{"130":4,"144":2,"161":2,"773":6,"774":4}}],["error",{"0":{"337":1},"2":{"95":1,"126":10,"128":4,"130":4,"144":6,"150":2,"161":2,"163":4,"328":1,"331":2,"333":2,"334":3,"337":6,"383":1,"400":3,"449":1,"598":2,"599":2,"627":1,"710":2,"711":2,"712":4,"713":2,"764":3,"773":8,"774":4,"780":4}}],["errors",{"2":{"91":1,"430":1,"544":1}}],["erc20outbox",{"2":{"100":1,"101":1}}],["erc20rollupeventinbox",{"2":{"100":1,"101":1}}],["erc20inbox",{"2":{"100":1,"101":1}}],["erc20bridge",{"2":{"100":1,"101":1}}],["erc20tokenbridge",{"2":{"93":2}}],["erc20",{"2":{"93":2}}],["earn",{"2":{"281":1,"676":1}}],["early",{"2":{"221":1,"291":2,"681":4,"682":2}}],["ease",{"0":{"582":1}}],["easily",{"2":{"406":1,"454":1}}],["easiest",{"2":{"388":2,"461":1,"727":1}}],["easier",{"2":{"42":1}}],["easy2stake",{"2":{"489":1,"490":1}}],["easy",{"2":{"41":1,"250":1,"582":1,"650":1,"690":1}}],["eager",{"2":{"42":1}}],["each",{"2":{"25":1,"27":2,"36":1,"46":1,"58":1,"63":1,"91":1,"110":1,"119":1,"125":1,"127":1,"130":1,"160":2,"166":1,"171":1,"202":4,"214":1,"281":1,"303":1,"322":1,"328":2,"329":1,"404":1,"430":2,"485":1,"486":1,"501":2,"525":1,"533":2,"588":1,"590":1,"591":3,"592":2,"593":2,"594":2,"643":1,"644":1,"650":1,"651":2,"652":1,"670":1,"671":1,"674":1,"677":1,"682":1,"717":1,"740":1,"776":1}}],["es",{"2":{"489":2,"490":2,"491":2,"492":2,"508":1,"509":1,"510":1}}],["estimates",{"2":{"592":1}}],["estimategas",{"2":{"592":2}}],["estimated",{"2":{"592":1,"599":2}}],["estimate",{"2":{"36":1,"93":8,"294":2,"592":1,"593":1}}],["estimating",{"0":{"591":1,"593":1},"2":{"36":2,"592":1,"599":2}}],["establishes",{"2":{"527":1}}],["established",{"2":{"434":1}}],["establish",{"2":{"36":1,"90":2,"427":1}}],["especially",{"2":{"34":1,"44":1,"609":1}}],["essentially",{"2":{"321":1}}],["essential",{"2":{"34":1,"39":1,"41":1,"47":1,"88":1,"90":1,"252":1,"313":1,"326":1,"398":5,"683":1,"689":1}}],["elevated",{"2":{"559":2}}],["eliminating",{"2":{"328":1}}],["eligibility",{"0":{"23":1},"2":{"20":1,"22":1}}],["else",{"2":{"144":2,"430":1,"784":2}}],["elastic",{"2":{"33":1}}],["eth0",{"2":{"378":2}}],["etherscan",{"2":{"202":6,"203":6,"208":1,"210":6}}],["ethereumclient",{"2":{"126":6,"128":4,"130":2}}],["ethereum",{"0":{"112":1,"134":1,"220":1,"400":1},"1":{"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1},"2":{"33":1,"82":3,"84":1,"85":1,"91":1,"103":2,"107":1,"108":2,"111":2,"112":4,"120":1,"124":2,"125":4,"126":12,"128":3,"130":4,"134":3,"144":12,"163":12,"216":1,"221":3,"225":1,"226":2,"227":8,"228":2,"231":1,"251":1,"255":1,"400":6,"454":2,"455":7,"542":1,"546":4,"590":1,"690":1}}],["ethcmn",{"2":{"144":2,"161":2,"162":2,"163":2}}],["ethclient",{"2":{"144":10,"161":8,"162":8,"163":8}}],["eths",{"2":{"93":2}}],["eth",{"0":{"84":1},"2":{"77":1,"82":2,"84":5,"86":1,"87":2,"90":1,"91":6,"93":7,"95":1,"546":1,"690":1}}],["ethnicity",{"2":{"6":1}}],["etc",{"2":{"30":2,"32":1,"42":1,"68":1,"137":1,"174":1,"337":2,"495":1,"507":1,"604":4,"606":4,"607":4,"608":4,"740":2}}],["evidence",{"2":{"717":1,"754":2}}],["evolution",{"2":{"480":1,"648":1}}],["evm",{"2":{"81":1,"107":1,"144":4,"161":6,"162":2,"163":4,"165":1,"202":1,"210":1,"211":2,"221":1,"231":1,"249":2,"251":2,"272":6,"545":1,"546":3,"578":1,"584":1}}],["evaluated",{"2":{"25":1}}],["evaluate",{"2":{"23":1,"32":1}}],["ever",{"2":{"291":2}}],["everything",{"2":{"57":1,"118":2,"186":1,"368":5,"431":1}}],["everyone",{"2":{"6":1,"35":1,"46":2,"443":1,"445":1,"448":1,"450":1,"501":1}}],["every",{"2":{"2":1,"21":1,"25":1,"28":1,"109":1,"211":1,"216":2,"228":2,"275":4,"287":1,"299":1,"303":1,"370":1,"443":1,"583":2,"588":1,"643":3,"644":1,"646":3,"649":1,"651":5,"652":1,"677":1,"733":1,"771":1}}],["even",{"2":{"34":2,"205":1,"391":1,"609":1,"645":1,"649":1}}],["eventually",{"2":{"594":1,"652":1}}],["eventpayforblobs",{"2":{"147":2}}],["eventschan",{"2":{"162":6}}],["eventsiterator",{"2":{"144":8,"161":8}}],["events",{"2":{"36":6,"46":1,"48":1,"50":1,"58":1,"90":3,"91":2,"144":4,"147":4,"160":2,"161":6,"162":2,"163":4,"208":2,"294":2,"381":2}}],["event",{"2":{"9":1,"23":1,"30":5,"31":2,"32":3,"34":2,"35":2,"36":1,"37":5,"38":11,"39":9,"40":5,"46":2,"50":1,"91":3,"112":1,"144":12,"161":8,"162":8,"163":2,"208":1,"219":1,"381":1,"400":2,"429":4}}],["e",{"2":{"9":1,"22":1,"32":1,"42":2,"119":1,"144":12,"160":1,"161":12,"174":2,"175":1,"187":1,"206":1,"217":1,"275":1,"325":1,"338":1,"361":10,"373":1,"378":2,"390":12,"392":12,"393":12,"403":1,"455":1,"459":1,"560":1,"586":1,"588":1,"594":1,"622":1,"632":1,"643":3,"644":1,"645":4,"646":4,"648":2,"649":6,"651":4,"652":9,"706":4,"740":1,"780":8}}],["ed25519",{"2":{"717":1}}],["eds",{"0":{"713":1,"781":1},"2":{"713":8,"781":10}}],["editing",{"2":{"337":1,"377":1,"431":1}}],["edits",{"2":{"8":1}}],["edit",{"2":{"8":1,"211":2,"303":1,"337":1,"429":2,"435":1}}],["education",{"2":{"6":1,"44":1}}],["embark",{"2":{"765":1}}],["embedded",{"2":{"238":1}}],["emvpw0p8nijmvnocp4bv6k+v6gjmwdxuku=",{"2":{"762":2}}],["emitted",{"2":{"219":1}}],["emits",{"2":{"144":2,"161":2,"163":2}}],["employ",{"2":{"629":1}}],["employed",{"2":{"281":1}}],["employees",{"2":{"41":1}}],["empty",{"2":{"210":1,"352":1,"709":1,"772":2,"773":3,"775":2,"778":1}}],["empowering",{"2":{"46":1}}],["empower",{"2":{"44":1}}],["emphasizing",{"2":{"34":1}}],["empathy",{"2":{"7":1}}],["emergency",{"2":{"23":1}}],["emails",{"0":{"48":1},"2":{"48":2}}],["email",{"2":{"7":1,"23":1,"26":1,"30":1,"39":2,"41":2,"47":1,"48":1,"57":1}}],["engine",{"2":{"389":1,"391":1}}],["engages",{"2":{"281":1}}],["engage",{"2":{"38":1,"39":1,"40":1,"44":1,"683":1}}],["engaged",{"2":{"36":1}}],["engagement",{"2":{"32":1,"37":1}}],["engaging",{"2":{"24":1,"35":1,"37":1,"41":1,"49":1,"57":1,"58":1}}],["enabling",{"2":{"320":1,"402":1,"554":1,"650":1,"784":2}}],["enabled=0",{"2":{"214":2}}],["enabled",{"2":{"202":2,"274":1,"313":1,"326":1,"429":12,"437":1,"541":1}}],["enables",{"2":{"112":1,"221":1,"255":1,"316":1,"320":1,"341":1,"400":1,"583":1,"584":1,"617":1,"642":1,"644":1,"648":2,"649":1,"650":1,"676":1}}],["enable",{"0":{"205":1,"364":1},"2":{"18":1,"91":4,"211":2,"316":1,"320":2,"363":1,"371":2,"427":1,"454":1,"541":1,"546":1,"604":3,"606":3,"607":3,"608":3,"642":1,"645":1,"648":1,"728":1,"784":2}}],["envcd",{"2":{"211":1}}],["env",{"2":{"202":4,"210":11,"211":7,"218":1,"586":1}}],["environments",{"2":{"64":1,"487":1,"505":1}}],["environment",{"0":{"397":1},"1":{"398":1,"399":1},"2":{"7":1,"46":1,"202":4,"210":3,"211":10,"251":1,"254":1,"311":1,"320":1,"341":1,"343":1,"388":1,"397":2,"457":1,"462":1,"477":1,"478":1,"480":1,"542":3,"586":1,"616":1,"649":1,"697":1,"707":2,"766":1,"768":1,"774":3}}],["enough",{"2":{"136":1,"227":1,"643":1}}],["encrypt",{"2":{"263":2}}],["encrypted",{"2":{"263":5,"701":1}}],["encapsulating",{"2":{"88":1}}],["encounter",{"2":{"334":1,"337":1,"383":1,"449":1,"481":1,"627":1,"764":1}}],["encouraging",{"2":{"44":1}}],["encouraged",{"2":{"334":1,"501":1,"737":1}}],["encourages",{"2":{"35":1,"38":1,"41":1,"86":1}}],["encourage",{"2":{"31":1,"37":1,"38":1,"39":1}}],["encode",{"2":{"155":2,"539":1,"599":2,"643":1}}],["encoded",{"2":{"125":1,"127":1,"137":1,"142":1,"147":1,"152":1,"169":2,"183":1,"190":1,"191":1,"194":1,"266":1,"539":2,"540":1,"571":1,"596":4,"597":4,"745":9,"747":2}}],["encoding",{"2":{"125":1,"150":2,"171":1,"564":1,"599":6,"634":2,"643":2,"645":8,"648":1,"651":1,"771":2}}],["encompasses",{"2":{"238":1}}],["encompass",{"2":{"41":1}}],["enjoy",{"2":{"46":1,"58":1,"93":2}}],["enjoyable",{"2":{"35":1}}],["enlightening",{"2":{"44":1}}],["endkey",{"2":{"156":3}}],["ending",{"2":{"156":2,"649":1,"767":1}}],["endshare=1",{"2":{"152":1}}],["endblock",{"2":{"144":6,"161":4}}],["end=20",{"2":{"142":1}}],["endpoints",{"0":{"64":1,"65":1,"66":1,"67":1,"68":1,"487":1,"489":1,"490":1,"491":1,"492":1,"494":1,"495":1,"496":1,"497":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1},"1":{"67":1,"68":1,"497":1},"2":{"65":7,"67":1,"68":3,"252":1,"301":1,"310":1,"322":1,"326":1,"371":2,"487":1,"489":1,"494":1,"495":3,"505":1,"506":1,"507":2,"509":2,"511":1,"561":1,"708":1,"719":1,"728":1,"733":1,"736":1,"777":1}}],["endpoint",{"0":{"321":1,"376":1,"737":1},"1":{"377":1,"378":1,"379":1},"2":{"63":1,"65":2,"68":1,"91":3,"109":2,"136":4,"141":1,"142":1,"143":1,"144":4,"147":1,"149":1,"151":1,"152":3,"153":1,"160":1,"161":4,"163":4,"202":1,"210":1,"211":2,"238":1,"244":1,"245":1,"275":4,"301":1,"316":6,"317":2,"318":2,"319":2,"320":4,"321":1,"338":2,"371":1,"376":1,"378":1,"390":1,"422":3,"465":3,"486":1,"495":1,"497":1,"508":1,"509":1,"510":1,"546":1,"560":2,"737":5,"745":1,"762":1}}],["end",{"2":{"38":1,"125":2,"141":1,"147":6,"151":1,"152":4,"156":3,"163":4,"172":1,"175":1,"216":2,"219":1,"294":2,"295":2,"429":4,"646":1,"651":1}}],["enhancement",{"2":{"328":1}}],["enhanced",{"2":{"59":1}}],["enhances",{"2":{"35":1,"38":1}}],["enhance",{"2":{"32":1,"652":1}}],["entails",{"2":{"645":1,"649":4,"650":1}}],["entering",{"2":{"616":1}}],["enter",{"2":{"263":2,"275":1,"281":1,"291":2,"658":1,"662":1,"702":1}}],["enters",{"2":{"23":1}}],["entrypoint",{"2":{"202":1,"210":1,"234":2,"706":2,"707":2}}],["entry",{"2":{"86":2,"254":1}}],["enthusiastic",{"2":{"43":1}}],["enthusiasts",{"2":{"37":1,"44":1}}],["entities",{"2":{"224":1,"639":1}}],["entitle",{"2":{"69":1,"512":1}}],["entity",{"2":{"26":2,"320":1,"338":2,"560":1}}],["entirely",{"2":{"134":1}}],["entire",{"2":{"29":1,"110":1,"338":1,"356":1,"372":1,"496":1,"560":1,"633":1,"642":1,"652":1,"707":1}}],["ensuring",{"2":{"18":1,"39":1,"58":1}}],["ensures",{"2":{"381":1,"400":1,"629":1,"633":1,"649":1}}],["ensure",{"2":{"2":1,"31":1,"36":1,"37":1,"39":1,"40":2,"41":1,"86":1,"88":1,"90":1,"226":1,"337":1,"400":1,"431":1,"450":1,"459":1,"481":1,"530":1,"601":1,"649":1,"672":2,"764":1}}],["enforced",{"2":{"396":1,"590":1}}],["enforce",{"2":{"46":1}}],["enforcement",{"0":{"8":1,"10":1,"11":1},"1":{"12":1,"13":1,"14":1,"15":1},"2":{"10":1,"16":1}}],["enforcing",{"2":{"8":1,"13":1,"14":1}}],["exit",{"2":{"143":6,"144":2,"163":2}}],["exist",{"2":{"201":2,"246":1,"331":1,"408":1,"423":1,"468":1,"673":1,"674":1,"684":1,"685":1}}],["exists",{"2":{"167":1,"170":1,"433":1}}],["existent",{"2":{"127":1}}],["existing",{"0":{"212":1,"524":1,"707":1},"2":{"22":1,"25":1,"36":1,"41":1,"54":1,"55":1,"91":1,"184":1,"204":1,"208":4,"210":1,"212":2,"217":1,"275":1,"311":1,"334":1,"336":1,"341":1,"432":1,"434":1,"435":1,"450":1,"455":1,"544":1,"551":1,"584":2,"594":1,"706":1,"707":2,"718":1}}],["exec",{"2":{"706":2,"707":2}}],["execstart=$",{"2":{"604":2,"606":2,"607":2,"608":2}}],["executable",{"2":{"214":2,"651":4,"670":2}}],["execution",{"2":{"130":1,"204":1,"249":1,"251":1,"455":1,"580":2,"583":3,"584":3,"642":2,"648":1,"649":7,"650":1,"690":1,"722":1}}],["executing",{"2":{"93":2,"381":1,"649":1}}],["executor",{"2":{"93":6}}],["executed",{"2":{"373":1,"622":1,"649":1,"651":1}}],["executes",{"2":{"369":2}}],["execute",{"2":{"51":1,"57":1,"204":1,"294":1,"329":1,"370":1,"398":1,"580":1,"583":1,"648":1}}],["exercises",{"2":{"126":1}}],["exhaustive",{"2":{"109":2}}],["extends",{"2":{"651":1}}],["extendeddatasquare",{"2":{"713":2,"781":2}}],["extendedheader",{"2":{"712":2}}],["extendedheaders",{"2":{"459":1}}],["extended",{"0":{"645":1,"713":1,"781":1},"2":{"174":1,"175":1,"643":4,"645":6,"651":4,"652":2,"670":1,"713":1,"760":1,"780":4,"781":1}}],["extension",{"0":{"656":1,"661":1},"2":{"294":4,"784":2}}],["external",{"0":{"378":1},"2":{"13":1,"107":1,"275":4,"378":3,"582":1,"728":1}}],["extradata",{"2":{"538":2}}],["extra",{"0":{"374":1},"1":{"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1},"2":{"91":2,"95":1,"175":1,"592":1,"625":1}}],["exact",{"2":{"485":1,"593":1,"677":1}}],["exactly",{"2":{"25":1,"275":2,"565":1,"717":1}}],["example",{"0":{"118":1,"144":1,"163":1,"182":1,"760":1},"2":{"68":2,"74":1,"90":1,"93":1,"118":1,"142":2,"147":2,"152":2,"155":1,"156":1,"157":1,"159":1,"160":3,"163":5,"172":1,"180":1,"182":1,"202":8,"210":5,"211":3,"218":1,"244":1,"245":1,"263":1,"265":2,"294":1,"301":1,"308":1,"313":1,"317":1,"318":1,"319":1,"326":1,"329":1,"331":1,"332":1,"338":2,"343":2,"361":1,"367":1,"380":1,"381":1,"391":1,"392":1,"408":1,"409":1,"412":1,"432":1,"518":1,"546":1,"559":1,"564":3,"565":1,"580":1,"591":1,"607":1,"616":1,"646":2,"649":1,"652":1,"674":1,"682":1,"706":1,"707":1,"711":1,"712":1,"737":2,"740":1,"742":1,"744":2,"745":4,"747":3,"751":1,"754":1,"757":1,"760":1,"762":2,"775":1,"780":1}}],["examples",{"0":{"330":1,"749":1},"1":{"331":1,"332":1,"333":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1},"2":{"7":2,"9":1,"134":1,"314":1,"320":1,"598":1,"748":1,"762":1}}],["exceed",{"2":{"369":1}}],["exceptions",{"0":{"722":1}}],["exceptional",{"2":{"18":1,"37":1}}],["except",{"2":{"144":2,"609":1}}],["exclusively",{"2":{"59":1}}],["exclusive",{"2":{"47":1,"58":1,"147":1}}],["exchange",{"2":{"23":1,"87":1}}],["exposes",{"2":{"509":1}}],["expose",{"0":{"377":1}}],["exposed",{"2":{"126":1,"245":1,"422":1,"465":1,"719":1,"726":1,"736":1}}],["exporter",{"0":{"276":1},"2":{"276":1}}],["exported",{"2":{"263":2}}],["exporting",{"0":{"263":1,"701":1}}],["export",{"0":{"271":1},"2":{"93":1,"260":4,"263":3,"271":1,"275":1,"293":2,"299":2,"314":15,"399":4,"405":4,"412":4,"539":3,"560":3,"701":7,"706":1,"742":2,"743":1,"744":2,"762":1,"784":10}}],["expand",{"2":{"40":1,"46":1}}],["express",{"2":{"38":1}}],["expression",{"2":{"6":1}}],["expensive",{"2":{"171":1,"183":1,"185":1,"188":1,"199":2}}],["expenses",{"2":{"38":1}}],["experimentation",{"2":{"584":1}}],["experimentalsuggestchain",{"2":{"784":4}}],["experimental",{"2":{"221":1,"341":2,"481":1,"549":1}}],["experimenting",{"2":{"576":1}}],["experiment",{"2":{"439":1}}],["experiences",{"2":{"7":1}}],["experience",{"2":{"6":2,"7":1,"26":1,"32":1,"35":1,"38":1,"46":1,"528":1,"542":1,"549":1,"724":1,"765":1}}],["experts",{"2":{"37":2,"58":1}}],["expertise",{"2":{"37":1,"42":1,"58":1}}],["expects",{"2":{"316":1,"396":1}}],["expect",{"2":{"48":1,"58":1,"124":1,"707":1,"779":10,"780":6,"781":6}}],["expectations",{"2":{"36":1}}],["expected",{"2":{"23":1,"30":1,"130":2,"204":1,"295":1,"331":1,"332":1,"333":1,"383":2,"627":2,"674":2}}],["exploring",{"2":{"259":1,"384":1}}],["exploreme",{"2":{"498":1}}],["explored",{"2":{"197":1}}],["explorer",{"0":{"92":1,"257":1},"2":{"72":1,"79":1,"92":2,"257":2,"461":1,"498":2,"514":1,"601":2,"616":1,"622":1,"685":1,"773":2,"785":2,"786":1}}],["explorers",{"0":{"72":1,"498":1,"514":1},"2":{"72":1,"498":2,"514":3,"622":1,"640":1,"715":1}}],["explore",{"2":{"34":1,"50":1,"51":1,"457":1}}],["explains",{"2":{"427":1,"517":1}}],["explained",{"2":{"183":1,"188":1,"197":1}}],["explanation",{"2":{"12":1,"632":1}}],["explicit",{"2":{"7":1}}],["pwd",{"2":{"707":2}}],["ps",{"2":{"706":1,"707":1}}],["psdocker",{"2":{"706":1,"707":1}}],["psql",{"2":{"380":2}}],["python3",{"2":{"545":2}}],["p",{"2":{"215":2,"372":6,"539":2,"560":2,"561":1,"706":2}}],["pk",{"2":{"214":2}}],["pkg",{"2":{"144":2,"150":2,"163":2,"383":14,"398":4,"599":6,"627":14}}],["pfbs",{"2":{"169":1,"183":1,"185":1,"530":2,"593":1}}],["pfb",{"0":{"149":1,"591":1,"763":1},"1":{"150":1},"2":{"93":1,"137":5,"139":1,"145":1,"149":1,"150":2,"169":4,"170":1,"171":1,"191":2,"485":2,"588":1,"591":4,"671":1,"747":3}}],["p2p",{"0":{"351":1,"361":1},"1":{"352":1,"353":1},"2":{"65":5,"68":2,"91":4,"126":1,"244":4,"245":6,"246":4,"260":2,"313":2,"314":4,"316":2,"318":2,"319":2,"320":4,"322":1,"324":4,"325":5,"326":2,"329":6,"334":4,"335":4,"336":4,"338":4,"390":12,"392":12,"393":12,"407":2,"408":2,"421":4,"422":2,"423":4,"464":4,"465":6,"466":8,"468":4,"477":4,"478":8,"511":1,"518":2,"523":2,"546":4,"559":3,"561":2,"567":2,"607":2,"648":1,"700":9,"701":6,"702":6,"706":4,"707":3,"736":4,"737":8,"738":8,"740":2,"742":4,"744":4,"752":2,"762":2,"767":4}}],["pin",{"2":{"674":1}}],["pinning",{"2":{"674":1}}],["pinnacle",{"2":{"480":1}}],["pings",{"2":{"218":1}}],["pink",{"2":{"137":1}}],["pieces",{"2":{"125":1}}],["pick",{"0":{"85":1,"90":1},"2":{"308":1,"344":1,"361":1,"622":1,"657":1,"700":1}}],["pitches",{"2":{"38":1}}],["pitch",{"2":{"38":2}}],["pizza",{"2":{"35":1}}],["phase",{"2":{"355":1}}],["phrase",{"2":{"291":2,"430":1}}],["photos",{"2":{"31":1,"32":1}}],["physical",{"2":{"7":1}}],["plugin",{"2":{"277":1}}],["plus",{"2":{"84":1,"771":1}}],["plonky2x",{"2":{"214":7,"215":3,"233":1}}],["plonk",{"2":{"202":1,"203":1,"213":1,"214":3,"215":1}}],["plw1gxabnavhwwurqswb0xh25zv9xhielqtvld0xqc4=",{"2":{"147":2}}],["plain",{"2":{"684":1,"745":1,"747":1}}],["plaintext",{"2":{"559":2,"745":1}}],["plasma",{"2":{"537":1,"542":2}}],["plastic",{"2":{"35":1}}],["play",{"2":{"385":1,"453":1,"692":1}}],["playbook",{"2":{"44":1}}],["playlist",{"2":{"40":1}}],["platform",{"0":{"41":1,"218":1},"2":{"49":1,"203":1,"211":2,"218":3,"219":1,"251":1,"388":1,"480":1}}],["platforms",{"2":{"30":1,"39":1,"40":1,"720":1}}],["planned",{"2":{"36":1,"39":1,"526":1}}],["planning",{"2":{"32":1,"42":1,"344":1}}],["plans",{"2":{"35":1}}],["plan",{"2":{"30":1,"35":1,"36":1,"39":1,"40":1,"41":1,"51":1,"57":1}}],["placement",{"2":{"22":2,"26":1}}],["place",{"2":{"22":10,"38":1,"275":1,"291":2,"432":1,"574":1,"709":1,"778":1}}],["plethora",{"2":{"276":1}}],["pledge",{"0":{"6":1},"2":{"6":2}}],["please",{"2":{"2":1,"4":1,"26":4,"30":1,"47":2,"57":1,"91":1,"124":1,"134":1,"152":1,"153":1,"163":2,"221":1,"336":2,"347":1,"387":1,"388":1,"428":2,"430":1,"485":1,"530":1,"536":1,"623":1,"700":1,"784":2}}],["panel",{"2":{"668":1}}],["panic",{"2":{"383":2,"627":2}}],["padded",{"2":{"651":1}}],["paper",{"2":{"643":1,"646":1,"652":1}}],["packet",{"2":{"429":8,"435":4}}],["packets",{"2":{"427":3,"428":1,"429":2}}],["packages",{"2":{"398":1}}],["package",{"0":{"599":1},"2":{"104":1,"143":1,"144":1,"163":1,"261":1,"275":1,"599":2,"771":1}}],["pagination",{"2":{"297":4}}],["page",{"2":{"26":1,"73":1,"77":1,"87":1,"113":1,"160":1,"244":3,"245":1,"258":1,"275":2,"277":1,"281":1,"301":1,"309":1,"311":1,"312":1,"324":1,"388":2,"390":2,"397":1,"422":2,"453":1,"462":1,"465":1,"500":1,"501":2,"515":1,"524":1,"537":1,"556":1,"558":1,"572":1,"573":2,"574":1,"588":1,"619":1,"625":1,"651":1,"656":1,"700":1,"706":2,"737":1,"738":1,"783":1}}],["pairs",{"2":{"322":1}}],["paired",{"2":{"275":1}}],["paid",{"2":{"87":1,"546":1,"674":1}}],["path=$path",{"2":{"399":4}}],["path",{"0":{"287":1},"2":{"203":2,"211":3,"215":2,"246":1,"247":1,"266":4,"267":2,"287":1,"349":1,"392":6,"393":4,"396":1,"423":1,"424":1,"468":1,"469":1,"559":4,"699":2,"741":1,"743":3,"744":5}}],["pattern",{"2":{"15":1}}],["payload",{"2":{"773":4}}],["paying",{"0":{"669":1,"689":1},"1":{"670":1,"671":1},"2":{"690":1}}],["payee",{"2":{"429":2}}],["payer",{"2":{"294":2}}],["payment",{"2":{"404":1,"670":2,"717":1}}],["payments",{"2":{"86":1}}],["payforblob",{"2":{"144":6,"150":1,"161":2,"163":2,"245":1,"422":2,"466":1,"471":1}}],["payforblobs",{"0":{"670":1},"2":{"137":1,"400":1,"465":1,"544":1,"592":1,"596":2,"651":3,"652":1,"670":3,"689":1,"738":1,"764":1}}],["pay",{"2":{"87":1,"91":1,"245":1,"404":2,"412":1,"422":1,"466":1,"546":1,"592":1,"738":1}}],["paradigm",{"2":{"649":2}}],["parallel",{"2":{"584":1}}],["param",{"2":{"266":2}}],["paramfilter",{"2":{"266":1}}],["params=",{"2":{"784":6}}],["params",{"2":{"91":1,"266":3,"355":1,"540":3,"717":1,"762":2,"784":27}}],["parameterchangeproposal",{"2":{"266":2}}],["parameters",{"0":{"484":1,"679":1,"784":1},"1":{"485":1},"2":{"93":1,"154":4,"160":2,"204":1,"266":1,"281":1,"322":1,"484":2,"525":1,"588":1,"591":2,"592":1,"652":1,"679":2,"692":1,"740":1,"783":1,"784":3,"785":1,"786":1}}],["parameter",{"2":{"86":2,"122":1,"147":1,"266":3,"337":2,"485":2,"591":1,"592":1,"593":1,"622":1}}],["parity",{"2":{"174":1,"643":1,"645":1}}],["parsing",{"2":{"169":1,"170":2,"179":1,"183":1,"194":1}}],["parsed",{"2":{"199":1,"210":1,"773":2}}],["parse",{"2":{"163":2,"169":2,"171":1,"183":1,"185":1,"199":1,"760":1,"773":2}}],["parenthash",{"2":{"538":2}}],["parent",{"2":{"86":1,"90":2,"93":18}}],["parts",{"2":{"542":1,"670":1,"692":1,"754":4}}],["party",{"2":{"372":1,"402":1,"404":1,"412":1,"639":1,"715":1}}],["partitioned",{"2":{"646":1,"651":1}}],["partitions",{"2":{"646":1,"733":1}}],["particularly",{"2":{"629":1,"720":1}}],["particular",{"2":{"227":1,"343":1,"528":1,"530":1}}],["participating",{"2":{"42":1,"46":1,"58":1,"63":1,"272":1,"445":1,"486":1,"501":1}}],["participation",{"2":{"6":1,"18":1,"23":1,"32":1,"49":1,"86":1}}],["participates",{"2":{"533":1}}],["participate",{"0":{"548":1},"1":{"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"555":1,"556":1},"2":{"38":1,"47":1,"58":1,"65":1,"86":1,"443":1,"486":1,"501":1,"533":1,"551":1,"552":1,"612":1,"622":1,"650":1}}],["participant",{"2":{"23":1,"48":1}}],["participants",{"2":{"22":1,"40":1,"42":3,"46":1,"58":1,"448":1,"450":4,"451":2,"452":1}}],["parties",{"2":{"178":1,"639":1}}],["part",{"2":{"47":1,"137":1,"139":2,"140":1,"145":1,"163":6,"174":1,"175":5,"179":1,"183":3,"187":1,"227":1,"322":1,"428":1,"484":1,"542":1,"568":1,"582":1,"617":1,"646":2,"649":1,"682":1,"689":1,"690":1}}],["partnering",{"2":{"34":1,"38":1}}],["passes",{"2":{"651":1,"741":1}}],["passed",{"2":{"246":1,"260":2,"422":1,"423":1,"465":1,"468":1,"748":1,"773":2}}],["passing",{"0":{"520":1,"521":1}}],["passionate",{"2":{"58":1}}],["passphrase",{"2":{"263":2,"616":3}}],["password",{"2":{"263":3,"275":1,"291":2}}],["pass",{"2":{"122":1,"266":1,"709":1,"741":1,"772":3,"773":3,"775":2,"778":1,"784":2}}],["pasting",{"2":{"768":1}}],["paste",{"2":{"91":1,"124":1,"767":1}}],["past",{"0":{"531":1},"1":{"532":1},"2":{"38":1,"294":1,"367":1,"444":1,"635":1,"636":3,"637":1,"639":1,"640":2}}],["policy",{"2":{"429":4,"435":4}}],["political",{"2":{"7":1}}],["polypore",{"2":{"429":6}}],["popup",{"2":{"658":1}}],["populating",{"2":{"378":1,"772":1}}],["populated",{"2":{"773":1}}],["populate",{"2":{"110":1}}],["populates",{"2":{"67":1,"68":1,"494":1,"495":1,"506":1,"507":1}}],["popularity",{"2":{"36":1}}],["popular",{"2":{"36":1,"39":1}}],["pops",{"2":{"245":2,"265":4,"301":2,"303":2,"329":2,"403":1,"405":2,"412":2,"413":2,"429":2,"465":4,"466":2,"489":1,"490":1,"491":1,"495":1,"507":1,"509":1,"510":1,"560":4,"561":3,"706":2,"707":2,"737":2,"786":2}}],["point",{"2":{"254":1,"275":2,"291":2,"338":1,"489":1,"490":1,"491":1,"508":1,"509":1,"510":1,"594":1,"649":2,"700":1}}],["pointing",{"2":{"172":1}}],["pointer",{"2":{"109":1,"112":1,"125":2,"127":1,"172":1}}],["points",{"0":{"22":1},"2":{"328":1,"521":1}}],["portid",{"2":{"434":4}}],["portions",{"2":{"632":1,"633":1,"634":1}}],["portion",{"2":{"21":1,"137":1,"298":1,"302":1,"644":1,"682":1,"691":1}}],["portrays",{"2":{"182":1}}],["portal",{"2":{"81":1,"85":3,"86":1}}],["port",{"2":{"67":1,"68":5,"91":1,"244":5,"245":1,"275":3,"276":1,"303":2,"313":2,"326":4,"328":1,"333":2,"422":1,"429":4,"434":8,"451":4,"452":3,"465":1,"477":8,"478":3,"494":1,"495":15,"506":1,"507":3,"508":1,"509":1,"510":1,"737":5,"762":2}}],["ports",{"0":{"313":1,"326":1},"2":{"65":3,"68":2,"244":2,"309":2,"313":7,"324":2,"326":7,"390":2,"422":2,"453":2,"465":2,"619":2,"706":4,"707":4,"737":2}}],["poolcelestia",{"2":{"267":1}}],["pool",{"0":{"267":1,"680":1},"2":{"36":1,"267":9,"680":2,"692":1}}],["potentially",{"2":{"36":1,"40":1,"591":1,"592":1,"720":1}}],["potential",{"2":{"30":1,"36":1,"37":2,"38":2,"49":1,"91":1,"226":1}}],["powerful",{"2":{"273":1}}],["power",{"2":{"23":1,"528":1,"530":1,"651":1,"754":4,"765":1}}],["pos",{"0":{"647":1},"1":{"648":1},"2":{"648":2}}],["possibly",{"2":{"611":1}}],["possible",{"2":{"39":1,"81":1,"108":1,"130":2,"149":1,"182":1,"208":1,"235":1,"336":1,"406":1,"583":1,"643":1,"645":1,"652":1,"672":1,"674":1,"717":1,"764":1}}],["possibilities",{"2":{"457":1,"649":1}}],["positions",{"2":{"175":1}}],["position",{"2":{"109":1}}],["positives",{"2":{"652":1}}],["positiveerror",{"2":{"334":1}}],["positive",{"2":{"7":1,"46":1,"334":3,"652":1}}],["postgresql",{"2":{"380":1}}],["poster",{"0":{"90":1},"2":{"86":4,"88":1,"90":2,"91":7,"93":3,"109":3}}],["posted",{"2":{"85":3,"86":1,"91":1,"93":2,"109":2,"112":1,"118":1,"122":1,"124":1,"125":2,"126":1,"130":3,"134":1,"136":1,"137":1,"139":1,"154":4,"168":2,"180":1,"186":1,"187":1,"191":1,"194":1,"250":1,"331":1,"455":1,"564":1,"565":3,"710":1,"732":1,"773":1,"779":1}}],["post",{"0":{"562":1,"601":1,"763":1},"1":{"563":1,"564":1,"565":1},"2":{"34":1,"37":1,"39":1,"81":1,"86":1,"91":1,"109":2,"124":1,"128":2,"165":2,"178":1,"179":1,"228":1,"333":2,"404":1,"454":1,"540":2,"544":1,"546":1,"557":3,"564":4,"565":1,"598":2,"710":2,"762":4,"763":1,"775":1}}],["posts",{"2":{"30":1,"32":1,"85":1,"455":3,"542":3}}],["postings",{"2":{"88":1}}],["posting",{"0":{"134":1,"564":1},"2":{"9":1,"86":3,"87":1,"90":2,"91":1,"109":1,"124":1,"128":1,"385":1,"400":2,"455":4,"561":1,"563":1,"776":1}}],["peerid",{"2":{"752":1}}],["peer",{"0":{"452":1},"2":{"355":3,"452":3,"478":5,"609":1,"623":1,"674":6}}],["peerexchange",{"2":{"353":1}}],["peers=$",{"2":{"361":6}}],["peers",{"0":{"353":1},"2":{"352":2,"355":3,"361":38,"371":1,"378":1,"451":3,"478":2,"511":1}}],["pending",{"2":{"77":1,"79":1}}],["percentage",{"2":{"267":1,"281":2,"676":1}}],["persist",{"2":{"391":1}}],["persisted",{"2":{"381":1,"396":1}}],["persistent",{"0":{"391":1,"452":1},"1":{"392":1,"393":1},"2":{"361":13,"393":1,"451":5,"452":1}}],["perspective",{"2":{"238":1,"652":1}}],["person",{"2":{"40":2,"58":1}}],["personal",{"2":{"6":1,"7":1,"26":1,"37":1,"38":1}}],["per",{"2":{"37":1,"70":2,"512":2,"591":2,"592":2,"593":1,"599":2,"671":1,"677":1,"687":1}}],["performs",{"2":{"651":1,"740":1}}],["performed",{"2":{"431":2,"462":1,"644":1,"721":1}}],["performing",{"2":{"252":1,"644":1,"652":2}}],["perform",{"2":{"130":2,"322":1,"458":1,"459":1,"649":2,"652":1,"673":1}}],["performance",{"2":{"18":1,"20":1,"23":1,"32":1,"59":1,"221":1,"273":1,"337":1,"341":1,"481":1,"510":1,"549":1,"584":1}}],["perfect",{"2":{"34":1}}],["permanently",{"2":{"281":1,"672":1}}],["permanent",{"0":{"15":1},"2":{"13":1,"14":1,"15":1,"322":1}}],["permissions",{"2":{"391":1,"396":2,"726":1}}],["permissioned",{"2":{"225":1}}],["permissionless",{"2":{"205":1,"206":1,"564":1,"642":1,"649":1,"691":1}}],["permission",{"0":{"407":1,"410":1},"1":{"411":1},"2":{"7":1,"406":1}}],["periods",{"2":{"23":1}}],["period",{"2":{"13":1,"14":2,"22":1,"24":1,"86":2,"208":1,"281":3,"434":2}}],["people",{"2":{"7":1,"13":1,"14":1,"34":1,"36":1,"41":1,"42":1}}],["put",{"2":{"670":1}}],["punish",{"2":{"281":1}}],["pure",{"2":{"118":2}}],["purposes",{"2":{"126":1,"343":1,"396":1,"501":1,"635":1}}],["purpose",{"2":{"46":1,"353":1,"455":1,"639":1,"672":1,"699":1}}],["purchased",{"2":{"7":1}}],["pub",{"2":{"295":2,"296":2,"754":4,"784":2}}],["pubkeyed25519",{"2":{"754":4}}],["pubkey",{"2":{"291":4,"292":8,"296":2,"707":4}}],["pubkey=$",{"2":{"272":2,"622":2}}],["pubs",{"2":{"36":1}}],["publish",{"2":{"274":1,"641":1,"670":1}}],["published",{"2":{"109":1,"121":1,"139":1,"144":2,"164":1,"225":1,"579":1,"580":1,"629":2,"672":2,"674":1}}],["publishing",{"2":{"7":1,"275":3}}],["publicnode",{"2":{"546":2}}],["publicly",{"2":{"58":1,"377":1}}],["public",{"2":{"3":1,"7":1,"9":1,"12":1,"14":2,"15":1,"37":1,"69":1,"81":1,"87":1,"118":6,"163":2,"218":2,"309":2,"371":1,"376":1,"377":1,"378":1,"448":1,"489":1,"490":1,"491":1,"495":1,"507":1,"508":1,"510":1,"512":1,"546":3,"622":1,"637":1,"673":1,"674":2,"681":1,"682":1,"728":1}}],["pulled",{"2":{"775":1}}],["pull",{"2":{"2":2,"334":1,"450":1,"536":1,"699":1}}],["push",{"2":{"2":2,"118":2,"429":4}}],["pragma",{"2":{"118":2,"163":1}}],["practices",{"0":{"674":1},"2":{"54":1}}],["prune",{"2":{"368":2,"496":1,"673":1}}],["pruned",{"2":{"23":1,"27":1,"611":1,"673":1}}],["pruning",{"0":{"362":1,"672":1,"673":1},"1":{"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"673":1,"674":1},"2":{"68":1,"367":2,"368":1,"495":1,"496":1,"672":1,"673":4}}],["predetermined",{"2":{"528":1,"632":1}}],["precompiles",{"2":{"584":1}}],["precise",{"2":{"485":1}}],["precedence",{"2":{"328":1}}],["prefixed",{"2":{"651":1,"745":1}}],["prefix",{"2":{"429":12,"539":2,"785":1,"786":1}}],["preferred",{"0":{"654":1}}],["preference",{"2":{"527":1}}],["preferences",{"2":{"312":1,"343":1}}],["prefer",{"2":{"244":1,"737":1}}],["press",{"2":{"667":1}}],["preserved",{"2":{"334":1}}],["presence",{"2":{"328":1,"609":1}}],["present",{"2":{"225":1,"322":1,"324":1,"334":1}}],["presenters",{"2":{"37":1}}],["presenting",{"2":{"37":1}}],["presentation",{"0":{"53":1,"54":1,"55":1,"56":1},"2":{"30":1,"37":1,"38":1,"53":3,"54":3,"55":3,"56":2}}],["presentations",{"2":{"30":1,"31":1,"37":1,"54":1,"55":1,"58":1}}],["presumes",{"2":{"311":1}}],["preventing",{"2":{"400":1}}],["prevent",{"2":{"302":1,"303":1,"438":1}}],["previously",{"2":{"309":1,"455":1,"622":1,"740":1}}],["previoushash",{"2":{"125":2,"128":2}}],["previous",{"0":{"232":1},"1":{"233":1,"234":1,"235":1,"236":1},"2":{"32":1,"87":1,"112":1,"125":2,"204":2,"213":1,"215":3,"216":1,"227":1,"233":1,"294":1,"298":1,"302":1,"328":1,"336":1,"449":1,"561":1,"635":1,"661":1}}],["preimage",{"0":{"110":1},"2":{"108":1,"110":3}}],["pre",{"0":{"312":1,"342":1,"347":1,"403":1},"1":{"343":1},"2":{"86":1,"204":1,"310":1,"312":3,"342":2,"527":1,"528":1,"530":1,"537":1,"558":1}}],["prerequisites",{"0":{"82":1,"103":1,"116":1,"136":1,"307":1,"389":1,"473":1,"705":1},"2":{"474":1,"697":1}}],["prerequisite",{"2":{"47":1,"279":2,"697":1}}],["preparing",{"2":{"31":1}}],["prepared",{"2":{"383":1,"627":1}}],["prepare",{"2":{"30":2,"39":1,"526":1}}],["proj",{"2":{"768":2}}],["project",{"0":{"709":1,"770":1,"778":1},"2":{"163":2,"169":1,"267":2,"564":1,"709":1,"770":2,"778":1}}],["projector",{"2":{"34":1}}],["projectors",{"2":{"30":1,"34":1}}],["projects",{"2":{"23":1,"38":1,"724":1}}],["probabilistically",{"2":{"652":1}}],["probability",{"2":{"643":1}}],["probably",{"2":{"580":1}}],["problem",{"0":{"630":1,"636":1},"2":{"630":2,"639":2,"642":1,"649":1,"650":1}}],["problematic",{"2":{"629":1}}],["problems",{"2":{"572":1,"636":1,"638":1}}],["progress",{"2":{"560":1}}],["programs",{"2":{"681":1}}],["programmatic",{"2":{"725":1}}],["programmatically",{"0":{"593":1},"2":{"134":1,"599":2}}],["programmed",{"2":{"527":1,"528":1,"530":1}}],["programming",{"2":{"164":1}}],["program",{"0":{"17":1,"18":1,"20":1,"43":1,"44":1},"1":{"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1},"2":{"18":1,"20":2,"22":2,"23":4,"25":1,"26":3,"27":1,"28":2,"33":1,"36":1,"37":1,"44":1,"47":2,"48":1,"50":1,"56":3,"58":3,"228":1,"569":1,"570":1,"771":4,"772":5,"773":6,"775":2}}],["pro",{"2":{"498":1}}],["property",{"2":{"652":1,"687":1}}],["properties",{"2":{"238":1,"559":2,"583":1}}],["properly",{"2":{"355":1}}],["proposing",{"2":{"651":1}}],["proposed",{"2":{"630":1}}],["propose",{"2":{"281":1,"679":1}}],["proposer",{"2":{"266":4,"455":1,"546":4,"754":8}}],["proposal",{"2":{"266":14,"267":5,"680":1}}],["proposalscelestia",{"2":{"266":1}}],["proposals",{"2":{"266":6,"267":3,"528":1,"653":1,"679":2,"692":1}}],["proxy",{"2":{"218":1}}],["pros",{"0":{"170":1,"176":1,"180":1,"184":1,"188":1,"192":1,"195":1},"2":{"166":1,"170":1}}],["prospective",{"2":{"20":1}}],["produced",{"2":{"711":1,"712":1,"780":1}}],["producers",{"2":{"645":2,"652":1}}],["producer",{"2":{"630":2,"651":4}}],["produceblock",{"2":{"128":2}}],["producing",{"2":{"126":2,"277":1,"533":1}}],["product",{"2":{"591":1,"592":2}}],["production",{"0":{"64":1,"487":1,"505":1},"2":{"64":1,"65":2,"86":2,"238":1,"301":2,"361":1,"480":1,"487":3,"489":2,"505":3,"549":1,"582":1,"609":2,"737":2}}],["products",{"2":{"60":1}}],["provably",{"2":{"672":1}}],["provisions",{"2":{"677":1}}],["provision",{"2":{"497":1}}],["proving",{"0":{"132":1,"144":1,"174":1,"175":1,"217":1},"2":{"124":1,"145":1,"164":1,"165":1,"167":1,"169":2,"175":2,"179":4,"211":1,"217":2,"218":1,"235":1,"586":4,"629":1}}],["provides",{"2":{"41":1,"122":1,"244":1,"251":1,"273":1,"402":1,"422":1,"485":1,"574":1,"585":1,"601":1,"642":1,"646":1,"648":1,"649":1,"650":1,"674":1,"724":1,"726":1,"737":1}}],["provided",{"2":{"33":1,"37":1,"44":1,"81":1,"93":1,"157":1,"174":1,"183":1,"191":2,"202":2,"352":1,"355":1,"371":2,"646":3,"698":1,"717":1}}],["providers",{"0":{"715":1},"1":{"716":1,"717":1,"718":1,"719":1,"720":1,"721":1,"722":1},"2":{"34":1,"64":1,"65":1,"487":2,"489":1,"505":2,"582":1,"674":2,"715":1,"728":1}}],["provider",{"0":{"109":1,"717":1},"1":{"718":1,"719":1,"720":1,"721":1,"722":1},"2":{"26":1,"34":1,"64":1,"90":1,"108":1,"109":1,"208":1,"372":1,"487":1,"505":1,"542":1,"577":1,"609":1}}],["provide",{"0":{"641":1},"2":{"18":1,"26":1,"31":1,"35":1,"40":1,"41":1,"67":1,"68":2,"104":1,"111":1,"139":1,"140":1,"141":1,"145":1,"174":1,"175":2,"273":1,"294":1,"310":1,"343":1,"352":1,"373":1,"449":1,"494":1,"495":2,"499":1,"506":1,"507":2,"513":1,"536":1,"564":1,"622":2,"634":1,"639":2,"640":2,"642":1,"646":2,"674":1,"745":1}}],["providing",{"0":{"648":1},"2":{"12":1,"35":1,"44":1,"49":1,"59":1,"112":1,"199":1,"249":1,"584":1,"726":1,"762":1}}],["provers",{"2":{"205":1,"206":1,"586":1}}],["prover=network",{"2":{"586":1}}],["prover=local",{"2":{"586":1}}],["prover=",{"2":{"202":2}}],["prover",{"0":{"205":1,"207":1,"211":1},"2":{"202":7,"205":1,"206":2,"207":3,"208":2,"211":7,"212":1,"228":1,"586":1}}],["proven",{"2":{"180":1,"187":1,"216":1,"233":1}}],["proveshars`",{"2":{"163":2}}],["provesharesv2`",{"2":{"163":2}}],["provesharesv2",{"2":{"153":1}}],["proveshares",{"2":{"149":1,"151":1,"153":3,"163":2,"175":1}}],["proves",{"2":{"156":2,"221":1}}],["prove=true",{"2":{"147":1}}],["proved",{"2":{"127":1}}],["prove",{"2":{"121":1,"125":3,"128":1,"130":1,"137":1,"139":5,"141":1,"145":1,"147":1,"152":3,"154":2,"157":1,"159":1,"164":1,"165":1,"168":5,"174":2,"175":6,"178":1,"183":1,"188":1,"191":1,"211":3,"227":1,"580":1,"646":1,"651":1}}],["proofnonce",{"2":{"144":4,"161":2,"163":2}}],["proof",{"0":{"121":1,"137":1,"141":1,"145":1,"146":1,"149":1,"151":1,"161":1,"168":1,"173":1,"212":1,"676":1,"691":1},"1":{"138":1,"139":1,"142":1,"143":1,"147":1,"148":1,"150":1,"152":1,"153":1},"2":{"110":1,"118":12,"119":2,"120":1,"121":1,"122":5,"124":1,"127":5,"130":2,"132":1,"139":2,"140":1,"141":4,"142":4,"143":2,"144":14,"145":3,"146":1,"147":9,"148":2,"149":1,"151":5,"152":3,"154":9,"155":1,"156":12,"158":1,"159":14,"160":11,"163":40,"164":2,"168":6,"169":1,"170":1,"173":1,"174":6,"175":11,"179":1,"182":1,"183":3,"187":3,"188":2,"191":3,"194":5,"197":1,"199":3,"202":4,"205":1,"206":1,"208":2,"210":2,"211":1,"214":3,"216":1,"217":1,"218":2,"219":3,"224":1,"227":4,"238":1,"281":1,"583":3,"634":2,"643":1,"646":1,"652":1,"653":1,"676":3,"683":1,"691":2}}],["proofs",{"0":{"122":1,"135":1,"154":1,"169":1,"194":1,"195":1,"196":1,"218":1,"219":1,"645":1},"1":{"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"154":1,"155":2,"156":2,"157":2,"158":2,"159":2,"160":2,"161":2,"162":2,"163":2,"164":1,"195":1,"196":1},"2":{"110":1,"121":1,"122":2,"127":1,"136":1,"137":1,"139":1,"140":1,"145":1,"147":6,"151":4,"152":4,"154":4,"156":8,"159":10,"162":1,"163":15,"164":1,"168":9,"169":5,"171":1,"174":1,"175":5,"176":1,"178":1,"179":3,"180":1,"182":2,"183":4,"185":1,"186":1,"190":1,"191":1,"194":3,"196":1,"202":1,"203":1,"205":1,"206":3,"208":1,"211":6,"212":1,"213":2,"215":3,"216":1,"217":2,"221":1,"227":2,"229":1,"233":2,"234":1,"235":1,"236":1,"415":2,"427":1,"583":1,"633":1,"634":1,"643":1,"645":2,"646":1,"649":1,"652":1}}],["procedure",{"2":{"252":1,"739":1}}],["proceeding",{"2":{"87":1,"130":1,"428":1}}],["proceed",{"2":{"79":1,"86":2,"164":1,"191":1,"194":1,"448":1,"667":1,"697":1}}],["processing",{"2":{"584":1}}],["processed",{"2":{"579":1,"609":1}}],["processes",{"2":{"238":1,"427":1,"602":1,"604":1,"610":1,"640":1,"774":2}}],["process",{"0":{"19":1,"21":1,"28":1,"526":1,"528":1,"602":1},"1":{"20":1,"21":1,"22":1,"23":1,"24":1,"527":1,"528":1,"529":2,"530":2,"531":2,"532":2,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1},"2":{"21":1,"30":1,"41":1,"73":1,"81":1,"86":1,"112":1,"127":1,"130":3,"162":2,"186":1,"187":1,"227":1,"238":3,"248":1,"255":1,"321":1,"329":1,"373":1,"404":1,"425":1,"455":1,"470":1,"484":1,"500":1,"515":1,"525":1,"526":1,"528":1,"556":1,"579":1,"603":1,"608":1,"621":1,"634":1,"649":1,"697":1,"765":1,"775":2}}],["proto",{"2":{"163":2,"599":2}}],["protobuf",{"0":{"191":1},"2":{"140":4,"169":2,"170":1,"171":1,"183":2,"190":1,"191":2,"193":1,"194":2}}],["protocol",{"2":{"23":1,"37":1,"107":1,"126":1,"227":1,"233":1,"313":1,"320":1,"326":1,"427":1,"527":2,"528":1,"530":2,"590":1,"676":1,"681":1,"709":1,"778":1}}],["protection",{"2":{"726":1}}],["protect",{"2":{"24":1,"91":1,"726":1}}],["prohibited",{"2":{"23":1,"328":1}}],["prometheuslistenaddr",{"2":{"274":2}}],["prometheus",{"2":{"274":9,"275":17,"276":1,"321":1,"428":1}}],["prompts",{"2":{"776":1}}],["promptanswer",{"2":{"775":2}}],["prompting",{"0":{"774":1},"2":{"775":1}}],["prompt",{"0":{"765":1,"769":1},"1":{"766":1,"767":1,"768":1,"769":1,"770":2,"771":2,"772":2,"773":2,"774":2,"775":2,"776":1},"2":{"87":1,"729":1,"765":1,"770":2,"771":2,"772":8,"773":13,"774":2,"775":14}}],["prompted",{"2":{"85":1,"263":2,"558":1,"622":1}}],["promptly",{"2":{"10":1,"109":1}}],["prominent",{"2":{"58":1}}],["promote",{"2":{"36":1,"39":2,"40":3,"58":1,"584":1}}],["promotions",{"2":{"31":1}}],["promotional",{"2":{"30":1,"31":1}}],["promoting",{"2":{"18":1}}],["profileecho",{"2":{"399":1}}],["profile",{"2":{"399":3}}],["proficient",{"2":{"18":1}}],["professionals",{"2":{"40":1}}],["professional",{"2":{"7":1,"674":2}}],["primitive",{"2":{"631":1,"650":1}}],["primitives",{"2":{"629":1}}],["primarily",{"2":{"86":2,"724":1}}],["primary",{"2":{"18":1,"49":1,"112":1,"322":1}}],["priv",{"2":{"627":1}}],["privacy",{"2":{"10":1,"58":1}}],["privatecelestia",{"2":{"744":1}}],["privatekey",{"2":{"546":10}}],["private",{"0":{"744":1},"2":{"7":2,"12":1,"14":1,"26":1,"34":1,"86":2,"88":1,"93":2,"118":4,"202":10,"203":4,"204":8,"210":4,"211":2,"260":2,"263":4,"279":2,"289":1,"294":6,"328":1,"336":4,"584":1,"701":1,"744":7}}],["pricing",{"2":{"226":1}}],["priced",{"2":{"589":1}}],["price",{"0":{"748":1},"2":{"91":3,"429":8,"588":1,"590":4,"592":3,"599":2,"671":1,"710":3,"748":10,"773":2,"779":3}}],["prices",{"2":{"7":1,"589":1}}],["printf",{"2":{"598":4,"710":4,"711":2,"712":4,"773":6,"775":4}}],["printed",{"2":{"202":1,"210":1}}],["println",{"2":{"143":8,"144":6,"162":2,"163":2,"599":6,"779":2,"780":2}}],["print",{"2":{"30":1,"260":2}}],["priority",{"2":{"754":4}}],["prioritised",{"2":{"671":2}}],["prioritized",{"2":{"589":2}}],["prior",{"2":{"25":1,"30":1,"39":1,"279":2,"526":1}}],["pr",{"2":{"2":1}}],["n11",{"2":{"646":2}}],["n12",{"2":{"646":2}}],["n14",{"2":{"646":1}}],["n7",{"2":{"646":1}}],["n8",{"2":{"646":1}}],["n2",{"2":{"644":1,"645":1,"646":1}}],["nft",{"2":{"635":1}}],["nfts",{"2":{"37":1}}],["nsoy0rgl7hqt4vwlg441gqkjsz2fbunzxipgns8ov",{"2":{"707":2}}],["ns",{"2":{"599":6,"773":2}}],["nc",{"2":{"473":1}}],["ncdu",{"2":{"398":4}}],["ncreated",{"2":{"383":2,"627":2}}],["ntfs",{"2":{"396":1}}],["npanic",{"2":{"383":2,"627":2}}],["np5wre24w+e79",{"2":{"147":2}}],["ngithub",{"2":{"383":12,"627":12}}],["nruntime",{"2":{"383":2,"627":2}}],["nw",{"2":{"280":1}}],["n",{"2":{"271":2,"294":2,"313":1,"326":1,"338":2,"361":12,"383":20,"598":4,"622":2,"627":20,"636":1,"644":1,"645":2,"710":4,"711":2,"712":4,"773":6,"775":4}}],["nvme",{"2":{"239":1,"416":1,"535":2}}],["nyzlbfjjnskofrzur8xvjijla+wbptwm0kbyglilxlg=",{"2":{"142":2}}],["nmbwwwhpiphwagai7maqm",{"2":{"142":2}}],["nmts",{"0":{"646":1},"2":{"642":2,"646":2,"651":1,"733":1}}],["nmtproof",{"2":{"156":2,"163":2}}],["nmt",{"2":{"139":2,"151":2,"154":2,"646":2,"779":2}}],["nidstring",{"2":{"773":4}}],["nil",{"2":{"128":10,"130":6,"136":6,"143":6,"144":36,"148":4,"150":8,"153":2,"161":14,"162":12,"163":12,"598":12,"599":16,"710":12,"711":8,"712":10,"713":8,"772":2,"773":22,"774":4,"775":10}}],["nitro",{"0":{"112":1},"2":{"92":1,"96":4,"104":4,"107":1,"108":2,"109":3,"110":2,"112":2,"400":1}}],["nice",{"2":{"34":1}}],["null",{"2":{"294":4,"295":2,"297":4,"380":1,"604":2,"606":2,"607":2,"608":2,"616":2,"622":2}}],["nutshell",{"2":{"139":1}}],["numerous",{"2":{"630":1,"649":1}}],["numerator",{"2":{"429":4}}],["num",{"2":{"429":4}}],["numleaves",{"2":{"159":3,"175":2}}],["numia",{"2":{"64":4,"487":4,"489":1,"490":1,"491":1,"495":1,"505":4,"507":1,"508":1,"510":1}}],["number=26656",{"2":{"452":1}}],["number=26656ip",{"2":{"452":1}}],["numbers",{"0":{"62":1,"483":1,"503":1}}],["number",{"2":{"30":1,"36":1,"86":2,"93":8,"159":2,"165":1,"172":1,"174":2,"210":1,"221":1,"274":4,"276":1,"295":2,"296":2,"337":1,"452":2,"485":1,"528":1,"530":1,"538":2,"583":1,"591":3,"592":1,"594":1,"599":2,"633":1,"644":1,"650":2,"652":2}}],["nurturing",{"2":{"47":1}}],["never",{"2":{"559":10}}],["neither",{"2":{"331":1,"648":1}}],["necessitate",{"2":{"321":1}}],["necessity",{"2":{"320":1}}],["necessary",{"0":{"634":1},"2":{"24":1,"30":1,"34":3,"88":1,"90":1,"109":2,"110":1,"154":4,"160":2,"174":1,"183":1,"210":3,"225":1,"378":1,"398":1,"429":1,"542":1,"583":1,"609":1,"622":2,"633":1,"648":1,"652":1,"741":1}}],["netcat",{"2":{"473":1}}],["netcelestia",{"2":{"466":1,"737":1}}],["net",{"2":{"291":2,"466":1,"489":2,"490":2,"491":2,"492":1,"495":2,"498":1,"499":1,"507":1,"508":1,"509":1,"510":1,"514":1,"737":1}}],["network=$network",{"2":{"390":6,"392":6,"393":6}}],["network=arabica",{"2":{"390":1,"518":2}}],["network=arabicaexport",{"2":{"390":1}}],["network=mochacelestia",{"2":{"408":1}}],["network=mocha",{"2":{"390":1,"408":1,"706":2}}],["network=mochaexport",{"2":{"390":1}}],["network=celestia",{"2":{"390":1}}],["network=celestiaexport",{"2":{"390":1}}],["network=custom",{"2":{"314":2}}],["network=",{"2":{"314":2}}],["networking",{"2":{"31":1,"35":1,"42":2}}],["networks",{"0":{"314":1,"361":1,"548":1},"1":{"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"555":1,"556":1},"2":{"26":1,"86":1,"126":1,"272":1,"324":1,"325":1,"328":1,"361":9,"371":2,"427":1,"432":1,"434":1,"452":1,"459":1,"467":1,"495":1,"501":1,"526":1,"533":1,"573":1,"622":1,"623":1,"642":1,"691":1,"783":1}}],["network",{"0":{"60":1,"61":1,"73":1,"272":1,"324":1,"375":1,"439":1,"453":1,"481":1,"482":1,"484":1,"500":1,"502":1,"515":1,"526":1,"527":1,"530":1,"532":1,"556":1,"657":1,"679":1,"744":1,"784":1},"1":{"62":1,"325":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"485":1,"527":1,"528":1,"529":1,"530":1,"531":1,"532":1},"2":{"18":2,"24":1,"37":1,"38":1,"60":1,"63":1,"67":1,"68":3,"73":3,"81":1,"85":2,"86":2,"90":3,"91":4,"93":6,"104":2,"126":1,"130":2,"140":2,"154":2,"227":1,"231":1,"238":5,"244":4,"245":9,"246":4,"248":1,"272":1,"280":1,"281":1,"282":1,"284":1,"289":1,"303":2,"304":1,"311":2,"314":8,"316":4,"318":2,"319":2,"320":8,"322":1,"324":10,"325":6,"328":2,"329":6,"334":8,"335":6,"336":10,"338":10,"341":1,"352":1,"361":1,"371":1,"373":1,"377":2,"383":3,"390":7,"392":6,"393":6,"399":1,"407":2,"421":4,"422":5,"423":4,"439":1,"445":1,"449":1,"454":1,"455":1,"458":1,"464":4,"465":6,"466":12,"468":4,"477":4,"478":4,"480":2,"481":2,"484":1,"486":1,"494":1,"495":2,"500":3,"501":2,"506":1,"507":1,"508":1,"511":1,"515":3,"523":2,"526":6,"527":2,"530":1,"532":3,"533":4,"546":1,"549":2,"554":2,"556":3,"557":1,"559":4,"561":6,"564":3,"565":1,"567":2,"571":1,"580":1,"583":1,"586":1,"598":4,"609":2,"612":1,"617":2,"621":1,"622":2,"627":4,"629":1,"638":1,"643":1,"644":1,"648":1,"649":3,"650":2,"652":4,"653":1,"657":1,"661":1,"667":1,"673":2,"674":3,"676":1,"679":1,"683":3,"689":2,"691":2,"692":1,"700":20,"701":12,"702":12,"706":3,"707":3,"710":4,"715":1,"728":1,"732":1,"736":4,"737":8,"738":13,"742":8,"744":8,"745":2,"762":3,"767":4,"771":2,"772":2,"773":10,"775":2,"779":4,"783":1,"784":4}}],["nearby",{"2":{"39":1}}],["needing",{"2":{"180":1,"294":1,"302":1,"303":1,"631":1,"642":1,"674":1}}],["need",{"2":{"41":1,"57":1,"67":1,"68":1,"84":1,"86":1,"88":1,"91":2,"109":2,"110":1,"126":5,"127":1,"136":1,"141":1,"142":1,"145":1,"147":1,"152":1,"168":1,"170":1,"175":2,"180":1,"183":2,"185":1,"187":1,"190":2,"193":1,"194":1,"201":1,"202":1,"208":1,"235":2,"245":2,"247":1,"275":4,"279":2,"290":1,"299":1,"301":2,"304":1,"307":1,"313":2,"316":1,"320":1,"325":1,"326":2,"328":1,"329":1,"337":1,"338":1,"352":1,"353":1,"363":1,"371":2,"373":1,"377":1,"378":1,"380":1,"383":1,"391":2,"392":1,"404":1,"405":1,"406":1,"422":2,"424":1,"430":2,"434":1,"435":1,"440":1,"441":1,"442":1,"446":1,"448":1,"449":1,"466":1,"469":1,"494":1,"495":1,"506":1,"507":1,"525":1,"526":1,"530":1,"545":1,"546":1,"554":1,"558":1,"560":1,"582":2,"583":1,"586":2,"616":1,"622":1,"627":1,"634":1,"644":1,"645":1,"674":1,"690":1,"699":1,"700":1,"706":1,"709":1,"738":2,"739":1,"740":1,"741":1,"742":1,"744":1,"762":1,"771":1,"772":2,"773":2,"774":1,"778":1,"784":2}}],["needs",{"2":{"38":1,"41":1,"42":1,"166":1,"168":1,"183":1,"199":1,"217":1,"234":1,"544":1,"583":1,"636":1,"646":1}}],["needed",{"2":{"30":1,"31":1,"34":1,"37":1,"88":1,"91":1,"109":1,"125":1,"136":1,"154":2,"160":2,"175":2,"210":1,"215":2,"275":1,"278":1,"350":1,"355":1,"373":1,"591":1,"592":1,"607":1,"622":1,"633":1,"634":1,"635":1,"648":1,"766":1,"768":1,"773":1}}],["negatives",{"2":{"652":1}}],["negatively",{"2":{"26":1,"38":1}}],["negotiate",{"2":{"34":1}}],["nextheaderfunctionid",{"2":{"218":1}}],["nextheight",{"2":{"130":4}}],["next",{"0":{"113":1,"259":1,"289":1,"344":1,"457":1,"573":1,"776":1},"2":{"32":1,"85":2,"86":1,"90":1,"94":1,"108":1,"109":1,"113":1,"122":1,"130":2,"142":1,"144":2,"147":1,"152":1,"161":2,"171":1,"202":1,"204":2,"210":4,"211":5,"215":2,"218":1,"229":1,"272":1,"275":1,"286":1,"297":6,"329":1,"446":1,"527":1,"573":1,"601":1,"650":1,"651":2,"706":1,"738":1,"745":1,"754":2,"772":2,"773":7,"775":2,"780":2}}],["newsubmitoptions",{"2":{"710":4}}],["newsletters",{"2":{"32":1}}],["newcredentials",{"2":{"599":2}}],["newclient",{"2":{"598":2,"710":2,"711":2,"712":2,"713":2,"772":2,"773":2,"774":2,"775":2}}],["newblob",{"2":{"599":2}}],["newblobv0",{"2":{"598":2,"710":3,"773":2}}],["newblobnamespacev0",{"2":{"598":2,"710":3,"711":2,"712":2,"773":2}}],["newblobstreamxfilterer",{"2":{"162":2}}],["newblobstreamx",{"2":{"144":2,"161":2}}],["newer",{"2":{"266":1}}],["newwrappers",{"2":{"163":2}}],["newint",{"2":{"144":8,"156":4,"159":4,"160":8,"163":16}}],["newly",{"2":{"93":1,"435":1,"630":1}}],["newmetric",{"2":{"64":2,"487":2,"490":1,"491":1,"505":2,"507":1,"508":1,"510":1}}],["new",{"0":{"162":1,"200":1,"202":1,"272":1,"291":1,"434":1,"446":1,"449":1,"523":1,"585":1,"690":1,"711":1,"712":1,"780":1},"1":{"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"586":1},"2":{"2":2,"22":2,"23":2,"25":1,"36":1,"37":1,"41":3,"42":1,"90":1,"125":1,"136":2,"143":2,"144":4,"152":1,"153":1,"161":2,"162":3,"163":2,"200":1,"201":1,"208":1,"212":1,"227":2,"228":1,"247":1,"262":2,"275":1,"281":1,"289":1,"299":1,"329":1,"334":2,"352":1,"361":1,"379":1,"380":1,"381":1,"383":1,"424":1,"427":1,"432":3,"433":1,"434":3,"435":1,"439":2,"444":1,"446":1,"449":1,"450":1,"453":1,"459":1,"469":1,"478":1,"522":1,"526":1,"528":3,"530":2,"552":1,"559":3,"582":2,"583":2,"584":1,"585":1,"586":1,"594":1,"609":1,"627":1,"629":2,"630":1,"631":2,"637":1,"650":1,"656":1,"672":1,"674":2,"711":4,"712":11,"765":1,"767":2,"770":1,"773":4,"774":1,"776":1,"779":8,"780":9,"781":2,"785":3,"786":1}}],["novel",{"2":{"642":1}}],["nor",{"2":{"331":1,"648":1}}],["normal",{"2":{"130":3,"164":1,"371":1,"591":1,"629":1}}],["normally",{"2":{"34":1}}],["now",{"2":{"87":1,"91":2,"94":1,"109":1,"163":2,"202":1,"204":1,"205":1,"211":1,"215":1,"259":1,"275":1,"289":2,"297":1,"344":1,"384":1,"390":1,"391":1,"393":1,"406":2,"408":1,"425":1,"429":1,"430":1,"434":1,"435":1,"450":1,"452":1,"453":1,"455":1,"457":1,"495":1,"525":1,"538":1,"539":2,"547":1,"563":1,"564":1,"607":1,"608":1,"622":3,"638":1,"673":1,"706":1,"707":1,"736":1,"737":1,"754":1,"767":2,"773":4,"775":4,"784":1,"785":1,"786":1}}],["none",{"2":{"177":1,"181":1,"189":1,"192":1,"195":1,"434":4,"741":1}}],["nonce",{"2":{"118":4,"120":1,"144":4,"154":4,"160":10,"161":2,"163":6,"400":1,"538":2,"539":2,"594":2,"599":2}}],["non",{"2":{"23":1,"27":1,"109":2,"127":1,"294":2,"328":1,"438":1,"526":2,"530":1,"546":1,"679":1,"743":1}}],["no",{"0":{"640":1},"2":{"13":1,"14":1,"22":1,"34":1,"68":1,"69":1,"117":2,"171":1,"186":1,"250":1,"266":5,"277":1,"325":2,"333":3,"355":1,"403":1,"495":1,"512":1,"582":1,"588":1,"590":1,"629":1,"645":1,"652":1,"690":1,"695":1,"728":1,"748":1}}],["notfound",{"2":{"764":2}}],["notable",{"0":{"722":1},"2":{"633":1}}],["notably",{"2":{"591":1}}],["nothing",{"2":{"367":3}}],["notify",{"2":{"459":1}}],["notification",{"2":{"80":1}}],["notice",{"2":{"154":4,"156":6,"157":2,"159":2,"160":4,"295":1,"296":1,"536":1,"648":1,"745":1}}],["noted",{"2":{"443":1,"722":1}}],["notes",{"0":{"304":1,"611":1,"717":1},"1":{"718":1,"719":1,"720":1,"721":1,"722":1},"2":{"48":1,"369":1,"530":1,"673":1}}],["note",{"0":{"378":1},"2":{"26":1,"47":1,"70":1,"91":2,"104":1,"105":1,"110":1,"117":1,"125":1,"126":3,"128":1,"130":2,"140":1,"142":1,"147":1,"151":1,"152":1,"163":2,"164":1,"166":1,"168":1,"172":1,"174":1,"204":1,"214":1,"215":1,"216":1,"218":1,"221":1,"227":1,"233":2,"234":1,"245":1,"266":1,"275":1,"279":2,"283":1,"287":1,"294":1,"302":1,"307":1,"316":1,"324":2,"331":1,"337":1,"343":1,"367":1,"387":1,"407":1,"422":1,"430":1,"449":1,"452":1,"485":1,"512":1,"541":1,"560":1,"586":1,"591":2,"599":2,"607":1,"646":1,"649":1,"651":2,"652":1,"682":1,"700":1,"737":1,"740":1}}],["not",{"2":{"7":1,"8":1,"22":1,"23":7,"26":1,"34":1,"35":2,"58":1,"59":1,"65":1,"68":2,"69":1,"86":2,"90":2,"91":1,"93":2,"96":1,"110":1,"112":1,"117":1,"124":2,"127":1,"128":1,"144":2,"145":1,"163":2,"168":1,"173":1,"174":1,"178":1,"179":1,"180":1,"183":2,"193":1,"199":1,"201":1,"202":3,"208":1,"210":5,"211":2,"215":2,"227":1,"234":1,"244":1,"245":1,"266":1,"275":1,"281":1,"287":1,"304":1,"307":1,"314":1,"322":6,"324":1,"325":1,"334":1,"338":1,"343":1,"355":2,"368":1,"371":1,"378":1,"381":2,"383":1,"396":1,"399":1,"400":1,"407":2,"408":2,"409":1,"414":1,"422":1,"426":1,"430":1,"487":1,"489":1,"495":1,"505":1,"507":1,"509":1,"512":1,"526":1,"530":2,"533":1,"552":1,"560":1,"590":3,"591":1,"592":1,"594":3,"599":2,"609":3,"610":1,"611":1,"617":2,"627":1,"633":1,"634":1,"639":1,"645":2,"651":1,"652":2,"672":1,"673":2,"674":2,"679":1,"700":2,"706":1,"708":1,"719":1,"720":1,"722":1,"733":1,"735":1,"737":1,"738":1,"739":1,"742":3,"748":1,"764":2,"774":2,"777":1}}],["nodeclient",{"2":{"772":2,"773":4,"775":2}}],["nodeconfig",{"2":{"88":1,"89":1,"90":1,"91":1,"104":2}}],["nodeip",{"2":{"772":4,"773":4,"775":6}}],["nodebuilder",{"2":{"334":6}}],["nodessection",{"2":{"625":1}}],["nodestake",{"2":{"489":1,"490":1,"491":1,"498":1,"514":1}}],["nodes",{"0":{"66":1,"238":1,"374":1,"386":1,"415":1,"459":1,"488":1,"493":1,"504":1,"533":1,"535":1,"536":1,"603":1,"605":1,"631":1},"1":{"67":1,"68":1,"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"489":1,"490":1,"491":1,"492":1,"494":1,"495":1,"496":1,"497":1,"505":1,"506":1,"507":1,"534":1,"535":1,"536":1,"604":1,"606":1,"607":1,"608":1},"2":{"54":1,"65":3,"67":1,"68":2,"87":1,"121":1,"125":2,"126":1,"147":2,"152":2,"156":8,"159":2,"163":4,"179":1,"183":1,"237":1,"238":4,"275":2,"310":1,"313":3,"321":1,"322":3,"326":3,"328":1,"335":1,"339":1,"352":1,"353":1,"355":2,"356":1,"361":3,"376":1,"384":1,"397":1,"406":1,"415":5,"451":2,"459":3,"474":1,"486":1,"489":1,"490":1,"491":1,"494":1,"495":4,"496":3,"501":1,"506":1,"507":2,"508":3,"509":2,"510":2,"511":1,"528":1,"554":1,"583":2,"594":1,"607":1,"612":1,"617":1,"629":1,"630":1,"631":2,"632":2,"633":5,"634":5,"636":1,"641":1,"642":1,"643":6,"644":6,"645":3,"646":3,"648":1,"649":3,"650":2,"652":5,"672":1,"673":8,"674":12,"716":1,"724":1,"728":1,"736":1}}],["node",{"0":{"54":1,"67":1,"91":1,"92":1,"102":1,"104":1,"105":1,"129":1,"133":1,"237":1,"240":1,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"276":1,"302":1,"315":1,"322":1,"327":1,"338":1,"340":1,"356":1,"358":1,"363":2,"373":1,"379":1,"384":1,"385":1,"387":1,"391":1,"392":1,"393":1,"405":1,"406":1,"408":1,"414":1,"417":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"452":1,"458":1,"461":1,"462":1,"463":1,"464":1,"465":1,"468":1,"469":1,"470":1,"476":1,"477":1,"478":1,"494":1,"506":1,"511":1,"518":1,"534":1,"544":1,"558":1,"559":1,"561":1,"562":1,"563":1,"571":1,"596":1,"597":2,"598":1,"599":1,"600":1,"602":1,"606":1,"607":1,"608":1,"612":1,"614":1,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"673":1,"697":1,"700":1,"701":1,"702":1,"706":1,"723":1,"730":1,"736":1,"743":1,"752":1,"767":2},"1":{"103":1,"104":1,"105":1,"130":1,"131":1,"132":1,"133":1,"134":1,"238":1,"239":1,"240":1,"241":2,"242":1,"243":2,"244":2,"245":2,"246":3,"247":3,"248":2,"316":1,"317":1,"318":1,"319":1,"320":1,"321":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"339":1,"341":1,"342":1,"343":1,"344":1,"345":1,"357":1,"358":1,"359":2,"360":2,"361":2,"362":1,"363":1,"364":3,"365":3,"366":1,"367":1,"368":1,"369":1,"370":1,"371":1,"372":1,"373":1,"374":1,"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"382":1,"383":1,"385":1,"386":2,"387":1,"392":1,"393":1,"406":1,"407":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":2,"421":3,"422":3,"423":2,"424":3,"425":2,"426":2,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":2,"467":2,"468":2,"469":3,"470":2,"471":1,"559":1,"560":2,"561":1,"563":1,"564":1,"565":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1,"613":1,"614":1,"615":2,"616":2,"617":1,"618":2,"619":2,"620":2,"621":3,"622":1,"623":1,"624":1,"625":1,"626":1,"627":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"707":1,"724":1,"725":1,"726":1,"727":1,"728":1,"729":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":1,"741":1,"742":1,"743":1,"744":2,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1},"2":{"3":2,"23":2,"24":1,"26":2,"27":1,"42":1,"54":6,"63":3,"65":3,"67":2,"68":7,"82":1,"87":1,"88":1,"90":4,"91":10,"92":1,"93":1,"94":1,"96":3,"104":3,"105":3,"109":6,"110":1,"112":1,"126":13,"130":1,"133":1,"136":5,"137":1,"156":16,"163":12,"168":1,"237":1,"238":4,"239":1,"243":3,"244":4,"245":8,"246":2,"247":3,"248":2,"260":4,"265":12,"271":6,"274":1,"275":1,"276":1,"277":1,"279":4,"280":1,"286":3,"287":2,"298":1,"299":1,"301":3,"302":2,"303":3,"307":1,"309":1,"311":1,"312":1,"313":5,"314":6,"315":4,"316":6,"317":2,"318":2,"319":2,"320":4,"321":3,"322":11,"324":5,"325":1,"326":5,"328":7,"329":26,"331":4,"332":3,"333":1,"334":6,"335":2,"336":6,"337":1,"338":5,"341":17,"342":3,"343":7,"344":6,"345":1,"347":1,"349":4,"350":1,"352":1,"355":7,"356":1,"357":1,"361":10,"363":3,"367":1,"369":1,"370":1,"371":3,"372":2,"373":2,"376":1,"378":1,"380":1,"383":2,"385":2,"386":2,"387":3,"388":7,"390":30,"391":5,"392":27,"393":30,"396":1,"398":1,"399":2,"402":1,"403":3,"404":6,"405":1,"406":2,"407":1,"408":3,"409":2,"412":3,"413":2,"414":3,"416":1,"419":1,"422":12,"423":2,"424":3,"425":2,"426":2,"429":4,"445":1,"449":1,"452":7,"453":2,"455":2,"458":1,"460":1,"461":1,"463":1,"464":2,"465":6,"466":9,"468":2,"469":3,"470":1,"471":1,"472":3,"473":1,"476":3,"477":7,"478":9,"479":10,"481":1,"485":1,"486":3,"487":1,"488":2,"493":3,"494":2,"495":5,"501":10,"505":1,"506":2,"507":4,"508":1,"509":1,"510":1,"511":4,"517":2,"518":3,"523":2,"524":1,"526":1,"533":11,"535":4,"536":2,"540":2,"543":1,"544":4,"557":2,"558":7,"559":6,"560":3,"561":12,"563":2,"565":1,"566":1,"567":1,"568":3,"569":1,"570":1,"571":7,"573":1,"583":1,"590":3,"593":1,"597":1,"598":3,"599":6,"600":1,"603":1,"604":1,"606":2,"607":4,"608":6,"609":1,"612":1,"613":1,"614":1,"617":5,"618":1,"619":2,"621":2,"622":2,"623":2,"625":1,"627":5,"629":3,"632":2,"633":4,"635":1,"643":1,"644":2,"646":1,"652":8,"673":3,"674":3,"681":1,"697":1,"698":2,"699":5,"700":10,"701":6,"702":6,"705":1,"706":15,"707":9,"708":1,"709":3,"710":3,"719":2,"722":1,"723":2,"724":1,"725":1,"726":1,"727":2,"730":1,"733":1,"734":1,"735":1,"736":4,"737":3,"738":9,"739":2,"740":7,"741":6,"742":6,"743":10,"744":8,"745":7,"747":3,"750":2,"751":1,"752":2,"753":1,"758":3,"762":7,"765":2,"766":1,"767":8,"771":2,"772":3,"773":2,"776":1,"777":1,"778":3,"779":1}}],["navigating",{"2":{"208":1}}],["navigate",{"2":{"90":1,"476":1,"601":1,"656":1,"661":1,"665":1}}],["named",{"2":{"311":1,"312":1,"342":1,"517":1,"544":1}}],["name=$",{"2":{"372":6}}],["name=",{"2":{"279":2}}],["name=validator",{"2":{"272":2,"446":2}}],["name=validator1",{"2":{"272":2,"445":2}}],["namekey",{"2":{"272":1}}],["namevalidator",{"2":{"272":1}}],["names",{"2":{"215":1,"706":2,"707":2}}],["namespacebytes",{"2":{"773":2}}],["namespacehex",{"2":{"772":2,"773":4,"775":4}}],["namespaced",{"0":{"646":1},"2":{"642":1,"646":1,"648":1,"651":3,"733":1}}],["namespaceid",{"2":{"157":5,"163":8,"773":14,"775":8}}],["namespacenode",{"2":{"154":2,"156":12,"158":4,"163":10}}],["namespacemerklemultiproof",{"2":{"154":2,"156":10,"163":6}}],["namespaces",{"0":{"733":1},"2":{"147":2,"174":1,"564":1,"646":3,"651":1,"673":1,"674":1,"710":2,"733":1,"779":2}}],["namespace",{"0":{"157":1},"2":{"91":8,"93":1,"109":2,"125":8,"128":4,"139":2,"145":2,"147":4,"152":4,"154":6,"156":31,"157":21,"163":16,"175":2,"250":1,"274":4,"331":1,"332":2,"540":1,"564":5,"565":7,"596":2,"597":2,"598":10,"599":6,"601":2,"646":6,"651":5,"670":3,"674":1,"710":11,"711":6,"712":11,"730":1,"745":7,"747":12,"755":2,"760":3,"762":2,"771":2,"772":6,"773":23,"775":10,"776":2,"779":16,"780":13}}],["name",{"0":{"518":1,"519":1,"520":1},"1":{"520":1,"521":1},"2":{"26":1,"30":1,"77":1,"86":2,"202":2,"211":2,"246":7,"262":8,"263":4,"272":8,"275":6,"291":2,"292":4,"308":2,"314":2,"361":7,"372":6,"391":2,"423":7,"429":4,"445":4,"446":4,"447":4,"449":3,"466":2,"468":7,"517":1,"518":1,"520":3,"559":2,"564":1,"583":1,"616":2,"622":2,"700":7,"701":6,"702":6,"706":2,"707":2,"738":8,"767":2,"785":1,"786":1}}],["naming",{"2":{"2":1,"41":3}}],["natural",{"2":{"639":1}}],["nature",{"2":{"12":1,"226":1,"267":1,"638":1,"642":1}}],["natively",{"2":{"86":1}}],["native",{"2":{"82":1,"84":1,"93":6,"95":1,"108":1,"430":1,"437":1,"438":1,"653":1,"689":1,"695":1,"785":1}}],["nationality",{"2":{"6":1}}],["natnet",{"2":{"57":1}}],["nat",{"2":{"30":1,"378":1}}],["icon",{"2":{"786":1}}],["icons",{"2":{"52":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=celestia",{"2":{"747":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=",{"2":{"745":2,"747":11,"748":2}}],["ignore",{"2":{"646":1}}],["ignition",{"2":{"214":16}}],["ibctransfer",{"2":{"717":1}}],["ibchost",{"2":{"717":1}}],["ibc",{"0":{"427":1},"1":{"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"427":3,"428":2,"429":4,"434":1,"437":4}}],["i++",{"2":{"128":2}}],["illustrate",{"2":{"124":1}}],["illustrations",{"2":{"52":1}}],["i",{"0":{"199":1},"2":{"119":1,"128":6,"144":4,"156":4,"158":4,"159":4,"160":5,"163":32,"174":2,"175":1,"187":1,"206":1,"217":1,"325":1,"361":10,"377":2,"378":2,"455":1,"459":1,"594":1,"643":3,"644":1,"645":4,"646":3,"648":2,"649":6,"651":3,"652":8}}],["io",{"2":{"72":1,"93":2,"156":2,"157":2,"280":1,"372":12,"390":6,"392":6,"393":6,"489":1,"490":1,"491":1,"498":3,"499":1,"508":1,"509":1,"510":1,"514":3,"684":1,"706":2,"773":2,"786":1}}],["ip=",{"2":{"607":2}}],["ip=consensus",{"2":{"518":2}}],["ip6",{"2":{"478":4,"752":4}}],["ip4",{"2":{"314":4,"478":13,"607":2,"752":8}}],["ip",{"2":{"65":1,"67":2,"68":6,"91":2,"244":11,"245":6,"246":6,"314":2,"316":2,"317":2,"318":2,"319":2,"320":4,"324":2,"329":2,"334":2,"338":2,"377":2,"390":6,"393":6,"407":2,"408":2,"422":3,"423":6,"451":4,"465":7,"466":6,"468":6,"477":4,"478":4,"494":2,"495":4,"506":2,"507":2,"561":3,"607":2,"608":2,"619":2,"706":2,"707":2,"737":14,"738":6,"762":2,"767":2,"772":2,"773":2,"775":2}}],["idvalidator",{"2":{"445":1}}],["id=$",{"2":{"452":2}}],["id=",{"2":{"279":2,"616":2,"622":2}}],["id=testnet",{"2":{"272":2,"445":2}}],["ids",{"2":{"204":1,"210":2,"314":1,"325":1}}],["idaoracle",{"2":{"117":1,"118":6,"120":1,"122":1,"163":6}}],["ide",{"2":{"771":1}}],["idea",{"2":{"580":1}}],["ideas",{"2":{"35":1}}],["ideally",{"2":{"37":1}}],["ideal",{"2":{"34":1,"251":1}}],["identically",{"2":{"124":1}}],["identifiers",{"2":{"235":2,"571":1,"646":1}}],["identifier",{"2":{"86":1,"118":2}}],["identify",{"2":{"35":1,"42":1,"109":1,"125":2,"646":1}}],["identifying",{"2":{"32":1}}],["identity",{"2":{"6":2,"571":1,"651":1,"670":1}}],["id",{"0":{"247":1,"325":1,"424":1,"469":1,"752":1},"2":{"26":3,"70":1,"86":2,"91":4,"125":1,"142":2,"147":4,"152":4,"156":19,"157":13,"163":12,"202":4,"204":3,"206":2,"207":2,"209":1,"210":3,"211":10,"218":4,"245":1,"247":1,"265":6,"266":14,"268":4,"269":8,"270":4,"272":8,"275":1,"279":20,"294":6,"301":3,"303":5,"314":5,"325":2,"361":6,"412":2,"422":1,"424":1,"429":4,"434":40,"445":5,"449":4,"452":4,"469":1,"477":2,"478":3,"479":2,"512":1,"532":1,"540":4,"542":1,"546":6,"559":1,"560":2,"616":1,"651":1,"700":1,"706":9,"707":10,"738":1,"747":1,"750":2,"751":2,"752":6,"753":2,"754":10,"762":4,"771":2,"772":2,"773":2,"785":1}}],["ifconfig",{"2":{"452":2}}],["if",{"0":{"640":1},"2":{"4":1,"23":3,"24":1,"25":1,"26":5,"30":2,"31":1,"34":3,"35":1,"36":2,"37":1,"38":2,"39":1,"40":2,"41":3,"42":3,"59":1,"60":1,"81":2,"91":4,"105":1,"109":3,"112":2,"117":1,"125":1,"126":1,"127":1,"128":8,"130":10,"139":2,"148":4,"151":1,"154":4,"155":2,"156":1,"160":1,"162":6,"163":4,"168":1,"169":1,"170":1,"172":1,"174":3,"178":1,"179":2,"180":1,"183":1,"185":1,"191":1,"197":1,"199":1,"201":1,"202":12,"205":1,"208":1,"210":2,"215":6,"216":1,"217":1,"225":1,"227":1,"234":1,"244":2,"245":1,"266":1,"271":1,"274":3,"275":3,"277":1,"281":3,"283":1,"288":1,"291":2,"294":2,"301":1,"303":1,"309":2,"311":1,"313":2,"314":1,"320":1,"324":1,"326":3,"329":1,"334":1,"336":1,"339":1,"341":1,"342":1,"343":2,"344":2,"345":1,"352":2,"355":2,"361":3,"363":1,"367":1,"368":2,"371":2,"373":3,"380":1,"383":1,"387":1,"388":2,"390":1,"391":1,"398":1,"399":1,"407":1,"422":1,"425":1,"431":1,"432":2,"433":1,"438":1,"439":2,"443":1,"444":1,"448":1,"449":2,"507":1,"509":1,"536":1,"542":2,"545":1,"546":2,"558":1,"560":1,"561":1,"568":1,"569":1,"570":1,"572":1,"574":1,"580":1,"583":2,"586":1,"588":2,"590":1,"591":2,"593":1,"594":4,"599":26,"603":1,"604":3,"606":1,"607":1,"608":2,"609":1,"610":1,"611":1,"616":3,"617":1,"622":3,"627":2,"629":1,"631":1,"633":1,"634":1,"643":1,"645":2,"646":1,"652":3,"695":1,"700":2,"708":1,"709":1,"728":1,"733":3,"735":1,"737":3,"738":1,"739":1,"741":2,"742":2,"743":1,"744":1,"745":2,"748":2,"757":1,"763":1,"764":1,"765":1,"767":2,"771":1,"773":1,"774":2,"776":1,"777":1,"778":1,"784":8,"785":1}}],["inherently",{"2":{"672":1}}],["inherit",{"2":{"582":1}}],["inherits",{"2":{"278":1}}],["inheriting",{"2":{"221":1}}],["inability",{"2":{"636":1}}],["inappropriate",{"2":{"7":1,"8":1,"12":2,"14":1,"15":1}}],["innovative",{"2":{"583":1}}],["innernode",{"2":{"156":12,"163":12}}],["ini",{"2":{"337":1}}],["initiatives",{"2":{"680":1,"681":2,"682":1}}],["initialisation",{"2":{"324":1,"352":1}}],["initialise",{"2":{"68":1,"495":1}}],["initialization",{"2":{"322":1,"349":1,"355":1,"517":1}}],["initializing",{"2":{"208":1,"244":1,"559":1,"736":1,"767":1}}],["initialize",{"0":{"244":1,"392":1,"421":1,"445":1,"464":1,"559":1,"619":1,"770":1},"1":{"560":1},"2":{"117":1,"260":2,"334":1,"336":1,"338":1,"355":1,"361":1,"392":1,"404":1,"477":1,"478":1,"571":1,"582":1,"619":1,"744":2,"770":1,"771":2,"772":3,"773":2}}],["initializedinfo\\tnode\\tnodebuilder",{"2":{"559":1}}],["initialized",{"2":{"87":1,"117":1,"136":1,"347":1,"437":1,"444":1,"464":1,"559":1,"561":1,"568":1}}],["initial",{"2":{"22":1,"86":1,"266":2,"649":2,"676":1,"681":1,"682":1}}],["initcelestia",{"2":{"421":1,"464":1,"736":1,"744":1}}],["init",{"2":{"117":1,"244":8,"260":2,"272":2,"324":3,"329":3,"336":4,"338":2,"361":6,"392":9,"421":5,"445":2,"464":5,"477":2,"478":2,"559":16,"619":2,"736":5,"744":5,"767":6,"770":2}}],["initgit",{"2":{"117":1}}],["inputting",{"2":{"616":1,"622":1}}],["input=$",{"2":{"539":2}}],["input=3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"539":2}}],["inputs",{"2":{"118":2,"521":1}}],["input",{"0":{"411":1},"2":{"118":2,"187":3,"191":2,"194":2,"203":1,"316":1,"411":3,"525":1,"539":4,"540":2,"601":1}}],["inbox",{"2":{"100":1,"101":1,"110":1}}],["indeed",{"2":{"642":1,"651":1,"652":1}}],["independently",{"2":{"226":1,"649":1}}],["indexing",{"0":{"364":1},"2":{"322":1,"363":1,"366":1,"380":1,"635":1}}],["index`",{"2":{"202":2}}],["index",{"2":{"125":2,"142":2,"144":2,"147":6,"150":8,"151":2,"152":2,"159":3,"160":2,"163":4,"172":1,"174":1,"175":3,"291":2,"322":4,"332":2,"380":2,"565":4,"624":1}}],["indexers",{"2":{"640":1}}],["indexer",{"0":{"380":1,"624":1},"2":{"364":1,"366":2,"380":3,"624":1}}],["indexed",{"2":{"120":1,"380":2,"571":1}}],["indexes",{"2":{"86":1}}],["induced",{"2":{"130":1}}],["industry",{"2":{"38":1}}],["indicates",{"2":{"337":1,"408":1,"762":1}}],["indicated",{"2":{"214":1}}],["indicators",{"2":{"32":1}}],["individual",{"2":{"9":1,"15":1,"26":1,"58":1,"122":1}}],["individuals",{"2":{"7":1,"15":1,"224":1}}],["infra",{"2":{"728":1}}],["infrastructure",{"2":{"23":2,"26":1,"42":1,"93":4,"321":1,"501":1,"554":1,"674":1,"681":1}}],["inflation",{"0":{"677":1},"2":{"677":3,"687":2}}],["infocelestia",{"2":{"752":1,"758":1}}],["infocurl",{"2":{"604":1}}],["info\\tnode\\tnodebuilder",{"2":{"559":10}}],["infos",{"2":{"294":2}}],["informed",{"2":{"500":1,"515":1,"556":1}}],["inform",{"2":{"109":1}}],["informative",{"2":{"42":1,"57":1,"58":1}}],["information$",{"2":{"260":1}}],["information",{"0":{"27":1,"623":1},"2":{"7":1,"36":1,"42":2,"81":2,"87":1,"88":1,"94":1,"105":1,"109":1,"111":1,"112":1,"125":2,"126":2,"127":2,"136":1,"139":1,"142":1,"147":1,"152":1,"163":1,"172":1,"174":1,"202":1,"210":1,"233":1,"234":1,"235":1,"244":1,"245":1,"258":1,"260":1,"266":1,"275":2,"277":1,"303":2,"309":1,"322":1,"324":1,"390":1,"422":3,"437":1,"453":1,"465":2,"571":1,"593":1,"599":2,"619":1,"635":2,"636":1,"638":1,"700":1,"706":2,"737":1,"738":1,"752":1,"754":1}}],["informalsystems",{"2":{"280":1}}],["informal",{"2":{"31":1}}],["info",{"0":{"45":1},"1":{"46":1,"47":1,"48":1,"49":1,"50":1},"2":{"26":1,"147":2,"294":4,"429":2,"478":3,"530":1,"571":1,"604":1,"616":2,"622":2,"638":1,"740":1,"752":1,"758":1}}],["intuitive",{"2":{"199":1}}],["int64",{"2":{"144":8,"156":4,"160":4,"161":4,"163":8}}],["intended",{"2":{"413":1}}],["intensive",{"2":{"367":1}}],["intel",{"2":{"399":1}}],["integrating",{"2":{"229":1,"715":1}}],["integration",{"0":{"454":1,"455":1},"1":{"455":1,"456":2,"457":1},"2":{"81":2,"82":1,"96":1,"103":1,"107":2,"108":2,"109":2,"110":1,"111":2,"112":1,"221":1,"250":2,"259":1,"277":1,"455":1,"456":2,"457":2,"481":1,"542":1,"546":1}}],["integrations",{"0":{"63":1,"486":1,"783":1},"1":{"64":1,"65":1,"66":1,"67":1,"68":1,"487":1,"488":1,"489":1,"490":1,"491":1,"492":1,"493":1,"494":1,"495":1,"496":1,"497":1,"784":1,"785":1,"786":1},"2":{"277":1,"400":1}}],["integrate",{"0":{"114":1,"123":1,"228":1,"229":1,"715":1},"1":{"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"229":1,"230":1,"231":1,"716":1,"717":1,"718":1,"719":1,"720":1,"721":1,"722":1},"2":{"228":1,"229":2,"277":1,"584":1,"765":1}}],["integrated",{"2":{"111":1}}],["integrates",{"2":{"96":1}}],["integrity",{"2":{"86":2}}],["integer",{"2":{"86":1}}],["intermediate",{"2":{"644":1,"645":1,"651":1,"652":1}}],["interruptions",{"2":{"481":1}}],["inter",{"2":{"427":1}}],["intervals",{"2":{"682":1}}],["interval",{"2":{"275":4,"334":4,"429":2}}],["interfaces",{"2":{"126":2,"377":2,"684":1,"685":1,"694":1}}],["interface",{"0":{"120":1},"2":{"109":2,"117":1,"120":3,"122":1,"126":4,"219":1,"278":1,"303":2,"601":2,"648":1,"739":1}}],["internally",{"2":{"238":1}}],["internal",{"2":{"91":5,"724":1}}],["interestingly",{"2":{"650":1}}],["interested",{"2":{"38":2,"39":3,"42":3,"537":1,"569":1,"570":1}}],["interest",{"2":{"36":2,"37":1,"47":1}}],["interests",{"2":{"36":1,"41":1,"42":1}}],["interactivecelestia",{"2":{"308":1}}],["interactive",{"2":{"58":1,"308":1}}],["interactions",{"2":{"13":1,"126":1,"252":1}}],["interaction",{"2":{"13":2,"14":3,"15":1,"31":1,"90":1,"238":1}}],["interacting",{"2":{"3":1,"134":1,"313":1,"325":1,"326":1,"723":1,"727":1,"740":2}}],["interact",{"2":{"6":1,"122":1,"136":1,"231":1,"252":1,"254":1,"396":1,"459":1,"474":1,"508":1,"509":1,"510":1,"567":1,"569":1,"570":1,"601":1,"706":2,"707":2,"719":1,"723":1,"739":1,"740":2,"741":1,"742":1,"743":2}}],["intake",{"2":{"41":2}}],["introducing",{"2":{"650":1}}],["introduction",{"0":{"53":1,"56":1,"106":1,"165":1,"404":1,"454":1,"650":1,"731":1},"1":{"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"195":1,"196":1,"197":1,"198":1,"199":1,"455":1,"456":1,"457":1,"732":1,"733":1},"2":{"37":1,"53":2,"55":1,"56":3,"81":1,"82":1,"103":1,"107":1,"108":1,"250":1,"716":1}}],["introduces",{"2":{"673":1}}],["introduced",{"2":{"610":1}}],["introduce",{"2":{"31":1,"530":1}}],["into",{"0":{"566":1,"638":1},"1":{"567":1,"568":1,"569":1,"570":1,"571":1},"2":{"22":1,"25":1,"53":1,"77":1,"89":1,"93":1,"96":1,"109":1,"110":1,"111":1,"137":2,"139":1,"208":1,"214":1,"221":1,"263":1,"273":1,"277":1,"286":1,"311":1,"316":1,"325":1,"334":1,"341":1,"345":1,"430":1,"481":1,"528":1,"572":1,"590":1,"643":2,"645":1,"646":2,"649":1,"651":5,"670":3,"700":1,"733":1,"773":2}}],["incoming",{"2":{"780":2}}],["incomplete",{"2":{"646":1}}],["incorrectly",{"0":{"645":1},"2":{"633":1,"634":1,"645":2}}],["incorrect",{"2":{"91":1,"400":1,"634":1}}],["incentive",{"2":{"652":1}}],["incentives",{"2":{"37":1,"639":1}}],["incentivized",{"2":{"681":1}}],["incentivizes",{"2":{"641":1}}],["incentivize",{"0":{"639":1},"2":{"639":1}}],["inception",{"2":{"480":1}}],["incurred",{"2":{"404":1,"412":1}}],["incubators",{"2":{"34":1}}],["incredible",{"2":{"44":1}}],["increased",{"2":{"93":2}}],["increases",{"2":{"39":1,"86":1,"632":1,"650":1}}],["increase",{"2":{"38":1,"39":1,"274":2,"337":1,"649":1,"650":1}}],["increasing",{"2":{"36":1,"337":1,"644":1,"650":1}}],["incident",{"2":{"10":1,"13":1}}],["inclusion",{"0":{"122":1,"132":1,"141":1,"145":1,"146":1,"149":1,"151":1,"175":1},"1":{"142":1,"143":1,"147":1,"148":1,"150":1,"152":1,"153":1},"2":{"40":1,"117":1,"119":2,"120":1,"122":4,"125":1,"127":3,"132":1,"137":1,"139":1,"141":1,"142":1,"144":2,"146":1,"147":2,"151":1,"155":1,"156":1,"160":1,"163":1,"164":1,"168":3,"169":2,"174":2,"175":7,"188":1,"191":1,"199":2,"227":2,"610":1}}],["inclusive",{"2":{"6":1,"46":1,"216":1}}],["including",{"2":{"13":1,"14":2,"15":1,"26":1,"30":3,"31":1,"41":1,"46":1,"58":1,"86":1,"88":1,"94":1,"525":1,"542":1,"592":1,"616":1,"681":1}}],["included",{"2":{"120":2,"127":2,"128":3,"137":1,"160":2,"172":1,"174":1,"183":1,"227":1,"485":1,"528":1,"532":1,"588":2,"594":3,"598":2,"609":1,"610":1,"611":1,"670":1,"710":2,"745":1,"747":1,"748":1,"779":2}}],["includes",{"2":{"13":1,"51":1,"52":1,"87":1,"96":1,"111":1,"428":1,"450":1,"530":1,"638":1,"646":1,"670":1,"682":1,"721":1}}],["include",{"2":{"7":2,"9":1,"38":1,"172":1,"216":1,"228":1,"276":1,"322":1,"451":1,"530":1,"541":1,"584":1,"640":1,"670":1,"741":1}}],["invocations",{"2":{"373":1,"622":1}}],["involves",{"2":{"591":1,"637":1}}],["involve",{"2":{"126":2,"127":1,"542":1}}],["involvement",{"2":{"37":1}}],["involved",{"2":{"13":1,"14":1,"190":1,"455":1,"591":1,"592":1}}],["inverted",{"2":{"322":2}}],["investigations",{"2":{"185":1}}],["investigate",{"2":{"36":1,"38":1}}],["investigated",{"2":{"10":1,"170":1,"183":1,"193":1}}],["invalid",{"0":{"383":1,"627":1},"2":{"127":2,"130":2,"163":4,"174":1,"179":2,"183":2,"334":2,"383":2,"627":2,"645":2,"652":1,"779":2,"780":2}}],["invitation",{"2":{"47":1}}],["invitations",{"2":{"30":1}}],["invites",{"2":{"48":1}}],["invite",{"2":{"37":2,"39":2}}],["invisible",{"2":{"6":1}}],["inspect",{"2":{"629":1}}],["inspired",{"2":{"16":1,"178":1,"202":1}}],["insecure",{"2":{"599":4}}],["inside",{"0":{"191":1},"2":{"172":2,"187":1,"188":1,"191":2,"193":1,"194":3,"196":1,"246":1,"311":1,"383":1,"423":1,"449":1,"450":1,"451":1,"468":1,"627":2,"698":1,"700":1,"771":1,"776":1}}],["insight",{"2":{"273":1}}],["insightful",{"2":{"44":1}}],["insights",{"2":{"32":1,"37":1,"58":1,"280":1}}],["instrumentation",{"2":{"274":6}}],["instructions",{"0":{"210":1},"2":{"200":1,"211":2,"214":1,"217":1,"218":1,"245":1,"282":1,"283":1,"294":1,"312":1,"343":1,"345":1,"359":1,"388":3,"396":1,"398":2,"422":1,"501":2,"545":1,"546":1,"568":1,"585":1,"586":1,"614":1,"622":1,"624":1}}],["instead",{"2":{"104":1,"110":1,"126":1,"130":3,"161":4,"162":4,"163":4,"176":1,"194":1,"400":1,"455":1,"530":1,"590":3,"594":1,"673":1,"690":1,"747":1}}],["instability",{"2":{"481":1,"549":1}}],["instantiate",{"0":{"453":1,"736":1},"2":{"439":1,"649":1,"736":1}}],["instantiation",{"0":{"439":1},"1":{"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1}}],["instantiating",{"2":{"105":1,"736":1}}],["instantaneous",{"2":{"426":1}}],["instance",{"2":{"77":1,"92":2,"214":1,"215":1,"235":1,"240":1,"275":1,"315":1,"336":1,"358":1,"417":1,"462":1,"563":1,"586":1,"614":1}}],["instances",{"2":{"10":1}}],["installer",{"2":{"388":1}}],["installed",{"2":{"116":1,"202":1,"208":1,"287":1,"298":1,"307":1,"311":1,"342":1,"343":2,"344":1,"347":1,"384":1,"399":2,"403":1,"428":1,"429":1,"473":4,"474":1,"558":2,"705":1,"766":1,"784":1}}],["installs",{"2":{"341":1,"699":2}}],["installation",{"0":{"343":1,"442":1,"699":1},"2":{"312":2,"342":2,"343":3,"697":1}}],["installmake",{"2":{"311":1,"341":1}}],["installing",{"0":{"117":1,"312":1,"341":1,"342":1},"1":{"343":1},"2":{"241":1,"243":1,"310":1,"312":1,"341":1,"342":1,"359":1,"360":1,"388":1,"396":1,"398":2,"419":1,"463":1,"618":1}}],["install",{"0":{"243":1,"310":1,"340":1,"360":1,"398":1,"399":1,"419":1,"463":1,"618":1,"767":1},"1":{"311":1,"312":1,"313":1,"341":1,"342":1,"343":1,"344":1,"345":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1},"2":{"89":2,"117":3,"203":2,"210":2,"243":1,"275":1,"277":1,"282":1,"284":1,"307":1,"311":3,"312":1,"341":3,"343":5,"345":1,"371":1,"388":1,"398":15,"399":2,"428":1,"442":1,"463":1,"558":2,"604":2,"606":2,"607":2,"608":2,"699":2,"708":1,"735":1,"739":1,"767":1,"777":1,"784":2}}],["insulting",{"2":{"7":1}}],["in",{"0":{"74":1,"75":1,"112":1,"154":1,"204":1,"336":1,"406":1,"408":1,"435":1,"461":1,"548":1,"594":1,"631":1,"673":1},"1":{"75":1,"76":2,"77":2,"78":1,"79":1,"80":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"205":1,"206":1,"207":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"555":1,"556":1},"2":{"3":1,"4":2,"6":2,"7":1,"8":1,"9":1,"11":2,"12":1,"13":1,"18":1,"20":1,"22":6,"23":6,"24":3,"26":2,"28":1,"29":1,"31":1,"32":1,"33":1,"34":2,"35":4,"36":3,"37":2,"38":6,"39":7,"40":4,"42":7,"44":2,"46":2,"47":2,"48":1,"50":1,"54":1,"55":1,"58":4,"60":2,"63":2,"64":1,"65":2,"68":2,"74":2,"76":3,"77":4,"79":3,"80":3,"84":1,"85":2,"86":12,"87":4,"88":1,"89":1,"90":5,"91":10,"93":10,"94":3,"95":1,"96":1,"97":1,"104":4,"107":1,"108":2,"109":7,"110":10,"111":1,"112":3,"113":1,"119":2,"120":2,"121":1,"122":2,"125":13,"126":3,"127":12,"128":4,"130":1,"136":3,"137":8,"139":9,"140":1,"141":1,"150":2,"152":3,"153":2,"155":3,"156":13,"157":1,"158":1,"159":9,"160":8,"161":2,"162":1,"164":2,"165":1,"166":2,"167":1,"168":3,"169":4,"171":3,"172":4,"173":1,"174":9,"175":9,"179":2,"180":1,"182":2,"183":5,"184":1,"185":1,"186":1,"187":3,"188":1,"190":1,"191":2,"194":1,"197":2,"199":5,"201":1,"202":7,"203":3,"204":5,"205":1,"208":6,"210":6,"211":16,"213":2,"214":2,"215":7,"216":3,"217":2,"219":1,"221":2,"224":1,"226":1,"227":5,"228":1,"230":1,"233":2,"234":1,"235":1,"238":3,"244":1,"246":1,"247":1,"250":2,"251":1,"254":1,"263":1,"266":4,"267":2,"272":2,"275":3,"276":1,"281":3,"283":1,"287":1,"289":1,"291":3,"294":1,"295":1,"296":1,"298":2,"301":1,"303":1,"304":1,"308":1,"311":1,"312":2,"314":1,"315":1,"316":1,"320":2,"321":3,"322":4,"326":1,"328":4,"329":2,"331":1,"334":1,"336":2,"337":4,"338":1,"341":1,"343":5,"348":1,"349":1,"352":1,"353":1,"355":1,"356":1,"361":7,"363":1,"365":1,"366":1,"367":2,"368":2,"371":3,"378":1,"380":2,"381":6,"383":2,"385":1,"387":1,"388":2,"392":3,"396":1,"399":1,"400":4,"404":2,"407":1,"422":1,"423":1,"424":1,"426":2,"427":2,"428":1,"431":2,"432":5,"443":1,"444":1,"445":1,"448":3,"449":2,"450":2,"452":1,"455":3,"457":1,"461":1,"464":1,"465":1,"466":2,"467":1,"468":1,"469":1,"478":1,"480":2,"484":1,"485":6,"486":4,"487":1,"497":1,"501":3,"505":1,"507":1,"509":1,"510":1,"511":1,"518":1,"521":1,"525":1,"527":3,"528":3,"530":5,"532":1,"533":2,"537":1,"541":2,"542":4,"544":2,"546":1,"547":1,"551":1,"554":1,"557":3,"559":4,"560":4,"561":3,"564":6,"565":3,"566":1,"568":2,"569":1,"570":1,"571":3,"580":1,"582":1,"583":2,"584":2,"585":1,"586":5,"588":5,"589":1,"590":3,"591":4,"592":4,"593":2,"594":2,"595":1,"597":1,"600":1,"601":5,"604":3,"608":2,"609":2,"610":1,"611":1,"612":2,"616":2,"622":3,"627":2,"631":2,"634":1,"636":1,"637":1,"638":1,"639":1,"642":1,"643":4,"644":3,"646":1,"649":9,"650":1,"651":3,"652":3,"653":1,"656":1,"657":1,"661":1,"670":1,"671":2,"672":3,"673":3,"674":4,"676":1,"677":2,"680":1,"681":1,"682":2,"687":1,"689":1,"690":3,"691":2,"692":1,"694":1,"695":1,"698":1,"699":4,"700":2,"701":1,"706":3,"707":3,"709":1,"710":1,"711":5,"712":6,"717":1,"718":1,"719":4,"722":2,"723":1,"728":1,"730":1,"733":1,"736":1,"737":1,"738":2,"740":3,"741":1,"742":1,"743":1,"744":1,"745":4,"747":4,"748":1,"752":2,"753":1,"757":6,"760":1,"762":3,"765":1,"767":5,"768":2,"770":1,"771":1,"773":3,"778":1,"779":1,"780":4,"784":2,"785":2,"786":2}}],["imagine",{"2":{"584":1}}],["image",{"2":{"104":1,"390":1,"706":3,"707":6,"786":1}}],["imagery",{"2":{"7":1}}],["images",{"2":{"3":1,"786":1}}],["immutable",{"2":{"86":2,"118":2}}],["improperly",{"2":{"633":1}}],["improve",{"2":{"41":1}}],["improvement",{"2":{"32":1,"528":1,"644":1}}],["improvements",{"2":{"4":1,"481":1}}],["improved",{"2":{"28":1,"221":1,"273":1}}],["improves",{"2":{"23":1}}],["improving",{"2":{"2":1}}],["impractical",{"2":{"629":1}}],["importing",{"0":{"263":1,"524":1,"702":1},"2":{"161":2,"162":2,"163":2,"314":1}}],["import",{"0":{"771":1},"2":{"118":6,"143":2,"144":4,"150":1,"161":4,"162":4,"163":10,"238":1,"263":5,"275":2,"314":1,"430":1,"524":2,"568":1,"593":1,"598":1,"599":1,"702":1,"710":1,"771":4,"784":7}}],["importance",{"2":{"58":1}}],["important",{"0":{"45":1},"1":{"46":1,"47":1,"48":1,"49":1,"50":1},"2":{"23":1,"27":1,"110":1,"125":2,"275":1,"276":1,"291":2,"325":1,"526":1,"560":1,"592":1,"609":1,"648":1}}],["implement",{"2":{"528":1,"649":1,"674":2,"776":1}}],["implemented",{"2":{"164":1,"509":1,"527":1,"532":1,"586":1,"673":4}}],["implements",{"2":{"109":1}}],["implementations",{"0":{"222":1,"236":1},"2":{"126":2,"427":1}}],["implementation",{"0":{"109":1,"110":1,"111":1,"232":1,"406":1},"1":{"233":1,"234":1,"235":1,"236":1},"2":{"108":3,"122":1,"124":1,"163":4,"221":3,"222":1,"226":1,"227":2,"233":1,"236":1,"238":1,"428":1,"525":1,"585":1,"740":1}}],["impactful",{"2":{"37":1,"58":1}}],["impact",{"2":{"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"26":1,"38":1,"528":1}}],["item",{"2":{"775":1}}],["items",{"2":{"772":1,"773":1}}],["ith",{"2":{"592":2}}],["itrocket",{"2":{"489":1,"490":1,"491":1,"492":1,"495":1,"498":1,"499":1,"507":1,"508":1,"509":1,"510":1,"514":1}}],["itself",{"2":{"96":1,"275":2}}],["its",{"2":{"18":2,"26":2,"86":4,"87":2,"110":1,"139":1,"147":1,"149":1,"156":2,"157":2,"163":2,"166":1,"168":1,"172":1,"174":1,"178":1,"182":1,"183":1,"187":1,"199":1,"202":1,"209":1,"210":1,"225":1,"226":1,"259":2,"275":1,"322":1,"337":1,"480":1,"590":1,"591":1,"601":2,"604":1,"606":1,"607":1,"608":1,"631":1,"632":1,"646":2,"649":1,"683":1,"691":1,"750":1,"776":1}}],["it",{"2":{"2":2,"23":1,"29":1,"35":1,"36":1,"41":2,"42":1,"47":1,"60":5,"77":1,"86":5,"88":2,"90":1,"91":3,"92":1,"104":1,"109":6,"110":1,"112":1,"119":1,"120":1,"122":6,"124":1,"126":2,"130":2,"136":1,"137":2,"139":2,"141":2,"151":2,"155":2,"157":2,"160":1,"163":2,"165":1,"168":1,"170":1,"172":1,"174":2,"179":1,"182":1,"183":1,"187":2,"194":1,"199":1,"202":10,"203":4,"204":3,"208":1,"210":8,"211":2,"214":4,"215":5,"216":1,"217":1,"218":1,"219":1,"226":1,"227":2,"233":1,"234":3,"235":1,"244":2,"245":1,"250":1,"251":2,"254":1,"273":1,"274":2,"275":6,"276":1,"277":1,"281":1,"287":1,"291":2,"294":1,"305":1,"308":1,"312":1,"313":1,"316":1,"320":2,"322":1,"324":1,"325":1,"326":1,"333":1,"334":2,"336":2,"337":1,"339":1,"343":1,"344":1,"368":1,"372":1,"376":1,"377":2,"381":1,"383":1,"385":1,"391":2,"402":1,"406":1,"422":2,"427":1,"428":2,"430":1,"431":1,"438":1,"448":1,"450":2,"451":1,"455":1,"464":1,"474":1,"480":1,"481":1,"485":1,"501":1,"507":1,"525":1,"526":1,"538":1,"539":1,"546":1,"549":1,"552":1,"554":1,"557":2,"560":1,"561":1,"564":2,"565":1,"579":1,"582":1,"588":2,"591":2,"592":4,"594":4,"598":2,"599":2,"601":1,"604":2,"609":1,"610":1,"611":1,"616":1,"617":2,"627":1,"629":5,"632":2,"633":1,"638":1,"639":1,"645":1,"646":1,"649":1,"650":1,"651":5,"652":1,"674":2,"677":1,"697":1,"699":1,"710":2,"722":1,"726":1,"728":1,"737":2,"740":1,"745":1,"754":2,"763":2,"764":1,"765":1,"767":3,"768":1,"773":7,"774":3,"775":1,"776":2,"784":4}}],["issuing",{"2":{"690":1}}],["issuance",{"2":{"677":2}}],["issues",{"2":{"8":1,"54":1,"91":1,"345":1,"456":1,"546":3,"572":1}}],["issue",{"2":{"4":1,"93":1,"428":1,"536":2,"594":1,"636":1,"677":1,"690":1}}],["isn",{"2":{"130":1,"485":1,"586":1}}],["isvalid",{"2":{"130":2}}],["isolates",{"2":{"583":1}}],["isolated",{"2":{"388":1}}],["isolate",{"2":{"126":1}}],["is",{"0":{"221":1,"227":1,"233":1,"579":1,"580":1,"629":1,"630":1,"632":1,"634":1,"635":1,"636":1,"637":1,"640":1},"1":{"222":1},"2":{"1":1,"7":1,"9":1,"14":1,"16":1,"20":1,"21":1,"23":1,"25":1,"26":2,"29":1,"31":1,"34":1,"37":1,"38":1,"39":2,"41":3,"42":1,"43":1,"46":1,"47":2,"49":2,"50":1,"51":1,"53":1,"54":2,"55":2,"58":3,"59":4,"60":1,"63":1,"70":1,"71":1,"79":1,"84":1,"85":3,"86":8,"87":1,"88":3,"90":3,"91":7,"93":10,"94":1,"96":2,"108":3,"109":7,"110":2,"111":1,"112":2,"117":2,"118":2,"119":3,"120":2,"122":6,"124":3,"125":30,"126":5,"127":6,"128":6,"130":6,"134":1,"136":1,"137":3,"139":5,"141":2,"145":1,"147":2,"148":1,"149":2,"150":1,"151":1,"152":1,"153":1,"155":2,"156":5,"157":3,"159":2,"160":12,"163":6,"164":1,"165":1,"167":1,"168":1,"169":1,"172":3,"173":1,"174":9,"175":12,"178":3,"179":6,"180":1,"183":9,"185":1,"186":1,"187":6,"188":1,"191":6,"193":1,"194":4,"197":1,"199":6,"202":13,"204":2,"205":2,"208":3,"210":4,"211":6,"212":2,"213":1,"214":8,"215":7,"218":1,"219":1,"221":4,"224":1,"225":2,"226":2,"227":3,"233":2,"234":3,"235":1,"238":5,"240":1,"244":1,"245":4,"248":1,"249":2,"250":3,"254":1,"255":1,"266":3,"273":1,"275":5,"277":2,"278":1,"281":6,"282":1,"289":3,"291":2,"294":1,"295":1,"296":1,"303":2,"308":1,"310":1,"312":2,"313":2,"314":1,"315":1,"317":1,"318":1,"319":1,"320":2,"322":4,"324":2,"325":4,"326":2,"328":1,"329":1,"331":1,"333":1,"334":3,"336":2,"337":2,"338":2,"339":1,"341":2,"342":2,"343":3,"350":1,"352":1,"353":2,"355":4,"358":1,"361":3,"363":1,"365":2,"367":1,"368":2,"370":1,"373":2,"378":3,"380":7,"381":1,"383":1,"385":1,"387":1,"388":3,"390":2,"391":1,"396":2,"399":1,"400":3,"404":1,"406":1,"413":1,"414":1,"417":1,"422":3,"426":1,"427":1,"428":4,"431":3,"437":1,"438":1,"439":1,"445":2,"447":1,"448":1,"452":2,"454":2,"455":8,"456":1,"457":1,"459":1,"461":1,"465":1,"467":1,"477":1,"479":2,"480":2,"481":2,"485":7,"486":2,"496":1,"497":1,"501":4,"508":2,"509":3,"510":3,"512":1,"526":3,"528":1,"537":1,"542":3,"544":2,"545":1,"546":1,"549":2,"552":2,"554":1,"557":2,"558":1,"559":2,"560":1,"561":5,"564":5,"565":4,"568":3,"571":1,"579":1,"580":1,"582":2,"583":1,"585":1,"588":4,"590":4,"591":4,"592":14,"593":2,"594":2,"599":8,"601":2,"602":1,"604":3,"607":1,"608":1,"609":3,"610":1,"611":1,"614":1,"617":3,"621":1,"622":3,"627":1,"629":2,"630":3,"631":1,"632":3,"633":6,"634":3,"635":2,"636":2,"637":2,"638":3,"639":3,"641":1,"642":2,"643":6,"645":7,"646":8,"648":7,"649":3,"650":3,"651":5,"652":9,"653":1,"659":1,"663":1,"668":1,"670":2,"672":5,"673":3,"674":4,"676":1,"682":3,"689":1,"690":1,"694":1,"695":4,"696":1,"697":1,"698":1,"709":1,"715":1,"717":2,"719":1,"720":1,"721":1,"722":3,"723":1,"726":1,"727":2,"728":2,"732":1,"736":1,"738":1,"740":5,"741":2,"742":2,"743":1,"744":3,"745":3,"747":3,"748":2,"750":1,"751":1,"752":2,"753":1,"754":1,"757":2,"764":1,"767":2,"771":1,"773":5,"775":2,"778":1,"784":5}}],["lcd",{"2":{"490":2}}],["luckily",{"2":{"636":1,"639":1}}],["lunaroasis",{"2":{"466":2,"489":1,"490":1,"491":1,"495":1,"737":2}}],["lumina",{"2":{"461":2,"777":1}}],["l5dhzjldczo",{"2":{"291":2,"292":2}}],["ljj6hspn0kn09qf9fy8kdyh40000gn",{"2":{"287":4}}],["lsm",{"2":{"322":3}}],["ls",{"2":{"214":2,"215":2}}],["ldflags",{"2":{"214":2}}],["lfg",{"2":{"93":2}}],["l2genesisdeltatimeoffset",{"2":{"541":1}}],["l2s",{"2":{"112":1,"221":2,"226":1,"400":2,"455":1}}],["l2",{"0":{"90":1,"546":1},"2":{"84":1,"86":2,"87":1,"88":1,"93":6,"111":1,"120":1,"122":1,"221":1,"225":2,"229":1,"400":1,"454":1,"546":2,"630":2}}],["l1",{"0":{"546":1},"2":{"84":2,"86":1,"93":8,"538":1,"539":1,"542":2,"546":4,"630":1}}],["l3s",{"2":{"112":1,"221":1,"400":1}}],["l3configuration",{"2":{"93":2}}],["l3",{"2":{"74":1,"77":1,"79":1,"88":2,"93":6}}],["lts",{"2":{"240":1,"358":1,"417":1,"462":1,"614":1,"720":1}}],["lt",{"2":{"68":6,"70":3,"77":1,"91":8,"128":2,"136":3,"142":1,"144":4,"147":1,"148":2,"150":7,"152":1,"161":4,"162":6,"203":8,"204":30,"206":4,"207":4,"209":6,"215":4,"216":1,"233":1,"244":8,"245":4,"246":12,"262":8,"263":6,"264":8,"265":18,"266":20,"267":4,"268":6,"269":16,"270":4,"271":6,"272":2,"275":2,"303":4,"314":10,"316":10,"317":4,"318":4,"319":4,"320":16,"324":10,"329":10,"334":8,"335":4,"336":8,"338":9,"393":2,"405":4,"412":4,"422":4,"423":12,"430":4,"466":6,"467":3,"468":12,"495":6,"512":3,"538":1,"571":2,"596":4,"597":4,"604":4,"606":4,"607":6,"608":6,"616":4,"619":2,"622":2,"700":13,"701":12,"702":12,"706":5,"707":8,"711":6,"712":6,"737":6,"738":21,"740":6,"742":6,"743":4,"745":8,"747":8,"751":2,"754":4,"757":6,"759":4,"772":6,"773":6,"775":12,"784":14}}],["living",{"2":{"484":1}}],["lives",{"2":{"42":1,"110":1,"289":1}}],["live",{"2":{"40":4,"76":1,"289":1,"457":1,"481":1,"546":1}}],["lifecycle",{"0":{"651":1},"1":{"652":1}}],["life",{"2":{"480":1,"670":1}}],["libp2p",{"2":{"238":1,"652":1}}],["libssl",{"2":{"398":4}}],["libs",{"2":{"163":2}}],["library",{"0":{"154":1,"708":1,"725":1,"777":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"778":1,"779":1,"780":1,"781":1,"782":1},"2":{"122":3,"154":1,"163":2,"174":1,"183":1,"191":1,"522":1,"708":1,"725":1,"726":1,"777":1}}],["libraries",{"2":{"34":2,"188":1,"718":1,"720":1,"721":1,"771":1}}],["lib",{"2":{"118":2,"122":1,"163":2}}],["license",{"2":{"118":2}}],["limit=fc+∑i=1nssn",{"2":{"592":1}}],["limit×gas",{"2":{"592":1}}],["limitnofile=65535",{"2":{"604":2}}],["limitnofile=1400000",{"2":{"337":2,"606":2,"607":2}}],["limitnofile",{"2":{"337":2}}],["limits",{"0":{"590":1},"1":{"591":1,"592":1,"593":1},"2":{"274":2,"337":1,"530":1,"649":1,"748":1}}],["limited",{"2":{"266":1,"644":2,"650":1,"717":1}}],["limitations",{"2":{"171":1}}],["limit",{"2":{"70":1,"294":2,"337":1,"407":2,"412":2,"485":1,"512":1,"530":1,"590":2,"592":4,"593":1,"599":2,"745":1,"748":1,"757":1}}],["lightdsudo",{"2":{"608":2}}],["lightd",{"2":{"608":13}}],["light$home",{"2":{"544":1}}],["lightbridgefull",{"2":{"390":1}}],["lightlink",{"2":{"163":1}}],["light",{"0":{"54":1,"91":1,"133":1,"331":1,"332":1,"338":1,"385":1,"391":1,"458":1,"459":1,"461":1,"462":1,"464":1,"465":1,"468":1,"470":1,"478":1,"504":1,"544":1,"558":1,"559":1,"561":1,"562":1,"563":1,"597":1,"608":1,"736":1,"767":1},"1":{"339":1,"386":1,"392":1,"393":1,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":2,"467":2,"468":2,"469":3,"470":2,"471":1,"505":1,"506":1,"507":1,"559":1,"560":2,"561":1,"563":1,"564":1,"565":1},"2":{"54":7,"65":1,"68":3,"82":1,"91":7,"111":1,"126":9,"133":1,"134":1,"221":2,"227":2,"238":1,"244":1,"315":2,"321":1,"322":4,"328":1,"331":1,"332":1,"335":3,"338":7,"339":1,"344":1,"348":2,"349":2,"355":6,"371":2,"385":2,"392":6,"393":6,"403":1,"405":1,"407":2,"408":4,"409":2,"415":2,"422":1,"458":1,"459":2,"460":1,"461":1,"464":6,"465":7,"466":12,"468":9,"469":3,"470":1,"471":1,"472":1,"478":10,"479":7,"493":1,"495":1,"496":2,"501":1,"518":2,"523":2,"533":2,"535":1,"544":7,"557":2,"558":1,"559":13,"560":3,"561":3,"565":1,"566":1,"567":4,"568":1,"569":1,"570":1,"571":2,"583":1,"593":1,"607":1,"608":7,"631":1,"632":4,"633":6,"634":2,"642":1,"643":5,"644":8,"645":3,"650":2,"652":9,"673":6,"698":1,"700":2,"701":2,"702":2,"706":5,"707":10,"722":1,"728":1,"734":1,"736":8,"737":14,"738":12,"742":3,"743":3,"744":12,"745":1,"762":3,"766":1,"767":10}}],["lightning",{"2":{"42":1,"454":1}}],["lisbon",{"2":{"44":1}}],["listcelestia",{"2":{"299":1,"308":1}}],["listing",{"2":{"262":2}}],["listens",{"2":{"377":1}}],["listen",{"2":{"219":1,"274":4,"275":1,"377":1,"459":1,"652":1}}],["listening",{"0":{"162":1},"2":{"162":1,"377":1}}],["listed",{"2":{"65":1,"487":1,"489":1,"505":1,"532":1,"586":1}}],["list",{"0":{"58":1,"292":1},"2":{"26":2,"30":1,"36":1,"37":2,"50":2,"58":6,"86":1,"109":3,"118":2,"156":2,"159":2,"203":1,"205":1,"206":2,"211":1,"218":1,"244":2,"245":2,"262":2,"266":1,"274":2,"292":2,"299":2,"308":1,"329":2,"361":2,"422":2,"429":4,"435":4,"451":2,"466":2,"486":1,"501":1,"622":1,"643":1,"666":1,"679":1,"706":3,"707":3,"714":1,"738":2,"782":1}}],["linear",{"2":{"592":1}}],["lines",{"2":{"271":2}}],["line",{"0":{"279":1},"2":{"244":1,"278":1,"303":1,"336":1,"350":1,"381":1,"390":1,"451":1,"737":1,"739":1}}],["lineup",{"2":{"37":1}}],["linuxdocker",{"2":{"391":1}}],["linux",{"2":{"91":1,"240":1,"312":1,"342":1,"358":1,"389":1,"396":1,"399":12,"417":1,"462":1,"614":1,"720":1}}],["linked",{"2":{"133":1}}],["link",{"2":{"63":1,"231":1,"275":2,"276":1,"486":1,"501":1,"773":2}}],["links",{"2":{"26":2,"48":1,"136":1}}],["little",{"2":{"34":1,"87":1,"449":1,"722":1}}],["likely",{"2":{"126":5,"334":1,"383":1,"627":1,"640":1,"722":2}}],["likelihood",{"2":{"39":1,"652":1}}],["like",{"2":{"13":1,"30":1,"34":2,"35":1,"40":1,"41":2,"42":1,"63":1,"73":1,"82":1,"84":1,"86":2,"91":1,"92":1,"104":1,"124":1,"125":1,"130":1,"202":3,"215":2,"246":1,"275":1,"283":1,"284":1,"288":1,"294":3,"314":2,"320":1,"326":1,"329":1,"336":1,"337":1,"339":1,"373":1,"383":1,"388":1,"390":2,"398":1,"423":1,"425":1,"431":1,"468":1,"477":1,"481":1,"486":1,"500":1,"501":2,"515":1,"530":1,"538":1,"542":3,"556":1,"574":1,"579":1,"580":2,"583":2,"627":1,"629":1,"630":1,"632":1,"638":1,"641":1,"676":1,"691":1,"706":1,"707":1,"709":1,"728":2,"733":2,"737":1,"738":1,"744":1,"747":1,"754":2,"757":3,"763":1,"764":1,"767":1,"778":1,"784":1}}],["laddr",{"2":{"313":1}}],["ladder",{"2":{"16":1}}],["lang",{"2":{"303":2}}],["languages",{"2":{"136":1,"164":1}}],["language",{"2":{"7":1,"12":1}}],["laid",{"2":{"191":1,"194":1}}],["latter",{"2":{"187":1,"650":1}}],["latency",{"2":{"429":4}}],["latestblock",{"2":{"228":1,"233":5}}],["latestblocknumber",{"2":{"144":4,"161":4}}],["latestrollupheight",{"2":{"126":2,"128":6}}],["latest",{"2":{"59":1,"60":2,"95":1,"96":1,"104":1,"126":2,"140":1,"216":2,"221":1,"227":5,"233":1,"298":1,"311":6,"312":1,"341":6,"343":5,"345":1,"383":1,"390":6,"392":6,"393":6,"422":1,"427":1,"538":2,"552":1,"558":3,"561":2,"585":1,"627":2,"630":1,"674":2,"706":2,"717":1,"781":6}}],["later",{"2":{"34":1,"215":1,"311":1,"446":1,"636":1,"651":1,"652":1}}],["large",{"2":{"171":1,"217":1,"557":1,"722":2}}],["larger",{"2":{"34":1,"36":1,"274":2,"644":1,"722":1}}],["layout",{"2":{"127":1,"137":2,"168":1}}],["layers",{"2":{"642":2,"648":1,"649":7,"672":2}}],["layer",{"0":{"642":1},"1":{"643":1,"644":1,"645":1,"646":1,"647":1,"648":1},"2":{"91":1,"107":2,"111":1,"178":2,"221":1,"227":1,"237":2,"238":1,"249":1,"250":1,"251":1,"356":1,"400":1,"455":5,"532":1,"542":1,"557":1,"579":3,"580":3,"642":3,"644":2,"646":4,"648":4,"649":6,"651":1,"652":1,"670":1,"690":1,"716":1,"719":1,"730":1,"732":1}}],["lag",{"2":{"60":1}}],["label",{"2":{"275":2,"437":1}}],["labels",{"2":{"275":4}}],["labeled",{"2":{"47":1}}],["labs",{"2":{"23":1,"37":2,"38":2,"39":2,"40":5,"41":10,"58":1,"59":1,"81":2,"93":1,"249":1,"681":1}}],["lastly",{"2":{"275":1}}],["lastblock",{"2":{"128":6}}],["last",{"2":{"26":1,"35":1,"37":1,"208":1,"216":1,"271":2,"281":1,"560":2,"754":6,"775":1}}],["law",{"2":{"24":1}}],["launching",{"2":{"36":1}}],["launch",{"0":{"20":1,"88":1},"2":{"87":1,"88":1,"250":1,"650":1,"682":2,"690":1}}],["lemongrass",{"0":{"532":1},"2":{"527":2,"530":1,"532":2}}],["lemonade",{"2":{"35":1}}],["leonardo",{"2":{"479":2,"564":3,"565":2}}],["legacy",{"2":{"266":3,"267":2}}],["ledger",{"2":{"202":2,"629":1}}],["len",{"2":{"128":8,"130":6,"144":2,"156":4,"158":2,"159":4,"160":2,"163":12,"599":4,"711":2,"712":2,"772":2,"773":2,"775":2,"779":2,"780":2}}],["length",{"2":{"125":2}}],["left",{"2":{"126":1,"179":2,"187":1,"191":1,"194":1,"639":1}}],["lets",{"2":{"583":1}}],["let",{"2":{"41":3,"87":1,"122":1,"349":1,"557":1,"559":2,"560":2,"563":1,"564":1,"565":1,"598":2,"710":2,"736":1,"737":1,"740":1,"750":1,"751":1,"754":1,"765":1,"767":1,"772":1,"779":12,"780":12,"781":4}}],["leveraging",{"2":{"434":1}}],["leverages",{"2":{"118":1}}],["leverage",{"2":{"37":1,"38":1,"39":1,"497":1}}],["levels",{"2":{"726":1}}],["leveldb",{"2":{"380":1}}],["level",{"2":{"6":1,"59":1,"122":1,"124":1,"137":1,"199":1,"215":1,"276":1,"429":2,"632":1,"683":1,"726":1}}],["lessons",{"2":{"32":1}}],["less",{"2":{"23":1,"24":1,"169":1,"183":1,"485":1,"526":1,"580":1,"674":1}}],["leapwallet",{"2":{"684":1}}],["leap",{"0":{"660":1,"661":1,"785":1},"1":{"661":1,"662":1,"663":1},"2":{"653":1,"682":1,"783":1,"785":3}}],["leave",{"2":{"604":1}}],["leaves",{"2":{"118":2,"156":6,"159":2,"651":1}}],["leaving",{"2":{"485":1}}],["leafs",{"2":{"646":1}}],["leaf",{"2":{"142":2,"147":2,"152":2,"159":2}}],["least",{"2":{"23":1,"35":1,"39":1,"82":1,"84":1,"211":1,"279":2,"371":1,"449":1,"546":1,"633":1,"643":1,"645":1,"652":2}}],["lead",{"2":{"13":1,"14":1,"37":1}}],["leaders",{"2":{"6":1,"8":2,"10":2,"11":1,"12":1}}],["learned",{"2":{"32":1,"298":1,"305":1,"565":1}}],["learning",{"2":{"3":1,"7":1,"40":1,"42":2,"457":1,"573":1}}],["learn",{"2":{"3":1,"40":1,"46":1,"50":1,"63":1,"73":1,"79":1,"81":2,"86":1,"94":1,"107":1,"113":1,"125":1,"137":1,"163":1,"227":1,"236":1,"250":1,"251":1,"261":1,"283":1,"297":1,"304":1,"311":1,"312":2,"341":1,"343":1,"388":1,"404":1,"433":1,"486":1,"497":1,"500":1,"515":1,"524":1,"530":1,"533":1,"547":1,"556":1,"557":1,"560":1,"564":1,"567":1,"573":1,"580":1,"588":1,"597":1,"600":1,"653":1,"670":1,"676":2,"679":2,"680":1,"691":1,"692":1,"706":1,"716":1,"718":1,"719":1,"727":1,"740":1,"748":1,"765":2}}],["lost",{"2":{"334":1,"391":1}}],["lose",{"2":{"281":1,"308":1}}],["loses",{"2":{"23":1}}],["locked",{"2":{"682":1,"784":2}}],["lock",{"2":{"328":1,"584":1}}],["located",{"2":{"127":1,"247":1,"322":1,"424":1,"469":1}}],["locate",{"2":{"125":1,"478":1}}],["locations",{"2":{"342":1}}],["location",{"0":{"327":1},"1":{"328":1,"329":1,"330":1,"331":1,"332":1,"333":1},"2":{"23":1,"26":1,"35":2,"58":1,"125":2,"127":1,"128":1,"172":1,"173":1,"174":3,"187":1,"260":4,"287":1,"322":1,"329":10,"343":1,"349":1,"450":1,"464":1,"744":1}}],["localroot",{"2":{"707":1}}],["localheadheight",{"2":{"560":1}}],["localhost",{"2":{"92":1,"93":3,"143":2,"144":2,"274":2,"275":4,"313":3,"326":3,"377":2,"477":6,"478":4,"479":4,"538":2,"539":2,"604":2,"709":2,"741":1,"767":1,"775":2,"778":2}}],["localized",{"2":{"158":1}}],["locally",{"2":{"81":1,"203":2,"212":1,"289":1,"320":1,"590":1}}],["local",{"0":{"211":1,"217":1,"284":1,"285":1,"472":1},"1":{"285":1,"286":2,"287":2,"288":2,"289":2,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1},"2":{"2":1,"34":1,"36":1,"37":2,"38":2,"39":3,"40":2,"47":1,"77":1,"79":1,"81":1,"87":1,"93":1,"94":1,"208":2,"211":5,"217":2,"235":1,"263":2,"283":1,"288":1,"291":2,"292":4,"297":1,"298":1,"305":1,"312":1,"320":1,"342":1,"343":2,"361":2,"371":1,"383":4,"392":2,"393":2,"399":21,"472":1,"474":2,"507":1,"586":2,"616":1,"627":4,"701":1,"707":1,"781":2}}],["loop",{"2":{"211":1}}],["looks",{"2":{"86":1,"747":1}}],["looking",{"2":{"42":1,"81":2,"93":1,"160":1,"227":1,"251":1,"371":1,"387":1,"388":1,"539":1,"767":1}}],["look",{"2":{"40":1,"92":1,"104":1,"122":1,"124":1,"144":2,"161":4,"163":2,"202":1,"294":1,"314":2,"337":1,"392":1,"393":1,"450":1,"478":1,"538":1,"539":1,"540":1,"643":1,"648":1,"652":1,"706":1,"707":1,"737":1,"744":1,"747":1,"750":1,"757":1}}],["load",{"2":{"77":1,"379":1,"380":1,"381":1,"599":2,"700":1,"771":2,"772":3,"773":2}}],["logfile",{"2":{"343":1}}],["log=debug",{"2":{"215":2}}],["log",{"2":{"147":2,"275":1,"294":2,"322":1,"336":1,"337":2,"343":2,"373":1,"429":2,"571":1,"616":2,"622":3,"767":1,"771":2}}],["logging",{"2":{"95":1}}],["logged",{"2":{"90":1}}],["logsbloom",{"2":{"538":2}}],["logs",{"0":{"271":1},"2":{"79":1,"93":1,"210":1,"211":1,"271":7,"294":2,"331":1,"337":1,"371":1,"541":1,"542":1,"559":1,"561":1,"604":1,"606":1,"607":1,"608":1,"616":2,"622":2}}],["logos",{"2":{"41":1}}],["logo",{"2":{"38":1,"41":1,"52":1,"785":1}}],["login",{"2":{"275":1}}],["logic",{"2":{"109":2,"112":1,"126":1,"179":1,"214":1,"229":2,"238":1,"584":1,"648":1}}],["logical",{"2":{"37":1}}],["logistics",{"0":{"33":1,"57":1},"1":{"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1},"2":{"30":1,"33":1,"37":1}}],["lowers",{"2":{"86":1}}],["lower",{"2":{"86":2}}],["low",{"2":{"26":1,"137":1,"400":1,"454":1,"609":1,"784":2,"786":1}}],["lot",{"2":{"26":1,"33":1,"34":1,"51":1,"199":1}}],["longer",{"2":{"86":1,"277":1,"546":1,"629":1,"645":1,"690":1,"722":1}}],["long",{"2":{"22":1,"87":1,"643":1,"673":1,"674":1,"677":1}}],["love",{"2":{"2":1,"42":1}}],["ll",{"2":{"0":1,"35":1,"50":1,"57":1,"58":1,"76":1,"77":1,"79":1,"84":1,"86":1,"87":1,"94":1,"109":1,"298":1,"329":1,"371":1,"373":1,"383":1,"392":1,"408":1,"446":1,"538":1,"542":3,"557":1,"558":1,"559":2,"560":2,"561":1,"564":4,"565":2,"586":1,"622":1,"627":1,"629":1,"706":1,"707":1,"740":1,"765":4,"775":1,"785":1,"786":1}}],["wget",{"2":{"378":2,"398":10,"399":8}}],["wsl",{"2":{"396":2}}],["ws",{"2":{"254":1,"429":4,"492":2,"709":2,"775":2,"778":2}}],["wss",{"0":{"254":1},"2":{"90":6,"91":6,"254":1,"492":4}}],["w",{"2":{"214":2,"773":4,"774":2}}],["wrong",{"0":{"336":1,"383":1,"627":1},"2":{"336":2,"383":2,"627":2}}],["wrapped",{"2":{"215":1,"459":1}}],["wrappers",{"2":{"163":2}}],["wrapper",{"2":{"144":4,"161":2,"211":2,"214":4,"215":2}}],["wrapping",{"0":{"775":1},"2":{"126":1}}],["wraps",{"2":{"126":2,"214":1}}],["writing",{"2":{"126":2,"134":1,"569":1,"570":1}}],["write",{"0":{"525":1},"2":{"33":1,"291":2,"525":2,"536":1,"707":1,"765":1}}],["written",{"2":{"12":1,"221":1,"399":1,"455":2}}],["won",{"2":{"90":1,"91":1,"183":1,"208":1,"371":1,"544":1,"552":1}}],["wonderful",{"2":{"33":1}}],["worry",{"2":{"109":1,"388":1}}],["world",{"2":{"43":1,"480":1,"598":4,"710":4,"765":1,"779":4}}],["words",{"2":{"120":1,"174":1,"216":1,"557":1,"564":1,"636":1,"649":1}}],["word",{"2":{"36":1,"39":1}}],["workshop",{"0":{"53":1,"54":1,"55":1,"56":1}}],["workshops",{"2":{"34":1,"37":1}}],["works",{"0":{"234":1},"2":{"35":2,"96":1,"295":1,"321":1,"591":1,"593":1,"594":1,"632":1,"676":1,"691":1}}],["working",{"0":{"444":1,"445":1},"2":{"30":1,"34":2,"274":1,"341":1,"413":1,"444":1,"456":1,"566":1,"699":2}}],["work",{"2":{"21":1,"23":1,"35":1,"68":1,"122":1,"134":1,"169":1,"371":1,"526":1,"579":1,"646":1,"720":1,"767":1}}],["wouldn",{"2":{"634":1}}],["would",{"2":{"34":1,"39":1,"42":5,"63":1,"104":1,"122":1,"124":1,"126":9,"127":1,"130":3,"183":2,"185":1,"191":2,"194":1,"203":1,"225":1,"226":1,"266":1,"284":1,"294":1,"314":1,"326":1,"361":1,"373":1,"388":1,"390":2,"425":1,"486":1,"501":2,"542":1,"586":1,"709":1,"728":1,"733":2,"738":1,"744":1,"757":1,"778":1,"784":1}}],["www",{"2":{"16":3,"64":1,"487":1,"505":1}}],["walks",{"2":{"472":1}}],["walkthrough",{"0":{"394":1},"1":{"395":1}}],["wallet=",{"2":{"616":2,"622":2}}],["wallets",{"0":{"430":1,"466":1,"738":1},"1":{"467":1},"2":{"308":1,"430":3,"653":1,"694":1,"783":1}}],["wallet",{"0":{"261":1,"299":1,"306":1,"308":1,"309":1,"615":1,"654":1,"655":1,"660":1,"664":1,"665":1,"697":1,"783":1},"1":{"307":1,"308":1,"309":1,"656":1,"657":1,"658":1,"659":1,"661":1,"662":1,"663":1,"665":1,"666":1,"667":1,"668":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"707":1,"784":1,"785":1,"786":1},"2":{"77":1,"79":1,"80":1,"82":1,"85":3,"87":2,"202":6,"245":1,"265":1,"266":6,"267":2,"268":2,"269":4,"270":2,"272":1,"306":1,"308":3,"309":2,"367":1,"404":1,"422":1,"431":1,"466":1,"467":2,"524":1,"601":2,"615":1,"616":8,"622":4,"684":2,"685":1,"697":1,"724":1,"726":1,"728":1,"738":5,"784":5,"785":2,"786":2}}],["wanting",{"2":{"726":1}}],["want",{"2":{"202":9,"203":1,"205":1,"208":1,"210":1,"213":1,"219":1,"266":1,"274":2,"308":1,"321":1,"352":2,"361":1,"367":2,"368":2,"373":1,"386":1,"429":1,"439":2,"443":1,"448":1,"501":1,"552":1,"557":1,"559":1,"560":1,"561":2,"564":1,"567":1,"574":1,"580":1,"583":1,"594":1,"599":4,"601":1,"616":2,"622":2,"632":1,"640":1,"700":1,"713":2,"728":1,"740":2,"781":2,"785":1}}],["wantedby=multi",{"2":{"604":2,"606":2,"607":2,"608":2}}],["wanted",{"2":{"147":2,"294":2,"616":2,"622":2}}],["wants",{"2":{"136":1,"443":1}}],["waiting",{"2":{"93":6,"126":1,"128":1,"130":3,"171":2,"599":2,"767":1}}],["wait",{"2":{"91":1,"109":1,"130":1,"163":2,"211":1,"309":1,"594":1,"599":2,"662":1,"767":1}}],["watchopts",{"2":{"162":2}}],["watchdatacommitmentstored",{"2":{"162":3}}],["watch",{"2":{"40":1}}],["water",{"2":{"35":2}}],["warn\\tnode\\tnodebuilder",{"2":{"559":2}}],["warn",{"2":{"277":1}}],["warning",{"0":{"13":1},"2":{"12":1,"13":1,"60":1,"65":1,"69":1,"91":1,"152":1,"153":1,"326":1,"338":1,"456":1,"487":1,"489":1,"505":1,"512":1,"530":1,"728":1,"733":1}}],["warehouse",{"2":{"64":1,"487":1,"505":1}}],["warm",{"2":{"39":1}}],["way",{"2":{"38":1,"60":1,"84":1,"110":1,"140":1,"166":1,"169":2,"170":1,"171":1,"172":1,"183":2,"191":1,"199":1,"203":2,"204":1,"266":1,"275":1,"291":2,"308":1,"312":1,"342":1,"388":2,"457":1,"459":1,"461":1,"564":1,"639":1,"642":1,"722":1,"727":2,"765":1}}],["ways",{"2":{"6":1,"165":1,"230":1,"455":1,"500":1,"515":1,"533":1,"556":1,"573":1,"582":1,"595":1,"723":1,"727":1}}],["wasm",{"2":{"96":1}}],["was",{"0":{"144":1},"2":{"12":1,"81":1,"83":1,"93":5,"111":1,"121":1,"122":5,"124":1,"128":1,"130":1,"136":1,"137":1,"139":2,"144":6,"154":6,"155":1,"160":7,"163":2,"164":1,"168":2,"174":1,"180":1,"186":1,"187":1,"191":1,"194":1,"204":2,"205":1,"208":1,"214":1,"215":2,"233":1,"287":1,"289":1,"311":1,"331":1,"372":1,"383":1,"399":1,"431":1,"455":1,"462":1,"532":1,"580":1,"598":2,"599":4,"604":1,"606":1,"607":1,"608":1,"616":1,"627":1,"629":1,"646":1,"651":1,"652":1,"706":1,"710":3,"745":1,"747":2,"748":1,"773":1,"779":3}}],["windows",{"2":{"389":1,"396":2}}],["window",{"2":{"281":1,"426":1,"609":1,"610":1,"611":1,"673":5,"706":1,"707":1,"767":1,"784":8}}],["wise",{"2":{"651":1}}],["wish",{"2":{"216":1,"227":1,"590":1,"594":1,"674":1}}],["wisdom",{"2":{"50":1}}],["wiki",{"2":{"8":1}}],["willingness",{"2":{"594":1}}],["willing",{"2":{"592":1,"724":1}}],["will",{"2":{"8":2,"10":1,"11":1,"20":2,"21":2,"22":3,"23":2,"25":2,"26":1,"27":1,"28":1,"34":1,"35":1,"36":2,"37":1,"38":1,"41":1,"42":3,"44":1,"46":1,"47":2,"60":2,"63":1,"67":1,"68":2,"74":1,"79":1,"80":2,"81":2,"84":1,"85":2,"86":1,"87":2,"88":1,"90":3,"91":3,"92":3,"93":1,"104":1,"105":2,"109":5,"117":2,"124":1,"125":1,"126":3,"130":1,"136":1,"139":1,"140":1,"141":1,"144":2,"145":1,"152":1,"153":1,"154":5,"156":1,"161":2,"163":4,"165":1,"166":2,"168":1,"169":4,"171":1,"172":1,"174":4,"175":2,"183":1,"186":1,"187":1,"188":1,"190":1,"191":2,"193":1,"194":3,"200":1,"202":2,"203":2,"204":5,"208":1,"210":3,"214":1,"215":3,"216":1,"219":2,"221":1,"228":4,"235":3,"237":1,"243":1,"244":1,"245":2,"263":3,"266":1,"275":6,"279":2,"281":8,"283":1,"287":3,"290":1,"291":1,"294":2,"295":1,"296":1,"297":2,"301":3,"302":1,"303":1,"306":1,"310":1,"311":4,"312":3,"314":3,"315":1,"316":3,"321":3,"324":2,"326":1,"329":1,"331":2,"332":1,"334":1,"337":1,"338":2,"341":2,"342":2,"343":1,"349":1,"355":1,"361":1,"363":1,"367":1,"368":3,"370":2,"371":1,"375":1,"380":2,"381":2,"391":4,"392":1,"393":1,"397":1,"399":1,"404":4,"405":1,"413":1,"414":1,"422":2,"426":1,"429":1,"430":1,"438":1,"440":1,"441":1,"442":1,"445":2,"446":1,"449":3,"450":3,"458":2,"464":2,"466":2,"474":1,"477":1,"478":1,"481":2,"486":1,"494":1,"495":1,"501":1,"506":1,"507":1,"518":1,"520":1,"526":1,"530":4,"538":1,"539":1,"540":1,"541":1,"542":2,"544":1,"545":1,"546":1,"552":1,"554":1,"557":1,"559":2,"560":1,"561":1,"568":1,"574":1,"582":2,"588":2,"589":1,"594":3,"599":4,"601":1,"604":1,"606":1,"607":2,"608":3,"609":1,"612":1,"616":1,"622":2,"629":2,"630":1,"632":1,"633":1,"639":1,"640":1,"652":1,"653":1,"656":1,"658":1,"659":1,"663":1,"668":1,"671":1,"672":1,"673":5,"674":2,"676":1,"681":1,"682":4,"694":1,"697":2,"699":1,"700":4,"706":1,"707":2,"708":1,"709":1,"711":2,"712":2,"722":3,"728":1,"730":1,"733":1,"736":1,"737":1,"738":2,"739":2,"740":1,"741":1,"742":3,"743":1,"744":1,"745":5,"747":6,"748":3,"750":1,"751":1,"754":3,"757":1,"762":3,"767":4,"768":1,"770":1,"771":2,"772":2,"773":3,"775":3,"777":1,"778":1,"780":4,"784":4,"785":1,"786":1}}],["withcancel",{"2":{"772":2,"773":2,"775":2}}],["withfeegranteraddress",{"2":{"710":1}}],["withsigneraddress",{"2":{"710":1}}],["withkeyname",{"2":{"710":1}}],["withgas",{"2":{"710":1}}],["withgasprice",{"2":{"710":2}}],["withheld",{"2":{"630":1}}],["withhold",{"2":{"630":1,"652":1}}],["withholding",{"2":{"630":1}}],["withtransportcredentials",{"2":{"599":2}}],["withdraw",{"0":{"79":1},"2":{"268":2}}],["withdrawalsroot",{"2":{"538":2}}],["withdrawals",{"2":{"86":1}}],["withdrawal",{"0":{"78":1,"80":1},"1":{"79":1,"80":1},"2":{"23":1,"74":2,"79":2,"80":2}}],["within",{"2":{"9":1,"15":1,"20":1,"23":4,"34":1,"37":1,"44":1,"58":1,"86":1,"396":1,"609":1,"610":1,"670":1,"673":3,"740":1}}],["without",{"2":{"7":1,"90":1,"109":1,"137":1,"170":1,"294":1,"388":1,"390":1,"402":1,"406":1,"496":1,"544":1,"582":1,"631":1,"632":1,"642":1,"650":1,"674":1,"682":1,"709":1,"743":1,"778":1}}],["with",{"0":{"66":1,"94":1,"105":1,"106":1,"114":1,"123":1,"228":1,"229":1,"246":1,"248":1,"250":1,"271":1,"283":1,"306":1,"391":1,"423":1,"425":1,"468":1,"470":1,"518":1,"519":1,"542":1,"562":1,"568":1,"602":1,"604":1,"621":1,"655":1,"660":1,"664":1,"697":1,"746":1,"783":1,"784":1},"1":{"67":1,"68":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"229":1,"230":1,"231":1,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"392":1,"393":1,"424":1,"469":1,"520":1,"521":1,"543":1,"544":1,"545":1,"546":1,"547":1,"563":1,"564":1,"565":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1,"656":1,"657":1,"658":1,"659":1,"661":1,"662":1,"663":1,"665":1,"666":1,"667":1,"668":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"707":1,"784":1,"785":1,"786":1},"2":{"1":1,"2":1,"3":3,"13":3,"14":3,"23":2,"24":1,"25":1,"26":2,"30":2,"31":1,"32":2,"34":5,"36":5,"37":7,"38":2,"39":2,"40":5,"41":3,"42":1,"43":1,"44":1,"47":1,"48":2,"49":1,"55":1,"57":1,"58":1,"59":1,"60":1,"65":3,"68":4,"70":1,"81":1,"82":1,"84":1,"86":2,"87":1,"90":2,"91":2,"93":6,"96":5,"103":1,"104":2,"107":1,"108":2,"109":3,"110":2,"111":2,"112":1,"122":3,"126":3,"130":1,"134":1,"136":1,"139":1,"142":1,"144":2,"147":1,"150":1,"152":1,"156":2,"157":1,"158":1,"159":1,"160":6,"161":2,"163":2,"164":1,"165":1,"166":1,"172":1,"175":1,"178":1,"183":1,"202":1,"203":1,"208":1,"210":1,"214":1,"216":1,"217":1,"218":2,"219":1,"221":2,"225":1,"227":3,"228":1,"229":3,"231":1,"233":3,"238":3,"244":2,"245":2,"248":2,"249":3,"250":1,"252":2,"254":1,"260":2,"266":6,"268":1,"269":2,"270":1,"271":1,"275":5,"277":1,"278":1,"279":2,"281":1,"287":1,"294":2,"304":1,"309":1,"310":1,"311":1,"312":2,"313":1,"314":2,"316":1,"322":1,"325":1,"326":1,"329":3,"334":1,"335":1,"338":2,"341":2,"342":1,"355":1,"361":1,"363":1,"367":1,"373":1,"377":1,"383":1,"385":3,"390":1,"393":1,"396":1,"400":2,"402":1,"403":2,"404":2,"405":1,"422":4,"425":1,"428":1,"430":1,"437":1,"439":2,"443":1,"446":1,"448":3,"449":2,"450":2,"452":4,"453":1,"454":2,"455":2,"457":1,"459":1,"461":1,"465":2,"466":3,"470":1,"471":1,"472":1,"474":2,"478":1,"481":2,"485":1,"487":1,"489":1,"495":2,"505":1,"508":1,"509":2,"510":1,"512":1,"517":1,"518":1,"520":1,"524":1,"526":2,"528":1,"530":1,"538":1,"542":2,"544":1,"546":4,"547":1,"554":1,"560":1,"561":1,"565":1,"566":1,"567":1,"569":1,"570":1,"573":1,"577":1,"580":1,"583":1,"584":2,"586":1,"588":1,"589":1,"592":1,"594":2,"601":1,"609":1,"617":1,"621":2,"622":1,"627":2,"630":1,"634":1,"635":1,"636":1,"641":1,"643":2,"644":1,"645":6,"646":2,"648":1,"649":1,"650":1,"651":4,"652":3,"656":1,"670":1,"671":1,"676":1,"683":1,"691":1,"695":1,"697":1,"700":1,"705":1,"706":3,"707":5,"708":1,"710":2,"711":2,"712":2,"716":1,"717":1,"719":1,"720":1,"723":2,"726":2,"727":2,"737":3,"738":4,"739":1,"740":5,"741":1,"742":3,"743":2,"744":2,"745":2,"747":1,"750":1,"757":1,"762":2,"764":1,"765":2,"767":2,"768":2,"771":2,"772":5,"773":6,"775":6,"776":1,"777":1,"779":2}}],["whole",{"2":{"643":1}}],["whom",{"2":{"151":1}}],["whose",{"2":{"147":1,"202":2}}],["who",{"0":{"640":1},"2":{"21":1,"23":1,"37":1,"39":2,"40":3,"58":1,"250":1,"443":1,"450":1,"552":1,"724":1,"728":1,"744":1}}],["whitelist",{"0":{"206":1},"2":{"205":1,"206":3}}],["whitelisting",{"0":{"205":1},"2":{"202":1,"205":2,"586":1}}],["whitelisted",{"2":{"202":1}}],["whiteboard",{"2":{"34":1}}],["whiteboards",{"2":{"30":1,"34":1}}],["while",{"2":{"18":1,"35":1,"93":1,"156":1,"165":1,"221":1,"227":1,"322":1,"337":4,"455":2,"481":1,"542":1,"549":1,"644":1,"649":1,"652":1,"674":1,"697":1,"717":1,"722":1,"757":1,"767":1,"780":2}}],["which",{"0":{"384":1},"1":{"385":1,"386":1,"387":1},"2":{"7":1,"26":1,"35":1,"41":1,"42":1,"63":1,"85":1,"86":3,"88":1,"90":2,"91":1,"92":1,"97":1,"104":1,"108":1,"109":1,"110":3,"111":3,"112":2,"122":1,"125":1,"126":2,"128":1,"137":2,"139":4,"141":1,"142":1,"147":1,"149":1,"151":1,"152":1,"154":2,"156":2,"157":1,"158":1,"160":5,"166":1,"168":1,"174":1,"179":1,"180":1,"184":1,"187":1,"191":1,"193":1,"194":1,"199":1,"202":3,"204":3,"205":1,"206":3,"211":2,"213":2,"214":3,"215":2,"218":1,"219":1,"221":2,"224":1,"225":1,"234":1,"235":1,"243":1,"244":1,"245":1,"266":1,"275":2,"309":1,"311":1,"314":1,"321":1,"324":1,"370":1,"377":2,"380":2,"384":1,"387":1,"390":1,"414":1,"422":2,"427":1,"428":1,"438":1,"450":2,"452":1,"453":1,"455":1,"458":1,"465":2,"485":4,"486":1,"501":1,"509":3,"526":3,"527":1,"528":1,"541":1,"564":1,"568":1,"591":1,"604":2,"606":2,"607":2,"608":2,"619":1,"624":1,"630":1,"638":1,"639":1,"649":1,"670":2,"674":1,"676":1,"692":1,"700":1,"706":1,"710":1,"717":1,"723":1,"727":1,"728":1,"737":1,"745":4,"747":4,"748":1,"750":1,"773":2,"774":1}}],["why",{"0":{"634":1,"639":1},"2":{"12":1,"26":1,"42":5,"58":1,"214":1,"526":1}}],["whenever",{"2":{"39":1,"400":1,"501":1}}],["when",{"2":{"8":1,"9":1,"36":1,"42":1,"44":1,"58":1,"90":1,"91":2,"109":2,"137":1,"139":1,"144":2,"157":1,"161":2,"163":2,"169":1,"175":1,"179":1,"186":1,"187":2,"205":1,"214":1,"219":1,"266":1,"274":2,"275":2,"313":1,"320":1,"325":1,"326":1,"329":1,"331":1,"332":1,"333":1,"337":2,"361":2,"378":1,"380":2,"392":1,"408":1,"449":1,"455":1,"467":1,"546":1,"558":1,"560":2,"566":1,"567":1,"568":1,"592":1,"593":1,"629":2,"630":1,"646":1,"682":1,"706":1,"709":1,"716":1,"738":1,"740":1,"741":1,"778":1}}],["whereas",{"2":{"86":1}}],["where",{"0":{"638":1},"2":{"7":1,"70":1,"109":2,"110":1,"127":1,"147":1,"154":2,"158":1,"201":1,"210":1,"211":1,"238":1,"261":1,"303":2,"333":1,"338":1,"426":1,"467":1,"480":1,"512":1,"560":1,"586":1,"588":1,"590":1,"591":1,"592":1,"609":1,"634":1,"645":1,"651":1,"659":1,"663":1,"668":1,"673":1,"674":3,"736":1,"738":1,"740":1,"765":1,"767":1}}],["whether",{"2":{"2":1,"36":1,"381":1,"609":1,"630":1,"636":1,"642":1,"784":3}}],["whatever",{"2":{"308":1,"573":1}}],["what",{"0":{"221":1,"227":1,"233":1,"579":1,"580":1,"629":1,"630":1,"632":1,"633":1,"635":1,"636":1,"637":1,"641":1},"1":{"222":1},"2":{"7":1,"21":1,"42":4,"53":1,"54":1,"55":1,"59":1,"79":1,"87":1,"124":1,"127":1,"130":1,"174":1,"211":2,"312":1,"316":1,"343":1,"399":1,"558":1,"574":1,"672":1,"744":1,"747":1,"757":1,"775":2}}],["went",{"2":{"616":1}}],["weak",{"2":{"371":1,"636":1}}],["we+s5gft6g944xbkvvygqb9oy+u",{"2":{"291":2,"292":2}}],["weth",{"2":{"93":2}}],["week",{"2":{"70":1,"512":1,"528":1,"530":1}}],["weeks",{"2":{"39":1,"208":1,"369":1,"370":1}}],["webrtc",{"2":{"478":10}}],["webhook",{"2":{"277":1}}],["websocket",{"0":{"492":1},"2":{"90":5,"136":2,"143":2,"144":2,"429":4,"492":4}}],["websites",{"2":{"499":1,"513":1}}],["website",{"2":{"26":1,"40":1,"90":1,"784":2}}],["web",{"0":{"71":1},"2":{"71":1,"275":1}}],["web3",{"2":{"42":1,"44":1}}],["were",{"2":{"16":1,"122":5,"154":6,"155":1,"216":1,"227":1,"682":1,"776":1}}],["well",{"2":{"13":1,"34":1,"35":2,"58":2,"109":1,"110":1,"202":1,"422":1,"428":1,"542":1,"584":1,"672":1,"720":1,"724":1}}],["welcoming",{"2":{"6":1,"34":1,"46":1}}],["welcome",{"2":{"0":1,"20":1,"31":1,"41":2,"42":1,"43":1,"48":1,"51":1,"480":1,"557":1,"765":1}}],["we",{"2":{"2":1,"4":1,"6":2,"23":1,"34":1,"42":8,"46":2,"58":2,"59":1,"85":2,"86":1,"90":1,"105":1,"109":1,"117":2,"122":1,"125":4,"126":3,"127":1,"130":4,"137":1,"139":5,"141":1,"144":2,"145":1,"154":5,"155":2,"156":6,"159":1,"161":2,"163":4,"164":1,"169":1,"172":1,"173":1,"174":4,"175":5,"186":1,"202":4,"204":4,"205":1,"208":2,"209":2,"210":10,"211":1,"214":1,"215":1,"266":2,"275":1,"277":2,"283":1,"287":1,"297":1,"298":2,"301":4,"306":1,"308":1,"316":1,"321":1,"329":1,"344":2,"350":1,"375":1,"392":2,"399":1,"429":1,"430":2,"432":1,"434":1,"435":2,"445":2,"446":1,"456":1,"481":1,"501":1,"507":1,"538":1,"546":2,"557":1,"558":1,"561":2,"563":2,"564":2,"568":2,"583":1,"586":1,"594":1,"599":12,"607":1,"672":1,"699":1,"706":1,"707":2,"711":1,"712":1,"716":1,"717":2,"718":1,"719":1,"721":1,"722":1,"730":1,"740":1,"745":6,"747":2,"750":1,"754":1,"762":1,"765":1,"767":3,"771":4,"772":8,"773":26,"774":1,"775":11,"780":3,"784":5}}],["dns",{"2":{"762":1}}],["dns4",{"2":{"65":4}}],["d85c907ce660878a8203ac74baa147ccc1f87114b45b568b72ad207b62afe45e",{"2":{"754":2}}],["d6",{"2":{"646":1}}],["d5",{"2":{"646":2}}],["d4",{"2":{"646":2}}],["d3",{"2":{"646":1}}],["dynamic",{"2":{"583":1,"591":1,"592":1}}],["dl",{"2":{"399":8}}],["db",{"2":{"383":1,"627":1}}],["dbs",{"2":{"383":1,"627":1}}],["dbbackend",{"2":{"380":1}}],["d7wrs",{"2":{"147":2}}],["dcproof",{"2":{"143":2,"144":2}}],["dfcelestia",{"2":{"104":1}}],["drop",{"2":{"594":1,"681":1}}],["dropped",{"2":{"594":1}}],["dropdown",{"2":{"76":1}}],["drafted",{"2":{"484":1}}],["drawing",{"2":{"50":1}}],["drift",{"2":{"429":4}}],["drinks",{"2":{"35":4}}],["d",{"2":{"41":2,"91":1,"92":1,"130":4,"283":1,"288":1,"294":2,"372":6,"540":2,"542":1,"598":2,"681":1,"682":2,"710":2,"711":4,"712":4,"757":1,"763":1,"773":4}}],["dah",{"2":{"754":2,"755":2,"760":2}}],["daemon",{"2":{"328":1,"337":3,"602":1,"604":6,"606":3,"607":3,"608":4,"617":1}}],["darwin",{"2":{"312":1,"342":1,"399":12}}],["daring",{"2":{"291":2}}],["dac",{"2":{"225":1,"226":1}}],["dacs",{"0":{"223":1},"1":{"224":1,"225":1,"226":1},"2":{"224":1,"226":2}}],["daverifier",{"0":{"154":1,"163":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1},"2":{"122":3,"154":1,"163":11,"174":1}}],["daser",{"2":{"338":1,"560":1}}],["das",{"0":{"643":1},"1":{"644":1,"645":1},"2":{"110":1,"221":1,"458":1,"459":1,"557":2,"558":1,"561":1,"608":1,"632":1,"642":2,"643":2,"644":4,"645":1,"652":4,"756":2}}],["dashboard",{"2":{"68":1,"275":5,"321":1,"495":2,"656":2,"657":1,"659":1,"663":1}}],["dashboards",{"2":{"23":1,"275":1,"622":1,"676":1}}],["dao",{"2":{"86":1}}],["da",{"0":{"66":1,"67":1,"68":1,"106":1,"109":1,"220":1,"386":1,"494":1,"495":1,"496":1,"504":1,"506":1,"507":1,"647":1},"1":{"67":1,"68":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1,"497":1,"505":1,"506":1,"507":1,"648":1},"2":{"65":5,"67":1,"68":5,"91":3,"96":1,"105":1,"108":2,"109":1,"112":1,"113":1,"124":1,"126":4,"127":1,"130":1,"178":2,"186":1,"221":2,"227":3,"238":1,"250":1,"338":1,"349":1,"386":1,"400":1,"403":1,"404":4,"454":1,"455":8,"458":1,"459":1,"479":2,"494":1,"495":7,"496":1,"506":1,"507":2,"511":8,"540":2,"542":1,"545":1,"546":1,"547":1,"557":2,"561":2,"564":3,"565":2,"568":1,"573":1,"642":3,"644":2,"646":4,"648":3,"649":6,"652":5,"698":1,"716":1,"724":2,"726":2,"728":1,"732":1}}],["day",{"2":{"39":1,"673":2}}],["days",{"2":{"35":1,"281":1,"673":2}}],["dat2024",{"2":{"214":1}}],["dat",{"2":{"214":31}}],["database",{"2":{"571":2}}],["datastore",{"0":{"322":1},"2":{"322":5}}],["datasharelen",{"2":{"125":4}}],["datasharestart",{"2":{"125":4}}],["datalen",{"2":{"172":2,"174":1}}],["datahash",{"2":{"144":2,"163":2}}],["datacommitmentstored",{"2":{"208":1,"219":1}}],["datacommitment",{"2":{"144":2,"161":2}}],["datarootinclusionproof",{"2":{"143":2,"144":2,"160":9,"163":10}}],["dataroot",{"2":{"118":4,"139":2,"144":2,"160":5,"163":2}}],["dataroottupleroot",{"2":{"141":1}}],["dataroottuples",{"2":{"119":5,"120":1}}],["dataroottuple",{"2":{"118":4,"119":2,"120":1,"122":1,"141":1,"144":2,"154":2,"160":7,"163":2}}],["dataavailabilityprovider",{"2":{"109":2}}],["data",{"0":{"67":1,"68":1,"119":1,"122":1,"127":1,"133":1,"141":1,"155":1,"162":1,"174":1,"175":1,"199":1,"216":1,"223":1,"335":1,"365":1,"471":1,"493":1,"494":1,"495":1,"506":1,"507":1,"535":1,"539":1,"540":1,"562":1,"564":1,"565":1,"587":1,"605":1,"628":1,"629":1,"630":1,"631":1,"632":1,"633":1,"635":1,"636":1,"637":2,"639":1,"640":1,"641":1,"642":1,"643":1,"645":1,"648":1,"652":1,"672":1,"673":1,"713":1,"745":1,"747":1,"756":1,"781":1},"1":{"142":1,"143":1,"217":1,"218":1,"219":1,"224":1,"225":1,"226":1,"494":1,"495":1,"496":1,"497":1,"563":1,"564":1,"565":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"606":1,"607":1,"608":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"640":1,"641":1,"643":1,"644":2,"645":2,"646":1,"647":1,"648":1,"673":1,"674":1,"746":1},"2":{"26":1,"37":1,"42":1,"53":1,"64":1,"65":1,"81":1,"85":5,"90":3,"91":1,"107":2,"109":10,"110":8,"111":5,"112":6,"118":5,"119":1,"120":1,"121":1,"122":8,"124":2,"125":31,"126":7,"127":7,"128":16,"130":10,"133":1,"136":1,"137":5,"139":9,"141":6,"142":2,"144":10,"145":3,"147":5,"149":1,"151":3,"152":2,"154":14,"155":2,"157":1,"158":1,"159":1,"160":31,"162":2,"163":14,"164":3,"165":4,"167":2,"168":8,"169":3,"170":2,"172":9,"173":1,"174":7,"175":19,"178":2,"179":7,"180":1,"182":2,"183":3,"186":2,"187":8,"190":1,"191":5,"194":5,"199":6,"214":9,"221":3,"224":2,"225":4,"226":2,"227":5,"228":1,"231":1,"233":1,"237":1,"238":3,"250":2,"252":1,"275":4,"294":2,"315":1,"316":1,"321":2,"322":7,"332":2,"335":1,"336":1,"337":4,"342":1,"363":1,"365":2,"368":3,"369":2,"372":19,"375":1,"376":2,"383":1,"385":3,"391":3,"400":2,"402":1,"412":1,"414":1,"415":1,"454":2,"455":14,"458":2,"459":1,"481":1,"487":1,"496":5,"501":1,"505":1,"533":5,"539":1,"542":5,"544":2,"557":6,"560":1,"561":1,"563":1,"564":6,"565":11,"571":3,"580":3,"583":2,"587":2,"596":2,"597":2,"599":8,"600":1,"601":2,"608":1,"616":2,"617":2,"622":2,"627":2,"629":11,"630":7,"631":7,"632":9,"633":2,"634":6,"635":4,"636":6,"637":4,"638":3,"639":9,"640":4,"641":6,"642":5,"643":11,"644":3,"645":11,"646":14,"648":5,"649":2,"650":6,"651":15,"652":9,"670":9,"672":7,"673":7,"674":12,"689":1,"690":1,"713":1,"719":3,"720":1,"730":2,"732":1,"733":3,"736":1,"745":9,"747":10,"754":2,"762":4,"765":3,"771":2,"772":2,"773":5,"775":5,"779":2,"781":1}}],["date",{"2":{"25":1,"30":1,"341":1,"532":1}}],["dumps",{"2":{"699":2}}],["dummy",{"2":{"214":3}}],["dubbing",{"2":{"648":1}}],["duty",{"2":{"291":2}}],["dues",{"2":{"41":4}}],["due",{"2":{"23":1,"58":1,"91":1,"324":1,"400":1,"591":1,"594":1,"642":1,"649":1,"652":1,"682":1}}],["duration",{"2":{"22":3,"27":1}}],["during",{"0":{"31":1},"2":{"14":1,"22":1,"24":1,"31":1,"35":1,"38":1,"160":1,"214":1,"227":1,"281":1,"312":1,"322":1,"352":1,"355":1,"373":1,"406":1,"517":1,"526":1,"609":1,"622":1,"633":1}}],["domain",{"2":{"762":1}}],["dos",{"2":{"726":1}}],["double",{"2":{"281":2,"334":1,"558":1}}],["doing",{"2":{"130":1,"156":1,"312":1,"343":1,"537":1,"558":1,"580":1}}],["downside",{"2":{"645":1}}],["down",{"2":{"349":1,"528":1,"559":2,"564":1,"565":1,"593":1,"699":1,"785":1,"786":1}}],["downtime",{"2":{"112":1,"281":1,"400":2}}],["downloads",{"2":{"275":1,"341":1,"369":4,"372":1}}],["downloading",{"0":{"130":1},"2":{"130":1,"203":1,"398":1,"631":1,"645":2}}],["downloaded",{"0":{"213":1},"1":{"214":1,"215":1},"2":{"88":1,"89":1,"203":2,"211":1,"213":1,"214":1,"215":2,"369":1,"630":1,"674":1}}],["download",{"0":{"88":1},"2":{"87":1,"88":3,"126":1,"130":10,"203":2,"211":1,"214":16,"239":1,"284":1,"312":1,"342":1,"343":1,"357":1,"361":7,"369":1,"383":1,"399":1,"416":1,"460":1,"507":2,"613":1,"627":1,"629":3,"631":2,"632":1,"642":2,"643":1,"644":3,"645":1,"646":1,"648":1,"674":1,"722":1,"733":1,"734":1,"770":1}}],["do",{"0":{"631":1,"641":1},"2":{"42":1,"60":1,"65":1,"68":1,"84":1,"124":1,"159":1,"199":1,"204":1,"210":1,"216":1,"244":1,"245":1,"275":2,"307":1,"321":1,"322":2,"324":1,"368":1,"371":1,"377":1,"396":1,"400":1,"422":1,"426":1,"430":1,"432":1,"439":1,"444":1,"487":1,"489":1,"505":1,"507":1,"530":1,"560":2,"580":1,"590":1,"608":1,"631":1,"634":1,"672":1,"673":1,"674":1,"700":2,"706":1,"719":1,"737":1,"738":1,"772":1,"785":1}}],["dont",{"2":{"560":1}}],["done",{"2":{"93":10,"124":1,"127":1,"145":1,"155":1,"162":2,"175":2,"185":1,"240":1,"266":1,"358":1,"417":1,"443":1,"554":1,"561":2,"594":1,"610":1,"614":1,"711":2,"712":2}}],["don",{"2":{"26":1,"34":1,"39":1,"40":1,"79":1,"109":2,"202":2,"233":1,"299":1,"373":1,"380":1,"432":1,"525":1,"542":1,"582":1,"583":1,"584":1,"599":2,"622":1,"634":1,"639":1,"728":1}}],["docker",{"0":{"388":1,"704":1},"1":{"389":1,"390":1,"391":1,"392":1,"393":1,"394":1,"395":1,"396":1,"705":1,"706":1,"707":1},"2":{"82":2,"91":7,"92":2,"388":7,"389":4,"391":1,"392":2,"393":2,"541":2,"705":2,"706":3,"707":4}}],["docs",{"2":{"23":1,"64":2,"90":1,"104":2,"132":1,"163":1,"168":1,"228":1,"277":1,"280":1,"312":2,"321":1,"343":4,"371":1,"474":2,"487":2,"505":2,"547":1,"558":2,"600":1}}],["documented",{"2":{"162":1,"208":2}}],["documents",{"2":{"104":2}}],["document",{"2":{"22":1,"32":1,"139":1,"165":1,"200":1,"279":6,"484":1,"517":1,"585":1,"672":1,"715":1}}],["documentation",{"0":{"0":1,"131":1,"714":1,"782":1},"1":{"1":1,"2":1,"3":1,"4":1,"132":1,"133":1,"134":1},"2":{"0":1,"1":1,"3":1,"4":1,"23":1,"31":1,"63":1,"81":1,"95":1,"121":1,"122":1,"126":2,"127":3,"163":1,"175":2,"182":1,"202":1,"203":1,"208":1,"212":1,"217":1,"230":1,"234":1,"235":2,"261":2,"266":1,"274":2,"304":1,"486":1,"564":1,"568":1,"714":1,"718":1,"723":1,"782":1}}],["doesn",{"0":{"639":1},"2":{"136":1,"174":1,"199":1,"414":1,"428":1,"584":1,"741":1,"764":1}}],["does",{"0":{"638":1},"2":{"22":1,"26":1,"59":1,"69":1,"110":1,"201":1,"202":1,"287":1,"322":2,"396":1,"407":1,"408":2,"509":1,"512":1,"533":1,"590":1,"592":1,"594":1,"645":1,"651":1}}],["dimensional",{"2":{"643":1,"645":4,"648":1,"651":1}}],["dir",{"2":{"329":3}}],["directed",{"2":{"422":1,"465":1}}],["directories",{"2":{"322":2,"571":1,"674":1}}],["directory",{"0":{"3":1,"287":1,"444":1,"445":1},"2":{"76":1,"89":1,"94":1,"117":1,"246":1,"247":1,"272":1,"286":1,"287":4,"289":1,"311":1,"322":11,"336":1,"341":1,"343":5,"369":1,"372":1,"383":2,"391":4,"399":1,"423":1,"424":1,"444":2,"450":3,"466":2,"468":1,"469":1,"476":1,"544":1,"558":1,"571":2,"627":3,"699":2,"700":4,"707":5,"738":2,"741":1,"770":1,"771":1}}],["directly",{"0":{"601":1},"2":{"126":1,"130":2,"219":1,"225":1,"590":1,"592":1,"599":2,"601":1,"719":1,"743":1,"784":1}}],["direct",{"2":{"65":2,"68":1,"277":1,"478":10}}],["digest",{"2":{"156":9,"163":4,"214":2}}],["digital",{"2":{"7":1,"717":1}}],["dial",{"2":{"144":2,"161":2,"162":2,"163":2,"333":2,"378":1,"599":2}}],["diagram",{"2":{"139":1,"234":1,"677":1}}],["diagrams",{"2":{"3":1,"137":1}}],["did",{"2":{"42":2,"211":2}}],["difficulty",{"2":{"34":1,"36":1,"538":2}}],["difference",{"0":{"637":1},"2":{"104":1,"130":1,"175":1,"183":2,"194":1}}],["different",{"0":{"518":1,"519":1},"1":{"520":1,"521":1},"2":{"33":1,"63":1,"90":1,"91":1,"122":1,"130":1,"164":1,"173":2,"179":1,"182":1,"186":1,"197":1,"202":5,"216":3,"230":1,"233":1,"255":1,"266":1,"275":1,"301":1,"325":2,"329":2,"371":1,"378":1,"486":1,"517":2,"518":1,"520":1,"521":1,"533":1,"573":1,"574":1,"594":1,"638":2,"649":1,"682":1,"726":1,"767":1,"776":1}}],["differing",{"2":{"7":1}}],["div",{"2":{"784":4}}],["dividing",{"2":{"590":1}}],["divided",{"2":{"22":1,"25":1}}],["diving",{"0":{"566":1},"1":{"567":1,"568":1,"569":1,"570":1,"571":1}}],["dive",{"0":{"537":1},"1":{"538":1,"539":1,"540":1,"541":1},"2":{"537":1}}],["dives",{"2":{"42":1,"53":1}}],["diverse",{"2":{"6":1}}],["disruptions",{"2":{"400":1}}],["disruptive",{"2":{"18":1}}],["disk",{"2":{"239":1,"276":1,"357":1,"381":2,"416":1,"460":1,"535":1,"536":1,"613":1,"734":1}}],["disable",{"2":{"320":2,"754":2}}],["disables",{"2":{"320":1,"380":1}}],["disabled",{"2":{"206":1,"772":2,"773":2,"775":2}}],["disability",{"2":{"6":1}}],["distinguish",{"2":{"86":1}}],["distribution",{"2":{"69":1,"267":2,"268":2,"512":1,"717":1}}],["distributed",{"2":{"649":1}}],["distribute",{"2":{"21":1}}],["disputes",{"2":{"86":1,"649":1}}],["dispute",{"2":{"86":1,"580":1}}],["displaydenom",{"2":{"694":1}}],["displayed",{"2":{"263":1}}],["display",{"0":{"694":1},"2":{"86":1,"747":1}}],["displaying",{"2":{"31":1}}],["disparagement",{"2":{"15":1}}],["disqualify",{"2":{"23":1}}],["discard",{"0":{"381":1},"2":{"109":1,"111":1,"322":1,"381":1,"571":1}}],["disclaimer",{"2":{"79":1}}],["discussed",{"2":{"171":1}}],["discussion",{"2":{"37":2}}],["discussions",{"2":{"31":1,"44":1}}],["discuss",{"2":{"37":1,"40":1,"51":1,"186":1,"672":1}}],["discover",{"2":{"42":1}}],["discovering",{"2":{"37":1,"371":1}}],["discounts",{"2":{"34":1}}],["discord",{"0":{"49":1,"70":1},"2":{"10":1,"26":1,"39":2,"47":3,"48":1,"49":2,"70":2,"309":1,"430":3,"467":1,"500":1,"512":2,"515":1,"556":2,"563":1,"738":2}}],["discretion",{"2":{"24":1}}],["discrepancies",{"2":{"4":1}}],["denoted",{"2":{"651":2}}],["denomination",{"0":{"695":1,"696":1},"2":{"695":2}}],["denominations",{"0":{"693":1},"1":{"694":1,"695":1,"696":1}}],["denominator",{"2":{"429":4}}],["denominated",{"2":{"689":1}}],["denominate",{"2":{"87":1}}],["denom",{"2":{"266":2,"294":4,"295":2,"297":4,"408":2,"409":2,"413":2,"429":4,"750":2,"751":2,"785":1,"786":1}}],["deadbeef",{"2":{"779":2}}],["deadline",{"2":{"23":2,"25":1}}],["deal",{"2":{"652":1}}],["dealing",{"2":{"645":1}}],["derivation",{"2":{"429":4}}],["derogatory",{"2":{"7":1}}],["deducting",{"2":{"590":1}}],["deducted",{"2":{"409":2,"413":2,"590":1}}],["dedicated",{"2":{"23":1,"31":1,"47":1,"249":1,"578":1}}],["debug",{"2":{"260":2,"383":4,"627":4}}],["debugging",{"2":{"92":1,"260":2}}],["demosubmitdata",{"2":{"599":2}}],["demo",{"0":{"124":1},"2":{"122":1,"124":1,"125":1,"126":4,"599":2}}],["demonstration",{"0":{"140":1,"329":1},"1":{"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1},"2":{"446":1}}],["demonstrating",{"2":{"7":1,"15":1}}],["demonstrate",{"2":{"38":1,"784":1}}],["degree",{"2":{"110":1,"111":1}}],["defer",{"2":{"162":4,"599":2}}],["defaultgasprice",{"2":{"598":2,"773":2}}],["defaultestimategas",{"2":{"592":1,"593":2,"599":2}}],["defaults",{"2":{"86":1,"244":1,"266":1,"380":1,"592":1,"737":1}}],["default",{"0":{"518":1},"2":{"67":1,"68":2,"112":2,"202":3,"205":3,"206":2,"216":1,"244":1,"246":1,"247":1,"260":2,"274":2,"275":6,"313":1,"314":1,"324":1,"325":1,"326":1,"328":1,"349":1,"350":1,"352":2,"355":1,"365":3,"368":4,"370":1,"377":1,"380":1,"381":1,"423":1,"424":1,"429":4,"452":1,"468":1,"469":1,"494":1,"495":1,"496":1,"506":1,"507":1,"508":1,"509":1,"510":1,"517":2,"518":2,"525":1,"544":2,"583":1,"589":1,"591":1,"594":1,"598":2,"673":1,"700":3,"709":1,"710":2,"717":1,"737":1,"741":2,"743":1,"748":2,"750":1,"762":1,"773":2,"778":1,"779":3,"784":2}}],["definitions",{"2":{"682":2}}],["defining",{"0":{"125":1},"2":{"126":1}}],["defines",{"2":{"322":1,"622":1}}],["defined",{"2":{"86":1,"126":1,"142":1,"147":1,"156":1,"169":1,"171":1,"172":1,"194":1,"216":1,"528":1,"530":2,"622":1,"682":2}}],["define",{"2":{"37":1,"125":2,"151":1,"175":1,"179":2,"187":1,"191":1,"194":1,"205":1,"510":1,"528":1,"583":1}}],["defi",{"2":{"37":1}}],["deeper",{"0":{"566":1},"1":{"567":1,"568":1,"569":1,"570":1,"571":1},"2":{"683":1}}],["deepen",{"2":{"58":1}}],["deep",{"0":{"537":1},"1":{"538":1,"539":1,"540":1,"541":1},"2":{"42":1,"53":1,"537":1}}],["deemed",{"2":{"12":1}}],["deem",{"2":{"8":1,"11":1}}],["decreasing",{"2":{"687":1}}],["decreases",{"2":{"677":1}}],["decentralised",{"0":{"678":1,"692":1},"1":{"679":1,"680":1},"2":{"692":2}}],["decentralized",{"2":{"226":1,"461":1}}],["decentralization",{"0":{"224":1},"2":{"499":1}}],["decouple",{"2":{"649":1}}],["decoupling",{"2":{"583":1,"584":1,"650":1}}],["decoding",{"2":{"157":1,"429":4,"773":2}}],["decode",{"2":{"199":1,"599":2,"765":1,"773":2,"775":2,"776":1}}],["decoder",{"2":{"193":1}}],["decoded",{"2":{"156":4,"747":1}}],["decodestring",{"2":{"148":2,"150":2,"773":2}}],["decline",{"2":{"291":2}}],["declare",{"2":{"245":1,"301":1,"325":1,"422":1,"700":1,"706":1,"738":1}}],["deciding",{"0":{"384":1},"1":{"385":1,"386":1,"387":1}}],["decide",{"2":{"380":1}}],["decimal",{"2":{"210":1}}],["decimals",{"2":{"86":1,"687":1,"785":1,"786":1}}],["decisions",{"2":{"8":1}}],["deck",{"2":{"38":2}}],["desc",{"2":{"764":2}}],["descendants",{"2":{"646":2}}],["describing",{"2":{"648":1}}],["describes",{"2":{"125":2,"361":1,"427":1,"617":1}}],["described",{"2":{"20":1,"157":1,"187":1,"571":1,"651":3,"681":1,"682":1}}],["descriptor",{"2":{"337":1}}],["descriptors",{"2":{"337":1}}],["description=celestia",{"2":{"604":2,"606":2,"607":2,"608":2}}],["descriptions",{"2":{"86":2,"348":1}}],["description",{"0":{"44":1},"2":{"36":1,"38":1,"41":3,"86":1,"266":6,"267":2,"313":1,"326":1,"591":1,"681":1}}],["desert",{"2":{"559":2}}],["deserialization",{"0":{"191":1},"2":{"191":1,"194":1}}],["deserialize",{"2":{"190":1}}],["deserialized",{"2":{"109":1,"191":2}}],["desktop",{"2":{"91":1,"388":1,"389":1,"391":1}}],["destination",{"2":{"79":1,"309":1,"427":1}}],["desired",{"2":{"84":1,"234":1,"311":1,"341":1,"399":1,"662":1,"762":1}}],["desire",{"2":{"38":1}}],["designs",{"2":{"197":1}}],["design",{"0":{"321":1},"2":{"171":1,"226":1,"275":1,"316":1,"321":1,"355":1,"584":1}}],["designate",{"2":{"31":1}}],["designed",{"2":{"20":1,"43":1,"44":1,"51":1,"226":1,"501":2,"552":1,"645":1,"725":1}}],["delta",{"2":{"541":1}}],["deleted",{"2":{"391":1}}],["delete",{"2":{"262":2,"336":1,"375":1,"391":1,"698":1}}],["deleting",{"2":{"262":2}}],["delegating",{"2":{"683":1,"691":1}}],["delegation=1000000",{"2":{"622":3}}],["delegation=1",{"2":{"272":2}}],["delegations",{"2":{"20":1,"27":1}}],["delegation",{"0":{"17":1,"19":1},"1":{"18":1,"19":1,"20":2,"21":2,"22":2,"23":2,"24":2,"25":1,"26":1,"27":1,"28":1},"2":{"18":1,"22":4,"23":4,"24":1,"26":2,"260":2,"676":2}}],["delegator",{"2":{"653":1,"676":1}}],["delegators",{"2":{"281":2,"676":1}}],["delegate",{"0":{"269":1,"616":1},"2":{"269":3,"281":1,"616":5}}],["delegated",{"2":{"25":2,"281":1,"295":4,"582":1,"622":1}}],["delayedcelestia",{"2":{"301":1}}],["delayed",{"2":{"283":2,"294":7,"301":1}}],["delay",{"2":{"211":1,"429":4,"434":4}}],["delays",{"2":{"86":1}}],["delivering",{"2":{"58":1}}],["delivery",{"2":{"35":1}}],["delivers",{"2":{"18":1}}],["deprecated",{"2":{"152":1,"153":1,"163":2,"326":1,"728":1,"733":1}}],["depth",{"2":{"86":1,"566":1,"677":1}}],["depositing",{"2":{"95":1}}],["deposited",{"2":{"93":2}}],["deposit",{"0":{"75":1,"77":1},"1":{"76":1,"77":1},"2":{"74":2,"77":2,"93":5,"266":5,"267":2}}],["deployer",{"2":{"202":2,"546":4}}],["deployed",{"0":{"204":1,"231":1},"1":{"205":1,"206":1,"207":1},"2":{"42":1,"60":1,"86":2,"87":1,"91":1,"93":3,"204":2,"205":1,"211":2,"218":1,"231":1,"233":1,"234":3,"235":1,"361":1,"586":1,"728":1}}],["deployhelper",{"2":{"100":1,"101":1}}],["deployment",{"0":{"85":1,"86":1,"210":1,"212":1},"2":{"81":2,"85":3,"86":4,"87":1,"202":1,"208":4,"210":4,"212":1,"215":1,"217":1,"231":6,"234":1,"235":1,"542":1,"586":1}}],["deployments",{"0":{"97":1,"100":1,"101":1,"200":1,"585":1},"1":{"98":1,"99":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"586":1},"2":{"65":2,"91":1,"97":2,"98":1,"99":1,"202":3,"215":1,"216":1,"221":1,"227":2,"228":1,"233":1,"487":2,"489":2,"505":2,"542":1}}],["deploy",{"0":{"55":1,"81":1,"87":1,"202":1,"203":1,"208":1,"235":1,"242":1,"617":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"209":1,"210":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"618":1,"619":1,"620":1,"621":1},"2":{"55":1,"60":1,"85":1,"86":2,"87":3,"93":4,"103":1,"107":1,"113":1,"200":1,"201":1,"202":8,"203":2,"204":1,"208":1,"210":6,"212":1,"215":2,"217":2,"221":1,"227":1,"235":2,"249":1,"254":1,"454":1,"501":1,"542":3,"545":1,"546":4,"552":1,"554":1,"577":1,"578":1,"582":2,"586":2}}],["deploying",{"0":{"201":1,"545":1,"546":1,"582":1,"586":1},"1":{"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1},"2":{"3":1,"55":1,"81":1,"84":1,"202":1,"204":1,"205":1,"208":1,"210":2,"480":1,"546":1,"549":1,"574":1,"582":2,"585":1,"586":1,"690":2}}],["depends",{"2":{"369":1,"485":1}}],["dependent",{"2":{"134":1,"373":1,"592":1,"622":1}}],["dependency",{"0":{"543":1},"1":{"544":1},"2":{"117":1,"709":1,"778":1}}],["dependencies",{"0":{"241":1,"359":1,"398":1,"418":1,"441":1,"735":1,"766":1},"1":{"736":1,"737":1,"738":1,"767":1,"768":1},"2":{"89":1,"241":1,"359":1,"384":1,"388":1,"418":1,"441":1,"462":1,"708":1,"735":1,"739":1,"766":1,"777":1}}],["depend",{"2":{"91":1,"97":1,"226":1,"630":1,"633":1}}],["depending",{"2":{"34":1,"35":1,"58":1,"63":1,"171":1,"215":1,"302":1,"312":1,"342":1,"370":1,"371":1,"380":1,"386":1,"486":1,"501":1,"591":1,"771":1}}],["dependable",{"2":{"18":1}}],["deter",{"2":{"281":1}}],["deterministic",{"2":{"649":1}}],["determining",{"2":{"11":1,"591":1}}],["determined",{"2":{"128":1,"485":3,"592":1}}],["determines",{"2":{"86":1}}],["determine",{"2":{"30":1,"35":2,"37":1,"42":1,"63":1,"486":1,"501":1,"682":1,"710":1,"779":1}}],["detects",{"2":{"784":1}}],["detecting",{"2":{"371":1}}],["detection",{"2":{"328":1}}],["detected",{"2":{"130":1}}],["detect",{"2":{"126":1,"343":1}}],["details",{"0":{"26":1,"61":1,"168":1,"173":1,"295":1,"296":1,"482":1,"502":1},"1":{"62":1},"2":{"20":1,"41":1,"77":2,"79":1,"80":2,"87":1,"96":1,"137":1,"139":1,"140":1,"168":1,"169":1,"175":1,"182":1,"183":1,"187":1,"191":1,"194":4,"197":1,"234":1,"281":1,"291":1,"295":1,"296":1,"326":1,"328":1,"542":1,"592":1,"601":1,"643":1,"646":1,"648":2,"652":1,"662":1,"687":1,"728":1,"729":1,"733":1}}],["detailed",{"2":{"2":1,"21":1,"41":1,"81":1,"215":1,"266":1,"670":1}}],["devs",{"2":{"681":1}}],["devnetl1",{"2":{"541":1}}],["devnet",{"0":{"59":1,"69":1,"284":1,"285":1,"286":1,"288":1,"290":1,"294":1,"295":1,"296":1,"297":1,"319":1,"537":1,"545":1,"552":1,"553":1},"1":{"60":1,"61":1,"62":1,"63":1,"64":1,"65":1,"66":1,"67":1,"68":1,"69":1,"70":2,"71":2,"72":1,"73":1,"285":1,"286":2,"287":2,"288":2,"289":2,"290":1,"291":2,"292":2,"293":2,"294":2,"295":2,"296":2,"297":2,"538":1,"539":1,"540":1,"541":1,"553":1},"2":{"59":1,"60":1,"63":1,"65":1,"68":1,"70":1,"113":1,"244":1,"279":2,"283":1,"286":1,"287":1,"288":1,"289":4,"297":1,"298":1,"301":1,"305":1,"319":1,"350":1,"361":2,"371":1,"422":2,"465":1,"467":1,"501":1,"528":1,"541":1,"542":2,"545":2,"552":2,"619":1,"737":1,"738":1,"784":2,"785":2}}],["devrel",{"2":{"35":1,"37":1}}],["developing",{"2":{"422":1}}],["development",{"0":{"397":1},"1":{"398":1,"399":1},"2":{"81":1,"86":2,"341":1,"397":2,"501":1,"549":1,"582":1,"681":2}}],["developers",{"2":{"59":1,"60":1,"86":1,"107":2,"221":2,"228":1,"249":1,"251":2,"252":1,"402":1,"454":1,"501":1,"526":1,"552":1,"554":1,"574":1,"576":1,"583":1,"584":3,"670":1,"672":1,"674":1,"681":1,"689":2,"690":3,"724":1,"783":1}}],["developer",{"2":{"23":1,"39":1,"76":1,"166":1,"321":1,"439":1,"528":1,"574":1,"611":1,"723":1}}],["develop",{"2":{"23":1,"38":1}}],["devops",{"2":{"23":1,"320":1,"542":1}}],["dev",{"2":{"1":1,"104":1,"160":2,"398":4,"604":2,"606":2,"607":2,"608":2}}],["devyarn",{"2":{"1":1}}],["yconfirm",{"2":{"622":1}}],["ycelestia",{"2":{"268":1,"270":1}}],["yparity",{"2":{"539":2}}],["yum",{"2":{"398":4}}],["ysudo",{"2":{"398":3}}],["y",{"2":{"268":1,"270":1,"294":9,"398":3,"622":4}}],["yield",{"2":{"199":1}}],["y33zld2luvedelzzr9cf92+2etaimiwhn9pcaqaszwpqckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwoha36hewmw",{"2":{"152":2}}],["yh2zdyne9u",{"2":{"147":2}}],["yhcdb4cz7z4lrxmvrq5f8=",{"2":{"142":2}}],["y91da3zryfzmc7l",{"2":{"147":2}}],["yamlversion",{"2":{"707":1}}],["yamlextra",{"2":{"91":1}}],["yarn",{"2":{"1":2,"89":1,"93":2}}],["ymlglobal",{"2":{"275":1}}],["yml",{"2":{"91":1,"275":3,"276":1,"541":1,"707":2}}],["yet",{"2":{"93":2,"128":1,"201":1,"344":1,"370":1,"764":1}}],["yescelestia",{"2":{"412":1}}],["yesterday",{"2":{"271":2}}],["yes",{"2":{"42":1,"266":1,"279":2,"294":1,"412":1,"559":1,"676":1}}],["yearly",{"2":{"682":1}}],["years",{"2":{"549":1}}],["year",{"2":{"24":1,"25":1,"677":2,"682":14,"687":2}}],["youth",{"2":{"291":2}}],["youtube",{"2":{"34":1,"40":2,"542":1}}],["yours",{"2":{"287":1}}],["yourself",{"2":{"275":2}}],["yourprivatekey",{"2":{"93":3}}],["your",{"0":{"74":1,"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"85":1,"86":1,"87":1,"88":2,"89":1,"91":1,"92":1,"93":1,"240":1,"292":1,"294":1,"300":1,"303":1,"327":1,"334":1,"345":1,"417":1,"451":1,"452":1,"461":1,"462":1,"544":1,"562":1,"563":1,"567":1,"602":1,"623":1,"654":1,"656":1,"658":1,"659":1,"661":1,"663":1,"665":1,"667":1,"668":1,"706":1,"750":1,"752":1,"753":1,"770":1,"771":1},"1":{"75":1,"76":2,"77":2,"78":1,"79":2,"80":2,"241":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"418":1,"463":1,"563":1,"564":1,"565":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1},"2":{"2":5,"23":2,"24":1,"26":5,"29":1,"34":4,"35":7,"36":6,"37":11,"38":14,"39":15,"40":7,"41":8,"42":1,"44":1,"47":1,"49":1,"50":2,"51":1,"57":1,"58":3,"59":1,"63":1,"65":1,"68":3,"74":2,"76":2,"77":7,"79":7,"80":4,"82":1,"84":2,"85":3,"86":11,"87":13,"88":8,"89":1,"90":6,"91":16,"92":3,"93":20,"94":5,"140":1,"203":1,"204":1,"205":1,"206":2,"215":2,"229":4,"234":1,"235":1,"237":1,"244":3,"245":3,"254":1,"260":4,"263":1,"268":1,"269":1,"270":1,"271":7,"272":2,"273":1,"274":3,"275":3,"277":2,"283":1,"288":1,"289":2,"291":5,"294":1,"297":1,"299":1,"300":1,"301":1,"303":1,"308":2,"309":2,"311":1,"312":3,"313":3,"314":2,"315":2,"316":4,"321":1,"324":2,"326":3,"329":6,"334":5,"337":1,"338":1,"341":1,"342":2,"343":3,"344":2,"345":2,"352":2,"361":4,"363":2,"365":1,"366":1,"367":1,"368":2,"369":1,"371":1,"373":1,"376":1,"378":1,"380":1,"381":1,"383":5,"386":1,"388":2,"390":2,"391":2,"392":1,"396":1,"397":1,"398":1,"399":3,"405":5,"406":1,"407":1,"408":2,"412":5,"418":1,"422":7,"430":1,"439":1,"443":1,"445":1,"446":1,"448":2,"449":3,"452":3,"453":2,"457":1,"461":1,"464":2,"465":1,"466":3,"467":1,"471":1,"477":1,"486":1,"487":1,"495":3,"497":2,"501":1,"505":1,"530":1,"540":1,"541":2,"542":3,"544":2,"545":1,"546":6,"557":1,"558":1,"559":4,"560":3,"561":2,"563":1,"564":6,"565":1,"566":1,"567":3,"568":1,"569":1,"570":1,"577":1,"578":1,"580":1,"586":5,"588":2,"601":3,"604":1,"610":1,"616":2,"619":3,"622":9,"623":2,"624":1,"627":11,"657":1,"658":1,"662":1,"668":1,"676":1,"684":1,"685":1,"697":1,"700":3,"702":1,"705":1,"706":2,"707":3,"709":6,"710":1,"727":1,"736":2,"737":2,"738":6,"740":3,"741":1,"742":3,"743":5,"744":5,"747":3,"752":1,"753":1,"757":1,"758":1,"762":2,"763":1,"764":1,"767":5,"768":1,"770":1,"771":1,"778":6,"785":1,"786":1}}],["you",{"2":{"0":2,"2":1,"4":1,"23":3,"25":1,"26":6,"29":4,"30":1,"33":1,"34":4,"35":7,"36":4,"37":3,"39":1,"40":3,"41":11,"42":8,"47":2,"48":1,"50":2,"51":2,"54":1,"55":1,"57":2,"58":4,"59":1,"63":3,"65":2,"69":1,"70":1,"72":1,"76":1,"77":3,"79":3,"80":3,"81":4,"84":1,"85":1,"86":2,"87":5,"88":1,"89":1,"91":9,"92":2,"93":4,"94":1,"104":4,"105":1,"109":5,"110":2,"111":1,"117":1,"125":1,"126":2,"139":2,"163":3,"168":1,"202":13,"203":3,"204":1,"205":2,"208":1,"210":1,"211":4,"213":1,"214":1,"215":6,"216":3,"219":1,"227":1,"228":1,"231":1,"233":1,"235":2,"244":3,"245":8,"247":1,"248":1,"252":1,"254":2,"259":2,"261":1,"263":3,"266":2,"268":1,"269":2,"270":1,"271":2,"272":3,"274":6,"275":10,"277":3,"283":1,"284":1,"287":1,"288":2,"289":2,"290":2,"291":3,"294":4,"295":1,"296":1,"297":3,"298":1,"299":1,"301":3,"302":3,"303":4,"304":1,"305":1,"306":1,"307":1,"308":4,"309":2,"310":2,"311":4,"312":3,"313":3,"314":3,"315":1,"316":1,"320":1,"321":2,"324":1,"326":5,"329":5,"334":2,"336":2,"337":2,"338":5,"339":1,"341":4,"343":2,"344":3,"345":2,"347":1,"349":1,"352":3,"353":1,"356":1,"361":7,"363":1,"367":3,"368":3,"371":5,"373":7,"376":1,"377":2,"378":1,"380":3,"381":2,"383":3,"384":2,"385":1,"386":1,"387":2,"388":5,"390":4,"391":10,"392":3,"393":1,"396":1,"398":1,"399":2,"404":4,"405":1,"406":1,"408":1,"409":1,"414":1,"418":1,"419":1,"422":9,"424":1,"425":2,"429":3,"430":1,"431":1,"432":2,"433":1,"434":3,"439":3,"440":1,"441":1,"442":1,"443":2,"444":3,"445":1,"446":1,"448":2,"449":5,"450":4,"452":6,"453":2,"457":2,"458":2,"461":1,"465":1,"466":6,"467":3,"469":1,"471":1,"474":2,"486":4,"495":2,"496":1,"497":2,"498":1,"501":8,"507":3,"512":2,"514":1,"520":1,"521":1,"525":2,"530":1,"533":2,"536":1,"539":1,"541":1,"542":6,"544":4,"545":2,"546":5,"547":2,"551":1,"557":2,"558":5,"559":12,"560":6,"561":5,"563":1,"564":7,"565":7,"566":1,"567":2,"568":4,"569":1,"570":1,"572":1,"574":5,"576":1,"580":3,"586":2,"593":1,"601":4,"603":1,"604":2,"606":2,"607":2,"608":1,"609":1,"612":2,"616":8,"617":2,"618":1,"621":1,"622":11,"627":4,"629":1,"653":3,"659":2,"663":2,"668":2,"676":1,"694":1,"697":3,"699":1,"700":6,"701":1,"706":4,"707":2,"708":2,"709":5,"710":1,"711":1,"712":1,"713":3,"719":1,"728":2,"733":6,"735":1,"737":5,"738":11,"739":3,"740":7,"741":1,"742":3,"743":4,"744":2,"745":1,"747":3,"748":3,"751":1,"757":3,"758":1,"762":1,"763":2,"764":2,"765":5,"767":4,"768":1,"771":1,"773":1,"775":4,"776":3,"777":2,"778":5,"779":1,"780":1,"781":3,"784":2,"785":6,"786":4}}],["a1",{"2":{"707":2}}],["await",{"2":{"779":6,"780":8,"781":6,"784":4}}],["away",{"2":{"690":1}}],["awareness",{"2":{"30":1}}],["ahzu6yr9xmpixlquhgbhj9xl3wiaoz6pe3cvml",{"2":{"292":2,"296":2}}],["ahead",{"2":{"35":1,"130":1}}],["a5jf",{"2":{"291":2,"292":2}}],["aztec",{"2":{"214":17}}],["aka",{"2":{"186":1,"208":1,"216":1,"594":1}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaecawqfbgcicra=",{"2":{"540":2,"762":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaba==",{"2":{"147":2,"152":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaap8aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaazz5aj1mijjrowjdcifyjkr0pcroiu2jigmd9bzuhzro",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqs98k+8wq2ix2bdctfohjtrqbqybtpdb1bufy",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaabxaaaacbaagroagqgaqqdaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseqovy2vszxn0awexdwc1zwt0mmnjn250dzrkdg1zzdlsn3n0ctbzn3z5ztd5btjyzhishqaaaaaaaaaaaaaaaaaaaaaaaaasexiyqkmkmoizggkxaiigrflow1m",{"2":{"152":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaacugaaacbaagrnagqfaqqcaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseaovy2vszxn0awexywxwngzwbhf5d21jnmn1adl5mzvly2xychf5cwf4mjn2z3zrczushqaaaaaaaaaaaaaaaaaaaaaaaaaaaagicagicagiggfeiiazloeqsgxg3row7sr1rkq7dvjygp3axkaqy4og6hyc0eibabjnclikrgofl2nvc21vcy5jcnlwdg8uc2vjcdi1nmsxllb1yktlerijcieca4ief8fzeabqlvc2wocefs+lhak0mdnmpnsxylkqv7qsbaoccaey5pebehekcwoedxrpyridmtyweltvbbpa7xbbsgyfrwtzcfhq3va1vhtbriczyd0elkajo6klsdooeqcwovaguwtdp55v8btf3wc7",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqaaaaaaeuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5rt0t52lwq3l0fnm6kqqka7nrxfnm8zc",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5ru6k2enim7thjqycl82hsxpinycelhed9qk+p9zbnide",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouu=",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaejpdcbnowap3dm=",{"2":{"332":2,"747":8}}],["aaaaaaaaaaaaaaaaaaaaaaaaabitejjcqyqyijkaaaaaaaaaaaaaaaaaaaaaaaaaehmsmkjdjdkimbiwnpodwizbfr0uifhpkwgy",{"2":{"152":2}}],["axtrw6s+qsnuzfgfeg37da6igop2zqck+04egqkaggbgaisewoncgr1dglheguymtawmbdq6awaqclylqpnrfod6h8mgmwxjfenhwhru39ecrvkmfknq8+hhuodhdoqig",{"2":{"152":2}}],["ai",{"2":{"489":1,"490":1,"491":1,"495":1,"499":1,"684":1,"685":1,"765":1}}],["airdrop",{"2":{"69":1,"512":1}}],["aiming",{"2":{"226":1}}],["aims",{"2":{"44":1,"717":1}}],["aim",{"2":{"37":1,"226":1}}],["aid",{"2":{"29":1,"634":1}}],["aura",{"2":{"280":2}}],["augments",{"2":{"238":1,"652":1}}],["aunt",{"2":{"144":4}}],["aunts",{"2":{"142":2,"144":4,"147":2,"152":2,"159":5,"160":4,"163":8}}],["authcelestia",{"2":{"767":1}}],["authentication",{"2":{"328":2,"726":1,"741":1,"742":5,"743":1,"774":2}}],["authenticated",{"2":{"175":1,"199":1}}],["authorization",{"2":{"540":2,"741":1,"762":2}}],["authorize",{"2":{"278":1}}],["authority",{"2":{"86":1}}],["auth",{"0":{"567":1,"742":1,"744":1},"2":{"91":10,"266":2,"294":2,"296":2,"540":2,"567":5,"591":1,"709":5,"717":1,"740":2,"741":5,"742":9,"743":2,"744":7,"745":4,"747":2,"750":1,"762":7,"767":1,"772":4,"773":4,"775":4,"778":5}}],["autogenerated",{"2":{"706":1}}],["automated",{"2":{"610":1}}],["automate",{"2":{"328":1}}],["automatically",{"2":{"23":1,"86":1,"281":1,"525":1,"527":1,"530":1,"593":1,"599":2,"710":1,"748":1,"779":1}}],["auto",{"2":{"86":2,"268":2,"270":2,"294":6,"429":2}}],["audible",{"2":{"34":1}}],["audience",{"0":{"36":1},"2":{"34":1,"36":3,"37":1,"38":1,"39":1,"40":1}}],["amd",{"2":{"399":1}}],["amd64",{"2":{"312":1,"342":1,"399":12}}],["amanda",{"2":{"263":2}}],["amazonaws",{"2":{"214":16}}],["amountceles",{"2":{"272":1}}],["amount=1000000utia",{"2":{"622":2}}],["amount=9000000utia",{"2":{"449":2}}],["amount=5000000000000utia",{"2":{"272":2}}],["amount=",{"2":{"272":2,"447":2}}],["amount",{"0":{"79":1,"666":1},"2":{"35":1,"77":1,"86":1,"217":1,"265":2,"266":2,"267":2,"269":4,"272":3,"294":8,"295":2,"297":4,"381":2,"407":3,"408":2,"409":2,"447":2,"448":1,"449":3,"591":1,"592":1,"622":1,"633":1,"641":1,"650":1,"658":1,"662":1,"666":1,"682":2,"750":2,"751":2,"757":3}}],["among",{"2":{"31":1,"35":1,"238":1,"526":1,"648":1,"649":1}}],["ample",{"2":{"39":1}}],["amp",{"0":{"4":1,"87":1,"269":1,"675":1},"1":{"676":1,"677":1,"678":1,"679":1,"680":1,"681":1,"682":1},"2":{"1":4,"2":2,"38":1,"53":1,"54":1,"55":1,"58":1,"87":1,"142":2,"144":14,"147":1,"150":2,"152":2,"156":6,"157":2,"161":10,"162":2,"163":10,"215":8,"218":1,"238":1,"275":1,"299":4,"338":2,"343":4,"398":10,"560":14,"606":4,"607":4,"681":3,"682":5,"779":10,"780":8,"781":6}}],["affect",{"2":{"337":1,"610":1}}],["affected",{"2":{"7":1}}],["affordable",{"2":{"40":1}}],["affiliated",{"2":{"38":1}}],["after=network",{"2":{"604":2,"606":2,"607":2,"608":2}}],["afterwards",{"2":{"24":1}}],["after",{"0":{"32":1,"409":1},"2":{"22":2,"23":2,"34":1,"39":1,"40":1,"77":1,"79":2,"80":2,"81":1,"86":2,"88":1,"90":1,"92":1,"96":1,"164":1,"172":1,"203":1,"204":1,"210":1,"211":1,"244":1,"263":1,"281":2,"312":1,"334":1,"342":1,"343":1,"349":1,"369":1,"373":1,"379":1,"380":1,"381":1,"391":1,"398":2,"409":1,"413":1,"429":1,"431":1,"450":1,"528":1,"530":1,"542":1,"608":1,"609":1,"616":1,"622":2,"623":1,"627":1,"659":1,"663":1,"668":1,"673":1,"737":1,"747":1,"773":2,"775":1}}],["average",{"2":{"784":2,"786":1}}],["avril14th",{"2":{"489":1,"490":1,"491":1,"508":1,"509":1,"510":1}}],["avoid",{"2":{"35":1,"38":1,"39":1,"91":1,"275":1,"391":1,"430":1,"546":2,"592":1}}],["avoiding",{"2":{"13":1,"18":1}}],["availability",{"0":{"67":1,"68":1,"223":1,"471":1,"493":1,"494":1,"495":1,"506":1,"507":1,"535":1,"605":1,"628":1,"629":1,"630":1,"631":1,"632":1,"633":1,"637":1,"642":1,"643":1,"648":1,"652":1,"756":1},"1":{"224":1,"225":1,"226":1,"494":1,"495":1,"496":1,"497":1,"606":1,"607":1,"608":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"640":1,"641":1,"643":1,"644":2,"645":2,"646":1,"647":1,"648":1},"2":{"30":1,"36":1,"37":1,"53":1,"65":1,"85":1,"107":2,"111":1,"112":2,"120":1,"122":1,"165":3,"179":1,"182":1,"194":1,"221":2,"224":2,"225":1,"226":2,"237":1,"238":2,"250":1,"315":1,"321":1,"342":1,"376":2,"385":2,"400":2,"402":1,"412":1,"454":1,"455":2,"458":2,"459":1,"481":1,"496":1,"501":1,"533":4,"542":1,"546":1,"557":2,"580":1,"583":2,"608":1,"609":1,"617":2,"629":7,"630":3,"631":5,"632":4,"633":1,"634":1,"637":1,"638":1,"639":1,"642":4,"645":1,"649":1,"650":5,"651":1,"670":1,"672":2,"673":1,"689":1,"690":1,"719":2,"730":1}}],["available",{"2":{"16":2,"21":1,"29":1,"31":1,"40":2,"50":1,"71":1,"111":1,"122":1,"174":1,"178":1,"179":1,"227":2,"260":2,"266":1,"274":2,"312":3,"342":3,"377":3,"380":1,"381":2,"485":1,"496":1,"542":1,"557":1,"567":1,"576":1,"579":1,"632":2,"637":1,"639":1,"642":1,"643":2,"648":1,"649":1,"651":3,"652":4,"670":2,"674":2,"682":2,"710":1,"714":1,"782":1}}],["ago",{"2":{"706":2,"707":2}}],["agreeing",{"2":{"649":1}}],["agree",{"2":{"649":1}}],["agreement",{"2":{"580":1}}],["agnostic",{"2":{"648":1}}],["again",{"2":{"329":1,"334":1,"435":1,"594":1,"652":1,"764":1,"767":1}}],["against",{"2":{"91":1,"119":1,"122":2,"227":1,"234":1,"336":1}}],["aggression",{"2":{"15":1}}],["agendas",{"2":{"30":1}}],["agenda",{"2":{"30":1}}],["age",{"2":{"6":1}}],["arise",{"2":{"638":1}}],["arises",{"2":{"630":1}}],["aria2",{"2":{"398":4}}],["aria2c",{"2":{"372":6}}],["arm",{"2":{"399":1}}],["arm64",{"2":{"312":1,"342":1,"399":12}}],["armored",{"2":{"263":2,"701":1}}],["architectnodes",{"2":{"429":2}}],["architecture",{"2":{"321":1,"343":1}}],["architectures",{"2":{"312":1,"342":1,"650":1}}],["archive",{"2":{"68":1,"367":1,"489":1,"490":1,"491":1,"492":1,"495":1,"508":1,"509":1,"510":1}}],["archival",{"0":{"496":1,"497":1},"1":{"497":1},"2":{"23":1,"27":1,"496":2,"497":1,"673":3,"674":5}}],["array",{"2":{"355":1,"779":3}}],["arranging",{"2":{"31":1}}],["arranges",{"2":{"651":1}}],["arrangement",{"2":{"649":1}}],["arranged",{"2":{"643":1,"649":1}}],["arrange",{"2":{"30":2,"36":1,"37":1}}],["arrived",{"2":{"309":1}}],["args",{"2":{"392":4,"393":4,"740":3,"743":2,"772":8,"773":8,"775":8}}],["arg",{"2":{"260":2}}],["argument",{"2":{"191":1,"194":1}}],["arguments",{"2":{"187":1,"564":1,"740":1,"771":2,"772":5,"773":5,"775":2}}],["artifacts",{"0":{"213":1},"1":{"214":1,"215":1},"2":{"203":1}}],["arfge6qnxuiz18vlglgewtw",{"2":{"147":4}}],["arbitrary",{"2":{"126":2,"267":1,"557":1}}],["arbitrum",{"0":{"81":1,"84":1,"98":1,"100":1,"106":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1},"2":{"74":1,"76":1,"77":3,"79":4,"81":4,"82":3,"83":1,"84":3,"85":1,"87":5,"90":6,"91":1,"93":2,"95":1,"97":1,"98":1,"103":3,"104":2,"107":5,"108":2,"109":1,"111":1,"112":2,"113":1,"216":1,"228":1,"231":2,"400":1}}],["arabicaresturl",{"2":{"784":2}}],["arabicarpcurl",{"2":{"784":2}}],["arabicachainid",{"2":{"325":1,"361":6,"372":2,"544":2,"747":1,"784":2,"785":1}}],["arabicacelestia",{"2":{"244":1,"245":1,"246":1,"319":1,"421":1,"423":1,"464":1,"465":1,"466":1,"468":1,"736":1,"737":2,"738":1,"767":1}}],["arabicaversions",{"2":{"311":2,"341":2,"390":2,"392":2,"393":2}}],["arabica",{"0":{"59":1,"69":1,"319":1,"332":1,"552":1,"553":1},"1":{"60":1,"61":1,"62":1,"63":1,"64":1,"65":1,"66":1,"67":1,"68":1,"69":1,"70":2,"71":2,"72":1,"73":1,"553":1},"2":{"59":2,"60":3,"63":1,"65":12,"68":5,"70":2,"71":1,"72":3,"244":2,"245":5,"246":1,"309":1,"319":4,"325":2,"328":1,"332":1,"338":1,"361":3,"371":2,"390":1,"421":1,"422":4,"423":1,"464":1,"465":4,"466":3,"467":1,"468":1,"501":1,"518":2,"523":2,"528":1,"532":2,"552":3,"554":1,"609":1,"619":1,"700":2,"736":1,"737":5,"738":3,"742":3,"754":2,"767":9,"773":3,"784":6,"785":6}}],["around",{"0":{"636":1},"2":{"12":1,"43":1,"321":1,"385":1,"453":1,"559":2,"630":1,"636":1,"638":1}}],["areas",{"2":{"32":1,"37":1,"42":1}}],["area",{"2":{"31":1,"36":1,"37":1,"38":1,"39":1,"42":1}}],["aren",{"2":{"29":1,"301":1}}],["are",{"0":{"336":1,"633":1,"641":1},"2":{"8":2,"10":1,"16":1,"18":1,"20":2,"22":2,"23":3,"25":1,"29":1,"30":1,"33":2,"35":1,"36":2,"42":3,"44":1,"46":1,"53":1,"58":1,"59":1,"63":1,"64":1,"69":1,"72":1,"74":1,"86":3,"87":1,"90":1,"91":4,"93":2,"109":1,"110":1,"118":2,"119":2,"125":1,"126":3,"127":1,"128":1,"130":3,"134":1,"136":1,"137":3,"139":3,"142":1,"144":2,"147":1,"151":1,"152":1,"156":1,"158":2,"159":2,"161":2,"163":2,"164":1,"168":2,"173":1,"174":1,"178":1,"179":1,"180":1,"185":1,"186":1,"187":2,"188":1,"191":1,"194":1,"197":1,"199":1,"202":5,"203":1,"204":1,"210":1,"211":2,"213":1,"215":5,"218":2,"224":1,"225":1,"231":1,"233":1,"239":1,"244":1,"245":1,"252":2,"261":2,"266":5,"267":2,"271":1,"272":1,"273":1,"274":2,"275":3,"281":1,"283":1,"289":1,"294":1,"301":2,"303":2,"309":1,"312":1,"313":3,"320":1,"322":4,"324":1,"326":3,"328":4,"334":2,"336":3,"342":1,"350":1,"352":1,"357":1,"361":1,"370":1,"371":3,"373":2,"380":1,"381":6,"387":1,"388":1,"390":1,"398":4,"399":1,"409":1,"415":1,"416":1,"422":2,"425":1,"427":1,"432":1,"448":1,"453":1,"455":2,"456":1,"460":1,"465":1,"486":1,"487":1,"498":1,"500":1,"501":3,"505":1,"507":1,"511":1,"512":1,"514":1,"515":1,"525":1,"526":2,"528":2,"530":1,"533":1,"539":1,"540":1,"545":1,"546":2,"554":1,"556":1,"574":1,"576":2,"579":2,"580":1,"582":1,"583":1,"584":1,"590":2,"591":3,"592":1,"594":1,"598":2,"601":1,"603":2,"609":2,"611":2,"613":1,"617":1,"619":1,"622":6,"631":1,"633":4,"636":1,"638":1,"639":1,"640":1,"642":3,"643":3,"644":1,"645":2,"648":1,"649":3,"651":4,"652":1,"670":1,"671":2,"673":1,"674":2,"677":1,"682":4,"700":3,"706":2,"710":3,"711":1,"712":1,"717":1,"719":1,"720":2,"722":2,"723":1,"724":1,"727":1,"734":1,"736":1,"737":3,"740":1,"741":1,"742":1,"743":1,"744":2,"764":1,"766":1,"780":1}}],["abbreviation",{"2":{"687":1}}],["abci++",{"2":{"648":1,"651":1}}],["abci",{"0":{"381":1},"2":{"381":8,"648":1}}],["abstain",{"2":{"266":1}}],["abi",{"2":{"144":2,"155":2,"163":2}}],["abigen",{"2":{"136":1}}],["ability",{"2":{"112":1,"169":1,"281":1,"422":2,"465":2,"630":1,"634":1,"635":1}}],["able",{"2":{"34":2,"35":1,"58":1,"79":2,"80":1,"90":1,"91":1,"125":2,"139":1,"169":1,"183":1,"185":1,"190":1,"204":1,"211":1,"277":1,"321":1,"542":1,"544":1,"552":1,"582":1,"594":1,"604":1,"606":1,"607":1,"608":1,"622":1,"631":1,"634":1,"646":2,"673":1,"773":1,"776":1,"785":1,"786":1}}],["abusive",{"2":{"10":1}}],["about",{"0":{"455":1},"1":{"456":1},"2":{"3":1,"7":1,"16":1,"20":1,"30":1,"36":1,"37":1,"42":5,"43":1,"58":1,"63":1,"73":1,"79":1,"81":2,"86":1,"94":1,"107":1,"109":1,"110":1,"125":2,"137":1,"211":2,"234":1,"236":1,"250":1,"260":2,"291":1,"312":1,"341":1,"343":1,"388":2,"404":1,"457":1,"486":1,"496":1,"497":1,"500":2,"515":2,"533":1,"547":1,"556":2,"564":1,"567":1,"573":2,"580":1,"593":1,"636":1,"637":1,"638":2,"692":1,"727":1,"732":1,"733":1,"740":2,"747":1,"748":1}}],["above",{"2":{"2":1,"23":1,"65":1,"68":1,"85":1,"91":1,"105":1,"130":1,"133":1,"139":3,"154":1,"155":1,"157":1,"162":1,"163":1,"164":1,"169":1,"172":1,"186":1,"191":1,"197":1,"202":1,"210":1,"238":1,"267":1,"294":1,"345":1,"391":1,"448":1,"449":1,"466":1,"559":1,"565":1,"568":1,"571":1,"591":1,"599":2,"627":1,"648":1,"651":2,"744":1,"745":1,"747":3,"750":1}}],["atomic",{"2":{"650":1}}],["atlas",{"2":{"96":1}}],["atmosphere",{"2":{"34":1,"35":1}}],["at",{"0":{"681":1,"687":1},"1":{"682":1},"2":{"9":1,"10":1,"16":3,"23":1,"26":1,"34":2,"35":2,"36":2,"37":1,"38":3,"39":1,"40":1,"42":1,"67":1,"68":1,"71":1,"82":1,"84":1,"93":1,"97":1,"122":2,"124":1,"154":2,"160":4,"180":1,"199":1,"211":1,"212":1,"215":3,"216":2,"217":1,"218":1,"221":1,"227":1,"246":1,"247":1,"251":1,"260":4,"275":2,"277":1,"279":2,"287":1,"304":1,"312":1,"313":1,"321":1,"326":1,"338":1,"342":1,"343":1,"367":1,"371":1,"423":1,"424":1,"428":1,"430":1,"448":1,"449":1,"456":1,"468":1,"469":1,"481":1,"494":1,"495":1,"506":1,"507":1,"528":1,"546":1,"552":1,"559":1,"560":1,"579":1,"588":2,"594":1,"598":2,"607":1,"633":1,"636":1,"643":3,"645":1,"648":1,"651":1,"652":3,"676":1,"677":2,"680":1,"681":1,"682":7,"683":1,"687":1,"710":3,"711":2,"712":7,"713":3,"747":1,"773":4,"779":3,"780":5,"781":1}}],["attack",{"2":{"630":3,"633":1}}],["attacks",{"2":{"7":1,"86":1}}],["attach",{"2":{"275":2}}],["attempt",{"2":{"629":1}}],["attempting",{"2":{"432":1}}],["attesting",{"2":{"160":1}}],["attestations",{"2":{"225":2,"400":1}}],["attestation",{"2":{"154":2,"160":4}}],["attestationproof",{"0":{"160":1},"2":{"154":6,"160":6,"163":4}}],["attests",{"2":{"139":1}}],["attested",{"2":{"118":2,"231":1}}],["attended",{"2":{"39":1}}],["attendees",{"2":{"30":3,"31":4,"32":3,"34":2,"35":2,"36":2,"37":2,"39":1,"40":1,"42":1,"46":1,"58":2}}],["attending",{"2":{"39":2}}],["attend",{"2":{"36":1,"40":3}}],["attendance",{"2":{"30":1,"32":1,"36":3,"39":2}}],["attention",{"2":{"7":1,"546":1}}],["attributes",{"2":{"147":4}}],["attribution",{"0":{"16":1}}],["attracting",{"2":{"39":1}}],["attract",{"2":{"36":1,"37":1}}],["algorithm",{"2":{"648":1}}],["almost",{"2":{"563":1}}],["although",{"2":{"652":3}}],["alt",{"2":{"545":1,"546":1,"547":1}}],["alternatives",{"2":{"370":1}}],["alternatively",{"2":{"130":2,"183":1,"190":1,"203":1,"209":1,"217":1,"521":1,"645":1,"652":1,"712":1,"740":1,"773":1}}],["alternative",{"2":{"112":1,"171":1,"172":1,"212":1}}],["alert",{"2":{"784":4}}],["alertmanager",{"2":{"275":2}}],["alerts",{"0":{"277":1},"2":{"275":2,"277":1}}],["alerting",{"2":{"26":1}}],["alias",{"0":{"696":1},"2":{"264":2,"559":1,"696":1}}],["align",{"2":{"38":1}}],["aligned",{"2":{"8":1,"23":1}}],["along",{"2":{"126":1,"139":1,"160":1,"163":2,"203":1,"228":1,"233":1,"322":1,"542":1,"670":1,"737":1,"765":1}}],["alongside",{"2":{"42":1,"107":1,"427":1}}],["alphab",{"2":{"489":1,"490":1,"491":1,"495":1,"499":1,"684":1,"685":1}}],["alpha",{"2":{"96":1,"140":2,"218":1}}],["alchemy",{"2":{"90":3}}],["alcohol",{"2":{"35":1}}],["already",{"2":{"23":1,"40":1,"41":1,"44":1,"91":1,"151":1,"201":1,"208":1,"216":2,"277":1,"290":1,"315":1,"352":1,"355":1,"399":1,"432":1,"433":1,"435":1,"444":1,"594":1,"646":1,"708":1,"718":1,"733":1,"735":1,"739":1,"777":1}}],["also",{"2":{"9":1,"23":1,"35":3,"38":1,"39":1,"40":2,"42":1,"77":1,"86":2,"111":1,"127":1,"130":2,"140":1,"143":1,"147":2,"168":1,"182":1,"186":1,"193":1,"208":1,"211":2,"214":1,"215":1,"227":1,"235":1,"238":2,"273":1,"276":1,"281":1,"289":1,"301":1,"320":1,"350":1,"371":2,"385":1,"386":1,"387":1,"400":1,"406":1,"448":1,"449":1,"461":1,"464":1,"501":1,"507":1,"542":1,"546":1,"554":1,"559":2,"601":1,"646":1,"651":1,"652":1,"692":1,"700":1,"706":1,"707":1,"726":1,"737":1,"740":1,"743":1,"745":1,"765":1,"773":1,"784":2}}],["allocation",{"0":{"681":1},"1":{"682":1},"2":{"681":1,"682":1}}],["allocating",{"2":{"40":1}}],["allocated",{"2":{"267":1,"681":1,"682":1}}],["allocate",{"2":{"35":1}}],["allotting",{"2":{"37":1}}],["allowance",{"0":{"407":1,"408":1,"410":1},"1":{"411":1},"2":{"405":1,"413":1}}],["allowances",{"0":{"405":1,"412":1},"1":{"406":1,"407":1,"413":1},"2":{"412":1}}],["allowing",{"2":{"41":1,"412":1,"437":1,"501":1}}],["allow",{"2":{"38":2,"67":1,"86":1,"92":1,"169":1,"197":1,"205":1,"206":1,"221":2,"227":1,"252":1,"313":1,"314":1,"321":2,"326":1,"356":1,"391":1,"429":4,"435":4,"454":1,"458":1,"494":1,"506":1,"508":1,"509":1,"510":1,"557":1,"612":1,"629":1,"674":3,"743":1,"784":2}}],["allows",{"2":{"22":1,"40":2,"41":1,"86":1,"107":1,"111":2,"112":1,"120":1,"122":1,"141":1,"151":1,"165":1,"167":1,"170":1,"172":1,"174":1,"176":1,"178":2,"206":2,"210":1,"217":1,"277":1,"310":1,"313":2,"326":2,"328":1,"337":1,"376":1,"381":1,"388":1,"404":1,"452":1,"455":1,"509":1,"542":1,"544":1,"568":1,"601":1,"644":1,"653":1,"692":1,"709":1,"719":1,"724":1,"733":1,"748":1,"778":1,"784":1}}],["allowed",{"2":{"14":1,"412":2}}],["all",{"0":{"365":1,"703":1},"2":{"9":1,"10":2,"26":2,"41":1,"42":1,"46":3,"60":1,"68":1,"93":2,"125":2,"164":1,"168":1,"202":1,"215":1,"221":1,"227":3,"260":1,"264":1,"291":2,"304":1,"308":1,"313":1,"326":1,"339":1,"348":1,"363":1,"365":2,"368":1,"369":2,"372":1,"375":3,"377":2,"388":1,"391":1,"414":1,"415":1,"431":2,"444":2,"448":2,"450":4,"480":1,"495":1,"496":1,"522":1,"525":3,"527":1,"532":1,"533":1,"580":1,"582":3,"583":2,"584":1,"591":1,"592":1,"593":1,"599":2,"611":1,"622":1,"629":3,"631":3,"632":1,"638":1,"646":3,"649":3,"652":1,"673":1,"674":1,"680":1,"682":1,"711":1,"712":5,"736":1,"741":1,"747":6,"771":1,"773":1,"779":2,"780":5}}],["always",{"2":{"2":1,"34":1,"60":1,"109":1,"204":1,"361":2,"380":2,"554":1,"591":1,"700":1}}],["ad5ezbg0",{"2":{"762":2}}],["adjusted",{"2":{"591":1,"592":1}}],["adjust",{"2":{"338":1,"584":1}}],["adventure",{"2":{"765":1}}],["advertise",{"2":{"378":1}}],["advisable",{"2":{"588":1}}],["advise",{"2":{"507":1}}],["advised",{"2":{"324":1,"361":1}}],["advantages",{"2":{"199":1}}],["advanced",{"0":{"760":1},"2":{"568":1,"776":1}}],["advance",{"2":{"35":1,"39":1}}],["advances",{"2":{"7":1,"227":1}}],["adr019",{"2":{"677":1}}],["adrs",{"2":{"238":1,"648":1}}],["adr",{"2":{"169":1,"321":2}}],["adapt",{"2":{"139":1,"154":1}}],["adapted",{"2":{"16":1,"83":1,"682":1}}],["admin",{"2":{"91":2,"275":1,"546":4,"567":2,"742":4,"744":2,"762":2}}],["administrative",{"2":{"86":1,"724":1}}],["adhere",{"2":{"46":1}}],["adhering",{"2":{"23":1}}],["addnetworkkeplr",{"2":{"784":17}}],["adds",{"2":{"338":1,"560":1,"591":1,"651":1}}],["addcustomprover",{"2":{"206":1,"207":2}}],["addblock",{"2":{"128":2,"130":4}}],["addrs",{"2":{"752":2}}],["addr",{"2":{"91":1,"274":2,"334":2,"429":8,"478":2,"599":4}}],["addresscelestia",{"2":{"408":1,"410":1,"521":1,"563":1,"753":1}}],["address=$",{"2":{"378":2,"452":2}}],["address=$evm",{"2":{"272":2}}],["address=address",{"2":{"299":4}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0d",{"2":{"757":1}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0dexport",{"2":{"757":1}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"293":1}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5export",{"2":{"293":1}}],["address=celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"293":2}}],["address=",{"2":{"272":2,"275":1,"405":4,"412":4}}],["addresses",{"2":{"86":2,"91":3,"94":1,"412":1,"522":1,"571":1,"586":1}}],["address",{"0":{"333":1,"378":1,"521":1,"751":1,"753":1},"2":{"7":1,"9":1,"23":1,"26":3,"38":1,"70":5,"86":8,"91":6,"93":4,"100":1,"101":1,"125":1,"144":2,"161":2,"162":2,"163":2,"202":9,"203":2,"204":21,"206":1,"207":4,"209":2,"210":6,"211":4,"218":2,"231":1,"244":1,"245":2,"265":10,"267":1,"272":5,"274":2,"291":3,"292":4,"293":3,"294":16,"295":5,"296":5,"297":4,"300":1,"301":4,"309":2,"313":2,"314":2,"326":1,"328":1,"333":2,"361":2,"377":1,"378":8,"405":4,"407":2,"408":3,"410":1,"412":8,"413":2,"422":2,"429":4,"446":1,"451":8,"452":4,"466":2,"467":5,"478":1,"479":6,"512":5,"518":1,"520":1,"521":3,"539":1,"559":2,"563":3,"571":1,"586":2,"599":2,"616":2,"707":4,"737":1,"738":7,"741":1,"751":9,"753":2,"754":8,"757":2,"767":4,"785":1,"786":1}}],["added",{"2":{"86":1,"93":2,"112":1,"275":2,"278":1,"448":1,"450":1,"522":1,"629":1,"776":1}}],["add",{"0":{"76":1,"89":1,"207":1,"430":1,"447":1,"452":1,"784":1},"2":{"39":1,"41":1,"76":1,"85":1,"91":2,"126":2,"130":4,"205":1,"207":1,"244":1,"260":4,"262":2,"272":5,"275":1,"279":8,"283":1,"291":2,"299":5,"308":2,"316":1,"329":1,"352":1,"399":1,"429":1,"430":6,"435":3,"446":2,"447":2,"450":1,"451":1,"466":2,"523":2,"674":1,"682":1,"698":1,"700":6,"702":6,"709":1,"719":1,"737":1,"738":2,"771":1,"778":3,"783":2,"784":6,"785":4,"786":3}}],["addition",{"2":{"34":1,"353":1,"639":1,"652":1,"690":1}}],["additionally",{"2":{"39":1,"91":1,"108":1,"109":2,"112":1,"126":1,"643":1,"679":1}}],["additional",{"0":{"100":1,"101":1,"625":1,"761":1},"1":{"762":1,"763":1,"764":1},"2":{"32":1,"38":1,"40":1,"98":1,"99":1,"107":1,"125":1,"188":1,"591":1,"625":1,"645":1,"659":1,"663":1,"668":1,"726":1,"740":1}}],["adding",{"0":{"448":1,"785":1,"786":1},"2":{"2":1,"93":2,"262":2,"276":1,"430":1,"431":1,"584":1}}],["apt",{"2":{"398":6}}],["aptyummac",{"2":{"398":1}}],["aptyum",{"2":{"398":1}}],["apache",{"2":{"118":2}}],["api",{"0":{"490":1,"509":1,"595":1,"598":1,"714":1,"723":1,"724":1,"727":1,"728":1,"729":1,"758":1,"782":1},"1":{"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"724":1,"725":2,"726":2,"727":2,"728":1,"729":2},"2":{"42":1,"64":1,"65":3,"90":1,"202":6,"203":4,"210":6,"218":3,"266":1,"315":1,"322":1,"376":1,"385":1,"428":1,"487":1,"490":14,"505":1,"509":14,"598":1,"600":2,"640":1,"674":2,"714":1,"719":2,"723":5,"724":4,"725":1,"726":1,"728":2,"729":1,"730":1,"739":1,"741":1,"742":1,"743":2,"758":1,"765":3,"766":1,"768":3,"771":2,"772":3,"773":2,"776":1,"782":1,"785":1,"786":1}}],["apology",{"2":{"12":1}}],["apologizing",{"2":{"7":1}}],["appcelestia",{"2":{"375":1,"444":1}}],["appcd",{"2":{"311":1}}],["appconsts",{"2":{"150":6,"599":4}}],["appdsudo",{"2":{"604":2}}],["appd",{"0":{"412":1},"1":{"413":1},"2":{"260":4,"261":2,"262":8,"263":6,"264":6,"265":10,"266":10,"267":4,"268":2,"269":4,"270":2,"272":10,"279":18,"287":2,"288":2,"291":2,"292":2,"294":6,"295":2,"296":2,"297":4,"299":8,"301":4,"308":6,"309":4,"311":5,"312":5,"361":12,"373":9,"375":2,"379":1,"380":1,"381":1,"383":1,"412":2,"413":2,"437":3,"444":3,"445":2,"446":2,"447":2,"449":2,"450":3,"452":2,"453":2,"474":1,"479":2,"596":2,"599":2,"603":1,"604":15,"616":4,"622":13,"627":2}}],["append",{"2":{"118":2,"130":2}}],["appendix",{"0":{"95":1},"1":{"96":1,"97":1,"98":1,"99":1,"100":1,"101":1},"2":{"91":1}}],["appear",{"2":{"93":1,"275":1,"658":1}}],["appearance",{"2":{"6":1}}],["appeal",{"2":{"36":1}}],["app",{"0":{"283":1,"306":1,"310":1,"360":1,"439":1,"442":1,"596":1,"604":1,"651":1,"665":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"311":1,"312":1,"313":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"652":1},"2":{"64":1,"90":2,"144":2,"150":4,"152":1,"153":1,"156":4,"157":4,"163":6,"238":3,"260":2,"275":4,"281":1,"283":1,"284":1,"286":3,"287":8,"288":2,"291":4,"292":2,"294":6,"295":2,"296":2,"297":4,"298":1,"306":1,"307":1,"310":2,"311":12,"312":4,"313":1,"360":1,"361":13,"365":1,"367":1,"368":2,"371":5,"372":18,"373":4,"375":1,"377":2,"378":2,"380":1,"381":1,"383":1,"414":1,"427":1,"439":1,"442":1,"444":1,"448":1,"449":1,"450":3,"451":1,"473":1,"476":3,"484":1,"485":1,"487":1,"505":1,"533":1,"564":1,"590":2,"593":2,"594":1,"599":20,"604":1,"607":1,"609":1,"617":1,"622":3,"627":1,"648":6,"651":1,"652":2,"684":1,"685":1,"719":1,"754":4}}],["appreciate",{"2":{"42":1,"46":1}}],["appreciation",{"2":{"37":2}}],["approximation",{"2":{"485":1,"591":1}}],["approximately",{"2":{"79":1,"80":1}}],["approving",{"2":{"79":1}}],["approvedprovers",{"2":{"586":1}}],["approve",{"2":{"77":1,"80":1,"85":1,"601":1,"658":1}}],["approval",{"2":{"47":1,"658":1}}],["approaching",{"2":{"588":1}}],["approaches",{"2":{"164":1}}],["approach",{"2":{"36":1,"37":1,"38":1,"63":1,"186":1,"193":1,"199":1,"486":1,"501":1}}],["appropriate",{"2":{"8":2,"126":2,"337":1,"343":1,"429":1,"670":1,"710":1,"779":1}}],["apple",{"2":{"312":1,"342":1,"399":1}}],["applicable",{"2":{"24":2,"26":1,"30":1}}],["applicant",{"2":{"22":1}}],["applicants",{"2":{"22":8,"23":2,"25":2}}],["applications",{"2":{"23":1,"25":1,"27":3,"59":1,"249":1,"251":2,"254":1,"457":1,"480":1,"549":1,"579":1,"583":2,"584":2,"602":1,"604":1,"640":1,"646":1,"672":1,"674":1,"733":2}}],["application",{"0":{"25":1,"26":1},"1":{"26":1},"2":{"20":3,"23":3,"26":1,"238":1,"260":10,"276":1,"301":1,"308":1,"337":1,"372":1,"380":1,"383":1,"540":2,"567":1,"583":2,"584":1,"586":1,"590":2,"594":1,"609":1,"627":1,"646":7,"648":3,"690":1,"733":1,"737":1,"762":2}}],["applies",{"2":{"9":2,"105":1,"525":1}}],["applying",{"2":{"26":1,"32":1,"643":1}}],["apply",{"2":{"20":1,"24":1,"25":1,"316":1,"371":1,"649":1}}],["appointed",{"2":{"9":1}}],["acelestia",{"2":{"616":1}}],["achieve",{"2":{"521":1}}],["achieved",{"2":{"44":1,"276":1,"363":1}}],["acquire",{"0":{"84":1},"2":{"84":1}}],["acquaintances",{"2":{"38":1,"39":1}}],["across",{"2":{"41":2,"109":1,"156":1,"438":1,"583":1,"681":1}}],["acknowledging",{"2":{"38":1}}],["accurate",{"2":{"590":1}}],["accurately",{"2":{"333":1,"592":1}}],["accomplish",{"2":{"707":1}}],["accommodate",{"2":{"30":1}}],["accordingly",{"2":{"42":1,"91":1,"338":1,"518":1}}],["according",{"2":{"35":1,"227":1}}],["accountaddress",{"2":{"740":1}}],["accountname",{"2":{"599":2}}],["accounted",{"2":{"591":1}}],["accountexport",{"2":{"299":1}}],["accounts",{"0":{"297":1},"2":{"93":5,"144":2,"163":2,"278":4,"279":2,"297":1,"304":1,"404":1,"405":1,"591":1}}],["account",{"0":{"283":1,"290":1,"294":1,"295":1,"296":1,"300":1,"301":1,"409":1,"413":1,"447":1,"594":1,"753":1,"757":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":2,"292":2,"293":2,"294":2,"295":2,"296":2,"297":2,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1},"2":{"9":1,"86":2,"90":3,"93":9,"202":5,"260":4,"266":4,"272":3,"279":10,"283":3,"289":1,"290":1,"291":2,"294":12,"295":11,"296":6,"297":3,"298":2,"299":4,"301":4,"305":2,"325":1,"402":2,"403":2,"404":6,"405":4,"408":1,"409":2,"412":7,"413":1,"422":1,"429":4,"430":1,"447":2,"465":1,"479":6,"542":1,"544":2,"546":10,"563":3,"564":1,"571":2,"591":3,"594":1,"599":6,"638":1,"750":2,"753":3,"764":4,"767":4,"768":2,"785":1,"786":1}}],["accessing",{"2":{"636":1,"637":1}}],["accessible",{"2":{"30":1,"58":1,"227":1,"313":2,"326":2,"636":1,"699":4}}],["accessed",{"2":{"377":1}}],["access",{"0":{"68":1,"367":1,"495":1,"507":1},"2":{"36":1,"37":1,"47":2,"50":1,"58":1,"64":4,"68":2,"92":1,"136":1,"170":1,"184":1,"193":1,"202":2,"221":1,"244":1,"403":1,"422":2,"465":1,"487":4,"495":1,"505":4,"507":1,"591":1,"631":1,"635":1,"636":2,"640":2,"668":1,"674":4,"724":1,"725":1,"737":1,"762":1,"784":2}}],["accept",{"2":{"187":1,"274":2,"376":1,"590":1,"594":1,"652":1}}],["accepts",{"2":{"111":1,"211":1,"652":2}}],["accepted",{"2":{"22":1,"110":1,"559":1}}],["acceptable",{"2":{"8":1}}],["accepting",{"2":{"7":2}}],["actors",{"2":{"640":1}}],["acts",{"2":{"202":1}}],["actually",{"2":{"629":1,"722":1}}],["actual",{"2":{"126":3,"128":1,"137":1,"173":1,"214":1,"571":1,"591":1,"677":1}}],["activation",{"2":{"541":1}}],["activating",{"2":{"526":1}}],["activatecd",{"2":{"545":1}}],["activates",{"2":{"527":1}}],["activate",{"2":{"352":1,"528":2,"530":1,"545":1}}],["activity",{"2":{"92":1,"542":1}}],["activities",{"2":{"24":1,"30":1,"31":1}}],["active",{"2":{"20":1,"23":3,"26":2,"49":1,"238":1,"706":1,"707":1}}],["acting",{"2":{"9":1}}],["actions",{"2":{"13":1,"126":4}}],["action",{"2":{"8":1,"11":1,"147":2,"740":1}}],["act",{"2":{"6":1,"281":1}}],["async",{"2":{"779":2,"780":1,"781":1,"784":2}}],["aside",{"2":{"682":1}}],["ascii",{"2":{"263":2,"701":1}}],["aspects",{"2":{"41":1,"58":1}}],["asked",{"2":{"46":1,"199":1,"501":1}}],["ask",{"2":{"34":1,"37":1,"38":1,"652":1,"784":2}}],["assurances",{"0":{"641":1}}],["assumption",{"2":{"338":1,"560":1,"592":1,"633":2,"636":1}}],["assumptions",{"0":{"633":1},"2":{"224":1,"328":1,"636":1}}],["assumed",{"2":{"633":1,"695":1}}],["assumes",{"2":{"215":2,"315":1,"341":1,"474":1,"592":1,"633":1,"762":1}}],["assume",{"2":{"126":1,"202":1,"583":1,"767":1}}],["assign",{"2":{"86":1,"272":1}}],["assist",{"2":{"40":1,"41":1}}],["assistance",{"2":{"39":1,"41":1}}],["associated",{"2":{"23":1,"39":1,"160":2,"322":2,"455":1,"520":1,"565":1,"651":2,"750":1}}],["asset",{"2":{"689":1}}],["assets",{"2":{"7":1,"255":1}}],["assert",{"2":{"191":1,"779":6}}],["asserted",{"2":{"187":2}}],["assertions",{"2":{"86":3}}],["assessing",{"2":{"32":1}}],["assess",{"2":{"20":1,"36":1}}],["as",{"0":{"106":1,"407":1,"408":1,"410":1,"452":1,"577":1,"602":1,"763":1},"1":{"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"411":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1},"2":{"6":1,"7":2,"9":1,"13":2,"22":1,"23":2,"30":1,"34":2,"36":1,"37":3,"38":2,"39":2,"41":1,"44":1,"48":1,"50":1,"51":1,"58":3,"60":1,"68":1,"79":1,"86":1,"87":2,"88":2,"91":1,"93":1,"108":1,"109":2,"110":2,"113":1,"117":1,"119":1,"122":1,"125":5,"126":2,"127":2,"130":1,"133":1,"136":1,"139":1,"147":1,"152":2,"153":2,"154":1,"155":1,"156":2,"157":3,"158":1,"159":1,"162":2,"163":5,"169":1,"175":1,"178":1,"180":2,"183":1,"184":1,"186":1,"187":3,"188":1,"191":6,"194":2,"197":1,"199":1,"202":3,"203":2,"204":1,"208":1,"210":3,"211":2,"213":1,"215":2,"221":1,"224":1,"226":1,"227":2,"233":2,"234":1,"238":1,"245":1,"248":1,"250":1,"254":1,"260":2,"266":1,"267":1,"273":1,"275":5,"276":1,"278":1,"287":1,"293":3,"294":1,"295":1,"299":1,"301":1,"308":2,"313":1,"320":1,"321":1,"322":6,"325":1,"326":1,"328":2,"332":1,"333":1,"355":1,"365":1,"371":1,"372":1,"373":1,"396":1,"400":2,"405":2,"413":1,"422":4,"425":1,"426":1,"428":3,"437":1,"439":1,"447":1,"451":1,"452":1,"455":5,"465":2,"470":1,"474":1,"477":1,"480":1,"481":1,"484":2,"485":1,"501":1,"509":1,"527":1,"538":1,"539":2,"542":4,"552":1,"554":1,"564":1,"571":1,"582":6,"590":2,"591":1,"592":2,"594":1,"599":2,"602":1,"603":1,"604":1,"608":1,"609":1,"616":2,"617":1,"621":1,"623":1,"629":2,"632":2,"633":1,"635":1,"636":1,"639":2,"643":4,"645":3,"646":4,"648":1,"649":5,"651":3,"652":3,"653":1,"672":3,"673":4,"674":4,"676":1,"680":1,"682":2,"690":3,"691":1,"692":1,"709":3,"711":1,"712":1,"715":1,"717":2,"718":1,"724":2,"725":1,"726":2,"736":1,"740":3,"744":1,"745":2,"757":1,"762":1,"768":1,"771":1,"772":2,"773":2,"775":2,"776":1,"778":3,"779":1,"780":1}}],["annual",{"2":{"677":2}}],["annually",{"2":{"677":1,"687":1}}],["announced",{"2":{"39":1}}],["announce",{"2":{"39":1}}],["announcements",{"2":{"500":1,"515":1,"556":2}}],["announcement",{"2":{"39":1,"73":1,"500":1,"501":1,"515":1,"556":1}}],["announcing",{"2":{"39":2}}],["anger",{"2":{"291":2}}],["analytics",{"0":{"499":1,"513":1},"2":{"499":2,"513":1}}],["analysis",{"2":{"183":1}}],["analyze",{"2":{"32":1}}],["analogously",{"2":{"120":1}}],["analogous",{"2":{"119":1}}],["analog",{"2":{"118":2}}],["another",{"0":{"247":1,"424":1,"469":1,"751":1,"757":1},"2":{"86":1,"93":2,"170":1,"183":1,"244":1,"265":1,"281":1,"355":1,"400":1,"404":1,"405":1,"415":1,"438":1,"561":1,"590":1,"617":1,"651":1,"706":1,"707":1,"737":1,"751":1}}],["answer",{"2":{"42":1,"294":1,"774":1}}],["answers",{"2":{"16":1,"41":1,"629":1}}],["anticipate",{"2":{"36":1}}],["an",{"0":{"79":1,"81":1,"90":1,"212":1,"376":1,"383":1,"407":1,"524":1,"542":1,"546":1,"627":1,"713":1,"763":1,"781":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"377":1,"378":1,"379":1,"543":1,"544":1,"545":1,"546":1,"547":1},"2":{"4":1,"6":1,"9":5,"12":1,"15":1,"21":1,"23":4,"26":1,"31":1,"34":1,"36":1,"37":2,"38":1,"41":1,"46":1,"47":2,"49":1,"53":1,"54":1,"55":1,"58":1,"68":2,"77":2,"79":1,"84":1,"86":2,"87":1,"90":4,"93":1,"94":1,"103":1,"107":2,"109":1,"110":1,"111":1,"112":2,"113":1,"117":1,"119":1,"122":2,"124":1,"126":4,"127":2,"136":1,"141":1,"144":2,"151":2,"155":1,"156":2,"157":1,"159":1,"160":3,"161":2,"163":4,"171":1,"172":2,"175":1,"178":2,"179":1,"182":1,"199":2,"202":6,"203":1,"208":3,"210":3,"212":1,"217":1,"218":1,"221":2,"222":1,"228":1,"238":2,"240":1,"244":2,"245":1,"249":1,"251":3,"260":4,"263":1,"267":2,"272":1,"273":1,"275":1,"276":1,"281":1,"301":3,"302":1,"308":1,"311":1,"312":1,"316":1,"317":1,"318":1,"319":1,"321":2,"324":1,"328":2,"332":1,"334":3,"337":1,"355":1,"358":1,"367":1,"380":1,"381":1,"383":3,"388":1,"390":3,"392":1,"400":2,"417":1,"422":1,"428":2,"434":1,"449":1,"462":1,"477":1,"485":1,"495":1,"546":1,"547":1,"559":1,"568":1,"583":1,"586":2,"590":1,"591":3,"593":1,"594":1,"599":2,"614":1,"616":2,"619":1,"622":1,"627":3,"630":1,"633":3,"642":1,"646":4,"648":1,"649":6,"650":1,"651":1,"652":1,"676":1,"677":1,"683":1,"687":1,"689":1,"696":1,"707":2,"709":2,"710":1,"713":1,"726":1,"737":3,"742":1,"743":1,"744":2,"745":3,"747":2,"751":1,"752":1,"753":1,"754":1,"757":1,"764":1,"765":1,"766":1,"767":1,"768":6,"772":2,"773":3,"775":2,"778":2,"779":2,"781":1}}],["anyone",{"2":{"427":1,"454":1,"629":1,"650":1}}],["anyway",{"2":{"326":1,"728":1,"733":1}}],["anything",{"2":{"180":1,"430":1,"544":1}}],["anytrust",{"2":{"85":1,"86":1,"107":1,"109":1}}],["any",{"2":{"4":1,"7":1,"8":1,"10":1,"11":1,"14":1,"15":1,"23":4,"24":1,"26":1,"30":3,"31":2,"39":2,"42":1,"69":2,"91":1,"124":1,"174":1,"199":1,"201":1,"206":1,"208":1,"221":1,"260":2,"275":4,"311":1,"334":1,"341":1,"345":1,"349":1,"355":1,"371":1,"408":1,"437":1,"481":1,"496":1,"512":2,"536":1,"544":1,"580":1,"582":1,"584":2,"586":1,"588":1,"616":1,"629":1,"644":1,"691":1,"698":1,"719":1,"721":1,"722":1,"740":1}}],["and",{"0":{"33":1,"35":1,"39":1,"60":1,"74":1,"88":1,"89":1,"92":1,"102":1,"215":1,"224":1,"226":1,"250":1,"263":1,"281":1,"314":1,"331":1,"332":1,"355":1,"362":1,"392":1,"466":1,"479":1,"481":1,"504":1,"511":1,"546":1,"562":1,"589":1,"590":1,"610":1,"637":1,"657":1,"659":1,"662":1,"663":1,"666":1,"672":1,"673":1,"704":1,"710":1,"718":1,"719":1,"738":1,"767":1,"779":1},"1":{"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"103":1,"104":1,"105":1,"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"467":1,"505":1,"506":1,"507":1,"563":1,"564":1,"565":1,"590":1,"591":2,"592":2,"593":2,"594":1,"673":1,"674":1,"705":1,"706":1,"707":1},"2":{"0":1,"1":1,"2":4,"3":2,"6":5,"7":8,"8":6,"9":1,"10":3,"12":1,"18":3,"20":2,"21":1,"22":3,"23":11,"25":1,"26":10,"27":2,"30":12,"31":7,"32":6,"33":1,"34":6,"35":9,"36":7,"37":6,"38":8,"39":11,"40":11,"41":4,"42":3,"44":4,"46":4,"47":2,"48":1,"50":2,"51":3,"52":1,"53":1,"54":1,"55":1,"56":1,"57":2,"58":10,"59":2,"65":1,"68":1,"74":3,"79":3,"80":1,"81":5,"82":3,"85":2,"86":13,"87":4,"88":3,"89":1,"90":6,"91":1,"92":2,"93":5,"94":2,"96":2,"103":1,"105":1,"107":2,"109":9,"110":3,"111":1,"119":1,"121":1,"122":9,"124":3,"125":3,"126":8,"127":3,"128":1,"130":10,"132":1,"136":1,"137":5,"139":4,"140":2,"141":1,"144":2,"145":2,"147":2,"150":1,"151":2,"156":5,"157":2,"159":3,"160":4,"161":4,"162":2,"163":4,"164":3,"165":1,"166":2,"168":3,"169":1,"172":3,"173":2,"174":2,"175":5,"178":3,"179":3,"180":2,"182":1,"183":5,"185":1,"186":2,"187":3,"191":4,"194":2,"196":1,"197":2,"199":4,"202":8,"203":4,"204":3,"205":3,"208":3,"209":1,"210":6,"211":3,"214":2,"215":5,"216":3,"217":2,"218":1,"219":1,"221":4,"226":5,"227":4,"228":1,"229":1,"233":4,"234":1,"235":4,"237":1,"238":5,"244":1,"245":1,"247":1,"251":1,"252":1,"254":1,"255":1,"256":1,"258":1,"259":2,"260":6,"263":2,"266":5,"267":2,"273":3,"275":9,"276":1,"279":2,"281":8,"282":1,"283":1,"284":2,"286":1,"287":2,"291":1,"293":1,"294":2,"295":1,"298":1,"299":1,"300":1,"303":1,"305":1,"307":1,"310":2,"311":2,"313":2,"314":1,"316":2,"321":1,"322":9,"326":3,"328":7,"331":3,"332":2,"333":2,"334":1,"335":1,"336":1,"337":2,"338":2,"339":1,"341":7,"343":1,"344":1,"345":1,"347":1,"348":1,"350":1,"352":1,"361":1,"363":1,"365":1,"367":1,"369":2,"370":1,"371":6,"372":1,"376":1,"378":1,"380":2,"381":4,"385":1,"388":2,"389":2,"391":1,"392":1,"397":1,"398":4,"399":2,"400":3,"404":1,"405":1,"408":1,"412":2,"415":2,"422":1,"424":1,"427":4,"428":1,"429":2,"430":1,"431":2,"432":5,"435":2,"438":1,"439":1,"450":1,"454":3,"455":4,"456":1,"457":2,"459":1,"463":1,"464":1,"465":1,"469":1,"472":1,"474":2,"476":1,"478":2,"480":2,"481":4,"485":4,"495":2,"501":2,"507":1,"508":1,"510":2,"511":1,"517":1,"518":1,"522":1,"525":2,"526":2,"527":1,"528":2,"530":2,"532":2,"533":2,"536":1,"538":1,"539":1,"541":2,"542":7,"544":4,"545":1,"546":1,"549":4,"552":1,"557":4,"559":5,"560":3,"561":4,"563":2,"564":2,"565":2,"568":1,"571":4,"572":1,"573":1,"574":3,"576":1,"579":2,"580":4,"583":4,"584":2,"586":1,"587":1,"588":1,"590":2,"591":3,"592":6,"593":3,"594":2,"595":1,"599":14,"601":6,"604":1,"606":1,"607":3,"608":1,"610":1,"611":2,"617":1,"622":3,"623":1,"627":2,"629":2,"630":3,"633":1,"634":1,"635":3,"636":2,"637":2,"638":2,"639":4,"641":2,"642":3,"643":4,"644":1,"645":3,"646":8,"648":3,"649":9,"650":2,"651":7,"652":3,"653":2,"656":1,"657":1,"658":1,"661":1,"662":2,"665":1,"666":1,"667":1,"670":4,"671":1,"672":4,"673":1,"674":4,"676":2,"677":2,"679":4,"681":6,"682":3,"683":1,"690":1,"692":1,"694":1,"695":1,"698":1,"700":1,"701":1,"708":1,"709":1,"710":3,"712":2,"713":1,"715":1,"717":5,"718":2,"719":1,"721":2,"722":1,"723":2,"724":4,"725":1,"726":1,"727":1,"728":1,"730":1,"733":4,"735":1,"736":2,"737":1,"739":1,"740":2,"741":1,"742":2,"744":1,"745":4,"747":1,"748":2,"757":2,"759":1,"762":1,"763":1,"764":1,"765":3,"767":4,"768":2,"770":1,"771":4,"772":5,"773":19,"774":4,"775":7,"776":1,"777":1,"778":2,"779":2,"781":1,"783":3,"784":2,"785":3,"786":4}}],["a",{"0":{"42":1,"54":1,"55":1,"102":1,"104":1,"105":1,"125":1,"144":1,"179":1,"180":1,"181":1,"182":1,"191":1,"202":1,"211":1,"212":1,"237":1,"246":1,"261":1,"272":1,"283":1,"291":1,"299":1,"301":1,"302":1,"306":1,"308":1,"309":1,"312":1,"333":1,"338":2,"342":1,"358":1,"363":2,"407":1,"408":2,"410":2,"411":1,"414":1,"423":1,"432":1,"443":1,"445":1,"446":1,"452":1,"458":1,"461":1,"468":1,"472":1,"518":2,"519":1,"523":1,"538":1,"545":1,"546":1,"558":1,"576":1,"577":1,"579":1,"580":1,"582":1,"599":1,"600":1,"601":1,"602":1,"612":1,"614":1,"616":1,"647":1,"651":1,"657":1,"662":1,"666":1,"687":1,"697":1,"736":1,"737":1,"762":1,"763":1,"767":1,"785":1,"786":1},"1":{"103":1,"104":1,"105":1,"180":1,"181":1,"182":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"339":2,"343":1,"359":1,"360":1,"361":1,"364":2,"365":2,"411":2,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":2,"425":1,"426":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"459":1,"460":1,"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"467":1,"468":1,"469":2,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"520":1,"521":1,"559":1,"560":1,"561":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1,"613":1,"614":1,"615":2,"616":2,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"626":1,"627":1,"648":1,"652":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"707":1},"2":{"2":4,"3":5,"6":1,"7":3,"12":2,"13":5,"14":4,"15":2,"18":3,"20":1,"21":2,"22":2,"23":6,"24":1,"25":1,"26":2,"27":1,"28":1,"29":2,"30":6,"31":1,"33":3,"34":12,"35":3,"36":8,"37":7,"38":7,"39":3,"40":3,"41":8,"42":4,"44":1,"46":2,"47":2,"48":1,"50":1,"51":1,"53":1,"54":7,"55":5,"58":5,"59":2,"60":2,"67":3,"68":4,"70":2,"74":2,"79":1,"80":1,"81":3,"82":3,"84":2,"85":2,"86":15,"87":3,"88":1,"90":7,"91":10,"92":1,"93":2,"94":1,"103":1,"104":2,"105":3,"107":1,"108":1,"109":21,"110":5,"111":3,"112":2,"117":1,"118":3,"119":8,"120":4,"122":13,"124":3,"125":15,"126":19,"127":3,"128":3,"130":6,"136":3,"137":10,"139":17,"141":5,"145":5,"146":1,"149":1,"151":7,"154":2,"156":4,"157":3,"159":2,"160":8,"163":2,"165":1,"167":1,"168":2,"169":5,"170":1,"171":1,"172":7,"173":1,"174":6,"175":12,"176":1,"178":3,"179":3,"180":3,"183":7,"186":1,"187":1,"188":1,"191":1,"193":2,"194":1,"197":1,"199":3,"200":1,"201":3,"202":17,"203":1,"204":6,"205":1,"206":2,"207":2,"208":11,"209":1,"210":4,"211":7,"212":2,"214":10,"215":10,"216":4,"217":5,"218":3,"219":3,"221":2,"224":2,"225":1,"226":3,"227":8,"228":2,"230":1,"233":1,"234":3,"235":3,"238":6,"244":1,"245":5,"246":2,"247":1,"248":2,"249":1,"250":3,"251":2,"254":1,"255":1,"259":1,"260":10,"263":4,"266":7,"267":4,"269":2,"271":1,"272":1,"273":2,"274":2,"275":16,"276":1,"277":3,"278":3,"279":2,"281":9,"282":2,"283":4,"287":1,"289":4,"290":1,"291":3,"294":3,"295":1,"297":2,"298":4,"299":3,"301":4,"302":2,"303":2,"304":1,"305":3,"306":1,"309":1,"310":1,"311":1,"312":2,"313":5,"314":2,"315":1,"320":6,"321":2,"322":2,"324":1,"325":1,"326":5,"328":2,"329":3,"331":4,"332":1,"333":1,"336":4,"337":1,"338":7,"341":2,"342":2,"343":2,"344":1,"349":2,"352":1,"353":1,"355":5,"356":1,"357":1,"361":4,"363":1,"367":2,"368":1,"369":2,"370":1,"371":4,"372":2,"373":2,"376":1,"377":1,"378":2,"380":1,"381":2,"383":1,"385":2,"386":2,"387":4,"388":2,"389":2,"390":1,"391":6,"392":1,"393":2,"396":3,"400":2,"402":2,"403":1,"404":4,"407":1,"408":2,"409":1,"411":1,"412":2,"414":3,"422":8,"423":2,"424":1,"425":2,"427":1,"428":2,"430":1,"432":1,"433":3,"434":17,"438":3,"439":2,"443":1,"444":2,"446":2,"452":1,"453":1,"454":2,"455":4,"456":1,"457":2,"458":1,"460":1,"461":1,"465":5,"466":1,"468":2,"469":1,"470":1,"472":2,"474":2,"477":1,"478":1,"479":1,"480":1,"481":1,"484":2,"485":9,"486":1,"494":3,"495":3,"497":1,"500":1,"501":2,"506":3,"507":5,"510":2,"512":2,"515":1,"517":4,"518":2,"520":2,"521":1,"522":1,"524":1,"526":1,"527":1,"528":5,"530":4,"533":1,"536":3,"537":1,"538":4,"539":1,"542":8,"544":2,"545":3,"546":4,"552":1,"554":1,"556":1,"557":6,"558":1,"559":4,"560":3,"563":1,"564":5,"565":3,"567":1,"568":3,"569":1,"570":1,"574":1,"576":1,"577":1,"579":3,"580":5,"582":7,"583":3,"584":2,"585":1,"586":4,"587":1,"588":6,"589":1,"590":6,"591":10,"592":13,"593":4,"594":7,"598":4,"599":10,"601":3,"602":1,"603":2,"604":1,"609":4,"610":2,"611":1,"612":1,"613":1,"614":1,"615":1,"616":3,"617":4,"621":2,"622":4,"623":1,"627":2,"629":2,"630":5,"631":3,"632":6,"633":5,"634":3,"635":2,"636":4,"637":1,"638":2,"639":4,"641":1,"642":5,"643":9,"644":3,"645":7,"646":4,"648":5,"649":10,"650":3,"651":13,"652":9,"653":2,"656":1,"657":1,"658":1,"662":1,"666":1,"668":1,"670":5,"671":3,"673":3,"674":2,"676":4,"679":2,"680":1,"681":2,"682":2,"683":4,"689":1,"690":6,"691":3,"692":1,"697":1,"698":1,"700":5,"701":1,"702":1,"706":2,"707":1,"709":1,"710":7,"711":6,"712":5,"713":1,"717":1,"719":1,"722":1,"723":1,"724":2,"725":1,"726":1,"728":1,"733":1,"734":1,"736":2,"737":4,"738":2,"739":1,"740":1,"742":2,"743":3,"744":4,"745":7,"746":1,"748":2,"757":3,"759":1,"762":3,"764":1,"765":1,"767":3,"770":2,"771":5,"772":4,"773":21,"774":3,"775":4,"776":3,"778":1,"779":4,"780":1,"781":1,"784":2,"785":1,"786":1}}],["bzsidenode",{"2":{"159":6,"160":6,"163":8}}],["bip44",{"2":{"784":2}}],["bip39",{"2":{"702":1}}],["billion",{"2":{"682":1}}],["bi",{"2":{"592":2}}],["bidirectional",{"2":{"353":1}}],["bitter",{"2":{"291":2}}],["bigger",{"2":{"629":1,"633":1}}],["big",{"2":{"144":8,"156":4,"159":4,"160":8,"163":18}}],["bincd",{"2":{"214":1}}],["bin",{"2":{"209":2,"211":2,"214":5,"215":2,"279":2,"311":1,"312":1,"342":2,"343":6,"398":2,"399":9,"545":2,"558":2,"706":2,"707":2}}],["binaries",{"2":{"203":2,"211":1,"312":2,"342":2,"397":1}}],["binarymerkleproof",{"2":{"118":4,"119":1,"144":2,"154":4,"159":9,"160":5,"163":8}}],["binary",{"0":{"311":1,"312":1,"342":1,"345":1},"1":{"343":1},"2":{"96":1,"104":1,"110":2,"118":2,"119":1,"122":1,"139":1,"141":1,"145":1,"151":2,"154":2,"160":2,"174":2,"175":1,"211":5,"214":1,"215":1,"243":1,"260":2,"282":2,"287":1,"310":1,"311":5,"312":4,"341":4,"342":3,"343":1,"345":1,"383":1,"388":1,"403":1,"463":1,"473":1,"528":2,"530":3,"557":1,"558":3,"568":1,"627":2,"699":4,"767":1}}],["binding",{"2":{"144":2,"161":2,"163":2}}],["bindings",{"2":{"136":7,"144":4,"161":2,"162":2,"163":4,"228":1,"233":1}}],["bind",{"2":{"144":6,"161":2,"162":2,"163":4,"377":1}}],["blind",{"2":{"291":2}}],["blue",{"2":{"137":1}}],["blobclient",{"2":{"779":2}}],["blobchan",{"2":{"711":2}}],["blobresponse",{"2":{"711":2}}],["blobtypes",{"2":{"593":4,"599":6}}],["blobtxs",{"2":{"595":1}}],["blobtx",{"2":{"587":1,"599":4}}],["blobdata",{"2":{"564":3}}],["blobpointer",{"2":{"109":1}}],["blob",{"0":{"149":1,"167":1,"168":1,"169":1,"170":1,"171":1,"183":1,"184":1,"185":1,"190":1,"192":1,"193":1,"411":1,"588":1,"601":1,"762":1},"1":{"150":1,"168":1,"169":1,"170":1,"171":1,"184":1,"185":1,"191":1,"192":1,"193":1},"2":{"91":1,"93":1,"109":1,"110":2,"136":4,"137":2,"139":1,"144":4,"145":1,"147":6,"149":1,"150":7,"155":1,"156":1,"160":2,"161":2,"163":4,"166":1,"167":1,"168":8,"169":2,"170":1,"173":1,"175":3,"176":1,"183":5,"184":1,"186":1,"188":1,"190":1,"191":5,"194":7,"199":2,"331":4,"332":2,"333":2,"371":4,"408":4,"409":1,"411":5,"412":2,"479":3,"485":4,"520":3,"521":3,"525":1,"530":1,"557":3,"564":6,"565":6,"587":2,"588":2,"591":6,"592":6,"593":6,"596":2,"597":3,"598":24,"599":14,"600":1,"601":6,"670":1,"671":1,"673":1,"710":30,"711":5,"712":2,"740":8,"745":12,"746":1,"747":10,"748":3,"762":5,"771":8,"772":6,"773":51,"775":11,"776":1,"779":34,"780":2}}],["blobspace",{"0":{"669":1,"689":1},"1":{"670":1,"671":1}}],["blobsharerange",{"2":{"150":2,"163":4}}],["blobs",{"0":{"401":1,"516":1,"519":1,"587":1,"710":1,"711":1,"732":1,"779":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":1,"412":1,"413":1,"517":1,"518":1,"519":1,"520":2,"521":2,"522":1,"523":1,"524":1,"525":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1},"2":{"68":1,"109":1,"137":1,"150":1,"402":1,"404":2,"495":1,"507":1,"517":1,"540":1,"542":1,"557":1,"587":1,"588":1,"591":1,"592":3,"598":2,"601":1,"670":2,"673":1,"710":5,"711":11,"712":13,"730":1,"747":1,"773":1,"779":13,"780":17}}],["blobstreamgit",{"2":{"586":1}}],["blobstreamwrapper",{"2":{"162":4}}],["blobstreamxcd",{"2":{"208":1}}],["blobstreamxdatacommitmentstored",{"2":{"144":4,"161":4,"162":2}}],["blobstreamxwrapper",{"2":{"144":14,"161":6,"162":4}}],["blobstreamxsp1",{"2":{"136":1,"144":1,"161":1,"162":1,"163":1}}],["blobstreamx",{"0":{"208":1},"1":{"209":1,"210":1},"2":{"91":4,"109":3,"111":2,"118":1,"120":1,"136":4,"144":16,"154":2,"161":8,"162":4,"163":10,"200":1,"202":2,"203":5,"204":2,"208":5,"210":4,"211":9,"212":2,"215":7,"217":3,"233":4,"234":1}}],["blobstream",{"0":{"97":1,"111":1,"114":1,"117":1,"123":1,"124":1,"132":1,"135":1,"144":1,"165":1,"200":1,"220":1,"221":1,"222":1,"223":1,"227":1,"228":1,"229":1,"230":1,"232":2,"233":1,"234":1,"235":1,"585":1},"1":{"98":1,"99":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"154":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"164":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"195":1,"196":1,"197":1,"198":1,"199":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"221":1,"222":2,"223":1,"224":2,"225":2,"226":2,"227":1,"228":1,"229":2,"230":2,"231":2,"233":2,"234":2,"235":2,"236":2,"586":1},"2":{"26":1,"90":3,"91":6,"96":1,"97":1,"108":1,"110":1,"111":1,"112":1,"117":4,"118":22,"121":1,"122":9,"124":3,"125":2,"126":4,"127":3,"128":1,"130":2,"132":1,"136":4,"137":2,"139":5,"141":2,"144":7,"154":4,"160":6,"161":5,"162":5,"163":13,"164":1,"165":2,"166":2,"168":2,"171":1,"174":1,"175":2,"178":2,"186":1,"201":1,"203":2,"212":1,"216":3,"217":1,"218":4,"219":2,"221":11,"222":3,"224":2,"225":2,"226":3,"227":12,"228":6,"229":4,"230":2,"231":8,"233":8,"234":3,"235":3,"236":1,"400":1,"585":3,"586":6}}],["blocktimes",{"2":{"722":1}}],["blockdataroot",{"2":{"160":3,"163":8}}],["blockres",{"2":{"144":2,"150":2}}],["blocknumber",{"2":{"144":2,"161":2,"539":2}}],["block",{"0":{"92":1,"130":1,"133":1,"144":1,"365":1,"370":1,"383":2,"594":1,"627":2,"634":1,"754":1},"2":{"68":1,"91":1,"93":12,"118":16,"119":2,"120":1,"122":5,"124":1,"125":34,"126":2,"127":4,"128":17,"130":15,"137":4,"139":3,"141":3,"144":10,"149":1,"150":6,"151":1,"152":1,"160":16,"161":4,"163":6,"168":3,"171":1,"172":3,"174":1,"183":1,"187":1,"199":1,"209":4,"215":2,"216":6,"221":1,"227":2,"228":1,"233":3,"238":2,"267":1,"279":2,"322":3,"338":2,"363":1,"365":2,"368":3,"369":1,"370":2,"371":1,"381":3,"383":4,"412":2,"415":2,"429":4,"455":1,"459":1,"461":1,"477":5,"485":3,"495":1,"528":1,"530":1,"532":1,"538":3,"560":2,"588":2,"594":2,"599":2,"616":1,"622":1,"627":5,"629":3,"630":4,"631":2,"632":4,"633":4,"634":2,"637":1,"640":1,"642":1,"643":8,"644":3,"645":4,"646":3,"648":2,"650":2,"651":10,"652":13,"670":3,"672":1,"674":4,"677":3,"680":1,"692":1,"713":2,"722":1,"733":1,"745":1,"747":6,"748":1,"754":10,"762":1,"773":2,"781":2,"785":1}}],["blockscout",{"2":{"77":1,"92":2}}],["blocks",{"0":{"128":1},"2":{"67":1,"86":2,"92":1,"125":3,"126":4,"127":1,"128":12,"130":13,"139":4,"145":1,"161":2,"172":2,"178":2,"208":1,"216":1,"238":3,"281":2,"289":1,"322":4,"365":3,"368":4,"369":2,"371":3,"455":3,"494":1,"506":1,"507":2,"533":2,"594":2,"607":1,"629":1,"633":2,"634":1,"637":1,"644":1,"645":1,"673":3,"674":3,"677":1,"722":2}}],["blockchains",{"0":{"581":1,"641":1,"649":1,"722":1},"1":{"582":1,"583":1,"584":1},"2":{"53":3,"56":1,"58":1,"127":1,"255":1,"281":1,"574":2,"580":3,"582":2,"583":2,"584":1,"629":2,"631":1,"639":1,"641":1,"649":6,"650":1}}],["blockchain",{"0":{"580":1,"638":1,"647":1},"1":{"648":1},"2":{"18":1,"34":1,"51":1,"53":1,"125":3,"126":3,"130":1,"134":1,"252":3,"322":1,"356":1,"370":2,"372":1,"427":1,"454":2,"526":1,"533":1,"579":1,"580":3,"582":3,"599":2,"629":1,"630":1,"636":1,"638":1,"639":1,"641":1,"642":2,"648":3,"649":1,"650":2,"653":1,"676":2,"689":1,"690":2,"722":2,"765":3,"775":3}}],["blog",{"2":{"30":1,"32":1}}],["b",{"2":{"130":10,"163":24,"341":1,"434":8,"586":1,"681":1,"682":1,"779":4}}],["brush",{"2":{"580":1}}],["brevity",{"2":{"559":1,"649":1}}],["brew",{"2":{"275":1,"398":4}}],["breaking",{"2":{"526":4,"528":1,"532":1,"554":1,"593":1}}],["break",{"2":{"60":1,"349":1,"564":1,"565":1}}],["breaks",{"2":{"31":1,"37":1}}],["broken",{"2":{"291":2,"528":1}}],["browsers",{"2":{"728":1}}],["browser",{"0":{"461":1,"656":1,"661":1},"2":{"82":1,"275":1,"461":1,"497":1,"656":1}}],["broadcasttx",{"2":{"599":2}}],["broadcast",{"2":{"210":2,"279":4,"303":2,"412":2,"510":1,"650":1}}],["broadcasting",{"2":{"68":1,"294":2,"303":2,"495":1,"507":1,"508":1,"622":2}}],["broader",{"2":{"37":1,"40":1,"58":1,"481":1}}],["branding",{"0":{"52":1}}],["brand",{"2":{"41":1,"52":1}}],["branch",{"2":{"2":3}}],["brightlystake",{"2":{"489":1,"490":1,"491":1,"508":1,"509":1,"510":1}}],["brightest",{"2":{"58":1}}],["bridging",{"0":{"74":1},"1":{"75":1,"76":1,"77":1,"78":1,"79":1,"80":1},"2":{"74":1,"87":1,"227":2,"255":1}}],["bridgefulllight",{"2":{"700":1,"701":1,"702":1}}],["bridgecelestia",{"2":{"478":1,"479":1}}],["bridgecreator",{"2":{"100":1,"101":1}}],["bridge=",{"2":{"314":4}}],["bridgesudo",{"2":{"337":1}}],["bridges",{"2":{"227":1,"533":1}}],["bridge",{"0":{"67":1,"75":1,"78":1,"237":1,"238":1,"240":1,"242":1,"244":1,"245":1,"246":1,"248":1,"255":1,"363":1,"477":1,"494":1,"504":1,"506":1,"511":1,"607":1,"619":1,"620":1,"621":1},"1":{"76":1,"77":1,"79":1,"80":1,"238":1,"239":1,"240":1,"241":2,"242":1,"243":2,"244":2,"245":2,"246":3,"247":3,"248":2,"364":1,"365":1,"505":1,"506":1,"507":1,"621":1},"2":{"23":2,"26":3,"27":1,"65":6,"67":1,"68":2,"74":2,"76":1,"77":1,"79":1,"80":2,"84":2,"88":1,"93":8,"94":1,"100":1,"101":1,"105":1,"126":2,"163":4,"221":1,"237":2,"238":4,"239":1,"243":1,"244":9,"245":12,"246":9,"247":3,"248":2,"255":2,"313":2,"314":4,"322":1,"326":2,"328":1,"335":1,"336":4,"337":10,"349":2,"350":1,"353":1,"355":3,"363":1,"386":1,"387":1,"400":1,"472":1,"477":10,"478":2,"479":2,"493":1,"494":1,"495":2,"501":1,"506":1,"507":2,"511":7,"533":1,"535":1,"607":20,"608":1,"617":3,"619":2,"620":2,"621":2,"649":1,"698":1,"700":2,"701":2,"702":2,"736":1}}],["briefly",{"2":{"38":1,"87":1}}],["bringing",{"2":{"275":1}}],["bring",{"2":{"35":1,"58":1}}],["bonddenomalias",{"2":{"696":1}}],["bonddenom",{"2":{"695":1}}],["bonded",{"2":{"281":2}}],["bonus",{"2":{"598":2,"776":1}}],["box",{"2":{"584":1}}],["boxes",{"2":{"79":1}}],["bound",{"2":{"485":1}}],["bounds",{"2":{"174":2,"179":1}}],["bot",{"2":{"430":1}}],["both",{"2":{"22":1,"23":1,"27":1,"88":1,"93":1,"97":1,"126":1,"186":1,"204":1,"226":1,"275":1,"283":1,"303":1,"310":1,"430":1,"455":1,"521":1,"592":1,"642":1,"646":1,"649":1,"670":1,"679":1}}],["bootstrapping",{"0":{"690":1},"2":{"674":1}}],["bootstrappeers",{"2":{"352":2}}],["bootstrappers",{"2":{"352":1,"495":1}}],["bootstrapper",{"2":{"314":1,"352":3,"511":1}}],["bootstrap",{"0":{"352":1},"2":{"355":1,"690":1}}],["boolean",{"2":{"316":2,"320":1}}],["bool",{"2":{"118":2,"144":2,"163":2}}],["boost",{"2":{"40":1}}],["book",{"2":{"34":1,"134":1}}],["board",{"2":{"37":2}}],["borrowing",{"2":{"34":1}}],["body",{"2":{"6":1,"294":2}}],["bad",{"2":{"634":2}}],["bar",{"2":{"601":1}}],["bare",{"2":{"390":1}}],["barrier",{"2":{"86":2}}],["bak",{"2":{"361":10,"378":2}}],["balancecelestia",{"2":{"408":1,"409":1,"563":1,"750":1}}],["balance",{"0":{"750":1,"751":1,"757":1},"2":{"93":4,"226":1,"267":1,"297":3,"367":1,"400":1,"408":3,"409":2,"413":1,"422":1,"465":1,"563":2,"750":2,"751":7,"767":3,"785":1,"786":1}}],["balances",{"0":{"297":1,"409":1},"2":{"68":1,"244":1,"265":5,"294":1,"297":6,"309":2,"413":2,"422":1,"495":1,"507":1,"638":2,"737":1}}],["batcher",{"2":{"455":5,"539":1,"541":1,"542":1,"546":4}}],["batched",{"2":{"225":1}}],["batches",{"0":{"541":1},"2":{"86":2,"90":1,"109":1,"111":2,"119":1,"144":2,"161":2,"163":2,"171":1,"215":5,"233":2,"455":3,"541":2,"651":1}}],["batchposter",{"2":{"112":1}}],["batch",{"0":{"90":1},"2":{"86":4,"87":1,"88":2,"90":2,"91":5,"93":3,"95":1,"109":8,"120":2,"139":4,"160":1,"208":1,"216":1,"429":8,"541":4}}],["backward",{"2":{"526":2}}],["backers",{"2":{"681":2,"682":2}}],["backed",{"2":{"380":2}}],["backend=test",{"2":{"622":2}}],["backend=",{"2":{"279":2}}],["backend",{"2":{"245":2,"261":4,"279":8,"299":3,"303":4,"308":2,"320":1,"412":2,"422":2,"446":2,"447":2,"449":2,"466":4,"479":2,"523":2,"559":4,"700":6,"701":6,"702":6,"706":2,"707":2,"738":4}}],["background",{"0":{"328":1,"602":1},"1":{"603":1,"604":1,"605":1,"606":1,"607":1,"608":1},"2":{"143":2,"144":4,"150":4,"163":2,"248":1,"373":1,"425":1,"470":1,"602":1,"603":1,"604":1,"608":1,"621":1,"772":2,"773":2,"775":2}}],["back",{"2":{"80":1,"90":1,"109":1,"112":1,"130":1,"179":3,"199":1,"202":1,"247":1,"424":1,"428":1,"438":1,"455":1,"469":1,"598":2,"627":2,"710":2,"771":1,"773":2,"775":2,"776":2,"779":2}}],["basically",{"2":{"584":1}}],["basic",{"0":{"741":1},"1":{"742":1,"743":1,"744":1},"2":{"275":1,"380":1,"384":1,"389":2,"740":1,"741":1}}],["basefeepergas",{"2":{"538":1}}],["basechainhandle",{"2":{"434":8}}],["baseaccount",{"2":{"296":3}}],["base64=truecelestia",{"2":{"747":2}}],["base64=true",{"2":{"747":3}}],["base64",{"2":{"142":1,"147":1,"152":1,"156":1,"157":1,"539":3,"540":1,"745":4,"747":4,"763":1}}],["base",{"0":{"99":1,"101":1,"296":1},"2":{"84":2,"86":13,"87":6,"88":1,"91":2,"93":12,"94":1,"97":1,"99":1,"185":1,"216":1,"228":1,"231":2,"295":4,"649":2}}],["based",{"2":{"22":2,"23":1,"82":1,"122":1,"214":1,"224":1,"311":1,"341":1,"343":1,"473":1,"588":2,"591":2,"592":3,"611":1,"641":1,"653":1,"671":1,"676":1,"677":1,"690":1,"717":1,"722":2,"748":1,"765":1}}],["bashroot",{"2":{"707":1}}],["bashmoniker=",{"2":{"622":1}}],["bashmake",{"2":{"311":1,"341":4}}],["bashinfo\\tnode\\tnodebuilder",{"2":{"559":1}}],["bash$home",{"2":{"544":3}}],["bashhermes",{"2":{"430":1,"431":1,"433":3,"434":2}}],["bashvalidator",{"2":{"616":1}}],["bashvim",{"2":{"429":1}}],["bashver=",{"2":{"399":3}}],["bashzsh",{"2":{"399":1}}],["bashdocker",{"2":{"390":3,"392":3,"393":3,"706":4,"707":4}}],["bashpersistent",{"2":{"361":3}}],["bashprometheus",{"2":{"275":1}}],["bashprivate",{"2":{"93":1}}],["bashsuccess",{"2":{"431":1,"434":2}}],["bashsudo",{"2":{"337":2,"391":1,"398":4}}],["bashseeds=$",{"2":{"361":2}}],["bashnano",{"2":{"337":1}}],["bashenter",{"2":{"616":1}}],["bashecho",{"2":{"399":2}}],["basherror",{"2":{"337":1}}],["bashexport",{"2":{"287":1,"293":1,"299":1,"301":1,"314":2,"390":7,"405":1,"412":1,"477":1,"478":1,"538":1,"539":1,"560":1,"742":2,"743":1,"757":1,"762":1}}],["bashfatal",{"2":{"336":1}}],["bashfunding",{"2":{"93":1}}],["bashbash",{"2":{"312":1,"474":1,"558":1}}],["bashbalances",{"2":{"297":2}}],["bashgo",{"2":{"399":1,"709":1}}],["bashgas",{"2":{"294":1}}],["bashgrafana",{"2":{"275":1}}],["bashgit",{"2":{"89":1,"311":3,"341":3}}],["bash",{"0":{"474":1},"2":{"274":1,"279":1,"287":1,"291":1,"292":2,"294":3,"295":2,"296":2,"297":2,"312":1,"320":1,"329":2,"331":1,"332":1,"333":1,"343":5,"361":1,"391":1,"392":1,"393":1,"398":3,"399":4,"435":2,"474":2,"476":2,"558":1,"561":2,"564":1,"565":1,"700":3,"701":3,"702":3,"706":2,"707":1,"738":2,"744":2,"762":1}}],["bashcargo",{"2":{"778":1}}],["bashcast",{"2":{"538":1,"539":1}}],["bashcontainer",{"2":{"706":1,"707":1}}],["bashcurl",{"2":{"274":1,"477":1,"540":1,"762":1}}],["bashcd",{"2":{"215":1,"286":1,"288":1,"291":1,"311":1,"341":1,"372":3,"391":1,"399":4,"476":1}}],["bashcelestia",{"2":{"68":2,"91":2,"299":3,"301":2,"314":1,"329":2,"334":2,"335":2,"341":1,"343":1,"348":1,"361":6,"407":2,"408":3,"409":1,"410":1,"411":1,"412":1,"413":1,"437":1,"477":2,"478":3,"479":4,"495":1,"558":1,"559":1,"561":1,"563":2,"564":2,"565":2,"567":1,"596":1,"597":1,"616":2,"619":1,"620":1,"736":3,"737":6,"738":3,"740":3,"743":1,"744":2,"745":4,"747":5,"748":1,"750":1,"751":2,"752":1,"753":1,"754":2,"755":1,"756":1,"757":3,"758":1,"759":2,"760":1}}],["bash2024",{"2":{"214":1,"383":1,"627":1}}],["bashyarn",{"2":{"1":1}}],["bank",{"2":{"265":10,"279":4,"297":4,"309":2,"412":2,"413":2,"479":2,"717":1}}],["bandwidth",{"2":{"239":1,"357":1,"416":1,"460":1,"535":1,"536":1,"613":1,"644":1,"722":2,"734":1}}],["banner",{"2":{"38":1}}],["banners",{"2":{"38":1}}],["ban",{"0":{"14":1,"15":1},"2":{"13":1,"14":2,"15":1}}],["buckets",{"2":{"429":8}}],["bug",{"2":{"336":2,"536":1}}],["burned",{"2":{"266":1}}],["bubs",{"0":{"249":1,"251":1},"1":{"250":1,"251":1,"252":2,"253":2,"254":2,"255":2,"256":2,"257":2,"258":2,"259":1},"2":{"249":2,"250":3,"251":2,"252":1,"253":1,"254":3,"255":2,"256":2,"257":1,"258":1,"259":1,"457":1}}],["businesses",{"2":{"38":1}}],["budget",{"2":{"35":3,"40":1}}],["button",{"2":{"87":1,"88":1,"275":1,"601":2,"661":1,"784":4}}],["but",{"2":{"7":1,"23":1,"26":1,"29":1,"34":1,"35":3,"38":1,"41":1,"42":1,"58":1,"60":1,"86":4,"109":2,"110":1,"125":1,"126":2,"161":2,"162":2,"163":2,"170":1,"208":1,"210":1,"219":1,"226":1,"227":2,"276":1,"287":1,"290":1,"322":2,"368":2,"371":1,"381":1,"383":1,"414":1,"430":1,"445":1,"481":1,"501":1,"521":1,"533":1,"542":1,"546":1,"580":1,"594":1,"617":1,"627":1,"638":1,"651":1,"673":1,"682":2,"719":1,"720":1}}],["buildmake",{"2":{"341":1}}],["builds",{"2":{"287":1}}],["builders",{"2":{"582":1}}],["builder",{"2":{"214":1}}],["buildcd",{"2":{"202":1}}],["build",{"0":{"214":1,"215":1,"771":1},"2":{"37":1,"165":1,"166":1,"178":1,"183":1,"202":2,"203":2,"211":3,"213":2,"214":14,"215":22,"221":1,"230":1,"251":1,"286":2,"287":3,"288":2,"291":2,"311":1,"341":10,"398":4,"399":1,"439":1,"568":1,"573":1,"582":1,"689":1}}],["building",{"0":{"1":1,"251":1,"311":1,"575":1,"647":1,"769":1},"1":{"252":1,"253":1,"254":1,"255":1,"256":1,"257":1,"258":1,"576":1,"577":1,"578":1,"648":1,"770":1,"771":1,"772":1,"773":1,"774":1,"775":1},"2":{"3":1,"166":1,"215":1,"341":1,"397":1,"463":1,"568":1,"576":1,"724":1,"767":1}}],["built",{"0":{"250":1,"312":1,"342":1},"1":{"343":1},"2":{"1":1,"110":1,"166":1,"168":1,"178":1,"214":2,"224":1,"233":1,"238":2,"281":1,"310":1,"312":3,"342":2,"427":2,"437":1,"454":2,"455":1,"457":1,"558":1,"648":2,"674":1,"691":1,"699":1}}],["bypassing",{"2":{"328":1}}],["bytes=",{"2":{"485":1}}],["bytes28",{"2":{"156":2,"157":2}}],["bytes1",{"2":{"156":2,"157":2}}],["bytes",{"0":{"485":1},"2":{"118":4,"154":2,"155":2,"156":5,"157":1,"158":4,"163":6,"174":1,"204":4,"484":1,"485":4,"588":4,"591":1,"598":4,"599":2,"644":2,"645":3,"651":1,"710":4,"745":1,"773":2}}],["bytes32",{"2":{"118":8,"142":1,"147":1,"152":1,"156":2,"159":3,"160":2,"163":2,"204":11,"206":3,"207":2,"219":1}}],["byte",{"2":{"91":3,"125":8,"144":10,"156":17,"157":7,"159":4,"160":6,"163":36,"202":2,"226":1,"592":1,"593":1,"598":4,"599":4,"710":4,"711":2,"712":2,"773":4}}],["by",{"0":{"144":1,"366":1,"754":1},"2":{"7":1,"16":1,"18":1,"20":1,"22":2,"23":2,"32":1,"35":1,"36":1,"37":1,"40":1,"41":1,"42":1,"54":1,"58":2,"81":1,"85":1,"86":2,"87":1,"89":1,"90":1,"91":2,"93":3,"109":1,"112":1,"118":2,"120":1,"122":7,"124":1,"125":1,"126":5,"128":2,"130":2,"139":3,"140":1,"141":1,"142":1,"144":6,"147":1,"154":4,"157":1,"160":2,"163":6,"164":1,"168":2,"171":1,"172":1,"174":2,"175":2,"178":1,"183":1,"187":1,"202":1,"204":2,"205":1,"206":2,"212":1,"214":2,"215":1,"216":3,"218":2,"219":1,"221":2,"233":1,"234":1,"236":1,"245":2,"249":1,"250":1,"260":4,"266":2,"274":1,"275":3,"276":1,"279":2,"280":1,"281":1,"295":1,"309":1,"313":3,"315":1,"326":3,"341":1,"343":1,"350":2,"352":2,"355":2,"368":1,"370":1,"371":1,"377":2,"380":2,"383":2,"391":1,"400":1,"404":1,"412":1,"422":2,"427":2,"428":1,"434":1,"441":1,"442":1,"443":1,"444":1,"451":1,"453":1,"455":2,"463":1,"466":3,"479":1,"485":4,"496":1,"508":1,"517":1,"520":2,"521":1,"533":2,"541":2,"544":1,"554":1,"558":1,"563":1,"567":1,"582":1,"583":1,"584":1,"586":1,"589":2,"590":6,"591":5,"592":6,"593":2,"594":2,"616":1,"627":2,"630":1,"631":1,"632":1,"633":1,"634":1,"643":2,"644":1,"646":2,"648":3,"650":2,"651":5,"652":3,"671":1,"673":3,"674":3,"677":1,"682":1,"683":1,"690":1,"691":1,"698":1,"706":1,"707":2,"717":1,"721":2,"722":1,"728":1,"730":1,"732":1,"738":3,"745":3,"754":4,"755":4,"760":6,"767":2,"771":1,"773":1,"780":2,"785":1}}],["bearer",{"2":{"540":2,"762":2}}],["bedrock",{"2":{"250":1}}],["belonging",{"2":{"322":1}}],["belong",{"2":{"154":2,"168":2,"174":1}}],["below",{"2":{"20":1,"21":1,"41":1,"65":1,"74":1,"86":1,"91":1,"97":1,"98":1,"99":1,"127":1,"137":1,"160":1,"171":1,"188":1,"233":1,"234":1,"309":1,"311":1,"312":1,"392":1,"393":1,"422":1,"465":1,"474":1,"487":1,"489":1,"505":1,"507":1,"511":1,"539":1,"540":1,"616":1,"622":2,"648":1,"651":2,"674":1,"677":1,"681":1,"682":1,"709":1,"778":1}}],["bech32prefixconspub",{"2":{"784":2}}],["bech32prefixconsaddr",{"2":{"784":2}}],["bech32prefixvalpub",{"2":{"784":2}}],["bech32prefixvaladdr",{"2":{"784":2}}],["bech32prefixaccpub",{"2":{"784":2}}],["bech32prefixaccaddr",{"2":{"784":2}}],["bech32config",{"2":{"784":2}}],["bech",{"2":{"616":2}}],["because",{"2":{"110":1,"128":1,"173":1,"331":1,"369":1,"428":1,"584":1,"629":1,"639":1,"722":1,"767":1,"773":1}}],["becomes",{"2":{"355":1,"518":1,"629":2}}],["become",{"2":{"47":1,"50":1}}],["behalf",{"2":{"406":1}}],["behave",{"2":{"278":1}}],["behavior",{"2":{"7":2,"8":2,"10":1,"12":2,"13":1,"14":1,"15":1,"281":1,"328":1,"371":1,"459":1,"740":1}}],["behind",{"2":{"60":1,"109":1,"378":1,"554":1,"722":1}}],["beneficial",{"2":{"42":1}}],["benefit",{"2":{"38":2,"40":1,"111":1}}],["benefits",{"0":{"581":1},"1":{"582":1,"583":1,"584":1},"2":{"34":1,"38":1,"53":1,"56":1,"58":2,"574":2}}],["better",{"2":{"41":1,"42":1,"126":1,"166":1,"197":1,"199":1,"259":1,"674":1}}],["between",{"0":{"432":1,"637":1},"2":{"36":1,"37":1,"87":1,"130":1,"175":1,"183":1,"202":1,"226":1,"255":2,"313":1,"326":1,"415":1,"427":2,"428":1,"429":1,"432":1,"434":1,"533":1,"607":1,"649":1,"677":1}}],["betaarabica",{"2":{"544":1}}],["betaarabicamocha",{"2":{"468":1}}],["betamochaarabica",{"2":{"244":1,"246":1,"311":1,"341":1,"361":4,"372":1,"373":1,"390":2,"392":1,"393":1,"399":1,"421":1,"423":1,"464":1,"465":1,"466":1,"622":1,"736":1,"737":2,"738":1,"784":1}}],["beta",{"0":{"317":1,"331":1,"480":1,"549":1,"550":1,"684":1},"1":{"481":1,"482":1,"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1,"490":1,"491":1,"492":1,"493":1,"494":1,"495":1,"496":1,"497":1,"498":1,"499":1,"500":1,"550":1},"2":{"23":4,"24":1,"26":4,"27":1,"112":1,"136":1,"231":3,"245":1,"317":1,"324":1,"325":3,"328":1,"331":3,"338":1,"343":2,"361":1,"371":1,"390":1,"400":1,"422":2,"456":1,"465":1,"480":3,"481":2,"486":2,"495":1,"498":1,"500":2,"528":1,"532":2,"549":2,"556":1,"588":1,"609":1,"619":1,"684":1,"700":3,"706":1,"707":1,"737":1,"738":1,"762":1}}],["beefy",{"2":{"211":1,"214":1,"215":1}}],["beer",{"2":{"35":1}}],["been",{"2":{"26":1,"93":2,"96":1,"109":1,"112":2,"118":3,"168":1,"219":1,"281":1,"295":1,"309":1,"326":1,"328":1,"409":1,"413":2,"434":1,"464":1,"484":1,"564":1,"604":1,"608":1,"629":1,"638":1,"639":1,"674":2,"728":1,"733":1,"767":1}}],["beginkey",{"2":{"156":3,"175":2}}],["beginning",{"2":{"38":2,"156":2,"160":1,"208":1,"677":1}}],["begin",{"2":{"32":1,"130":1,"175":1,"275":1,"405":1,"772":1}}],["be",{"0":{"154":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1},"2":{"7":2,"10":2,"12":1,"20":1,"22":3,"25":3,"26":1,"28":1,"34":3,"35":3,"37":1,"38":3,"39":4,"42":4,"47":1,"58":1,"60":2,"64":1,"68":1,"79":2,"80":1,"85":1,"86":5,"87":1,"90":1,"91":4,"92":2,"97":1,"105":1,"109":3,"110":2,"111":2,"112":1,"117":1,"122":1,"125":4,"126":5,"127":2,"128":3,"130":3,"136":8,"137":2,"139":3,"140":1,"141":1,"142":2,"143":1,"145":1,"146":1,"147":2,"149":1,"151":1,"152":3,"153":2,"155":2,"156":2,"157":2,"158":1,"159":1,"160":4,"161":2,"162":1,"163":3,"164":1,"166":3,"168":3,"169":4,"170":1,"171":2,"172":4,"174":2,"175":6,"178":2,"180":3,"182":2,"183":5,"185":1,"186":1,"187":4,"188":2,"190":2,"191":2,"193":1,"194":2,"197":1,"201":1,"202":11,"203":2,"204":1,"206":2,"208":3,"209":1,"210":3,"211":2,"214":1,"215":4,"216":3,"217":1,"218":1,"219":2,"221":1,"228":2,"230":1,"233":4,"234":2,"235":1,"243":1,"244":1,"245":1,"246":1,"250":1,"263":3,"266":5,"267":1,"273":1,"274":1,"276":1,"277":1,"278":1,"279":2,"281":4,"287":1,"298":1,"304":2,"309":1,"311":2,"312":1,"313":1,"316":1,"321":2,"324":2,"326":2,"334":4,"337":1,"342":1,"350":1,"352":1,"355":2,"363":1,"366":1,"371":5,"376":1,"377":1,"380":2,"381":1,"390":1,"391":2,"397":1,"400":3,"404":1,"406":1,"422":4,"423":1,"426":2,"427":1,"429":1,"430":2,"434":2,"437":3,"438":1,"443":1,"448":1,"449":1,"450":1,"453":1,"465":2,"466":1,"468":1,"481":1,"484":1,"485":4,"487":1,"505":1,"509":1,"511":1,"520":1,"522":1,"526":1,"528":2,"530":2,"541":3,"542":1,"544":3,"546":1,"552":3,"554":2,"559":2,"564":1,"567":1,"582":4,"584":2,"586":1,"588":2,"589":1,"590":1,"591":3,"592":1,"593":2,"594":3,"599":4,"604":1,"606":2,"607":2,"608":1,"609":2,"610":2,"619":1,"622":3,"630":1,"633":1,"634":3,"636":2,"639":2,"640":1,"643":1,"644":1,"645":3,"646":1,"649":3,"651":2,"652":1,"670":2,"671":1,"672":1,"673":4,"674":3,"677":2,"682":2,"690":1,"698":1,"699":1,"700":2,"706":1,"707":1,"710":2,"717":1,"721":1,"722":3,"725":1,"728":2,"733":1,"736":1,"737":1,"738":1,"740":1,"741":2,"742":2,"745":6,"748":2,"751":1,"762":1,"765":2,"766":1,"767":4,"768":1,"771":1,"773":1,"779":2,"785":1,"786":1}}],["best",{"2":{"7":1,"54":1,"58":1,"63":1,"276":1,"486":1,"501":1,"583":1}}],["being",{"2":{"7":1,"23":1,"25":1,"86":1,"91":2,"104":1,"110":1,"128":1,"150":2,"152":1,"153":1,"156":2,"157":1,"158":1,"159":1,"160":3,"187":1,"202":1,"214":1,"238":1,"324":1,"363":1,"369":1,"438":1,"542":1,"611":1,"636":1,"652":1,"682":1,"717":1,"748":1}}],["before",{"0":{"30":1},"2":{"2":1,"23":2,"26":1,"36":2,"37":1,"39":1,"87":1,"91":2,"112":1,"127":1,"130":3,"155":1,"171":1,"211":1,"233":1,"234":1,"289":1,"294":2,"324":1,"371":2,"391":1,"428":1,"444":1,"447":1,"530":2,"545":1,"604":1,"622":2,"651":1,"740":1,"784":3}}],["rsmt2d",{"2":{"713":2}}],["rs",{"2":{"461":1}}],["rsvp",{"2":{"30":1}}],["rf",{"2":{"311":2,"336":4,"341":2,"372":6,"399":8}}],["rfc",{"2":{"119":1}}],["richer",{"2":{"724":1}}],["rickroll",{"2":{"559":1}}],["rigorous",{"2":{"480":1}}],["right",{"2":{"8":1,"76":1,"91":1,"558":1,"574":1,"601":1,"661":1,"690":1}}],["risk",{"2":{"221":1}}],["r6a",{"2":{"217":1}}],["r",{"2":{"215":2,"361":2,"477":2,"539":4,"560":4,"681":1,"682":2,"755":2,"760":2}}],["r1cs",{"2":{"214":2}}],["r1",{"2":{"137":1}}],["r0",{"2":{"137":1}}],["rm",{"2":{"104":2,"311":2,"336":4,"341":2,"372":6,"399":16}}],["rc",{"2":{"96":1,"104":2}}],["rblocks",{"2":{"88":1}}],["rpcs",{"2":{"68":1,"495":1}}],["rpc",{"0":{"64":1,"65":1,"67":1,"90":1,"252":1,"333":1,"376":1,"377":1,"487":1,"489":1,"494":1,"496":1,"504":1,"505":1,"506":1,"508":1,"600":1,"719":1,"724":1,"726":1,"727":1,"730":1,"739":1},"1":{"253":1,"254":1,"377":1,"378":1,"379":1,"497":1,"505":1,"506":1,"507":1,"725":1,"726":1,"727":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":2,"741":2,"742":2,"743":2,"744":2,"745":2,"746":2,"747":2,"748":2,"749":2,"750":2,"751":2,"752":2,"753":2,"754":2,"755":2,"756":2,"757":2,"758":2,"759":2,"760":2,"761":1,"762":1,"763":1,"764":1},"2":{"64":3,"65":4,"67":2,"68":1,"90":3,"91":18,"93":7,"109":1,"126":4,"133":1,"136":5,"137":1,"142":1,"143":2,"144":8,"147":1,"150":2,"152":1,"161":4,"162":2,"163":6,"202":7,"203":4,"204":12,"208":1,"209":5,"210":4,"211":5,"218":2,"238":1,"244":1,"245":2,"252":2,"253":1,"254":1,"265":4,"301":8,"302":1,"303":5,"310":1,"313":2,"314":1,"326":2,"328":1,"329":2,"331":2,"333":3,"338":2,"344":1,"371":4,"376":1,"377":3,"378":1,"381":3,"390":5,"403":1,"405":2,"412":5,"413":2,"422":1,"429":16,"465":5,"466":3,"477":4,"478":3,"487":3,"489":16,"490":1,"491":2,"492":1,"494":2,"495":8,"505":3,"506":2,"507":4,"508":10,"510":1,"538":2,"539":2,"542":1,"546":7,"560":4,"561":4,"600":1,"609":1,"619":1,"706":2,"707":2,"708":1,"709":1,"719":2,"723":1,"724":3,"726":3,"727":1,"730":1,"733":1,"736":1,"737":4,"739":1,"740":2,"741":4,"742":1,"743":1,"752":1,"753":1,"762":1,"764":2,"767":2,"772":2,"773":2,"775":2,"777":1,"778":4,"779":4,"780":2,"781":2,"784":10,"785":2,"786":2}}],["round",{"2":{"754":2}}],["rounds",{"2":{"632":2}}],["roughly",{"2":{"594":1,"722":1}}],["route",{"2":{"333":2}}],["router",{"2":{"313":1,"326":1}}],["routes",{"2":{"210":1,"333":1}}],["routine",{"2":{"36":1}}],["robusta",{"2":{"744":2}}],["robust",{"2":{"251":1}}],["rowproof",{"2":{"158":1,"159":1,"163":4}}],["rowproofs",{"0":{"159":1},"2":{"154":2,"159":2,"160":1,"163":2,"175":4}}],["rowroots",{"0":{"158":1},"2":{"154":4,"158":3,"163":4}}],["row",{"2":{"110":3,"122":4,"137":1,"139":6,"145":3,"147":8,"151":6,"152":8,"154":2,"156":1,"159":1,"160":1,"168":2,"174":2,"175":7,"645":1,"651":4,"754":2}}],["rows",{"2":{"110":2,"122":3,"139":1,"151":1,"154":8,"156":1,"158":1,"159":1,"168":2,"174":2,"643":1}}],["ro",{"2":{"104":2}}],["room",{"2":{"588":1}}],["rooms",{"2":{"34":1}}],["roots",{"2":{"109":1,"110":5,"111":1,"122":2,"128":1,"137":1,"139":4,"147":2,"151":3,"152":2,"154":2,"156":1,"158":8,"160":1,"163":6,"168":6,"225":1,"227":2,"238":1,"643":3,"644":1,"645":1,"651":2,"652":1,"754":4}}],["root",{"0":{"141":1},"1":{"142":1,"143":1},"2":{"76":1,"89":2,"92":1,"93":1,"96":1,"110":2,"111":2,"112":1,"118":4,"119":4,"122":10,"125":1,"127":5,"128":1,"139":9,"141":8,"142":1,"144":12,"145":5,"147":1,"151":6,"154":14,"158":4,"159":1,"160":26,"163":10,"164":2,"168":8,"169":2,"174":5,"175":15,"187":4,"191":3,"194":2,"199":2,"221":1,"227":4,"322":1,"643":1,"645":1,"646":1,"651":2,"670":1,"707":2,"741":1}}],["role",{"0":{"688":1},"1":{"689":1,"690":1,"691":1,"692":1,"693":1,"694":1,"695":1,"696":1},"2":{"54":1,"55":1,"86":1,"692":1,"774":2}}],["roles",{"2":{"30":1}}],["roll",{"2":{"542":2,"545":3}}],["rolling",{"2":{"281":1}}],["rollback",{"2":{"260":8}}],["rollkit",{"2":{"42":1,"55":2}}],["rollupinclusionproofs",{"2":{"155":1,"156":1,"157":1,"159":1,"160":1,"182":1}}],["rollupuserlogic",{"2":{"100":1,"101":1}}],["rollupadminlogic",{"2":{"100":1,"101":1}}],["rollupeventinbox",{"2":{"100":1,"101":1}}],["rollupcreator",{"2":{"91":1,"98":1,"99":1,"100":1,"101":1}}],["rollup",{"0":{"55":1,"74":1,"75":1,"77":1,"78":1,"79":1,"81":1,"124":1,"126":1,"129":1,"163":1,"199":1,"542":1,"574":1,"579":1},"1":{"75":1,"76":2,"77":2,"78":1,"79":2,"80":2,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"127":1,"128":1,"130":1,"131":1,"132":1,"133":1,"134":1,"543":1,"544":1,"545":1,"546":1,"547":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1},"2":{"38":1,"55":4,"74":2,"77":4,"79":1,"81":3,"84":1,"85":3,"88":2,"90":1,"92":1,"93":8,"94":2,"103":1,"113":1,"118":15,"122":1,"124":3,"125":11,"126":15,"130":4,"134":1,"137":2,"139":2,"140":1,"145":2,"149":1,"157":1,"158":1,"160":2,"163":4,"165":1,"166":1,"169":4,"170":2,"171":1,"172":7,"175":3,"178":3,"179":7,"180":2,"182":1,"183":7,"186":2,"187":5,"190":2,"191":4,"194":4,"197":1,"199":2,"227":1,"229":1,"230":1,"234":1,"250":1,"251":1,"339":1,"422":2,"455":4,"542":3,"544":1,"546":2,"547":1,"573":1,"577":1,"579":1,"580":1,"582":2,"583":1,"584":5,"646":1,"672":2,"674":7,"681":1,"689":1,"716":1}}],["rollups",{"0":{"106":1,"165":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"192":1,"193":1,"230":1,"577":1,"674":1,"690":1},"1":{"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":2,"180":3,"181":3,"182":3,"183":2,"184":3,"185":3,"186":1,"187":2,"188":3,"189":3,"190":2,"191":3,"192":3,"193":3,"194":2,"195":2,"196":2,"197":1,"198":1,"199":1},"2":{"3":1,"37":1,"42":1,"53":1,"55":1,"59":1,"60":1,"84":1,"105":1,"108":1,"124":1,"127":3,"164":1,"165":2,"166":2,"171":1,"178":3,"179":1,"186":2,"191":1,"197":2,"227":4,"230":1,"250":1,"454":1,"480":1,"501":1,"537":1,"542":1,"549":1,"552":1,"554":1,"574":1,"578":1,"579":1,"580":1,"582":2,"583":6,"584":3,"630":1,"640":1,"649":1,"672":1,"674":3,"690":1}}],["roster",{"2":{"26":1}}],["rustasync",{"2":{"780":1,"781":1}}],["rustuse",{"2":{"779":1}}],["rust",{"0":{"569":1,"777":1},"1":{"778":1,"779":1,"780":1,"781":1,"782":1},"2":{"215":2,"221":1,"227":1,"427":1,"428":1,"569":2,"585":1,"727":1,"777":1}}],["rules",{"2":{"22":1,"126":1,"205":1,"565":1,"649":1}}],["rundown",{"2":{"574":1}}],["runtime",{"2":{"383":4,"406":1,"434":8,"627":4}}],["runs",{"2":{"275":2,"287":1,"592":1}}],["runners",{"2":{"68":1}}],["running",{"0":{"102":1,"104":1,"105":1,"316":1,"518":1,"533":1,"706":1},"1":{"103":1,"104":1,"105":1,"317":1,"318":1,"319":1,"320":1,"534":1,"535":1,"536":1},"2":{"3":1,"23":1,"54":1,"63":1,"82":1,"89":1,"90":1,"91":1,"93":6,"94":1,"105":1,"109":2,"117":1,"126":1,"211":1,"212":1,"218":1,"227":1,"239":1,"245":2,"271":1,"273":1,"274":1,"275":1,"276":1,"279":2,"289":1,"301":1,"302":1,"315":2,"321":1,"328":3,"333":1,"337":1,"341":1,"355":1,"357":1,"361":2,"371":1,"373":2,"383":3,"385":1,"387":2,"390":1,"391":1,"393":1,"397":1,"398":2,"403":1,"416":1,"422":2,"425":1,"426":1,"428":1,"430":1,"444":1,"453":1,"460":1,"466":3,"471":1,"477":1,"486":1,"501":1,"507":1,"530":1,"545":1,"546":2,"547":1,"554":1,"558":1,"561":2,"563":3,"567":1,"590":1,"598":2,"602":1,"603":1,"604":2,"609":1,"613":1,"617":3,"622":2,"627":4,"633":1,"707":1,"710":2,"716":1,"733":1,"734":1,"737":1,"738":3,"741":1,"742":1,"762":1,"767":4}}],["run",{"0":{"54":1,"91":1,"92":1,"211":1,"212":1,"245":1,"246":1,"286":1,"384":1,"420":1,"423":1,"461":1,"468":1,"542":1,"558":1,"620":1,"622":1,"767":1},"1":{"246":1,"247":1,"385":1,"386":1,"387":1,"421":1,"422":1,"424":1,"469":1,"543":1,"544":1,"545":1,"546":1,"547":1,"559":1,"560":1,"561":1,"621":1},"2":{"1":1,"23":2,"26":1,"51":1,"54":2,"63":1,"65":1,"68":1,"91":1,"92":1,"93":3,"94":1,"104":4,"105":1,"126":1,"202":1,"204":1,"208":4,"209":2,"210":1,"211":6,"214":3,"215":3,"217":2,"218":2,"235":1,"238":3,"243":1,"244":1,"246":1,"260":2,"272":1,"275":4,"280":1,"286":3,"287":2,"289":1,"294":1,"303":1,"308":1,"309":1,"310":1,"311":2,"312":1,"313":2,"321":1,"326":2,"334":1,"336":1,"338":1,"344":2,"345":1,"367":1,"371":1,"372":1,"373":1,"384":1,"386":1,"387":2,"388":6,"390":9,"392":9,"393":9,"397":1,"399":2,"404":1,"405":1,"410":1,"413":1,"421":1,"423":1,"425":1,"427":1,"431":1,"445":1,"446":1,"447":1,"449":2,"450":1,"452":2,"461":2,"464":1,"468":1,"476":1,"486":2,"495":1,"501":3,"507":1,"517":1,"533":1,"542":1,"544":1,"545":1,"557":1,"558":1,"559":3,"561":1,"564":1,"565":1,"572":1,"584":2,"586":1,"616":2,"617":1,"619":1,"620":1,"622":1,"705":1,"706":3,"709":1,"724":1,"726":1,"728":1,"737":1,"739":1,"745":1,"767":1,"770":1,"772":2,"773":2,"775":8,"778":1}}],["raas",{"2":{"542":2,"577":1}}],["rates",{"2":{"677":1}}],["rate",{"2":{"677":1,"786":3}}],["rate=0",{"2":{"272":6,"622":6}}],["rather",{"2":{"59":1,"226":1,"580":1,"677":1}}],["ram",{"2":{"211":1,"214":1,"215":1,"217":1,"239":1,"341":1,"357":1,"416":1,"460":1,"535":3,"536":2,"586":1,"613":1,"734":1}}],["rawlog",{"2":{"599":4}}],["raw",{"2":{"155":1,"238":2,"294":2,"361":10,"398":2,"459":1,"616":2,"622":2,"786":1}}],["rawmessage",{"2":{"125":2,"128":2}}],["rand",{"2":{"91":1}}],["randomly",{"2":{"643":1}}],["randomness",{"2":{"214":1}}],["random",{"2":{"91":1,"183":1,"214":1,"632":1,"650":1,"652":2}}],["ranges",{"0":{"216":1},"1":{"217":1,"218":1,"219":1},"2":{"216":2,"233":3}}],["range",{"0":{"151":1},"1":{"152":1,"153":1},"2":{"91":1,"109":3,"142":1,"144":6,"147":2,"149":1,"151":3,"156":4,"158":2,"159":4,"160":2,"161":6,"163":26,"174":1,"204":1,"210":2,"211":5,"215":14,"216":1,"217":1,"218":1,"219":2,"227":1,"228":2,"646":2}}],["rapidly",{"2":{"44":1}}],["race",{"2":{"6":1}}],["raises",{"2":{"86":1}}],["raise",{"2":{"4":1,"30":1}}],["redelegate",{"2":{"659":1,"663":1,"668":1}}],["reducing",{"2":{"650":1}}],["reduces",{"2":{"525":1}}],["reduce",{"2":{"455":1,"582":1}}],["reduced",{"2":{"34":1,"180":1,"481":1,"549":1,"582":1,"652":1}}],["redundant",{"2":{"634":1}}],["reed",{"2":{"643":2,"645":5,"648":1,"651":1}}],["reinitializing",{"2":{"444":1}}],["reinitialize",{"2":{"324":1}}],["reindexing",{"2":{"381":2}}],["reindex",{"2":{"381":1}}],["rejoin",{"2":{"281":1}}],["rejects",{"2":{"652":1}}],["rejected",{"2":{"438":1,"652":1}}],["reject",{"2":{"8":1,"645":1}}],["revoke",{"0":{"410":1},"1":{"411":1},"2":{"406":1,"410":3}}],["revert",{"2":{"163":2}}],["reveal",{"2":{"110":1}}],["revisit",{"2":{"40":1}}],["reviewing",{"2":{"32":1}}],["reviewed",{"2":{"10":1,"20":1,"23":1}}],["review",{"0":{"87":1},"2":{"2":1,"30":1,"47":1,"86":1,"87":2,"662":2,"667":1}}],["retain",{"0":{"365":1},"2":{"363":1,"365":5,"368":4}}],["returning",{"2":{"710":2,"779":2}}],["returned",{"2":{"204":3,"281":1,"438":1,"616":1,"646":1,"747":1}}],["return",{"2":{"118":2,"128":10,"130":12,"162":8,"203":2,"204":3,"215":2,"477":1,"599":18,"747":3,"757":1,"774":2,"784":2}}],["returns",{"2":{"91":1,"118":2,"126":4,"172":1,"204":1,"711":1,"712":1,"713":1,"745":1,"773":1,"774":2,"780":1,"781":1}}],["retrial",{"2":{"652":1}}],["retried",{"2":{"160":1}}],["retrievability",{"0":{"641":1,"672":1,"673":1},"1":{"673":1,"674":1},"2":{"638":1,"672":1,"673":1}}],["retrievable",{"2":{"496":1,"639":1,"672":1}}],["retrieval",{"2":{"322":1,"635":1}}],["retrieving",{"0":{"565":1,"710":1,"747":1,"779":1},"2":{"109":1,"371":1,"385":1,"561":1,"635":1,"639":1}}],["retrievedblobs",{"2":{"598":2,"710":2}}],["retrieved",{"2":{"136":1,"155":1,"160":1,"636":1,"674":1,"741":1,"771":2,"772":2,"773":2,"779":8}}],["retrieve",{"0":{"562":1},"1":{"563":1,"564":1,"565":1},"2":{"109":2,"151":1,"544":2,"557":2,"560":1,"565":2,"636":1,"730":1,"747":1,"763":1,"771":2,"772":2,"773":2,"774":1,"779":2}}],["retryable",{"2":{"93":6}}],["retryables",{"2":{"93":4}}],["rebasing",{"2":{"86":1}}],["rename",{"2":{"262":2}}],["renaming",{"2":{"262":2}}],["rentals",{"2":{"40":1}}],["renewals",{"2":{"22":1}}],["renewal",{"2":{"22":1,"25":1}}],["rewards",{"0":{"268":1},"2":{"267":1,"268":3,"281":1,"659":1,"663":1,"668":1,"676":2,"680":1,"682":1,"683":1,"691":1,"692":1}}],["reward",{"0":{"640":1},"2":{"37":1,"641":1}}],["regenerate",{"0":{"214":1}}],["regenerated",{"2":{"203":1}}],["regeneration",{"2":{"211":1}}],["regenerating",{"0":{"213":1},"1":{"214":1,"215":1},"2":{"203":1}}],["regen",{"2":{"140":4}}],["regions",{"2":{"41":1}}],["registering",{"2":{"210":1}}],["registerfunction",{"2":{"204":4}}],["register",{"0":{"204":1},"1":{"205":1,"206":1,"207":1},"2":{"204":3,"215":1,"429":2}}],["registered",{"2":{"30":1,"202":1,"205":2,"211":2,"235":1}}],["registry",{"2":{"202":1,"361":3,"371":1,"786":1}}],["registration",{"2":{"30":1,"31":1,"47":1,"204":1,"210":1}}],["regular",{"2":{"36":1,"42":1,"84":1,"278":1,"648":1}}],["regardless",{"2":{"6":1,"169":1,"609":1,"611":1}}],["refund",{"2":{"590":1,"592":1}}],["refunded",{"2":{"590":1}}],["refresh",{"2":{"429":2}}],["refreshments",{"0":{"35":1},"2":{"30":1,"35":6,"38":1}}],["refers",{"2":{"174":2,"238":1,"322":1}}],["referred",{"2":{"136":1,"649":1,"651":2}}],["referrals",{"2":{"37":2}}],["referencing",{"2":{"127":1,"170":2,"172":1,"173":1,"199":2}}],["references",{"2":{"187":1}}],["referenced",{"2":{"168":1,"172":1,"183":1,"187":1,"191":1,"194":1}}],["reference",{"0":{"199":1},"2":{"0":1,"36":1,"139":1,"179":1,"182":1,"186":1,"190":1,"191":1,"199":3,"433":6,"525":1}}],["refer",{"2":{"65":1,"86":1,"136":1,"202":1,"208":1,"244":1,"245":1,"281":1,"309":1,"324":1,"345":1,"388":1,"390":2,"422":2,"453":1,"465":1,"501":1,"592":2,"598":1,"619":1,"625":1,"646":1,"677":1,"700":1,"706":2,"737":1,"738":1,"746":1,"776":1}}],["rec",{"2":{"599":4}}],["recipient",{"2":{"267":2,"757":1}}],["recency",{"2":{"673":2}}],["recent",{"2":{"109":1,"496":1,"538":1}}],["receipt",{"2":{"682":1}}],["receiptsroot",{"2":{"538":2}}],["receiving",{"2":{"26":1,"780":2}}],["receiveroutine",{"2":{"383":4,"627":4}}],["receiver",{"2":{"93":4}}],["received",{"2":{"23":1,"162":1,"459":1,"643":1,"652":2}}],["receives",{"2":{"22":3,"629":1,"680":1,"692":1}}],["receive",{"2":{"20":1,"22":1,"26":1,"28":1,"47":1,"48":1,"202":1,"481":1,"549":1,"633":1,"643":1,"683":1,"711":1,"712":1,"748":1,"780":1}}],["recap",{"2":{"48":1}}],["recruiting",{"2":{"42":2}}],["reconstructing",{"2":{"645":1}}],["reconstruction",{"0":{"634":1}}],["reconstruct",{"2":{"633":1,"634":1,"674":1}}],["recoverable",{"2":{"645":1}}],["recovered",{"2":{"643":1}}],["recover",{"2":{"291":2,"308":1,"702":6}}],["recompute",{"2":{"110":1}}],["recommend",{"2":{"59":1,"86":1,"105":1,"344":2,"501":1,"546":2,"586":1,"716":1}}],["recommends",{"2":{"41":1}}],["recommendations",{"2":{"35":1}}],["recommended",{"0":{"534":1},"2":{"23":1,"29":1,"90":1,"199":1,"202":2,"211":1,"239":1,"245":1,"266":1,"339":1,"341":1,"357":1,"385":1,"396":1,"416":1,"422":1,"460":1,"609":1,"613":1,"617":1,"652":1,"697":1,"727":1,"734":1,"784":2}}],["recognizable",{"2":{"86":1}}],["recognize",{"2":{"47":1}}],["recognition",{"2":{"37":1}}],["recorded",{"2":{"40":4}}],["record",{"2":{"34":1}}],["recordings",{"2":{"34":1,"40":3}}],["recording",{"0":{"40":1},"2":{"34":2,"40":6}}],["reactjs",{"2":{"784":1}}],["react",{"0":{"784":1},"2":{"783":1,"784":4}}],["reaching",{"2":{"687":1}}],["reaches",{"2":{"632":1,"677":1}}],["reached",{"2":{"599":2}}],["reach",{"2":{"23":1,"30":1,"37":1,"38":1,"39":1,"40":3}}],["reaped",{"2":{"594":1}}],["reapplying",{"2":{"25":1}}],["reapply",{"2":{"23":1}}],["real",{"2":{"90":1,"480":1,"542":1,"604":1,"608":1}}],["readiness",{"2":{"527":1,"530":1}}],["reading",{"2":{"126":2,"244":1,"344":1,"422":1,"455":4,"635":1,"737":1}}],["reads",{"2":{"455":2,"774":1}}],["readme",{"2":{"282":1,"545":1,"546":1,"586":1}}],["reader",{"2":{"126":1,"136":1}}],["read",{"0":{"539":1},"2":{"79":1,"81":2,"96":1,"109":1,"110":1,"125":1,"126":1,"208":1,"396":1,"496":1,"501":1,"539":1,"591":1,"728":1,"732":1,"733":1,"740":1,"747":1}}],["ready",{"2":{"26":1,"140":1,"289":1,"371":1,"561":1,"563":1,"576":1,"582":1,"622":1,"765":1}}],["reasonable",{"2":{"217":1}}],["reasonably",{"2":{"7":1}}],["reason",{"2":{"24":1,"722":1}}],["reasons",{"2":{"8":1,"199":1}}],["resubmission",{"0":{"609":1,"610":1},"1":{"610":1,"611":1},"2":{"609":1}}],["resubmitted",{"2":{"610":1}}],["resubmit",{"2":{"594":2,"611":1}}],["results",{"2":{"139":1,"140":1,"281":1,"381":4,"754":2}}],["resulting",{"2":{"139":1,"328":1,"645":1,"649":1}}],["result",{"2":{"23":2,"142":2,"147":4,"152":2,"155":1,"156":1,"209":1,"331":2,"332":3,"333":2,"396":1,"408":4,"409":2,"477":2,"478":2,"521":1,"540":3,"560":5,"561":2,"564":2,"565":2,"604":2,"643":1,"646":2,"649":3,"745":6,"747":8,"748":2,"750":2,"751":2,"752":2,"753":2,"754":2,"755":2,"757":2,"760":2,"762":3}}],["resolve",{"2":{"649":1}}],["resolved",{"2":{"428":1}}],["resolving",{"2":{"456":1}}],["resolution",{"2":{"336":1,"580":1}}],["resources",{"0":{"280":1,"374":1,"625":1,"761":1},"1":{"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"762":1,"763":1,"764":1},"2":{"39":1,"40":2,"43":1,"44":2,"50":1,"51":1,"95":1,"134":1,"625":2,"716":1}}],["resource",{"2":{"37":1,"50":1,"58":1,"226":1,"367":1,"644":2,"650":1}}],["resetting",{"0":{"334":1}}],["reset",{"0":{"375":1,"444":1},"2":{"324":1,"335":4,"375":2,"383":1,"444":2,"627":3}}],["reserved",{"2":{"174":1,"485":1,"651":2}}],["research",{"2":{"36":1,"38":1,"681":1}}],["restartsec=3",{"2":{"604":2,"606":2,"607":2,"608":2}}],["restart=on",{"2":{"604":2,"606":2,"607":2,"608":2}}],["restart",{"0":{"379":1},"2":{"274":1,"316":1,"337":3,"345":1,"379":1,"380":1,"381":1,"383":1,"406":1,"627":2}}],["restaurant",{"2":{"34":1}}],["restaurants",{"2":{"34":2}}],["restrictions",{"2":{"682":1}}],["restrict",{"2":{"205":1,"584":1}}],["rest",{"2":{"127":1,"214":1,"326":1,"428":1,"429":2,"490":2,"509":3,"728":1,"767":1,"784":10,"785":1,"786":1}}],["resides",{"2":{"110":1}}],["resilience",{"2":{"26":1}}],["resp",{"2":{"599":20,"711":6,"774":4}}],["respectively",{"2":{"218":1}}],["respective",{"2":{"27":1,"67":1,"68":1,"126":1,"130":1,"137":1,"272":1,"371":2,"494":1,"495":1,"501":1,"506":1,"507":1}}],["respect",{"2":{"10":1}}],["respectfully",{"2":{"46":1}}],["respectful",{"2":{"7":1}}],["responses",{"0":{"381":1},"2":{"42":1,"381":9,"765":1,"776":1}}],["response",{"2":{"8":1,"42":1,"142":1,"147":1,"152":1,"154":1,"156":4,"157":1,"159":4,"160":1,"331":2,"408":1,"560":1,"564":1,"565":2,"599":4,"643":1,"706":1,"707":1,"747":3,"750":1,"751":1,"752":1,"753":1,"774":2,"775":2}}],["responsible",{"2":{"8":1,"10":1,"86":1,"87":1,"90":1,"126":2,"455":1,"650":1,"674":2}}],["responsibilities",{"0":{"8":1}}],["responsibility",{"2":{"7":1,"8":1,"122":2,"611":1,"639":1}}],["requiring",{"2":{"650":1}}],["requires",{"2":{"119":1,"166":1,"171":1,"193":1,"202":1,"208":1,"217":1,"218":1,"219":1,"227":1,"229":1,"541":1,"639":1}}],["require",{"2":{"105":1,"118":4,"164":1,"169":1,"171":1,"227":1,"328":1,"367":1,"526":2,"583":1,"639":1,"640":1,"645":2,"649":2,"740":1}}],["requirement",{"2":{"35":1,"278":1,"645":1}}],["requirements",{"0":{"239":1,"357":1,"368":1,"416":1,"440":1,"460":1,"534":1,"613":1,"734":1},"2":{"23":1,"30":1,"37":1,"54":1,"55":1,"86":1,"197":1,"239":1,"357":1,"368":1,"416":1,"440":1,"460":1,"613":1,"722":2,"734":1}}],["required",{"2":{"29":1,"30":1,"86":1,"149":1,"188":1,"202":1,"211":1,"244":1,"250":1,"309":1,"313":1,"324":1,"325":2,"326":1,"371":1,"388":1,"390":1,"422":1,"453":1,"465":1,"582":1,"592":1,"617":1,"619":1,"645":1,"706":1,"737":1,"743":1,"770":1,"771":1}}],["requisites",{"0":{"347":1,"403":1}}],["requestheaderrange",{"2":{"219":1,"233":1}}],["requesting",{"0":{"216":1},"1":{"217":1,"218":1,"219":1},"2":{"218":1,"219":1,"658":1}}],["requests",{"2":{"202":2,"218":1,"219":1,"238":1,"376":1,"641":2,"646":1,"652":1,"674":1,"741":1}}],["requestedheight",{"2":{"560":2}}],["requested",{"2":{"12":1,"216":1,"218":1,"219":1,"233":1,"563":1}}],["request",{"0":{"147":1,"152":1,"218":1,"219":1},"2":{"2":2,"38":1,"70":1,"109":1,"142":1,"147":1,"152":1,"155":1,"156":1,"216":1,"218":1,"219":1,"245":1,"281":1,"328":1,"331":2,"332":2,"370":1,"422":1,"467":1,"512":1,"536":1,"563":1,"651":1,"738":1,"740":1,"742":1,"767":1,"784":2}}],["remainder",{"2":{"281":1,"287":1,"294":1,"405":1,"563":1}}],["remain",{"2":{"273":1,"365":1,"445":1,"583":1,"588":1,"672":1}}],["remaining",{"2":{"156":2,"157":1,"297":1,"413":1,"485":1,"580":1,"682":4}}],["remains",{"2":{"18":1,"199":1,"221":1,"481":1,"549":1}}],["removing",{"2":{"281":1}}],["removed",{"2":{"93":2,"152":1,"153":1,"281":2,"326":1,"559":1,"728":1,"733":1,"771":1}}],["removechainowner",{"2":{"93":2}}],["remove",{"2":{"8":1,"311":1,"335":1,"341":1,"383":2,"539":2,"627":2}}],["remote",{"2":{"40":1,"238":1,"252":1,"260":2,"275":2,"350":3,"355":1,"586":1,"739":1}}],["remember",{"2":{"34":1,"38":1,"254":1,"371":1,"380":1,"381":1,"481":1,"539":1,"584":1}}],["reminders",{"2":{"39":1}}],["reminder",{"2":{"30":1,"39":1,"79":1}}],["replicated",{"2":{"649":1}}],["replaced",{"2":{"161":2}}],["replace",{"2":{"144":2,"183":1,"287":1,"450":1,"465":1,"594":1,"742":1}}],["replaces",{"2":{"140":1,"214":1,"377":1,"648":1}}],["replacing",{"2":{"93":2,"309":1,"706":1,"707":1}}],["replaying",{"2":{"211":1,"212":1,"674":1}}],["replayer",{"0":{"212":1},"2":{"208":2}}],["replay",{"2":{"96":1,"110":1}}],["repeat",{"2":{"448":1}}],["repo",{"2":{"117":2,"202":1,"203":1,"227":1,"238":2,"272":1,"361":1,"450":1,"452":1}}],["report",{"2":{"27":1,"336":2}}],["reporting",{"2":{"23":1}}],["reporter",{"2":{"10":1}}],["reported",{"2":{"10":1}}],["repository",{"0":{"89":1,"456":1},"2":{"0":1,"1":1,"2":2,"4":1,"89":3,"92":1,"93":1,"117":1,"208":1,"211":2,"212":1,"228":1,"233":1,"250":1,"311":1,"341":1,"361":2,"456":1,"586":1,"623":1,"698":1,"699":1}}],["represent",{"2":{"137":1}}],["representation",{"2":{"126":1,"156":2,"157":2}}],["representative",{"2":{"9":1}}],["represents",{"2":{"109":2,"322":1,"740":1}}],["representing",{"2":{"9":2}}],["relies",{"2":{"371":1,"427":1}}],["religion",{"2":{"6":1}}],["reloadsudo",{"2":{"337":1}}],["reload",{"2":{"337":2}}],["released",{"2":{"428":1,"528":1}}],["release",{"2":{"211":1,"215":4,"427":1,"530":1,"558":1,"673":1}}],["releasesource",{"2":{"211":1}}],["releases",{"2":{"152":1,"153":1,"312":1,"342":1}}],["relevant",{"2":{"37":2,"39":2,"42":1,"63":2,"322":1,"383":1,"459":1,"478":1,"486":2,"501":2,"599":2,"627":2,"642":1,"652":1}}],["relevantly",{"2":{"2":1}}],["relaying",{"0":{"427":1},"1":{"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"400":1,"428":1,"430":3}}],["relayers",{"2":{"427":1}}],["relayer",{"0":{"430":1,"436":1},"2":{"206":1,"228":1,"235":1,"427":3,"428":2,"436":1}}],["relayed",{"2":{"109":2,"119":1,"120":1,"124":1,"127":1,"128":1,"219":1}}],["relay",{"2":{"109":1,"211":1,"235":1,"427":1,"429":1}}],["relays",{"2":{"97":1,"111":1,"221":1}}],["relatively",{"2":{"609":1,"722":1}}],["relative",{"0":{"722":1},"2":{"193":1,"722":1}}],["relations",{"2":{"39":1}}],["relationships",{"2":{"32":1,"36":1}}],["related",{"2":{"38":1,"42":1,"244":1,"422":2,"465":1,"638":1,"737":1}}],["relying",{"2":{"224":1,"674":1}}],["rely",{"2":{"65":2,"215":1,"225":1,"487":2,"489":2,"505":2,"674":1,"718":1}}],["re",{"2":{"2":1,"34":1,"35":1,"46":1,"81":2,"86":2,"91":1,"117":1,"139":1,"163":2,"173":1,"178":1,"183":1,"202":3,"210":6,"215":2,"227":1,"277":1,"324":1,"334":1,"336":1,"339":1,"341":1,"344":1,"383":1,"391":2,"432":1,"558":2,"561":1,"563":1,"568":1,"569":1,"570":1,"574":1,"576":1,"583":1,"586":1,"599":4,"609":1,"627":2,"707":1,"765":1,"776":1,"785":1,"786":1}}],["svg",{"0":{"763":1},"2":{"763":2,"786":1}}],["ss",{"2":{"592":1}}],["sst",{"2":{"571":1}}],["ssd",{"2":{"357":1,"460":1,"535":1,"536":2,"613":1,"734":1}}],["sgvsbg8gd28ybgqh",{"2":{"540":2}}],["snaps",{"2":{"372":12}}],["snapshot",{"2":{"369":2,"372":1,"638":1}}],["snapshots",{"2":{"368":1,"371":3,"674":4}}],["snap",{"2":{"372":24}}],["snippets",{"2":{"136":1,"140":1,"771":1}}],["s3",{"2":{"214":16}}],["skipauth",{"2":{"328":1}}],["skip",{"2":{"201":1,"215":2,"432":1,"617":1,"709":1,"733":2,"767":2,"772":2,"773":2,"775":2,"778":1}}],["skillsets",{"2":{"46":1}}],["src",{"2":{"160":2,"203":2,"383":4,"627":4,"784":8}}],["srl59gitsiwc9lqdyaszfc6tvusyy7njx8",{"2":{"152":2}}],["squaresizeupperbound",{"2":{"150":2}}],["square",{"0":{"138":1,"713":1,"781":1},"2":{"109":1,"110":2,"122":3,"127":1,"137":2,"144":2,"150":6,"163":2,"168":1,"172":2,"173":1,"174":9,"175":1,"485":4,"565":1,"651":3,"713":1,"781":1}}],["sql",{"2":{"64":1,"487":1,"505":1}}],["switching",{"2":{"324":1}}],["switch",{"2":{"85":1,"163":2,"275":1,"455":1,"784":2,"786":1}}],["swag",{"0":{"57":1},"2":{"37":1}}],["symbol",{"2":{"786":2}}],["syndtr",{"2":{"140":4}}],["sync|async|block",{"2":{"303":2}}],["syncing",{"0":{"338":1,"721":1},"1":{"339":1},"2":{"248":1,"338":1,"370":1,"560":2,"606":1,"607":2,"608":1,"621":1,"627":1,"635":1,"672":1,"721":1,"733":1}}],["synced",{"2":{"82":1,"544":1,"561":1}}],["sync",{"0":{"67":1,"369":1,"370":1,"371":1,"372":1,"494":1,"506":1},"1":{"370":1,"371":1,"372":1},"2":{"67":1,"302":1,"303":2,"338":1,"356":1,"369":4,"370":2,"371":7,"372":2,"494":1,"506":1,"533":1,"544":1,"560":4,"604":4,"608":1,"627":1,"636":1,"674":3,"721":3,"733":1}}],["systemctl",{"2":{"337":4,"604":6,"606":4,"607":4,"608":6}}],["systems",{"2":{"275":2,"312":1,"342":1,"718":1}}],["systemd",{"0":{"248":1,"271":1,"425":1,"470":1,"602":1,"604":1,"621":1},"1":{"603":1,"604":1,"605":1,"606":1,"607":1,"608":1},"2":{"248":1,"271":7,"337":2,"373":1,"425":1,"470":1,"602":1,"604":6,"606":5,"607":5,"608":4,"621":1}}],["system",{"2":{"22":1,"30":1,"224":1,"273":2,"276":1,"277":1,"322":2,"337":5,"341":1,"343":4,"388":1,"431":1,"558":1,"571":1,"591":1,"592":2,"604":4,"606":4,"607":4,"608":4,"649":2,"726":1}}],["sdk",{"2":{"63":1,"96":4,"140":7,"238":1,"260":2,"266":2,"278":1,"281":1,"428":1,"486":1,"509":1,"510":1,"584":1,"586":1,"587":1,"591":1,"599":2,"648":1,"653":1,"676":3,"680":1,"691":1,"698":1,"717":4,"718":2,"719":1,"721":1,"722":1}}],["sashabaranov",{"2":{"770":2,"771":2}}],["saying",{"2":{"560":1}}],["sanity",{"2":{"772":1}}],["sandbox",{"2":{"497":1}}],["sanctions",{"2":{"23":1}}],["sausage",{"2":{"291":2}}],["salt=",{"2":{"202":2}}],["salt",{"2":{"202":5,"204":4,"210":2}}],["sales",{"2":{"38":1,"69":1,"512":1}}],["save",{"0":{"287":1,"368":1},"2":{"202":1,"210":1,"266":1,"275":1,"308":1,"334":1,"368":1,"380":1,"381":1,"446":1,"496":1,"559":3,"767":2,"771":1}}],["saved",{"2":{"137":1,"139":1,"169":1,"184":1,"187":1}}],["saving",{"2":{"37":1,"171":1,"266":1}}],["same",{"0":{"594":1},"2":{"112":1,"125":1,"139":1,"170":1,"175":1,"184":1,"187":1,"191":2,"202":2,"204":1,"224":1,"235":1,"275":4,"281":1,"328":1,"339":3,"361":1,"445":1,"447":1,"478":1,"521":1,"527":1,"561":2,"599":2,"622":1,"649":2,"719":1,"726":1}}],["sampling",{"0":{"471":1,"632":1,"633":1,"643":1},"1":{"644":1,"645":1},"2":{"53":1,"221":1,"238":1,"458":1,"481":1,"533":1,"557":1,"561":1,"583":1,"608":1,"631":1,"632":5,"633":1,"634":1,"642":1,"643":3,"645":1,"650":2,"673":3,"722":1,"756":2}}],["sampler",{"0":{"756":1}}],["samples",{"2":{"644":1}}],["sampled",{"2":{"561":2,"633":1,"652":1}}],["samplefrom",{"2":{"338":2,"560":2}}],["sample",{"0":{"53":1,"54":1,"55":1,"56":1},"2":{"53":2,"54":2,"55":2,"56":2,"163":1,"338":1,"557":1,"560":1,"650":1,"673":1}}],["said",{"2":{"96":1}}],["safely",{"2":{"111":1,"329":1,"650":1}}],["safe",{"2":{"46":1,"280":1,"291":2,"559":3,"767":2}}],["smartstake",{"2":{"499":1}}],["smart",{"0":{"578":1},"2":{"81":1,"87":2,"90":1,"122":7,"124":1,"136":1,"139":1,"141":1,"142":1,"147":1,"152":1,"154":5,"160":2,"164":1,"169":1,"174":1,"175":2,"216":1,"227":2,"228":1,"229":1,"231":1,"233":1,"234":1,"254":1,"578":1,"580":1,"582":1,"584":1,"586":1,"638":1,"690":1}}],["smartphone",{"2":{"34":1}}],["smaller",{"2":{"588":1}}],["small",{"2":{"40":1,"109":1,"125":1,"197":1,"583":1,"632":1,"644":1,"650":1}}],["smooth",{"2":{"37":1}}],["shgo",{"2":{"775":2}}],["shgit",{"2":{"117":1,"699":1}}],["shmkdir",{"2":{"770":1}}],["shnode",{"2":{"607":1}}],["sha3uncles",{"2":{"538":2}}],["sharing",{"2":{"40":1,"58":1,"674":1}}],["shareclient",{"2":{"779":2}}],["shareversionzero",{"2":{"599":2}}],["shareindexinrowmajororder",{"2":{"175":2}}],["shareindexinrow",{"2":{"175":4}}],["shareproof",{"2":{"163":2,"175":6}}],["shareproofs",{"0":{"156":1},"2":{"154":2,"156":3,"163":4,"175":2}}],["sharesize",{"2":{"592":1}}],["sharesproof",{"2":{"154":3,"156":1,"157":1,"158":1,"159":1,"163":18}}],["shares",{"2":{"118":2,"122":5,"125":3,"127":1,"137":4,"139":3,"145":1,"151":3,"152":4,"154":14,"155":1,"156":2,"157":1,"158":1,"159":1,"163":4,"169":1,"172":1,"175":4,"180":1,"199":4,"224":1,"238":1,"415":2,"485":4,"588":2,"591":2,"592":2,"593":1,"643":5,"645":4,"646":3,"650":1,"651":4,"652":3,"747":2}}],["shared",{"2":{"58":1,"449":1}}],["share",{"0":{"151":1,"167":1,"168":1,"169":1,"170":1,"171":1,"183":1,"184":1,"185":1,"190":1,"192":1,"193":1},"1":{"152":1,"153":1,"168":1,"169":1,"170":1,"171":1,"184":1,"185":1,"191":1,"192":1,"193":1},"2":{"26":1,"30":1,"32":1,"34":1,"37":1,"39":4,"40":3,"42":1,"125":6,"137":2,"139":5,"147":5,"149":1,"151":6,"152":2,"163":2,"166":1,"167":1,"168":11,"169":2,"170":1,"172":2,"173":1,"174":2,"175":9,"176":1,"180":2,"183":7,"184":1,"186":1,"188":1,"190":1,"191":5,"194":7,"199":3,"272":1,"332":2,"334":4,"448":1,"450":1,"452":3,"485":3,"564":1,"565":7,"588":2,"591":1,"592":2,"598":6,"643":1,"651":1,"652":1,"674":2,"683":1,"710":7,"711":2,"712":4,"713":3,"745":1,"747":8,"755":2,"760":3,"762":2,"771":2,"773":7,"781":3}}],["shpeer=",{"2":{"452":1}}],["ship",{"2":{"452":1}}],["shirts",{"2":{"37":1}}],["shtia",{"2":{"447":1}}],["shutdown",{"2":{"426":1}}],["shcurl",{"2":{"604":1}}],["shcat",{"2":{"604":1,"606":1,"607":1,"608":1}}],["shcd",{"2":{"286":1,"476":1,"545":1}}],["shceles",{"2":{"272":1}}],["shcelestia",{"2":{"244":4,"245":3,"246":3,"261":1,"263":3,"264":2,"265":5,"266":5,"267":2,"268":1,"269":2,"270":1,"308":3,"309":1,"311":1,"316":1,"317":1,"318":1,"319":1,"324":1,"338":2,"373":4,"375":1,"421":3,"422":1,"423":3,"444":1,"450":1,"453":1,"464":3,"465":3,"466":3,"468":3,"518":1,"520":1,"521":1,"622":4,"767":3}}],["shsed",{"2":{"377":1}}],["shstaking",{"2":{"272":1,"449":1}}],["shsudo",{"2":{"271":1,"604":4,"606":2,"607":2,"608":4}}],["shexport",{"2":{"768":1}}],["shexternal",{"2":{"378":1}}],["sherror",{"2":{"334":1}}],["shevm",{"2":{"272":1}}],["shellsource",{"2":{"211":1}}],["shellforge",{"2":{"210":1}}],["shelltendermint",{"2":{"209":1}}],["shellcast",{"2":{"204":3,"206":1,"207":1}}],["shellcd",{"2":{"202":1,"203":1,"208":1,"210":1,"211":1,"214":1}}],["shell",{"2":{"202":2,"399":1}}],["shellgit",{"2":{"202":1,"586":1}}],["shkey",{"2":{"272":1,"446":1}}],["shvalidator",{"2":{"272":1,"445":1}}],["sh",{"2":{"202":2,"245":1,"262":1,"279":4,"286":1,"287":2,"312":2,"336":1,"343":4,"371":4,"398":2,"422":1,"466":2,"474":2,"476":1,"523":1,"524":1,"558":2,"699":2,"703":1,"706":2,"707":2,"764":1}}],["shforge",{"2":{"117":1}}],["shove",{"2":{"291":2}}],["shoutout",{"2":{"38":1}}],["shouldn",{"2":{"639":1}}],["should",{"0":{"199":1},"2":{"26":1,"34":1,"38":1,"50":1,"65":1,"86":1,"87":1,"136":1,"155":1,"186":1,"187":1,"199":1,"202":3,"204":1,"208":1,"210":1,"211":1,"214":5,"215":2,"216":2,"221":1,"275":1,"312":1,"329":1,"337":1,"365":1,"367":1,"371":3,"431":1,"434":2,"439":1,"445":1,"449":1,"450":2,"487":1,"489":1,"505":1,"530":1,"541":2,"546":1,"558":1,"590":1,"591":1,"606":1,"607":1,"610":1,"616":2,"622":2,"674":1,"690":1,"700":1,"722":2,"745":1,"767":1}}],["showing",{"2":{"409":1}}],["shown",{"2":{"234":1,"332":1,"622":1}}],["shows",{"2":{"139":1,"182":1,"599":2,"646":1,"648":1,"760":1}}],["showcase",{"2":{"38":1}}],["show",{"2":{"37":1,"38":1,"63":1,"174":1,"272":2,"297":2,"329":1,"331":1,"341":1,"399":1,"413":1,"452":2,"464":2,"486":1,"501":1,"542":1,"616":2,"622":3,"762":1,"784":1}}],["shortly",{"2":{"77":1}}],["short",{"2":{"37":1,"392":1}}],["scattered",{"2":{"765":1}}],["scavenger",{"0":{"765":1,"769":1},"1":{"766":1,"767":1,"768":1,"769":1,"770":2,"771":2,"772":2,"773":2,"774":2,"775":2,"776":1},"2":{"729":1,"765":1,"770":6,"775":1}}],["scan",{"2":{"427":1}}],["scaling",{"0":{"583":1},"2":{"583":2,"629":1,"630":1,"642":1}}],["scalable",{"2":{"226":1,"455":1,"639":1,"642":1,"650":1}}],["scalability",{"0":{"226":1,"644":1},"2":{"111":1,"226":2}}],["scale",{"2":{"583":2,"644":1}}],["scaleway",{"2":{"214":1,"215":1}}],["scales",{"2":{"165":1,"221":1,"650":2}}],["scroll",{"2":{"786":1}}],["scrolling",{"2":{"785":1}}],["scratches",{"2":{"584":1}}],["scratch",{"2":{"582":1}}],["scraped",{"2":{"275":2}}],["scrape",{"2":{"275":16}}],["scripts",{"2":{"279":2,"286":2,"287":2,"371":6,"476":3}}],["script",{"0":{"89":1,"474":1},"2":{"76":1,"89":5,"92":1,"93":7,"94":1,"202":2,"210":4,"218":2,"279":2,"286":1,"312":1,"342":1,"343":3,"474":1,"476":1,"558":1,"568":1,"767":1,"775":1}}],["screen",{"2":{"23":1,"34":1,"601":2,"658":1,"662":1}}],["scheme",{"0":{"139":1},"2":{"168":1,"643":1,"645":1,"648":1,"651":1}}],["schemes",{"2":{"52":1,"717":1}}],["schedules",{"2":{"682":1}}],["scheduler",{"2":{"530":1}}],["schedule",{"2":{"30":1,"31":1,"35":1,"37":1,"42":1,"682":2,"687":1}}],["schools",{"2":{"38":1}}],["scene",{"2":{"36":1}}],["scope",{"0":{"9":1},"2":{"56":1,"528":1}}],["slice",{"2":{"561":2,"710":3,"773":2}}],["slightly",{"2":{"485":1}}],["slides",{"2":{"37":1}}],["slower",{"2":{"554":1}}],["slowest",{"2":{"370":1}}],["slowly",{"2":{"546":3}}],["slots",{"2":{"20":1,"22":1}}],["sl",{"2":{"312":2,"343":4,"361":8,"474":2,"558":2}}],["slack",{"2":{"277":1}}],["slashboard",{"2":{"499":1}}],["slashing",{"0":{"281":1},"2":{"270":2,"281":3,"717":1}}],["slashed",{"2":{"23":1,"24":1,"26":1,"208":1,"281":4}}],["slas",{"2":{"65":1,"487":1,"489":1,"505":1}}],["soundness",{"2":{"652":1}}],["sourcing",{"2":{"582":1}}],["sources",{"2":{"275":1}}],["source",{"0":{"311":1,"341":1},"2":{"91":1,"139":1,"210":2,"267":2,"275":4,"310":1,"321":1,"399":4,"428":1,"429":4,"510":1,"545":2,"568":1}}],["sophistication",{"2":{"479":2,"564":2,"565":2}}],["software",{"0":{"62":1,"483":1,"503":1,"550":1,"553":1,"555":1},"2":{"54":1,"55":1,"60":1,"112":1,"221":1,"310":1,"397":1,"501":1,"526":2}}],["sovereign",{"0":{"55":1},"2":{"53":1,"55":5,"60":1,"422":2,"501":1,"552":1,"554":1}}],["soda",{"2":{"35":1}}],["somewhere",{"2":{"446":1,"559":3,"767":2}}],["sometimes",{"2":{"238":1,"415":1}}],["something",{"2":{"104":1,"110":1,"215":2,"275":1,"314":1,"754":2,"767":1}}],["some",{"0":{"175":1,"633":1,"641":1},"2":{"34":1,"40":1,"84":1,"92":1,"125":3,"126":1,"128":1,"154":4,"160":2,"166":1,"266":1,"267":1,"275":1,"279":4,"302":1,"304":1,"321":1,"349":1,"405":1,"434":8,"542":1,"566":1,"579":1,"583":1,"584":1,"599":2,"640":1,"641":1,"651":1,"672":1,"674":1,"682":1,"717":1,"720":1,"745":1,"765":1,"767":1,"772":2,"775":1,"779":2,"780":4,"781":2}}],["someone",{"2":{"31":1,"39":1}}],["solomon",{"2":{"643":2,"645":5,"648":1,"651":1}}],["solution",{"2":{"130":1,"165":1,"197":1,"221":1,"226":1,"642":1,"645":1,"649":1,"650":1}}],["solutions",{"2":{"111":1,"572":1,"594":1,"630":1,"642":1}}],["solidityuint256",{"2":{"175":1}}],["soliditypragma",{"2":{"163":1}}],["solidity",{"2":{"117":1,"118":4,"142":1,"147":1,"152":1,"154":1,"156":6,"157":1,"159":4,"160":2,"163":2,"164":1,"168":1,"213":1,"231":1}}],["soliciting",{"2":{"32":1}}],["sol",{"2":{"111":1,"118":7,"120":1,"122":1,"155":1,"156":1,"157":1,"159":1,"160":1,"163":4,"203":3,"210":2,"214":4,"215":4,"228":1,"233":1,"234":1}}],["solely",{"2":{"674":1}}],["sole",{"2":{"24":1}}],["so",{"2":{"22":1,"23":2,"28":1,"35":2,"39":1,"60":1,"79":1,"91":1,"117":1,"125":2,"139":2,"149":1,"150":1,"156":3,"173":1,"174":1,"187":1,"199":1,"210":1,"215":1,"244":1,"246":1,"294":1,"299":1,"334":1,"368":1,"371":1,"373":1,"375":1,"396":1,"399":1,"423":1,"439":1,"444":1,"452":2,"468":1,"495":1,"496":1,"576":1,"622":1,"631":1,"633":1,"634":2,"646":1,"652":1,"672":1,"700":1,"737":1,"741":1,"765":1,"785":1}}],["sorted",{"2":{"571":1,"611":1}}],["sort",{"2":{"14":1,"15":1}}],["social",{"2":{"9":1,"13":1,"30":1,"32":1,"39":4,"40":1,"266":1}}],["socio",{"2":{"6":1}}],["spin",{"0":{"443":1},"1":{"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1},"2":{"443":1,"542":1}}],["spinning",{"2":{"320":1}}],["splits",{"2":{"651":1}}],["split",{"2":{"137":1,"643":1,"645":1,"651":1,"670":1,"681":1}}],["sp1blobstreamwrapper",{"2":{"144":2,"161":2,"162":2,"163":2}}],["sp1blobstream",{"2":{"136":2,"228":1}}],["sp1",{"0":{"227":1,"228":1,"585":1},"1":{"229":1,"230":1,"231":1,"586":1},"2":{"136":2,"144":4,"161":4,"162":4,"163":4,"221":3,"222":1,"227":10,"228":6,"231":8,"585":3,"586":14}}],["sparsesharesneeded",{"2":{"592":1}}],["sparse",{"2":{"485":2}}],["spans",{"0":{"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"179":1,"180":1,"181":1,"182":1,"187":1,"188":1,"189":1},"1":{"173":1,"174":1,"175":1,"176":1,"177":1,"180":1,"181":1,"182":1,"188":1,"189":1},"2":{"147":1,"151":1,"166":1,"172":3,"173":1,"174":3,"175":7,"176":1,"179":4,"182":1,"183":2,"186":1,"187":5,"197":3,"199":2}}],["span",{"0":{"541":1},"2":{"125":12,"126":4,"127":2,"128":8,"130":3,"154":4,"156":1,"174":1,"541":2}}],["space",{"2":{"46":1,"276":1,"380":1,"381":2,"496":1}}],["spaces",{"2":{"9":2,"13":1,"34":5,"38":1}}],["spdx",{"2":{"118":2}}],["sponsoring",{"2":{"38":1}}],["sponsorship",{"2":{"38":5}}],["sponsors",{"0":{"38":1},"2":{"38":9,"39":1,"46":1}}],["spread",{"2":{"36":1,"39":1}}],["speed",{"2":{"369":1,"610":1}}],["spend",{"2":{"266":1,"267":7,"407":2,"412":2,"592":1,"680":1}}],["specialization",{"2":{"649":1}}],["specialized",{"2":{"649":3}}],["specialize",{"2":{"580":1}}],["specif",{"2":{"154":2,"160":2}}],["specifying",{"2":{"275":1,"520":1,"521":1,"590":1}}],["specify",{"2":{"86":1,"202":4,"244":2,"328":1,"343":1,"392":2,"525":1,"559":1,"561":1,"594":1,"700":1,"737":2,"748":1}}],["specifies",{"2":{"86":1,"407":1,"700":1}}],["specified",{"2":{"13":1,"14":1,"87":1,"202":1,"203":1,"211":2,"213":1,"215":2,"218":1,"260":2,"321":1,"407":1,"590":2,"592":1,"673":1,"695":1,"700":1,"740":1,"748":1,"762":1}}],["specifications",{"2":{"125":1,"281":1,"484":1}}],["specifically",{"2":{"58":1,"90":1,"371":1,"629":1,"638":1}}],["specific",{"0":{"151":1},"1":{"152":1,"153":1},"2":{"35":1,"37":1,"42":1,"73":1,"86":1,"109":1,"120":2,"125":2,"126":4,"128":1,"207":1,"214":2,"215":3,"217":2,"224":1,"226":1,"233":1,"276":1,"313":1,"322":1,"326":1,"328":1,"343":2,"448":1,"500":1,"515":1,"556":1,"740":2,"759":1,"784":1}}],["spec",{"2":{"497":1}}],["specs",{"2":{"137":2,"139":1,"156":2,"157":2,"160":4,"266":2,"593":1,"747":1}}],["speak",{"2":{"37":1}}],["speaking",{"2":{"36":1,"42":1}}],["speaker",{"0":{"58":1},"2":{"30":1,"34":1,"36":1,"37":3,"50":1,"58":5}}],["speakers",{"0":{"37":1},"2":{"30":3,"31":1,"32":1,"34":1,"36":5,"37":13,"38":2,"39":3,"42":2,"46":1,"56":1,"58":2}}],["sequential",{"2":{"429":4,"584":1}}],["sequence",{"0":{"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"179":1,"180":1,"181":1,"182":1,"187":1,"188":1,"189":1},"1":{"173":1,"174":1,"175":1,"176":1,"177":1,"180":1,"181":1,"182":1,"188":1,"189":1},"2":{"166":1,"172":3,"173":1,"174":3,"175":7,"176":1,"179":4,"182":1,"183":2,"186":1,"187":5,"197":3,"199":2,"295":2,"296":2,"400":1,"430":1,"591":1,"594":1,"599":2,"649":2}}],["sequencers",{"2":{"162":1,"183":1,"582":1}}],["sequencersignature",{"2":{"125":2,"128":2,"130":2}}],["sequenceraddress",{"2":{"125":2,"130":2}}],["sequencer",{"0":{"126":1},"1":{"127":1,"128":1},"2":{"110":1,"112":2,"125":3,"126":7,"127":2,"128":8,"130":8,"400":1,"546":4}}],["sequencerinbox",{"2":{"91":2,"100":2,"101":2,"111":1}}],["sed",{"2":{"361":12,"378":2}}],["semantic",{"2":{"341":1}}],["semi",{"2":{"224":1}}],["severity",{"2":{"630":1}}],["severe",{"2":{"281":1}}],["several",{"2":{"109":1,"216":1,"485":1,"514":1,"533":1,"682":1}}],["self",{"2":{"217":1,"260":2,"272":2,"622":4}}],["selecting",{"2":{"34":1,"90":1,"107":1,"284":1}}],["selection",{"0":{"324":1},"1":{"325":1},"2":{"26":1,"58":1}}],["select",{"0":{"654":1,"657":1,"662":1},"2":{"30":1,"76":2,"85":1,"162":2,"294":1,"311":1,"324":1,"368":1,"380":1,"501":3,"558":1,"601":1,"624":1,"656":1,"657":1,"658":2,"661":2,"662":1,"665":1,"666":1,"700":1}}],["selected",{"2":{"23":1,"27":1,"674":1}}],["separation",{"2":{"649":1}}],["separating",{"2":{"583":1}}],["separately",{"2":{"183":1,"568":1}}],["separate",{"2":{"156":1,"238":2,"320":1,"405":1,"568":1,"643":1,"652":1,"726":1}}],["separated",{"2":{"137":1,"211":1,"361":2,"451":2}}],["september",{"2":{"527":1}}],["sepoliaeth",{"2":{"546":1}}],["sepoliafaucet",{"2":{"84":1}}],["sepolia",{"0":{"84":1,"98":1,"99":1,"100":1,"101":1},"2":{"77":2,"79":2,"81":1,"82":1,"84":3,"85":1,"87":1,"90":4,"93":2,"97":2,"98":1,"99":1,"231":3,"251":1,"253":1,"254":1,"255":1,"256":1,"257":1,"542":2,"546":5}}],["session",{"2":{"53":1,"54":1,"55":1}}],["sessions",{"2":{"38":1,"58":1}}],["search",{"0":{"657":1,"666":1},"2":{"601":2}}],["sealfields",{"2":{"538":2}}],["seamless",{"2":{"481":1}}],["seamlessly",{"2":{"400":1}}],["seasoned",{"2":{"50":1}}],["seating",{"2":{"31":1,"34":1}}],["seats",{"2":{"27":4}}],["sentry",{"2":{"361":1,"429":6}}],["sent",{"2":{"93":2,"139":1,"309":1,"580":1,"591":1}}],["sensitive",{"2":{"88":1,"724":1}}],["sense",{"2":{"36":1,"40":1}}],["sender",{"2":{"434":16,"651":1,"670":1}}],["sendrequest",{"2":{"331":2,"333":2}}],["sending",{"2":{"211":1,"252":1,"309":1,"400":1,"651":1,"757":1}}],["sends",{"2":{"112":1}}],["send",{"2":{"30":2,"32":1,"39":3,"41":1,"202":1,"204":2,"265":6,"267":1,"279":8,"281":1,"301":1,"412":1,"415":1,"438":1,"479":3}}],["serving",{"2":{"635":1,"641":1,"674":1}}],["servicecat",{"2":{"604":1,"606":1,"607":1,"608":1}}],["servicenano",{"2":{"337":1}}],["service",{"0":{"339":1,"577":1,"715":1,"717":1},"1":{"716":1,"717":1,"718":2,"719":2,"720":2,"721":2,"722":2},"2":{"65":1,"271":7,"337":9,"377":3,"481":1,"487":1,"489":1,"505":1,"542":1,"602":1,"604":8,"606":7,"607":7,"608":7,"715":1,"726":1}}],["services",{"0":{"354":1},"1":{"355":1},"2":{"23":1,"34":1,"339":2,"499":2,"707":2}}],["served",{"2":{"274":2}}],["serves",{"2":{"238":1,"254":1,"438":1,"480":1,"652":1}}],["servergrafana",{"2":{"275":1}}],["server",{"0":{"247":1,"424":1,"469":1},"2":{"47":1,"70":1,"247":1,"275":6,"313":2,"321":1,"326":2,"424":1,"430":1,"469":1,"512":1,"599":2}}],["servers",{"2":{"26":1,"371":2}}],["serve",{"2":{"44":1,"376":1,"639":1,"641":1}}],["serialized",{"2":{"109":1}}],["serious",{"2":{"14":1}}],["series",{"2":{"13":1,"275":2,"681":1,"682":1}}],["secp256k1",{"2":{"291":2,"292":4,"296":2,"707":2,"717":1}}],["sections",{"2":{"63":1,"197":1,"229":1,"349":1,"486":1,"501":1}}],["section",{"2":{"36":1,"68":1,"83":1,"86":2,"90":1,"109":1,"122":1,"127":1,"142":1,"147":1,"152":1,"156":1,"160":1,"163":4,"166":1,"171":1,"174":1,"183":2,"186":1,"187":1,"191":1,"194":2,"199":1,"203":1,"204":2,"208":2,"210":4,"211":2,"213":2,"215":5,"244":1,"245":1,"287":1,"298":1,"309":1,"311":1,"314":1,"316":1,"324":1,"329":1,"337":1,"341":1,"345":1,"350":1,"380":1,"381":1,"387":1,"388":1,"390":1,"392":1,"422":2,"427":1,"432":1,"453":1,"465":1,"474":1,"561":1,"566":1,"571":1,"574":1,"617":1,"619":1,"648":1,"700":1,"706":3,"708":1,"733":1,"737":1,"738":1,"739":1,"744":1,"746":1,"771":1,"777":1}}],["securing",{"2":{"36":1,"37":1,"38":2}}],["security",{"0":{"224":1,"633":1,"634":1},"2":{"10":1,"26":2,"221":2,"224":1,"226":1,"235":1,"343":1,"396":1,"559":2,"582":2,"629":1,"636":1}}],["securely",{"2":{"88":1,"165":1,"221":1,"400":1,"650":1}}],["secure",{"2":{"24":1,"30":1,"226":1,"320":1,"370":1,"639":1,"653":1,"683":1,"691":2}}],["seconds",{"2":{"93":2,"275":4,"706":4,"707":4,"722":1,"767":1}}],["second",{"2":{"22":4,"156":1,"183":1,"233":1,"433":1,"542":1,"563":1,"594":1,"609":1,"610":1,"611":1,"633":1}}],["setgaslimitandfee",{"2":{"599":2}}],["setwhiteliststatus",{"2":{"206":2}}],["sets",{"2":{"147":1,"742":1,"784":1}}],["settling",{"2":{"227":1}}],["settlement",{"2":{"137":1,"165":1,"171":1,"172":1,"179":1,"180":1,"183":2,"185":1,"186":2,"187":3,"190":1,"191":1,"194":1,"227":1,"455":1,"580":1,"642":2,"648":1,"649":4}}],["settles",{"2":{"107":1}}],["settle",{"2":{"81":1,"87":1,"111":1,"227":1,"454":1}}],["settled",{"2":{"77":1,"80":1}}],["settingpruning",{"2":{"368":1}}],["settingmin",{"2":{"365":1}}],["settings",{"2":{"76":1,"275":1,"322":1,"328":1,"363":1,"380":1,"381":1,"571":1}}],["setting",{"0":{"93":1,"237":1,"240":1,"285":1,"290":1,"414":1,"417":1,"458":1,"462":1,"472":1,"477":1,"478":1,"544":1,"602":1,"612":1,"614":1,"735":1,"748":1},"1":{"238":1,"239":1,"240":1,"241":2,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"286":1,"287":1,"288":1,"289":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"603":1,"604":1,"605":1,"606":1,"607":1,"608":1,"613":1,"614":1,"615":2,"616":2,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"626":1,"627":1,"736":1,"737":1,"738":1},"2":{"7":1,"41":2,"54":1,"55":1,"93":8,"211":1,"237":1,"248":1,"251":1,"311":1,"337":1,"341":1,"355":1,"361":1,"365":2,"368":1,"397":1,"414":1,"418":1,"458":1,"462":1,"470":1,"472":1,"541":1,"542":1,"559":1,"560":1,"599":4,"603":1,"612":1,"614":1,"621":1,"697":1,"736":1,"743":1,"757":1,"766":1}}],["setupprivate",{"2":{"93":1}}],["setup",{"0":{"83":1,"89":1,"241":1,"274":1,"388":1,"391":1,"418":1,"441":1,"475":1,"543":1,"709":1,"778":1},"1":{"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"389":1,"390":1,"391":1,"392":2,"393":2,"394":1,"395":1,"396":1,"476":1,"477":1,"478":1,"479":1,"544":1},"2":{"26":2,"30":1,"76":1,"86":1,"89":5,"92":1,"93":2,"202":2,"205":1,"206":1,"214":1,"250":1,"275":2,"277":1,"290":1,"312":1,"315":1,"343":1,"371":1,"427":1,"441":1,"599":2,"617":1,"739":1,"771":1,"780":2}}],["setupsigner",{"2":{"599":2}}],["setups",{"2":{"23":1,"328":1}}],["set",{"0":{"206":1,"293":1,"302":1,"358":1,"359":1,"361":1,"560":1},"1":{"359":1,"360":1,"361":1},"2":{"18":2,"20":1,"22":1,"23":1,"26":1,"30":1,"31":1,"36":1,"41":2,"79":1,"90":1,"91":4,"93":10,"122":1,"125":4,"128":1,"151":1,"168":1,"178":1,"202":7,"205":2,"206":1,"210":6,"211":5,"224":1,"248":1,"263":3,"275":1,"276":1,"281":3,"287":1,"293":1,"298":2,"299":2,"301":2,"302":1,"303":1,"304":1,"320":1,"337":1,"338":2,"350":1,"353":1,"356":1,"361":6,"366":1,"371":2,"380":1,"381":1,"390":3,"391":1,"392":1,"399":1,"405":1,"412":1,"431":1,"446":1,"462":1,"477":1,"478":1,"533":1,"538":1,"539":1,"541":1,"559":1,"560":3,"561":2,"582":2,"584":1,"586":3,"592":4,"621":1,"638":1,"643":1,"649":1,"676":2,"682":1,"710":1,"724":1,"726":1,"740":4,"741":2,"742":5,"743":4,"744":4,"745":1,"747":1,"748":3,"754":2,"757":1,"762":1,"768":1,"770":1,"771":1,"774":4,"779":1}}],["sees",{"2":{"630":1}}],["seeing",{"2":{"434":2,"606":1,"607":1}}],["seed",{"2":{"361":2,"430":5,"623":1,"681":1,"682":1}}],["seeds",{"2":{"361":13}}],["seeking",{"2":{"341":1}}],["seek",{"2":{"34":1,"37":1}}],["see",{"2":{"16":1,"73":1,"76":1,"77":4,"79":3,"80":1,"87":1,"91":1,"93":1,"94":1,"110":1,"111":1,"127":2,"134":1,"156":2,"157":2,"210":1,"211":1,"214":1,"227":1,"234":1,"238":3,"258":1,"264":1,"265":1,"274":1,"275":1,"282":1,"287":1,"291":1,"303":2,"309":1,"311":1,"312":1,"371":1,"373":1,"380":1,"404":1,"408":1,"428":2,"431":1,"485":1,"495":1,"500":1,"515":1,"525":1,"542":1,"545":1,"546":1,"556":1,"558":2,"559":2,"560":1,"561":2,"564":2,"565":2,"599":4,"601":1,"604":1,"606":1,"607":2,"608":1,"616":2,"622":2,"629":1,"648":1,"659":1,"663":1,"670":1,"679":1,"694":1,"709":1,"714":2,"747":1,"766":1,"767":1,"778":1,"782":2,"785":1,"786":1}}],["sexualized",{"2":{"7":1}}],["sexual",{"2":{"6":1,"7":1}}],["sex",{"2":{"6":1}}],["superior",{"2":{"724":1}}],["supply",{"0":{"675":1},"1":{"676":1,"677":1,"678":1,"679":1,"680":1,"681":1,"682":1},"2":{"238":1,"677":1,"681":1,"682":6,"687":1}}],["supporters",{"2":{"681":2}}],["supported",{"2":{"168":1,"400":1,"497":1,"601":1,"721":1}}],["supports",{"2":{"322":1,"676":1,"718":1}}],["supportive",{"2":{"46":1}}],["supporting",{"2":{"38":1,"41":1,"56":1}}],["support",{"2":{"30":1,"33":1,"35":1,"38":4,"40":1,"43":1,"44":1,"57":2,"81":2,"90":1,"110":1,"249":1,"273":1,"278":1,"396":1,"427":1,"428":1,"509":1,"530":2,"583":1,"584":2,"617":1,"674":2,"676":1}}],["sudo",{"2":{"271":4,"398":2,"399":16,"604":2,"606":4,"607":4,"608":2}}],["sudden",{"2":{"18":1}}],["suits",{"2":{"166":1}}],["suitable",{"2":{"30":1,"380":2}}],["summarize",{"2":{"137":1}}],["summarizes",{"2":{"126":4}}],["summary",{"2":{"53":1,"54":1,"55":1,"226":1}}],["surface",{"2":{"584":1}}],["sure",{"2":{"91":2,"116":1,"117":1,"139":2,"140":2,"164":1,"168":1,"175":1,"183":2,"187":2,"191":1,"194":1,"202":2,"204":1,"211":3,"214":1,"215":2,"273":1,"274":2,"298":1,"311":1,"313":3,"326":3,"347":1,"426":1,"559":1,"604":1,"700":1,"742":1,"767":1}}],["surveys",{"2":{"31":1}}],["suggest",{"2":{"784":2}}],["suggested",{"0":{"674":1},"2":{"594":1,"674":1}}],["suggests",{"2":{"41":1}}],["suggestions",{"0":{"4":1},"2":{"4":1,"34":1}}],["sustainable",{"2":{"38":1}}],["sustained",{"2":{"14":1,"15":1}}],["sufficiently",{"2":{"652":1}}],["sufficient",{"2":{"34":1,"174":1,"403":1,"645":2}}],["succinct",{"0":{"218":1},"2":{"202":4,"203":2,"204":6,"205":1,"211":5,"218":7,"219":1,"221":1,"227":1,"233":1,"235":1,"586":1}}],["succinctxgit",{"2":{"202":1}}],["succinctx",{"2":{"202":4,"214":4,"215":2}}],["succinctgateway",{"0":{"202":1,"204":1},"1":{"205":1,"206":1,"207":1},"2":{"202":7,"204":1,"205":1,"210":3,"215":1,"234":2}}],["succinctlabs",{"2":{"136":4,"144":4,"161":2,"162":2,"163":4,"202":2,"203":2,"208":2,"211":2,"214":2,"215":2,"586":2}}],["succeeds",{"2":{"109":1}}],["success",{"2":{"32":1,"44":1,"77":1,"431":3,"434":2,"747":1}}],["successful",{"2":{"29":1,"36":1,"38":1,"39":1,"51":1,"57":1,"93":1,"204":1,"542":1,"599":4,"616":1,"652":1,"762":1,"773":1}}],["successfully",{"2":{"23":1,"90":1,"122":2,"168":1,"219":1,"248":1,"309":2,"311":1,"429":1,"430":1,"434":1,"542":1,"564":1,"565":1,"604":1,"606":1,"607":1,"608":1,"621":1,"629":1,"632":1,"636":1,"710":1,"767":1,"773":2,"779":1}}],["such",{"2":{"7":1,"30":1,"36":1,"37":2,"38":1,"86":1,"125":2,"126":1,"276":1,"278":1,"313":1,"322":4,"326":1,"400":1,"422":1,"465":1,"484":1,"591":1,"599":2,"630":1,"633":1,"635":1,"636":1,"639":1,"645":1,"649":1,"651":1,"652":2,"672":1,"692":1,"709":1,"715":1,"736":1,"740":2,"776":1,"778":1}}],["subdomain",{"2":{"762":1}}],["subtract",{"2":{"719":1}}],["subtrees",{"2":{"651":1}}],["subtree",{"2":{"168":6}}],["subtreerootthreshold",{"2":{"150":2}}],["sub",{"2":{"599":2,"780":4}}],["subcommands",{"0":{"264":1},"2":{"260":6}}],["subset",{"2":{"679":1}}],["subsequently",{"2":{"124":1}}],["subsequent",{"2":{"22":1,"527":1}}],["subspace",{"2":{"266":4}}],["subscribing",{"0":{"711":1,"712":1,"780":1},"2":{"776":1,"780":2}}],["subscribes",{"2":{"712":2}}],["subscribeblobs",{"2":{"711":2}}],["subscribeheaders",{"2":{"709":1,"712":4,"778":1}}],["subscribe",{"2":{"90":3,"91":1,"711":6,"712":6,"780":6}}],["subscription",{"2":{"162":6,"709":1,"778":1,"780":1}}],["subscriptions",{"2":{"90":1}}],["submitoptions",{"2":{"779":4}}],["submitpayforblob",{"2":{"599":2,"600":1}}],["submitdata",{"2":{"599":2}}],["submitblob",{"2":{"598":4,"710":4}}],["submitblockdata",{"2":{"126":2,"128":2}}],["submitfraudproof",{"2":{"163":8}}],["submitter",{"2":{"266":1}}],["submitted",{"2":{"87":1,"125":8,"144":2,"155":2,"161":2,"163":2,"172":2,"208":1,"216":1,"267":1,"429":2,"450":1,"542":1,"594":3,"601":1,"747":1,"748":1,"773":2,"775":1}}],["submitting",{"0":{"133":1,"411":1,"519":1,"587":1,"594":1,"710":1,"745":1,"762":1,"779":1},"1":{"520":1,"521":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"746":1},"2":{"134":1,"157":1,"180":1,"183":1,"186":1,"187":1,"211":1,"217":1,"244":1,"266":1,"409":1,"422":1,"471":1,"479":1,"525":1,"591":1,"593":1,"601":2,"671":1,"737":1,"745":1,"746":1,"747":1,"776":1,"779":2}}],["submits",{"2":{"126":2,"427":1,"598":2,"710":2,"773":3}}],["submitheader",{"2":{"126":4,"128":2}}],["submitrollupblock",{"2":{"118":2}}],["submit",{"0":{"520":1,"521":1,"623":1,"746":1},"2":{"87":1,"133":1,"163":5,"171":1,"202":1,"205":1,"206":3,"208":1,"211":1,"215":1,"217":1,"266":10,"267":4,"402":1,"406":1,"408":3,"411":3,"422":2,"465":2,"479":2,"517":1,"520":3,"521":3,"525":1,"527":1,"544":1,"564":4,"587":2,"588":1,"592":1,"594":2,"595":1,"597":3,"598":4,"599":6,"600":2,"601":3,"623":1,"652":1,"670":2,"679":1,"680":1,"689":1,"710":5,"730":1,"740":6,"745":12,"748":2,"762":2,"764":1,"765":1,"771":2,"772":2,"773":11,"775":2,"776":2,"779":7}}],["submission",{"0":{"401":1,"409":1,"516":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":1,"412":1,"413":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1},"2":{"47":1,"186":1,"205":2,"206":1,"211":1,"267":1,"455":1,"748":1,"762":1}}],["submissions",{"2":{"20":1,"404":1}}],["subjectivity",{"2":{"371":1}}],["subject",{"2":{"23":1,"37":1,"60":1,"588":1,"611":1,"682":2,"717":1,"722":1}}],["s",{"0":{"86":1,"88":1,"92":1,"161":1,"413":1,"642":1},"1":{"643":1,"644":1,"645":1,"646":1,"647":1,"648":1},"2":{"7":1,"16":1,"18":1,"20":2,"21":1,"22":1,"23":2,"24":2,"26":1,"27":1,"35":1,"36":3,"38":1,"40":1,"42":1,"47":1,"50":1,"58":1,"60":1,"63":1,"67":1,"68":2,"70":1,"81":1,"82":1,"83":1,"86":9,"87":9,"88":4,"90":4,"91":1,"92":1,"93":3,"94":1,"103":1,"107":1,"110":1,"111":2,"122":4,"125":1,"128":28,"130":3,"137":1,"139":1,"165":1,"174":1,"179":1,"187":3,"199":1,"202":3,"205":1,"210":4,"211":1,"214":2,"216":1,"218":1,"221":2,"226":2,"227":4,"233":2,"245":1,"250":1,"260":2,"261":1,"266":1,"271":4,"274":3,"275":3,"276":2,"277":1,"281":1,"301":1,"303":2,"313":1,"316":1,"320":1,"322":7,"326":1,"331":1,"334":1,"337":2,"343":1,"344":1,"349":1,"361":14,"372":12,"377":2,"378":2,"380":1,"396":1,"400":1,"402":2,"404":2,"409":1,"413":1,"422":2,"427":1,"429":2,"431":1,"455":1,"458":1,"465":2,"478":1,"479":2,"480":2,"481":1,"486":1,"494":1,"495":2,"499":1,"501":1,"506":1,"507":2,"508":2,"512":1,"518":1,"521":1,"532":1,"539":2,"540":2,"542":1,"549":1,"552":1,"557":5,"559":2,"560":7,"563":1,"564":2,"565":2,"579":1,"580":1,"584":3,"586":1,"591":2,"592":2,"598":2,"599":2,"601":2,"604":2,"611":1,"636":1,"638":1,"639":1,"642":1,"643":1,"644":1,"651":1,"652":1,"670":1,"680":1,"682":2,"684":1,"685":1,"689":1,"691":1,"692":1,"710":2,"716":1,"719":1,"723":1,"732":1,"736":1,"737":1,"739":1,"740":1,"742":1,"750":1,"751":1,"752":1,"753":1,"754":1,"757":1,"758":1,"765":6,"767":1,"772":1,"773":2,"775":5,"777":1,"779":2,"784":1,"786":1}}],["situation",{"2":{"634":1}}],["site",{"0":{"0":1,"1":1},"1":{"1":1,"2":1,"3":1,"4":1},"2":{"1":1,"784":8}}],["six",{"2":{"595":1}}],["sig",{"2":{"280":1}}],["signaled",{"2":{"527":1,"528":1,"530":1}}],["signaling",{"2":{"527":2,"528":1,"530":4}}],["signal",{"2":{"178":1,"527":1,"530":1}}],["signatures",{"2":{"278":1,"294":2,"754":2}}],["signature",{"2":{"125":4,"128":4,"130":4,"591":1,"651":1,"670":1,"754":2}}],["signers",{"2":{"517":1}}],["signer",{"0":{"519":1,"521":1},"1":{"520":1,"521":1},"2":{"147":2,"202":2,"294":2,"521":4,"530":1,"598":2,"599":12,"710":2}}],["signedtx",{"2":{"279":2}}],["signed",{"2":{"128":1,"279":4,"520":1}}],["signbytes",{"2":{"128":2}}],["signs",{"2":{"127":1}}],["sign",{"2":{"90":1,"128":2,"202":2,"279":6,"599":6,"768":2}}],["significant",{"2":{"367":1,"381":1,"673":1}}],["significantly",{"2":{"38":1,"582":1,"588":1,"722":1}}],["signifies",{"2":{"328":1}}],["signing",{"0":{"272":1},"2":{"88":1,"281":2,"294":2,"622":2,"717":1,"718":1,"726":1,"728":1}}],["signup",{"0":{"47":1}}],["sidebar",{"2":{"275":2}}],["sidenode",{"2":{"159":4,"160":4,"163":8}}],["sidenodes",{"2":{"144":2,"156":6,"159":6,"160":2,"163":6}}],["side",{"2":{"156":2,"159":2,"168":2,"434":8}}],["simulated",{"2":{"400":1}}],["simulates",{"2":{"204":1}}],["simultaneous",{"2":{"274":2}}],["simplifies",{"2":{"525":1}}],["simplicity",{"2":{"172":1,"479":2,"564":2,"565":2}}],["simply",{"2":{"126":2,"238":1,"275":1,"438":1,"455":1}}],["simpler",{"2":{"176":1,"632":1}}],["simplerollup",{"2":{"163":8}}],["simple",{"2":{"124":1,"127":1,"163":1,"180":1,"188":1,"203":1,"204":1,"234":1,"582":1}}],["simplest",{"2":{"84":1,"130":1,"380":1}}],["similarly",{"2":{"187":1,"211":1,"225":1,"278":1,"648":1,"661":1,"690":1}}],["similar",{"2":{"91":1,"93":1,"144":2,"160":1,"161":2,"162":2,"163":2,"186":1,"194":1,"202":1,"210":1,"267":1,"322":1,"337":1,"339":1,"392":1,"393":1,"434":2,"478":1,"539":1,"540":1,"590":1,"616":2,"622":1,"650":1,"722":1,"747":1,"750":1}}],["since",{"2":{"90":1,"91":1,"109":1,"119":1,"144":2,"161":2,"163":2,"169":1,"186":1,"199":1,"210":6,"277":1,"301":1,"480":1,"532":1,"590":1,"592":1,"630":1,"634":1,"644":1,"645":1,"652":1,"677":1,"721":1,"772":2,"773":2,"775":2}}],["single",{"2":{"13":1,"88":1,"120":1,"126":1,"137":1,"172":1,"180":3,"279":4,"286":3,"287":2,"371":1,"460":1,"476":3,"535":1,"636":1,"639":1,"649":1,"734":1}}],["sizeofdatainbytes",{"2":{"593":2}}],["sizes",{"2":{"147":2,"197":1,"592":1}}],["size",{"0":{"588":1},"2":{"6":1,"36":2,"91":4,"122":3,"157":1,"169":1,"171":1,"174":5,"429":8,"485":9,"530":1,"538":2,"565":1,"588":2,"591":4,"592":3,"593":1,"633":2,"638":1,"644":1,"650":1,"651":2,"670":1,"671":1,"676":1,"740":1,"748":1}}],["stuck",{"2":{"400":1}}],["stub",{"2":{"118":1}}],["styles",{"2":{"784":6}}],["style",{"2":{"396":1}}],["stops",{"2":{"400":1}}],["stop",{"0":{"426":1},"2":{"136":2,"266":1,"329":1,"426":1}}],["storing",{"2":{"112":1,"571":1,"607":1,"636":1,"637":1,"639":1,"641":1,"674":2}}],["stories",{"2":{"42":1}}],["storecelestia",{"2":{"743":1}}],["storecd",{"2":{"391":1}}],["store=$home",{"2":{"743":2}}],["storesudo",{"2":{"391":1}}],["stores",{"2":{"322":4,"414":1,"533":1,"571":1,"648":1}}],["store",{"0":{"327":1,"335":1,"392":1,"571":1,"640":1,"743":1},"1":{"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"744":1},"2":{"88":1,"109":1,"112":1,"238":1,"322":1,"328":3,"329":9,"335":5,"336":4,"338":1,"381":3,"391":4,"392":9,"393":8,"415":1,"429":8,"464":2,"477":4,"478":6,"479":6,"496":1,"544":1,"559":7,"561":1,"571":2,"591":1,"635":1,"639":2,"640":1,"641":1,"644":1,"648":1,"672":1,"674":1,"736":1,"740":4,"741":7,"743":9,"744":8,"745":4,"747":2,"767":4}}],["stored",{"2":{"86":3,"109":1,"139":1,"160":1,"162":1,"219":1,"227":1,"261":1,"303":2,"381":2,"633":1,"634":1,"636":1,"672":1,"673":2,"736":1}}],["storage",{"0":{"362":1,"368":1,"391":1,"414":1,"415":1,"417":1,"420":1,"421":1,"422":1,"423":1,"425":1,"426":1,"606":1,"635":1,"636":1,"637":1,"639":1},"1":{"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"392":1,"393":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":2,"422":2,"423":1,"424":2,"425":1,"426":1},"2":{"42":1,"112":1,"218":1,"239":1,"275":2,"322":4,"357":1,"367":1,"368":1,"380":1,"381":1,"393":1,"414":1,"415":2,"416":2,"422":3,"423":2,"424":1,"425":2,"426":1,"460":1,"493":1,"496":1,"501":1,"533":1,"535":1,"606":2,"613":1,"635":2,"636":2,"637":1,"639":2,"641":2,"673":1,"734":1}}],["stick",{"2":{"172":1}}],["sticking",{"2":{"86":1}}],["still",{"2":{"60":1,"166":1,"168":2,"211":2,"328":1,"350":1,"368":1,"422":1,"474":1,"481":1,"546":1,"627":1,"644":1,"648":1,"767":1,"784":1}}],["str",{"2":{"779":4,"780":4,"781":4}}],["stronger",{"0":{"641":1}}],["strong",{"2":{"639":1}}],["straight",{"2":{"497":1}}],["straightforward",{"2":{"193":1}}],["strategy",{"2":{"336":1}}],["strike",{"2":{"226":1}}],["string",{"2":{"65":1,"67":1,"68":1,"143":2,"202":2,"214":1,"244":1,"313":2,"325":2,"326":2,"422":1,"494":1,"495":1,"506":1,"507":1,"598":4,"599":2,"709":1,"710":4,"711":4,"712":4,"713":4,"741":3,"742":1,"745":2,"762":1,"772":2,"773":17,"774":4,"775":8,"778":1}}],["struct",{"2":{"109":1,"125":10,"126":6,"154":4,"156":9,"157":2,"159":5,"160":4}}],["structured",{"2":{"322":1}}],["structures",{"0":{"119":1},"2":{"110":1,"125":2,"137":1,"160":2,"599":2}}],["structure",{"0":{"3":1},"2":{"22":1,"125":2,"156":2,"159":2,"322":1}}],["streaming",{"0":{"220":1},"1":{"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1},"2":{"40":4}}],["stress",{"2":{"35":1}}],["strengthen",{"2":{"32":1}}],["steal",{"2":{"630":1}}],["steady",{"2":{"18":1,"22":1}}],["step",{"0":{"76":1,"77":1,"79":1,"80":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1},"2":{"54":2,"79":1,"85":1,"86":1,"87":2,"90":1,"125":1,"128":1,"130":1,"163":1,"175":1,"201":1,"204":1,"215":1,"280":2,"432":1,"443":1,"448":1,"449":1,"481":1,"661":1,"738":1,"773":1}}],["steps",{"0":{"113":1,"259":1,"289":1,"344":1,"457":1,"573":1,"700":1,"701":1,"702":1,"776":1},"2":{"29":1,"90":1,"104":1,"105":1,"108":1,"199":1,"201":1,"215":1,"237":1,"311":2,"312":1,"341":1,"428":1,"430":1,"439":1,"443":1,"528":1,"586":1,"601":1,"603":1,"622":3,"627":1}}],["stands",{"2":{"695":1}}],["standard",{"2":{"41":1,"341":1,"427":1,"587":1,"589":1,"645":4,"671":1,"717":2,"719":1}}],["standards",{"0":{"7":1},"2":{"8":1,"14":1,"15":1}}],["stay",{"2":{"277":1,"500":1,"515":1,"556":1}}],["stage",{"2":{"221":1,"481":1}}],["stacks",{"0":{"574":1},"1":{"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1},"2":{"573":1,"716":1}}],["stack=",{"2":{"383":2,"627":2}}],["stack",{"0":{"250":1,"454":1,"542":1,"566":1},"1":{"455":1,"456":1,"457":1,"543":1,"544":1,"545":1,"546":1,"547":1,"567":1,"568":1,"569":1,"570":1,"571":1},"2":{"107":1,"249":1,"251":1,"259":1,"383":4,"454":1,"455":1,"457":1,"542":3,"547":1,"582":2,"584":1,"627":4,"649":2}}],["stakin",{"2":{"489":1,"490":1,"491":1}}],["staking",{"0":{"675":1,"683":1,"695":1,"696":1},"1":{"676":1,"677":1,"678":1,"679":1,"680":1,"681":1,"682":1,"684":1,"685":1},"2":{"86":1,"87":1,"266":6,"269":4,"272":1,"616":2,"622":2,"653":1,"676":3,"682":1,"683":2,"684":1,"685":1,"691":1,"692":1,"695":2,"717":1}}],["stakecurrency",{"2":{"784":2}}],["staked",{"2":{"656":1,"682":1}}],["stakeflow",{"2":{"489":1,"490":1,"491":1,"498":1,"508":1,"509":1,"510":1,"514":1}}],["stakers",{"2":{"679":1,"680":1}}],["staker",{"2":{"93":3}}],["stakes",{"2":{"86":2}}],["stake",{"0":{"616":1,"653":1,"655":1,"658":1,"660":1,"662":1,"664":1,"667":1,"676":1,"691":1},"1":{"654":1,"655":1,"656":2,"657":2,"658":2,"659":2,"660":1,"661":2,"662":2,"663":2,"664":1,"665":2,"666":2,"667":2,"668":2},"2":{"18":1,"21":1,"23":1,"86":6,"224":1,"238":1,"266":1,"281":4,"616":1,"653":3,"656":1,"658":1,"659":1,"661":1,"662":1,"663":1,"665":1,"668":1,"676":4,"683":1,"684":1,"691":2}}],["statscelestia",{"2":{"756":1}}],["stats",{"0":{"756":1},"2":{"561":1,"756":1}}],["static",{"2":{"275":2,"571":1,"591":4,"592":2}}],["stateroot",{"2":{"538":2}}],["statesync",{"2":{"371":3}}],["stated",{"2":{"210":1}}],["stateless",{"2":{"122":1}}],["state",{"0":{"68":1,"367":1,"371":1,"495":1,"507":1,"638":1},"2":{"68":3,"86":4,"127":2,"130":1,"163":4,"179":3,"183":1,"187":1,"191":1,"194":1,"202":1,"210":3,"227":1,"238":2,"244":2,"260":6,"302":1,"322":2,"367":1,"368":1,"369":2,"371":7,"372":1,"381":3,"383":29,"407":2,"408":2,"409":2,"410":2,"422":3,"437":1,"455":1,"465":1,"479":4,"495":2,"507":2,"508":1,"510":1,"525":2,"563":4,"580":1,"590":1,"591":1,"592":1,"594":1,"600":1,"627":31,"630":1,"638":4,"648":3,"649":8,"651":2,"672":2,"674":2,"721":1,"722":1,"737":2,"740":2,"750":2,"751":4,"753":2,"757":6,"767":2}}],["statements",{"0":{"771":1},"2":{"771":2}}],["statement",{"2":{"26":1}}],["status",{"0":{"206":1,"258":1},"2":{"6":1,"65":1,"77":1,"205":2,"206":6,"258":2,"260":4,"282":1,"331":2,"495":2,"604":4,"608":2,"610":1,"706":2,"707":2}}],["stable",{"2":{"22":1,"481":1,"549":1}}],["stability",{"0":{"60":1,"481":1},"2":{"18":1}}],["startcelestia",{"2":{"373":1,"453":1,"620":1,"622":1}}],["starts",{"2":{"210":1,"217":1,"677":1}}],["startshare=0",{"2":{"152":1}}],["startindex",{"2":{"172":2,"174":2}}],["starting",{"0":{"476":1},"2":{"20":1,"44":1,"125":1,"141":1,"151":1,"245":1,"329":1,"339":1,"449":1,"545":1,"623":1,"649":1,"680":1,"709":1,"778":1}}],["startblock",{"2":{"144":6,"161":4,"208":1}}],["start=10",{"2":{"142":1}}],["start",{"0":{"248":1,"373":1,"390":1,"393":1,"422":1,"425":1,"436":1,"465":1,"470":1,"557":1,"561":1,"604":1,"621":1},"1":{"466":1,"467":1,"468":1,"469":1,"470":1,"558":1,"559":1,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1},"2":{"64":1,"68":6,"91":3,"92":1,"125":2,"126":1,"136":2,"143":2,"144":4,"147":5,"152":2,"156":3,"163":4,"172":1,"216":1,"244":1,"245":8,"246":7,"247":1,"259":1,"260":4,"279":2,"295":2,"307":1,"309":2,"314":3,"316":3,"317":2,"318":2,"319":2,"320":4,"324":2,"329":3,"334":3,"338":2,"348":2,"371":1,"373":9,"375":1,"384":1,"390":6,"392":1,"393":10,"407":3,"408":3,"422":5,"423":7,"424":1,"428":1,"429":6,"436":2,"453":2,"457":1,"465":7,"466":8,"468":7,"469":1,"474":3,"477":3,"478":3,"487":1,"495":3,"505":1,"518":3,"557":1,"561":5,"563":1,"576":1,"582":1,"604":5,"606":5,"607":6,"608":7,"620":1,"622":9,"627":1,"676":1,"706":2,"707":3,"709":1,"727":1,"737":12,"738":8,"740":1,"767":4,"772":1,"778":1}}],["startup",{"2":{"34":1,"607":1}}],["started",{"0":{"115":1,"716":1},"1":{"116":1,"117":1,"118":1},"2":{"1":1,"26":1,"33":1,"41":1,"92":1,"312":1,"329":1,"342":1,"385":1,"391":1,"405":1,"546":1,"557":1,"561":2,"573":1,"604":1,"608":1,"684":1,"685":1,"706":1,"716":1,"727":2,"765":1}}],["gpt3dot5turbo",{"2":{"774":2}}],["gpt3",{"2":{"774":4,"775":2}}],["gpt",{"2":{"765":2,"766":1,"774":4,"775":4,"776":2}}],["glance",{"0":{"687":1}}],["global",{"2":{"275":3,"429":2}}],["gcpbb",{"2":{"592":1}}],["gg",{"2":{"430":2}}],["gm",{"2":{"408":2,"520":2,"521":2,"740":4,"745":3,"747":6,"748":2}}],["gz",{"2":{"399":24}}],["ghcr",{"2":{"390":6,"392":6,"393":6,"706":2}}],["gbps",{"2":{"239":2,"357":2,"416":2,"535":2,"536":2,"613":2}}],["gb",{"2":{"239":1,"357":1,"416":1,"460":1,"535":3,"536":2,"613":1,"734":1}}],["gnark",{"2":{"214":1}}],["gklcgflcsrm9caqasaapsckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwohaqdvbvupglandgtlocgsoherbafsfbb5l0wdvbjjesehegqkaggbgjjcariscgwkbhv0awesbdixotiqto9cgkcjrjcoyijj81bttfb2gudg7o8auawf0bscbhw9ppd99xpq1slpemfyq0y1joj",{"2":{"147":4}}],["gt",{"2":{"68":6,"70":3,"77":1,"91":8,"128":2,"136":3,"140":8,"142":1,"147":1,"148":2,"150":7,"152":1,"203":8,"204":30,"206":4,"207":4,"209":6,"215":2,"233":1,"244":8,"245":4,"246":12,"262":8,"263":6,"264":8,"265":18,"266":20,"267":4,"268":6,"269":16,"270":4,"271":12,"272":2,"275":2,"279":2,"287":2,"303":4,"314":10,"316":10,"317":4,"318":4,"319":4,"320":16,"324":10,"329":10,"334":8,"335":4,"336":8,"338":9,"372":12,"373":1,"393":2,"399":8,"405":4,"412":4,"422":4,"423":12,"430":4,"466":6,"467":3,"468":12,"495":6,"512":3,"538":1,"571":2,"596":4,"597":4,"604":2,"606":2,"607":4,"608":4,"616":4,"619":2,"622":3,"700":13,"701":12,"702":12,"706":5,"707":8,"737":6,"738":21,"740":6,"742":6,"743":4,"745":8,"747":8,"751":2,"754":4,"757":6,"759":4,"772":6,"773":6,"775":12,"780":8,"781":2,"784":14}}],["gobin",{"2":{"699":2}}],["google",{"2":{"599":4}}],["good",{"2":{"275":1,"391":2}}],["gonna",{"2":{"559":10}}],["gone",{"2":{"307":1}}],["go$ver",{"2":{"399":24}}],["goroutine",{"2":{"383":4,"627":4}}],["govcelestia",{"2":{"266":1}}],["gov",{"2":{"266":12,"267":2,"717":1}}],["governing",{"2":{"692":1}}],["governance",{"0":{"266":1,"675":1,"678":1,"692":1},"1":{"267":1,"676":1,"677":1,"678":1,"679":2,"680":2,"681":1,"682":1},"2":{"266":3,"267":1,"485":3,"588":1,"591":1,"592":2,"648":1,"653":1,"679":2,"680":1,"682":1,"692":3}}],["governs",{"2":{"235":1}}],["go\\t",{"2":{"161":1}}],["go\\tsharesproof",{"2":{"153":1}}],["goimport",{"2":{"150":1,"593":1,"598":1,"599":1,"710":1}}],["going",{"2":{"79":1,"289":1,"350":1,"533":1,"604":1}}],["gopackage",{"2":{"143":1,"144":1,"163":1,"771":1}}],["goleveldb",{"2":{"140":4}}],["golangnodearabica",{"2":{"399":2}}],["golangnodemocha",{"2":{"399":2}}],["golangnodemainnet",{"2":{"399":2}}],["golang",{"0":{"143":1,"148":1,"150":1,"153":1,"399":1,"570":1,"598":1,"708":1},"1":{"709":1,"710":1,"711":1,"712":1,"713":1,"714":1},"2":{"136":2,"143":1,"148":1,"149":1,"150":1,"153":1,"156":1,"158":1,"159":1,"160":1,"163":1,"228":1,"233":1,"341":1,"399":11,"570":2,"598":2,"599":4,"708":1,"725":1,"727":1,"765":2,"766":1,"775":1}}],["gogo",{"2":{"140":2}}],["gohttps",{"2":{"136":2}}],["gotten",{"2":{"155":1,"175":1}}],["got",{"2":{"130":2,"383":2,"561":1,"627":2,"747":1}}],["gotype",{"2":{"125":2,"126":1}}],["gossiped",{"2":{"590":1,"609":1,"643":1}}],["gossiping",{"2":{"130":2,"610":1}}],["gossip",{"2":{"130":1,"415":1}}],["gofunc",{"2":{"128":2,"130":1,"156":1,"157":1,"158":1,"159":1,"160":1,"711":1,"773":1,"775":1}}],["goals",{"2":{"582":1}}],["goal",{"2":{"125":1}}],["goes",{"2":{"54":1,"80":1,"179":3,"199":1,"338":1,"341":1,"719":1}}],["go",{"0":{"770":1},"2":{"44":1,"109":1,"125":1,"126":1,"134":1,"136":3,"140":5,"144":7,"148":1,"150":2,"161":1,"162":2,"163":7,"166":1,"200":1,"214":4,"228":1,"237":1,"256":1,"257":1,"261":1,"275":1,"287":2,"306":1,"311":1,"316":1,"331":1,"332":1,"336":2,"342":1,"343":3,"383":36,"391":2,"397":1,"399":18,"427":4,"432":1,"558":1,"559":14,"627":36,"649":1,"697":2,"712":1,"713":1,"740":1,"767":4,"770":10,"771":3,"772":5,"773":6,"774":1,"775":10}}],["game",{"2":{"765":2}}],["gaming",{"2":{"37":1,"583":1}}],["gather",{"2":{"316":1}}],["gateways",{"2":{"202":1}}],["gateway",{"0":{"728":1,"729":1},"1":{"729":1},"2":{"91":2,"93":2,"201":1,"202":3,"204":7,"205":1,"210":3,"211":4,"235":1,"326":3,"509":1,"723":1,"724":1,"728":3,"729":1,"733":1}}],["gas=220000",{"2":{"622":1}}],["gas=220000moniker=",{"2":{"622":1}}],["gasperblobbyte",{"2":{"591":1}}],["gasperbyte",{"2":{"591":1,"592":2}}],["gaspricestep",{"2":{"784":2}}],["gasprice",{"2":{"539":2,"590":1,"779":1}}],["gastoconsume",{"2":{"591":2,"592":1}}],["gasused",{"2":{"538":2}}],["gaslimit",{"2":{"538":2,"590":1,"593":2,"599":4,"745":4,"757":1}}],["gas",{"0":{"590":1,"591":1,"592":1,"593":1,"748":1},"1":{"591":1,"592":1,"593":1},"2":{"82":1,"84":1,"86":3,"87":2,"91":4,"147":4,"219":1,"226":1,"268":2,"270":2,"294":12,"301":2,"429":16,"525":1,"530":1,"539":2,"588":1,"589":2,"590":9,"591":9,"592":18,"593":5,"599":6,"616":4,"622":4,"671":1,"690":1,"710":3,"745":2,"748":12,"757":7,"773":2,"779":3,"786":3}}],["gaining",{"2":{"630":1}}],["gain",{"2":{"42":1,"50":1,"58":1,"636":1,"765":1}}],["gained",{"2":{"32":1}}],["gap",{"2":{"36":1}}],["gauge",{"2":{"36":1}}],["grid",{"2":{"588":1}}],["grzxooejihch93+g3mldibq6ff+nroakrbgupfu8muo=",{"2":{"147":2}}],["grpcaddr",{"2":{"599":4}}],["grpc",{"0":{"68":1,"491":1,"495":1,"507":1,"510":1,"599":1},"2":{"65":3,"68":4,"244":2,"245":1,"275":3,"313":2,"422":2,"429":12,"465":2,"477":4,"491":14,"495":9,"507":5,"509":3,"510":14,"599":10,"737":3,"762":1}}],["groundbreaking",{"2":{"481":1}}],["group",{"2":{"36":2,"39":1,"40":1,"41":13,"42":7}}],["groups",{"2":{"34":1,"36":2,"39":5,"41":2}}],["grove",{"0":{"497":1},"2":{"64":2,"487":2,"497":2,"505":2}}],["growth",{"2":{"58":1}}],["grow",{"2":{"44":1}}],["growing",{"2":{"44":1}}],["grep",{"2":{"541":1}}],["grepping",{"2":{"541":1}}],["green",{"2":{"137":1}}],["greet",{"2":{"31":1}}],["greater",{"2":{"197":1,"371":1}}],["greatly",{"2":{"40":1}}],["great",{"2":{"35":1,"457":1}}],["grant",{"0":{"407":1},"2":{"406":1,"407":3,"410":2,"412":3}}],["granting",{"0":{"405":1,"412":1},"1":{"406":1,"407":1,"413":1},"2":{"402":1,"405":1}}],["grantee",{"0":{"408":1},"2":{"403":1,"404":2,"405":5,"407":3,"412":6}}],["granter",{"0":{"407":1,"410":1,"413":1},"1":{"411":1},"2":{"294":2,"403":1,"404":2,"405":5,"408":2,"412":6,"413":1}}],["granted",{"2":{"47":1,"413":1}}],["graphical",{"2":{"278":1}}],["graphics",{"2":{"30":1}}],["grafana",{"2":{"275":3,"277":3,"321":1,"495":1}}],["gravity",{"2":{"221":1}}],["gradients",{"2":{"137":1}}],["grading",{"2":{"22":1}}],["grassroots",{"2":{"43":1}}],["gratitude",{"2":{"37":1,"38":1}}],["gracefully",{"2":{"7":1,"426":1}}],["guru",{"2":{"498":1,"508":2,"509":2,"510":2,"514":1}}],["guardian",{"2":{"202":1,"210":1}}],["guardian=",{"2":{"202":2}}],["guaranteed",{"2":{"652":1,"674":2,"720":1}}],["guaranteeing",{"2":{"650":1}}],["guarantees",{"2":{"221":2,"235":1,"674":1}}],["guarantee",{"2":{"26":1,"68":1,"495":1,"507":1,"639":1,"640":1,"643":1,"645":1,"672":1}}],["guidance",{"0":{"33":1},"1":{"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1}}],["guide",{"0":{"29":1,"346":1,"427":1,"439":1,"557":1,"739":1},"1":{"30":1,"31":1,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"347":1,"348":1,"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"558":1,"559":1,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1},"2":{"43":1,"50":1,"54":1,"63":2,"74":2,"81":3,"85":1,"93":1,"217":1,"276":1,"280":2,"283":1,"306":1,"310":1,"321":1,"329":1,"338":1,"356":1,"381":1,"402":1,"405":1,"414":1,"427":1,"439":2,"441":1,"442":1,"458":1,"472":1,"474":1,"480":1,"486":2,"501":2,"533":1,"542":3,"557":2,"558":1,"560":1,"563":1,"568":1,"571":1,"612":1,"699":1,"705":1,"708":1,"709":1,"727":1,"733":2,"776":1,"777":1,"778":1}}],["guidelines",{"0":{"2":1,"11":1,"52":1},"1":{"12":1,"13":1,"14":1,"15":1},"2":{"2":1,"11":1,"16":1,"33":2}}],["guides",{"2":{"0":1,"3":2,"23":2,"33":1,"94":1,"380":1,"501":1,"536":1,"574":1}}],["gi",{"2":{"142":2}}],["git",{"2":{"89":1,"117":1,"203":2,"208":2,"211":2,"214":2,"215":4,"311":7,"341":7,"398":4,"699":3}}],["gitgit",{"2":{"89":1}}],["githubusercontent",{"2":{"361":10,"398":2,"786":1}}],["github",{"0":{"456":1},"2":{"26":2,"89":2,"136":4,"140":18,"143":2,"144":16,"150":6,"156":2,"157":2,"160":2,"161":2,"162":2,"163":24,"202":2,"203":2,"208":2,"211":2,"214":2,"215":2,"280":2,"303":2,"311":2,"326":1,"341":2,"371":4,"383":16,"456":1,"536":1,"586":2,"593":2,"598":6,"599":16,"627":16,"699":2,"709":2,"710":6,"728":1,"733":1,"770":4,"771":8}}],["ginger",{"0":{"530":1},"2":{"73":1,"500":1,"515":1,"530":1,"556":1}}],["given",{"0":{"336":1},"2":{"60":1,"109":1,"146":1,"171":1,"197":1,"202":1,"209":1,"334":2,"336":2,"367":1,"485":1,"552":1,"554":1,"633":1,"646":1,"710":1,"713":3,"762":1,"773":1,"774":2,"779":1,"781":1}}],["gives",{"2":{"39":1,"58":1,"111":1,"184":1,"485":1,"676":1}}],["give",{"2":{"38":1,"391":1,"406":1,"559":2,"574":1}}],["giving",{"2":{"7":1,"34":1,"111":1}}],["gifts",{"2":{"37":1}}],["g",{"2":{"22":1,"32":1,"42":2,"275":1,"338":1,"373":1,"377":2,"403":1,"560":1,"586":1,"588":1,"622":1,"632":1,"646":1,"652":1,"740":1}}],["gem",{"0":{"664":1,"665":1},"1":{"665":1,"666":1,"667":1,"668":1},"2":{"653":1}}],["genutil",{"2":{"717":1}}],["genuine",{"2":{"47":1,"58":1}}],["genuinely",{"2":{"46":1}}],["gentx",{"2":{"260":2,"272":4,"449":5,"450":7}}],["gentxscelestia",{"2":{"450":1}}],["gentxs",{"2":{"260":2,"450":1}}],["gentle",{"2":{"81":1,"82":1,"103":1}}],["genesis",{"0":{"272":1,"447":1,"449":1,"450":1,"681":1},"1":{"682":1},"2":{"160":2,"209":2,"210":4,"260":20,"272":3,"304":1,"314":10,"355":1,"361":7,"369":1,"447":2,"448":3,"449":2,"450":5,"477":1,"532":1,"627":1,"636":1,"673":1,"680":1,"681":2,"682":1,"687":1}}],["generating",{"0":{"700":1},"2":{"168":1,"174":1,"203":1,"217":1,"559":2,"767":2}}],["generation",{"2":{"140":1,"173":1,"650":1}}],["generate",{"2":{"168":1,"199":1,"202":1,"203":1,"211":2,"213":2,"214":4,"215":3,"217":1,"227":1,"233":1,"235":1,"260":2,"272":1,"279":4,"306":1,"634":2,"645":1,"697":1,"700":1,"747":1,"765":1,"768":2}}],["generates",{"2":{"141":1}}],["generated",{"2":{"70":1,"86":4,"124":1,"136":1,"151":1,"175":1,"199":1,"211":1,"214":1,"215":4,"219":2,"245":1,"322":1,"422":1,"446":1,"449":1,"466":1,"467":1,"512":1,"559":2,"568":1,"645":1,"710":2,"738":2,"745":1,"750":1,"767":2,"773":1,"779":2}}],["generally",{"2":{"591":1}}],["generalized",{"2":{"172":1}}],["general",{"2":{"26":1,"197":1,"580":1,"591":1,"643":1,"682":1,"698":1}}],["gender",{"2":{"6":1}}],["geolocation",{"2":{"23":1}}],["getenv",{"2":{"774":2}}],["geteds",{"2":{"713":7,"781":1}}],["getbyheight",{"2":{"713":2,"754":1}}],["getblockdata",{"2":{"126":2,"130":2}}],["getaddress",{"2":{"599":2}}],["getall",{"2":{"598":2,"674":2,"710":3,"712":2,"773":1,"779":1}}],["geth",{"2":{"455":1}}],["getheader",{"2":{"126":4,"130":2}}],["getlatestblock",{"2":{"130":2}}],["getlatestrollupheight",{"2":{"126":2}}],["gets",{"2":{"109":1,"110":1,"137":1,"139":2,"172":1,"214":1,"281":1}}],["getting",{"0":{"115":1,"716":1},"1":{"116":1,"117":1,"118":1},"2":{"24":2,"93":2,"95":1,"203":1,"209":1,"281":1,"629":1,"716":1,"766":1}}],["get",{"0":{"567":1,"752":1,"753":1,"754":1,"756":1},"2":{"1":1,"26":1,"33":1,"36":1,"41":1,"109":1,"110":2,"144":8,"147":1,"161":2,"163":4,"175":2,"204":2,"218":1,"245":1,"265":1,"266":1,"276":1,"281":1,"309":1,"312":1,"331":2,"332":2,"333":2,"338":2,"342":1,"361":1,"371":1,"385":1,"400":1,"405":1,"422":2,"430":1,"465":1,"467":1,"477":3,"478":1,"479":2,"540":2,"546":1,"557":1,"560":2,"565":4,"567":1,"573":1,"579":1,"580":1,"583":1,"588":1,"592":1,"594":1,"599":2,"616":1,"629":1,"684":1,"685":1,"709":3,"713":2,"727":2,"745":1,"747":15,"752":1,"753":1,"754":6,"755":4,"759":1,"760":7,"765":1,"770":4,"772":2,"773":5,"775":4,"776":1,"778":1,"779":2,"780":2,"781":8}}],["ok",{"2":{"780":4}}],["okpajw+kyhnqkq5vch",{"2":{"147":2}}],["oil",{"2":{"291":2}}],["o",{"2":{"214":2,"372":12,"644":1,"645":2}}],["older",{"2":{"208":1,"526":1,"673":1}}],["old",{"2":{"152":1,"153":1,"324":1,"334":1,"637":1}}],["oss",{"2":{"720":1}}],["ostrich",{"2":{"291":2}}],["os|file|kwallet|pass|test|memory",{"2":{"261":1,"303":2}}],["os",{"2":{"143":2,"144":2,"163":2,"274":2,"398":1,"771":2,"772":8,"773":8,"774":2,"775":8}}],["occupied",{"2":{"485":1}}],["occurring",{"2":{"722":1}}],["occurs",{"2":{"630":1}}],["occur",{"2":{"130":1,"266":1,"682":2}}],["occasional",{"2":{"481":1,"549":1}}],["october",{"2":{"27":1,"682":2}}],["omitempty",{"2":{"125":2}}],["owners",{"2":{"93":6}}],["ownership",{"2":{"93":2}}],["owner",{"2":{"86":1,"93":5,"202":3,"204":4,"210":1}}],["own",{"2":{"65":1,"68":1,"86":1,"91":1,"217":1,"221":1,"244":1,"297":1,"301":1,"309":1,"311":1,"352":1,"422":1,"439":1,"445":1,"454":1,"487":1,"495":1,"497":1,"505":1,"542":1,"582":1,"584":1,"586":1,"616":1,"619":1,"646":1,"649":1,"650":1,"674":1,"676":1,"690":1,"691":1,"710":1,"724":1,"763":1,"768":1}}],["ovh",{"2":{"23":1}}],["overpaying",{"2":{"592":1}}],["overpay",{"2":{"590":1}}],["overhead",{"2":{"454":1,"455":1}}],["override",{"2":{"275":2}}],["over",{"0":{"434":1},"2":{"53":1,"54":1,"125":4,"127":1,"128":1,"139":3,"166":1,"167":1,"199":1,"200":1,"211":1,"228":1,"237":1,"306":1,"316":1,"338":1,"341":1,"397":1,"434":2,"559":2,"563":1,"580":1,"674":1,"692":1,"697":2,"728":1,"738":1,"740":1}}],["overview",{"0":{"107":1,"137":1,"238":1,"402":1,"415":1,"459":1,"517":1,"533":1,"671":1,"686":1},"1":{"138":1,"139":1,"534":1,"535":1,"536":1,"687":1,"688":1,"689":1,"690":1,"691":1,"692":1,"693":1,"694":1,"695":1,"696":1},"2":{"21":1,"31":1,"41":1,"53":1,"54":1,"55":1,"64":2,"77":1,"79":1,"81":1,"82":1,"96":1,"103":1,"108":1,"122":2,"321":1,"344":1,"487":2,"505":2,"659":1,"663":1,"671":1,"716":1}}],["overall",{"2":{"7":1,"35":1,"96":1}}],["otel",{"2":{"23":1,"317":2,"318":2,"319":2,"321":3}}],["otherwise",{"2":{"10":1,"91":1,"109":1,"111":1,"149":1,"183":1,"202":1,"208":1,"210":1,"213":1,"266":1,"443":1,"604":1,"745":1,"762":1,"773":1}}],["others",{"2":{"7":1,"210":1,"452":1}}],["other",{"0":{"386":1,"448":1,"722":1},"2":{"3":1,"7":2,"8":1,"12":1,"23":2,"24":1,"26":1,"34":1,"36":5,"37":2,"39":2,"41":1,"42":3,"46":1,"69":1,"86":1,"107":1,"109":1,"120":1,"125":2,"134":1,"136":1,"164":1,"178":1,"197":1,"215":1,"216":1,"226":1,"238":1,"244":1,"252":1,"322":1,"328":1,"338":1,"377":1,"406":1,"422":1,"437":1,"448":2,"449":1,"450":2,"451":2,"452":2,"512":1,"525":1,"542":1,"557":1,"564":1,"583":1,"588":2,"589":1,"592":1,"629":1,"636":1,"639":1,"646":1,"649":2,"674":3,"680":1,"691":1,"700":1,"720":2,"722":1,"724":1,"727":1,"733":1,"737":1}}],["observe",{"2":{"336":1,"542":1}}],["observer",{"2":{"317":2,"318":2,"319":2}}],["observed",{"2":{"199":1}}],["object",{"2":{"90":2,"557":1}}],["objective",{"2":{"26":1}}],["objectives",{"0":{"18":1},"2":{"18":1,"30":1}}],["obtained",{"2":{"209":1,"210":1,"766":1}}],["obtain",{"2":{"38":1,"90":1}}],["obligated",{"2":{"10":1}}],["oprexqlg9er1oey1de4mkwvmjlfnqoocg==",{"2":{"754":2}}],["opqym",{"2":{"292":2,"296":2}}],["op",{"0":{"250":1,"454":1,"542":1},"1":{"455":1,"456":1,"457":1,"543":1,"544":1,"545":1,"546":1,"547":1},"2":{"249":1,"251":1,"259":1,"454":1,"455":10,"457":1,"537":1,"541":1,"542":7,"545":3,"547":1}}],["ops",{"2":{"212":1,"560":2,"561":1}}],["opt",{"2":{"211":1,"337":4,"690":1}}],["opted",{"2":{"202":2}}],["optimize",{"2":{"722":1}}],["optimized",{"2":{"649":1}}],["optimism",{"0":{"537":1},"1":{"538":1,"539":1,"540":1,"541":1},"2":{"250":2,"454":1,"455":2,"456":1,"537":1,"547":1,"682":1}}],["optimised",{"2":{"221":1}}],["optimistically",{"2":{"178":1,"179":1}}],["optimistic",{"0":{"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1},"1":{"179":1,"180":2,"181":2,"182":2,"183":1,"184":2,"185":2},"2":{"127":1,"130":1,"165":1,"171":1,"178":4,"179":1,"182":1,"186":1,"197":1,"227":1}}],["optimally",{"2":{"649":1}}],["optimal",{"2":{"341":1}}],["option",{"0":{"370":1,"371":1,"372":1,"520":1,"521":1},"2":{"107":1,"238":1,"266":2,"275":1,"341":2,"342":1,"350":1,"380":4,"381":1,"568":1,"601":1,"622":1}}],["options",{"0":{"343":1,"380":1,"624":1,"703":1},"2":{"34":2,"35":1,"40":1,"85":1,"216":1,"260":1,"261":1,"264":1,"265":1,"266":2,"274":2,"294":4,"343":1,"371":2,"380":1,"486":1,"501":1,"521":1,"533":1,"567":1,"574":1,"576":1,"582":1,"584":1,"599":6,"624":1,"710":1}}],["optionally",{"2":{"77":1,"79":2,"361":1,"745":1}}],["optional",{"0":{"213":1,"246":1,"247":1,"248":1,"302":1,"303":1,"363":1,"367":1,"375":1,"376":1,"380":1,"381":1,"410":1,"411":1,"412":1,"413":1,"423":1,"424":1,"425":1,"444":1,"448":1,"468":1,"469":1,"470":1,"525":1,"617":1,"621":1,"624":1,"746":1},"1":{"214":1,"215":1,"364":1,"365":1,"377":1,"378":1,"379":1,"411":1,"413":1,"424":1,"469":1,"618":1,"619":1,"620":1,"621":1},"2":{"23":1,"34":1,"39":1,"294":1,"341":1,"361":1,"373":1,"525":1,"627":2,"652":1,"745":10,"785":1,"786":2}}],["opportunities",{"2":{"42":1,"58":1}}],["opportunity",{"2":{"18":1}}],["operating",{"2":{"312":1,"322":1,"337":1,"342":1,"343":1,"388":1}}],["operation",{"2":{"88":1,"322":1}}],["operations",{"2":{"59":1,"245":1,"422":1,"591":1,"651":1,"695":1}}],["operators",{"0":{"339":1},"2":{"321":1,"455":1,"481":1,"526":1,"533":1,"681":1}}],["operator",{"2":{"211":1,"215":1,"217":1,"218":3,"219":1,"273":1,"341":1,"380":1}}],["operates",{"2":{"226":1}}],["operate",{"2":{"109":1,"322":1,"649":1}}],["operated",{"2":{"23":1}}],["openaikey",{"2":{"774":6}}],["openaimkdir",{"2":{"770":1}}],["openai",{"0":{"768":1},"2":{"765":2,"766":1,"768":5,"770":1,"771":4,"774":15,"775":1}}],["opened",{"2":{"435":1}}],["opening",{"2":{"337":2}}],["opentelemetry",{"2":{"320":1,"321":1}}],["openrpcgo",{"2":{"709":1}}],["openrpc",{"2":{"96":1,"598":6,"709":2,"710":6,"726":1,"770":2,"771":6}}],["openssl",{"2":{"91":1}}],["open",{"0":{"337":1,"434":1,"656":1,"661":1,"665":1},"2":{"6":1,"22":1,"25":1,"27":3,"65":3,"68":1,"244":1,"267":2,"274":2,"275":2,"309":1,"313":3,"321":1,"324":1,"326":2,"337":9,"338":1,"390":1,"422":1,"428":1,"451":1,"453":1,"456":1,"465":1,"510":1,"560":1,"563":1,"619":1,"656":1,"706":1,"737":1}}],["opinions",{"2":{"7":1}}],["our",{"0":{"6":1,"7":1},"2":{"6":1,"7":2,"8":1,"9":1,"42":1,"46":2,"47":2,"49":1,"58":2,"73":1,"289":1,"301":2,"308":1,"344":1,"392":1,"399":1,"430":1,"446":1,"558":1,"559":1,"563":1,"745":1,"750":1,"751":1,"767":4,"771":2,"772":2,"773":5,"775":4}}],["outcome",{"2":{"651":1}}],["outsource",{"2":{"582":1}}],["outsourcing",{"2":{"582":1}}],["outside",{"2":{"196":1,"591":1,"639":1,"673":1}}],["outbound",{"2":{"427":1}}],["outbox",{"2":{"100":1,"101":1}}],["output",{"2":{"260":2,"279":6,"287":2,"291":1,"292":1,"294":1,"295":1,"296":1,"297":2,"303":4,"308":1,"311":1,"312":2,"341":1,"343":1,"398":2,"399":1,"409":1,"413":1,"431":1,"434":2,"446":1,"452":2,"464":1,"478":2,"538":1,"539":1,"616":2,"622":1,"745":3,"747":4,"754":2,"760":1,"767":1,"775":1}}],["outputs",{"2":{"214":1,"271":2}}],["outputinfo",{"2":{"76":1,"94":1}}],["outline",{"2":{"124":2,"130":1,"165":1}}],["outlined",{"2":{"22":1,"104":1,"105":1,"130":1,"183":1,"199":1}}],["out",{"0":{"74":1,"78":1},"1":{"75":1,"76":1,"77":1,"78":1,"79":2,"80":2},"2":{"0":1,"30":3,"37":1,"38":1,"39":1,"40":1,"74":2,"94":1,"109":1,"118":2,"121":1,"126":1,"169":1,"174":2,"179":1,"191":1,"194":1,"221":1,"245":1,"274":2,"275":1,"311":1,"321":1,"341":1,"399":1,"439":1,"471":1,"495":1,"501":2,"554":1,"558":1,"569":1,"570":1,"572":1,"573":1,"580":1,"584":1,"594":1,"632":1,"716":1,"729":1,"740":1,"763":1}}],["onto",{"2":{"641":1}}],["onstart",{"2":{"383":2,"627":2}}],["onclick=",{"2":{"784":2}}],["oncall",{"2":{"277":2}}],["onchain",{"0":{"219":1},"2":{"111":1,"112":1,"202":1,"203":2,"211":1,"213":1,"215":2,"221":2,"229":1,"234":1,"455":1,"583":1,"622":1,"630":1,"682":1}}],["once",{"2":{"24":1,"87":1,"90":1,"109":1,"128":1,"187":1,"194":1,"210":1,"245":1,"275":2,"294":1,"371":1,"404":1,"422":1,"426":1,"448":1,"450":2,"466":1,"477":1,"527":1,"558":1,"559":1,"561":1,"563":1,"564":1,"579":1,"601":1,"632":1,"639":1,"651":1,"672":1,"673":2,"674":1,"697":1,"738":1,"740":1,"768":1}}],["only",{"2":{"91":3,"96":2,"109":2,"110":3,"111":1,"130":2,"149":1,"166":1,"169":1,"172":1,"175":1,"180":1,"205":1,"206":2,"214":1,"227":1,"267":1,"279":2,"291":2,"308":1,"313":1,"328":1,"361":1,"373":1,"396":1,"426":1,"439":1,"495":1,"511":1,"583":1,"584":1,"588":1,"592":1,"599":2,"622":2,"634":1,"636":1,"639":1,"642":1,"643":1,"644":1,"645":2,"646":2,"648":1,"649":3,"650":2,"651":2,"673":2,"674":1,"700":1,"717":1,"719":1,"728":1,"733":1,"743":1,"773":1}}],["online",{"2":{"9":1,"31":1,"38":1,"39":1,"604":2,"606":2,"607":2,"608":2}}],["onboarding",{"0":{"42":1}}],["onecelestia",{"2":{"561":1}}],["oneexport",{"2":{"405":1}}],["ones",{"2":{"169":1,"187":1,"213":1,"432":1,"435":1}}],["onestepproofentry",{"2":{"100":1,"101":1}}],["onestepproverhostio",{"2":{"100":1,"101":1}}],["onestepprovermath",{"2":{"100":1,"101":1}}],["onestepprovermemory",{"2":{"100":1,"101":1}}],["onestepprover0",{"2":{"100":1,"101":1}}],["one",{"0":{"594":1},"2":{"39":1,"40":1,"41":1,"42":1,"74":2,"90":1,"91":1,"104":1,"107":1,"109":1,"110":1,"134":1,"152":1,"153":1,"166":1,"169":1,"178":1,"184":1,"187":1,"191":3,"199":1,"208":1,"210":1,"212":1,"214":1,"216":2,"228":1,"231":1,"244":1,"245":2,"260":4,"265":5,"266":3,"275":3,"287":1,"289":1,"290":2,"299":1,"301":2,"303":2,"328":1,"329":2,"336":1,"342":1,"355":2,"403":3,"404":1,"405":2,"412":2,"413":2,"415":1,"422":1,"427":2,"429":2,"450":1,"465":4,"466":2,"485":2,"489":1,"490":1,"491":1,"495":1,"507":1,"509":1,"510":1,"528":1,"530":1,"560":4,"561":3,"565":1,"580":1,"582":1,"583":1,"584":1,"587":1,"588":1,"591":1,"594":1,"617":1,"619":1,"633":1,"645":2,"646":1,"649":2,"651":2,"652":2,"700":1,"706":2,"707":2,"733":1,"737":2,"771":2,"774":1,"776":1,"786":2}}],["onwards",{"2":{"22":1,"163":2}}],["on",{"0":{"140":1,"251":1,"281":1,"290":1,"301":1,"368":1,"378":1,"533":1,"540":1,"575":1,"676":1,"683":1,"744":1},"1":{"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"252":1,"253":1,"254":1,"255":1,"256":1,"257":1,"258":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"534":1,"535":1,"536":1,"576":1,"577":1,"578":1,"684":1,"685":1},"2":{"3":2,"7":2,"22":2,"23":5,"26":5,"30":1,"33":1,"34":3,"35":2,"37":2,"38":1,"39":4,"40":5,"41":1,"42":1,"47":1,"53":1,"54":1,"55":2,"58":1,"59":3,"60":2,"63":1,"65":2,"68":1,"70":2,"76":1,"77":2,"79":3,"81":1,"82":2,"84":1,"86":10,"87":2,"88":1,"90":1,"91":5,"92":1,"93":51,"97":1,"107":1,"109":3,"110":1,"111":4,"112":3,"120":1,"124":2,"126":6,"128":1,"136":1,"137":1,"139":2,"163":1,"165":1,"167":1,"168":3,"169":1,"170":1,"171":2,"174":2,"175":2,"178":1,"180":1,"182":1,"202":2,"204":1,"214":3,"215":4,"216":2,"218":1,"219":1,"221":2,"224":2,"225":4,"226":2,"227":5,"228":2,"230":1,"231":8,"234":1,"238":2,"240":1,"244":4,"245":4,"248":1,"249":1,"250":2,"251":1,"261":1,"266":3,"267":1,"272":1,"274":2,"275":9,"276":1,"277":2,"280":1,"281":1,"282":2,"283":1,"289":3,"297":2,"298":2,"301":2,"302":1,"305":2,"309":2,"311":2,"312":2,"313":4,"315":1,"321":3,"322":1,"324":2,"326":5,"329":1,"331":1,"341":1,"342":1,"343":1,"356":1,"358":1,"359":1,"360":1,"366":1,"368":1,"369":1,"370":1,"371":2,"373":1,"377":3,"380":4,"381":1,"383":1,"386":1,"388":1,"390":3,"391":5,"396":1,"398":1,"400":4,"402":1,"403":1,"406":1,"412":1,"417":1,"422":4,"427":3,"429":2,"438":1,"453":2,"454":1,"455":6,"456":1,"458":1,"459":1,"461":1,"462":2,"465":3,"470":1,"471":1,"473":1,"485":3,"486":1,"487":2,"489":2,"495":1,"496":1,"497":2,"500":1,"501":7,"505":2,"508":1,"512":2,"515":1,"524":1,"526":1,"528":3,"533":3,"536":1,"537":1,"538":1,"539":1,"542":4,"544":1,"545":3,"546":1,"552":3,"554":3,"557":2,"564":3,"574":2,"576":1,"578":1,"580":2,"584":1,"586":1,"588":3,"591":3,"592":6,"598":2,"599":2,"601":4,"609":1,"611":1,"612":1,"614":2,"615":1,"619":2,"621":1,"622":2,"627":2,"630":1,"632":1,"633":1,"641":1,"642":1,"643":1,"644":1,"646":1,"648":2,"649":3,"652":1,"653":2,"658":1,"662":1,"670":1,"671":3,"673":2,"674":6,"676":3,"677":1,"679":2,"682":2,"689":2,"690":2,"692":1,"697":1,"700":1,"705":2,"706":4,"707":1,"710":2,"716":1,"718":1,"720":1,"722":1,"724":2,"728":1,"733":1,"736":1,"737":2,"738":3,"742":3,"743":1,"747":1,"748":1,"762":1,"765":2,"767":1,"771":1}}],["oracle",{"0":{"110":1},"2":{"108":1,"110":3,"120":1}}],["originate",{"2":{"609":1}}],["originally",{"2":{"329":1,"590":1}}],["original",{"2":{"81":1,"174":1,"221":1,"295":2,"594":1,"643":1,"645":3,"646":1,"651":2,"652":1}}],["origin",{"2":{"79":1,"299":4,"300":1,"611":1}}],["orientation",{"2":{"6":1}}],["orbitsetupscriptconfig",{"2":{"88":1,"89":1}}],["orbit",{"0":{"74":1,"77":1,"81":1,"86":1,"87":1},"1":{"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1},"2":{"74":2,"76":2,"81":5,"82":2,"83":1,"84":2,"85":1,"86":8,"87":7,"89":5,"91":1,"92":1,"93":28,"94":1,"96":4,"97":1,"103":3,"107":4,"108":1,"110":1}}],["ordered",{"2":{"328":2,"646":1,"649":2}}],["order",{"0":{"336":1},"2":{"35":1,"37":1,"63":1,"65":1,"90":1,"109":1,"110":2,"136":1,"139":1,"174":1,"175":1,"246":1,"336":2,"348":1,"392":1,"422":1,"423":1,"426":1,"448":1,"465":1,"468":1,"486":2,"507":1,"544":1,"579":1,"588":1,"590":1,"622":1,"644":1,"649":1,"672":1,"674":1,"741":1,"742":1,"743":1,"752":1,"753":1,"762":1,"768":1}}],["ordering",{"2":{"35":1,"434":2,"580":1,"650":1}}],["organizing",{"2":{"33":1,"36":2,"41":2,"46":1,"50":1,"57":1}}],["organizers",{"2":{"34":1,"37":1,"38":1,"42":2,"43":1,"44":2,"46":1,"47":1,"49":1,"50":2,"58":1}}],["organizer",{"2":{"33":1,"37":1,"41":4,"50":1,"57":1,"58":1}}],["organize",{"2":{"29":2,"36":1,"37":1}}],["organization",{"2":{"26":1}}],["org",{"0":{"5":1,"46":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1},"2":{"6":1,"10":1,"16":3,"24":1,"40":1,"41":2,"46":1,"57":1,"86":1,"312":2,"343":4,"399":8,"474":2,"489":2,"490":2,"491":2,"492":1,"508":1,"509":1,"510":1,"558":2,"599":4}}],["or",{"0":{"102":1,"302":1,"546":1,"744":1},"1":{"103":1,"104":1,"105":1},"2":{"2":1,"4":1,"6":2,"7":8,"8":2,"9":2,"10":1,"12":2,"13":2,"14":2,"15":2,"22":1,"23":7,"24":4,"26":3,"30":3,"31":4,"32":1,"34":4,"35":3,"36":3,"37":5,"38":4,"39":3,"40":2,"41":1,"42":2,"58":1,"59":1,"65":1,"67":1,"68":3,"69":1,"84":1,"85":1,"86":3,"91":2,"93":5,"94":1,"96":1,"104":1,"107":1,"112":2,"122":1,"124":1,"126":1,"127":1,"130":2,"134":2,"136":1,"137":2,"139":1,"160":1,"165":1,"169":1,"174":1,"186":1,"203":2,"204":1,"205":1,"208":1,"211":3,"213":1,"215":1,"224":2,"225":1,"227":1,"238":1,"244":3,"260":4,"261":1,"272":1,"275":6,"277":3,"278":1,"281":2,"301":1,"302":2,"309":1,"320":2,"334":2,"338":4,"343":1,"361":1,"368":1,"371":1,"377":1,"386":1,"388":1,"389":1,"390":2,"392":1,"400":5,"422":3,"435":1,"439":1,"449":1,"452":1,"465":2,"466":1,"481":2,"485":1,"487":1,"494":1,"495":3,"497":1,"505":1,"506":1,"507":1,"509":1,"512":1,"526":1,"536":2,"549":1,"558":1,"560":1,"564":1,"580":2,"582":1,"583":1,"584":3,"587":1,"590":1,"591":1,"594":1,"599":4,"603":1,"609":2,"610":1,"611":1,"619":2,"630":2,"636":1,"640":1,"645":1,"649":1,"652":1,"659":1,"663":1,"668":1,"670":1,"674":2,"676":1,"682":2,"690":1,"695":1,"698":1,"699":1,"700":3,"707":1,"719":1,"728":2,"736":1,"737":2,"738":2,"740":1,"741":1,"744":2,"745":1,"762":2,"766":1}}],["often",{"2":{"34":1,"36":1,"37":1,"39":1,"526":1,"590":1,"592":1}}],["offloads",{"2":{"579":1}}],["offline",{"2":{"9":1,"281":1}}],["off",{"2":{"219":1,"275":1,"773":1}}],["offchain",{"2":{"81":2,"93":1,"226":1,"229":1,"630":1}}],["offense",{"2":{"281":1}}],["offensive",{"2":{"8":1}}],["offers",{"2":{"51":1,"85":1,"221":1,"226":1,"251":1}}],["offered",{"2":{"36":1}}],["offering",{"2":{"35":1,"107":1}}],["offer",{"2":{"34":4,"35":1,"37":1,"38":2,"226":1}}],["officially",{"2":{"9":1}}],["official",{"2":{"0":1,"9":2,"91":1}}],["of",{"0":{"5":1,"18":1,"46":1,"74":1,"137":1,"144":1,"172":1,"173":1,"174":1,"175":2,"176":1,"177":1,"179":1,"180":1,"181":1,"182":1,"187":1,"188":1,"189":1,"222":1,"225":1,"232":1,"238":1,"288":1,"297":1,"327":1,"415":1,"459":1,"581":1,"582":1,"633":1,"639":1,"641":1,"645":1,"651":1,"666":1,"676":1,"686":1,"688":1,"691":1,"751":1,"757":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"138":1,"139":1,"173":1,"174":1,"175":1,"176":1,"177":1,"180":1,"181":1,"182":1,"188":1,"189":1,"233":1,"234":1,"235":1,"236":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"582":1,"583":1,"584":1,"652":1,"687":1,"688":1,"689":2,"690":2,"691":2,"692":2,"693":2,"694":2,"695":2,"696":2},"2":{"0":1,"2":1,"6":2,"7":6,"8":2,"9":2,"10":3,"11":2,"12":3,"13":3,"14":4,"15":6,"16":4,"18":3,"20":1,"21":3,"22":5,"23":7,"24":1,"25":2,"26":3,"27":1,"30":2,"31":1,"32":1,"33":3,"34":3,"35":1,"36":8,"37":5,"38":6,"39":1,"40":2,"41":5,"42":4,"43":1,"44":1,"46":5,"47":2,"49":1,"50":2,"53":2,"54":1,"55":1,"56":1,"58":7,"63":1,"65":2,"68":1,"69":2,"70":1,"74":3,"76":1,"77":3,"79":1,"80":1,"81":3,"84":2,"86":6,"87":3,"89":2,"90":1,"91":3,"92":1,"93":5,"94":3,"96":1,"104":1,"107":1,"108":2,"109":8,"110":2,"111":2,"112":2,"119":3,"122":5,"125":28,"126":10,"127":3,"128":2,"130":8,"134":2,"136":1,"137":4,"139":11,"140":2,"141":2,"142":1,"145":3,"149":1,"150":3,"151":4,"152":3,"153":2,"154":8,"155":1,"156":12,"157":2,"158":1,"159":10,"160":10,"161":4,"162":2,"163":10,"164":1,"165":1,"166":1,"168":2,"169":4,"170":2,"171":1,"172":9,"173":1,"174":10,"175":20,"176":2,"178":2,"179":6,"180":1,"182":2,"183":10,"185":2,"186":1,"187":9,"188":1,"191":4,"194":4,"196":1,"197":3,"199":6,"201":1,"202":12,"203":2,"204":13,"205":2,"206":2,"208":3,"210":6,"211":8,"214":2,"215":2,"216":1,"217":1,"218":1,"219":1,"221":6,"222":1,"224":2,"225":1,"226":3,"227":5,"228":1,"233":1,"236":1,"238":3,"244":3,"245":1,"246":7,"250":2,"255":1,"259":2,"266":3,"267":1,"273":1,"274":4,"275":2,"276":1,"277":1,"278":1,"279":2,"281":7,"282":1,"287":2,"288":1,"289":1,"294":1,"297":3,"298":2,"299":4,"302":2,"309":1,"311":2,"320":1,"321":2,"322":3,"324":1,"328":3,"329":1,"336":1,"337":1,"338":3,"341":2,"342":1,"344":1,"349":2,"352":1,"353":1,"355":1,"361":2,"365":1,"367":1,"368":3,"369":1,"370":2,"371":1,"381":4,"388":1,"389":2,"390":1,"396":1,"399":2,"400":3,"405":1,"408":2,"422":3,"423":7,"427":2,"428":2,"430":1,"446":3,"450":2,"451":2,"453":1,"455":2,"457":1,"459":1,"464":1,"465":2,"468":7,"480":3,"484":1,"485":2,"486":4,"495":2,"496":1,"501":5,"507":1,"512":3,"525":1,"526":2,"527":3,"528":2,"530":2,"532":1,"533":1,"538":1,"546":2,"549":2,"558":2,"561":4,"563":2,"564":3,"565":3,"568":1,"574":1,"579":1,"580":6,"582":7,"583":6,"584":3,"585":1,"586":2,"587":1,"589":2,"590":5,"591":10,"592":8,"593":3,"594":3,"599":4,"601":1,"606":1,"607":1,"609":2,"610":1,"611":1,"616":2,"617":1,"619":2,"622":5,"625":1,"627":1,"629":2,"630":4,"632":3,"633":3,"634":1,"635":1,"636":2,"638":2,"639":4,"640":2,"641":1,"642":2,"643":5,"644":5,"645":8,"646":7,"648":7,"649":11,"650":4,"651":15,"652":4,"653":1,"657":1,"658":1,"662":1,"666":1,"670":3,"671":2,"672":3,"673":6,"674":4,"676":5,"677":3,"679":2,"680":1,"681":4,"682":6,"683":2,"687":1,"689":1,"690":2,"691":3,"692":2,"697":1,"699":2,"700":1,"705":1,"706":1,"709":1,"710":3,"712":5,"713":2,"714":1,"717":1,"720":1,"722":2,"724":3,"726":1,"733":1,"737":1,"739":1,"740":1,"741":2,"742":2,"744":1,"745":8,"747":3,"748":3,"750":1,"751":4,"754":2,"757":3,"760":1,"765":2,"767":1,"775":2,"778":1,"779":3,"780":3,"781":2,"782":1,"785":1,"786":1}}],["m",{"2":{"499":1,"545":2,"684":1}}],["mzonder",{"2":{"490":1}}],["mb",{"2":{"460":1,"535":1,"734":1}}],["my",{"2":{"391":5,"392":8,"393":8,"466":6,"517":1,"544":1,"559":2,"707":4,"767":2}}],["myrollup",{"2":{"118":2}}],["mnemonic",{"2":{"291":3,"308":1,"430":4,"559":4,"702":2,"767":2}}],["mv",{"2":{"215":2}}],["mkdir",{"2":{"214":2,"215":2,"372":6,"391":2}}],["md013",{"2":{"754":2}}],["md",{"2":{"160":2}}],["mtgbzqhrqol61okkzmhrfyq5bk6goklgwrvparpyxve=",{"2":{"147":2}}],["msgsend",{"2":{"412":2}}],["msgsubmitproposal",{"2":{"266":2}}],["msgcreatevestingaccount",{"2":{"294":2}}],["msgpayforblobs",{"2":{"147":2,"167":1,"412":2,"587":1,"592":2,"732":2}}],["msg",{"2":{"147":2,"266":1,"429":4,"651":1,"774":4}}],["mut",{"2":{"780":2}}],["mutual",{"0":{"353":1}}],["mutually",{"2":{"36":1}}],["multiaddress",{"2":{"607":1}}],["multiaddresses",{"2":{"352":1}}],["multiaccounts",{"0":{"516":1},"1":{"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1}}],["multi",{"2":{"280":1}}],["multiplies",{"2":{"592":1}}],["multiplier",{"2":{"429":4}}],["multiple",{"0":{"594":1},"2":{"37":1,"72":1,"105":1,"122":1,"139":1,"150":1,"151":3,"154":8,"156":4,"172":2,"275":1,"328":1,"339":1,"498":1,"583":1,"632":1,"635":1,"640":1,"643":1,"646":1,"649":2,"651":1,"733":1}}],["multiproof",{"2":{"156":2}}],["multisign",{"2":{"279":2}}],["multisig",{"0":{"278":1},"1":{"279":1,"280":1},"2":{"86":1,"235":1,"278":3,"279":18,"280":3}}],["mustnewv0",{"2":{"599":2}}],["must",{"2":{"86":2,"91":1,"246":2,"266":1,"334":4,"366":1,"371":1,"387":1,"399":1,"422":1,"423":2,"443":1,"444":1,"445":1,"450":2,"465":1,"468":2,"485":1,"522":1,"544":2,"546":1,"590":1,"594":3,"622":1,"642":1,"644":1,"646":3,"649":2,"709":1,"778":1}}],["much",{"2":{"35":1,"91":1,"449":1,"580":1,"582":1,"583":1}}],["microtia",{"0":{"696":1},"2":{"696":1}}],["micro",{"2":{"695":1}}],["microphone",{"2":{"34":2}}],["microphones",{"2":{"30":1,"34":1}}],["mixhash",{"2":{"538":2}}],["milestone",{"2":{"501":1}}],["million",{"2":{"271":2}}],["mib",{"2":{"485":1,"588":3}}],["middleware",{"2":{"438":1}}],["mirrors",{"2":{"251":1}}],["migrate",{"0":{"247":1,"424":1,"469":1},"2":{"247":1,"260":4,"424":1,"469":1}}],["might",{"2":{"34":3,"171":1,"266":1,"337":1,"361":1,"367":1,"495":1,"552":1,"580":1,"645":1,"737":1,"740":1}}],["mint",{"2":{"717":1}}],["mintscan",{"2":{"498":1,"514":1,"786":1}}],["minor",{"2":{"717":1}}],["minority",{"2":{"266":1}}],["miner",{"2":{"538":2}}],["mined",{"2":{"93":4}}],["mins",{"2":{"211":1}}],["minns",{"2":{"156":2,"163":2}}],["minnamespace",{"2":{"156":4,"163":4}}],["min",{"2":{"156":4,"272":2,"365":1,"368":4,"429":4,"622":3}}],["minimized",{"2":{"642":1}}],["minimal",{"2":{"118":1,"180":1,"341":1,"454":1,"481":1,"717":1}}],["minimum",{"0":{"357":1},"2":{"23":1,"86":1,"93":4,"117":1,"156":2,"239":2,"357":1,"416":2,"460":2,"579":1,"590":1,"613":1,"633":1,"734":2}}],["minutes",{"2":{"37":1,"109":1,"211":1,"214":1,"215":1,"217":1,"371":1,"560":1}}],["minute",{"0":{"395":1},"2":{"35":1,"42":1,"281":1,"594":1}}],["mind",{"2":{"35":1,"361":1,"622":1,"700":2}}],["mindful",{"2":{"35":1}}],["mismatch",{"2":{"645":1}}],["misbehaviour",{"2":{"429":2}}],["misuse",{"2":{"91":1}}],["mission",{"2":{"18":1}}],["mistakes",{"2":{"7":1}}],["mock",{"2":{"542":1,"545":1}}],["mocharesturl",{"2":{"784":2}}],["mocharpcurl",{"2":{"784":2}}],["mochadocker",{"2":{"706":1}}],["mochamainnet",{"2":{"544":1}}],["mocha4",{"2":{"507":1,"508":1,"510":1}}],["mochachainid",{"2":{"325":1,"361":8,"372":2,"544":2,"559":8,"560":1,"561":2,"571":1,"616":2,"622":2,"743":3,"784":2}}],["mochacelestia",{"2":{"91":1,"244":1,"245":1,"246":1,"265":1,"318":1,"329":1,"335":1,"421":1,"423":1,"464":1,"465":1,"466":1,"468":1,"559":1,"567":1,"736":1,"737":2,"738":1}}],["mochaversions",{"2":{"311":2,"341":2,"390":2,"392":2,"393":2,"558":2,"561":2,"706":2}}],["mocha",{"0":{"91":1,"298":1,"301":1,"318":1,"331":1,"332":1,"501":1,"512":1,"545":1,"546":1,"554":1,"555":1,"685":1},"1":{"299":1,"300":1,"301":1,"302":1,"303":1,"502":1,"503":1,"504":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1,"514":1,"515":1},"2":{"23":3,"26":1,"27":1,"59":2,"60":2,"81":1,"82":2,"91":7,"97":1,"109":1,"136":2,"231":3,"244":2,"245":6,"246":1,"250":2,"265":5,"283":1,"289":1,"297":1,"298":2,"301":7,"303":4,"305":1,"309":1,"318":4,"325":2,"328":1,"329":7,"331":2,"332":2,"335":1,"338":1,"361":1,"371":2,"390":1,"402":1,"403":3,"405":2,"407":2,"412":5,"413":2,"421":1,"422":3,"423":1,"427":1,"429":9,"430":2,"432":1,"433":6,"434":6,"435":3,"464":1,"465":4,"466":3,"467":1,"468":1,"501":7,"507":6,"508":5,"509":6,"510":11,"511":16,"512":2,"513":1,"514":2,"515":2,"528":1,"532":2,"542":4,"544":2,"545":1,"554":4,"556":1,"557":1,"558":1,"559":4,"560":4,"561":6,"563":1,"565":1,"567":1,"609":1,"619":1,"622":1,"685":3,"700":3,"706":4,"707":8,"736":1,"737":5,"738":3,"784":6,"786":5}}],["mounted",{"2":{"707":1}}],["mounting",{"0":{"707":1},"2":{"391":1,"707":1}}],["mount",{"2":{"391":2,"392":1,"396":1,"544":1,"706":1,"707":1}}],["moment",{"2":{"180":1,"183":1,"321":1}}],["moved",{"2":{"450":1,"649":1}}],["move",{"2":{"77":2,"79":1,"89":1,"738":1}}],["moniker",{"2":{"622":3}}],["moniker=$moniker",{"2":{"272":2,"622":2}}],["moniker=validator",{"2":{"272":2}}],["monitors",{"2":{"282":1}}],["monitor",{"0":{"282":1},"2":{"275":4,"282":1,"321":1,"610":1,"611":1}}],["monitoring",{"0":{"610":1},"2":{"23":1,"26":1,"273":1,"277":1,"398":1}}],["monolithic",{"0":{"649":1},"2":{"53":1,"455":1,"580":2,"649":3,"716":1}}],["monthly",{"2":{"36":1,"48":1}}],["month",{"2":{"23":1,"25":1}}],["months",{"2":{"21":1,"22":6,"23":1,"25":1,"26":1,"166":1,"168":1}}],["more",{"0":{"131":1},"1":{"132":1,"133":1,"134":1},"2":{"20":1,"24":1,"34":1,"35":1,"36":1,"38":1,"73":1,"79":1,"81":3,"86":3,"87":1,"92":1,"94":1,"107":1,"110":1,"112":1,"125":2,"126":2,"127":2,"136":1,"137":2,"139":1,"142":1,"147":1,"152":1,"163":2,"168":1,"169":1,"174":1,"175":2,"182":1,"190":1,"194":1,"196":1,"199":2,"210":1,"212":1,"226":2,"227":1,"230":1,"233":1,"234":2,"235":1,"236":1,"245":1,"250":1,"251":1,"261":1,"266":1,"277":1,"281":3,"290":1,"291":1,"301":1,"303":2,"304":1,"311":1,"312":2,"326":1,"337":1,"341":1,"343":1,"371":1,"388":1,"404":1,"422":1,"455":1,"496":1,"497":1,"500":1,"515":1,"524":1,"530":1,"533":1,"546":1,"547":1,"556":1,"560":1,"564":1,"566":1,"567":1,"580":1,"583":3,"584":1,"587":1,"588":1,"592":1,"593":1,"597":1,"598":1,"600":1,"616":2,"629":1,"632":1,"633":1,"643":1,"644":3,"646":1,"648":3,"650":1,"652":1,"679":1,"692":1,"700":1,"706":1,"718":1,"727":1,"728":1,"729":1,"732":1,"733":2,"738":1,"740":2,"747":1,"748":1,"774":1,"776":1}}],["modifying",{"2":{"451":1}}],["modify",{"0":{"451":1},"2":{"337":1,"451":1,"546":1,"740":1}}],["modifications",{"2":{"717":1}}],["modifiable",{"2":{"266":1}}],["modified",{"2":{"238":1,"250":1,"646":1,"648":1,"722":1}}],["moduleencodingregisters",{"2":{"599":2}}],["modules",{"2":{"591":1,"717":2,"770":1}}],["module=consensus",{"2":{"383":2,"627":2}}],["module",{"0":{"401":1,"406":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":1,"412":1,"413":1},"2":{"266":4,"281":1,"402":1,"404":1,"413":1,"437":1,"438":1,"525":2,"593":1,"740":5,"743":2,"759":2,"784":2}}],["modularity",{"0":{"53":1},"2":{"42":1,"53":1}}],["modular",{"0":{"29":1,"42":1,"43":1,"51":1,"56":1,"220":1,"580":1,"581":1,"649":1},"1":{"30":1,"31":1,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1,"52":1,"53":1,"54":1,"55":1,"56":1,"57":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1,"582":1,"583":1,"584":1},"2":{"18":1,"29":2,"33":1,"34":1,"35":2,"36":3,"37":4,"39":1,"40":1,"41":2,"42":2,"43":2,"44":2,"47":3,"48":1,"50":2,"51":2,"53":4,"56":3,"57":1,"58":9,"227":1,"454":1,"498":1,"574":2,"580":4,"582":2,"583":2,"584":1,"629":1,"649":3,"650":2,"689":1,"690":1,"716":2,"775":2}}],["mod",{"2":{"140":3,"287":2,"383":14,"427":1,"627":14,"770":2}}],["model",{"2":{"592":1,"692":1,"774":2}}],["modern",{"2":{"510":1}}],["moderation",{"2":{"8":1}}],["mode=",{"2":{"279":2}}],["mode",{"2":{"76":2,"211":2,"279":4,"303":4,"369":1,"412":2,"429":12,"690":1}}],["mozilla",{"2":{"16":1}}],["mostly",{"2":{"422":1}}],["most",{"2":{"0":1,"37":1,"42":5,"44":1,"90":1,"199":1,"349":1,"370":1,"388":1,"459":1,"631":1,"639":1,"708":1,"720":1,"777":1}}],["mesa",{"2":{"490":1,"491":1,"507":1,"508":1,"510":1}}],["messages",{"2":{"30":1,"32":1,"190":1,"266":2,"294":2,"412":2,"527":1,"717":1,"765":1,"774":2}}],["message",{"2":{"2":1,"41":3,"109":1,"112":1,"147":2,"304":1,"309":1,"592":1,"651":2,"747":1,"774":4,"775":2,"776":1}}],["me",{"2":{"378":2,"452":2,"508":1,"509":1,"510":1}}],["met",{"2":{"590":1}}],["metric",{"2":{"316":1}}],["metricscurl",{"2":{"274":1}}],["metrics",{"0":{"273":1,"315":1,"316":1,"321":1},"1":{"274":1,"275":1,"276":1,"277":1,"316":1,"317":2,"318":2,"319":2,"320":2,"321":1},"2":{"273":3,"274":8,"275":3,"276":2,"315":2,"316":12,"317":6,"318":6,"319":6,"320":15,"321":2,"428":1}}],["meta",{"2":{"528":1}}],["metadata",{"2":{"160":2,"459":1,"571":1,"583":1,"652":1}}],["metamask",{"2":{"82":1}}],["methods",{"2":{"527":1,"600":1,"674":1,"709":2,"714":1,"740":1,"778":2,"782":1}}],["method",{"2":{"120":1,"122":2,"153":2,"157":1,"166":1,"174":1,"210":1,"233":1,"455":1,"474":1,"540":2,"674":3,"710":2,"711":2,"712":2,"713":2,"721":1,"740":5,"743":2,"759":3,"760":1,"762":2,"779":2,"780":2,"781":2,"784":2}}],["mechanisms",{"2":{"87":1,"112":1,"130":1,"591":1,"592":1}}],["mechanism",{"0":{"112":1,"225":1},"2":{"87":1,"108":2,"112":4,"164":1,"199":1,"227":1,"277":1,"281":1,"370":1,"400":2,"527":1,"530":1,"631":1,"632":1,"642":1,"674":1,"676":1,"683":1}}],["measured",{"2":{"86":1}}],["meaningful",{"2":{"722":1}}],["meaning",{"2":{"168":2,"238":1,"372":1,"722":1}}],["mean",{"2":{"126":2}}],["meant",{"2":{"64":1,"487":1,"505":1,"728":1}}],["means",{"2":{"21":1,"139":1,"199":1,"205":1,"338":1,"377":2,"387":1,"388":1,"525":1,"560":1,"564":1,"583":2,"588":1,"590":1,"594":1,"644":2,"649":2,"653":1,"671":1,"673":1,"717":1,"736":1}}],["menu",{"0":{"348":1},"2":{"76":1,"301":1,"311":1,"312":1,"542":1,"558":1,"759":2,"786":1}}],["mentioned",{"2":{"104":1,"507":1}}],["mention",{"2":{"38":2}}],["mempool",{"0":{"589":1},"1":{"590":1,"591":1,"592":1,"593":1,"594":1},"2":{"400":1,"588":1,"589":2,"590":2,"594":2,"599":2,"671":1}}],["memo",{"2":{"294":2,"429":4}}],["memory",{"2":{"127":1,"163":2,"239":1,"276":1,"357":1,"416":1,"460":1,"535":1,"536":1,"613":1,"734":1}}],["memorable",{"2":{"58":1,"86":1}}],["member",{"2":{"41":1}}],["members",{"0":{"42":1},"2":{"6":1,"22":1,"30":1,"39":3,"41":2,"42":2,"225":1,"267":1,"594":1,"681":1}}],["merge",{"2":{"322":1,"334":1}}],["merkelized",{"2":{"670":1}}],["merkelizes",{"2":{"227":1}}],["merkleized",{"2":{"119":1,"139":1}}],["merkle",{"0":{"194":1,"195":1,"196":1,"646":1},"1":{"195":1,"196":1},"2":{"110":1,"119":4,"120":1,"122":1,"127":1,"139":3,"141":2,"144":4,"145":3,"151":1,"154":2,"156":4,"159":4,"160":4,"163":8,"168":6,"174":2,"175":5,"188":1,"190":1,"196":1,"225":1,"227":2,"642":1,"643":6,"644":1,"645":2,"646":2,"648":2,"651":4,"652":3,"733":1}}],["merchandise",{"2":{"57":2}}],["merely",{"2":{"26":1}}],["mev",{"2":{"42":1}}],["meetups",{"2":{"32":1,"34":4,"36":5,"37":1,"38":1,"39":1,"40":4,"41":6,"42":2,"43":1,"51":3,"57":2,"58":1}}],["meetup",{"0":{"29":1,"30":1,"31":1,"32":1,"41":1,"42":1,"43":1,"51":1,"56":1},"1":{"30":1,"31":1,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1,"52":1,"53":1,"54":1,"55":1,"56":1,"57":1},"2":{"29":2,"30":2,"32":1,"33":3,"34":4,"35":2,"36":7,"37":9,"38":5,"39":8,"40":4,"41":10,"42":5,"43":1,"44":4,"46":1,"47":2,"48":1,"50":4,"56":2,"57":1,"58":6}}],["meet",{"2":{"21":1}}],["media",{"2":{"3":1,"9":1,"13":1,"30":1,"32":1,"39":4,"40":1}}],["magnitude",{"2":{"722":1}}],["macos",{"2":{"545":2}}],["mac",{"2":{"389":1,"391":1,"399":2}}],["machines",{"2":{"275":1,"377":1,"649":1}}],["machine",{"2":{"2":1,"82":1,"211":2,"214":1,"215":1,"217":1,"238":1,"240":1,"244":1,"251":1,"275":1,"289":2,"309":1,"313":1,"324":1,"326":1,"358":1,"388":1,"390":1,"391":3,"417":1,"422":1,"437":1,"453":1,"462":1,"465":1,"590":1,"592":1,"614":1,"619":1,"648":3,"649":1,"651":2,"705":1,"706":1,"736":1,"737":1,"767":1}}],["majority",{"2":{"645":1}}],["major",{"2":{"175":1,"648":1}}],["master",{"2":{"160":2,"361":10,"786":1}}],["malicious",{"2":{"130":1,"208":2,"281":1,"645":1}}],["mapping",{"2":{"110":1,"156":2,"159":1,"322":2,"586":1}}],["matters",{"2":{"174":1}}],["math",{"2":{"144":2,"163":2}}],["matching",{"2":{"586":1}}],["match",{"2":{"125":1,"140":1,"780":4}}],["matches",{"2":{"91":1,"199":1,"707":1}}],["matrix",{"0":{"96":1},"2":{"91":1,"643":4,"645":1,"651":5,"652":1}}],["materials",{"0":{"50":1},"2":{"0":1,"30":2,"31":1,"51":1}}],["made",{"2":{"81":1,"111":1,"227":1,"289":1,"297":1,"328":1,"584":1,"633":1,"648":1,"651":2,"652":1,"670":2,"674":1,"723":1}}],["manual",{"0":{"475":1},"1":{"476":1,"477":1,"478":1,"479":1},"2":{"525":1,"674":1}}],["manually",{"2":{"328":1,"352":1,"355":1,"361":2,"594":1,"599":2,"610":1,"674":1,"740":1}}],["managing",{"2":{"404":1}}],["manager",{"2":{"275":1}}],["management",{"0":{"262":1,"265":1,"522":1,"568":1,"718":1},"1":{"263":1,"523":1,"524":1},"2":{"388":1,"568":2,"571":1,"718":1}}],["manages",{"2":{"202":1}}],["managed",{"2":{"168":1,"455":1,"673":1}}],["manage",{"0":{"659":1,"663":1,"668":1},"2":{"30":1,"36":1,"260":2,"322":2,"381":1,"542":1,"568":1,"599":2,"698":1}}],["manifest",{"2":{"322":1,"571":1}}],["many",{"0":{"337":1},"2":{"39":1,"60":1,"125":1,"134":1,"275":1,"337":2,"398":1,"533":1,"583":1,"591":1,"593":1,"649":1,"677":1,"680":1,"718":1}}],["manner",{"2":{"24":1,"396":1}}],["maximize",{"2":{"584":1}}],["maximum",{"0":{"485":1,"588":1},"2":{"156":2,"274":2,"485":8,"588":2,"592":1,"740":1}}],["maxvalidators",{"2":{"266":4}}],["maxns",{"2":{"156":2,"163":2}}],["maxnamespace",{"2":{"156":4,"163":4}}],["max",{"2":{"26":1,"156":4,"233":1,"266":3,"272":4,"274":2,"429":20,"484":1,"622":4}}],["markdownlint",{"2":{"754":2}}],["marking",{"2":{"673":1}}],["market",{"0":{"589":1,"671":1},"1":{"590":1,"591":1,"592":1,"593":1,"594":1}}],["marketing",{"0":{"39":1},"2":{"39":1}}],["marks",{"2":{"107":1,"480":1,"549":1}}],["mark",{"2":{"26":1}}],["may",{"0":{"640":1},"2":{"10":1,"12":1,"13":1,"14":1,"22":1,"23":1,"34":2,"38":2,"39":3,"85":1,"87":1,"91":1,"164":1,"302":1,"313":1,"326":1,"337":1,"371":1,"380":1,"386":1,"391":1,"481":1,"549":1,"566":1,"567":1,"591":1,"609":1,"610":1,"640":1,"652":2,"673":1,"674":1,"680":1,"682":1,"690":1,"771":1}}],["mail",{"2":{"9":1}}],["maintenance",{"2":{"681":1}}],["maintained",{"2":{"228":1}}],["maintaining",{"2":{"46":1,"54":1,"86":1,"221":1,"594":1}}],["maintains",{"2":{"22":1,"343":1}}],["maintain",{"2":{"18":1,"22":1,"23":2,"27":1,"32":1,"36":1,"37":1,"39":1,"235":1,"328":1}}],["mainly",{"2":{"215":2}}],["mainnetresturl",{"2":{"784":2}}],["mainnetrpcurl",{"2":{"784":2}}],["mainnetchainid",{"2":{"325":2,"361":8,"372":2,"784":2}}],["mainnetversions",{"2":{"311":2,"341":2,"343":2,"390":2,"392":2,"393":2}}],["mainnet",{"0":{"317":1,"331":1,"480":1,"549":1,"550":1,"684":1},"1":{"481":1,"482":1,"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1,"490":1,"491":1,"492":1,"493":1,"494":1,"495":1,"496":1,"497":1,"498":1,"499":1,"500":1,"550":1},"2":{"23":4,"24":1,"26":4,"27":1,"69":2,"112":1,"136":1,"228":2,"231":4,"244":1,"245":1,"246":1,"311":1,"317":1,"324":1,"325":3,"328":1,"331":3,"338":1,"341":1,"343":2,"361":5,"369":1,"371":2,"372":1,"373":1,"390":3,"392":1,"393":1,"399":1,"400":1,"421":1,"422":2,"423":1,"464":1,"465":2,"466":1,"468":1,"480":3,"481":2,"486":2,"489":2,"490":2,"491":2,"492":1,"495":2,"498":3,"499":3,"500":2,"512":2,"528":1,"532":2,"549":2,"556":1,"588":1,"609":1,"619":1,"622":1,"684":1,"700":3,"706":1,"707":1,"736":1,"737":3,"738":2,"762":1,"784":5}}],["main",{"0":{"772":1},"2":{"2":1,"94":1,"136":4,"143":4,"144":4,"163":4,"214":16,"215":2,"280":1,"371":4,"648":1,"740":1,"771":6,"772":5,"773":5,"775":9}}],["making",{"2":{"2":1,"41":1,"42":1,"93":1,"227":1,"251":1,"331":1,"332":1,"377":1,"378":1,"379":1,"380":1,"381":1,"649":1,"650":1,"741":1}}],["makeconfig",{"2":{"599":2}}],["makes",{"0":{"633":1},"2":{"187":1,"250":1,"589":1}}],["make",{"2":{"0":1,"2":1,"6":1,"44":1,"90":1,"91":1,"109":1,"116":1,"117":1,"121":1,"140":3,"144":2,"156":5,"158":2,"159":4,"160":2,"162":2,"163":12,"168":1,"183":1,"202":3,"204":1,"211":3,"214":1,"215":2,"227":1,"273":1,"274":2,"283":1,"294":1,"305":1,"313":3,"326":3,"347":1,"371":1,"377":1,"398":4,"536":1,"557":1,"559":2,"582":1,"583":2,"604":1,"643":1,"651":1,"674":1,"699":5,"700":1,"767":1}}],["css",{"2":{"784":2}}],["cycle",{"2":{"670":1}}],["ccv",{"2":{"429":4}}],["c4ibesqxgzc5zxj3vtugbiadqamienbyjkegcac=",{"2":{"408":2}}],["c",{"2":{"312":2,"329":1,"343":4,"372":6,"398":2,"399":8,"426":1,"474":2,"558":2}}],["cgo",{"2":{"214":2,"341":1}}],["cpu",{"2":{"239":1,"357":1,"416":1,"460":1,"535":1,"536":1,"613":1,"734":1}}],["cp",{"2":{"203":2,"210":2,"211":2,"215":2}}],["cd",{"2":{"202":2,"203":2,"208":2,"211":2,"214":4,"215":2,"311":2,"341":3,"372":3,"399":4,"586":2,"699":2,"770":2}}],["cips",{"2":{"528":3,"532":1}}],["cip",{"2":{"484":2,"527":1,"528":1,"530":7,"532":2,"673":1}}],["circulation",{"2":{"682":1}}],["circulating",{"2":{"682":4}}],["circuits",{"0":{"215":1},"2":{"190":1,"203":2,"204":3,"211":2,"213":1,"214":2,"215":5,"233":3}}],["circuit",{"0":{"191":1},"2":{"169":1,"187":1,"188":1,"191":3,"193":1,"194":4,"196":1,"202":1,"204":1,"210":3,"211":2,"214":13,"215":23,"234":1}}],["ciruit",{"2":{"203":1}}],["city",{"2":{"36":1,"38":1,"39":1,"64":1,"487":1,"505":1}}],["cmd",{"2":{"148":2}}],["cqebcp4bciavy2vszxn0aweuymxvyi52ms5nc2dqyxlgb3jcbg9icxj6ci9jzwxlc3rpytf2ogvzy3u3znu5bhy4nzlrenu1dwvndwv1cnrxnxn3nmhzbtnuzridaaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"147":2}}],["ctx",{"2":{"143":2,"144":10,"153":2,"161":4,"162":6,"163":4,"598":8,"710":8,"711":8,"712":8,"713":8,"772":2,"773":9,"774":2,"775":8}}],["cfg",{"2":{"90":1,"91":2,"104":1}}],["chunk",{"2":{"565":1}}],["cherry",{"2":{"277":1}}],["cheap",{"2":{"214":1}}],["cheaper",{"2":{"212":1}}],["checking",{"0":{"409":1,"413":1,"652":1},"2":{"343":1,"646":1,"716":1}}],["checkout",{"2":{"163":1,"215":2,"311":6,"341":6,"371":1}}],["checksum",{"2":{"343":1}}],["checks",{"2":{"118":2,"122":3,"772":1}}],["check",{"0":{"288":1,"750":1,"751":1},"2":{"31":1,"79":1,"112":1,"118":1,"121":1,"122":1,"126":1,"130":2,"139":1,"142":1,"147":1,"152":1,"160":1,"163":5,"174":2,"194":1,"203":1,"212":1,"215":1,"225":1,"235":2,"274":3,"288":1,"294":1,"295":1,"296":1,"297":1,"308":1,"309":1,"311":2,"320":1,"321":1,"334":1,"341":2,"408":1,"409":1,"427":1,"431":4,"471":1,"495":1,"538":1,"558":2,"561":1,"563":1,"569":1,"570":1,"572":1,"573":1,"579":1,"599":4,"604":3,"608":2,"616":1,"632":1,"642":1,"646":1,"706":1,"707":1,"729":1,"741":1,"763":1,"767":1,"773":1}}],["checklist",{"2":{"29":1}}],["choices",{"2":{"774":2}}],["choice",{"2":{"622":2,"657":1,"662":1}}],["chown",{"2":{"391":2}}],["choosing",{"2":{"208":1,"446":1}}],["chooses",{"2":{"643":1}}],["choose",{"0":{"79":1,"576":1,"666":1},"2":{"77":1,"79":1,"86":1,"166":1,"203":1,"275":1,"294":1,"302":1,"312":2,"320":1,"329":1,"343":1,"380":1,"445":1,"662":1,"666":1,"674":1}}],["chose",{"2":{"60":1}}],["chosen",{"2":{"37":1,"87":1,"342":1,"380":2}}],["chatmessageroleuser",{"2":{"774":2}}],["chatcompletion",{"2":{"774":2}}],["chatcompletionmessage",{"2":{"774":2}}],["chatcompletionrequest",{"2":{"774":2}}],["chatgpt",{"0":{"774":1},"2":{"771":2,"772":2,"773":3,"775":1}}],["chart",{"2":{"681":1}}],["charge",{"2":{"676":1}}],["charged",{"2":{"592":1}}],["characters",{"2":{"26":1}}],["characteristics",{"2":{"6":1}}],["chainname",{"2":{"784":12}}],["chain=celestia",{"2":{"684":1}}],["chainode",{"2":{"489":1,"490":1,"491":1,"492":1}}],["chainid",{"2":{"202":2,"434":8,"784":16}}],["chainlist",{"2":{"86":1}}],["chain",{"0":{"76":1,"86":1,"87":1,"88":2,"92":1,"93":1,"125":1,"325":1,"449":1,"582":1,"785":1,"786":1},"2":{"68":1,"76":2,"79":2,"81":1,"84":1,"85":1,"86":26,"87":12,"88":7,"90":2,"91":3,"92":1,"93":56,"94":2,"107":1,"109":6,"110":1,"112":1,"120":1,"125":3,"126":1,"136":1,"171":1,"172":1,"180":1,"200":1,"201":2,"202":12,"204":1,"210":2,"211":5,"214":1,"215":1,"218":2,"219":2,"221":1,"227":2,"234":1,"245":1,"265":6,"266":12,"268":4,"269":8,"270":4,"272":6,"277":1,"279":12,"294":6,"301":3,"302":1,"303":7,"314":2,"325":3,"338":2,"361":11,"371":1,"402":1,"412":2,"422":1,"427":3,"428":1,"429":4,"430":6,"433":12,"434":22,"437":1,"438":1,"445":4,"449":3,"479":2,"495":1,"496":1,"507":1,"532":1,"542":1,"545":1,"546":8,"559":1,"560":1,"561":2,"580":1,"585":1,"586":2,"616":2,"622":2,"627":1,"629":2,"630":1,"650":1,"672":1,"690":1,"700":1,"706":1,"717":1,"719":1,"721":1,"722":1,"738":1,"754":2,"784":2,"785":5,"786":4}}],["chains",{"0":{"432":1},"2":{"26":1,"64":1,"76":1,"81":1,"82":2,"86":3,"93":1,"97":2,"103":1,"107":1,"130":1,"165":1,"202":1,"228":1,"231":1,"427":1,"428":1,"429":30,"430":1,"431":2,"432":1,"435":4,"455":1,"487":1,"505":1,"546":1,"676":1,"680":1,"684":1,"685":1,"722":1,"786":1}}],["challengemanager",{"2":{"100":1,"101":1}}],["challenge",{"2":{"86":1,"87":1,"111":1,"776":1}}],["challenges",{"2":{"42":1}}],["challenging",{"2":{"38":1}}],["changing",{"0":{"327":1},"1":{"328":1,"329":1,"330":1,"331":1,"332":1,"333":1},"2":{"368":1,"584":1}}],["changeable",{"2":{"679":2}}],["change",{"0":{"303":1},"2":{"202":2,"211":2,"266":6,"272":2,"275":1,"286":1,"311":1,"329":1,"341":1,"353":1,"361":1,"518":1,"532":1,"544":1,"588":1,"591":1,"622":2,"673":1,"679":1,"717":1,"719":1,"722":1}}],["changed",{"2":{"93":2,"544":1,"740":1}}],["changes",{"2":{"2":4,"18":1,"37":1,"39":1,"60":2,"96":2,"238":1,"266":4,"379":1,"380":1,"381":1,"422":1,"481":1,"528":1,"530":1,"552":1,"594":1,"610":1,"648":2}}],["chan",{"2":{"162":2,"711":2,"712":2}}],["channelid",{"2":{"434":4}}],["channel",{"2":{"34":1,"47":2,"48":1,"70":1,"73":1,"91":4,"309":1,"429":4,"434":13,"435":4,"500":1,"512":1,"515":1,"556":1,"563":1,"564":1,"711":3,"712":3}}],["channelside",{"2":{"434":4}}],["channels",{"0":{"435":1},"2":{"13":1,"30":1,"40":2,"42":1,"429":2,"432":1,"435":2,"738":1}}],["chances",{"2":{"38":1}}],["chance",{"2":{"26":1,"371":1}}],["cumulo",{"2":{"489":2,"490":2,"491":2,"492":2,"508":2,"509":2,"510":2}}],["culmination",{"2":{"480":1,"549":1}}],["custody",{"0":{"718":1}}],["custodians",{"2":{"715":1}}],["custodian",{"2":{"23":1}}],["custom=robusta",{"2":{"744":2}}],["custom=private",{"2":{"744":2}}],["custom=test",{"2":{"477":2,"478":2}}],["custom=",{"2":{"314":4}}],["customtargetblock",{"2":{"233":3}}],["customizations",{"2":{"584":1}}],["customization",{"2":{"584":1}}],["customizability",{"0":{"584":1},"2":{"584":1}}],["customizing",{"2":{"86":1}}],["customized",{"2":{"584":1}}],["customize",{"2":{"41":2,"86":1,"700":1}}],["custom",{"0":{"76":1,"207":1,"246":1,"314":1,"333":1,"423":1,"468":1,"744":1,"785":1,"786":1},"1":{"424":1,"469":1},"2":{"41":3,"76":1,"82":1,"84":1,"86":1,"91":1,"205":1,"206":3,"207":3,"233":1,"246":9,"314":3,"328":1,"333":2,"334":2,"338":1,"390":1,"423":9,"468":9,"477":4,"478":7,"479":6,"584":1,"586":1,"700":1,"743":3,"744":9,"783":1,"785":1,"786":3}}],["currencies",{"2":{"784":2}}],["currency",{"2":{"690":1,"786":1}}],["current",{"2":{"37":1,"97":1,"215":1,"227":2,"262":2,"343":2,"485":1,"591":1,"638":1,"699":2}}],["currently",{"2":{"22":1,"42":1,"149":1,"166":1,"215":1,"231":1,"336":1,"400":1,"408":1,"427":1,"428":1,"455":1,"551":1,"576":1,"590":1,"595":1,"684":1,"685":1,"719":1,"720":1,"728":1}}],["curious",{"2":{"558":1}}],["curl",{"0":{"746":1,"762":1},"2":{"312":2,"343":4,"361":10,"372":6,"398":6,"452":2,"474":2,"477":1,"558":2,"560":4,"746":1,"762":1}}],["curated",{"2":{"37":1,"58":1}}],["cups",{"2":{"35":1}}],["ce1e5714",{"2":{"775":2,"776":1}}],["certhash",{"2":{"478":10}}],["certainty",{"2":{"110":1,"111":1}}],["certain",{"2":{"21":1,"174":1,"208":1,"266":1,"640":1}}],["cel",{"0":{"568":1,"698":1,"703":1,"704":1},"1":{"699":1,"700":1,"701":1,"702":1,"703":1,"705":1,"706":1,"707":1},"2":{"245":3,"328":1,"329":3,"341":3,"388":1,"404":1,"422":3,"466":5,"522":1,"523":2,"524":2,"568":4,"697":2,"698":1,"699":5,"700":7,"701":6,"702":6,"703":2,"706":3,"707":3,"738":4}}],["cele",{"2":{"706":2,"707":2}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hd",{"2":{"616":1}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hdenter",{"2":{"616":1}}],["celesvaloper",{"2":{"616":2}}],["celes",{"2":{"466":6,"517":1,"544":1,"559":2,"707":4,"767":2}}],["celestiatestnet",{"2":{"786":1}}],["celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p",{"2":{"616":2}}],["celestiavaloper",{"2":{"616":1}}],["celestiacelestia",{"2":{"465":1}}],["celestiacommunity",{"2":{"430":1}}],["celestialightnodeclient",{"2":{"126":6,"128":2,"130":2}}],["celestiaheight",{"2":{"125":4}}],["celestiaorg",{"2":{"89":2,"112":1,"117":2,"140":6,"144":2,"150":4,"156":2,"157":2,"160":2,"163":4,"250":1,"311":2,"341":2,"361":9,"371":4,"383":14,"390":6,"392":6,"393":6,"456":1,"537":1,"593":2,"598":6,"599":12,"610":1,"627":14,"699":2,"706":2,"709":2,"710":6,"770":2,"771":6}}],["celestiascan",{"2":{"72":1,"514":1}}],["celestia1hn25k7gkfq0fy5a0vmphs6mjma2de74gsn36ef",{"2":{"767":2}}],["celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86",{"2":{"764":2}}],["celestia1znk24rh52pgcd9z5x2x42jztjh6raaaphuvrt3",{"2":{"753":2}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umard",{"2":{"751":1}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umardcelestia",{"2":{"751":1}}],["celestia10d07y265gmmuvt4z0w9aw880jnsr700jtgz4v7",{"2":{"266":2}}],["celestia1wkhyhr7ngf0ayqlpnsnxg4d72hfs5453dvunm9",{"2":{"707":2}}],["celestia1lgvzg4ek9v499pl5vvsvqpquhwfg0jznpwd92m",{"2":{"559":2}}],["celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3",{"2":{"479":2}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxcelestia",{"2":{"309":1}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"309":2}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx$request",{"2":{"309":1}}],["celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"292":2,"294":2,"296":2}}],["celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"291":2,"292":2,"294":2,"295":2}}],["celestia17adsjkuecgjheugrdrwdqv9uh3qkrfmj9xzawx",{"2":{"267":2}}],["celestia1czpgn3hdh9sodm06d5qk23xzgpq2uyc8ggdqgw",{"2":{"265":2}}],["celestia1vdjkcetnw35kzvtk8pjhxcm4xan82wtvwcurwwtt0f6n2at9va6k2atjw3cn2umhxe58xmfndejs40vqs9",{"2":{"147":2}}],["celestia1",{"2":{"70":1,"467":1,"512":1,"738":1}}],["celestia",{"0":{"0":1,"5":1,"17":1,"43":1,"46":1,"52":1,"54":1,"94":1,"106":1,"133":1,"138":1,"144":1,"199":1,"237":1,"242":1,"243":1,"250":1,"281":1,"283":1,"306":1,"310":1,"315":1,"322":1,"340":1,"360":1,"405":1,"406":1,"408":1,"412":1,"414":1,"419":1,"439":1,"442":1,"443":1,"458":1,"463":1,"472":1,"526":1,"533":1,"534":1,"540":1,"542":1,"548":1,"575":1,"587":1,"596":1,"597":1,"598":1,"600":1,"604":1,"606":1,"607":1,"608":1,"612":1,"617":1,"618":1,"631":1,"633":1,"639":1,"642":1,"651":1,"657":1,"666":1,"673":1,"676":1,"683":1,"697":1,"715":1,"717":1,"730":1,"736":1,"767":1,"783":1,"784":1},"1":{"1":1,"2":1,"3":1,"4":1,"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":2,"244":2,"245":2,"246":2,"247":2,"248":2,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"311":1,"312":1,"313":1,"316":1,"317":1,"318":1,"319":1,"320":1,"321":1,"341":1,"342":1,"343":1,"344":1,"345":1,"406":1,"407":1,"413":1,"415":1,"416":1,"417":1,"418":1,"419":1,"420":2,"421":2,"422":2,"423":2,"424":2,"425":2,"426":2,"440":1,"441":1,"442":1,"443":1,"444":2,"445":2,"446":2,"447":2,"448":2,"449":2,"450":2,"451":2,"452":2,"453":2,"459":1,"460":1,"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"527":1,"528":1,"529":1,"530":1,"531":1,"532":1,"534":1,"535":1,"536":1,"543":1,"544":1,"545":1,"546":1,"547":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"555":1,"556":1,"576":1,"577":1,"578":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"613":1,"614":1,"615":1,"616":1,"617":1,"618":2,"619":2,"620":2,"621":2,"622":1,"623":1,"624":1,"625":1,"626":1,"627":1,"643":1,"644":1,"645":1,"646":1,"647":1,"648":1,"652":1,"684":1,"685":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"707":1,"716":1,"717":1,"718":2,"719":2,"720":2,"721":2,"722":2,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1,"784":1,"785":1,"786":1},"2":{"0":2,"3":4,"6":1,"7":1,"10":1,"18":3,"20":3,"21":1,"23":3,"24":2,"26":5,"34":2,"35":2,"36":1,"37":4,"38":2,"39":2,"40":6,"41":15,"42":5,"43":1,"44":1,"46":2,"48":1,"50":1,"51":2,"53":2,"54":4,"55":2,"56":1,"57":2,"58":4,"59":1,"60":1,"64":1,"65":11,"67":1,"68":5,"69":2,"70":4,"71":1,"72":1,"81":3,"82":1,"85":5,"90":1,"91":12,"96":5,"103":1,"104":4,"107":2,"108":2,"109":12,"110":6,"111":4,"112":3,"113":1,"118":1,"119":1,"120":1,"121":2,"122":6,"124":4,"125":20,"126":11,"127":4,"128":3,"130":4,"133":2,"136":2,"137":4,"139":4,"140":3,"144":2,"147":4,"150":2,"152":1,"153":1,"154":2,"155":1,"156":4,"157":5,"160":8,"163":6,"164":2,"165":2,"167":1,"168":5,"171":1,"172":4,"174":3,"175":2,"178":2,"179":1,"180":1,"183":2,"184":1,"186":1,"187":2,"191":1,"194":1,"199":3,"209":3,"211":1,"216":2,"218":1,"221":5,"224":2,"225":2,"226":1,"227":12,"231":1,"233":2,"237":1,"238":11,"243":2,"244":3,"245":3,"246":3,"247":2,"249":2,"250":3,"251":1,"259":1,"260":6,"262":8,"263":2,"264":3,"265":2,"266":4,"267":1,"269":2,"272":10,"273":2,"274":3,"275":5,"276":1,"278":1,"279":18,"281":2,"282":1,"283":1,"284":1,"286":3,"287":10,"288":4,"289":1,"291":4,"292":2,"294":6,"295":2,"296":2,"297":4,"298":1,"299":2,"306":2,"307":2,"309":4,"310":2,"311":10,"312":12,"313":1,"314":6,"315":2,"316":2,"317":3,"318":2,"319":2,"320":4,"321":2,"322":1,"324":3,"325":2,"326":2,"329":9,"331":2,"332":2,"333":2,"334":2,"335":1,"336":10,"337":15,"338":4,"341":11,"342":8,"343":11,"344":1,"347":1,"349":3,"350":1,"353":1,"355":6,"356":2,"360":1,"361":19,"363":1,"367":1,"371":5,"372":42,"373":4,"375":2,"377":2,"378":2,"379":1,"380":2,"381":2,"383":17,"388":6,"390":15,"392":22,"393":22,"396":1,"397":1,"399":1,"400":5,"402":1,"403":2,"404":2,"406":1,"412":3,"414":3,"415":1,"419":1,"422":2,"423":3,"424":2,"425":1,"427":2,"428":1,"429":9,"430":1,"437":3,"438":2,"439":2,"442":1,"444":3,"445":2,"446":2,"447":2,"448":1,"449":3,"450":4,"451":1,"452":2,"453":2,"454":2,"455":7,"457":1,"458":2,"459":2,"461":1,"463":2,"465":6,"466":4,"467":3,"468":3,"469":2,"472":1,"473":2,"474":4,"476":3,"477":6,"478":9,"479":6,"480":3,"481":1,"484":1,"485":2,"487":1,"489":16,"490":17,"491":15,"492":4,"494":1,"495":8,"497":2,"498":8,"499":6,"501":1,"505":1,"506":1,"507":7,"508":11,"509":8,"510":12,"511":8,"512":6,"513":1,"514":7,"517":1,"518":3,"524":1,"527":1,"528":3,"532":2,"533":3,"537":1,"542":4,"543":1,"544":7,"545":2,"546":1,"547":1,"549":1,"551":1,"552":1,"557":4,"558":9,"559":7,"560":1,"561":3,"564":4,"565":2,"566":1,"567":2,"568":3,"569":1,"570":1,"571":2,"573":1,"574":1,"576":1,"579":1,"583":1,"584":1,"587":1,"589":1,"590":2,"593":3,"594":2,"596":1,"597":1,"598":7,"599":16,"600":1,"601":1,"603":1,"604":16,"606":14,"607":18,"608":16,"609":3,"610":1,"612":2,"617":4,"618":1,"619":2,"622":7,"627":19,"629":1,"631":1,"633":1,"634":2,"639":1,"642":3,"643":3,"644":4,"645":1,"646":2,"648":12,"650":4,"651":3,"652":7,"653":2,"657":1,"661":1,"665":1,"666":1,"670":3,"671":2,"672":2,"673":2,"674":5,"676":3,"677":1,"680":2,"681":6,"682":1,"683":1,"684":2,"685":3,"689":2,"690":1,"691":2,"692":2,"697":1,"698":1,"699":5,"700":3,"705":1,"706":11,"707":17,"708":1,"709":3,"710":7,"715":1,"716":4,"717":2,"718":1,"719":3,"722":2,"723":2,"724":1,"727":1,"730":1,"732":1,"733":1,"735":1,"736":2,"737":5,"738":7,"739":2,"740":5,"741":1,"742":4,"743":2,"744":13,"745":4,"747":2,"750":1,"751":1,"754":2,"755":2,"757":1,"760":4,"762":6,"763":1,"765":3,"766":1,"767":5,"770":2,"771":6,"775":1,"776":3,"777":1,"778":6,"779":5,"783":1,"784":22,"785":4,"786":5}}],["celenium",{"0":{"601":1},"2":{"72":1,"93":1,"231":7,"338":2,"461":1,"498":1,"514":1,"542":1,"564":1,"601":4,"762":1,"773":2}}],["centric",{"2":{"226":1}}],["centralized",{"2":{"126":1,"224":2,"226":1}}],["center",{"2":{"26":1,"784":2}}],["crisis",{"2":{"717":1}}],["critical",{"2":{"39":1,"273":1,"294":2,"617":1,"629":1,"692":1}}],["criteria",{"0":{"23":1,"24":1},"2":{"20":1,"21":1,"22":1,"23":3}}],["cry",{"2":{"559":2}}],["cryptech",{"2":{"507":2,"508":1,"509":1,"510":1,"514":1}}],["cryptography",{"2":{"720":1}}],["cryptographic",{"2":{"322":1}}],["cryptokass",{"2":{"236":1}}],["crypto",{"2":{"144":2,"163":2,"291":2,"292":4,"296":2,"599":2,"707":2}}],["crate",{"2":{"428":1}}],["crashed",{"2":{"277":1}}],["cross",{"2":{"427":1}}],["crs",{"2":{"214":1}}],["credentials",{"2":{"599":2}}],["credibility",{"2":{"38":1}}],["creation",{"2":{"773":1,"779":2}}],["creative",{"2":{"564":1}}],["creating",{"0":{"128":1,"261":1,"450":1,"523":1},"2":{"34":1,"90":1,"93":2,"126":1,"127":2,"128":1,"164":1,"168":1,"289":2,"337":2,"432":1,"615":1,"690":1,"779":2,"780":2,"781":2}}],["creators",{"2":{"81":1}}],["createchatcompletion",{"2":{"774":2}}],["createandsubmitblob",{"2":{"773":6,"775":2}}],["createnamespaceid",{"2":{"773":7,"775":2}}],["createpayforblob",{"2":{"599":2}}],["creates",{"2":{"517":1,"773":2}}],["create2",{"2":{"202":5,"210":2}}],["createdblob",{"2":{"773":6,"775":2}}],["created",{"2":{"58":1,"141":1,"162":1,"175":1,"278":1,"289":1,"295":1,"304":1,"309":1,"429":1,"434":1,"435":2,"448":1,"450":1,"466":1,"467":1,"528":1,"559":1,"571":1,"604":1,"606":1,"607":1,"608":1,"706":2,"707":2,"738":2,"768":1,"773":3}}],["create",{"0":{"283":1,"291":1,"294":1,"299":1,"301":1,"306":1,"308":1,"432":1,"433":1,"446":1,"449":1,"697":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"434":1,"435":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"707":1},"2":{"2":3,"30":1,"38":2,"40":2,"41":2,"58":2,"90":1,"126":1,"128":1,"139":1,"160":1,"163":2,"169":1,"174":1,"178":1,"183":1,"203":2,"210":1,"211":2,"214":1,"233":2,"235":1,"245":1,"260":2,"267":1,"272":2,"275":2,"279":4,"283":1,"290":1,"291":1,"294":9,"297":1,"298":1,"301":3,"305":2,"308":1,"311":1,"391":2,"392":1,"404":1,"422":1,"427":1,"432":1,"433":7,"434":6,"446":1,"449":1,"450":1,"454":1,"466":1,"484":1,"522":1,"524":1,"559":1,"568":1,"595":1,"598":2,"599":4,"604":1,"606":1,"607":1,"616":1,"622":3,"710":2,"711":2,"712":2,"738":1,"741":1,"763":1,"771":5,"772":7,"773":15,"774":1,"775":4,"779":2,"784":1}}],["crucial",{"2":{"36":1,"38":1,"86":2,"88":2,"91":1,"481":1}}],["cause",{"2":{"485":1,"636":1,"677":1}}],["cautious",{"2":{"337":1}}],["cache",{"2":{"322":1}}],["cake",{"2":{"277":1}}],["cadence",{"2":{"216":2,"217":1,"218":1}}],["car",{"2":{"291":2}}],["carry",{"2":{"580":1}}],["carrying",{"2":{"260":2}}],["carries",{"2":{"137":1}}],["cargo",{"2":{"209":2,"211":2,"214":2,"215":2}}],["care",{"2":{"109":1}}],["capacities",{"2":{"717":1}}],["capacity",{"2":{"583":3,"644":1}}],["capability",{"2":{"427":1,"717":1}}],["capabilities",{"2":{"259":1,"337":1,"724":1}}],["capable",{"2":{"81":1}}],["capture",{"2":{"31":1}}],["catching",{"2":{"604":1}}],["catchup",{"2":{"561":2}}],["catch",{"2":{"48":1,"561":2,"784":2}}],["categories",{"2":{"681":1}}],["categorize",{"2":{"564":1,"565":1}}],["category",{"2":{"3":4,"542":1,"564":1,"681":1,"682":2}}],["cater",{"2":{"42":1}}],["catering",{"0":{"35":1},"2":{"35":1,"38":1}}],["caldera",{"2":{"249":1,"250":1,"251":1,"253":1,"254":1,"256":1,"257":1}}],["calculation",{"0":{"592":1}}],["calculating",{"2":{"122":1,"174":1,"590":1,"593":1}}],["calculates",{"2":{"591":1,"592":1}}],["calculated",{"2":{"485":1,"590":1,"592":3,"671":1,"677":1,"748":1}}],["calculate",{"2":{"156":2,"159":2,"174":1,"592":1,"677":1}}],["calendar",{"2":{"39":1,"48":1,"79":1}}],["calling",{"2":{"204":1,"206":1}}],["callopts",{"2":{"144":2}}],["called",{"2":{"125":1,"215":1,"221":1,"526":1,"587":1,"593":1,"630":1,"631":1,"652":1,"698":1,"707":1}}],["calldata",{"2":{"112":1,"118":8,"206":2,"207":2,"400":2,"455":4}}],["calls",{"2":{"48":1,"202":1,"234":1,"509":1}}],["call",{"0":{"539":1},"2":{"37":1,"47":1,"48":1,"112":1,"204":5,"219":1,"252":1,"539":1,"739":1,"752":1,"753":1,"773":1}}],["cafes",{"2":{"36":1}}],["cast",{"2":{"204":5,"206":1,"207":1}}],["caste",{"2":{"6":1}}],["cases",{"2":{"179":1,"609":1,"648":1}}],["case",{"2":{"77":1,"84":1,"111":1,"136":1,"156":1,"162":2,"171":1,"175":1,"183":1,"185":1,"186":1,"188":1,"197":1,"208":3,"211":2,"213":1,"308":1,"353":1,"371":1,"386":1,"400":1,"432":1,"455":1,"557":1,"560":1,"591":3,"616":1,"641":1,"771":1}}],["casual",{"2":{"36":2,"42":1}}],["cancel",{"2":{"772":4,"773":4,"775":4}}],["canceling",{"2":{"39":1}}],["canonical",{"2":{"110":1,"586":1,"594":1}}],["cannot",{"2":{"24":1,"40":1,"216":1,"630":2,"636":1,"649":1}}],["can",{"0":{"641":1},"2":{"7":1,"23":2,"28":1,"29":2,"30":1,"34":3,"35":5,"37":3,"38":5,"39":3,"40":5,"41":3,"42":2,"48":1,"54":1,"55":1,"58":3,"60":3,"65":2,"68":1,"70":1,"72":1,"77":2,"80":1,"86":4,"90":1,"92":1,"97":1,"104":3,"109":6,"110":5,"111":4,"112":1,"122":1,"124":1,"125":5,"126":5,"128":3,"136":4,"137":3,"139":3,"141":1,"143":1,"146":1,"149":1,"150":1,"151":2,"153":1,"155":2,"156":4,"157":2,"158":1,"159":1,"160":4,"161":2,"162":2,"163":2,"164":2,"166":3,"168":1,"169":1,"172":4,"174":2,"175":5,"178":3,"179":4,"180":2,"182":2,"183":2,"186":2,"187":2,"188":1,"191":1,"194":1,"197":1,"202":1,"203":3,"205":3,"206":2,"208":3,"209":2,"210":2,"211":3,"214":1,"215":5,"216":1,"217":2,"218":1,"221":1,"225":1,"228":2,"230":1,"231":1,"233":5,"234":1,"235":1,"238":1,"244":1,"245":3,"250":1,"252":1,"254":1,"259":1,"261":1,"266":10,"267":4,"268":1,"269":2,"270":1,"271":1,"272":2,"273":2,"274":2,"275":4,"276":1,"277":2,"278":1,"281":2,"288":1,"294":1,"297":2,"301":1,"302":1,"303":1,"304":2,"306":1,"308":2,"309":1,"311":1,"312":1,"314":1,"316":1,"321":1,"326":1,"334":1,"337":1,"343":2,"345":1,"350":1,"355":2,"361":4,"363":1,"368":1,"369":1,"371":3,"373":1,"375":1,"376":1,"377":2,"380":1,"381":2,"384":1,"385":1,"388":2,"390":1,"391":3,"392":1,"396":1,"397":1,"400":5,"406":2,"409":1,"418":1,"419":1,"422":5,"427":2,"430":1,"432":1,"433":1,"437":2,"443":1,"444":1,"448":1,"452":5,"453":1,"455":1,"457":1,"461":1,"465":1,"466":3,"467":1,"471":1,"474":1,"484":1,"485":3,"486":1,"495":2,"496":1,"497":2,"498":1,"501":1,"509":1,"511":1,"512":1,"514":1,"520":1,"521":1,"525":1,"526":1,"528":1,"533":3,"541":2,"547":1,"551":1,"554":1,"563":1,"564":1,"567":1,"568":1,"582":4,"583":1,"584":4,"591":1,"593":3,"594":1,"595":1,"599":6,"601":1,"607":1,"610":1,"616":3,"617":1,"618":1,"627":1,"629":3,"630":1,"633":3,"636":2,"643":1,"644":2,"646":3,"649":2,"650":1,"651":1,"652":2,"653":1,"659":1,"663":1,"668":1,"670":1,"672":1,"674":2,"677":2,"679":1,"683":1,"690":1,"691":1,"697":1,"698":1,"699":1,"700":1,"701":1,"706":1,"709":1,"710":3,"711":1,"712":1,"713":1,"721":1,"723":1,"725":1,"728":2,"733":3,"737":1,"738":5,"740":2,"741":2,"742":1,"743":2,"745":3,"747":1,"748":1,"757":1,"758":1,"762":1,"763":1,"767":2,"773":7,"775":2,"776":1,"778":1,"779":3,"780":1,"781":1,"783":1,"784":2,"785":2,"786":1}}],["clean",{"2":{"444":1}}],["clears",{"2":{"609":1}}],["clearing",{"0":{"335":1}}],["clear",{"2":{"2":1,"37":1,"429":4}}],["clock",{"2":{"429":4}}],["cloud",{"2":{"217":1,"275":1,"313":1,"320":1,"326":1,"498":1}}],["closely",{"2":{"251":1}}],["close",{"2":{"144":4,"161":4,"162":2,"163":2,"599":2,"772":2,"773":2,"775":2}}],["closer",{"2":{"122":1}}],["cloned",{"2":{"89":1}}],["clone",{"0":{"89":1},"2":{"1":1,"2":2,"89":3,"202":3,"203":2,"208":3,"211":4,"214":2,"215":2,"311":3,"341":3,"586":3,"699":2,"779":2}}],["clis",{"2":{"474":1}}],["cli",{"0":{"260":1,"596":1,"597":1,"730":1,"739":1},"1":{"261":1,"262":1,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":2,"741":2,"742":2,"743":2,"744":2,"745":2,"746":2,"747":2,"748":2,"749":2,"750":2,"751":2,"752":2,"753":2,"754":2,"755":2,"756":2,"757":2,"758":2,"759":2,"760":2,"761":1,"762":1,"763":1,"764":1},"2":{"260":2,"303":2,"308":1,"311":1,"312":1,"314":1,"333":1,"344":1,"428":2,"437":1,"466":1,"558":1,"564":1,"727":1,"733":1,"739":1,"740":2,"741":3,"742":1,"743":1,"759":1}}],["clientid",{"2":{"434":8}}],["clients",{"0":{"433":1,"434":1},"1":{"434":1,"435":1},"2":{"126":1,"429":2,"432":2,"433":2,"434":2,"533":1,"722":1}}],["client",{"0":{"123":1,"143":1,"148":1,"150":1,"153":1,"303":1,"569":1,"570":1,"598":1,"708":1,"777":1},"1":{"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"778":1,"779":1,"780":1,"781":1,"782":1},"2":{"91":1,"111":1,"126":2,"134":1,"136":1,"140":1,"143":3,"144":4,"148":1,"149":1,"150":3,"153":1,"156":20,"157":4,"158":4,"159":6,"160":8,"163":50,"221":2,"227":2,"229":2,"303":4,"331":2,"333":2,"371":1,"433":8,"434":8,"509":1,"567":1,"569":1,"570":1,"593":1,"598":7,"708":1,"710":6,"711":4,"712":6,"713":6,"719":1,"771":2,"772":7,"773":16,"774":5,"775":8,"776":1,"777":1,"779":12,"780":10,"781":10}}],["clicking",{"2":{"582":1,"785":2}}],["click",{"2":{"76":1,"77":3,"79":4,"80":1,"85":1,"87":1,"88":1,"256":1,"275":3,"601":2,"662":1,"785":1,"786":3}}],["clubs",{"2":{"34":2}}],["classname=",{"2":{"784":4}}],["classes",{"2":{"15":1}}],["clang",{"2":{"398":4}}],["claim",{"0":{"80":1,"268":1},"2":{"79":1,"80":3,"268":1,"659":1,"663":1,"668":1}}],["clarifying",{"2":{"8":1}}],["clarity",{"2":{"2":1,"12":1}}],["coingeckoid",{"2":{"784":6}}],["coindecimals",{"2":{"784":6}}],["coindenom",{"2":{"784":6}}],["coinminimaldenom",{"2":{"784":6}}],["cointype",{"2":{"784":2}}],["coin",{"2":{"632":1,"785":1,"786":1}}],["copied",{"2":{"372":1}}],["copies",{"2":{"215":2}}],["copy",{"2":{"91":1,"124":1,"203":3,"311":1,"341":1,"538":1,"636":1,"767":1}}],["cosmovisor",{"2":{"530":1}}],["cosmostation",{"0":{"786":1},"2":{"783":1,"786":2}}],["cosmoslist",{"2":{"499":1,"513":1}}],["cosmosnetwork",{"2":{"430":1}}],["cosmossdk",{"2":{"429":4}}],["cosmos",{"2":{"63":1,"140":7,"238":1,"260":2,"261":1,"266":5,"275":3,"278":1,"280":2,"281":1,"291":2,"292":4,"294":2,"295":2,"296":4,"304":1,"361":3,"412":2,"427":1,"428":1,"429":9,"430":1,"486":1,"509":1,"510":1,"584":1,"587":1,"591":1,"599":4,"604":2,"606":2,"607":2,"648":1,"653":1,"676":3,"680":1,"684":1,"691":3,"698":1,"707":2,"717":4,"718":2,"719":1,"721":1,"722":1,"785":1,"786":1}}],["costly",{"2":{"169":1}}],["cost",{"2":{"34":1,"84":1,"183":1,"185":1,"454":1,"582":1,"591":6,"592":5,"650":1}}],["costs",{"2":{"34":2,"35":1,"38":3,"40":1,"170":1,"193":1,"226":1,"591":3,"593":1}}],["corner",{"2":{"601":1,"785":1,"786":1}}],["coral",{"2":{"291":2}}],["correspond",{"2":{"208":1}}],["corresponds",{"2":{"194":1,"745":1}}],["corresponding",{"0":{"149":1},"1":{"150":1},"2":{"136":1,"137":1,"139":2,"141":1,"144":2,"149":2,"160":1,"161":2,"163":2,"167":1,"168":3,"172":1,"201":1,"202":2,"203":1,"204":2,"209":1,"210":1,"211":2,"214":1,"233":1,"284":1,"322":2,"427":1,"643":1,"652":2}}],["correctly",{"2":{"187":1,"191":1,"194":1,"202":1,"399":1,"428":1,"431":1,"604":1,"608":1,"649":1}}],["correct",{"2":{"110":1,"187":1,"215":1,"246":1,"247":1,"311":1,"313":2,"326":2,"371":1,"399":1,"423":1,"424":1,"439":1,"468":1,"469":1,"501":1,"643":1,"700":1}}],["correction",{"0":{"12":1}}],["corrective",{"2":{"8":1}}],["cores",{"2":{"239":1,"416":1,"535":1,"536":1,"613":1}}],["core",{"0":{"350":1,"737":1},"2":{"53":1,"65":1,"67":1,"68":7,"91":3,"109":1,"140":3,"238":8,"244":12,"245":6,"246":6,"316":2,"317":2,"318":2,"319":2,"320":4,"322":1,"324":2,"329":2,"334":2,"338":2,"350":2,"355":1,"357":1,"383":14,"390":6,"393":6,"407":2,"408":2,"422":5,"423":6,"439":1,"460":1,"465":8,"466":6,"468":6,"477":12,"478":4,"494":1,"495":5,"501":1,"506":1,"507":1,"518":2,"528":1,"535":2,"536":1,"561":3,"580":1,"608":2,"610":1,"619":2,"627":14,"648":4,"681":3,"682":1,"690":1,"706":2,"707":2,"719":1,"732":1,"734":1,"737":16,"738":6,"762":2,"767":2}}],["cooperation",{"2":{"46":1}}],["coordinating",{"2":{"527":1}}],["coordination",{"0":{"527":1},"2":{"30":1,"60":1,"526":2,"554":1}}],["coordinates",{"2":{"643":2}}],["coordinated",{"2":{"481":1}}],["coordinate",{"2":{"30":1,"40":2,"526":1}}],["coworking",{"2":{"38":1}}],["coding",{"2":{"37":1,"634":2,"648":1,"670":1}}],["codelab",{"2":{"275":2}}],["coded",{"2":{"238":1,"485":1,"633":1,"634":1}}],["codespace",{"2":{"147":2,"294":2,"599":4,"616":2,"622":2}}],["codebase",{"2":{"109":1,"552":1}}],["code",{"0":{"5":1,"46":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1},"2":{"8":2,"9":1,"11":1,"13":1,"14":1,"16":4,"24":1,"46":4,"109":2,"110":1,"124":1,"147":2,"228":1,"233":1,"238":1,"250":1,"275":1,"294":2,"485":1,"599":18,"616":1,"622":1,"764":2,"765":1,"771":1,"784":1}}],["covers",{"2":{"53":1,"54":1,"55":1,"56":1,"74":1,"81":1,"228":1,"356":1,"566":1,"783":1}}],["cover",{"2":{"38":1,"40":1,"41":1,"74":1,"84":1,"229":1,"298":1,"314":1,"402":1,"574":1,"730":1,"740":1}}],["covering",{"2":{"38":1,"41":2}}],["covered",{"2":{"36":1,"387":1}}],["covenant",{"2":{"16":4}}],["co",{"2":{"34":2,"38":2,"39":1,"41":1,"50":1,"499":1,"513":1}}],["course",{"2":{"583":1}}],["counterparty",{"2":{"429":2}}],["count",{"2":{"95":1}}],["country",{"2":{"23":1}}],["couldn",{"2":{"40":2,"144":2,"161":2}}],["could",{"2":{"7":1,"124":1,"125":1,"127":1,"130":3,"145":1,"174":1,"175":1,"277":1,"564":1,"584":1,"591":1,"592":1,"634":2,"645":1,"652":1,"674":3,"719":1,"740":1,"773":1,"775":1}}],["columns",{"2":{"122":1,"139":1,"174":1,"643":1}}],["column",{"2":{"110":1,"122":3,"137":1,"139":2,"174":1,"645":1,"651":3,"754":2}}],["collide",{"2":{"275":1}}],["collaboration",{"2":{"38":1,"44":1}}],["collaborate",{"2":{"34":1}}],["collectively",{"2":{"644":1}}],["collection",{"2":{"43":1,"50":1,"125":1}}],["collect",{"2":{"31":1,"260":4,"450":2}}],["collector",{"2":{"23":1,"93":4,"274":2,"320":2,"321":3}}],["color",{"2":{"6":1,"52":1}}],["cohorts",{"2":{"21":1,"22":3,"25":1}}],["cohort",{"0":{"21":1,"27":1},"2":{"21":3,"22":12,"23":1,"24":1,"25":1,"27":5}}],["conn",{"2":{"599":6}}],["connects",{"2":{"321":1}}],["connectivity",{"2":{"652":1}}],["connecting",{"2":{"126":2,"244":1,"422":1,"495":1,"622":1,"737":1}}],["connectionid",{"2":{"434":8}}],["connection",{"0":{"432":1,"434":1},"2":{"38":1,"90":5,"105":1,"109":1,"126":6,"238":1,"245":1,"320":5,"422":1,"432":1,"434":30,"465":1,"599":2,"737":1}}],["connectionside",{"2":{"434":4}}],["connections",{"0":{"320":1},"2":{"34":1,"36":1,"37":1,"58":1,"90":1,"274":6,"313":3,"326":3,"376":1,"427":2,"429":2,"432":2,"435":1,"451":2,"607":1}}],["connect",{"0":{"363":1,"737":1},"1":{"364":1,"365":1},"2":{"32":1,"36":1,"37":1,"49":1,"63":2,"85":1,"109":1,"144":2,"161":2,"163":2,"237":1,"238":1,"252":1,"254":1,"333":2,"361":4,"414":1,"486":2,"501":4,"533":1,"559":1,"561":1,"601":1,"622":2,"652":1,"684":1,"685":1,"762":1,"784":2}}],["connected",{"2":{"23":1,"363":1,"554":1,"633":2,"648":1,"785":1,"786":1}}],["congests",{"2":{"583":1}}],["congestion",{"2":{"583":1,"609":1,"652":1}}],["congested",{"2":{"400":1}}],["congrats",{"2":{"545":1,"547":1}}],["congratulations",{"0":{"94":1,"547":1},"2":{"289":1,"297":1,"305":1,"390":1,"393":1,"434":1,"565":1}}],["conjured",{"2":{"275":1}}],["conditions",{"2":{"191":1,"281":1}}],["conducting",{"2":{"633":1}}],["conduct",{"0":{"5":1,"46":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1},"2":{"7":1,"8":1,"9":1,"11":1,"13":1,"14":1,"16":4,"24":1,"30":1,"46":3,"533":1,"632":1}}],["concrete",{"2":{"773":2,"775":2}}],["concerned",{"2":{"635":1}}],["concepts",{"0":{"166":1},"1":{"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1}}],["concept",{"2":{"53":1,"673":1}}],["concurrency",{"2":{"561":2}}],["conclusion",{"0":{"164":1,"197":1,"305":1}}],["concise",{"2":{"2":1}}],["conf",{"2":{"104":2}}],["confidence",{"2":{"111":1,"632":2}}],["config\\t",{"2":{"559":2}}],["configs",{"2":{"104":2,"275":4}}],["configurable",{"2":{"112":1}}],["configurations",{"0":{"362":1},"1":{"363":1,"364":1,"365":1,"366":1,"367":1,"368":1},"2":{"88":1,"328":1,"379":1,"429":1,"431":1,"741":1}}],["configuration",{"0":{"88":1,"89":1,"380":1,"381":1,"429":1,"431":1,"624":1},"2":{"86":4,"87":1,"88":3,"260":4,"274":2,"275":3,"303":3,"308":1,"314":1,"322":3,"328":2,"334":2,"367":1,"371":2,"378":1,"380":2,"381":1,"429":1,"431":2,"525":3,"542":1,"544":1,"546":1,"559":1,"571":1,"624":1}}],["configuring",{"2":{"86":2,"88":1,"388":1,"428":1}}],["configures",{"2":{"261":1}}],["configured",{"2":{"91":1,"430":1,"541":1,"590":1}}],["configure",{"0":{"86":1,"376":1,"435":1},"1":{"377":1,"378":1,"379":1},"2":{"85":1,"86":2,"91":1,"93":3,"376":1,"380":1,"381":1,"432":1,"624":1}}],["config",{"0":{"76":1,"333":1,"334":1,"346":1,"349":1,"451":1},"1":{"347":1,"348":1,"349":1,"350":2,"351":2,"352":2,"353":2,"354":2,"355":2},"2":{"76":1,"88":4,"89":1,"90":1,"91":3,"104":5,"260":2,"261":2,"274":1,"275":8,"299":2,"303":2,"308":2,"322":1,"324":2,"333":1,"334":7,"336":1,"338":3,"349":4,"353":1,"355":1,"361":27,"363":1,"366":1,"371":2,"377":5,"378":4,"380":2,"381":2,"398":4,"428":1,"429":3,"431":5,"435":1,"448":1,"449":1,"450":4,"451":2,"464":1,"546":1,"559":2,"560":2,"571":1,"599":2,"624":1}}],["confirming",{"2":{"413":1}}],["confirmed",{"2":{"110":1,"111":1,"429":2,"599":2,"659":1,"663":1,"668":1}}],["confirmations",{"2":{"225":1}}],["confirmation",{"2":{"47":1,"128":1,"309":1,"429":2,"464":1}}],["confirm",{"0":{"659":1,"663":1},"2":{"30":1,"122":1,"225":1,"275":1,"294":2,"413":1,"622":1,"667":1}}],["conferences",{"2":{"39":1}}],["conference",{"2":{"39":1}}],["conventions",{"2":{"328":1}}],["convenient",{"2":{"30":1}}],["conversion",{"2":{"156":1,"687":1}}],["conversations",{"2":{"7":1,"31":1}}],["converts",{"2":{"773":2}}],["convert",{"2":{"155":1,"156":1,"157":1,"159":1,"773":3,"775":2}}],["converting",{"0":{"154":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1}}],["converted",{"2":{"142":1,"147":1,"152":1,"155":1,"158":1,"745":1}}],["consoleconfirm",{"2":{"622":1}}],["consolecode",{"2":{"616":1,"622":1}}],["console",{"2":{"540":1}}],["consoleblockhash",{"2":{"539":1}}],["consolebasefeepergas",{"2":{"538":1}}],["console$request",{"2":{"467":1}}],["console$",{"2":{"260":1}}],["cons",{"0":{"171":1,"177":1,"181":1,"185":1,"189":1,"193":1,"196":1},"2":{"166":1}}],["consumes",{"2":{"592":1}}],["consumer",{"2":{"429":4}}],["consume",{"2":{"381":1,"592":1}}],["consumed",{"2":{"140":1,"591":2}}],["consuming",{"2":{"109":1}}],["const",{"2":{"784":8}}],["construction",{"2":{"171":1,"174":1,"183":2}}],["constructions",{"2":{"164":1,"178":1,"186":1}}],["constructing",{"2":{"160":2}}],["constructive",{"2":{"7":1}}],["constructed",{"2":{"157":1,"233":1,"633":1}}],["construct",{"2":{"154":1,"156":4,"159":1,"776":1}}],["constructs",{"2":{"137":1,"166":1,"182":1,"773":1}}],["constructor",{"2":{"118":2}}],["constantly",{"2":{"402":1,"427":1}}],["constants",{"2":{"325":4,"361":22,"372":6,"399":6,"544":4,"559":8,"560":1,"561":2,"571":1,"616":2,"622":2,"743":3,"747":1,"784":18,"785":1}}],["constant",{"2":{"91":1,"485":2,"592":1}}],["consensus",{"0":{"66":1,"302":1,"356":1,"358":1,"363":1,"373":1,"374":1,"387":1,"488":1,"489":1,"536":1,"596":1,"599":1,"603":1},"1":{"67":1,"68":1,"357":1,"358":1,"359":2,"360":2,"361":2,"362":1,"363":1,"364":2,"365":2,"366":1,"367":1,"368":1,"369":1,"370":1,"371":1,"372":1,"373":1,"374":1,"375":2,"376":2,"377":2,"378":2,"379":2,"380":2,"381":2,"382":1,"383":1,"489":1,"490":1,"491":1,"492":1,"604":1},"2":{"59":1,"65":2,"67":1,"68":2,"91":2,"109":1,"121":1,"124":1,"126":1,"136":1,"137":1,"227":3,"233":1,"237":1,"238":3,"266":1,"275":1,"289":1,"298":1,"302":2,"312":1,"313":1,"338":4,"356":3,"357":1,"363":1,"370":1,"371":1,"376":1,"383":32,"387":2,"414":1,"454":1,"465":1,"466":2,"488":1,"494":1,"495":5,"501":2,"506":1,"507":7,"508":2,"510":4,"528":1,"532":1,"533":5,"536":1,"560":2,"561":1,"573":1,"580":1,"583":1,"584":1,"590":1,"599":4,"603":1,"612":1,"614":1,"617":1,"622":1,"625":2,"627":32,"645":1,"648":1,"649":6,"650":2,"676":1,"691":1,"717":1,"722":1,"737":2,"754":2,"762":2}}],["consequence",{"2":{"12":1,"13":1,"14":1,"15":1,"645":1}}],["consequences",{"2":{"11":1,"13":1,"630":2}}],["consist",{"2":{"126":1,"593":1}}],["consists",{"2":{"125":1,"322":1,"648":1,"649":1,"651":3,"670":1}}],["consistency",{"2":{"41":1}}],["consistent",{"2":{"41":2}}],["considerable",{"2":{"381":1}}],["considerations",{"0":{"321":1},"2":{"109":2,"316":1,"321":1}}],["consider",{"2":{"34":1,"36":2,"37":1,"40":3,"368":1,"559":2,"627":1,"632":1,"745":1}}],["considered",{"2":{"7":1}}],["context",{"2":{"143":4,"144":10,"148":2,"150":6,"163":8,"598":6,"599":8,"710":6,"711":4,"712":6,"713":4,"771":2,"772":4,"773":8,"774":4,"775":4}}],["contents",{"0":{"571":1},"2":{"776":1}}],["content",{"2":{"2":1,"40":2,"58":1,"266":2,"540":2,"604":1,"606":1,"607":1,"608":1,"762":2,"774":4}}],["contrastingly",{"2":{"645":1}}],["contrast",{"2":{"224":1,"637":1}}],["contract",{"0":{"97":1,"144":1,"208":1},"1":{"98":1,"99":1,"209":1,"210":1},"2":{"86":1,"87":2,"90":1,"91":4,"93":4,"100":1,"101":1,"109":2,"111":1,"118":6,"120":1,"121":1,"122":7,"124":1,"126":4,"136":3,"137":1,"139":4,"140":1,"141":2,"142":1,"144":12,"147":1,"152":1,"154":6,"160":5,"161":8,"162":6,"163":14,"164":1,"165":1,"169":2,"171":1,"172":1,"174":1,"175":2,"179":1,"183":2,"185":1,"186":2,"187":3,"190":1,"191":1,"194":1,"199":2,"201":1,"202":7,"203":3,"204":8,"205":1,"208":2,"210":9,"211":5,"212":2,"213":1,"214":4,"215":1,"216":3,"217":2,"218":4,"219":2,"225":1,"227":2,"228":5,"229":1,"231":2,"233":5,"234":5,"235":3,"546":4,"582":1,"586":1,"638":1,"690":1}}],["contracts",{"0":{"114":1,"117":1,"201":1,"231":1,"578":1,"586":1},"1":{"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1},"2":{"81":1,"84":1,"86":4,"87":4,"88":2,"91":2,"93":4,"94":1,"96":3,"97":1,"117":4,"118":6,"120":1,"122":1,"127":2,"128":4,"132":1,"134":2,"154":1,"180":1,"202":5,"203":4,"210":3,"221":1,"229":1,"231":2,"254":1,"578":1,"580":1,"584":1,"586":2}}],["control",{"2":{"202":1,"329":1,"381":1,"426":1,"668":1}}],["controlled",{"2":{"86":1}}],["contributor",{"2":{"16":4,"681":1}}],["contributors",{"2":{"6":1,"681":1,"682":1}}],["contributing",{"2":{"7":1}}],["contributions",{"2":{"2":1,"8":1,"20":1,"26":3}}],["contribution",{"0":{"2":1},"2":{"2":2,"37":1,"107":1}}],["contributes",{"2":{"7":1,"591":1}}],["contribute",{"2":{"6":1,"23":1,"26":2,"38":1}}],["containers",{"2":{"706":1,"707":1}}],["container",{"0":{"707":1},"2":{"391":5,"392":4,"393":2,"706":9,"707":11}}],["containerization",{"2":{"388":1}}],["contained",{"2":{"162":1,"167":1,"322":1}}],["containing",{"2":{"139":1,"144":4,"145":1,"150":1,"156":1,"158":1,"160":3,"161":2,"163":4,"172":3,"180":1,"183":1,"199":1,"202":1,"210":1,"275":2,"571":1,"598":2,"651":1,"710":2}}],["contain",{"2":{"88":1,"137":1,"139":1,"145":1,"150":1,"151":1,"156":1,"175":1,"267":1,"322":2,"404":1,"587":1,"643":1,"651":1,"674":1}}],["contains",{"2":{"63":1,"88":1,"91":1,"94":1,"125":2,"144":4,"147":1,"149":1,"154":4,"160":3,"161":2,"163":2,"267":1,"322":3,"336":1,"404":1,"486":1,"501":1,"538":1,"571":3,"588":1}}],["contacts",{"2":{"39":1,"40":1}}],["contact",{"2":{"35":1,"42":1}}],["continuing",{"2":{"622":1}}],["continuousvestingaccount",{"2":{"295":3}}],["continuous",{"2":{"283":1,"294":1}}],["continuously",{"2":{"60":1,"682":4}}],["continues",{"2":{"273":1,"549":1}}],["continue",{"2":{"79":1,"87":1,"400":1,"526":1,"601":1,"673":1,"674":1,"780":2}}],["continued",{"2":{"13":1,"38":1}}],["continually",{"2":{"28":1}}],["combines",{"2":{"765":1}}],["combined",{"0":{"755":1},"2":{"583":1}}],["coming",{"2":{"606":1,"607":1}}],["comfortable",{"2":{"341":1}}],["comexport",{"2":{"390":1}}],["cometbft",{"2":{"224":1,"227":1,"485":1,"676":1}}],["come",{"2":{"124":1,"227":1,"480":1,"574":1,"771":2}}],["comes",{"2":{"109":1}}],["comcelestia",{"2":{"68":1}}],["com",{"0":{"41":1},"2":{"39":2,"41":6,"65":11,"68":1,"71":1,"72":2,"84":1,"89":2,"91":2,"136":4,"140":18,"143":2,"144":16,"150":6,"160":2,"161":2,"162":2,"163":24,"202":2,"203":2,"208":2,"211":2,"214":18,"215":2,"245":2,"280":2,"303":2,"311":2,"341":2,"361":10,"371":4,"383":28,"390":1,"398":2,"429":4,"456":1,"465":2,"466":2,"489":7,"490":7,"491":5,"492":1,"498":1,"499":1,"507":4,"508":4,"509":5,"510":7,"511":8,"514":3,"518":2,"546":2,"586":2,"593":2,"598":6,"599":16,"627":28,"685":1,"699":2,"709":2,"710":6,"737":2,"767":2,"770":4,"771":8,"785":3,"786":1}}],["compiling",{"2":{"398":1}}],["compile",{"2":{"214":6}}],["compiler",{"2":{"117":1}}],["computing",{"2":{"722":1}}],["computation",{"2":{"226":1}}],["computed",{"2":{"175":1,"591":1,"643":1}}],["computesquaresizefromshareproof",{"2":{"122":1}}],["computesquaresizefromrowproof",{"2":{"122":1,"174":1}}],["computes",{"2":{"122":2,"591":1,"651":1}}],["compute",{"2":{"110":1,"651":1}}],["comprised",{"2":{"671":1}}],["comprises",{"2":{"160":1}}],["comprising",{"2":{"199":1}}],["comprehensive",{"2":{"0":1}}],["compatmode",{"2":{"428":2}}],["compatibility",{"0":{"96":1,"720":1},"2":{"91":1}}],["compatible",{"0":{"550":1,"553":1,"555":1},"2":{"81":1,"96":1,"249":1,"251":1,"428":1,"473":1,"526":2,"578":1,"720":1}}],["compared",{"2":{"226":1}}],["compare",{"2":{"175":1}}],["comparing",{"2":{"169":1}}],["compact",{"0":{"169":1},"2":{"169":4,"170":1,"183":1}}],["companion",{"2":{"50":1}}],["companies",{"2":{"38":3}}],["company",{"2":{"38":1}}],["compelling",{"2":{"38":1}}],["component",{"2":{"96":1,"584":1,"784":2}}],["components",{"0":{"108":1},"1":{"109":1,"110":1,"111":1,"112":1},"2":{"26":1,"33":1,"108":2,"199":1,"201":1,"229":1,"480":1,"542":1,"587":1,"593":2,"648":1,"784":8}}],["compose",{"2":{"82":1,"91":1,"92":1,"541":2,"706":2,"707":6}}],["composition",{"2":{"27":1}}],["complex",{"2":{"380":1}}],["completing",{"2":{"81":1,"622":1}}],["completely",{"2":{"744":1}}],["completes",{"2":{"632":1}}],["completed",{"2":{"311":1,"341":1,"697":1}}],["complete",{"2":{"23":1,"47":1,"87":1,"93":2,"214":1,"215":1,"646":1,"679":1,"697":1}}],["compliant",{"2":{"119":1}}],["compliance",{"2":{"23":1}}],["comply",{"2":{"24":1}}],["complaints",{"2":{"10":1}}],["comma",{"2":{"211":1,"361":2,"451":2}}],["commands",{"0":{"260":1,"755":1},"1":{"261":1,"262":1,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1},"2":{"260":2,"266":1,"272":1,"311":1,"312":1,"334":1,"338":1,"341":1,"361":1,"398":2,"412":1,"599":2,"699":1,"741":2,"770":1}}],["command",{"0":{"279":1,"740":1},"2":{"68":1,"70":1,"91":2,"93":1,"117":1,"172":1,"244":1,"245":1,"260":4,"264":4,"266":4,"267":2,"268":1,"269":2,"270":1,"271":3,"278":1,"294":4,"299":1,"301":2,"303":1,"309":1,"312":1,"316":2,"324":1,"329":1,"334":2,"335":1,"341":1,"350":1,"372":1,"377":1,"381":1,"390":1,"392":2,"393":2,"398":2,"408":1,"421":1,"422":1,"433":2,"434":1,"444":1,"445":1,"446":2,"447":1,"448":1,"449":2,"450":2,"452":2,"453":1,"464":1,"466":3,"467":1,"512":1,"518":1,"525":1,"558":1,"559":1,"561":2,"564":1,"565":1,"616":1,"699":1,"702":1,"706":2,"707":5,"737":2,"738":4,"739":1,"740":3,"742":1,"743":1,"744":1,"745":1,"747":3,"751":1,"754":1,"758":1,"759":2,"760":1,"767":2,"768":1,"775":1}}],["commission",{"2":{"23":1,"268":2,"272":6,"622":6,"667":1}}],["commitment",{"0":{"139":1,"167":1,"168":1,"169":1,"170":1,"171":1,"216":1},"1":{"168":1,"169":1,"170":1,"171":1,"217":1,"218":1,"219":1},"2":{"139":5,"142":1,"154":2,"160":3,"162":1,"166":1,"167":3,"168":9,"169":2,"170":2,"173":2,"175":3,"176":1,"183":6,"184":1,"186":1,"187":2,"188":1,"191":5,"194":7,"199":3,"219":1,"228":1,"233":1,"332":2,"408":1,"455":5,"565":6,"598":4,"643":1,"645":1,"651":6,"670":2,"710":4,"745":5,"747":10,"748":3,"762":2,"773":4,"775":2,"779":4}}],["commitments",{"0":{"162":1,"183":1,"184":1,"185":1,"190":1,"192":1,"193":1},"1":{"184":1,"185":1,"191":1,"192":1,"193":1},"2":{"111":1,"125":6,"127":1,"128":1,"162":1,"169":1,"180":1,"183":2,"186":1,"187":1,"190":1,"221":1,"408":2,"564":2,"643":1,"652":1}}],["committment",{"2":{"564":1,"565":2}}],["committing",{"0":{"127":1},"2":{"144":2,"161":2,"163":2}}],["committees",{"0":{"223":1},"1":{"224":1,"225":1,"226":1},"2":{"224":1}}],["committee",{"2":{"85":1}}],["committedto",{"2":{"163":4}}],["committed",{"0":{"144":1,"383":1,"627":1},"2":{"41":1,"119":1,"122":9,"125":1,"130":1,"137":2,"139":4,"141":2,"144":8,"154":8,"160":6,"163":4,"164":1,"168":1,"171":1,"172":1,"174":1,"175":2,"216":1,"233":1,"383":2,"599":4,"627":2,"651":1}}],["commitforge",{"2":{"117":1}}],["commits",{"2":{"8":1,"122":1,"127":1,"154":2,"160":2,"178":1,"194":1}}],["commit",{"2":{"2":3,"96":1,"117":1,"122":1,"127":1,"139":1,"183":1,"215":2,"341":1,"754":4}}],["commonly",{"2":{"275":1,"630":1}}],["common",{"2":{"16":1,"54":1,"144":2,"163":2,"320":1,"459":1,"572":1,"649":2,"708":1,"777":1}}],["communities",{"2":{"58":1}}],["community",{"0":{"42":1,"46":1,"65":1,"236":1,"267":1,"489":1,"490":1,"491":1,"492":1,"494":1,"495":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"680":1},"2":{"2":1,"3":2,"4":1,"6":2,"7":2,"8":2,"9":3,"10":2,"11":2,"12":3,"13":2,"14":3,"15":3,"16":1,"24":1,"26":1,"30":1,"32":1,"33":1,"34":4,"37":2,"39":2,"41":1,"44":1,"46":3,"47":1,"49":1,"51":1,"57":1,"58":1,"65":1,"68":1,"236":1,"266":1,"267":11,"480":1,"481":1,"487":1,"489":1,"495":1,"505":1,"526":2,"549":1,"554":1,"594":1,"676":1,"680":2,"692":2}}],["communicating",{"2":{"275":2}}],["communications",{"0":{"39":1}}],["communication",{"2":{"14":1,"39":1,"49":1,"313":1,"320":1,"326":1,"353":1,"427":1,"509":1,"607":1}}],["communicate",{"2":{"8":1,"36":1,"91":1,"617":1,"768":1}}],["comments",{"2":{"7":1,"8":1}}],["fn",{"2":{"779":2,"780":2,"781":2}}],["fsudo",{"2":{"604":1,"606":1,"607":1,"608":1}}],["fssl",{"2":{"398":2}}],["fc",{"2":{"592":2}}],["fmt",{"2":{"130":4,"143":2,"144":4,"161":2,"162":2,"163":2,"598":2,"599":8,"710":2,"771":2,"773":6,"774":4}}],["f",{"2":{"130":22,"541":1,"604":1,"606":1,"607":1,"608":1}}],["floor",{"2":{"687":1}}],["flow",{"2":{"22":1,"37":1}}],["flipping",{"2":{"632":1}}],["flat",{"2":{"590":3,"593":1,"671":1}}],["flag",{"2":{"109":1,"214":1,"244":1,"283":1,"294":2,"299":1,"303":1,"311":1,"313":1,"316":1,"320":3,"325":1,"326":1,"328":1,"329":1,"338":1,"350":1,"373":2,"392":1,"407":1,"559":1,"561":3,"622":2,"709":1,"737":1,"740":2,"741":1,"742":1,"743":1,"747":1,"748":3,"754":2,"762":2,"772":2,"773":2,"775":2,"778":1}}],["flags",{"0":{"316":1,"525":1,"741":1},"1":{"317":1,"318":1,"319":1,"320":1,"742":1,"743":1,"744":1},"2":{"91":1,"104":2,"264":4,"301":2,"314":2,"316":2,"328":2,"348":1,"390":1,"525":1,"596":2,"700":2,"740":4,"741":2}}],["flexibility",{"0":{"226":1},"2":{"197":1,"226":1,"584":1,"649":1}}],["flexible",{"2":{"35":1}}],["further",{"2":{"700":1}}],["furthermore",{"2":{"26":1,"47":1,"646":1,"649":1}}],["fulfill",{"2":{"202":2}}],["fullnodes",{"2":{"130":1}}],["fullnode",{"2":{"126":6,"130":4}}],["full",{"0":{"102":1,"104":1,"105":1,"129":1,"144":1,"331":1,"332":1,"414":1,"415":1,"417":1,"420":1,"421":1,"422":1,"423":1,"425":1,"426":1,"504":1,"511":1,"606":1},"1":{"103":1,"104":1,"105":1,"130":1,"131":1,"132":1,"133":1,"134":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":2,"422":2,"423":1,"424":2,"425":1,"426":1,"505":1,"506":1,"507":1},"2":{"49":1,"65":2,"68":1,"90":1,"91":3,"94":2,"104":1,"105":1,"109":1,"110":1,"126":4,"130":1,"136":2,"179":1,"183":1,"202":1,"260":2,"299":1,"301":1,"322":1,"328":1,"329":4,"331":1,"332":2,"335":1,"349":2,"386":1,"393":1,"414":1,"415":2,"416":1,"421":6,"422":7,"423":9,"424":3,"425":2,"426":1,"484":1,"489":1,"490":1,"491":1,"493":1,"495":2,"501":1,"507":4,"508":1,"509":1,"510":3,"511":7,"533":2,"535":1,"606":17,"633":3,"634":4,"643":3,"652":1,"698":1,"700":2,"701":2,"702":2,"714":1,"722":1,"736":1,"782":1}}],["fully",{"2":{"23":1,"27":1,"82":1,"497":1,"544":1,"673":2,"682":1}}],["fun",{"2":{"765":1}}],["func2",{"2":{"383":2,"627":2}}],["func",{"2":{"128":2,"130":3,"136":2,"143":2,"144":6,"150":2,"156":7,"157":1,"158":1,"159":1,"160":1,"163":22,"598":2,"599":2,"710":2,"711":1,"712":2,"713":2,"771":2,"772":2,"773":5,"774":2,"775":1}}],["functionalities",{"2":{"501":1}}],["functionality",{"2":{"30":1,"96":1,"126":2,"406":1,"719":1,"728":1}}],["functional",{"2":{"481":1}}],["functionids",{"2":{"210":1}}],["functionid",{"2":{"204":3,"206":2,"207":1,"210":1,"211":2,"218":1}}],["functionverifier",{"2":{"203":5,"215":4}}],["function",{"0":{"203":1,"204":1,"215":1,"772":1},"1":{"205":1,"206":1,"207":1},"2":{"112":1,"118":4,"122":5,"163":2,"202":3,"203":10,"204":16,"205":3,"206":4,"207":2,"210":8,"211":12,"214":1,"215":4,"218":2,"235":2,"591":2,"592":7,"593":3,"599":8,"646":1,"649":1,"771":2,"772":1,"773":2,"774":1,"775":1,"784":5}}],["functions",{"0":{"773":1},"2":{"110":1,"122":4,"202":2,"281":1,"580":3,"582":1,"649":5,"772":1,"773":1}}],["fund",{"0":{"300":1,"309":1},"2":{"93":1,"245":1,"267":2,"300":1,"309":1,"422":1,"466":1,"544":1,"680":1,"738":2,"767":1}}],["funded",{"2":{"82":1,"430":1,"544":2,"546":1,"733":1,"738":1,"764":1,"767":2}}],["funds",{"2":{"40":1,"77":2,"79":1,"84":1,"266":1,"267":3,"279":4,"281":1,"400":1,"403":2,"404":1,"408":1,"467":1,"479":1,"630":1,"680":1,"738":1}}],["funding",{"0":{"479":1,"563":1},"2":{"38":1,"93":3,"402":1,"474":1,"767":1}}],["future",{"2":{"21":1,"31":1,"32":2,"36":1,"37":1,"42":1,"96":1,"321":1,"326":1,"373":1,"532":1,"559":1,"584":1,"607":1,"622":1,"674":1,"681":1,"682":1,"719":1,"728":1,"733":1}}],["feasible",{"2":{"644":1}}],["feature",{"0":{"516":1},"1":{"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1},"2":{"86":1,"108":1,"400":1,"584":1}}],["features",{"2":{"58":1,"341":1,"439":1,"526":1,"528":3,"530":1,"583":1,"642":2,"724":1,"726":1,"776":1}}],["federation",{"2":{"275":2}}],["fed",{"2":{"214":1}}],["fek44boeswewectexicgqiabelorfjcagrqagqhaqqeaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmsegovy2vszxn0awexdjhlc2n1n2z1owx2odc5a3p1nxvlz3vldxj0ctvzdzzoc20zbmushqaaaaaaaaaaaaaaaaaaaaaaaaaaaawey1oiszk=",{"2":{"147":2}}],["few",{"2":{"130":1,"165":1,"171":1,"301":1,"371":1,"455":1,"500":1,"515":1,"528":1,"556":1,"560":1,"576":1,"582":2,"583":1,"767":1}}],["fetches",{"2":{"712":2,"713":2,"773":1}}],["fetchedblob",{"2":{"773":2,"775":4}}],["fetched",{"2":{"110":1,"328":1,"773":3,"775":3}}],["fetcher",{"2":{"109":1}}],["fetch",{"2":{"109":1,"202":1,"598":2,"710":2,"711":1,"712":3,"713":5,"765":1,"773":5,"775":4,"779":2,"780":3,"781":3}}],["fetching",{"0":{"713":1,"781":1},"2":{"90":1,"712":2,"780":2,"781":2}}],["feecurrencies",{"2":{"784":2}}],["fee=gas",{"2":{"592":1}}],["feegrant",{"0":{"401":1,"406":1,"408":1,"410":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":2,"412":1,"413":1},"2":{"402":1,"404":1,"405":2,"406":1,"408":1,"410":1,"412":4,"413":1,"591":1,"717":1}}],["fees=21000utia",{"2":{"616":1,"622":2}}],["fees=21000utiacelestia",{"2":{"616":1}}],["fees",{"0":{"590":1},"1":{"591":1,"592":1,"593":1},"2":{"279":4,"294":6,"301":2,"402":1,"404":1,"409":2,"412":3,"413":2,"429":4,"479":2,"590":3,"594":1,"609":1,"611":1,"671":3,"748":1}}],["feeling",{"2":{"564":1}}],["feel",{"2":{"201":1,"536":1}}],["fee",{"0":{"405":1,"412":1,"589":1,"592":1,"671":1},"1":{"406":1,"407":1,"413":1,"590":1,"591":1,"592":1,"593":1,"594":1},"2":{"86":1,"87":1,"93":20,"202":4,"294":2,"404":1,"405":1,"407":3,"410":2,"412":1,"413":1,"525":1,"590":5,"592":3,"671":2,"676":1,"689":1,"745":5,"757":6}}],["feedback",{"0":{"4":1,"28":1},"2":{"4":1,"7":1,"28":1,"30":1,"31":1,"32":2,"480":1,"536":1}}],["fellow",{"2":{"34":1,"44":1,"49":1}}],["february",{"2":{"20":1,"27":1}}],["fast",{"2":{"454":1,"721":1}}],["faster",{"2":{"352":1}}],["fastest",{"2":{"312":1,"342":1}}],["fatalf",{"2":{"772":2,"773":6,"775":8}}],["fatal",{"0":{"336":1},"2":{"336":2,"772":2,"773":4,"775":4}}],["favourite",{"2":{"203":1}}],["favorite",{"2":{"564":1}}],["favor",{"2":{"152":1,"153":1}}],["falsediscard",{"2":{"381":1}}],["false",{"2":{"144":2,"210":4,"294":2,"313":1,"320":2,"326":1,"350":1,"352":1,"353":1,"381":3,"429":24,"604":1,"652":3}}],["falls",{"2":{"428":1}}],["fallback",{"0":{"112":1,"400":1},"2":{"108":2,"112":6,"400":6}}],["fall",{"2":{"90":1,"112":1,"130":1}}],["faults",{"2":{"126":1}}],["faulty",{"2":{"111":1,"180":1}}],["faucets",{"2":{"430":1}}],["faucet",{"0":{"69":1,"256":1,"512":1},"1":{"70":1,"71":1},"2":{"69":1,"70":3,"71":2,"82":1,"84":1,"256":2,"300":1,"309":2,"512":4,"563":1,"738":2,"764":1,"767":1}}],["familiarity",{"2":{"82":1,"103":1}}],["family",{"2":{"39":2}}],["fact",{"2":{"110":1,"137":1,"150":1,"169":1,"175":1}}],["factories",{"2":{"91":1}}],["factory",{"2":{"87":1}}],["factors",{"2":{"36":1,"485":2}}],["facilitating",{"2":{"87":1}}],["facilitated",{"2":{"58":1}}],["facilitate",{"2":{"31":1,"648":1}}],["failed",{"2":{"331":2,"333":2,"772":2,"773":10,"775":8,"779":8,"780":4,"781":6,"784":2}}],["fail",{"2":{"211":1,"742":1}}],["failure",{"2":{"130":4,"383":2,"604":2,"606":2,"607":2,"608":2,"627":2}}],["fails",{"2":{"112":1,"333":1,"652":1}}],["failing",{"2":{"24":1}}],["fairly",{"2":{"10":1,"717":1}}],["fair",{"2":{"8":1,"18":1,"60":1}}],["faq",{"0":{"198":1,"382":1,"626":1,"628":1},"1":{"199":1,"383":1,"627":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"640":1,"641":1},"2":{"16":2}}],["frequently",{"2":{"552":1}}],["frequency",{"2":{"211":1,"215":3}}],["fresh",{"2":{"375":1}}],["freeze",{"2":{"210":1}}],["free",{"2":{"6":1,"34":1,"65":1,"201":1,"295":2,"487":1,"489":1,"505":1,"536":1,"674":2}}],["fraudulent",{"2":{"130":1,"371":1}}],["fraud",{"0":{"122":1,"645":1},"2":{"110":2,"122":1,"127":1,"130":3,"163":5,"164":1,"178":1,"179":4,"180":1,"183":2,"186":1,"415":2,"583":2,"633":1,"634":3,"645":1,"649":1}}],["frameworks",{"2":{"584":2}}],["framework",{"0":{"576":1},"2":{"510":1,"676":1}}],["frame",{"2":{"86":1}}],["friends",{"2":{"38":1,"39":2,"443":1}}],["friendly",{"2":{"35":2,"601":1}}],["from=$validator",{"2":{"616":2,"622":2}}],["from=",{"2":{"268":2}}],["from",{"0":{"78":1,"79":1,"212":1,"218":1,"311":1,"338":1,"341":1,"411":1,"594":1,"601":1},"1":{"79":1,"80":1,"339":1},"2":{"2":1,"4":1,"7":1,"12":1,"14":1,"15":1,"16":1,"26":2,"30":1,"31":1,"32":1,"37":1,"40":1,"41":1,"43":1,"44":1,"46":1,"48":1,"58":3,"59":1,"60":1,"67":2,"68":1,"70":1,"74":1,"76":1,"77":1,"83":1,"86":2,"87":1,"89":1,"90":2,"91":1,"92":1,"93":8,"97":1,"109":3,"110":1,"111":1,"117":1,"121":1,"122":4,"126":8,"128":1,"130":8,"136":1,"146":1,"155":2,"156":2,"157":2,"160":2,"163":4,"172":1,"173":1,"174":1,"179":1,"186":1,"199":1,"202":2,"203":1,"204":1,"208":3,"211":2,"212":1,"214":1,"216":1,"218":4,"221":1,"225":1,"227":1,"228":1,"238":2,"244":1,"245":1,"249":1,"263":1,"265":5,"266":7,"267":2,"269":4,"270":2,"275":7,"278":2,"279":14,"281":2,"287":1,"293":3,"294":8,"296":1,"299":2,"301":2,"302":1,"303":1,"310":1,"328":1,"334":1,"336":1,"338":3,"345":1,"353":1,"361":1,"369":2,"371":2,"372":3,"373":1,"376":1,"377":1,"383":1,"390":1,"398":2,"411":1,"413":1,"422":2,"430":1,"438":2,"455":6,"465":1,"467":1,"478":1,"479":1,"494":2,"495":1,"506":2,"507":3,"512":1,"538":1,"539":2,"552":1,"557":1,"560":2,"561":3,"563":1,"564":1,"565":2,"567":1,"568":2,"582":2,"583":1,"584":2,"586":1,"590":3,"594":2,"598":2,"599":6,"601":2,"607":2,"608":1,"609":1,"619":1,"622":3,"627":2,"630":1,"633":1,"634":1,"636":1,"637":1,"638":2,"646":1,"649":1,"650":2,"652":2,"666":1,"673":2,"674":2,"676":1,"682":5,"701":1,"702":1,"706":1,"710":2,"713":2,"719":1,"730":1,"733":1,"738":1,"741":3,"743":1,"744":1,"745":1,"747":3,"752":1,"754":1,"764":1,"765":1,"767":1,"771":2,"772":4,"773":7,"775":5,"776":1,"779":2,"781":4,"784":4}}],["five",{"2":{"681":1}}],["fit",{"0":{"638":1}}],["fits",{"2":{"583":1}}],["firewall",{"2":{"313":2,"326":2}}],["first",{"2":{"22":4,"37":1,"44":1,"51":1,"53":1,"63":1,"86":1,"91":2,"93":1,"107":1,"125":3,"126":1,"127":1,"128":1,"130":1,"144":2,"156":2,"157":1,"160":2,"161":2,"163":6,"165":1,"172":1,"183":1,"204":1,"215":2,"221":2,"228":1,"235":1,"249":1,"266":3,"267":1,"272":1,"275":1,"284":1,"291":1,"298":1,"308":1,"329":1,"344":1,"391":1,"398":1,"407":1,"455":2,"461":1,"476":1,"485":1,"486":1,"501":1,"530":1,"532":1,"539":1,"542":1,"558":1,"568":1,"591":2,"594":1,"614":1,"681":1,"687":1,"689":1,"697":1,"699":1,"713":2,"716":1,"757":1,"767":1,"773":5,"774":1,"781":2}}],["figure",{"2":{"399":1,"646":1,"648":1,"651":2}}],["figures",{"2":{"58":1}}],["figment",{"2":{"280":1}}],["fields",{"2":{"371":1}}],["field",{"2":{"147":1,"155":2,"156":1,"160":1,"209":1,"353":1,"378":2,"601":1,"773":1}}],["fine",{"2":{"652":1}}],["finished",{"2":{"608":1}}],["finish",{"0":{"93":1},"2":{"775":1}}],["financial",{"2":{"38":1}}],["finality",{"2":{"580":1}}],["finalizecommit",{"2":{"383":2,"627":2}}],["finalize",{"2":{"30":1,"662":1}}],["finally",{"2":{"105":1,"111":1,"160":1,"171":1,"175":1,"275":1,"528":1,"591":1,"601":1}}],["final",{"2":{"30":1,"214":1,"277":1,"279":2,"450":2,"649":3,"775":1}}],["finger",{"2":{"35":1}}],["finding",{"2":{"34":1,"38":1,"40":1,"42":2}}],["find",{"0":{"538":1,"540":1},"2":{"0":1,"4":1,"37":1,"38":1,"41":1,"54":1,"55":1,"65":1,"68":1,"90":2,"93":1,"98":1,"99":1,"109":3,"122":1,"127":2,"144":2,"161":2,"170":1,"215":2,"228":1,"233":1,"234":1,"245":1,"277":1,"287":1,"301":1,"326":1,"337":1,"349":1,"352":1,"396":1,"422":1,"448":1,"449":1,"456":1,"466":1,"495":2,"497":1,"511":1,"563":1,"566":1,"568":1,"728":1,"733":1,"737":1,"738":1}}],["fixed",{"2":{"565":1,"591":2,"592":2}}],["fixes",{"2":{"23":1}}],["fix",{"2":{"337":1,"383":1,"594":1,"627":1}}],["fixing",{"2":{"2":1}}],["fill",{"2":{"210":2,"275":1}}],["filled",{"2":{"22":1}}],["filter",{"0":{"438":1},"2":{"429":8,"435":4,"438":1,"711":2,"712":2,"780":2}}],["filteropts",{"2":{"144":2,"161":2}}],["filterdatacommitmentstored",{"2":{"144":2,"161":2}}],["filecoin",{"2":{"641":1}}],["file=",{"2":{"275":2}}],["file",{"0":{"411":1,"450":1,"451":1},"2":{"86":3,"88":3,"94":1,"104":3,"202":1,"210":2,"211":2,"215":1,"218":1,"260":6,"263":2,"266":5,"267":4,"272":1,"274":1,"275":1,"276":1,"303":2,"308":1,"311":1,"312":1,"322":3,"334":1,"336":2,"337":9,"342":1,"343":1,"355":1,"361":5,"377":1,"380":1,"381":1,"411":3,"430":9,"448":1,"449":2,"450":4,"451":2,"541":1,"542":1,"571":1,"586":1,"599":2,"601":1,"604":2,"606":2,"607":2,"608":1,"624":1,"771":2}}],["filesystem",{"2":{"396":1}}],["fileserror",{"2":{"337":1}}],["files",{"0":{"88":1,"89":1,"337":1,"431":1},"2":{"3":1,"52":1,"87":1,"88":3,"89":1,"247":2,"260":2,"322":8,"337":2,"398":1,"424":2,"450":4,"469":2,"559":1,"571":7}}],["four",{"2":{"168":1,"266":1,"580":1,"649":3}}],["foundry",{"2":{"116":1,"202":2,"204":1,"208":2}}],["found",{"2":{"68":1,"86":2,"97":1,"104":1,"110":1,"112":1,"122":1,"126":1,"136":1,"137":1,"156":1,"157":1,"159":1,"160":1,"168":1,"169":1,"172":1,"175":2,"182":2,"208":1,"210":1,"217":1,"230":1,"233":1,"250":1,"266":2,"322":1,"371":3,"437":1,"484":1,"559":2,"593":2,"677":1,"710":1,"711":2,"712":2,"742":1,"762":1,"764":2,"765":1,"767":2,"779":1,"780":2}}],["foundation",{"0":{"17":1,"19":1},"1":{"18":1,"19":1,"20":2,"21":2,"22":2,"23":2,"24":2,"25":1,"26":1,"27":1,"28":1},"2":{"18":2,"20":1,"21":2,"23":2,"24":1,"26":2,"27":1,"681":1}}],["folders",{"2":{"287":4,"375":1,"429":1}}],["folder",{"2":{"94":1,"110":1,"214":2,"215":4,"311":1}}],["followed",{"2":{"127":1,"201":1,"212":1}}],["follows",{"2":{"23":1,"126":1,"154":1,"156":2,"157":2,"158":1,"159":1,"162":1,"163":1,"169":1,"175":1,"191":1,"194":1,"275":1,"328":1,"437":1,"485":1,"740":1}}],["follow",{"2":{"11":1,"29":2,"32":1,"42":1,"90":1,"104":1,"199":1,"213":1,"217":1,"218":1,"241":1,"243":1,"248":1,"276":1,"312":1,"343":1,"359":1,"360":1,"373":1,"387":1,"388":1,"398":2,"418":1,"419":1,"425":1,"428":1,"430":1,"439":1,"440":1,"443":1,"470":1,"501":1,"542":1,"586":2,"601":1,"614":1,"615":1,"618":1,"621":1,"622":1,"624":1,"649":1}}],["following",{"2":{"1":1,"26":1,"35":1,"36":1,"46":1,"47":1,"48":1,"70":1,"85":1,"93":2,"97":1,"109":2,"116":1,"125":1,"136":1,"140":1,"154":1,"156":2,"159":1,"168":1,"172":1,"178":1,"179":1,"187":1,"191":1,"199":1,"201":1,"202":2,"211":3,"214":1,"216":1,"228":2,"231":1,"238":1,"239":1,"240":1,"244":1,"245":2,"252":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"275":1,"281":1,"294":1,"313":1,"315":1,"316":1,"321":1,"322":1,"326":1,"329":1,"334":2,"341":1,"349":1,"357":1,"358":1,"361":1,"363":1,"371":1,"372":1,"393":1,"408":1,"412":1,"416":1,"417":1,"421":1,"422":2,"427":1,"429":1,"431":1,"433":1,"434":1,"439":1,"441":1,"442":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":3,"451":2,"452":3,"453":1,"459":1,"460":1,"464":1,"466":3,"467":1,"485":1,"499":1,"512":1,"513":1,"518":1,"558":1,"561":1,"565":1,"571":1,"600":1,"613":1,"614":1,"619":1,"620":1,"622":1,"646":1,"648":1,"649":1,"651":1,"658":1,"659":1,"662":2,"663":1,"684":1,"685":1,"697":1,"699":1,"700":1,"702":1,"707":1,"709":1,"734":1,"738":4,"741":1,"742":1,"743":1,"744":1,"745":3,"747":3,"758":1,"759":2,"766":1,"767":1,"768":1,"770":1,"775":1,"778":1,"784":1,"785":1,"786":1}}],["foster",{"2":{"46":1,"58":1}}],["fosters",{"2":{"37":1}}],["fostering",{"2":{"18":1,"35":1,"43":1}}],["focuses",{"2":{"724":1}}],["focused",{"2":{"36":2,"59":1,"226":1,"552":1,"554":1}}],["focus",{"2":{"59":1,"315":1,"690":1}}],["focusing",{"2":{"7":2,"37":1}}],["foods",{"2":{"35":1}}],["food",{"2":{"35":2}}],["forest",{"2":{"651":1}}],["forever",{"2":{"639":1}}],["fortunately",{"2":{"275":1}}],["forward",{"2":{"202":1,"604":1}}],["forget",{"2":{"79":1,"291":2}}],["forge",{"2":{"36":1,"202":2,"203":6,"210":2}}],["forces",{"2":{"36":1}}],["former",{"2":{"650":1}}],["formerly",{"2":{"221":1}}],["formula",{"2":{"593":1}}],["formatting",{"0":{"740":1}}],["format",{"2":{"154":1,"155":1,"202":2,"263":1,"266":1,"303":2,"601":2,"701":1,"740":1,"745":3,"747":1,"751":1,"754":1,"757":1,"773":1}}],["formal",{"2":{"36":1}}],["forms",{"2":{"30":1,"31":1,"125":1}}],["form",{"0":{"47":1},"2":{"26":1,"28":1,"47":1,"86":1,"218":1,"682":1}}],["fork",{"2":{"2":3,"594":1}}],["for",{"0":{"42":1,"67":1,"68":1,"90":1,"91":1,"122":1,"162":1,"272":1,"339":1,"374":1,"401":1,"407":1,"410":1,"449":1,"494":1,"495":1,"504":1,"506":1,"507":1,"516":1,"525":1,"550":1,"553":1,"555":1,"633":1,"634":1,"647":1,"657":1,"666":1,"669":1,"674":1,"689":1,"700":1,"701":1,"702":1,"703":1,"715":1},"1":{"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":2,"412":1,"413":1,"505":1,"506":1,"507":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1,"648":1,"670":1,"671":1,"716":1,"717":1,"718":1,"719":1,"720":1,"721":1,"722":1},"2":{"0":1,"2":1,"3":3,"4":1,"6":1,"7":3,"8":2,"10":1,"11":1,"13":2,"14":1,"16":1,"18":1,"21":2,"22":3,"23":5,"24":2,"25":3,"26":3,"27":2,"30":3,"31":1,"32":4,"33":1,"34":13,"35":6,"36":4,"37":6,"38":4,"39":2,"40":5,"41":8,"42":3,"43":2,"44":1,"46":2,"47":2,"50":1,"51":1,"54":2,"55":1,"57":3,"58":1,"59":2,"63":1,"64":2,"65":1,"67":1,"68":5,"72":1,"73":1,"77":3,"81":1,"82":1,"84":2,"86":15,"87":1,"88":5,"90":6,"91":13,"92":1,"93":14,"96":4,"104":1,"107":2,"109":11,"110":5,"112":3,"117":1,"118":1,"120":1,"122":1,"124":1,"125":2,"126":12,"127":4,"128":3,"130":3,"134":2,"136":8,"137":1,"139":2,"140":1,"142":2,"144":2,"147":2,"151":1,"152":3,"153":1,"155":1,"160":2,"161":4,"162":4,"163":13,"165":1,"170":1,"171":2,"172":1,"174":1,"176":1,"179":1,"180":1,"187":1,"194":1,"197":1,"202":17,"204":2,"205":2,"206":1,"207":1,"208":1,"210":3,"211":10,"212":1,"214":1,"215":7,"216":2,"218":2,"219":2,"221":3,"224":1,"226":1,"227":2,"228":2,"229":1,"233":3,"234":3,"235":2,"239":3,"241":1,"243":1,"244":1,"245":6,"250":1,"251":2,"252":2,"258":1,"260":4,"263":2,"266":1,"273":2,"274":4,"275":1,"277":1,"278":1,"281":5,"282":1,"283":3,"287":1,"289":1,"294":3,"298":2,"299":3,"301":1,"302":1,"303":5,"306":1,"307":1,"308":1,"309":2,"311":2,"312":2,"313":3,"314":1,"315":3,"317":1,"318":1,"319":1,"320":2,"321":2,"322":2,"324":1,"325":3,"326":3,"328":2,"335":1,"336":1,"337":2,"338":1,"339":2,"341":1,"342":1,"343":2,"349":4,"350":2,"353":1,"355":3,"357":3,"361":5,"367":1,"368":1,"369":1,"370":1,"371":2,"373":1,"376":1,"378":2,"380":2,"381":3,"383":3,"385":1,"387":1,"388":3,"389":2,"390":2,"391":3,"392":1,"396":3,"397":1,"398":2,"399":1,"400":2,"402":1,"404":2,"405":2,"406":1,"407":1,"412":2,"416":3,"418":1,"419":1,"422":11,"427":2,"428":1,"429":2,"430":4,"431":2,"435":2,"437":1,"439":1,"444":1,"445":3,"446":1,"448":2,"449":1,"450":1,"453":1,"455":4,"456":1,"459":1,"460":3,"465":3,"466":3,"480":2,"484":1,"485":1,"486":1,"487":3,"489":1,"494":1,"495":5,"497":1,"498":1,"499":1,"501":3,"505":3,"506":1,"507":3,"509":1,"511":1,"513":1,"514":1,"525":4,"526":1,"527":5,"528":2,"530":5,"532":1,"537":1,"538":1,"539":1,"541":1,"544":1,"545":2,"546":2,"549":1,"552":1,"558":3,"559":6,"561":2,"563":2,"564":3,"568":3,"571":2,"572":1,"573":1,"574":3,"576":1,"583":1,"584":2,"585":1,"586":4,"588":3,"590":2,"591":3,"592":12,"593":4,"594":1,"598":1,"599":4,"601":3,"602":1,"604":1,"607":1,"609":1,"613":3,"616":1,"617":1,"618":1,"619":1,"622":1,"625":2,"627":4,"629":2,"630":1,"631":3,"632":4,"633":3,"635":1,"636":1,"637":1,"639":2,"640":2,"641":2,"642":1,"643":4,"644":3,"645":2,"646":7,"648":2,"649":4,"650":2,"651":3,"652":5,"658":1,"662":1,"672":1,"673":1,"674":8,"677":2,"681":2,"682":3,"684":1,"685":1,"689":2,"690":1,"691":1,"695":1,"696":1,"698":1,"699":1,"700":5,"706":5,"707":1,"715":1,"717":2,"718":1,"719":2,"720":1,"723":1,"725":1,"726":1,"728":1,"729":1,"733":1,"734":3,"737":3,"738":5,"740":3,"741":1,"743":1,"744":1,"745":1,"747":2,"748":2,"750":1,"751":6,"759":1,"762":1,"765":1,"766":1,"767":3,"768":2,"771":2,"773":1,"775":1,"776":2,"784":2}}],["tld",{"2":{"762":1}}],["tls",{"0":{"320":1},"2":{"320":7}}],["tls=false",{"2":{"320":2}}],["tls=true",{"2":{"317":2,"318":2,"319":2,"320":2}}],["tls=",{"2":{"316":2}}],["tbd",{"2":{"717":1}}],["tb",{"2":{"239":1,"357":1,"369":1,"416":1,"535":2,"536":2,"613":1}}],["tj9wswcyhm0r0i8t+p3hpftdieuyr9wspvkl1r2s=",{"2":{"142":2}}],["tmproto",{"2":{"156":2,"163":2,"599":6}}],["tm",{"2":{"140":2,"383":14,"627":14,"717":1}}],["txoption",{"2":{"599":2}}],["txtsudo",{"2":{"271":1}}],["txt",{"2":{"263":1,"271":5,"361":8}}],["txtcelestia",{"2":{"263":1}}],["txhashcelestia",{"2":{"757":1}}],["txhash",{"2":{"148":4,"150":2,"294":2,"616":3,"622":2,"757":1}}],["txsizecost",{"2":{"592":1}}],["txsizecostperbyte",{"2":{"591":1}}],["txsharerange",{"2":{"172":1}}],["txs",{"2":{"125":4,"128":6,"150":2,"260":2}}],["tx",{"2":{"93":6,"144":14,"147":5,"148":5,"150":6,"161":4,"163":2,"260":4,"265":6,"266":6,"267":2,"268":2,"269":4,"270":2,"279":10,"294":8,"301":4,"380":4,"412":2,"429":10,"437":2,"479":2,"538":2,"539":2,"588":1,"590":1,"591":1,"596":2,"616":7,"622":6,"651":1}}],["ts",{"2":{"91":1}}],["tcp",{"2":{"65":4,"143":2,"144":2,"303":2,"313":2,"314":4,"326":1,"333":2,"377":4,"478":6,"607":2,"706":2,"707":2,"752":6}}],["tuning",{"2":{"652":1}}],["tuplerootnonce",{"0":{"161":1},"2":{"154":2,"160":5}}],["tuple",{"2":{"118":10,"119":1,"127":1,"128":1,"139":4,"141":3,"144":2,"154":14,"160":17,"164":1,"168":3,"169":1,"174":1,"175":4,"199":1}}],["tutorial",{"0":{"569":1,"570":1,"708":1,"727":1,"729":1,"730":1,"777":1},"1":{"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1,"778":1,"779":1,"780":1,"781":1,"782":1},"2":{"81":1,"237":1,"240":1,"241":1,"243":1,"248":1,"283":1,"298":2,"302":1,"307":1,"310":1,"311":1,"315":5,"341":1,"344":1,"358":1,"360":1,"373":1,"385":1,"387":1,"390":1,"414":1,"417":1,"418":1,"419":1,"425":1,"429":1,"458":1,"462":1,"470":1,"471":1,"533":1,"569":1,"570":1,"597":1,"598":1,"612":1,"614":1,"615":1,"618":1,"621":1,"622":1,"653":1,"697":3,"708":1,"719":1,"727":1,"729":1,"730":1,"739":1,"763":1,"765":2,"767":2,"776":1,"777":1}}],["tutorials",{"2":{"0":1,"3":2,"23":1,"536":1,"574":1,"727":1}}],["turned",{"2":{"366":1}}],["turn",{"2":{"42":1,"76":1,"199":1}}],["twitch",{"2":{"40":1}}],["twitter",{"2":{"26":1,"39":2,"40":1,"564":1}}],["two",{"2":{"39":1,"74":1,"79":1,"137":2,"145":1,"151":1,"166":1,"168":1,"169":1,"175":1,"204":2,"215":2,"229":1,"238":1,"247":1,"266":1,"370":1,"371":1,"405":1,"424":1,"427":1,"434":1,"455":1,"467":1,"469":1,"527":1,"542":1,"551":1,"580":1,"587":1,"642":1,"646":1,"651":1,"670":1,"723":1}}],["typically",{"2":{"224":1,"694":1}}],["typical",{"2":{"127":1,"580":1,"722":2}}],["type=1",{"2":{"541":1}}],["type=spanbatch",{"2":{"541":1}}],["type=$node",{"2":{"390":6,"392":6,"393":6}}],["type=full",{"2":{"390":1}}],["type=fullexport",{"2":{"390":1}}],["type=bridge",{"2":{"390":1}}],["type=bridgeexport",{"2":{"390":1}}],["type=light",{"2":{"390":1,"706":2,"707":2}}],["type=lightexport",{"2":{"390":1}}],["type=ledger`",{"2":{"202":2}}],["type=private",{"2":{"202":4}}],["type",{"0":{"85":1},"2":{"63":1,"65":2,"68":2,"125":8,"126":7,"147":4,"156":2,"159":2,"178":1,"202":4,"245":2,"266":4,"291":4,"292":8,"294":2,"295":3,"296":5,"314":2,"316":2,"317":2,"318":2,"319":2,"320":4,"324":4,"328":2,"329":12,"334":4,"335":2,"336":4,"344":1,"349":1,"390":13,"392":8,"393":8,"399":1,"422":2,"429":12,"466":4,"486":1,"495":2,"501":3,"523":2,"530":1,"533":1,"535":1,"536":1,"540":2,"541":2,"561":2,"564":1,"571":1,"579":1,"630":2,"698":1,"700":7,"701":6,"702":6,"706":2,"707":6,"738":4,"742":4,"754":4,"762":2,"773":3,"775":2,"785":1,"786":1}}],["typescargo",{"2":{"778":1}}],["types",{"0":{"369":1},"1":{"370":1,"371":1,"372":1},"2":{"36":1,"63":1,"65":1,"163":6,"173":1,"183":1,"313":1,"326":1,"328":1,"344":1,"396":1,"486":2,"501":1,"571":1,"573":1,"583":1,"593":2,"598":4,"599":4,"640":1,"710":4,"736":1,"771":4,"778":2,"779":2}}],["typography",{"2":{"52":1}}],["typos",{"2":{"2":1}}],["tasked",{"2":{"634":1}}],["tasks",{"2":{"93":1,"398":1,"649":1}}],["tar",{"2":{"372":24,"398":4,"399":32}}],["targets",{"2":{"275":6}}],["targetblock",{"2":{"219":1}}],["target",{"2":{"140":1,"201":1,"202":1,"204":1,"210":1,"211":3,"215":3,"216":2,"221":1,"260":2,"336":1,"604":4,"606":4,"607":4,"608":4,"677":1}}],["targeting",{"2":{"90":1}}],["taking",{"2":{"109":1,"156":1,"157":1,"160":1,"169":1,"370":1}}],["taken",{"2":{"214":1}}],["takes",{"2":{"109":1,"141":1,"151":1,"214":2,"215":1,"217":1,"710":2,"713":1,"745":1,"773":1,"779":2,"781":1}}],["takeaways",{"2":{"32":1}}],["take",{"2":{"8":1,"47":1,"109":1,"122":1,"125":1,"154":1,"155":1,"159":1,"175":1,"191":1,"194":1,"199":1,"203":1,"302":1,"325":1,"328":1,"355":1,"371":1,"563":1,"643":1,"648":1,"652":1}}],["tab=staking",{"2":{"684":1}}],["tab",{"2":{"77":2,"79":2,"208":1,"256":1,"700":1}}],["tables",{"2":{"571":1}}],["table",{"2":{"68":1,"86":1,"681":1,"682":1}}],["tag",{"2":{"39":1,"311":6,"341":6,"343":2,"390":6,"392":6,"393":6,"558":2,"561":2,"706":2}}],["tags",{"2":{"30":1,"311":6,"341":6}}],["talented",{"2":{"37":1}}],["talks",{"2":{"34":1,"37":1,"40":1,"42":5}}],["talk",{"2":{"34":1,"37":1}}],["tailored",{"2":{"47":1,"58":1}}],["tailor",{"2":{"36":1,"38":1,"42":1}}],["t",{"0":{"639":1},"2":{"26":1,"29":1,"34":1,"37":1,"39":1,"40":3,"79":1,"90":1,"91":1,"109":2,"130":1,"136":1,"144":2,"155":1,"156":1,"157":1,"159":1,"160":1,"161":2,"174":1,"183":1,"199":1,"202":3,"208":1,"233":2,"287":4,"299":1,"301":1,"344":1,"371":1,"373":1,"377":1,"380":1,"383":18,"414":1,"428":1,"432":1,"485":1,"525":1,"542":1,"544":1,"552":1,"582":1,"583":1,"584":2,"586":1,"599":2,"622":1,"627":19,"633":1,"634":2,"639":2,"685":1,"728":2,"741":1,"764":1,"784":2}}],["tiny",{"2":{"786":1}}],["ti",{"2":{"706":2,"707":2}}],["tia",{"0":{"653":1,"655":1,"658":1,"659":1,"660":1,"662":1,"663":1,"664":1,"667":1,"668":1,"681":1,"686":1,"687":1,"688":1,"694":1},"1":{"654":1,"655":1,"656":2,"657":2,"658":2,"659":2,"660":1,"661":2,"662":2,"663":2,"664":1,"665":2,"666":2,"667":2,"668":2,"682":1,"687":1,"688":1,"689":2,"690":2,"691":2,"692":2,"693":2,"694":2,"695":2,"696":2},"2":{"653":3,"658":1,"676":1,"677":3,"679":1,"680":1,"681":1,"682":3,"687":2,"689":2,"690":1,"691":1,"692":1,"694":1,"695":2,"757":2,"784":6,"786":1}}],["title",{"2":{"266":6,"267":2}}],["tips",{"2":{"672":1}}],["tip",{"2":{"91":1,"216":1,"217":1,"245":1,"294":2,"309":1,"324":1,"334":2,"369":2,"371":2,"399":1,"422":1,"428":1,"453":1,"465":1,"495":1,"539":2,"544":1,"545":1,"546":1,"561":1,"564":1,"619":1,"627":1,"700":1,"706":1,"733":1,"736":1,"737":1,"738":1,"740":1,"744":1,"767":1,"771":1,"773":1}}],["timing",{"2":{"58":1,"594":1}}],["times",{"2":{"552":1,"643":1}}],["timestamps",{"2":{"559":1}}],["timestamp",{"2":{"294":3,"538":2,"616":2,"622":2,"677":1,"754":2}}],["timeseries",{"2":{"275":2}}],["timeouts",{"2":{"530":1}}],["timeout",{"2":{"294":2,"429":4,"599":2}}],["timely",{"2":{"24":1}}],["time",{"2":{"13":1,"14":1,"30":1,"39":1,"86":2,"90":1,"130":1,"211":2,"217":1,"233":1,"275":2,"281":1,"287":1,"294":2,"295":4,"302":1,"344":1,"369":2,"429":4,"431":1,"525":1,"532":1,"541":1,"542":1,"582":1,"591":1,"594":2,"599":2,"604":1,"608":1,"636":1,"651":1,"677":1,"722":1,"754":2,"771":1,"775":1}}],["tiers",{"2":{"22":1}}],["tier",{"2":{"22":1,"58":1}}],["tryfinalizecommit",{"2":{"383":2,"627":2}}],["try",{"2":{"361":1,"438":1,"740":1,"764":1,"767":1,"776":1,"784":2}}],["trying",{"2":{"109":1,"336":1,"337":1,"560":1,"764":1}}],["tr",{"2":{"361":10,"372":6}}],["treated",{"2":{"210":1,"591":1}}],["trees",{"0":{"646":1},"2":{"642":1,"646":1,"733":1}}],["tree",{"2":{"110":2,"118":2,"119":1,"139":2,"156":6,"159":6,"188":1,"646":2,"648":2,"651":1}}],["trpc",{"2":{"136":11,"143":4,"144":8,"148":2,"150":4,"153":2,"163":2}}],["tries",{"2":{"652":1}}],["triggered",{"2":{"400":3}}],["triggering",{"2":{"179":1}}],["trigger",{"2":{"179":1}}],["trick",{"2":{"110":1}}],["tripods",{"2":{"34":1}}],["truth",{"2":{"139":1}}],["true",{"2":{"91":6,"118":2,"144":2,"147":1,"148":2,"150":2,"210":1,"211":2,"274":4,"313":2,"320":1,"326":2,"352":1,"353":1,"371":3,"381":1,"429":10,"546":3,"561":4,"747":1}}],["trusts",{"2":{"355":1}}],["trustedpeers",{"2":{"355":1}}],["trustedpeer",{"0":{"355":1}}],["trustedhash",{"0":{"355":1},"2":{"355":1}}],["trusted",{"0":{"209":1,"338":1,"560":1},"1":{"339":1},"2":{"50":1,"208":3,"209":6,"210":6,"214":1,"238":2,"328":1,"338":8,"355":5,"371":2,"429":4,"478":3,"489":1,"490":1,"491":1,"508":1,"509":1,"510":1,"560":11,"561":6,"733":1}}],["trust",{"2":{"39":1,"338":3,"371":4,"429":4,"560":2,"642":1,"652":1}}],["trustworthy",{"2":{"18":1}}],["troubles",{"2":{"495":1}}],["troubleshooting",{"0":{"323":1,"396":1,"572":1,"764":1},"1":{"324":1,"325":1,"326":1,"327":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1,"336":1,"337":1},"2":{"54":1,"95":1,"244":1,"245":1,"309":1,"343":1,"345":1,"390":1,"422":2,"453":1,"465":1,"572":1,"619":1,"700":1,"706":2,"737":1,"738":1,"740":1}}],["trolling",{"2":{"7":1}}],["traditional",{"2":{"188":1,"455":1,"649":1}}],["tracking",{"2":{"339":1}}],["trackers",{"2":{"276":1}}],["track",{"2":{"30":1,"110":1,"127":1,"316":1}}],["transients",{"2":{"322":1}}],["transitions",{"2":{"130":1,"179":1,"187":1,"191":1,"194":1,"649":1}}],["transition",{"2":{"18":1,"163":4,"179":2,"183":1}}],["transcript15",{"2":{"214":4}}],["transcript14",{"2":{"214":4}}],["transcript13",{"2":{"214":4}}],["transcript12",{"2":{"214":4}}],["transcript11",{"2":{"214":4}}],["transcript06",{"2":{"214":4}}],["transcript05",{"2":{"214":4}}],["transcript04",{"2":{"214":4}}],["transact",{"2":{"400":1,"684":1}}],["transactopts",{"2":{"163":2}}],["transactionindex",{"2":{"539":2}}],["transaction",{"0":{"145":1,"146":2,"149":1,"199":1,"364":1,"380":1,"449":1,"538":1,"539":1,"609":1,"624":1,"651":1},"1":{"147":2,"148":2,"150":1,"610":1,"611":1,"652":1},"2":{"77":4,"79":3,"80":3,"85":3,"86":3,"87":4,"93":14,"127":1,"130":1,"137":3,"144":8,"145":4,"146":3,"147":3,"148":2,"149":1,"150":4,"155":1,"156":1,"161":2,"163":4,"164":1,"167":1,"172":2,"175":1,"180":2,"191":1,"199":13,"202":3,"204":2,"278":1,"279":4,"283":1,"294":3,"301":1,"303":2,"363":1,"366":1,"400":1,"402":1,"412":2,"449":1,"485":4,"520":1,"525":1,"530":1,"538":4,"539":2,"580":2,"583":2,"584":1,"587":1,"588":5,"590":2,"591":3,"592":10,"593":1,"594":8,"599":14,"601":1,"610":2,"622":3,"624":1,"629":2,"630":3,"631":1,"635":3,"636":3,"637":2,"638":2,"640":2,"641":2,"642":1,"649":1,"651":3,"658":1,"659":1,"662":2,"663":1,"668":1,"670":4,"671":2,"745":3,"747":3,"748":1,"757":1,"762":1}}],["transactions",{"0":{"366":1,"525":1,"594":1,"670":1},"2":{"68":1,"74":1,"77":2,"79":1,"80":1,"81":1,"87":2,"88":1,"92":1,"127":1,"130":1,"134":1,"137":1,"150":1,"227":1,"244":1,"245":1,"252":1,"260":2,"280":1,"366":1,"380":5,"381":1,"400":1,"406":1,"422":3,"465":1,"466":1,"471":1,"495":1,"507":1,"508":1,"510":1,"525":3,"538":3,"579":3,"580":2,"583":1,"587":2,"588":2,"589":2,"594":1,"599":4,"609":3,"610":1,"611":2,"624":1,"629":1,"636":1,"642":1,"643":1,"644":1,"648":1,"649":6,"650":1,"651":6,"652":2,"670":2,"671":2,"689":1,"695":1,"717":1,"718":1,"732":1,"737":1,"738":1,"765":1,"785":1,"786":1}}],["transferred",{"2":{"437":1}}],["transferring",{"2":{"93":2}}],["transferhermes",{"2":{"434":1}}],["transfer",{"0":{"437":1,"757":1},"1":{"438":1},"2":{"86":1,"255":1,"265":1,"427":1,"429":4,"434":7,"435":4,"437":6,"438":1,"682":1,"757":7}}],["translations",{"2":{"16":2}}],["teach",{"2":{"739":1}}],["teams",{"2":{"528":1}}],["team",{"2":{"26":1,"30":1,"35":1,"37":1,"39":1,"46":1,"81":1,"93":1,"170":1,"191":1,"194":1,"197":1,"217":1,"218":1,"238":1,"560":1,"561":1}}],["tee",{"2":{"604":2,"606":2,"607":2,"608":2}}],["territories",{"2":{"481":1}}],["term",{"2":{"677":1}}],["terminal",{"2":{"202":1,"312":2,"343":1,"426":1,"464":1,"478":1,"559":1,"561":2,"563":1,"601":1,"762":1,"767":1}}],["terms",{"2":{"13":1,"14":1,"667":1}}],["text|json",{"2":{"303":2}}],["text",{"2":{"266":1,"267":1,"303":2,"451":1,"745":2,"747":1}}],["texthttps",{"2":{"136":2}}],["text$request",{"2":{"70":1,"309":1,"512":1,"738":1}}],["temp",{"2":{"312":1,"342":1,"343":1}}],["temporarily",{"2":{"281":1}}],["temporary",{"0":{"14":1},"2":{"13":1,"14":1,"289":1,"322":1,"400":1}}],["template",{"2":{"213":1,"214":2,"541":1}}],["templates",{"2":{"91":1}}],["tendermintrpc",{"2":{"109":1}}],["tendermint",{"2":{"91":3,"136":1,"140":4,"142":1,"143":4,"144":10,"147":1,"150":4,"152":1,"163":22,"209":1,"211":1,"218":1,"238":1,"260":8,"272":2,"303":2,"375":2,"383":29,"428":2,"434":8,"444":2,"452":2,"599":6,"622":2,"627":30,"648":6,"717":2,"718":1,"719":1,"721":1,"722":2,"754":4}}],["teststaking",{"2":{"449":1}}],["testtia",{"2":{"447":1}}],["testkey2",{"2":{"520":2,"521":1}}],["testkey2celestia",{"2":{"520":1}}],["testkeycelestia",{"2":{"518":1}}],["testkey",{"2":{"446":1,"518":2,"523":2}}],["test3",{"2":{"279":4}}],["test2sig",{"2":{"279":4}}],["test2",{"2":{"279":8}}],["test1sig",{"2":{"279":4}}],["test1",{"2":{"279":8}}],["testcelestia",{"2":{"261":1,"299":1,"308":1,"477":2}}],["test",{"2":{"156":1,"157":1,"159":1,"160":1,"214":4,"245":3,"246":1,"251":2,"261":1,"275":1,"279":6,"289":1,"299":1,"303":2,"308":1,"412":2,"422":3,"423":1,"429":4,"431":1,"439":2,"446":1,"447":1,"449":1,"457":1,"466":4,"468":1,"477":2,"478":4,"479":5,"501":2,"523":2,"554":1,"571":2,"700":6,"701":6,"702":6,"706":4,"707":4,"738":4,"770":4}}],["tested",{"2":{"96":1,"528":1,"541":1,"720":1}}],["testing",{"0":{"479":1},"2":{"59":3,"60":1,"254":1,"474":1,"480":1,"497":1,"549":1}}],["testnetwork",{"2":{"439":1}}],["testnets",{"0":{"551":1},"1":{"552":1,"553":1,"554":1,"555":1},"2":{"82":1,"103":1,"430":1,"528":1,"551":1,"584":1,"784":1,"786":1}}],["testnet",{"0":{"91":1,"249":1,"318":1,"443":1,"467":1,"472":1,"501":1,"512":1,"546":1,"554":1,"555":1,"685":1},"1":{"250":1,"251":1,"252":1,"253":1,"254":1,"255":1,"256":1,"257":1,"258":1,"259":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"502":1,"503":1,"504":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1,"514":1,"515":1},"2":{"23":3,"26":1,"59":3,"60":1,"76":1,"81":2,"82":3,"84":5,"87":5,"90":1,"97":1,"136":1,"231":3,"244":1,"245":4,"249":2,"250":5,"251":1,"252":1,"254":3,"255":2,"256":1,"259":1,"283":1,"289":1,"297":1,"298":2,"301":1,"305":1,"318":1,"361":1,"402":1,"403":1,"422":4,"427":2,"429":11,"430":3,"432":1,"433":6,"434":8,"435":3,"439":1,"443":2,"445":1,"448":2,"453":1,"457":2,"465":1,"466":1,"467":2,"472":1,"474":1,"501":1,"507":3,"508":6,"509":6,"510":6,"512":1,"513":2,"514":8,"515":1,"528":1,"542":7,"544":1,"546":2,"554":2,"557":1,"558":1,"559":2,"561":1,"565":1,"619":1,"681":1,"685":4,"706":1,"737":1,"738":2,"764":2,"767":1,"784":2,"786":5}}],["telemetry",{"2":{"429":6}}],["telegram",{"2":{"39":2,"73":1,"277":1,"500":1,"515":1,"556":1}}],["tell",{"2":{"42":1}}],["tech",{"2":{"36":2,"38":1,"107":1,"489":1,"490":1,"491":1,"492":1}}],["technologies",{"2":{"42":1,"53":1,"481":1,"583":1}}],["technology",{"2":{"7":1,"36":1,"765":1}}],["technical",{"2":{"26":1,"30":1,"42":1}}],["though",{"2":{"649":1,"651":1}}],["thought",{"2":{"125":2}}],["thorough",{"2":{"185":1}}],["those",{"2":{"7":1,"13":1,"14":1,"33":1,"34":1,"40":3,"43":1,"125":1,"126":1,"139":1,"168":1,"199":1,"204":2,"266":1,"450":1,"501":1,"525":1,"537":1,"579":2,"580":1,"638":1,"640":1,"643":1,"717":1,"721":1}}],["thus",{"2":{"90":1,"91":1,"109":1,"111":1,"645":1,"649":3,"651":2}}],["thank",{"2":{"38":1,"81":1}}],["thanks",{"2":{"33":1,"108":1}}],["thanking",{"2":{"32":1}}],["than",{"2":{"24":1,"199":1,"226":1,"274":2,"281":1,"301":1,"329":1,"337":1,"455":1,"485":1,"580":1,"588":2,"589":1,"638":1,"673":1,"674":1,"677":2,"700":1,"722":1}}],["that",{"0":{"144":1,"163":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"187":1,"188":1,"189":1,"190":1,"192":1,"193":1,"633":1},"1":{"180":1,"181":1,"182":1,"184":1,"185":1,"188":1,"189":1,"191":1,"192":1,"193":1},"2":{"6":1,"7":1,"8":2,"18":1,"21":1,"23":4,"29":1,"30":1,"31":1,"34":2,"35":1,"36":1,"38":1,"42":1,"47":2,"58":3,"59":2,"67":1,"68":1,"86":3,"87":2,"89":1,"91":6,"93":2,"96":1,"104":2,"105":1,"107":1,"109":3,"110":4,"111":4,"117":2,"118":4,"120":2,"121":1,"122":13,"124":2,"125":18,"126":18,"127":4,"128":2,"130":6,"136":3,"137":3,"139":14,"141":1,"144":6,"145":2,"149":1,"154":13,"155":2,"156":1,"157":1,"160":9,"161":2,"163":12,"164":2,"165":3,"166":2,"167":1,"168":7,"169":1,"170":1,"172":1,"174":7,"175":8,"178":6,"179":6,"180":2,"182":1,"183":4,"185":1,"186":1,"187":4,"188":2,"191":3,"194":6,"197":2,"199":1,"202":6,"203":1,"204":3,"205":3,"206":1,"208":1,"209":1,"210":3,"211":1,"212":1,"214":1,"215":7,"216":1,"217":1,"218":1,"219":1,"221":1,"225":1,"227":4,"228":2,"233":3,"234":1,"235":1,"238":1,"244":1,"245":1,"248":1,"250":1,"251":1,"252":1,"255":1,"259":1,"266":5,"267":2,"275":5,"278":1,"281":3,"282":2,"284":1,"287":1,"289":2,"295":2,"298":1,"301":1,"303":1,"309":1,"310":1,"312":1,"313":4,"314":1,"316":1,"321":1,"322":6,"326":4,"331":1,"334":2,"336":1,"337":2,"338":4,"341":1,"344":1,"347":1,"355":1,"361":2,"367":1,"369":1,"373":1,"381":1,"383":1,"384":1,"387":1,"388":2,"391":1,"398":1,"399":1,"400":1,"404":3,"407":1,"408":1,"409":1,"413":3,"414":1,"415":1,"422":2,"425":1,"427":2,"428":2,"430":3,"432":2,"434":1,"435":1,"450":1,"452":2,"454":1,"455":1,"457":1,"459":1,"464":1,"466":1,"480":1,"481":1,"485":3,"494":1,"495":1,"501":1,"506":1,"507":3,"526":1,"528":1,"538":1,"541":1,"542":3,"544":2,"551":1,"557":1,"558":2,"559":2,"560":2,"561":1,"564":1,"565":1,"566":1,"568":1,"574":1,"576":1,"579":2,"580":2,"582":1,"583":3,"584":3,"588":1,"589":1,"590":3,"591":1,"592":5,"594":2,"599":6,"604":1,"616":1,"621":1,"622":4,"627":1,"629":4,"631":1,"632":1,"633":8,"634":2,"636":1,"637":1,"638":1,"639":1,"640":6,"641":1,"642":2,"643":3,"644":2,"645":1,"646":6,"648":4,"649":9,"650":4,"651":5,"652":4,"653":1,"662":1,"671":1,"672":5,"673":2,"674":2,"682":1,"690":1,"694":1,"697":1,"698":1,"700":3,"706":1,"711":1,"712":1,"717":1,"719":1,"721":1,"722":4,"737":1,"738":1,"740":5,"741":1,"742":1,"747":1,"757":1,"764":1,"765":2,"771":2,"772":1,"773":2,"775":1,"780":1,"784":5,"785":1,"786":1}}],["think",{"2":{"125":1}}],["things",{"0":{"641":1,"775":1},"2":{"93":2,"745":1}}],["third",{"2":{"22":4,"372":1,"402":1,"404":1,"412":1,"715":1}}],["this",{"0":{"638":1},"2":{"1":1,"2":2,"4":1,"8":1,"9":1,"11":1,"13":1,"14":1,"16":2,"22":4,"23":1,"26":1,"36":2,"37":3,"38":2,"39":1,"40":2,"41":1,"42":7,"43":1,"44":1,"46":1,"47":1,"49":1,"50":2,"51":2,"53":1,"54":2,"55":2,"57":1,"58":1,"63":1,"68":1,"69":1,"74":2,"77":1,"81":4,"83":1,"84":2,"85":4,"86":7,"87":4,"88":2,"90":3,"91":1,"92":2,"93":2,"94":1,"96":3,"104":2,"105":1,"109":3,"110":3,"111":1,"117":1,"122":5,"124":4,"125":8,"126":6,"127":3,"128":3,"130":1,"139":4,"140":1,"141":2,"145":1,"147":1,"151":1,"155":3,"156":3,"160":3,"163":4,"165":1,"166":1,"167":1,"169":1,"171":2,"174":5,"175":3,"179":3,"183":2,"186":1,"187":2,"193":1,"199":3,"200":1,"202":2,"204":1,"205":1,"208":2,"213":1,"214":5,"215":5,"217":1,"218":1,"219":1,"221":2,"227":2,"237":1,"238":2,"245":1,"250":1,"254":1,"266":3,"271":2,"275":7,"276":1,"279":4,"281":2,"283":2,"287":2,"289":1,"291":2,"294":1,"298":2,"302":1,"303":5,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"314":2,"315":3,"320":2,"321":2,"322":12,"324":2,"329":2,"331":3,"332":1,"334":1,"335":1,"337":5,"338":3,"341":4,"343":2,"350":2,"353":2,"356":1,"361":2,"363":1,"365":2,"367":1,"368":3,"370":1,"371":2,"373":1,"375":1,"376":1,"377":2,"378":1,"380":7,"381":3,"383":1,"385":1,"387":1,"388":2,"391":4,"392":1,"396":1,"397":2,"398":2,"400":2,"402":1,"408":1,"413":1,"414":1,"426":1,"427":2,"429":1,"432":2,"434":2,"439":2,"443":1,"445":1,"446":2,"449":1,"450":5,"455":3,"456":2,"457":2,"458":1,"459":1,"462":1,"471":1,"472":1,"474":1,"477":2,"480":1,"481":1,"485":1,"486":1,"495":1,"501":2,"509":1,"512":1,"517":1,"518":1,"520":1,"525":2,"526":1,"530":1,"533":3,"537":1,"538":1,"541":2,"542":5,"544":2,"549":1,"557":2,"558":1,"559":4,"560":5,"561":2,"563":2,"564":5,"565":1,"566":1,"568":1,"571":1,"574":2,"583":1,"584":1,"585":1,"588":2,"590":1,"591":3,"592":3,"593":3,"594":4,"599":10,"607":1,"609":1,"610":1,"612":1,"617":1,"622":2,"627":1,"629":1,"630":1,"631":1,"632":1,"633":2,"641":1,"644":2,"645":2,"646":2,"648":1,"649":4,"650":1,"651":2,"652":2,"653":2,"656":1,"671":1,"672":1,"673":2,"674":4,"682":1,"690":1,"695":1,"697":3,"699":1,"700":1,"706":1,"707":3,"708":1,"709":2,"711":2,"712":2,"713":1,"715":1,"717":1,"719":2,"721":1,"722":1,"730":1,"733":2,"736":1,"737":1,"739":1,"740":2,"743":2,"744":2,"745":1,"747":3,"752":1,"753":1,"754":2,"757":1,"760":1,"762":1,"765":2,"767":5,"770":1,"771":2,"773":1,"776":1,"777":1,"778":2,"780":2,"781":1,"783":1,"784":4}}],["thread",{"2":{"632":1}}],["threatening",{"2":{"8":1}}],["threshold",{"2":{"278":1,"279":2,"429":4,"590":1}}],["three",{"2":{"208":1,"229":1,"646":2,"649":1,"748":1}}],["throughput",{"2":{"221":1,"226":1,"227":1,"644":1,"649":2}}],["throughout",{"2":{"46":1,"765":1}}],["through",{"2":{"13":1,"32":1,"39":1,"80":1,"91":1,"93":2,"202":1,"234":1,"274":1,"275":1,"307":1,"310":1,"329":1,"414":1,"437":1,"458":1,"472":1,"530":1,"533":1,"591":1,"592":1,"606":1,"607":1,"610":1,"612":1,"616":1,"683":1,"692":1,"708":1,"765":1,"777":1}}],["theta",{"2":{"429":9,"430":2,"432":1,"433":6,"434":8,"435":3}}],["then",{"2":{"76":1,"77":1,"86":1,"87":1,"92":1,"109":1,"110":1,"124":2,"125":1,"127":2,"130":1,"139":5,"141":1,"148":1,"151":3,"156":1,"157":1,"162":1,"163":1,"164":1,"168":1,"174":1,"175":1,"179":2,"183":1,"191":3,"194":1,"197":1,"199":2,"202":3,"205":1,"208":1,"210":1,"211":2,"212":1,"214":1,"215":2,"216":1,"234":1,"235":2,"263":2,"266":2,"272":3,"275":3,"314":1,"321":2,"329":1,"334":1,"336":1,"352":1,"369":1,"371":1,"373":1,"383":1,"398":2,"407":1,"412":1,"450":1,"455":2,"557":1,"579":1,"588":1,"591":2,"592":1,"593":1,"594":1,"599":2,"601":1,"622":1,"627":1,"629":1,"643":2,"652":3,"662":1,"667":1,"670":1,"671":1,"702":1,"743":1,"747":1,"757":1,"764":1,"772":1,"773":3,"775":2,"776":1,"785":1,"786":1}}],["therefore",{"2":{"60":1,"126":1,"599":2,"629":1,"644":1}}],["there",{"0":{"640":1},"2":{"22":1,"36":1,"39":1,"44":1,"69":1,"72":1,"86":1,"130":1,"169":1,"183":1,"186":1,"199":1,"204":1,"215":1,"254":1,"266":3,"325":1,"370":1,"427":1,"455":1,"485":2,"497":1,"498":1,"500":1,"512":1,"514":1,"515":1,"530":1,"533":1,"556":1,"580":1,"582":1,"583":1,"586":1,"588":1,"590":1,"633":1,"634":2,"639":1,"640":1,"643":1,"644":1,"649":1,"719":1,"723":1,"745":1}}],["these",{"2":{"11":1,"13":1,"14":1,"29":1,"33":1,"34":1,"35":1,"39":1,"44":1,"64":1,"65":1,"67":1,"68":1,"87":1,"88":1,"90":1,"91":1,"122":2,"125":1,"126":2,"137":1,"139":1,"142":2,"147":1,"152":1,"156":1,"159":1,"168":1,"169":2,"171":1,"175":2,"182":1,"187":2,"194":1,"208":1,"211":2,"215":1,"218":1,"229":1,"233":1,"267":1,"275":2,"301":1,"312":1,"314":1,"342":2,"361":1,"371":1,"379":1,"381":1,"396":1,"398":2,"427":1,"443":1,"484":1,"485":1,"487":1,"494":1,"495":2,"505":1,"506":1,"507":1,"528":1,"580":1,"583":1,"586":1,"591":2,"593":1,"601":1,"622":1,"643":1,"649":2,"651":2,"674":1,"716":1,"722":1,"741":2,"748":1,"773":1}}],["they",{"2":{"7":1,"8":1,"11":1,"22":1,"34":1,"38":4,"39":2,"40":1,"41":1,"58":1,"60":1,"67":1,"68":1,"86":2,"88":1,"130":1,"142":1,"147":1,"152":1,"159":1,"169":1,"178":2,"179":2,"183":2,"216":1,"217":1,"252":1,"267":1,"281":3,"322":1,"371":1,"432":1,"449":1,"450":1,"452":1,"454":1,"459":2,"494":1,"495":1,"506":1,"507":1,"511":1,"530":1,"554":1,"579":2,"580":1,"582":1,"584":1,"590":1,"592":1,"594":3,"609":1,"611":1,"631":2,"633":2,"634":1,"640":1,"641":2,"644":1,"649":1,"674":1,"711":1,"712":1,"720":1,"740":1,"771":1,"780":1,"784":2}}],["their",{"2":{"7":1,"27":1,"30":1,"32":1,"34":2,"36":2,"37":2,"38":6,"39":3,"40":2,"41":2,"42":1,"47":1,"58":1,"59":1,"60":1,"67":1,"68":1,"86":2,"124":1,"139":1,"164":1,"165":3,"166":1,"173":1,"178":1,"179":1,"202":1,"217":1,"221":1,"249":1,"251":1,"275":2,"281":3,"321":1,"328":1,"348":1,"366":1,"371":1,"448":1,"450":3,"454":1,"455":1,"494":1,"495":1,"501":2,"506":1,"507":1,"526":1,"527":1,"528":1,"530":1,"537":1,"554":1,"574":1,"582":2,"583":2,"584":3,"590":1,"594":1,"611":1,"636":1,"640":1,"649":1,"650":2,"672":1,"674":4,"679":1,"690":3,"691":2,"724":1,"726":1,"730":1,"733":1}}],["theme",{"2":{"37":2}}],["them",{"2":{"2":1,"32":1,"34":1,"38":4,"39":1,"40":3,"41":3,"63":1,"104":1,"109":1,"121":1,"139":1,"156":3,"159":1,"164":1,"168":1,"172":1,"182":2,"203":2,"208":1,"211":2,"215":1,"217":1,"235":1,"281":1,"326":1,"334":1,"339":1,"371":1,"449":1,"450":1,"455":2,"486":1,"501":1,"507":1,"580":1,"642":1,"676":1,"728":1,"733":1,"771":1}}],["the",{"0":{"1":1,"17":1,"18":1,"30":1,"31":1,"32":1,"89":1,"90":1,"121":1,"130":1,"137":1,"138":1,"139":1,"146":1,"149":1,"154":2,"161":1,"163":1,"199":2,"201":1,"203":1,"204":2,"208":1,"209":1,"213":1,"214":1,"215":1,"218":1,"232":1,"241":1,"242":1,"244":1,"245":1,"246":1,"248":1,"250":1,"270":1,"285":1,"286":1,"287":1,"288":2,"295":1,"296":1,"297":2,"327":1,"335":1,"336":2,"348":1,"359":1,"361":1,"373":1,"379":1,"392":1,"393":1,"413":1,"418":1,"420":1,"421":1,"422":1,"423":1,"425":1,"426":1,"436":1,"449":1,"450":1,"453":1,"455":1,"464":1,"465":1,"468":1,"476":1,"477":1,"478":1,"539":1,"540":1,"548":1,"559":1,"560":1,"561":1,"566":1,"586":1,"594":1,"596":1,"597":1,"598":1,"599":1,"604":1,"617":1,"619":1,"620":1,"621":1,"622":1,"630":1,"633":1,"636":1,"637":1,"651":1,"666":1,"698":1,"748":1,"751":1,"769":1},"1":{"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"138":1,"139":1,"147":1,"148":1,"150":1,"155":2,"156":2,"157":2,"158":2,"159":2,"160":2,"161":2,"162":2,"163":2,"202":1,"203":1,"204":1,"205":3,"206":3,"207":3,"208":1,"209":2,"210":2,"211":1,"212":1,"214":1,"215":1,"233":1,"234":1,"235":1,"236":1,"243":1,"244":1,"245":1,"246":2,"247":2,"248":1,"286":1,"287":1,"288":1,"289":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"421":1,"422":1,"424":1,"456":1,"466":1,"467":1,"468":1,"469":2,"470":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"555":1,"556":1,"560":1,"567":1,"568":1,"569":1,"570":1,"571":1,"618":1,"619":1,"620":1,"621":2,"652":1,"699":1,"700":1,"701":1,"702":1,"703":1,"770":1,"771":1,"772":1,"773":1,"774":1,"775":1},"2":{"0":2,"1":2,"2":3,"3":2,"4":2,"7":4,"8":1,"9":1,"10":3,"11":1,"12":4,"13":2,"14":3,"15":1,"16":2,"18":5,"20":7,"21":3,"22":9,"23":17,"24":4,"25":3,"26":12,"27":3,"28":2,"29":1,"30":8,"31":4,"32":6,"33":2,"34":12,"35":4,"36":13,"37":15,"38":14,"39":9,"40":8,"41":7,"42":15,"43":2,"44":5,"46":5,"47":5,"48":2,"49":1,"50":2,"51":3,"53":4,"54":3,"55":3,"56":4,"57":1,"58":15,"59":2,"60":3,"63":5,"65":2,"67":1,"68":7,"70":2,"71":1,"73":2,"76":5,"77":7,"79":9,"80":6,"81":8,"84":6,"85":6,"86":40,"87":13,"88":7,"89":6,"90":12,"91":31,"92":2,"93":46,"94":3,"96":8,"97":5,"104":10,"105":2,"107":5,"108":3,"109":31,"110":18,"111":5,"112":14,"113":1,"116":1,"117":6,"118":7,"119":2,"120":4,"121":4,"122":34,"124":2,"125":54,"126":37,"127":25,"128":17,"130":34,"132":1,"133":2,"134":4,"136":11,"137":15,"139":27,"140":9,"141":8,"142":6,"143":2,"144":40,"145":10,"146":2,"147":10,"148":2,"149":5,"150":12,"151":9,"152":8,"153":6,"154":58,"155":9,"156":46,"157":12,"158":5,"159":24,"160":58,"161":26,"162":11,"163":65,"164":6,"165":3,"166":4,"167":4,"168":23,"169":15,"170":6,"171":8,"172":23,"173":3,"174":30,"175":47,"176":1,"178":4,"179":12,"180":6,"182":3,"183":23,"184":2,"185":5,"186":10,"187":29,"188":3,"190":2,"191":28,"193":1,"194":24,"196":1,"197":8,"199":31,"200":1,"201":4,"202":75,"203":23,"204":25,"205":9,"206":5,"208":16,"209":3,"210":51,"211":58,"212":6,"213":6,"214":24,"215":37,"216":9,"217":3,"218":13,"219":9,"221":11,"224":1,"225":4,"226":3,"227":20,"228":12,"229":2,"230":2,"231":3,"233":14,"234":9,"235":9,"236":1,"237":3,"238":13,"239":2,"240":1,"241":2,"243":3,"244":13,"245":9,"246":5,"247":5,"248":3,"249":1,"250":8,"252":4,"254":4,"255":2,"256":2,"257":1,"258":2,"259":1,"260":10,"261":3,"263":6,"266":22,"267":9,"268":1,"269":2,"270":1,"271":3,"272":3,"273":1,"274":7,"275":26,"276":4,"277":5,"278":3,"279":14,"281":20,"282":2,"283":2,"284":1,"286":2,"287":10,"288":1,"289":5,"291":4,"293":5,"294":15,"295":4,"296":3,"297":7,"298":3,"299":3,"300":1,"301":7,"302":4,"303":8,"304":1,"305":1,"308":3,"309":9,"310":1,"311":16,"312":10,"313":6,"314":2,"315":2,"316":6,"320":5,"321":11,"322":25,"324":3,"325":2,"326":8,"328":8,"329":4,"331":5,"332":3,"333":2,"334":4,"335":1,"336":8,"337":12,"338":13,"339":3,"341":15,"342":3,"343":10,"344":2,"345":3,"349":2,"350":3,"352":5,"353":3,"355":5,"356":2,"357":1,"358":1,"359":1,"360":1,"361":9,"363":1,"365":1,"366":1,"367":3,"368":5,"369":5,"370":6,"371":15,"372":5,"373":7,"376":1,"377":5,"378":3,"379":1,"380":6,"381":10,"383":6,"384":1,"385":1,"387":1,"388":8,"390":9,"391":7,"392":9,"393":2,"396":2,"398":5,"399":4,"400":6,"402":4,"403":2,"404":9,"405":8,"406":4,"407":6,"408":7,"409":2,"410":1,"412":4,"413":5,"414":1,"415":2,"416":2,"417":1,"418":1,"419":1,"421":1,"422":14,"423":5,"424":5,"425":2,"426":4,"427":5,"428":3,"429":5,"430":4,"431":5,"432":2,"433":2,"434":3,"435":2,"436":1,"437":5,"438":3,"439":1,"441":1,"442":1,"444":2,"445":5,"446":4,"447":2,"448":6,"449":6,"450":10,"451":4,"452":6,"453":3,"454":1,"455":15,"456":1,"457":3,"459":3,"460":1,"461":2,"462":1,"463":1,"464":4,"465":7,"466":10,"467":3,"468":5,"469":5,"470":2,"474":5,"476":2,"477":3,"478":7,"479":6,"480":6,"481":2,"484":2,"485":17,"486":6,"487":1,"489":1,"494":1,"495":6,"496":2,"497":1,"499":1,"500":2,"501":10,"505":1,"506":1,"507":3,"508":4,"509":5,"510":3,"511":2,"512":2,"513":1,"515":2,"518":3,"520":1,"521":4,"522":2,"524":1,"525":6,"526":6,"527":6,"528":8,"530":9,"532":4,"533":6,"536":1,"538":2,"539":8,"540":2,"541":1,"542":15,"544":5,"545":1,"546":3,"549":3,"552":1,"554":2,"556":2,"557":1,"558":9,"559":7,"560":12,"561":16,"563":5,"564":17,"565":17,"567":1,"568":7,"569":1,"570":1,"571":6,"572":1,"573":3,"574":3,"580":4,"582":6,"583":5,"584":6,"585":2,"586":10,"588":5,"589":1,"590":10,"591":26,"592":43,"593":6,"594":13,"597":1,"598":15,"599":48,"600":3,"601":15,"603":1,"604":1,"606":2,"607":4,"608":5,"609":2,"610":1,"611":1,"612":1,"613":1,"614":2,"615":1,"616":10,"617":3,"618":1,"619":3,"620":1,"621":3,"622":17,"623":1,"624":1,"625":2,"627":14,"629":14,"630":9,"631":2,"632":2,"633":4,"634":7,"635":2,"636":3,"638":5,"639":6,"641":2,"642":4,"643":18,"644":9,"645":17,"646":32,"648":26,"649":24,"650":10,"651":47,"652":32,"653":3,"656":1,"657":2,"658":2,"659":2,"661":1,"662":4,"663":2,"666":2,"667":1,"670":16,"671":3,"672":4,"673":6,"674":10,"676":3,"677":9,"679":1,"681":3,"682":11,"683":2,"684":2,"685":2,"687":1,"689":2,"690":2,"691":1,"692":2,"694":1,"695":2,"696":1,"697":3,"698":4,"699":4,"700":13,"701":1,"702":1,"705":1,"706":13,"707":11,"708":2,"709":5,"710":23,"711":2,"712":14,"713":15,"714":2,"715":1,"717":5,"718":2,"719":7,"720":2,"721":2,"722":5,"723":5,"724":6,"725":1,"726":4,"727":6,"728":5,"729":1,"730":2,"732":1,"733":5,"734":1,"736":2,"737":9,"738":16,"739":2,"740":18,"741":10,"742":8,"743":6,"744":4,"745":21,"746":1,"747":19,"748":13,"750":4,"751":6,"752":3,"754":4,"757":4,"758":1,"759":4,"760":4,"762":8,"763":1,"764":2,"765":7,"766":1,"767":11,"768":2,"770":2,"771":14,"772":15,"773":53,"774":6,"775":21,"776":4,"777":1,"778":5,"779":19,"780":12,"781":9,"782":2,"784":19,"785":3,"786":3}}],["todo",{"2":{"599":6,"712":2,"771":2,"772":3,"773":3,"775":1}}],["today",{"2":{"231":1,"271":2}}],["too",{"0":{"337":1},"2":{"337":3,"449":2}}],["tools",{"2":{"455":1}}],["toolset",{"2":{"204":1}}],["toolkit",{"0":{"51":1},"1":{"52":1,"53":1,"54":1,"55":1,"56":1,"57":1},"2":{"50":1,"51":1}}],["tool",{"2":{"49":1,"204":1,"260":2,"273":1,"381":1,"530":1,"542":1,"568":2}}],["toolings",{"2":{"321":1}}],["tooling",{"2":{"23":1,"166":1,"168":1,"184":1}}],["tomlvim",{"2":{"429":1}}],["tomldiscard",{"2":{"381":1}}],["tomlexternal",{"2":{"378":1}}],["tomlsed",{"2":{"377":1}}],["tomlseeds=$",{"2":{"361":2}}],["tomlrpc",{"2":{"371":1}}],["tomlpruning",{"2":{"367":1,"368":1}}],["tomlpersistent",{"2":{"361":3}}],["tomlmin",{"2":{"365":1}}],["tomlindexer",{"2":{"364":1,"366":1,"380":1}}],["toml`",{"2":{"361":2}}],["toml",{"0":{"303":1,"346":1,"349":1},"1":{"347":1,"348":1,"349":1,"350":2,"351":2,"352":2,"353":2,"354":2,"355":2},"2":{"274":1,"275":1,"303":8,"322":1,"338":3,"349":4,"361":7,"363":1,"365":1,"366":1,"367":1,"368":2,"371":2,"377":2,"378":1,"380":2,"381":2,"429":3,"431":1,"435":1,"451":1,"546":2,"559":2,"560":2,"571":1,"624":1}}],["tombstoned",{"2":{"24":1}}],["toattestationproof",{"2":{"160":2,"163":4}}],["torowproofs",{"2":{"159":2,"163":4}}],["torowroots",{"2":{"158":2,"163":4}}],["tonamespacenode",{"2":{"156":4,"158":2,"163":6}}],["tonamespacemerklemultiproofs",{"2":{"156":2,"163":4}}],["tosliceofbytes",{"2":{"150":2}}],["token=$",{"2":{"742":4,"744":2,"762":2}}],["tokencelestia",{"2":{"740":1}}],["tokenbridgeretryablesender",{"2":{"98":1,"99":1}}],["tokenbridgecreator",{"2":{"98":1,"99":1}}],["tokenbridgedeployment",{"2":{"93":2}}],["token",{"0":{"265":1,"438":1,"567":1,"694":1,"742":1,"744":1},"2":{"82":1,"84":2,"86":8,"88":1,"91":8,"93":13,"95":1,"265":1,"267":1,"328":1,"437":1,"438":3,"540":2,"567":2,"598":4,"653":1,"690":3,"709":4,"710":4,"711":4,"712":4,"713":4,"740":7,"741":9,"742":6,"743":3,"744":2,"745":4,"750":1,"762":3,"772":2,"773":2,"775":2,"778":4,"779":4,"780":4,"781":4}}],["tokens",{"0":{"269":1,"467":1,"658":1,"667":1},"2":{"7":1,"37":1,"69":2,"70":1,"82":1,"86":1,"87":1,"245":3,"265":1,"269":2,"294":1,"309":2,"422":3,"427":1,"430":2,"438":1,"466":1,"467":1,"512":3,"563":2,"564":1,"616":1,"622":1,"653":1,"658":1,"659":1,"663":1,"666":1,"668":1,"681":1,"682":6,"738":2,"757":1,"764":2,"767":2}}],["touch",{"2":{"58":1}}],["together",{"2":{"46":1,"275":1,"454":1,"643":1,"649":1,"651":1,"652":1}}],["topology",{"2":{"371":1}}],["topic",{"2":{"30":1,"36":1,"37":1,"266":1,"638":1}}],["topics",{"2":{"2":1,"30":1,"37":2,"42":2,"229":1,"566":1}}],["top",{"2":{"23":2,"58":1,"76":1,"287":1,"489":1,"490":1,"491":1,"498":1,"514":1,"601":1,"648":1,"649":1,"661":1,"724":1,"785":1,"786":1}}],["totaldifficulty",{"2":{"538":2}}],["total",{"2":{"20":1,"21":1,"142":2,"144":2,"147":2,"152":2,"159":3,"160":2,"163":4,"174":1,"297":4,"485":5,"588":2,"590":1,"591":2,"592":6,"677":1,"681":1,"687":1,"754":4}}],["towards",{"2":{"18":1,"24":1,"38":1,"281":1}}],["toward",{"2":{"7":1,"15":1}}],["to",{"0":{"53":1,"75":1,"77":1,"79":1,"106":1,"127":1,"133":1,"134":1,"144":1,"154":1,"165":1,"199":1,"220":1,"229":1,"247":1,"271":1,"283":1,"336":1,"363":1,"384":1,"424":1,"454":1,"469":1,"533":1,"545":1,"546":1,"587":1,"599":1,"600":1,"616":1,"641":1,"653":1,"707":1,"711":1,"712":1,"722":1,"737":1,"757":1,"780":1,"784":1,"785":1,"786":1},"1":{"76":1,"77":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"195":1,"196":1,"197":1,"198":1,"199":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"364":1,"365":1,"385":1,"386":1,"387":1,"455":1,"456":1,"457":1,"534":1,"535":1,"536":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1,"662":1,"663":1,"664":1,"665":1,"666":1,"667":1,"668":1},"2":{"0":2,"1":1,"2":4,"3":1,"6":3,"7":3,"8":3,"10":2,"13":1,"14":1,"16":1,"18":5,"20":5,"21":1,"22":1,"23":7,"24":3,"25":4,"26":5,"27":1,"29":3,"30":7,"31":1,"32":3,"33":2,"34":7,"35":4,"36":8,"37":14,"38":14,"39":10,"40":7,"41":14,"42":13,"43":1,"44":3,"46":4,"47":4,"48":2,"49":2,"50":2,"51":4,"53":2,"54":1,"55":1,"56":2,"57":1,"58":6,"60":3,"63":9,"64":1,"65":2,"67":3,"68":6,"69":1,"73":1,"74":1,"77":3,"79":7,"80":3,"81":3,"84":5,"85":7,"86":19,"87":10,"88":5,"90":15,"91":21,"92":2,"93":21,"94":1,"96":1,"97":1,"104":2,"105":3,"107":2,"108":2,"109":15,"110":6,"111":4,"112":8,"113":1,"116":1,"117":1,"118":6,"119":2,"120":1,"121":4,"122":21,"124":8,"125":23,"126":21,"127":8,"128":8,"130":13,"133":2,"134":1,"136":8,"137":5,"139":17,"140":5,"141":8,"142":4,"144":16,"145":5,"147":5,"151":8,"152":3,"154":27,"155":3,"156":12,"157":4,"159":7,"160":19,"161":10,"162":2,"163":22,"164":3,"165":4,"166":1,"168":24,"169":6,"170":3,"171":4,"172":5,"174":10,"175":18,"178":6,"179":6,"180":5,"182":2,"183":14,"184":1,"185":2,"186":3,"187":8,"188":1,"190":5,"191":5,"193":3,"194":8,"199":8,"200":2,"201":4,"202":44,"203":9,"204":11,"205":3,"206":4,"208":7,"210":14,"211":17,"212":3,"213":3,"214":7,"215":9,"216":5,"217":5,"218":1,"219":2,"221":5,"224":1,"225":1,"226":4,"227":17,"228":1,"230":1,"231":1,"233":3,"234":3,"235":5,"237":1,"238":5,"243":1,"244":7,"245":7,"246":1,"247":3,"249":2,"250":2,"251":2,"252":2,"254":3,"255":1,"256":2,"257":2,"258":1,"260":6,"263":4,"264":1,"265":6,"266":12,"267":10,"269":2,"273":2,"274":6,"275":23,"276":3,"277":4,"278":2,"279":8,"280":2,"281":10,"282":1,"283":3,"284":1,"287":1,"288":1,"289":3,"290":1,"291":2,"293":3,"294":8,"295":1,"297":1,"298":2,"299":3,"300":1,"301":6,"302":2,"303":3,"304":1,"305":2,"307":1,"308":2,"309":6,"310":1,"311":5,"312":4,"313":6,"314":1,"316":4,"320":10,"321":6,"322":8,"324":4,"325":2,"326":6,"328":2,"329":3,"331":2,"332":1,"333":3,"334":3,"336":4,"337":6,"338":5,"339":1,"341":1,"342":1,"343":2,"344":2,"345":2,"348":1,"350":1,"352":4,"353":3,"355":1,"356":2,"361":9,"363":2,"366":2,"367":2,"368":3,"369":2,"370":2,"371":8,"372":1,"373":4,"376":2,"377":3,"378":2,"379":1,"380":12,"381":9,"383":3,"384":1,"385":1,"386":1,"387":1,"388":10,"390":5,"391":9,"392":6,"393":2,"396":3,"397":1,"398":1,"399":4,"400":7,"402":3,"403":1,"404":4,"405":4,"406":3,"407":1,"408":1,"409":1,"410":1,"411":1,"412":2,"413":1,"414":1,"415":1,"422":14,"423":1,"424":3,"425":1,"426":2,"427":3,"428":2,"429":2,"430":7,"431":1,"432":2,"433":2,"434":4,"435":1,"437":2,"438":4,"439":4,"440":1,"441":1,"442":1,"443":2,"446":1,"448":3,"449":1,"450":4,"451":6,"452":2,"453":3,"454":4,"455":9,"457":1,"458":1,"459":1,"461":1,"465":6,"466":2,"467":2,"468":1,"469":3,"474":1,"476":1,"478":1,"479":1,"480":2,"481":2,"484":1,"485":2,"486":10,"487":1,"494":3,"495":7,"496":1,"500":2,"501":21,"505":1,"506":3,"507":4,"508":2,"509":2,"510":3,"511":1,"512":1,"515":2,"517":2,"518":1,"521":1,"522":2,"525":2,"526":4,"527":1,"528":2,"530":3,"533":3,"536":1,"539":5,"540":1,"541":1,"542":10,"544":7,"545":2,"546":7,"549":1,"552":3,"554":3,"556":2,"557":6,"558":4,"559":4,"560":8,"561":7,"563":2,"564":7,"565":5,"567":2,"568":2,"569":1,"570":1,"573":4,"574":2,"576":1,"579":3,"580":5,"582":6,"583":6,"584":4,"585":1,"586":7,"587":2,"588":3,"590":3,"591":4,"592":9,"594":8,"598":7,"599":26,"601":6,"603":1,"604":2,"606":1,"607":1,"608":1,"609":1,"611":2,"612":1,"616":7,"617":4,"619":2,"622":13,"623":1,"624":3,"625":1,"627":6,"629":7,"630":3,"631":4,"632":2,"633":3,"634":7,"635":1,"636":5,"639":7,"640":4,"642":7,"643":4,"644":3,"645":6,"646":6,"648":9,"649":8,"650":8,"651":11,"652":8,"653":2,"656":1,"661":2,"662":1,"665":1,"667":1,"668":1,"670":6,"672":2,"673":3,"674":18,"676":3,"677":4,"679":3,"680":3,"681":2,"682":9,"683":2,"684":1,"685":1,"689":1,"690":5,"691":2,"692":1,"697":1,"698":1,"699":1,"700":6,"702":1,"705":1,"706":7,"707":4,"709":7,"710":7,"711":5,"712":7,"713":2,"714":1,"716":2,"717":3,"719":2,"720":1,"722":3,"724":2,"726":3,"727":3,"728":4,"730":2,"732":2,"733":5,"737":9,"738":8,"739":2,"740":10,"741":3,"742":5,"743":6,"744":1,"745":8,"746":1,"747":9,"748":4,"750":1,"752":1,"753":1,"757":1,"758":1,"759":2,"760":2,"762":4,"763":2,"764":1,"765":7,"766":1,"767":5,"768":3,"770":1,"771":2,"772":6,"773":25,"774":3,"775":12,"776":8,"778":7,"779":7,"780":3,"781":4,"782":1,"783":4,"784":14,"785":4,"786":3}}]],"serializationVersion":2}';export{e as default}; diff --git a/pr-1815/assets/chunks/@localSearchIndexroot.ad8eddd0.js b/pr-1815/assets/chunks/@localSearchIndexroot.ad8eddd0.js deleted file mode 100644 index b03ddfe73..000000000 --- a/pr-1815/assets/chunks/@localSearchIndexroot.ad8eddd0.js +++ /dev/null @@ -1 +0,0 @@ -const e='{"documentCount":785,"nextId":785,"documentIds":{"0":"/docs-preview/pr-1815/README#celestia-documentation-site","1":"/docs-preview/pr-1815/README#building-the-site","2":"/docs-preview/pr-1815/README#contribution-guidelines","3":"/docs-preview/pr-1815/README#directory-structure","4":"/docs-preview/pr-1815/README#feedback-suggestions","5":"/docs-preview/pr-1815/community/coc#celestia-org-code-of-conduct","6":"/docs-preview/pr-1815/community/coc#our-pledge","7":"/docs-preview/pr-1815/community/coc#our-standards","8":"/docs-preview/pr-1815/community/coc#enforcement-responsibilities","9":"/docs-preview/pr-1815/community/coc#scope","10":"/docs-preview/pr-1815/community/coc#enforcement","11":"/docs-preview/pr-1815/community/coc#enforcement-guidelines","12":"/docs-preview/pr-1815/community/coc#_1-correction","13":"/docs-preview/pr-1815/community/coc#_2-warning","14":"/docs-preview/pr-1815/community/coc#_3-temporary-ban","15":"/docs-preview/pr-1815/community/coc#_4-permanent-ban","16":"/docs-preview/pr-1815/community/coc#attribution","17":"/docs-preview/pr-1815/community/foundation-delegation-program#the-celestia-foundation-delegation-program","18":"/docs-preview/pr-1815/community/foundation-delegation-program#objectives-of-the-program","19":"/docs-preview/pr-1815/community/foundation-delegation-program#foundation-delegation-process","20":"/docs-preview/pr-1815/community/foundation-delegation-program#program-launch","21":"/docs-preview/pr-1815/community/foundation-delegation-program#cohort-process","22":"/docs-preview/pr-1815/community/foundation-delegation-program#key-points","23":"/docs-preview/pr-1815/community/foundation-delegation-program#eligibility-criteria","24":"/docs-preview/pr-1815/community/foundation-delegation-program#undelegation-criteria","25":"/docs-preview/pr-1815/community/foundation-delegation-program#application","26":"/docs-preview/pr-1815/community/foundation-delegation-program#application-details","27":"/docs-preview/pr-1815/community/foundation-delegation-program#cohort-information","28":"/docs-preview/pr-1815/community/foundation-delegation-program#feedback-process","29":"/docs-preview/pr-1815/community/modular-meetup-guide#modular-meetup-guide","30":"/docs-preview/pr-1815/community/modular-meetup-guide#before-the-meetup","31":"/docs-preview/pr-1815/community/modular-meetup-guide#during-the-meetup","32":"/docs-preview/pr-1815/community/modular-meetup-guide#after-the-meetup","33":"/docs-preview/pr-1815/community/modular-meetup-guide#logistics-and-guidance","34":"/docs-preview/pr-1815/community/modular-meetup-guide#venue","35":"/docs-preview/pr-1815/community/modular-meetup-guide#catering-and-refreshments","36":"/docs-preview/pr-1815/community/modular-meetup-guide#audience","37":"/docs-preview/pr-1815/community/modular-meetup-guide#speakers","38":"/docs-preview/pr-1815/community/modular-meetup-guide#sponsors","39":"/docs-preview/pr-1815/community/modular-meetup-guide#communications-and-marketing","40":"/docs-preview/pr-1815/community/modular-meetup-guide#recording","41":"/docs-preview/pr-1815/community/modular-meetup-guide#utilizing-meetup-com-platform","42":"/docs-preview/pr-1815/community/modular-meetup-guide#onboarding-questions-for-community-members-joining-a-modular-meetup","43":"/docs-preview/pr-1815/community/modular-meetup-intro#celestia-modular-meetup-program","44":"/docs-preview/pr-1815/community/modular-meetup-intro#program-description","45":"/docs-preview/pr-1815/community/modular-meetup-intro#important-info","46":"/docs-preview/pr-1815/community/modular-meetup-intro#celestia-org-community-code-of-conduct","47":"/docs-preview/pr-1815/community/modular-meetup-intro#signup-form","48":"/docs-preview/pr-1815/community/modular-meetup-intro#emails","49":"/docs-preview/pr-1815/community/modular-meetup-intro#discord","50":"/docs-preview/pr-1815/community/modular-meetup-intro#materials","51":"/docs-preview/pr-1815/community/modular-meetup-toolkit#modular-meetup-toolkit","52":"/docs-preview/pr-1815/community/modular-meetup-toolkit#celestia-branding-guidelines","53":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-introduction-to-modularity-workshop-presentation","54":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-run-a-celestia-light-node-workshop-presentation","55":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-deploy-a-sovereign-rollup-workshop-presentation","56":"/docs-preview/pr-1815/community/modular-meetup-toolkit#sample-modular-meetup-introduction-workshop-presentation","57":"/docs-preview/pr-1815/community/modular-meetup-toolkit#swag-logistics","58":"/docs-preview/pr-1815/community/speaker-list#speaker-list","59":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#arabica-devnet","60":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#network-stability-and-upgrades","61":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#network-details","62":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#software-version-numbers","63":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#integrations","64":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#production-rpc-endpoints","65":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#community-rpc-endpoints","66":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#using-consensus-endpoints-with-da-nodes","67":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#data-availability-da-rpc-endpoints-for-bridge-node-sync","68":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#data-availability-da-grpc-endpoints-for-state-access","69":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#arabica-devnet-faucet","70":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#discord","71":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#web","72":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#explorers","73":"/docs-preview/pr-1815/how-to-guides/arabica-devnet#network-upgrades","74":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#bridging-in-and-out-of-your-orbit-rollup","75":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#bridge-in-deposit-to-your-rollup","76":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-1-add-your-custom-chain-config","77":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-2-deposit-to-your-orbit-rollup","78":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#bridge-out-withdrawal-from-your-rollup","79":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-1-choose-an-amount-to-withdraw-from-your-rollup","80":"/docs-preview/pr-1815/how-to-guides/arbitrum-bridge#step-2-claim-your-withdrawal","81":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#quickstart-deploy-an-arbitrum-orbit-rollup","82":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#prerequisites","83":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#setup","84":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-1-acquire-arbitrum-sepolia-eth","85":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-2-pick-your-deployment-type","86":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-3-configure-your-orbit-chain-s-deployment","87":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-4-review-deploy-your-orbit-chain","88":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-5-download-your-chain-s-configuration-files-and-launch-your-chain","89":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-6-clone-the-setup-script-repository-and-add-your-configuration-files","90":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-7-pick-an-l2-rpc-url-for-the-batch-poster","91":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-8-run-your-light-node-for-mocha-testnet","92":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-9-run-your-chain-s-node-and-block-explorer","93":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#step-10-finish-setting-up-your-chain","94":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#congratulations-with-celestia-underneath","95":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#appendix","96":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#compatibility-matrix","97":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#blobstream-x-contract-deployments","98":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#arbitrum-sepolia","99":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#base-sepolia","100":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#arbitrum-sepolia-additional-deployments","101":"/docs-preview/pr-1815/how-to-guides/arbitrum-deploy#base-sepolia-additional-deployments","102":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#running-a-full-node-and-or-validator","103":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#prerequisites","104":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#running-a-full-node","105":"/docs-preview/pr-1815/how-to-guides/arbitrum-full-node#running-a-full-node-with-validation","106":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#introduction-to-arbitrum-rollups-with-celestia-as-da","107":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#overview","108":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#key-components","109":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#da-provider-implementation","110":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#preimage-oracle-implementation","111":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#blobstream-x-implementation","112":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#ethereum-fallback-mechanism-in-nitro","113":"/docs-preview/pr-1815/how-to-guides/arbitrum-integration#next-steps","114":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#integrate-with-blobstream-contracts","115":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#getting-started","116":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#prerequisites","117":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#installing-blobstream-contracts","118":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#example-usage","119":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#data-structures","120":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#interface","121":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#querying-the-proof","122":"/docs-preview/pr-1815/how-to-guides/blobstream-contracts#verifying-data-inclusion-for-fraud-proofs","123":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#integrate-with-blobstream-client","124":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#blobstream-demo-rollup","125":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#defining-a-chain","126":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#rollup-sequencer","127":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#committing-to-data","128":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#creating-blocks","129":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#rollup-full-node","130":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#downloading-the-block","131":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#more-documentation","132":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#proving-inclusion-via-blobstream","133":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#submitting-block-data-to-celestia-via-light-node","134":"/docs-preview/pr-1815/how-to-guides/blobstream-offchain#posting-headers-to-ethereum","135":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#blobstream-proofs-queries","136":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#prerequisites","137":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#overview-of-the-proof-queries","138":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#the-celestia-square","139":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#the-commitment-scheme","140":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#hands-on-demonstration","141":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#_1-data-root-inclusion-proof","142":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#http-query","143":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client","144":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#full-example-of-proving-that-a-celestia-block-was-committed-to-by-blobstream-contract","145":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#_2-transaction-inclusion-proof","146":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#transaction-inclusion-proof-using-the-transaction-hash","147":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#http-request","148":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client-1","149":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#blob-inclusion-proof-using-the-corresponding-pfb-transaction-hash","150":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client-2","151":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#specific-share-range-inclusion-proof","152":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#http-request-1","153":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#golang-client-3","154":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#converting-the-proofs-to-be-usable-in-the-daverifier-library","155":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#data","156":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#shareproofs","157":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#namespace","158":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#rowroots","159":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#rowproofs","160":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#attestationproof","161":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#querying-the-proof-s-tuplerootnonce","162":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#listening-for-new-data-commitments","163":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#example-rollup-that-uses-the-daverifier","164":"/docs-preview/pr-1815/how-to-guides/blobstream-proof-queries#conclusion","165":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#introduction-to-blobstream-rollups","166":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#concepts","167":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment","168":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-proof-details","169":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-compact-proofs","170":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-pros","171":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#blob-share-commitment-cons","172":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans","173":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-proof-details","174":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-proving-unavailable-data","175":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-proving-inclusion-of-some-data","176":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-pros","177":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#sequence-of-spans-cons","178":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups","179":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans","180":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-pros","181":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-cons","182":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-example","183":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments","184":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-pros","185":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-cons","186":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups","187":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-sequence-of-spans","188":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-pros","189":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-cons","190":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-blob-share-commitments","191":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#protobuf-deserialization-inside-a-zk-circuit","192":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-pros","193":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-cons","194":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#heavy-merkle-proofs-usage","195":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#heavy-merkle-proofs-usage-pros","196":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#heavy-merkle-proofs-usage-cons","197":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#conclusion","198":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#faq","199":"/docs-preview/pr-1815/how-to-guides/blobstream-rollups#should-i-use-the-celestia-transaction-hash-to-reference-the-rollup-data","200":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#new-blobstream-x-deployments","201":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploying-the-contracts","202":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploy-a-new-succinctgateway","203":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploy-the-function-verifiers","204":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#register-the-function-verifier-in-the-deployed-succinctgateway","205":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#enable-prover-whitelisting","206":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#set-whitelist-status","207":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#add-custom-prover","208":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deploy-the-blobstreamx-contract","209":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#querying-the-trusted-hash","210":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#deployment-instructions","211":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#run-a-local-prover","212":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#run-a-proof-replayer-from-an-existing-deployment","213":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#optional-regenerating-the-downloaded-artifacts","214":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#regenerate-the-verifier-build","215":"/docs-preview/pr-1815/how-to-guides/blobstream-x-deploy#build-the-circuits-and-function-verifiers","216":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#requesting-data-commitment-ranges","217":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#local-proving","218":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#request-proofs-from-the-succinct-platform","219":"/docs-preview/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges#request-proofs-onchain","220":"/docs-preview/pr-1815/how-to-guides/blobstream#blobstream-streaming-modular-da-to-ethereum","221":"/docs-preview/pr-1815/how-to-guides/blobstream#what-is-blobstream","222":"/docs-preview/pr-1815/how-to-guides/blobstream#implementations-of-blobstream","223":"/docs-preview/pr-1815/how-to-guides/blobstream#blobstream-vs-data-availability-committees-dacs","224":"/docs-preview/pr-1815/how-to-guides/blobstream#decentralization-and-security","225":"/docs-preview/pr-1815/how-to-guides/blobstream#mechanism-of-verification","226":"/docs-preview/pr-1815/how-to-guides/blobstream#flexibility-and-scalability","227":"/docs-preview/pr-1815/how-to-guides/blobstream#what-is-sp1-blobstream","228":"/docs-preview/pr-1815/how-to-guides/blobstream#integrate-with-sp1-blobstream","229":"/docs-preview/pr-1815/how-to-guides/blobstream#how-to-integrate-with-blobstream","230":"/docs-preview/pr-1815/how-to-guides/blobstream#blobstream-rollups","231":"/docs-preview/pr-1815/how-to-guides/blobstream#deployed-contracts","232":"/docs-preview/pr-1815/how-to-guides/blobstreamx#blobstream-x-the-previous-zk-implementation-of-blobstream","233":"/docs-preview/pr-1815/how-to-guides/blobstreamx#what-is-blobstream-x","234":"/docs-preview/pr-1815/how-to-guides/blobstreamx#how-blobstream-x-works","235":"/docs-preview/pr-1815/how-to-guides/blobstreamx#deploy-blobstream-x","236":"/docs-preview/pr-1815/how-to-guides/blobstreamx#community-implementations","237":"/docs-preview/pr-1815/how-to-guides/bridge-node#setting-up-a-celestia-bridge-node","238":"/docs-preview/pr-1815/how-to-guides/bridge-node#overview-of-bridge-nodes","239":"/docs-preview/pr-1815/how-to-guides/bridge-node#hardware-requirements","240":"/docs-preview/pr-1815/how-to-guides/bridge-node#setting-up-your-bridge-node","241":"/docs-preview/pr-1815/how-to-guides/bridge-node#setup-the-dependencies","242":"/docs-preview/pr-1815/how-to-guides/bridge-node#deploy-the-celestia-bridge-node","243":"/docs-preview/pr-1815/how-to-guides/bridge-node#install-celestia-node","244":"/docs-preview/pr-1815/how-to-guides/bridge-node#initialize-the-bridge-node","245":"/docs-preview/pr-1815/how-to-guides/bridge-node#run-the-bridge-node","246":"/docs-preview/pr-1815/how-to-guides/bridge-node#optional-run-the-bridge-node-with-a-custom-key","247":"/docs-preview/pr-1815/how-to-guides/bridge-node#optional-migrate-node-id-to-another-server","248":"/docs-preview/pr-1815/how-to-guides/bridge-node#optional-start-the-bridge-node-with-systemd","249":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#bubs-testnet","250":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#built-with-the-op-stack-and-celestia","251":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#building-on-bubs","252":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#rpc-urls","253":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#https","254":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#wss","255":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#bridge","256":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#faucet","257":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#explorer","258":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#status","259":"/docs-preview/pr-1815/how-to-guides/bubs-testnet#next-steps","260":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#helpful-cli-commands","261":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#creating-a-wallet","262":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#key-management","263":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#importing-and-exporting-keys","264":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#querying-subcommands","265":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#token-management","266":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#governance","267":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#community-pool","268":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#claim-validator-rewards","269":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#delegate-undelegate-tokens","270":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#unjailing-the-validator","271":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#how-to-export-logs-with-systemd","272":"/docs-preview/pr-1815/how-to-guides/celestia-app-commands#signing-genesis-for-a-new-network","273":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#metrics","274":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#setup","275":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#visualization","276":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#node-exporter","277":"/docs-preview/pr-1815/how-to-guides/celestia-app-metrics#alerts","278":"/docs-preview/pr-1815/how-to-guides/celestia-app-multisig#multisig","279":"/docs-preview/pr-1815/how-to-guides/celestia-app-multisig#command-line","280":"/docs-preview/pr-1815/how-to-guides/celestia-app-multisig#resources","281":"/docs-preview/pr-1815/how-to-guides/celestia-app-slashing#jailing-and-slashing-on-celestia","282":"/docs-preview/pr-1815/how-to-guides/celestia-app-upgrade-monitor#upgrade-monitor","283":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#how-to-create-a-vesting-account-with-celestia-app","284":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#local-devnet","285":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#setting-up-the-local-devnet","286":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#run-the-devnet","287":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#save-the-home-directory-path","288":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#check-the-version-of-the-devnet","289":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#next-steps","290":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#setting-up-vesting-account-on-devnet","291":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-a-new-key","292":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#list-your-keys","293":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#set-variables","294":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-your-devnet-vesting-account","295":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#query-the-devnet-vesting-account-details","296":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#query-the-devnet-base-account-details","297":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#query-the-balances-of-the-devnet-accounts","298":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#mocha","299":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-a-wallet","300":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#fund-your-account","301":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#create-a-vesting-account-on-mocha","302":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#optional-set-up-a-consensus-node-or-validator","303":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#optional-change-your-client-toml","304":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#notes","305":"/docs-preview/pr-1815/how-to-guides/celestia-app-vesting#conclusion","306":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#create-a-wallet-with-celestia-app","307":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#prerequisites","308":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#create-a-wallet","309":"/docs-preview/pr-1815/how-to-guides/celestia-app-wallet#fund-a-wallet","310":"/docs-preview/pr-1815/how-to-guides/celestia-app#install-celestia-app","311":"/docs-preview/pr-1815/how-to-guides/celestia-app#building-binary-from-source","312":"/docs-preview/pr-1815/how-to-guides/celestia-app#installing-a-pre-built-binary","313":"/docs-preview/pr-1815/how-to-guides/celestia-app#ports","314":"/docs-preview/pr-1815/how-to-guides/celestia-node-custom-networks#custom-networks-and-values","315":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#celestia-node-metrics","316":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#running-metrics-flags","317":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#mainnet-beta","318":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#mocha-testnet","319":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#arabica-devnet","320":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#tls-connections","321":"/docs-preview/pr-1815/how-to-guides/celestia-node-metrics#metrics-endpoint-design-considerations","322":"/docs-preview/pr-1815/how-to-guides/celestia-node-store-structure#celestia-node-datastore","323":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#troubleshooting","324":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#network-selection","325":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#chain-id","326":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#ports","327":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#changing-the-location-of-your-node-store","328":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#background","329":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#demonstration","330":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#examples","331":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#mainnet-beta-full-and-mocha-light","332":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#mocha-full-and-arabica-light","333":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#using-a-custom-rpc-config-address","334":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#resetting-your-config","335":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#clearing-the-data-store","336":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#fatal-headers-given-to-the-heightsub-are-in-the-wrong-order","337":"/docs-preview/pr-1815/how-to-guides/celestia-node-troubleshooting#error-too-many-open-files","338":"/docs-preview/pr-1815/how-to-guides/celestia-node-trusted-hash#syncing-a-light-node-from-a-trusted-hash","339":"/docs-preview/pr-1815/how-to-guides/celestia-node-trusted-hash#for-service-operators","340":"/docs-preview/pr-1815/how-to-guides/celestia-node#install-celestia-node","341":"/docs-preview/pr-1815/how-to-guides/celestia-node#installing-from-source","342":"/docs-preview/pr-1815/how-to-guides/celestia-node#installing-a-pre-built-binary","343":"/docs-preview/pr-1815/how-to-guides/celestia-node#installation-options","344":"/docs-preview/pr-1815/how-to-guides/celestia-node#next-steps","345":"/docs-preview/pr-1815/how-to-guides/celestia-node#upgrading-your-binary","346":"/docs-preview/pr-1815/how-to-guides/config-toml#config-toml-guide","347":"/docs-preview/pr-1815/how-to-guides/config-toml#pre-requisites","348":"/docs-preview/pr-1815/how-to-guides/config-toml#viewing-the-help-menu","349":"/docs-preview/pr-1815/how-to-guides/config-toml#understanding-config-toml","350":"/docs-preview/pr-1815/how-to-guides/config-toml#core","351":"/docs-preview/pr-1815/how-to-guides/config-toml#p2p","352":"/docs-preview/pr-1815/how-to-guides/config-toml#bootstrap","353":"/docs-preview/pr-1815/how-to-guides/config-toml#mutual-peers","354":"/docs-preview/pr-1815/how-to-guides/config-toml#services","355":"/docs-preview/pr-1815/how-to-guides/config-toml#trustedhash-and-trustedpeer","356":"/docs-preview/pr-1815/how-to-guides/consensus-node#consensus-node","357":"/docs-preview/pr-1815/how-to-guides/consensus-node#minimum-hardware-requirements","358":"/docs-preview/pr-1815/how-to-guides/consensus-node#set-up-a-consensus-node","359":"/docs-preview/pr-1815/how-to-guides/consensus-node#set-up-the-dependencies","360":"/docs-preview/pr-1815/how-to-guides/consensus-node#install-celestia-app","361":"/docs-preview/pr-1815/how-to-guides/consensus-node#set-up-the-p2p-networks","362":"/docs-preview/pr-1815/how-to-guides/consensus-node#storage-and-pruning-configurations","363":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-connect-a-consensus-node-to-a-bridge-node","364":"/docs-preview/pr-1815/how-to-guides/consensus-node#enable-transaction-indexing","365":"/docs-preview/pr-1815/how-to-guides/consensus-node#retain-all-block-data","366":"/docs-preview/pr-1815/how-to-guides/consensus-node#query-transactions-by-hash","367":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-access-historical-state","368":"/docs-preview/pr-1815/how-to-guides/consensus-node#save-on-storage-requirements","369":"/docs-preview/pr-1815/how-to-guides/consensus-node#sync-types","370":"/docs-preview/pr-1815/how-to-guides/consensus-node#option-1-block-sync","371":"/docs-preview/pr-1815/how-to-guides/consensus-node#option-2-state-sync","372":"/docs-preview/pr-1815/how-to-guides/consensus-node#option-3-quick-sync","373":"/docs-preview/pr-1815/how-to-guides/consensus-node#start-the-consensus-node","374":"/docs-preview/pr-1815/how-to-guides/consensus-node#extra-resources-for-consensus-nodes","375":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-reset-network","376":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-configure-an-rpc-endpoint","377":"/docs-preview/pr-1815/how-to-guides/consensus-node#expose-rpc","378":"/docs-preview/pr-1815/how-to-guides/consensus-node#note-on-external-address","379":"/docs-preview/pr-1815/how-to-guides/consensus-node#restart-the-node","380":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-transaction-indexer-configuration-options","381":"/docs-preview/pr-1815/how-to-guides/consensus-node#optional-discard-abci-responses-configuration","382":"/docs-preview/pr-1815/how-to-guides/consensus-node#faq","383":"/docs-preview/pr-1815/how-to-guides/consensus-node#_2-3-committed-an-invalid-block-wrong-block-header-version","384":"/docs-preview/pr-1815/how-to-guides/decide-node#deciding-which-node-to-run","385":"/docs-preview/pr-1815/how-to-guides/decide-node#light-node","386":"/docs-preview/pr-1815/how-to-guides/decide-node#other-da-nodes","387":"/docs-preview/pr-1815/how-to-guides/decide-node#consensus-node","388":"/docs-preview/pr-1815/how-to-guides/docker-images#🐳-docker-setup","389":"/docs-preview/pr-1815/how-to-guides/docker-images#prerequisites","390":"/docs-preview/pr-1815/how-to-guides/docker-images#quick-start","391":"/docs-preview/pr-1815/how-to-guides/docker-images#light-node-setup-with-persistent-storage","392":"/docs-preview/pr-1815/how-to-guides/docker-images#initialize-the-node-store-and-key","393":"/docs-preview/pr-1815/how-to-guides/docker-images#start-the-node","394":"/docs-preview/pr-1815/how-to-guides/docker-images#video-walkthrough","395":"/docs-preview/pr-1815/how-to-guides/docker-images#_2-5-minute-version","396":"/docs-preview/pr-1815/how-to-guides/docker-images#troubleshooting","397":"/docs-preview/pr-1815/how-to-guides/environment#development-environment","398":"/docs-preview/pr-1815/how-to-guides/environment#install-dependencies","399":"/docs-preview/pr-1815/how-to-guides/environment#install-golang","400":"/docs-preview/pr-1815/how-to-guides/ethereum-fallback#ethereum-fallback","401":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#feegrant-module-for-blobs-submission","402":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#overview","403":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#pre-requisites","404":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#introduction","405":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#granting-fee-allowances-using-celestia-node","406":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#feegrant-module-implementation-in-celestia-node","407":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#grant-permission-for-an-allowance-as-a-granter","408":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#using-a-feegrant-allowance-as-a-grantee-in-celestia-node","409":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#checking-account-balances-after-submission","410":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-revoke-permission-for-a-feegrant-allowance-as-a-granter","411":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-submitting-a-blob-from-file-input","412":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-granting-fee-allowances-using-celestia-appd","413":"/docs-preview/pr-1815/how-to-guides/feegrant-for-blobs#optional-checking-the-granter-s-account","414":"/docs-preview/pr-1815/how-to-guides/full-storage-node#setting-up-a-celestia-full-storage-node","415":"/docs-preview/pr-1815/how-to-guides/full-storage-node#overview-of-full-storage-nodes","416":"/docs-preview/pr-1815/how-to-guides/full-storage-node#hardware-requirements","417":"/docs-preview/pr-1815/how-to-guides/full-storage-node#setting-up-your-full-storage-node","418":"/docs-preview/pr-1815/how-to-guides/full-storage-node#setup-the-dependencies","419":"/docs-preview/pr-1815/how-to-guides/full-storage-node#install-celestia-node","420":"/docs-preview/pr-1815/how-to-guides/full-storage-node#run-the-full-storage-node","421":"/docs-preview/pr-1815/how-to-guides/full-storage-node#initialize-the-full-storage-node","422":"/docs-preview/pr-1815/how-to-guides/full-storage-node#start-the-full-storage-node","423":"/docs-preview/pr-1815/how-to-guides/full-storage-node#optional-run-the-full-storage-node-with-a-custom-key","424":"/docs-preview/pr-1815/how-to-guides/full-storage-node#optional-migrate-node-id-to-another-server","425":"/docs-preview/pr-1815/how-to-guides/full-storage-node#optional-start-the-full-storage-node-with-systemd","426":"/docs-preview/pr-1815/how-to-guides/full-storage-node#stop-the-full-storage-node","427":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#ibc-relaying-guide","428":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#hermes","429":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#configuration","430":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#add-relayer-wallets","431":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#verify-configuration-files","432":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#create-a-connection-between-2-chains","433":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#create-clients","434":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#open-connection-over-new-clients","435":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#configure-channels-in-hermes","436":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#start-the-relayer","437":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#transfer","438":"/docs-preview/pr-1815/how-to-guides/ibc-relayer#token-filter","439":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#celestia-app-network-instantiation-guide","440":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#hardware-requirements","441":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#setup-dependencies","442":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#celestia-app-installation","443":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#spin-up-a-celestia-testnet","444":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#optional-reset-working-directory","445":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#initialize-a-working-directory","446":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#create-a-new-key","447":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#add-genesis-account-keyname","448":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#optional-adding-other-validators","449":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#create-the-genesis-transaction-for-new-chain","450":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#creating-the-genesis-json-file","451":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#modify-your-config-file","452":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#add-your-node-as-a-persistent-peer","453":"/docs-preview/pr-1815/how-to-guides/instantiate-testnet#instantiate-the-network","454":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#introduction-to-op-stack-integration","455":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#about-the-integration","456":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#github-repository","457":"/docs-preview/pr-1815/how-to-guides/intro-to-op-stack#next-steps","458":"/docs-preview/pr-1815/how-to-guides/light-node#setting-up-a-celestia-light-node","459":"/docs-preview/pr-1815/how-to-guides/light-node#overview-of-light-nodes","460":"/docs-preview/pr-1815/how-to-guides/light-node#hardware-requirements","461":"/docs-preview/pr-1815/how-to-guides/light-node#quickstart-run-a-light-node-in-your-browser","462":"/docs-preview/pr-1815/how-to-guides/light-node#setting-up-your-light-node","463":"/docs-preview/pr-1815/how-to-guides/light-node#install-celestia-node","464":"/docs-preview/pr-1815/how-to-guides/light-node#initialize-the-light-node","465":"/docs-preview/pr-1815/how-to-guides/light-node#start-the-light-node","466":"/docs-preview/pr-1815/how-to-guides/light-node#keys-and-wallets","467":"/docs-preview/pr-1815/how-to-guides/light-node#testnet-tokens","468":"/docs-preview/pr-1815/how-to-guides/light-node#optional-run-the-light-node-with-a-custom-key","469":"/docs-preview/pr-1815/how-to-guides/light-node#optional-migrate-node-id-to-another-server","470":"/docs-preview/pr-1815/how-to-guides/light-node#optional-start-light-node-with-systemd","471":"/docs-preview/pr-1815/how-to-guides/light-node#data-availability-sampling","472":"/docs-preview/pr-1815/how-to-guides/local-testnet#setting-up-a-celestia-local-testnet","473":"/docs-preview/pr-1815/how-to-guides/local-testnet#prerequisites","474":"/docs-preview/pr-1815/how-to-guides/local-testnet#starting-the-validator-node","475":"/docs-preview/pr-1815/how-to-guides/local-testnet#setting-up-the-bridge-node","476":"/docs-preview/pr-1815/how-to-guides/local-testnet#setting-up-the-light-node","477":"/docs-preview/pr-1815/how-to-guides/local-testnet#funding-and-testing","478":"/docs-preview/pr-1815/how-to-guides/mainnet#mainnet-beta","479":"/docs-preview/pr-1815/how-to-guides/mainnet#network-stability-and-upgrades","480":"/docs-preview/pr-1815/how-to-guides/mainnet#network-details","481":"/docs-preview/pr-1815/how-to-guides/mainnet#software-version-numbers","482":"/docs-preview/pr-1815/how-to-guides/mainnet#network-parameters","483":"/docs-preview/pr-1815/how-to-guides/mainnet#maximum-bytes","484":"/docs-preview/pr-1815/how-to-guides/mainnet#integrations","485":"/docs-preview/pr-1815/how-to-guides/mainnet#production-rpc-endpoints","486":"/docs-preview/pr-1815/how-to-guides/mainnet#consensus-nodes","487":"/docs-preview/pr-1815/how-to-guides/mainnet#community-consensus-rpc-endpoints","488":"/docs-preview/pr-1815/how-to-guides/mainnet#community-api-endpoints","489":"/docs-preview/pr-1815/how-to-guides/mainnet#community-grpc-endpoints","490":"/docs-preview/pr-1815/how-to-guides/mainnet#community-websocket-endpoints","491":"/docs-preview/pr-1815/how-to-guides/mainnet#data-availability-nodes","492":"/docs-preview/pr-1815/how-to-guides/mainnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","493":"/docs-preview/pr-1815/how-to-guides/mainnet#community-data-availability-da-grpc-endpoints-for-state-access","494":"/docs-preview/pr-1815/how-to-guides/mainnet#archival-da-rpc-endpoints","495":"/docs-preview/pr-1815/how-to-guides/mainnet#grove-archival-endpoints","496":"/docs-preview/pr-1815/how-to-guides/mainnet#explorers","497":"/docs-preview/pr-1815/how-to-guides/mainnet#analytics","498":"/docs-preview/pr-1815/how-to-guides/mainnet#network-upgrades","499":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#mocha-testnet","500":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#network-details","501":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#software-version-numbers","502":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#rpc-for-da-bridge-full-and-light-nodes","503":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#production-rpc-endpoints","504":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","505":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-data-availability-da-grpc-endpoints-for-state-access","506":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-rpc-endpoints","507":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-api-endpoints","508":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-grpc-endpoints","509":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#community-bridge-and-full-node-endpoints","510":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#mocha-testnet-faucet","511":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#analytics","512":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#explorers","513":"/docs-preview/pr-1815/how-to-guides/mocha-testnet#network-upgrades","514":"/docs-preview/pr-1815/how-to-guides/multiaccounts#multiaccounts-feature-for-blobs-submission","515":"/docs-preview/pr-1815/how-to-guides/multiaccounts#overview","516":"/docs-preview/pr-1815/how-to-guides/multiaccounts#running-a-node-with-a-different-default-key-name","517":"/docs-preview/pr-1815/how-to-guides/multiaccounts#submitting-blobs-with-a-different-signer-key-name","518":"/docs-preview/pr-1815/how-to-guides/multiaccounts#option-1-submit-passing-key-name","519":"/docs-preview/pr-1815/how-to-guides/multiaccounts#option-2-submit-passing-signer-address","520":"/docs-preview/pr-1815/how-to-guides/multiaccounts#key-management","521":"/docs-preview/pr-1815/how-to-guides/multiaccounts#creating-a-new-key","522":"/docs-preview/pr-1815/how-to-guides/multiaccounts#importing-an-existing-key","523":"/docs-preview/pr-1815/how-to-guides/multiaccounts#optional-flags-for-write-transactions","524":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#celestia-network-upgrade-process","525":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#network-upgrade-coordination","526":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#upgrade-process","527":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#upcoming-upgrade","528":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#ginger-network-upgrade","529":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#past-upgrades","530":"/docs-preview/pr-1815/how-to-guides/network-upgrade-process#lemongrass-network-upgrade","531":"/docs-preview/pr-1815/how-to-guides/nodes-overview#overview-to-running-nodes-on-celestia","532":"/docs-preview/pr-1815/how-to-guides/nodes-overview#recommended-celestia-node-requirements","533":"/docs-preview/pr-1815/how-to-guides/nodes-overview#data-availability-nodes","534":"/docs-preview/pr-1815/how-to-guides/nodes-overview#consensus-nodes","535":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#optimism-devnet-deep-dive","536":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#find-a-transaction","537":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#read-the-transaction-call-data","538":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#find-the-data-on-celestia","539":"/docs-preview/pr-1815/how-to-guides/optimism-devnet#span-batches","540":"/docs-preview/pr-1815/how-to-guides/optimism#run-an-op-stack-rollup-with-celestia-underneath","541":"/docs-preview/pr-1815/how-to-guides/optimism#dependency-setup","542":"/docs-preview/pr-1815/how-to-guides/optimism#setting-up-your-light-node","543":"/docs-preview/pr-1815/how-to-guides/optimism#deploying-a-devnet-to-mocha","544":"/docs-preview/pr-1815/how-to-guides/optimism#deploying-a-testnet-to-an-l1-or-l2-and-mocha","545":"/docs-preview/pr-1815/how-to-guides/optimism#congratulations","546":"/docs-preview/pr-1815/how-to-guides/participate#participate-in-the-celestia-networks","547":"/docs-preview/pr-1815/how-to-guides/participate#mainnet-beta","548":"/docs-preview/pr-1815/how-to-guides/participate#compatible-software-versions-for-mainnet-beta","549":"/docs-preview/pr-1815/how-to-guides/participate#testnets","550":"/docs-preview/pr-1815/how-to-guides/participate#arabica-devnet","551":"/docs-preview/pr-1815/how-to-guides/participate#compatible-software-versions-for-arabica-devnet","552":"/docs-preview/pr-1815/how-to-guides/participate#mocha-testnet","553":"/docs-preview/pr-1815/how-to-guides/participate#compatible-software-versions-for-mocha-testnet","554":"/docs-preview/pr-1815/how-to-guides/participate#network-upgrades","555":"/docs-preview/pr-1815/how-to-guides/quick-start#quick-start-guide","556":"/docs-preview/pr-1815/how-to-guides/quick-start#run-a-light-node","557":"/docs-preview/pr-1815/how-to-guides/quick-start#initialize-the-light-node","558":"/docs-preview/pr-1815/how-to-guides/quick-start#set-the-trusted-hash","559":"/docs-preview/pr-1815/how-to-guides/quick-start#start-the-light-node","560":"/docs-preview/pr-1815/how-to-guides/quick-start#post-and-retrieve-data-with-your-light-node","561":"/docs-preview/pr-1815/how-to-guides/quick-start#funding-your-light-node","562":"/docs-preview/pr-1815/how-to-guides/quick-start#posting-data","563":"/docs-preview/pr-1815/how-to-guides/quick-start#retrieving-data","564":"/docs-preview/pr-1815/how-to-guides/quick-start#diving-deeper-into-the-stack","565":"/docs-preview/pr-1815/how-to-guides/quick-start#get-your-auth-token","566":"/docs-preview/pr-1815/how-to-guides/quick-start#key-management-with-cel-key","567":"/docs-preview/pr-1815/how-to-guides/quick-start#rust-client-tutorial","568":"/docs-preview/pr-1815/how-to-guides/quick-start#golang-client-tutorial","569":"/docs-preview/pr-1815/how-to-guides/quick-start#node-store-contents","570":"/docs-preview/pr-1815/how-to-guides/quick-start#troubleshooting","571":"/docs-preview/pr-1815/how-to-guides/quick-start#next-steps","572":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#rollup-stacks","573":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#quickstart-building-on-celestia","574":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#choose-a-framework","575":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#rollups-as-a-service","576":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#smart-contracts","577":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#what-is-a-rollup","578":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#what-is-a-modular-blockchain","579":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#benefits-of-modular-blockchains","580":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#ease-of-deploying-a-chain","581":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#scaling","582":"/docs-preview/pr-1815/how-to-guides/rollup-stacks#customizability","583":"/docs-preview/pr-1815/how-to-guides/sp1-blobstream-deploy#new-sp1-blobstream-deployments","584":"/docs-preview/pr-1815/how-to-guides/sp1-blobstream-deploy#deploying-the-contracts","585":"/docs-preview/pr-1815/how-to-guides/submit-data#submitting-data-blobs-to-celestia","586":"/docs-preview/pr-1815/how-to-guides/submit-data#maximum-blob-size","587":"/docs-preview/pr-1815/how-to-guides/submit-data#fee-market-and-mempool","588":"/docs-preview/pr-1815/how-to-guides/submit-data#fees-and-gas-limits","589":"/docs-preview/pr-1815/how-to-guides/submit-data#estimating-pfb-gas","590":"/docs-preview/pr-1815/how-to-guides/submit-data#gas-fee-calculation","591":"/docs-preview/pr-1815/how-to-guides/submit-data#estimating-gas-programmatically","592":"/docs-preview/pr-1815/how-to-guides/submit-data#submitting-multiple-transactions-in-one-block-from-the-same-account","593":"/docs-preview/pr-1815/how-to-guides/submit-data#api","594":"/docs-preview/pr-1815/how-to-guides/submit-data#the-celestia-app-consensus-node-cli","595":"/docs-preview/pr-1815/how-to-guides/submit-data#the-celestia-node-light-node-cli","596":"/docs-preview/pr-1815/how-to-guides/submit-data#the-celestia-node-api-golang-client","597":"/docs-preview/pr-1815/how-to-guides/submit-data#grpc-to-a-consensus-node-via-the-user-package","598":"/docs-preview/pr-1815/how-to-guides/submit-data#rpc-to-a-celestia-node","599":"/docs-preview/pr-1815/how-to-guides/submit-data#post-a-blob-directly-from-celenium","600":"/docs-preview/pr-1815/how-to-guides/systemd#setting-up-your-node-as-a-background-process-with-systemd","601":"/docs-preview/pr-1815/how-to-guides/systemd#consensus-nodes","602":"/docs-preview/pr-1815/how-to-guides/systemd#start-the-celestia-app-with-systemd","603":"/docs-preview/pr-1815/how-to-guides/systemd#data-availability-nodes","604":"/docs-preview/pr-1815/how-to-guides/systemd#celestia-full-storage-node","605":"/docs-preview/pr-1815/how-to-guides/systemd#celestia-bridge-node","606":"/docs-preview/pr-1815/how-to-guides/systemd#celestia-light-node","607":"/docs-preview/pr-1815/how-to-guides/transaction-resubmission#transaction-resubmission","608":"/docs-preview/pr-1815/how-to-guides/transaction-resubmission#monitoring-and-resubmission","609":"/docs-preview/pr-1815/how-to-guides/transaction-resubmission#notes","610":"/docs-preview/pr-1815/how-to-guides/validator-node#setting-up-a-celestia-validator-node","611":"/docs-preview/pr-1815/how-to-guides/validator-node#hardware-requirements","612":"/docs-preview/pr-1815/how-to-guides/validator-node#setting-up-a-validator-node","613":"/docs-preview/pr-1815/how-to-guides/validator-node#wallet","614":"/docs-preview/pr-1815/how-to-guides/validator-node#delegate-stake-to-a-validator","615":"/docs-preview/pr-1815/how-to-guides/validator-node#optional-deploy-the-celestia-node","616":"/docs-preview/pr-1815/how-to-guides/validator-node#install-celestia-node","617":"/docs-preview/pr-1815/how-to-guides/validator-node#initialize-the-bridge-node","618":"/docs-preview/pr-1815/how-to-guides/validator-node#run-the-bridge-node","619":"/docs-preview/pr-1815/how-to-guides/validator-node#optional-start-the-bridge-node-with-systemd","620":"/docs-preview/pr-1815/how-to-guides/validator-node#run-the-validator-node","621":"/docs-preview/pr-1815/how-to-guides/validator-node#submit-your-validator-information","622":"/docs-preview/pr-1815/how-to-guides/validator-node#optional-transaction-indexer-configuration-options","623":"/docs-preview/pr-1815/how-to-guides/validator-node#additional-resources","624":"/docs-preview/pr-1815/how-to-guides/validator-node#faq","625":"/docs-preview/pr-1815/how-to-guides/validator-node#_2-3-committed-an-invalid-block-wrong-block-header-version","626":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#data-availability-faq","627":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-data-availability","628":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-the-data-availability-problem","629":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#how-do-nodes-verify-data-availability-in-celestia","630":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-data-availability-sampling","631":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-are-some-of-the-security-assumptions-that-celestia-makes-for-data-availability-sampling","632":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#why-is-block-reconstruction-necessary-for-security","633":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-data-storage","634":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-the-problem-around-data-storage","635":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-is-the-difference-between-data-availability-and-data-storage","636":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#where-does-blockchain-state-fit-into-this","637":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#why-doesn-t-celestia-incentivize-storage-of-historical-data","638":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#who-may-store-historical-data-if-there-is-no-reward","639":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-faq#what-are-some-things-blockchains-can-do-to-provide-stronger-assurances-of-data-retrievability","640":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#celestia-s-data-availability-layer","641":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#data-availability-sampling-das","642":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#scalability","643":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#fraud-proofs-of-incorrectly-extended-data","644":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#namespaced-merkle-trees-nmts","645":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#building-a-pos-blockchain-for-da","646":"/docs-preview/pr-1815/learn/how-celestia-works/data-availability-layer#providing-data-availability","647":"/docs-preview/pr-1815/learn/how-celestia-works/monolithic-vs-modular#monolithic-vs-modular-blockchains","648":"/docs-preview/pr-1815/learn/how-celestia-works/overview#introduction","649":"/docs-preview/pr-1815/learn/how-celestia-works/transaction-lifecycle#the-lifecycle-of-a-celestia-app-transaction","650":"/docs-preview/pr-1815/learn/how-celestia-works/transaction-lifecycle#checking-data-availability","651":"/docs-preview/pr-1815/learn/how-to-stake-tia#how-to-stake-tia","652":"/docs-preview/pr-1815/learn/how-to-stake-tia#select-your-preferred-wallet","653":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-tia-with-keplr-wallet","654":"/docs-preview/pr-1815/learn/how-to-stake-tia#open-your-keplr-browser-extension","655":"/docs-preview/pr-1815/learn/how-to-stake-tia#select-celestia-network-and-search-for-a-validator","656":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-your-tia-tokens","657":"/docs-preview/pr-1815/learn/how-to-stake-tia#confirm-and-manage-your-tia","658":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-tia-with-leap-wallet","659":"/docs-preview/pr-1815/learn/how-to-stake-tia#open-your-leap-browser-extension","660":"/docs-preview/pr-1815/learn/how-to-stake-tia#select-a-validator-and-stake-tia","661":"/docs-preview/pr-1815/learn/how-to-stake-tia#confirm-and-manage-your-tia-1","662":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-tia-with-gem-wallet","663":"/docs-preview/pr-1815/learn/how-to-stake-tia#open-your-gem-wallet-app","664":"/docs-preview/pr-1815/learn/how-to-stake-tia#choose-the-amount-of-celestia-and-search-for-a-validator","665":"/docs-preview/pr-1815/learn/how-to-stake-tia#stake-your-tia-tokens-1","666":"/docs-preview/pr-1815/learn/how-to-stake-tia#manage-your-tia","667":"/docs-preview/pr-1815/learn/paying-for-blobspace#paying-for-blobspace","668":"/docs-preview/pr-1815/learn/paying-for-blobspace#payforblobs-transactions","669":"/docs-preview/pr-1815/learn/paying-for-blobspace#fee-market-overview","670":"/docs-preview/pr-1815/learn/retrievability#data-retrievability-and-pruning","671":"/docs-preview/pr-1815/learn/retrievability#data-retrievability-and-pruning-in-celestia-node","672":"/docs-preview/pr-1815/learn/retrievability#suggested-practices-for-rollups","673":"/docs-preview/pr-1815/learn/staking-governance-supply#staking-governance-supply","674":"/docs-preview/pr-1815/learn/staking-governance-supply#proof-of-stake-on-celestia","675":"/docs-preview/pr-1815/learn/staking-governance-supply#inflation","676":"/docs-preview/pr-1815/learn/staking-governance-supply#decentralised-governance","677":"/docs-preview/pr-1815/learn/staking-governance-supply#network-parameters","678":"/docs-preview/pr-1815/learn/staking-governance-supply#community-pool","679":"/docs-preview/pr-1815/learn/staking-governance-supply#tia-allocation-at-genesis","680":"/docs-preview/pr-1815/learn/staking-governance-supply#unlocks","681":"/docs-preview/pr-1815/learn/staking#staking-on-celestia","682":"/docs-preview/pr-1815/learn/staking#mainnet-beta","683":"/docs-preview/pr-1815/learn/staking#mocha-testnet","684":"/docs-preview/pr-1815/learn/tia#overview-of-tia","685":"/docs-preview/pr-1815/learn/tia#tia-at-a-glance","686":"/docs-preview/pr-1815/learn/tia#role-of-tia","687":"/docs-preview/pr-1815/learn/tia#paying-for-blobspace","688":"/docs-preview/pr-1815/learn/tia#bootstrapping-new-rollups","689":"/docs-preview/pr-1815/learn/tia#proof-of-stake","690":"/docs-preview/pr-1815/learn/tia#decentralised-governance","691":"/docs-preview/pr-1815/learn/tia#denominations","692":"/docs-preview/pr-1815/learn/tia#tia-display-token","693":"/docs-preview/pr-1815/learn/tia#utia-staking-denomination","694":"/docs-preview/pr-1815/learn/tia#microtia-staking-denomination-alias","695":"/docs-preview/pr-1815/tutorials/celestia-node-key#create-a-wallet-with-celestia-node","696":"/docs-preview/pr-1815/tutorials/celestia-node-key#using-the-cel-key-utility","697":"/docs-preview/pr-1815/tutorials/celestia-node-key#installation","698":"/docs-preview/pr-1815/tutorials/celestia-node-key#steps-for-generating-node-keys","699":"/docs-preview/pr-1815/tutorials/celestia-node-key#steps-for-exporting-node-keys","700":"/docs-preview/pr-1815/tutorials/celestia-node-key#steps-for-importing-node-keys","701":"/docs-preview/pr-1815/tutorials/celestia-node-key#view-all-options-for-cel-key","702":"/docs-preview/pr-1815/tutorials/celestia-node-key#docker-and-cel-key","703":"/docs-preview/pr-1815/tutorials/celestia-node-key#prerequisites","704":"/docs-preview/pr-1815/tutorials/celestia-node-key#running-your-node","705":"/docs-preview/pr-1815/tutorials/celestia-node-key#mounting-existing-keys-to-container","706":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#golang-client-library","707":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#project-setup","708":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#submitting-and-retrieving-blobs","709":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#subscribing-to-new-blobs","710":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#subscribing-to-new-headers","711":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#fetching-an-extended-data-square-eds","712":"/docs-preview/pr-1815/tutorials/golang-client-tutorial#api-documentation","713":"/docs-preview/pr-1815/tutorials/integrate-celestia#integrate-celestia-for-service-providers","714":"/docs-preview/pr-1815/tutorials/integrate-celestia#getting-started","715":"/docs-preview/pr-1815/tutorials/integrate-celestia#celestia-service-provider-notes","716":"/docs-preview/pr-1815/tutorials/integrate-celestia#custody-and-key-management","717":"/docs-preview/pr-1815/tutorials/integrate-celestia#rpc-and-querying","718":"/docs-preview/pr-1815/tutorials/integrate-celestia#compatibility","719":"/docs-preview/pr-1815/tutorials/integrate-celestia#syncing","720":"/docs-preview/pr-1815/tutorials/integrate-celestia#notable-exceptions-relative-to-other-blockchains","721":"/docs-preview/pr-1815/tutorials/node-api#node-api","722":"/docs-preview/pr-1815/tutorials/node-api#rpc-api","723":"/docs-preview/pr-1815/tutorials/node-api#library","724":"/docs-preview/pr-1815/tutorials/node-api#rpc","725":"/docs-preview/pr-1815/tutorials/node-api#rpc-api-tutorial","726":"/docs-preview/pr-1815/tutorials/node-api#gateway-api","727":"/docs-preview/pr-1815/tutorials/node-api#gateway-api-tutorial","728":"/docs-preview/pr-1815/tutorials/node-tutorial#celestia-node-rpc-cli-tutorial","729":"/docs-preview/pr-1815/tutorials/node-tutorial#introduction","730":"/docs-preview/pr-1815/tutorials/node-tutorial#blobs","731":"/docs-preview/pr-1815/tutorials/node-tutorial#namespaces","732":"/docs-preview/pr-1815/tutorials/node-tutorial#hardware-requirements","733":"/docs-preview/pr-1815/tutorials/node-tutorial#setting-up-dependencies","734":"/docs-preview/pr-1815/tutorials/node-tutorial#instantiate-a-celestia-light-node","735":"/docs-preview/pr-1815/tutorials/node-tutorial#connect-to-a-core-endpoint","736":"/docs-preview/pr-1815/tutorials/node-tutorial#keys-and-wallets","737":"/docs-preview/pr-1815/tutorials/node-tutorial#rpc-cli-guide","738":"/docs-preview/pr-1815/tutorials/node-tutorial#command-formatting","739":"/docs-preview/pr-1815/tutorials/node-tutorial#basic-flags","740":"/docs-preview/pr-1815/tutorials/node-tutorial#auth-token","741":"/docs-preview/pr-1815/tutorials/node-tutorial#node-store","742":"/docs-preview/pr-1815/tutorials/node-tutorial#auth-token-on-custom-or-private-network","743":"/docs-preview/pr-1815/tutorials/node-tutorial#submitting-data","744":"/docs-preview/pr-1815/tutorials/node-tutorial#optional-submit-with-curl","745":"/docs-preview/pr-1815/tutorials/node-tutorial#retrieving-data","746":"/docs-preview/pr-1815/tutorials/node-tutorial#setting-the-gas-price","747":"/docs-preview/pr-1815/tutorials/node-tutorial#examples","748":"/docs-preview/pr-1815/tutorials/node-tutorial#check-your-balance","749":"/docs-preview/pr-1815/tutorials/node-tutorial#check-the-balance-of-another-address","750":"/docs-preview/pr-1815/tutorials/node-tutorial#get-your-node-id","751":"/docs-preview/pr-1815/tutorials/node-tutorial#get-your-account-address","752":"/docs-preview/pr-1815/tutorials/node-tutorial#get-block-header-by-height","753":"/docs-preview/pr-1815/tutorials/node-tutorial#combined-commands","754":"/docs-preview/pr-1815/tutorials/node-tutorial#get-data-availability-sampler-stats","755":"/docs-preview/pr-1815/tutorials/node-tutorial#transfer-balance-of-utia-to-another-account","756":"/docs-preview/pr-1815/tutorials/node-tutorial#api-version","757":"/docs-preview/pr-1815/tutorials/node-tutorial#help","758":"/docs-preview/pr-1815/tutorials/node-tutorial#advanced-example","759":"/docs-preview/pr-1815/tutorials/node-tutorial#additional-resources","760":"/docs-preview/pr-1815/tutorials/node-tutorial#submitting-a-blob-using-curl","761":"/docs-preview/pr-1815/tutorials/node-tutorial#post-an-svg-as-a-pfb","762":"/docs-preview/pr-1815/tutorials/node-tutorial#troubleshooting","763":"/docs-preview/pr-1815/tutorials/prompt-scavenger#prompt-scavenger","764":"/docs-preview/pr-1815/tutorials/prompt-scavenger#dependencies","765":"/docs-preview/pr-1815/tutorials/prompt-scavenger#install-celestia-node-and-run-a-light-node","766":"/docs-preview/pr-1815/tutorials/prompt-scavenger#openai-key","767":"/docs-preview/pr-1815/tutorials/prompt-scavenger#building-the-prompt-scavenger","768":"/docs-preview/pr-1815/tutorials/prompt-scavenger#initialize-your-go-project","769":"/docs-preview/pr-1815/tutorials/prompt-scavenger#build-your-import-statements","770":"/docs-preview/pr-1815/tutorials/prompt-scavenger#main-function","771":"/docs-preview/pr-1815/tutorials/prompt-scavenger#utility-functions","772":"/docs-preview/pr-1815/tutorials/prompt-scavenger#prompting-chatgpt","773":"/docs-preview/pr-1815/tutorials/prompt-scavenger#wrapping-things-up","774":"/docs-preview/pr-1815/tutorials/prompt-scavenger#next-steps","775":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#rust-client-library","776":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#project-setup","777":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#submitting-and-retrieving-blobs","778":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#subscribing-to-new-headers","779":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#fetching-an-extended-data-square-eds","780":"/docs-preview/pr-1815/tutorials/rust-client-tutorial#api-documentation","781":"/docs-preview/pr-1815/tutorials/wallets#wallet-integrations-with-celestia","782":"/docs-preview/pr-1815/tutorials/wallets#add-celestia-network-parameters-to-keplr-with-react","783":"/docs-preview/pr-1815/tutorials/wallets#adding-a-custom-chain-to-leap","784":"/docs-preview/pr-1815/tutorials/wallets#adding-a-custom-chain-to-cosmostation"},"fieldIds":{"title":0,"titles":1,"text":2},"fieldLength":{"0":[3,1,24],"1":[3,3,22],"2":[2,3,68],"3":[2,3,34],"4":[3,3,25],"5":[5,1,1],"6":[2,5,62],"7":[2,5,114],"8":[2,5,57],"9":[1,5,43],"10":[1,5,39],"11":[2,5,22],"12":[2,7,38],"13":[2,7,57],"14":[3,7,50],"15":[3,7,34],"16":[1,5,47],"17":[5,1,1],"18":[4,5,57],"19":[3,5,1],"20":[2,7,53],"21":[2,7,41],"22":[2,7,110],"23":[2,7,173],"24":[2,7,62],"25":[1,5,45],"26":[2,6,147],"27":[2,5,53],"28":[2,5,17],"29":[3,1,31],"30":[3,3,129],"31":[3,3,69],"32":[3,3,72],"33":[3,3,39],"34":[1,6,164],"35":[3,6,124],"36":[1,6,150],"37":[1,6,190],"38":[1,6,170],"39":[3,6,159],"40":[1,6,132],"41":[4,6,145],"42":[9,6,167],"43":[4,1,28],"44":[2,4,64],"45":[2,4,1],"46":[6,6,71],"47":[2,6,70],"48":[1,6,35],"49":[1,6,28],"50":[1,6,48],"51":[3,1,37],"52":[3,3,12],"53":[6,3,44],"54":[8,3,58],"55":[7,3,48],"56":[6,3,23],"57":[2,3,37],"58":[2,1,143],"59":[2,1,45],"60":[4,2,64],"61":[2,2,1],"62":[3,4,1],"63":[1,2,49],"64":[3,3,37],"65":[3,3,95],"66":[6,3,1],"67":[9,9,39],"68":[8,9,111],"69":[3,2,24],"70":[1,3,41],"71":[1,3,12],"72":[1,2,19],"73":[2,2,21],"74":[8,1,29],"75":[6,8,1],"76":[7,11,47],"77":[7,11,68],"78":[6,8,1],"79":[10,11,81],"80":[5,11,40],"81":[6,1,77],"82":[1,6,52],"83":[1,6,10],"84":[6,7,63],"85":[6,7,58],"86":[8,7,238],"87":[8,7,115],"88":[10,7,74],"89":[12,7,39],"90":[11,7,129],"91":[9,7,238],"92":[10,7,56],"93":[7,7,231],"94":[4,7,49],"95":[1,6,17],"96":[2,7,75],"97":[4,7,32],"98":[2,11,13],"99":[2,11,13],"100":[4,7,48],"101":[4,7,48],"102":[7,1,1],"103":[1,7,20],"104":[4,7,71],"105":[6,7,34],"106":[8,1,1],"107":[1,8,51],"108":[2,8,41],"109":[3,10,174],"110":[3,10,128],"111":[3,10,77],"112":[5,10,86],"113":[2,8,17],"114":[4,1,1],"115":[2,4,1],"116":[1,6,9],"117":[3,6,57],"118":[2,6,93],"119":[2,4,43],"120":[1,4,50],"121":[3,4,31],"122":[6,4,124],"123":[4,1,1],"124":[3,4,74],"125":[3,4,149],"126":[2,4,168],"127":[3,6,101],"128":[2,6,114],"129":[3,4,1],"130":[3,7,164],"131":[2,7,1],"132":[4,9,10],"133":[8,9,13],"134":[4,9,39],"135":[3,1,1],"136":[1,3,118],"137":[5,3,101],"138":[3,7,1],"139":[3,7,130],"140":[3,3,72],"141":[5,6,50],"142":[2,11,78],"143":[2,11,56],"144":[14,6,237],"145":[4,6,44],"146":[7,6,13],"147":[2,13,163],"148":[2,13,31],"149":[9,6,35],"150":[2,15,89],"151":[5,6,60],"152":[2,11,108],"153":[2,11,50],"154":[9,3,86],"155":[1,11,54],"156":[1,11,198],"157":[1,11,94],"158":[1,11,47],"159":[1,11,113],"160":[1,11,185],"161":[5,11,136],"162":[5,11,94],"163":[6,11,379],"164":[1,3,58],"165":[4,1,47],"166":[1,4,53],"167":[3,5,23],"168":[5,8,92],"169":[5,8,83],"170":[4,8,41],"171":[4,8,63],"172":[3,5,85],"173":[5,8,31],"174":[6,8,119],"175":[7,8,119],"176":[4,8,15],"177":[4,8,2],"178":[2,4,57],"179":[8,5,70],"180":[9,11,50],"181":[9,11,2],"182":[9,11,42],"183":[7,5,107],"184":[8,10,18],"185":[8,10,27],"186":[2,4,66],"187":[7,5,88],"188":[8,10,36],"189":[8,10,2],"190":[7,5,30],"191":[6,10,82],"192":[8,10,2],"193":[8,10,26],"194":[4,5,79],"195":[5,9,2],"196":[5,9,13],"197":[1,4,48],"198":[1,4,1],"199":[12,5,104],"200":[4,1,14],"201":[3,4,34],"202":[4,7,232],"203":[4,7,104],"204":[7,7,113],"205":[3,13,59],"206":[3,13,61],"207":[3,13,22],"208":[4,7,116],"209":[4,10,40],"210":[2,10,180],"211":[4,7,186],"212":[8,7,36],"213":[5,4,34],"214":[4,9,175],"215":[6,9,176],"216":[4,1,89],"217":[2,4,75],"218":[6,4,92],"219":[3,4,63],"220":[6,1,1],"221":[4,6,119],"222":[3,9,7],"223":[7,6,1],"224":[3,12,40],"225":[3,12,42],"226":[3,12,69],"227":[5,6,126],"228":[4,6,67],"229":[5,9,30],"230":[2,9,17],"231":[2,9,43],"232":[7,1,1],"233":[5,7,86],"234":[4,7,58],"235":[3,7,57],"236":[2,7,12],"237":[6,1,23],"238":[4,6,108],"239":[2,6,30],"240":[5,6,16],"241":[3,7,7],"242":[5,6,1],"243":[3,8,17],"244":[4,8,102],"245":[4,8,112],"246":[9,9,49],"247":[7,9,30],"248":[7,8,23],"249":[2,1,32],"250":[7,2,56],"251":[3,2,49],"252":[2,4,34],"253":[1,6,8],"254":[1,6,40],"255":[1,4,22],"256":[1,4,20],"257":[1,4,12],"258":[1,4,12],"259":[2,2,22],"260":[3,1,102],"261":[3,3,27],"262":[2,3,19],"263":[4,5,52],"264":[2,3,19],"265":[2,3,47],"266":[1,3,175],"267":[2,4,89],"268":[3,3,28],"269":[4,3,28],"270":[3,3,24],"271":[6,3,38],"272":[6,3,93],"273":[1,1,41],"274":[1,1,80],"275":[1,1,243],"276":[2,1,52],"277":[1,1,63],"278":[1,1,40],"279":[2,1,97],"280":[1,1,29],"281":[5,1,135],"282":[2,1,24],"283":[9,1,42],"284":[2,9,18],"285":[5,11,1],"286":[3,15,20],"287":[5,15,80],"288":[5,15,22],"289":[2,15,53],"290":[6,11,17],"291":[4,14,89],"292":[3,14,32],"293":[2,14,20],"294":[5,14,144],"295":[6,14,62],"296":[6,14,42],"297":[6,14,62],"298":[1,9,41],"299":[3,10,50],"300":[3,10,10],"301":[6,10,96],"302":[8,10,39],"303":[5,10,88],"304":[1,9,25],"305":[1,9,20],"306":[6,1,18],"307":[1,6,20],"308":[3,6,57],"309":[3,6,75],"310":[3,1,32],"311":[4,3,110],"312":[5,3,108],"313":[1,3,90],"314":[4,1,82],"315":[3,1,28],"316":[3,3,58],"317":[2,5,23],"318":[2,5,27],"319":[2,5,27],"320":[2,5,78],"321":[4,3,80],"322":[3,1,120],"323":[1,1,1],"324":[2,1,64],"325":[2,3,48],"326":[1,1,106],"327":[7,1,1],"328":[1,8,100],"329":[1,8,81],"330":[1,8,1],"331":[6,9,58],"332":[5,9,42],"333":[6,9,47],"334":[3,1,81],"335":[4,1,26],"336":[10,1,71],"337":[7,1,109],"338":[7,1,92],"339":[3,7,27],"340":[3,1,1],"341":[3,3,126],"342":[5,3,67],"343":[2,8,104],"344":[2,3,39],"345":[3,3,26],"346":[3,1,1],"347":[2,3,12],"348":[4,3,16],"349":[3,3,34],"350":[1,4,35],"351":[1,4,1],"352":[1,5,45],"353":[2,5,31],"354":[1,4,1],"355":[3,5,61],"356":[2,1,24],"357":[3,2,30],"358":[5,2,16],"359":[4,6,7],"360":[3,6,8],"361":[5,6,140],"362":[4,2,1],"363":[7,6,34],"364":[3,12,6],"365":[4,12,25],"366":[4,6,25],"367":[4,6,49],"368":[4,6,54],"369":[2,2,50],"370":[4,4,41],"371":[4,4,165],"372":[4,4,72],"373":[4,2,78],"374":[5,2,1],"375":[3,7,22],"376":[5,7,28],"377":[2,12,65],"378":[4,12,56],"379":[3,12,13],"380":[5,7,94],"381":[5,7,90],"382":[1,2,1],"383":[10,3,159],"384":[5,1,16],"385":[2,5,31],"386":[3,6,18],"387":[2,5,29],"388":[3,1,71],"389":[1,3,14],"390":[2,3,105],"391":[6,3,77],"392":[6,8,79],"393":[3,8,67],"394":[2,3,1],"395":[4,5,1],"396":[1,3,54],"397":[2,1,24],"398":[2,2,80],"399":[2,2,108],"400":[2,1,93],"401":[5,1,1],"402":[1,5,37],"403":[2,5,32],"404":[1,5,60],"405":[6,5,52],"406":[6,11,36],"407":[8,11,42],"408":[9,5,69],"409":[5,5,37],"410":[9,5,13],"411":[7,12,11],"412":[7,5,88],"413":[6,12,48],"414":[7,1,31],"415":[5,7,26],"416":[2,7,31],"417":[6,7,16],"418":[3,9,11],"419":[3,7,10],"420":[5,10,1],"421":[5,12,17],"422":[5,12,141],"423":[10,10,50],"424":[7,16,31],"425":[8,10,24],"426":[5,10,32],"427":[3,1,93],"428":[1,3,85],"429":[1,4,180],"430":[3,4,84],"431":[3,4,49],"432":[6,3,52],"433":[2,3,31],"434":[5,5,85],"435":[4,5,44],"436":[3,3,7],"437":[1,3,41],"438":[2,4,37],"439":[5,1,42],"440":[2,5,8],"441":[2,5,11],"442":[3,5,12],"443":[5,5,32],"444":[4,9,38],"445":[4,9,44],"446":[4,9,49],"447":[4,9,29],"448":[4,9,48],"449":[7,9,76],"450":[5,9,74],"451":[4,9,38],"452":[7,9,66],"453":[3,9,42],"454":[5,1,43],"455":[3,5,109],"456":[2,7,26],"457":[2,5,35],"458":[6,1,25],"459":[4,6,42],"460":[2,6,30],"461":[8,6,27],"462":[5,6,22],"463":[3,7,10],"464":[4,6,37],"465":[4,6,87],"466":[3,8,80],"467":[2,11,38],"468":[9,8,49],"469":[7,13,30],"470":[6,8,15],"471":[3,6,16],"472":[6,1,17],"473":[1,6,11],"474":[4,6,18],"475":[5,6,63],"476":[5,6,86],"477":[3,6,56],"478":[2,1,48],"479":[4,2,66],"480":[2,2,1],"481":[3,2,1],"482":[2,2,31],"483":[2,4,109],"484":[1,2,56],"485":[3,3,59],"486":[2,3,4],"487":[4,5,58],"488":[3,5,42],"489":[3,5,41],"490":[3,5,18],"491":[3,3,6],"492":[10,6,39],"493":[9,6,119],"494":[4,6,37],"495":[3,10,31],"496":[1,2,30],"497":[1,2,26],"498":[2,2,30],"499":[2,1,106],"500":[2,2,1],"501":[3,2,1],"502":[8,2,1],"503":[3,10,59],"504":[10,10,39],"505":[9,10,92],"506":[3,2,60],"507":[3,2,71],"508":[3,2,76],"509":[6,2,33],"510":[3,2,63],"511":[1,2,14],"512":[1,2,31],"513":[2,2,30],"514":[5,1,1],"515":[1,5,27],"516":[8,5,39],"517":[8,5,1],"518":[6,12,26],"519":[6,12,36],"520":[2,5,19],"521":[4,7,15],"522":[4,7,16],"523":[5,5,56],"524":[4,1,62],"525":[3,4,57],"526":[2,4,88],"527":[2,5,1],"528":[3,6,105],"529":[2,5,1],"530":[3,7,60],"531":[6,1,71],"532":[4,6,1],"533":[3,6,31],"534":[2,6,47],"535":[4,1,21],"536":[3,4,83],"537":[5,4,84],"538":[5,4,51],"539":[2,4,57],"540":[8,1,120],"541":[2,8,3],"542":[5,10,73],"543":[5,8,48],"544":[10,8,115],"545":[1,8,22],"546":[5,1,1],"547":[2,5,39],"548":[6,7,1],"549":[1,5,12],"550":[2,6,45],"551":[6,8,1],"552":[2,6,48],"553":[6,6,1],"554":[2,5,30],"555":[3,1,61],"556":[4,3,84],"557":[4,7,142],"558":[4,9,121],"559":[4,7,112],"560":[8,3,1],"561":[4,11,55],"562":[2,11,107],"563":[2,11,87],"564":[5,3,21],"565":[4,8,41],"566":[5,8,60],"567":[3,8,22],"568":[3,8,22],"569":[3,8,73],"570":[1,3,16],"571":[2,3,29],"572":[2,1,43],"573":[4,2,1],"574":[3,6,22],"575":[4,6,9],"576":[2,6,10],"577":[5,2,41],"578":[6,2,100],"579":[4,2,1],"580":[5,6,81],"581":[1,6,123],"582":[1,6,107],"583":[4,1,22],"584":[3,4,106],"585":[5,1,27],"586":[3,5,94],"587":[4,5,26],"588":[4,9,103],"589":[3,12,141],"590":[3,12,152],"591":[3,12,78],"592":[10,9,118],"593":[1,5,11],"594":[6,6,14],"595":[5,6,19],"596":[6,6,100],"597":[9,6,199],"598":[5,6,21],"599":[6,6,83],"600":[10,1,13],"601":[2,10,21],"602":[6,12,113],"603":[3,10,1],"604":[4,13,72],"605":[3,13,106],"606":[3,13,93],"607":[2,1,73],"608":[3,2,42],"609":[1,2,37],"610":[6,1,23],"611":[2,6,30],"612":[5,6,25],"613":[1,6,8],"614":[5,6,113],"615":[5,6,48],"616":[3,10,10],"617":[4,10,46],"618":[4,10,8],"619":[7,12,23],"620":[4,6,192],"621":[4,6,16],"622":[5,6,19],"623":[2,6,14],"624":[1,6,1],"625":[10,7,182],"626":[3,1,1],"627":[5,3,82],"628":[7,3,73],"629":[9,3,41],"630":[6,3,62],"631":[15,3,80],"632":[8,3,65],"633":[5,3,33],"634":[8,3,70],"635":[10,3,26],"636":[8,3,51],"637":[10,3,73],"638":[11,3,42],"639":[15,3,34],"640":[5,1,69],"641":[5,5,122],"642":[1,9,86],"643":[6,9,122],"644":[5,5,130],"645":[6,5,1],"646":[3,11,120],"647":[4,1,172],"648":[1,1,90],"649":[7,1,158],"650":[3,7,163],"651":[4,1,44],"652":[4,4,1],"653":[5,4,1],"654":[6,8,20],"655":[9,8,15],"656":[5,8,25],"657":[6,8,22],"658":[5,4,1],"659":[6,8,17],"660":[7,8,29],"661":[6,8,22],"662":[5,4,1],"663":[6,8,7],"664":[12,8,13],"665":[5,8,12],"666":[4,8,24],"667":[3,1,1],"668":[2,3,70],"669":[3,3,44],"670":[4,1,60],"671":[7,4,93],"672":[4,4,143],"673":[4,1,1],"674":[5,4,68],"675":[1,4,73],"676":[2,4,1],"677":[2,5,35],"678":[2,5,37],"679":[4,4,85],"680":[1,8,127],"681":[3,1,30],"682":[2,3,34],"683":[2,3,31],"684":[3,1,1],"685":[4,3,33],"686":[3,3,1],"687":[3,4,33],"688":[3,4,68],"689":[3,4,41],"690":[2,4,41],"691":[1,4,1],"692":[3,5,15],"693":[3,5,27],"694":[4,5,9],"695":[6,1,42],"696":[5,6,42],"697":[1,11,56],"698":[5,11,106],"699":[5,11,32],"700":[5,11,33],"701":[6,11,5],"702":[4,6,1],"703":[1,10,16],"704":[3,10,144],"705":[5,10,147],"706":[4,1,27],"707":[2,4,66],"708":[4,4,132],"709":[4,4,86],"710":[4,4,101],"711":[7,4,59],"712":[2,4,11],"713":[5,1,18],"714":[2,5,29],"715":[4,5,84],"716":[4,7,27],"717":[3,7,62],"718":[1,7,36],"719":[1,7,28],"720":[6,7,81],"721":[2,1,28],"722":[2,2,46],"723":[1,3,16],"724":[1,3,48],"725":[3,3,33],"726":[2,2,66],"727":[3,3,12],"728":[5,1,26],"729":[1,5,1],"730":[1,6,19],"731":[1,6,73],"732":[2,5,30],"733":[3,5,11],"734":[5,8,55],"735":[5,8,123],"736":[3,8,107],"737":[3,5,39],"738":[2,6,124],"739":[2,6,77],"740":[3,8,67],"741":[2,8,65],"742":[7,10,70],"743":[2,6,118],"744":[4,8,10],"745":[2,6,113],"746":[4,6,74],"747":[1,6,1],"748":[3,7,46],"749":[6,7,43],"750":[4,7,49],"751":[4,7,28],"752":[5,7,107],"753":[2,7,20],"754":[5,7,6],"755":[7,7,72],"756":[2,7,17],"757":[1,7,21],"758":[2,6,35],"759":[2,5,1],"760":[5,7,124],"761":[6,7,21],"762":[1,7,46],"763":[2,1,80],"764":[1,2,28],"765":[8,3,145],"766":[2,3,43],"767":[4,2,1],"768":[4,5,38],"769":[4,5,100],"770":[2,5,110],"771":[2,5,232],"772":[2,5,84],"773":[3,5,160],"774":[2,2,60],"775":[4,1,29],"776":[2,4,63],"777":[4,4,107],"778":[4,4,87],"779":[7,4,57],"780":[2,4,11],"781":[4,1,21],"782":[8,4,181],"783":[6,4,82],"784":[6,4,100]},"averageFieldLength":[3.90828025477707,5.662420382165603,55.36815286624203],"storedFields":{"0":{"title":"Celestia Documentation Site","titles":[]},"1":{"title":"Building the site","titles":["Celestia Documentation Site"]},"2":{"title":"Contribution Guidelines","titles":["Celestia Documentation Site"]},"3":{"title":"Directory Structure","titles":["Celestia Documentation Site"]},"4":{"title":"Feedback & Suggestions","titles":["Celestia Documentation Site"]},"5":{"title":"Celestia.org Code of Conduct","titles":[]},"6":{"title":"Our Pledge","titles":["Celestia.org Code of Conduct"]},"7":{"title":"Our Standards","titles":["Celestia.org Code of Conduct"]},"8":{"title":"Enforcement Responsibilities","titles":["Celestia.org Code of Conduct"]},"9":{"title":"Scope","titles":["Celestia.org Code of Conduct"]},"10":{"title":"Enforcement","titles":["Celestia.org Code of Conduct"]},"11":{"title":"Enforcement Guidelines","titles":["Celestia.org Code of Conduct"]},"12":{"title":"1. Correction","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"13":{"title":"2. Warning","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"14":{"title":"3. Temporary Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"15":{"title":"4. Permanent Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"16":{"title":"Attribution","titles":["Celestia.org Code of Conduct"]},"17":{"title":"The Celestia Foundation Delegation Program","titles":[]},"18":{"title":"Objectives of the program","titles":["The Celestia Foundation Delegation Program"]},"19":{"title":"Foundation delegation process","titles":["The Celestia Foundation Delegation Program"]},"20":{"title":"Program launch","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"21":{"title":"Cohort process","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"22":{"title":"Key Points","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"23":{"title":"Eligibility criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"24":{"title":"Undelegation criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"25":{"title":"Application","titles":["The Celestia Foundation Delegation Program"]},"26":{"title":"Application details","titles":["The Celestia Foundation Delegation Program","Application"]},"27":{"title":"Cohort information","titles":["The Celestia Foundation Delegation Program"]},"28":{"title":"Feedback process","titles":["The Celestia Foundation Delegation Program"]},"29":{"title":"Modular Meetup guide","titles":[]},"30":{"title":"Before the Meetup","titles":["Modular Meetup guide"]},"31":{"title":"During the Meetup","titles":["Modular Meetup guide"]},"32":{"title":"After the Meetup","titles":["Modular Meetup guide"]},"33":{"title":"Logistics and guidance","titles":["Modular Meetup guide"]},"34":{"title":"Venue","titles":["Modular Meetup guide","Logistics and guidance"]},"35":{"title":"Catering and refreshments","titles":["Modular Meetup guide","Logistics and guidance"]},"36":{"title":"Audience","titles":["Modular Meetup guide","Logistics and guidance"]},"37":{"title":"Speakers","titles":["Modular Meetup guide","Logistics and guidance"]},"38":{"title":"Sponsors","titles":["Modular Meetup guide","Logistics and guidance"]},"39":{"title":"Communications and marketing","titles":["Modular Meetup guide","Logistics and guidance"]},"40":{"title":"Recording","titles":["Modular Meetup guide","Logistics and guidance"]},"41":{"title":"Utilizing Meetup.com platform","titles":["Modular Meetup guide","Logistics and guidance"]},"42":{"title":"Onboarding questions for community members joining a Modular Meetup","titles":["Modular Meetup guide","Logistics and guidance"]},"43":{"title":"Celestia Modular Meetup program","titles":[]},"44":{"title":"Program description","titles":["Celestia Modular Meetup program"]},"45":{"title":"Important info","titles":["Celestia Modular Meetup program"]},"46":{"title":"Celestia.org Community Code of Conduct","titles":["Celestia Modular Meetup program","Important info"]},"47":{"title":"Signup form","titles":["Celestia Modular Meetup program","Important info"]},"48":{"title":"Emails","titles":["Celestia Modular Meetup program","Important info"]},"49":{"title":"Discord","titles":["Celestia Modular Meetup program","Important info"]},"50":{"title":"Materials","titles":["Celestia Modular Meetup program","Important info"]},"51":{"title":"Modular Meetup Toolkit","titles":[]},"52":{"title":"Celestia branding guidelines","titles":["Modular Meetup Toolkit"]},"53":{"title":"Sample “Introduction to Modularity” workshop presentation","titles":["Modular Meetup Toolkit"]},"54":{"title":"Sample “Run a Celestia light node” workshop presentation","titles":["Modular Meetup Toolkit"]},"55":{"title":"Sample “Deploy a Sovereign Rollup” workshop presentation","titles":["Modular Meetup Toolkit"]},"56":{"title":"Sample “Modular Meetup Introduction” workshop presentation","titles":["Modular Meetup Toolkit"]},"57":{"title":"Swag logistics","titles":["Modular Meetup Toolkit"]},"58":{"title":"Speaker list","titles":[]},"59":{"title":"Arabica devnet","titles":[]},"60":{"title":"Network stability and upgrades","titles":["Arabica devnet"]},"61":{"title":"Network details","titles":["Arabica devnet"]},"62":{"title":"Software version numbers","titles":["Arabica devnet","Network details"]},"63":{"title":"Integrations","titles":["Arabica devnet"]},"64":{"title":"Production RPC endpoints","titles":["Arabica devnet","Integrations"]},"65":{"title":"Community RPC endpoints","titles":["Arabica devnet","Integrations"]},"66":{"title":"Using consensus endpoints with DA nodes","titles":["Arabica devnet","Integrations"]},"67":{"title":"Data availability (DA) RPC endpoints for bridge node sync","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"68":{"title":"Data availability (DA) gRPC endpoints for state access","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"69":{"title":"Arabica devnet faucet","titles":["Arabica devnet"]},"70":{"title":"Discord","titles":["Arabica devnet","Arabica devnet faucet"]},"71":{"title":"Web","titles":["Arabica devnet","Arabica devnet faucet"]},"72":{"title":"Explorers","titles":["Arabica devnet"]},"73":{"title":"Network upgrades","titles":["Arabica devnet"]},"74":{"title":"Bridging in and out of your Orbit rollup","titles":[]},"75":{"title":"Bridge in (deposit) to your rollup","titles":["Bridging in and out of your Orbit rollup"]},"76":{"title":"Step 1: Add your custom chain config","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"77":{"title":"Step 2: Deposit to your Orbit rollup","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"78":{"title":"Bridge out (withdrawal) from your rollup","titles":["Bridging in and out of your Orbit rollup"]},"79":{"title":"Step 1: Choose an amount to withdraw from your rollup","titles":["Bridging in and out of your Orbit rollup","Bridge out (withdrawal) from your rollup"]},"80":{"title":"Step 2: Claim your withdrawal","titles":["Bridging in and out of your Orbit rollup","Bridge out (withdrawal) from your rollup"]},"81":{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","titles":[]},"82":{"title":"Prerequisites","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"83":{"title":"Setup","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"84":{"title":"Step 1: Acquire Arbitrum Sepolia ETH","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"85":{"title":"Step 2: Pick your deployment type","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"86":{"title":"Step 3: Configure your Orbit chain\'s deployment","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"87":{"title":"Step 4: Review & Deploy your Orbit chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"88":{"title":"Step 5: Download your chain\'s configuration files and launch your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"89":{"title":"Step 6: Clone the setup script repository and add your configuration files","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"90":{"title":"Step 7: Pick an L2 RPC URL for the Batch Poster","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"91":{"title":"Step 8: Run your light node for Mocha testnet","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"92":{"title":"Step 9: Run your chain\'s node and block explorer","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"93":{"title":"Step 10: Finish setting up your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"94":{"title":"Congratulations with Celestia underneath","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"95":{"title":"Appendix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"96":{"title":"Compatibility matrix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"97":{"title":"Blobstream X contract deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"98":{"title":"Arbitrum Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"99":{"title":"Base Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"100":{"title":"Arbitrum Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"101":{"title":"Base Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"102":{"title":"Running a full node and/or validator","titles":[]},"103":{"title":"Prerequisites","titles":["Running a full node and/or validator"]},"104":{"title":"Running a full node","titles":["Running a full node and/or validator"]},"105":{"title":"Running a full node with validation","titles":["Running a full node and/or validator"]},"106":{"title":"Introduction to Arbitrum rollups with Celestia as DA","titles":[]},"107":{"title":"Overview","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"108":{"title":"Key components","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"109":{"title":"DA provider implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"110":{"title":"Preimage Oracle Implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"111":{"title":"Blobstream X implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"112":{"title":"Ethereum fallback mechanism in Nitro","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"113":{"title":"Next steps","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"114":{"title":"Integrate with Blobstream contracts","titles":[]},"115":{"title":"Getting started","titles":["Integrate with Blobstream contracts"]},"116":{"title":"Prerequisites","titles":["Integrate with Blobstream contracts","Getting started"]},"117":{"title":"Installing Blobstream contracts","titles":["Integrate with Blobstream contracts","Getting started"]},"118":{"title":"Example usage","titles":["Integrate with Blobstream contracts","Getting started"]},"119":{"title":"Data structures","titles":["Integrate with Blobstream contracts"]},"120":{"title":"Interface","titles":["Integrate with Blobstream contracts"]},"121":{"title":"Querying the proof","titles":["Integrate with Blobstream contracts"]},"122":{"title":"Verifying data inclusion for fraud proofs","titles":["Integrate with Blobstream contracts"]},"123":{"title":"Integrate with Blobstream client","titles":[]},"124":{"title":"Blobstream demo rollup","titles":["Integrate with Blobstream client"]},"125":{"title":"Defining a chain","titles":["Integrate with Blobstream client"]},"126":{"title":"Rollup sequencer","titles":["Integrate with Blobstream client"]},"127":{"title":"Committing to data","titles":["Integrate with Blobstream client","Rollup sequencer"]},"128":{"title":"Creating blocks","titles":["Integrate with Blobstream client","Rollup sequencer"]},"129":{"title":"Rollup full node","titles":["Integrate with Blobstream client"]},"130":{"title":"Downloading the block","titles":["Integrate with Blobstream client","Rollup full node"]},"131":{"title":"More documentation","titles":["Integrate with Blobstream client","Rollup full node"]},"132":{"title":"Proving inclusion via Blobstream","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"133":{"title":"Submitting block data to Celestia via light node","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"134":{"title":"Posting headers to Ethereum","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"135":{"title":"Blobstream proofs queries","titles":[]},"136":{"title":"Prerequisites","titles":["Blobstream proofs queries"]},"137":{"title":"Overview of the proof queries","titles":["Blobstream proofs queries"]},"138":{"title":"The Celestia square","titles":["Blobstream proofs queries","Overview of the proof queries"]},"139":{"title":"The commitment scheme","titles":["Blobstream proofs queries","Overview of the proof queries"]},"140":{"title":"Hands-on demonstration","titles":["Blobstream proofs queries"]},"141":{"title":"1. Data root inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"142":{"title":"HTTP query","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"143":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"144":{"title":"Full example of proving that a Celestia block was committed to by Blobstream contract","titles":["Blobstream proofs queries","Hands-on demonstration"]},"145":{"title":"2. Transaction inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"146":{"title":"Transaction inclusion proof using the transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"147":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"148":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"149":{"title":"Blob inclusion proof using the corresponding PFB transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"150":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Blob inclusion proof using the corresponding PFB transaction hash"]},"151":{"title":"Specific share range inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"152":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"153":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"154":{"title":"Converting the proofs to be usable in the DAVerifier library","titles":["Blobstream proofs queries"]},"155":{"title":"data","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"156":{"title":"shareProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"157":{"title":"namespace","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"158":{"title":"rowRoots","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"159":{"title":"rowProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"160":{"title":"attestationProof","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"161":{"title":"Querying the proof\'s tupleRootNonce","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"162":{"title":"Listening for new data commitments","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"163":{"title":"Example rollup that uses the DAVerifier","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"164":{"title":"Conclusion","titles":["Blobstream proofs queries"]},"165":{"title":"Introduction to Blobstream rollups","titles":[]},"166":{"title":"Concepts","titles":["Introduction to Blobstream rollups"]},"167":{"title":"Blob share commitment","titles":["Introduction to Blobstream rollups","Concepts"]},"168":{"title":"Blob share commitment: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"169":{"title":"Blob share commitment: Compact proofs","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"170":{"title":"Blob share commitment: Pros","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"171":{"title":"Blob share commitment: Cons","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"172":{"title":"Sequence of spans","titles":["Introduction to Blobstream rollups","Concepts"]},"173":{"title":"Sequence of spans: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"174":{"title":"Sequence of spans: Proving unavailable data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"175":{"title":"Sequence of spans: Proving inclusion of some data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"176":{"title":"Sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"177":{"title":"Sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"178":{"title":"Optimistic rollups","titles":["Introduction to Blobstream rollups"]},"179":{"title":"Optimistic rollups that use a sequence of spans","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"180":{"title":"Optimistic rollups that use a sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use a sequence of spans"]},"181":{"title":"Optimistic rollups that use a sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use a sequence of spans"]},"182":{"title":"Optimistic rollups that use a sequence of spans: Example","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use a sequence of spans"]},"183":{"title":"Optimistic rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"184":{"title":"Optimistic rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"185":{"title":"Optimistic rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"186":{"title":"Zk-rollups","titles":["Introduction to Blobstream rollups"]},"187":{"title":"Zk-rollups that use sequence of spans","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"188":{"title":"Zk-rollups that use sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"189":{"title":"Zk-rollups that use sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"190":{"title":"Zk-rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"191":{"title":"Protobuf deserialization inside a zk-circuit","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"192":{"title":"Zk-rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"193":{"title":"Zk-rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"194":{"title":"Heavy merkle proofs usage","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"195":{"title":"heavy merkle proofs usage: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"196":{"title":"heavy merkle proofs usage: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"197":{"title":"Conclusion","titles":["Introduction to Blobstream rollups"]},"198":{"title":"FAQ","titles":["Introduction to Blobstream rollups"]},"199":{"title":"Should I use the Celestia transaction hash to reference the rollup data?","titles":["Introduction to Blobstream rollups","FAQ"]},"200":{"title":"New Blobstream X deployments","titles":[]},"201":{"title":"Deploying the contracts","titles":["New Blobstream X deployments"]},"202":{"title":"Deploy a new SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"203":{"title":"Deploy the function verifiers","titles":["New Blobstream X deployments","Deploying the contracts"]},"204":{"title":"Register the function verifier in the deployed SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"205":{"title":"Enable prover whitelisting","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"206":{"title":"Set Whitelist Status","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"207":{"title":"Add Custom Prover","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"208":{"title":"Deploy the BlobstreamX contract","titles":["New Blobstream X deployments","Deploying the contracts"]},"209":{"title":"Querying the trusted hash","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"210":{"title":"Deployment instructions","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"211":{"title":"Run a local prover","titles":["New Blobstream X deployments","Deploying the contracts"]},"212":{"title":"Run a proof replayer from an existing deployment","titles":["New Blobstream X deployments","Deploying the contracts"]},"213":{"title":"Optional: Regenerating the downloaded artifacts","titles":["New Blobstream X deployments"]},"214":{"title":"Regenerate the verifier-build","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"215":{"title":"Build the circuits and function verifiers","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"216":{"title":"Requesting data commitment ranges","titles":[]},"217":{"title":"Local proving","titles":["Requesting data commitment ranges"]},"218":{"title":"Request proofs from the Succinct platform","titles":["Requesting data commitment ranges"]},"219":{"title":"Request proofs onchain","titles":["Requesting data commitment ranges"]},"220":{"title":"Blobstream: Streaming modular DA to Ethereum","titles":[]},"221":{"title":"What is Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"222":{"title":"Implementations of Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","What is Blobstream?"]},"223":{"title":"Blobstream vs. data availability committees (DACs)","titles":["Blobstream: Streaming modular DA to Ethereum"]},"224":{"title":"Decentralization and security","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"225":{"title":"Mechanism of verification","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"226":{"title":"Flexibility and scalability","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"227":{"title":"What is SP1 Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"228":{"title":"Integrate with SP1 Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum"]},"229":{"title":"How to integrate with Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"230":{"title":"Blobstream rollups","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"231":{"title":"Deployed contracts","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"232":{"title":"Blobstream X: the previous zk implementation of Blobstream","titles":[]},"233":{"title":"What is Blobstream X?","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"234":{"title":"How Blobstream X works","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"235":{"title":"Deploy Blobstream X","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"236":{"title":"Community implementations","titles":["Blobstream X: the previous zk implementation of Blobstream"]},"237":{"title":"Setting up a Celestia bridge node","titles":[]},"238":{"title":"Overview of bridge nodes","titles":["Setting up a Celestia bridge node"]},"239":{"title":"Hardware requirements","titles":["Setting up a Celestia bridge node"]},"240":{"title":"Setting up your bridge node","titles":["Setting up a Celestia bridge node"]},"241":{"title":"Setup the dependencies","titles":["Setting up a Celestia bridge node","Setting up your bridge node"]},"242":{"title":"Deploy the Celestia bridge node","titles":["Setting up a Celestia bridge node"]},"243":{"title":"Install Celestia Node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"244":{"title":"Initialize the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"245":{"title":"Run the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"246":{"title":"Optional: run the bridge node with a custom key","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node","Run the bridge node"]},"247":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node","Run the bridge node"]},"248":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"249":{"title":"Bubs testnet","titles":[]},"250":{"title":"Built with the OP Stack and Celestia","titles":["Bubs testnet"]},"251":{"title":"Building on Bubs","titles":["Bubs testnet"]},"252":{"title":"RPC URLs","titles":["Bubs testnet","Building on Bubs"]},"253":{"title":"HTTPS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"254":{"title":"WSS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"255":{"title":"Bridge","titles":["Bubs testnet","Building on Bubs"]},"256":{"title":"Faucet","titles":["Bubs testnet","Building on Bubs"]},"257":{"title":"Explorer","titles":["Bubs testnet","Building on Bubs"]},"258":{"title":"Status","titles":["Bubs testnet","Building on Bubs"]},"259":{"title":"Next steps","titles":["Bubs testnet"]},"260":{"title":"Helpful CLI commands","titles":[]},"261":{"title":"Creating a wallet","titles":["Helpful CLI commands"]},"262":{"title":"Key management","titles":["Helpful CLI commands"]},"263":{"title":"Importing and exporting keys","titles":["Helpful CLI commands","Key management"]},"264":{"title":"Querying subcommands","titles":["Helpful CLI commands"]},"265":{"title":"Token management","titles":["Helpful CLI commands"]},"266":{"title":"Governance","titles":["Helpful CLI commands"]},"267":{"title":"Community Pool","titles":["Helpful CLI commands","Governance"]},"268":{"title":"Claim validator rewards","titles":["Helpful CLI commands"]},"269":{"title":"Delegate & undelegate tokens","titles":["Helpful CLI commands"]},"270":{"title":"Unjailing the validator","titles":["Helpful CLI commands"]},"271":{"title":"How to export logs with SystemD","titles":["Helpful CLI commands"]},"272":{"title":"Signing genesis for a new network","titles":["Helpful CLI commands"]},"273":{"title":"Metrics","titles":[]},"274":{"title":"Setup","titles":["Metrics"]},"275":{"title":"Visualization","titles":["Metrics"]},"276":{"title":"Node exporter","titles":["Metrics"]},"277":{"title":"Alerts","titles":["Metrics"]},"278":{"title":"Multisig","titles":[]},"279":{"title":"Command line","titles":["Multisig"]},"280":{"title":"Resources","titles":["Multisig"]},"281":{"title":"Jailing and slashing on Celestia","titles":[]},"282":{"title":"Upgrade Monitor","titles":[]},"283":{"title":"How to create a vesting account with celestia-app","titles":[]},"284":{"title":"Local devnet","titles":["How to create a vesting account with celestia-app"]},"285":{"title":"Setting up the local devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"286":{"title":"Run the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"287":{"title":"Save the home directory path","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"288":{"title":"Check the version of the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"289":{"title":"Next steps","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"290":{"title":"Setting up vesting account on devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"291":{"title":"Create a new key","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"292":{"title":"List your keys","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"293":{"title":"Set variables","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"294":{"title":"Create your devnet vesting account","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"295":{"title":"Query the devnet vesting account details","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"296":{"title":"Query the devnet base account details","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"297":{"title":"Query the balances of the devnet accounts","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"298":{"title":"Mocha","titles":["How to create a vesting account with celestia-app"]},"299":{"title":"Create a wallet","titles":["How to create a vesting account with celestia-app","Mocha"]},"300":{"title":"Fund your account","titles":["How to create a vesting account with celestia-app","Mocha"]},"301":{"title":"Create a vesting account on Mocha","titles":["How to create a vesting account with celestia-app","Mocha"]},"302":{"title":"Optional: Set up a consensus node or validator","titles":["How to create a vesting account with celestia-app","Mocha"]},"303":{"title":"Optional: Change your client.toml","titles":["How to create a vesting account with celestia-app","Mocha"]},"304":{"title":"Notes","titles":["How to create a vesting account with celestia-app"]},"305":{"title":"Conclusion","titles":["How to create a vesting account with celestia-app"]},"306":{"title":"Create a wallet with celestia-app","titles":[]},"307":{"title":"Prerequisites","titles":["Create a wallet with celestia-app"]},"308":{"title":"Create a wallet","titles":["Create a wallet with celestia-app"]},"309":{"title":"Fund a wallet","titles":["Create a wallet with celestia-app"]},"310":{"title":"Install celestia-app","titles":[]},"311":{"title":"Building binary from source","titles":["Install celestia-app"]},"312":{"title":"Installing a pre-built binary","titles":["Install celestia-app"]},"313":{"title":"Ports","titles":["Install celestia-app"]},"314":{"title":"Custom networks and values","titles":[]},"315":{"title":"celestia-node metrics","titles":[]},"316":{"title":"Running metrics flags","titles":["celestia-node metrics"]},"317":{"title":"Mainnet Beta","titles":["celestia-node metrics","Running metrics flags"]},"318":{"title":"Mocha testnet","titles":["celestia-node metrics","Running metrics flags"]},"319":{"title":"Arabica devnet","titles":["celestia-node metrics","Running metrics flags"]},"320":{"title":"TLS connections","titles":["celestia-node metrics","Running metrics flags"]},"321":{"title":"Metrics endpoint design considerations","titles":["celestia-node metrics"]},"322":{"title":"celestia-node datastore","titles":[]},"323":{"title":"Troubleshooting","titles":[]},"324":{"title":"Network selection","titles":["Troubleshooting"]},"325":{"title":"Chain ID","titles":["Troubleshooting","Network selection"]},"326":{"title":"Ports","titles":["Troubleshooting"]},"327":{"title":"Changing the location of your node store","titles":["Troubleshooting"]},"328":{"title":"Background","titles":["Troubleshooting","Changing the location of your node store"]},"329":{"title":"Demonstration","titles":["Troubleshooting","Changing the location of your node store"]},"330":{"title":"Examples","titles":["Troubleshooting","Changing the location of your node store"]},"331":{"title":"Mainnet Beta full and Mocha light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"332":{"title":"Mocha full and Arabica light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"333":{"title":"Using a custom rpc.config address","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"334":{"title":"Resetting your config","titles":["Troubleshooting"]},"335":{"title":"Clearing the data store","titles":["Troubleshooting"]},"336":{"title":"FATAL headers given to the heightSub are in the wrong order","titles":["Troubleshooting"]},"337":{"title":"Error: "too many open files"","titles":["Troubleshooting"]},"338":{"title":"Syncing a light node from a trusted hash","titles":[]},"339":{"title":"For service operators","titles":["Syncing a light node from a trusted hash"]},"340":{"title":"Install celestia-node","titles":[]},"341":{"title":"Installing from source","titles":["Install celestia-node"]},"342":{"title":"Installing a pre-built binary","titles":["Install celestia-node"]},"343":{"title":"Installation Options","titles":["Install celestia-node","Installing a pre-built binary"]},"344":{"title":"Next steps","titles":["Install celestia-node"]},"345":{"title":"Upgrading your binary","titles":["Install celestia-node"]},"346":{"title":"config.toml guide","titles":[]},"347":{"title":"Pre-requisites","titles":["config.toml guide"]},"348":{"title":"Viewing the help menu","titles":["config.toml guide"]},"349":{"title":"Understanding config.toml","titles":["config.toml guide"]},"350":{"title":"Core","titles":["config.toml guide","Understanding config.toml"]},"351":{"title":"P2P","titles":["config.toml guide","Understanding config.toml"]},"352":{"title":"Bootstrap","titles":["config.toml guide","Understanding config.toml","P2P"]},"353":{"title":"Mutual peers","titles":["config.toml guide","Understanding config.toml","P2P"]},"354":{"title":"Services","titles":["config.toml guide","Understanding config.toml"]},"355":{"title":"TrustedHash and TrustedPeer","titles":["config.toml guide","Understanding config.toml","Services"]},"356":{"title":"Consensus node","titles":[]},"357":{"title":"Minimum hardware requirements","titles":["Consensus node"]},"358":{"title":"Set up a consensus node","titles":["Consensus node"]},"359":{"title":"Set up the dependencies","titles":["Consensus node","Set up a consensus node"]},"360":{"title":"Install celestia-app","titles":["Consensus node","Set up a consensus node"]},"361":{"title":"Set up the P2P networks","titles":["Consensus node","Set up a consensus node"]},"362":{"title":"Storage and pruning configurations","titles":["Consensus node"]},"363":{"title":"Optional: Connect a consensus node to a bridge node","titles":["Consensus node","Storage and pruning configurations"]},"364":{"title":"Enable transaction indexing","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"365":{"title":"Retain all block data","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"366":{"title":"Query transactions by hash","titles":["Consensus node","Storage and pruning configurations"]},"367":{"title":"Optional: Access historical state","titles":["Consensus node","Storage and pruning configurations"]},"368":{"title":"Save on storage requirements","titles":["Consensus node","Storage and pruning configurations"]},"369":{"title":"Sync types","titles":["Consensus node"]},"370":{"title":"Option 1: Block sync","titles":["Consensus node","Sync types"]},"371":{"title":"Option 2: State sync","titles":["Consensus node","Sync types"]},"372":{"title":"Option 3: Quick sync","titles":["Consensus node","Sync types"]},"373":{"title":"Start the consensus node","titles":["Consensus node"]},"374":{"title":"Extra resources for consensus nodes","titles":["Consensus node"]},"375":{"title":"Optional: Reset network","titles":["Consensus node","Extra resources for consensus nodes"]},"376":{"title":"Optional: Configure an RPC endpoint","titles":["Consensus node","Extra resources for consensus nodes"]},"377":{"title":"Expose RPC","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"378":{"title":"Note on external-address","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"379":{"title":"Restart the node","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"380":{"title":"Optional: Transaction indexer configuration options","titles":["Consensus node","Extra resources for consensus nodes"]},"381":{"title":"Optional: Discard ABCI responses configuration","titles":["Consensus node","Extra resources for consensus nodes"]},"382":{"title":"FAQ","titles":["Consensus node"]},"383":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Consensus node","FAQ"]},"384":{"title":"Deciding which node to run","titles":[]},"385":{"title":"Light node","titles":["Deciding which node to run"]},"386":{"title":"Other DA nodes","titles":["Deciding which node to run","Light node"]},"387":{"title":"Consensus node","titles":["Deciding which node to run"]},"388":{"title":"🐳 Docker setup","titles":[]},"389":{"title":"Prerequisites","titles":["🐳 Docker setup"]},"390":{"title":"Quick start","titles":["🐳 Docker setup"]},"391":{"title":"Light node setup with persistent storage","titles":["🐳 Docker setup"]},"392":{"title":"Initialize the node store and key","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"393":{"title":"Start the node","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"394":{"title":"Video walkthrough","titles":["🐳 Docker setup"]},"395":{"title":"2.5 minute version","titles":["🐳 Docker setup","Video walkthrough"]},"396":{"title":"Troubleshooting","titles":["🐳 Docker setup"]},"397":{"title":"Development environment","titles":[]},"398":{"title":"Install dependencies","titles":["Development environment"]},"399":{"title":"Install Golang","titles":["Development environment"]},"400":{"title":"Ethereum fallback","titles":[]},"401":{"title":"FeeGrant module for blobs submission","titles":[]},"402":{"title":"Overview","titles":["FeeGrant module for blobs submission"]},"403":{"title":"Pre-requisites","titles":["FeeGrant module for blobs submission"]},"404":{"title":"Introduction","titles":["FeeGrant module for blobs submission"]},"405":{"title":"Granting fee allowances using celestia-node","titles":["FeeGrant module for blobs submission"]},"406":{"title":"FeeGrant module implementation in celestia-node","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"407":{"title":"Grant permission for an allowance as a granter","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"408":{"title":"Using a FeeGrant allowance as a grantee in celestia-node","titles":["FeeGrant module for blobs submission"]},"409":{"title":"Checking account balances after submission","titles":["FeeGrant module for blobs submission"]},"410":{"title":"Optional: Revoke permission for a FeeGrant allowance as a granter","titles":["FeeGrant module for blobs submission"]},"411":{"title":"Optional: Submitting a blob from file input","titles":["FeeGrant module for blobs submission","Optional: Revoke permission for a FeeGrant allowance as a granter"]},"412":{"title":"Optional: Granting fee allowances using celestia-appd","titles":["FeeGrant module for blobs submission"]},"413":{"title":"Optional: Checking the granter\'s account","titles":["FeeGrant module for blobs submission","Optional: Granting fee allowances using celestia-appd"]},"414":{"title":"Setting up a Celestia full storage Node","titles":[]},"415":{"title":"Overview of full storage nodes","titles":["Setting up a Celestia full storage Node"]},"416":{"title":"Hardware requirements","titles":["Setting up a Celestia full storage Node"]},"417":{"title":"Setting up your full storage node","titles":["Setting up a Celestia full storage Node"]},"418":{"title":"Setup the dependencies","titles":["Setting up a Celestia full storage Node","Setting up your full storage node"]},"419":{"title":"Install celestia-node","titles":["Setting up a Celestia full storage Node"]},"420":{"title":"Run the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"421":{"title":"Initialize the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"422":{"title":"Start the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"423":{"title":"Optional: run the full storage node with a custom key","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"424":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia full storage Node","Install celestia-node","Optional: run the full storage node with a custom key"]},"425":{"title":"Optional: start the full storage node with SystemD","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"426":{"title":"Stop the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"427":{"title":"IBC relaying guide","titles":[]},"428":{"title":"Hermes","titles":["IBC relaying guide"]},"429":{"title":"Configuration","titles":["IBC relaying guide","Hermes"]},"430":{"title":"Add relayer wallets","titles":["IBC relaying guide","Hermes"]},"431":{"title":"Verify configuration files","titles":["IBC relaying guide","Hermes"]},"432":{"title":"Create a connection between 2 chains","titles":["IBC relaying guide"]},"433":{"title":"Create clients","titles":["IBC relaying guide"]},"434":{"title":"Open connection over new clients","titles":["IBC relaying guide","Create clients"]},"435":{"title":"Configure channels in Hermes","titles":["IBC relaying guide","Create clients"]},"436":{"title":"Start the relayer","titles":["IBC relaying guide"]},"437":{"title":"Transfer","titles":["IBC relaying guide"]},"438":{"title":"Token filter","titles":["IBC relaying guide","Transfer"]},"439":{"title":"Celestia App network instantiation guide","titles":[]},"440":{"title":"Hardware requirements","titles":["Celestia App network instantiation guide"]},"441":{"title":"Setup dependencies","titles":["Celestia App network instantiation guide"]},"442":{"title":"celestia-app installation","titles":["Celestia App network instantiation guide"]},"443":{"title":"Spin up a Celestia testnet","titles":["Celestia App network instantiation guide"]},"444":{"title":"Optional: Reset working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"445":{"title":"Initialize a working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"446":{"title":"Create a new key","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"447":{"title":"Add genesis account KeyName","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"448":{"title":"Optional: Adding other validators","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"449":{"title":"Create the genesis transaction for new chain","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"450":{"title":"Creating the genesis JSON file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"451":{"title":"Modify your config file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"452":{"title":"Add your node as a persistent peer","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"453":{"title":"Instantiate the network","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"454":{"title":"Introduction to OP Stack integration","titles":[]},"455":{"title":"About the integration","titles":["Introduction to OP Stack integration"]},"456":{"title":"GitHub repository","titles":["Introduction to OP Stack integration","About the integration"]},"457":{"title":"Next steps","titles":["Introduction to OP Stack integration"]},"458":{"title":"Setting up a Celestia light node","titles":[]},"459":{"title":"Overview of light nodes","titles":["Setting up a Celestia light node"]},"460":{"title":"Hardware requirements","titles":["Setting up a Celestia light node"]},"461":{"title":"Quickstart: Run a light node in your browser","titles":["Setting up a Celestia light node"]},"462":{"title":"Setting up your light node","titles":["Setting up a Celestia light node"]},"463":{"title":"Install celestia-node","titles":["Setting up a Celestia light node","Setting up your light node"]},"464":{"title":"Initialize the light node","titles":["Setting up a Celestia light node"]},"465":{"title":"Start the light node","titles":["Setting up a Celestia light node"]},"466":{"title":"Keys and wallets","titles":["Setting up a Celestia light node","Start the light node"]},"467":{"title":"Testnet tokens","titles":["Setting up a Celestia light node","Start the light node","Keys and wallets"]},"468":{"title":"Optional: run the light node with a custom key","titles":["Setting up a Celestia light node","Start the light node"]},"469":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia light node","Start the light node","Optional: run the light node with a custom key"]},"470":{"title":"Optional: start light node with SystemD","titles":["Setting up a Celestia light node","Start the light node"]},"471":{"title":"Data availability sampling","titles":["Setting up a Celestia light node"]},"472":{"title":"Setting up a Celestia local testnet","titles":[]},"473":{"title":"Prerequisites","titles":["Setting up a Celestia local testnet"]},"474":{"title":"Starting the validator node","titles":["Setting up a Celestia local testnet"]},"475":{"title":"Setting up the bridge node","titles":["Setting up a Celestia local testnet"]},"476":{"title":"Setting up the light node","titles":["Setting up a Celestia local testnet"]},"477":{"title":"Funding and testing","titles":["Setting up a Celestia local testnet"]},"478":{"title":"Mainnet Beta","titles":[]},"479":{"title":"Network stability and upgrades","titles":["Mainnet Beta"]},"480":{"title":"Network details","titles":["Mainnet Beta"]},"481":{"title":"Software version numbers","titles":["Mainnet Beta"]},"482":{"title":"Network parameters","titles":["Mainnet Beta"]},"483":{"title":"Maximum bytes","titles":["Mainnet Beta","Network parameters"]},"484":{"title":"Integrations","titles":["Mainnet Beta"]},"485":{"title":"Production RPC endpoints","titles":["Mainnet Beta","Integrations"]},"486":{"title":"Consensus nodes","titles":["Mainnet Beta","Integrations"]},"487":{"title":"Community consensus RPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"488":{"title":"Community API endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"489":{"title":"Community gRPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"490":{"title":"Community WebSocket endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"491":{"title":"Data availability nodes","titles":["Mainnet Beta","Integrations"]},"492":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"493":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"494":{"title":"Archival DA RPC endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"495":{"title":"Grove archival endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes","Archival DA RPC endpoints"]},"496":{"title":"Explorers","titles":["Mainnet Beta"]},"497":{"title":"Analytics","titles":["Mainnet Beta"]},"498":{"title":"Network upgrades","titles":["Mainnet Beta"]},"499":{"title":"Mocha testnet","titles":[]},"500":{"title":"Network details","titles":["Mocha testnet"]},"501":{"title":"Software version numbers","titles":["Mocha testnet"]},"502":{"title":"RPC for DA bridge, full, and light nodes","titles":["Mocha testnet"]},"503":{"title":"Production RPC endpoints","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"504":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"505":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"506":{"title":"Community RPC endpoints","titles":["Mocha testnet"]},"507":{"title":"Community API endpoints","titles":["Mocha testnet"]},"508":{"title":"Community gRPC endpoints","titles":["Mocha testnet"]},"509":{"title":"Community bridge and full node endpoints","titles":["Mocha testnet"]},"510":{"title":"Mocha testnet faucet","titles":["Mocha testnet"]},"511":{"title":"Analytics","titles":["Mocha testnet"]},"512":{"title":"Explorers","titles":["Mocha testnet"]},"513":{"title":"Network upgrades","titles":["Mocha testnet"]},"514":{"title":"MultiAccounts feature for blobs submission","titles":[]},"515":{"title":"Overview","titles":["MultiAccounts feature for blobs submission"]},"516":{"title":"Running a node with a different default key name","titles":["MultiAccounts feature for blobs submission"]},"517":{"title":"Submitting blobs with a different signer/key name","titles":["MultiAccounts feature for blobs submission"]},"518":{"title":"Option 1: Submit passing key name","titles":["MultiAccounts feature for blobs submission","Submitting blobs with a different signer/key name"]},"519":{"title":"Option 2: Submit passing signer address","titles":["MultiAccounts feature for blobs submission","Submitting blobs with a different signer/key name"]},"520":{"title":"Key management","titles":["MultiAccounts feature for blobs submission"]},"521":{"title":"Creating a new key","titles":["MultiAccounts feature for blobs submission","Key management"]},"522":{"title":"Importing an existing key","titles":["MultiAccounts feature for blobs submission","Key management"]},"523":{"title":"Optional flags for write transactions","titles":["MultiAccounts feature for blobs submission"]},"524":{"title":"Celestia network upgrade process","titles":[]},"525":{"title":"Network upgrade coordination","titles":["Celestia network upgrade process"]},"526":{"title":"Upgrade process","titles":["Celestia network upgrade process"]},"527":{"title":"Upcoming upgrade","titles":["Celestia network upgrade process","Upgrade process"]},"528":{"title":"Ginger network upgrade","titles":["Celestia network upgrade process","Upgrade process","Upcoming upgrade"]},"529":{"title":"Past Upgrades","titles":["Celestia network upgrade process","Upgrade process"]},"530":{"title":"Lemongrass network upgrade","titles":["Celestia network upgrade process","Upgrade process","Past Upgrades"]},"531":{"title":"Overview to running nodes on Celestia","titles":[]},"532":{"title":"Recommended Celestia node requirements","titles":["Overview to running nodes on Celestia"]},"533":{"title":"Data availability nodes","titles":["Overview to running nodes on Celestia"]},"534":{"title":"Consensus nodes","titles":["Overview to running nodes on Celestia"]},"535":{"title":"Optimism devnet deep dive","titles":[]},"536":{"title":"Find a transaction","titles":["Optimism devnet deep dive"]},"537":{"title":"Read the transaction call data","titles":["Optimism devnet deep dive"]},"538":{"title":"Find the data on Celestia","titles":["Optimism devnet deep dive"]},"539":{"title":"Span batches","titles":["Optimism devnet deep dive"]},"540":{"title":"Run an OP Stack rollup with Celestia underneath","titles":[]},"541":{"title":"Dependency setup","titles":["Run an OP Stack rollup with Celestia underneath"]},"542":{"title":"Setting up your light node","titles":["Run an OP Stack rollup with Celestia underneath","Dependency setup"]},"543":{"title":"Deploying a devnet to Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"544":{"title":"Deploying a testnet to an L1 (or L2) and Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"545":{"title":"Congratulations","titles":["Run an OP Stack rollup with Celestia underneath"]},"546":{"title":"Participate in the Celestia networks","titles":[]},"547":{"title":"Mainnet Beta","titles":["Participate in the Celestia networks"]},"548":{"title":"Compatible software versions for Mainnet Beta","titles":["Participate in the Celestia networks","Mainnet Beta"]},"549":{"title":"Testnets","titles":["Participate in the Celestia networks"]},"550":{"title":"Arabica Devnet","titles":["Participate in the Celestia networks","Testnets"]},"551":{"title":"Compatible software versions for Arabica devnet","titles":["Participate in the Celestia networks","Testnets","Arabica Devnet"]},"552":{"title":"Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"553":{"title":"Compatible software versions for Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"554":{"title":"Network upgrades","titles":["Participate in the Celestia networks"]},"555":{"title":"Quick-start guide","titles":[]},"556":{"title":"Run a light node","titles":["Quick-start guide"]},"557":{"title":"Initialize the light node","titles":["Quick-start guide","Run a light node"]},"558":{"title":"Set the trusted hash","titles":["Quick-start guide","Run a light node","Initialize the light node"]},"559":{"title":"Start the light node","titles":["Quick-start guide","Run a light node"]},"560":{"title":"Post and retrieve data with your light node","titles":["Quick-start guide"]},"561":{"title":"Funding your light node","titles":["Quick-start guide","Post and retrieve data with your light node"]},"562":{"title":"Posting data","titles":["Quick-start guide","Post and retrieve data with your light node"]},"563":{"title":"Retrieving data","titles":["Quick-start guide","Post and retrieve data with your light node"]},"564":{"title":"Diving deeper into the stack","titles":["Quick-start guide"]},"565":{"title":"Get your auth token","titles":["Quick-start guide","Diving deeper into the stack"]},"566":{"title":"Key management with cel-key","titles":["Quick-start guide","Diving deeper into the stack"]},"567":{"title":"Rust client tutorial","titles":["Quick-start guide","Diving deeper into the stack"]},"568":{"title":"Golang client tutorial","titles":["Quick-start guide","Diving deeper into the stack"]},"569":{"title":"Node store contents","titles":["Quick-start guide","Diving deeper into the stack"]},"570":{"title":"Troubleshooting","titles":["Quick-start guide"]},"571":{"title":"Next steps","titles":["Quick-start guide"]},"572":{"title":"Rollup stacks","titles":[]},"573":{"title":"Quickstart - Building on Celestia","titles":["Rollup stacks"]},"574":{"title":"Choose a framework","titles":["Rollup stacks","Quickstart - Building on Celestia"]},"575":{"title":"Rollups as a Service","titles":["Rollup stacks","Quickstart - Building on Celestia"]},"576":{"title":"Smart contracts","titles":["Rollup stacks","Quickstart - Building on Celestia"]},"577":{"title":"What is a rollup?","titles":["Rollup stacks"]},"578":{"title":"What is a modular blockchain?","titles":["Rollup stacks"]},"579":{"title":"Benefits of modular blockchains","titles":["Rollup stacks"]},"580":{"title":"Ease of deploying a chain","titles":["Rollup stacks","Benefits of modular blockchains"]},"581":{"title":"Scaling","titles":["Rollup stacks","Benefits of modular blockchains"]},"582":{"title":"Customizability","titles":["Rollup stacks","Benefits of modular blockchains"]},"583":{"title":"New SP1 Blobstream deployments","titles":[]},"584":{"title":"Deploying the contracts","titles":["New SP1 Blobstream deployments"]},"585":{"title":"Submitting data blobs to Celestia","titles":[]},"586":{"title":"Maximum blob size","titles":["Submitting data blobs to Celestia"]},"587":{"title":"Fee market and mempool","titles":["Submitting data blobs to Celestia"]},"588":{"title":"Fees and gas limits","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"589":{"title":"Estimating PFB gas","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"590":{"title":"Gas fee calculation","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"591":{"title":"Estimating gas programmatically","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"592":{"title":"Submitting multiple transactions in one block from the same account","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"593":{"title":"API","titles":["Submitting data blobs to Celestia"]},"594":{"title":"The celestia-app consensus node CLI","titles":["Submitting data blobs to Celestia","API"]},"595":{"title":"The celestia-node light node CLI","titles":["Submitting data blobs to Celestia","API"]},"596":{"title":"The celestia-node API golang client","titles":["Submitting data blobs to Celestia","API"]},"597":{"title":"GRPC to a consensus node via the user package","titles":["Submitting data blobs to Celestia","API"]},"598":{"title":"RPC to a celestia-node","titles":["Submitting data blobs to Celestia","API"]},"599":{"title":"Post a blob directly from Celenium","titles":["Submitting data blobs to Celestia","API"]},"600":{"title":"Setting up your node as a background process with SystemD","titles":[]},"601":{"title":"Consensus nodes","titles":["Setting up your node as a background process with SystemD"]},"602":{"title":"Start the celestia-app with SystemD","titles":["Setting up your node as a background process with SystemD","Consensus nodes"]},"603":{"title":"Data availability nodes","titles":["Setting up your node as a background process with SystemD"]},"604":{"title":"Celestia full storage node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"605":{"title":"Celestia bridge node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"606":{"title":"Celestia light node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"607":{"title":"Transaction resubmission","titles":[]},"608":{"title":"Monitoring and resubmission","titles":["Transaction resubmission"]},"609":{"title":"Notes","titles":["Transaction resubmission"]},"610":{"title":"Setting up a Celestia validator node","titles":[]},"611":{"title":"Hardware requirements","titles":["Setting up a Celestia validator node"]},"612":{"title":"Setting up a validator node","titles":["Setting up a Celestia validator node"]},"613":{"title":"Wallet","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"614":{"title":"Delegate stake to a validator","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"615":{"title":"Optional: Deploy the celestia-node","titles":["Setting up a Celestia validator node"]},"616":{"title":"Install celestia-node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"617":{"title":"Initialize the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"618":{"title":"Run the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"619":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node","Run the bridge node"]},"620":{"title":"Run the validator node","titles":["Setting up a Celestia validator node"]},"621":{"title":"Submit your validator information","titles":["Setting up a Celestia validator node"]},"622":{"title":"Optional: Transaction indexer configuration options","titles":["Setting up a Celestia validator node"]},"623":{"title":"Additional resources","titles":["Setting up a Celestia validator node"]},"624":{"title":"FAQ","titles":["Setting up a Celestia validator node"]},"625":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Setting up a Celestia validator node","FAQ"]},"626":{"title":"Data availability FAQ","titles":[]},"627":{"title":"What is data availability?","titles":["Data availability FAQ"]},"628":{"title":"What is the data availability problem?","titles":["Data availability FAQ"]},"629":{"title":"How do nodes verify data availability in Celestia?","titles":["Data availability FAQ"]},"630":{"title":"What is data availability sampling?","titles":["Data availability FAQ"]},"631":{"title":"What are some of the security assumptions that Celestia makes for data availability sampling?","titles":["Data availability FAQ"]},"632":{"title":"Why is block reconstruction necessary for security?","titles":["Data availability FAQ"]},"633":{"title":"What is data storage?","titles":["Data availability FAQ"]},"634":{"title":"What is the problem around data storage?","titles":["Data availability FAQ"]},"635":{"title":"What is the difference between data availability and data storage?","titles":["Data availability FAQ"]},"636":{"title":"Where does blockchain state fit into this?","titles":["Data availability FAQ"]},"637":{"title":"Why doesn’t Celestia incentivize storage of historical data?","titles":["Data availability FAQ"]},"638":{"title":"Who may store historical data if there is no reward?","titles":["Data availability FAQ"]},"639":{"title":"What are some things blockchains can do to provide stronger assurances of data retrievability?","titles":["Data availability FAQ"]},"640":{"title":"Celestia\'s data availability layer","titles":[]},"641":{"title":"Data availability sampling (DAS)","titles":["Celestia\'s data availability layer"]},"642":{"title":"Scalability","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"643":{"title":"Fraud proofs of incorrectly extended data","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"644":{"title":"Namespaced Merkle trees (NMTs)","titles":["Celestia\'s data availability layer"]},"645":{"title":"Building a PoS blockchain for DA","titles":["Celestia\'s data availability layer"]},"646":{"title":"Providing data availability","titles":["Celestia\'s data availability layer","Building a PoS blockchain for DA"]},"647":{"title":"Monolithic vs. modular blockchains","titles":[]},"648":{"title":"Introduction","titles":[]},"649":{"title":"The lifecycle of a celestia-app transaction","titles":[]},"650":{"title":"Checking data availability","titles":["The lifecycle of a celestia-app transaction"]},"651":{"title":"How to stake TIA","titles":[]},"652":{"title":"Select your preferred wallet","titles":["How to stake TIA"]},"653":{"title":"Stake TIA with Keplr wallet","titles":["How to stake TIA"]},"654":{"title":"1️⃣ Open your Keplr browser extension","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"655":{"title":"2️⃣ Select Celestia network and search for a validator","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"656":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"657":{"title":"4️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"658":{"title":"Stake TIA with Leap wallet","titles":["How to stake TIA"]},"659":{"title":"1️⃣ Open your Leap browser extension","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"660":{"title":"2️⃣ Select a validator and stake TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"661":{"title":"3️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"662":{"title":"Stake TIA with Gem wallet","titles":["How to stake TIA"]},"663":{"title":"1️⃣ Open your Gem Wallet app","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"664":{"title":"2️⃣ Choose the amount of Celestia and search for a validator.","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"665":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"666":{"title":"4️⃣ Manage your TIA","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"667":{"title":"Paying for blobspace","titles":[]},"668":{"title":"PayForBlobs transactions","titles":["Paying for blobspace"]},"669":{"title":"Fee market overview","titles":["Paying for blobspace"]},"670":{"title":"Data retrievability and pruning","titles":[]},"671":{"title":"Data retrievability and pruning in celestia-node","titles":["Data retrievability and pruning"]},"672":{"title":"Suggested practices for rollups","titles":["Data retrievability and pruning"]},"673":{"title":"Staking, governance, & supply","titles":[]},"674":{"title":"Proof-of-stake on Celestia","titles":["Staking, governance, & supply"]},"675":{"title":"Inflation","titles":["Staking, governance, & supply"]},"676":{"title":"Decentralised governance","titles":["Staking, governance, & supply"]},"677":{"title":"Network parameters","titles":["Staking, governance, & supply","Decentralised governance"]},"678":{"title":"Community pool","titles":["Staking, governance, & supply","Decentralised governance"]},"679":{"title":"TIA allocation at genesis","titles":["Staking, governance, & supply"]},"680":{"title":"Unlocks","titles":["Staking, governance, & supply","TIA allocation at genesis"]},"681":{"title":"Staking on Celestia","titles":[]},"682":{"title":"Mainnet Beta","titles":["Staking on Celestia"]},"683":{"title":"Mocha testnet","titles":["Staking on Celestia"]},"684":{"title":"Overview of TIA","titles":[]},"685":{"title":"TIA at a glance","titles":["Overview of TIA"]},"686":{"title":"Role of TIA","titles":["Overview of TIA"]},"687":{"title":"Paying for blobspace","titles":["Overview of TIA","Role of TIA"]},"688":{"title":"Bootstrapping new rollups","titles":["Overview of TIA","Role of TIA"]},"689":{"title":"Proof-of-stake","titles":["Overview of TIA","Role of TIA"]},"690":{"title":"Decentralised governance","titles":["Overview of TIA","Role of TIA"]},"691":{"title":"Denominations","titles":["Overview of TIA","Role of TIA"]},"692":{"title":"TIA: display token","titles":["Overview of TIA","Role of TIA","Denominations"]},"693":{"title":"utia: staking denomination","titles":["Overview of TIA","Role of TIA","Denominations"]},"694":{"title":"microtia: staking denomination alias","titles":["Overview of TIA","Role of TIA","Denominations"]},"695":{"title":"Create a wallet with celestia-node","titles":[]},"696":{"title":"Using the cel-key utility","titles":["Create a wallet with celestia-node"]},"697":{"title":"Installation","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"698":{"title":"Steps for generating node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"699":{"title":"Steps for exporting node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"700":{"title":"Steps for importing node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"701":{"title":"View all options for cel-key","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"702":{"title":"Docker and cel-key","titles":["Create a wallet with celestia-node"]},"703":{"title":"Prerequisites","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"704":{"title":"Running your node","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"705":{"title":"Mounting existing keys to container","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"706":{"title":"Golang client library tutorial","titles":[]},"707":{"title":"Project setup","titles":["Golang client library tutorial"]},"708":{"title":"Submitting and retrieving blobs","titles":["Golang client library tutorial"]},"709":{"title":"Subscribing to new blobs","titles":["Golang client library tutorial"]},"710":{"title":"Subscribing to new headers","titles":["Golang client library tutorial"]},"711":{"title":"Fetching an Extended Data Square (EDS)","titles":["Golang client library tutorial"]},"712":{"title":"API documentation","titles":["Golang client library tutorial"]},"713":{"title":"Integrate Celestia for service providers","titles":[]},"714":{"title":"Getting started","titles":["Integrate Celestia for service providers"]},"715":{"title":"Celestia service provider notes","titles":["Integrate Celestia for service providers"]},"716":{"title":"Custody and key management","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"717":{"title":"RPC and querying","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"718":{"title":"Compatibility","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"719":{"title":"Syncing","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"720":{"title":"Notable exceptions relative to other blockchains","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"721":{"title":"Node API","titles":[]},"722":{"title":"RPC API","titles":["Node API"]},"723":{"title":"Library","titles":["Node API","RPC API"]},"724":{"title":"RPC","titles":["Node API","RPC API"]},"725":{"title":"RPC API tutorial","titles":["Node API","RPC API"]},"726":{"title":"Gateway API","titles":["Node API"]},"727":{"title":"Gateway API tutorial","titles":["Node API","Gateway API"]},"728":{"title":"Celestia-node RPC CLI tutorial","titles":[]},"729":{"title":"Introduction","titles":["Celestia-node RPC CLI tutorial"]},"730":{"title":"Blobs","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"731":{"title":"Namespaces","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"732":{"title":"Hardware requirements","titles":["Celestia-node RPC CLI tutorial"]},"733":{"title":"Setting up dependencies","titles":["Celestia-node RPC CLI tutorial"]},"734":{"title":"Instantiate a Celestia light node","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"735":{"title":"Connect to a core endpoint","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"736":{"title":"Keys and wallets","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"737":{"title":"RPC CLI guide","titles":["Celestia-node RPC CLI tutorial"]},"738":{"title":"Command formatting","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"739":{"title":"Basic flags","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"740":{"title":"Auth token 🔐","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"741":{"title":"Node store","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"742":{"title":"Auth token on custom or private network","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags","Node store"]},"743":{"title":"Submitting data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"744":{"title":"Optional: Submit with curl","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Submitting data"]},"745":{"title":"Retrieving data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"746":{"title":"Setting the gas price","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"747":{"title":"Examples","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"748":{"title":"Check your balance","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"749":{"title":"Check the balance of another address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"750":{"title":"Get your node ID","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"751":{"title":"Get your account address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"752":{"title":"Get block header by height","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"753":{"title":"Combined commands","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"754":{"title":"Get data availability sampler stats","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"755":{"title":"Transfer balance of utia to another account","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"756":{"title":"API version","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"757":{"title":"Help","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"758":{"title":"Advanced example","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"759":{"title":"Additional resources","titles":["Celestia-node RPC CLI tutorial"]},"760":{"title":"Submitting a blob using curl","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"761":{"title":"Post an SVG as a PFB","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"762":{"title":"Troubleshooting","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"763":{"title":"Prompt scavenger","titles":[]},"764":{"title":"Dependencies","titles":["Prompt scavenger"]},"765":{"title":"Install Celestia Node and run a light node","titles":["Prompt scavenger","Dependencies"]},"766":{"title":"OpenAI key","titles":["Prompt scavenger","Dependencies"]},"767":{"title":"Building the Prompt Scavenger","titles":["Prompt scavenger"]},"768":{"title":"Initialize your Go project","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"769":{"title":"Build your import statements","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"770":{"title":"Main function","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"771":{"title":"Utility functions","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"772":{"title":"Prompting ChatGPT","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"773":{"title":"Wrapping things up","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"774":{"title":"Next steps","titles":["Prompt scavenger"]},"775":{"title":"Rust client library tutorial","titles":[]},"776":{"title":"Project setup","titles":["Rust client library tutorial"]},"777":{"title":"Submitting and retrieving blobs","titles":["Rust client library tutorial"]},"778":{"title":"Subscribing to new headers","titles":["Rust client library tutorial"]},"779":{"title":"Fetching an Extended Data Square (EDS)","titles":["Rust client library tutorial"]},"780":{"title":"API documentation","titles":["Rust client library tutorial"]},"781":{"title":"Wallet integrations with Celestia","titles":[]},"782":{"title":"Add Celestia network parameters to Keplr with React","titles":["Wallet integrations with Celestia"]},"783":{"title":"Adding a custom chain to Leap","titles":["Wallet integrations with Celestia"]},"784":{"title":"Adding a custom chain to Cosmostation","titles":["Wallet integrations with Celestia"]}},"dirtCount":0,"index":[["∑i=1nssn",{"2":{"590":1}}],["×ss×gcpbb",{"2":{"590":1}}],[">",{"2":{"575":3}}],["||",{"2":{"696":2}}],["|",{"2":{"264":4,"361":14,"372":12,"475":2,"537":4,"539":1,"558":4,"602":4,"743":4,"745":2,"753":2,"755":2,"758":2}}],["~2",{"2":{"483":1}}],["~20",{"2":{"214":1}}],["~5",{"2":{"369":1}}],["~",{"2":{"246":1,"247":1,"336":4,"372":18,"377":2,"423":1,"424":1,"468":1,"469":1,"557":1,"569":2,"705":2,"765":2}}],["~1",{"2":{"369":1}}],["~10",{"2":{"215":1}}],["~1hr",{"2":{"215":1}}],["~30",{"2":{"217":1}}],["~3",{"2":{"215":1,"369":1}}],["^external",{"2":{"378":2}}],["^persistent",{"2":{"361":6}}],["^seeds",{"2":{"361":4}}],["^",{"2":{"203":2,"214":4,"215":4}}],["^0",{"2":{"118":2,"163":2}}],["\\tpromptanswer",{"2":{"773":2}}],["\\tproof",{"2":{"144":2}}],["\\tpayload",{"2":{"771":2}}],["\\theader",{"2":{"711":2}}],["\\theaderchan",{"2":{"710":2}}],["\\thelloworldblob",{"2":{"596":2,"708":2}}],["\\theight",{"2":{"144":2,"160":2,"163":4,"596":2,"708":2,"771":2}}],["\\tns",{"2":{"771":2}}],["\\tnodeip",{"2":{"770":2,"771":2,"773":2}}],["\\tnodeclient",{"2":{"769":2}}],["\\tnonce",{"2":{"144":2,"160":2,"163":4}}],["\\tnamespaceid",{"2":{"771":2,"773":2}}],["\\tnamespacebytes",{"2":{"771":2}}],["\\tnamespace",{"2":{"596":2,"708":2,"709":2,"710":2}}],["\\tlog",{"2":{"771":6,"773":4}}],["\\tlight",{"2":{"559":2}}],["\\tlatestblocknumber",{"2":{"144":2,"161":2}}],["\\tretrievedblobs",{"2":{"596":2,"708":2}}],["\\treturn",{"2":{"144":4,"156":8,"157":2,"158":2,"159":2,"160":2,"163":18,"596":2,"708":2,"711":2,"771":4,"772":4}}],["\\trowproofs",{"2":{"159":2,"163":2}}],["\\trowroots",{"2":{"158":2,"163":2}}],["\\tmaxns",{"2":{"156":2,"163":2}}],["\\tmaxsquaresize",{"2":{"150":2}}],["\\tminns",{"2":{"156":2,"163":2}}],["\\tsimplerollup",{"2":{"163":2}}],["\\tsimplerollupwrapper",{"2":{"163":2}}],["\\tsidenodes",{"2":{"144":2,"160":2,"163":2}}],["\\tshareproofs",{"2":{"156":2,"163":2}}],["\\tsharesproof",{"2":{"153":1,"163":4}}],["\\tsubtreerootthreshold",{"2":{"150":2}}],["\\tversion",{"2":{"150":2,"156":4,"163":6}}],["\\tvalid",{"2":{"144":2}}],["\\tvar",{"2":{"144":2,"156":6,"157":2,"161":2,"163":10}}],["\\twrappedproof",{"2":{"144":2}}],["\\twrapper",{"2":{"144":2,"161":2}}],["\\tcreatedblob",{"2":{"771":4,"773":2}}],["\\tclient",{"2":{"596":4,"708":4,"709":2,"710":2,"711":2,"770":2,"771":4,"773":2}}],["\\tcopy",{"2":{"156":6,"157":2,"163":2}}],["\\tcommitted",{"2":{"144":2}}],["\\tctx",{"2":{"143":2,"144":2,"163":4,"770":2,"771":4,"773":2}}],["\\tfetchedblob",{"2":{"771":2,"773":2}}],["\\tfor",{"2":{"144":4,"156":2,"158":2,"159":2,"160":2,"161":2,"163":16,"709":2,"710":2}}],["\\tfmt",{"2":{"143":2,"596":4,"708":4}}],["\\tblobchan",{"2":{"709":2}}],["\\tblobsharerange",{"2":{"150":2}}],["\\tblobstreamxwrapper",{"2":{"144":4,"163":2}}],["\\tblockdataroot",{"2":{"160":2,"163":2}}],["\\tblockres",{"2":{"144":2,"150":2}}],["\\ttmproto",{"2":{"163":2}}],["\\ttuple",{"2":{"144":2}}],["\\ttxhash",{"2":{"150":2}}],["\\ttx",{"2":{"144":2,"150":2,"163":2}}],["\\ttrpc",{"2":{"143":2,"144":2}}],["\\teventsiterator",{"2":{"144":2,"161":2}}],["\\tethclient",{"2":{"144":2,"161":2,"163":2}}],["\\tethcmn",{"2":{"144":2,"163":2}}],["\\terr",{"2":{"136":2,"143":2,"144":6,"161":2,"163":4}}],["\\tdatarootinclusionproof",{"2":{"160":2,"163":4}}],["\\tdataroot",{"2":{"144":2,"163":2}}],["\\tdcproof",{"2":{"143":2,"144":2}}],["\\tdefer",{"2":{"136":2,"144":2,"161":2,"163":2,"770":4,"771":4,"773":4}}],["\\t",{"2":{"136":6,"143":14,"144":90,"148":2,"150":22,"153":2,"156":8,"157":2,"158":2,"159":2,"160":4,"161":27,"162":24,"163":98,"557":2,"559":4,"596":28,"708":28,"709":12,"710":12,"711":8,"769":28,"770":24,"771":54,"773":26}}],["\\t\\tlog",{"2":{"770":4,"771":10,"773":12}}],["\\t\\tuint64",{"2":{"163":2}}],["\\t\\tclient",{"2":{"163":2}}],["\\t\\tctx",{"2":{"163":2,"772":2}}],["\\t\\tcase",{"2":{"162":4,"709":4,"710":4}}],["\\t\\tcopy",{"2":{"160":2}}],["\\t\\tproof",{"2":{"160":2,"163":2}}],["\\t\\tvar",{"2":{"160":2,"163":2}}],["\\t\\tversion",{"2":{"156":4,"157":2,"163":6}}],["\\t\\trowproofs",{"2":{"159":2,"163":2}}],["\\t\\trowroots",{"2":{"158":2,"163":2}}],["\\t\\treturn",{"2":{"136":2,"144":30,"150":8,"161":14,"163":8,"596":10,"708":10,"709":6,"710":6,"711":4,"771":6}}],["\\t\\tdcproof",{"2":{"163":2}}],["\\t\\tdigest",{"2":{"156":2,"163":4}}],["\\t\\tdataroot",{"2":{"144":2}}],["\\t\\tmax",{"2":{"156":2,"163":2}}],["\\t\\tmaxsquaresize",{"2":{"150":2}}],["\\t\\tmin",{"2":{"156":2,"163":2}}],["\\t\\tfor",{"2":{"156":2,"159":2,"163":6}}],["\\t\\tfmt",{"2":{"143":6,"144":6,"163":2}}],["\\t\\tselect",{"2":{"709":2,"710":2}}],["\\t\\tsharesproof",{"2":{"163":2}}],["\\t\\tshareproofs",{"2":{"156":2,"163":2}}],["\\t\\tsimplerollupwrapper",{"2":{"163":2}}],["\\t\\tsidenodes",{"2":{"144":4,"156":2,"159":2,"160":2,"163":6}}],["\\t\\tsubtreerootthreshold",{"2":{"150":2}}],["\\t\\tid",{"2":{"156":4,"157":2,"163":12}}],["\\t\\tint",{"2":{"150":2}}],["\\t\\tif",{"2":{"136":2,"144":2,"161":2}}],["\\t\\tblockdataroot",{"2":{"163":2}}],["\\t\\tblockres",{"2":{"150":2,"163":2}}],["\\t\\tbig",{"2":{"144":2}}],["\\t\\twrappedproof",{"2":{"144":2}}],["\\t\\ttuplerootnonce",{"2":{"160":2,"163":2}}],["\\t\\ttuple",{"2":{"144":2,"160":2,"163":2}}],["\\t\\tnumleaves",{"2":{"144":2}}],["\\t\\tnil",{"2":{"144":6,"161":6}}],["\\t\\tkey",{"2":{"144":2}}],["\\t\\theight",{"2":{"144":2}}],["\\t\\tevent",{"2":{"163":2}}],["\\t\\te",{"2":{"144":2,"161":2}}],["\\t\\terr",{"2":{"136":2}}],["\\t\\tos",{"2":{"143":6,"144":2,"163":2}}],["\\t\\t\\tif",{"2":{"710":2}}],["\\t\\t\\tfmt",{"2":{"709":2,"710":2}}],["\\t\\t\\tfor",{"2":{"163":2}}],["\\t\\t\\tattestationproof",{"2":{"163":2}}],["\\t\\t\\trowproofs",{"2":{"163":2}}],["\\t\\t\\trowroots",{"2":{"163":2}}],["\\t\\t\\treturn",{"2":{"162":2,"709":2,"710":2}}],["\\t\\t\\tnamespace",{"2":{"163":2}}],["\\t\\t\\tnumleaves",{"2":{"159":2,"160":2,"163":4}}],["\\t\\t\\tdata",{"2":{"163":2}}],["\\t\\t\\tdataroot",{"2":{"160":2,"163":2}}],["\\t\\t\\theight",{"2":{"160":2,"163":2}}],["\\t\\t\\tkey",{"2":{"159":2,"160":2,"163":4}}],["\\t\\t\\tcopy",{"2":{"159":2}}],["\\t\\t\\tcontext",{"2":{"144":2,"161":2,"162":2,"163":2}}],["\\t\\t\\tvar",{"2":{"159":2,"163":2}}],["\\t\\t\\tblobs",{"2":{"710":2}}],["\\t\\t\\tbzsidenode",{"2":{"163":2}}],["\\t\\t\\tbeginkey",{"2":{"156":2,"163":2}}],["\\t\\t\\tbreak",{"2":{"144":2,"161":2}}],["\\t\\t\\tshareproofs",{"2":{"163":2}}],["\\t\\t\\tsidenodes",{"2":{"156":4,"159":4,"160":2,"163":10}}],["\\t\\t\\tstart",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tfmt",{"2":{"710":2}}],["\\t\\t\\t\\tbzsidenode",{"2":{"163":2}}],["\\t\\t\\t\\tdatacommitment",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tendblock",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tstartblock",{"2":{"144":2,"161":2}}],["\\t\\t\\t\\tproofnonce",{"2":{"144":2,"161":2}}],["\\t\\t\\tevent",{"2":{"144":2,"161":2}}],["\\t\\t\\tendkey",{"2":{"156":2,"163":2}}],["\\t\\t\\tend",{"2":{"144":2,"161":2}}],["\\t\\t\\t",{"2":{"136":2,"144":2,"161":2,"162":2,"163":2,"710":4}}],["\\t\\t",{"2":{"136":4,"144":8,"148":4,"150":2,"153":2,"156":4,"159":4,"160":4,"161":6,"162":4,"163":20,"709":2,"710":2}}],["\\tif",{"2":{"136":4,"143":6,"144":32,"150":8,"153":2,"161":14,"163":10,"596":10,"708":10,"709":6,"710":6,"711":4,"770":4,"771":16,"772":2,"773":12}}],["🤪",{"2":{"126":1}}],["```json",{"2":{"752":2}}],["```",{"2":{"752":2}}],["`cel",{"2":{"697":2}}],["`celestia",{"2":{"597":4}}],["`file`",{"2":{"557":2}}],["`$home",{"2":{"361":2}}],["`job=",{"2":{"275":2}}],["`json",{"2":{"125":22}}],["`private",{"2":{"202":2}}],["`mnemonic",{"2":{"202":2}}],["`wallet",{"2":{"202":4}}],["`trpc",{"2":{"163":4}}],["`blobstreamdatacommitmentstored`",{"2":{"161":2,"162":2,"163":2}}],["`availabledataroot`",{"2":{"160":2}}],["`",{"2":{"125":22,"275":2,"697":2,"782":12}}],["=1",{"2":{"483":1}}],["==",{"2":{"144":2,"156":6,"159":3,"161":2,"392":2,"393":2,"589":1,"772":2}}],["=",{"2":{"118":2,"128":28,"130":14,"136":12,"140":8,"143":14,"144":74,"148":8,"150":22,"153":4,"156":20,"158":6,"159":12,"160":10,"161":30,"162":18,"163":96,"175":4,"215":2,"216":1,"218":1,"233":1,"274":8,"303":10,"338":1,"350":1,"352":2,"361":22,"364":2,"365":2,"366":2,"367":3,"368":6,"371":8,"373":1,"378":4,"380":2,"381":2,"429":170,"435":8,"451":2,"544":29,"558":1,"588":1,"590":4,"591":2,"596":20,"597":44,"620":1,"693":1,"708":20,"709":14,"710":18,"711":8,"762":4,"770":10,"771":34,"772":8,"773":26,"777":10,"778":20,"779":4,"782":8}}],["z20=",{"2":{"745":2}}],["zshrcecho",{"2":{"399":1}}],["zshrc",{"2":{"399":3}}],["zxrxj96",{"2":{"147":2}}],["zhsjrh",{"2":{"142":2}}],["zero",{"2":{"118":2,"124":1,"221":1}}],["zkvm",{"2":{"221":1,"227":1,"583":1}}],["zkp",{"2":{"118":2}}],["zk",{"0":{"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"232":1},"1":{"187":1,"188":2,"189":2,"190":1,"191":2,"192":2,"193":2,"194":1,"195":1,"196":1,"233":1,"234":1,"235":1,"236":1},"2":{"118":7,"127":2,"139":2,"165":1,"169":1,"186":1,"187":2,"188":1,"190":2,"191":4,"193":1,"194":5,"196":1,"197":1,"221":1,"227":4}}],["zip",{"2":{"88":2}}],["$address",{"2":{"755":6}}],["$auth",{"2":{"738":2}}],["$input",{"2":{"537":2}}],["$ip",{"2":{"452":2}}],["$trusted",{"2":{"558":4,"559":2}}],["$tx",{"2":{"537":2}}],["$tia",{"2":{"447":2}}],["$to",{"2":{"294":6,"295":2,"297":2,"301":2}}],["$granter",{"2":{"408":2,"412":2,"413":2}}],["$grantee",{"2":{"407":2,"410":2,"412":2}}],["$gopath",{"2":{"342":1,"343":1}}],["$network",{"2":{"390":3,"392":3,"393":3}}],["$networkdocker",{"2":{"390":3,"392":3,"393":3}}],["$node",{"2":{"390":6,"392":2,"452":2,"605":2,"741":3}}],["$encoded",{"2":{"538":2}}],["$external",{"2":{"378":2}}],["$etherscan",{"2":{"210":2}}],["$peer",{"2":{"452":1}}],["$peerpeer=",{"2":{"452":1}}],["$persistent",{"2":{"361":12}}],["$port",{"2":{"452":2}}],["$path",{"2":{"399":1}}],["$private",{"2":{"210":2}}],["$signer",{"2":{"519":2}}],["$shell",{"2":{"399":1}}],["$seeds",{"2":{"361":8}}],["$staking",{"2":{"272":2,"449":3}}],["$",{"2":{"312":2,"314":12,"343":4,"361":2,"372":6,"398":2,"556":2,"705":2,"753":2,"758":2}}],["$from",{"2":{"294":6,"296":2,"297":2,"301":2}}],["$broadcast",{"2":{"279":2}}],["$multisig",{"2":{"279":10}}],["$celestia",{"2":{"291":2,"292":2,"294":6,"295":2,"296":2,"297":4,"538":2,"760":2}}],["$celes",{"2":{"272":2}}],["$chain",{"2":{"272":4,"279":10,"445":4,"449":2}}],["$keyring",{"2":{"279":4}}],["$key",{"2":{"272":6,"446":3,"447":3,"449":3}}],["$validator",{"2":{"272":2,"279":6,"445":3,"614":2}}],["$rpc",{"2":{"210":2,"301":2,"390":6,"393":6,"407":2,"408":2,"412":2}}],["$request",{"2":{"70":1,"467":1,"510":1,"736":1}}],["$home",{"2":{"104":2,"203":2,"208":2,"211":2,"214":2,"215":2,"275":3,"286":3,"287":1,"288":2,"291":2,"311":3,"312":1,"341":2,"342":1,"343":1,"349":3,"361":11,"371":1,"372":6,"375":2,"378":2,"391":4,"392":8,"393":8,"399":20,"429":2,"444":2,"448":1,"449":1,"450":4,"451":1,"475":4,"476":6,"477":6,"542":2,"543":2,"742":4}}],["🌉🌉🌉🌉🌉",{"2":{"93":2}}],["⏰⏰⏰⏰⏰⏰",{"2":{"93":2}}],["🔐",{"0":{"740":1}}],["😜",{"2":{"557":1}}],["😎",{"2":{"391":2,"542":1}}],["🐳",{"0":{"388":1},"1":{"389":1,"390":1,"391":1,"392":1,"393":1,"394":1,"395":1,"396":1}}],["🙂",{"2":{"124":1}}],["🔃🔃🔃",{"2":{"93":2}}],["🚀🚀🚀🚀",{"2":{"93":2}}],["📝📝📝📝📝",{"2":{"93":2}}],["💰💰💰💰💰💰",{"2":{"93":2}}],["😁",{"2":{"91":1}}],["9anbaxno1b4x5lr2qy5qwqwrmnozejkctxwzq9bexsg=",{"2":{"752":4}}],["91e04695cf9cf531bc0891e7b1d602b3e8022c86",{"2":{"752":8}}],["99",{"2":{"630":1}}],["999994999800000",{"2":{"297":2}}],["94721",{"2":{"558":1}}],["9390",{"2":{"508":1}}],["973",{"2":{"483":2,"586":1}}],["96112",{"2":{"294":4}}],["90",{"2":{"679":1}}],["9099",{"2":{"508":1}}],["9095",{"2":{"489":1}}],["9090",{"2":{"65":1,"68":1,"244":1,"245":1,"275":2,"313":2,"326":1,"422":1,"465":1,"475":4,"489":2,"493":6,"505":2,"508":5,"735":1,"760":1}}],["9000000utia",{"2":{"449":1}}],["90000",{"2":{"144":2,"161":4}}],["9",{"0":{"92":1}}],["xxd",{"2":{"537":2}}],["xxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"766":1}}],["xxxxxxxxxxxxxxxxxxxxxxxxexport",{"2":{"766":1}}],["xxxxxxxxxxxxx",{"2":{"287":4}}],["xzf",{"2":{"399":8}}],["xf",{"2":{"372":6}}],["x86",{"2":{"312":1,"342":1}}],["xv92a3qxexport",{"2":{"287":1}}],["xv92a3qx",{"2":{"287":3}}],["x64",{"2":{"240":1,"358":1,"417":1,"462":1,"612":1}}],["xthp6xws=",{"2":{"152":2}}],["xiijl+gqm0fqxiw0z0o",{"2":{"152":2}}],["x",{"0":{"97":1,"111":1,"200":1,"232":1,"233":1,"234":1,"235":1},"1":{"98":1,"99":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"233":1,"234":1,"235":1,"236":1},"2":{"91":4,"96":1,"97":1,"108":1,"121":1,"122":7,"163":4,"164":1,"201":1,"203":2,"216":3,"217":1,"218":4,"219":2,"221":3,"222":2,"233":6,"234":3,"235":3,"266":1,"281":1,"372":6,"373":2,"475":2,"538":2,"543":1,"544":1,"591":2,"597":2,"620":2,"708":1,"760":2,"770":4,"771":10}}],["xyz",{"2":{"64":3,"218":1,"251":1,"253":1,"254":1,"256":1,"257":1,"429":6,"485":3,"487":1,"488":2,"489":2,"493":1,"503":3,"505":2,"506":2,"508":2}}],["7a5fabb19713d732d967b1da84fa0df5e87a7b62302d783f78743e216c1a3550",{"2":{"752":2}}],["741743z",{"2":{"752":2}}],["746",{"2":{"383":2,"625":2}}],["79",{"2":{"679":1}}],["75",{"2":{"607":1,"608":1,"609":1,"680":1}}],["73\\tnode",{"2":{"557":2}}],["767",{"2":{"536":2}}],["76au8rj4vsyvasph5lgqq2kg",{"2":{"147":2}}],["786bytes",{"2":{"483":1}}],["786",{"2":{"483":1,"586":1}}],["782",{"2":{"383":2,"625":2}}],["71",{"2":{"476":4,"750":4}}],["770",{"2":{"383":2,"625":2}}],["7",{"0":{"90":1},"2":{"147":2,"295":2,"428":1,"536":2,"679":1,"752":4}}],["554+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"765":2}}],["5iieerohbmff+ser3jpvroieejzjby+tre0ntadqll3",{"2":{"752":4}}],["59",{"2":{"679":1}}],["564+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"765":2}}],["56",{"2":{"460":2,"533":1,"732":2}}],["5s",{"2":{"275":2,"429":4}}],["512gb",{"2":{"217":1}}],["5158076079",{"2":{"93":2}}],["53",{"2":{"214":2}}],["57",{"2":{"163":2}}],["58",{"2":{"93":2,"156":4,"163":2,"214":2}}],["5",{"0":{"88":1,"395":1},"2":{"142":2,"147":2,"163":2,"275":2,"281":1,"429":4,"525":1,"526":1,"528":1,"592":2,"675":1,"685":1,"763":2,"764":1,"772":1,"774":2,"784":1}}],["500000000",{"2":{"752":4}}],["5000100000000utia",{"2":{"272":2}}],["500utia",{"2":{"477":1}}],["500utiacelestia",{"2":{"477":1}}],["500ms",{"2":{"429":4}}],["500",{"2":{"429":2,"460":1,"533":1,"586":1,"732":1}}],["504g",{"2":{"214":1,"215":1}}],["50",{"2":{"20":1,"22":2,"27":1,"732":1}}],["✨",{"2":{"85":1,"93":2}}],["02",{"2":{"752":2,"782":2}}],["025",{"2":{"429":2}}],["06",{"2":{"752":4}}],["0blockhash",{"2":{"537":1}}],["09",{"2":{"530":1}}],["08",{"2":{"530":2,"755":1}}],["07",{"2":{"434":8}}],["0ns",{"2":{"434":4}}],["0mfhykqui2bu+u1jxpzg7qy2bvv1lb3kiu+zak7nuiy=",{"2":{"331":2,"332":4,"333":2,"743":2}}],["0+",{"2":{"328":1,"428":1,"738":1}}],["010",{"2":{"321":1}}],["01",{"2":{"272":2,"429":6,"487":1,"488":1,"489":1,"506":1,"507":1,"508":1,"620":2,"782":2}}],["011",{"2":{"169":1}}],["03",{"2":{"214":2}}],["05",{"2":{"214":2,"765":4}}],["008",{"2":{"755":1}}],["004celestia",{"2":{"746":1}}],["004",{"2":{"746":3}}],["002",{"2":{"746":1,"760":2}}],["001hermes",{"2":{"433":2,"434":1}}],["001",{"2":{"429":3,"430":2,"432":1,"433":4,"434":7,"435":3}}],["003442",{"2":{"337":4}}],["000",{"2":{"281":1,"589":2,"590":1,"679":3,"685":3,"693":2}}],["000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000121312324243243288993946154604701154f739f3d1b5475786ddd960f06d8708d4e870da6501c51750",{"2":{"152":2}}],["00000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000584cb53884b394593052df4039e58c7d51f0e45cace7dd584125f62f9261b7900ac1eeef5e82349",{"2":{"147":2}}],["00",{"2":{"214":2,"530":3,"679":1,"680":2}}],["048091bc7ddc283f77bfbf91d73c44da58c3df8a9cbc867405d8b7f3daada22f",{"2":{"752":2}}],["04",{"2":{"214":16,"240":1,"358":1,"383":2,"417":1,"462":1,"612":1,"625":2,"718":1}}],["0xbe",{"2":{"596":2,"708":2,"709":2,"710":2,"777":2,"778":2}}],["0xb6052122545aacd2bdda0ca9fa56416bd968cdbc",{"2":{"101":1}}],["0x",{"2":{"210":1,"743":2}}],["0x0",{"2":{"383":2,"539":1,"625":2}}],["0x0000000000000000",{"2":{"536":2}}],["0x0000000000000000000000000000000000000000",{"2":{"536":2}}],["0x0000000000000000000000000000000000000000000000000000000000000000",{"2":{"536":2}}],["0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",{"2":{"536":2}}],["0x0000000000000000000000000000000000000000000000000000000000000001",{"2":{"202":2}}],["0x0000000000000000000000000000000000000001",{"2":{"202":2}}],["0x007d0b2a2e2b013612e8",{"2":{"215":2}}],["0x0c",{"2":{"109":1}}],["0x04cae899fc0b7ef45c529f8bf075d54f6fb70ed9",{"2":{"101":1}}],["0x03b43f7b61fa100611191f481ef48aa1fc98f434",{"2":{"101":1}}],["0x01b5905b154f21a393f5b5a0c6d15b53a493c05e",{"2":{"100":1}}],["0x019850732270d8c436585c7921219252422228b5d0f559da0da219f0fa2b7216",{"2":{"93":2}}],["0x8e1ede4ce0865b41d714",{"2":{"215":2}}],["0x89b7c7970c13bb587893a70697ad6d2a335b6a15",{"2":{"101":1}}],["0x8f97cb7c643acd7f79f3b13841b24a243da51242",{"2":{"101":1}}],["0x8dee6e88d3b62b258c1574cbb7005e1c3cf193b60a99b5c2fcfae00819b7ed82",{"2":{"93":2}}],["0xde",{"2":{"596":2,"708":2,"709":2,"710":2,"777":2,"778":2}}],["0xdeadbeef",{"2":{"596":4,"708":4,"709":3,"710":5,"778":3}}],["0xd4b998a35d20d98ed3488221f0c161a0a9572d3de66399482553c8e3d2fae751",{"2":{"536":2}}],["0xd883010d04846765746888676f312e32312e33856c696e7578000000000000006b3afa42dce1f87f1f07a1ef569c4d43e41738ef93c865098bfa1458645f384e2e4498bcfe4ad9353ff1913a2e16162f496fafe5b0939a6c78fb5b503248d6da01",{"2":{"536":2}}],["0xd2d353916b34a877793628049c99858f04123ee1",{"2":{"100":1}}],["0xd0a6699fc7519966685181c80bf98d35afa1fc95",{"2":{"100":1}}],["0xef",{"2":{"596":2,"708":2,"709":2,"710":2,"777":2,"778":2}}],["0xe2662ff9b41f39e63a850e50e013ea66e60a4f37",{"2":{"100":1}}],["0xe24a60b758b51b0a3da5e8f4f6ddf1cd0aff646c",{"2":{"100":1}}],["0xe371afcb8437bf61bd831ef57be7a2496d88488b",{"2":{"100":1}}],["0x383ed2debf9f9055920cd7340418dda7e2bca6b989eb6992d83d123d4e322f2a",{"2":{"537":2}}],["0x3c44cdddb6a900fa2b585dd299e03d12fa4293bc",{"2":{"537":2}}],["0x3",{"2":{"383":6,"625":6}}],["0x3b6e845fb9f0c8ee4e9f6d44781f6547d9c6359a",{"2":{"101":1}}],["0x3bc040eaca40b91fa06cf55ea91842fac88b1af4",{"2":{"100":1}}],["0x3681cbb0e95ab50b63f2fc524fbbcc78adefbd33",{"2":{"100":1}}],["0xad",{"2":{"596":2,"708":2,"709":2,"710":2,"777":2,"778":2}}],["0xaddress",{"2":{"544":11}}],["0xadd3a5dc0b8c605aeac891098e87cbaff43bb642896ebbf74f964c0690e46df2",{"2":{"537":2}}],["0xaf5c1505c7dfcebca94d9a6a8c0caf99b6c87a8ed6d6c0b3161c9026f270a84f",{"2":{"537":2}}],["0xaf8ff6af1180c8be9e4e8f3a5f882b3b227233f4abbefa479836d3721682a389",{"2":{"536":2}}],["0xa83ca7775bc2889825bcdedffa5b758cf69e8794",{"2":{"231":2}}],["0xa2140c9bde000dc5e21e",{"2":{"215":2}}],["0xac3427e621c6f10dc2abdab00188d92690503914",{"2":{"100":1}}],["0xa773e19dc9e822933a7e72df9c87ed1578701d29",{"2":{"100":1}}],["0xaa",{"2":{"210":1}}],["0xaa3b8b63ccca3c98b948fd1d6ed875d378de2c6c",{"2":{"99":1}}],["0xaae3a04931345df5ac6e784bb6bdeb29b1ff0286",{"2":{"98":1}}],["0x28",{"2":{"383":2,"625":2}}],["0x2b30a00",{"2":{"383":2,"625":2}}],["0x20d8153aacc4e6d29558fa3916bff422bede9b5e",{"2":{"101":1}}],["0x2588867f19e2de51f90f0ab852c7ad11228e3d83",{"2":{"100":1}}],["0x22a6580faeca49cf86cbb2f18f2b7f98031fc6ad",{"2":{"98":1}}],["0x55527d53fda37dbf1924482b40acf8625e1caa5b",{"2":{"101":1}}],["0x5a48adf22f526ebd06e3e8856cfea2490923cc55",{"2":{"101":1}}],["0x51d196e07a27dba0f4461dd6cc26108424f196f7",{"2":{"101":1}}],["0x5187a92539bb4a2befe1fc078745c84ab6d37171",{"2":{"100":1}}],["0x53dea3a90fd6c82840a1f7224f799d622f142df4",{"2":{"100":1}}],["0x5810f0916bae1067ca1efcc00aaaf30301af001c",{"2":{"100":1}}],["0x59d2db6c5095b9e329c80211b7a761d20064379e3382d156b69e5cf3b5fe2fc7",{"2":{"93":2}}],["0x664bf4bb4a57dd5768a0a98991d77c58fb7a4e164c2581c79fb33ce9c3d4c250",{"2":{"536":2}}],["0x676d",{"2":{"332":2,"743":3}}],["0x61254e43e5c1e9e801f9c56b47a9ac3eadf6d1e9",{"2":{"101":1}}],["0x61e154128b6a1400ea8090b4431b4aa1dbb80cc4",{"2":{"100":1}}],["0x630093954cbf19fe4532a2edd0bd3b10deca7a4d",{"2":{"100":1}}],["0x6cb49605f10831749c6090ad09918bc61439bace",{"2":{"100":1}}],["0x6c7360a96165c570dcb7ce609d748d612c5fa5b76e229cd81ba5f5c93c00f805",{"2":{"93":2}}],["0x9f4dfae061b5ddd86f95a81be5daa0d7fe32e7f7f770f86dc375e0007d249bd2",{"2":{"537":2}}],["0x9039e58b2089e5f9abbb",{"2":{"215":2}}],["0x9c3f372a2aacc0d7272f56a4664311b7647b0031",{"2":{"214":32}}],["0x99e9d2f04352b42c18f1da5dd93a970f82c08afe",{"2":{"101":1}}],["0x9abc41fefae7e7543a01fa837aec909f96147280",{"2":{"101":1}}],["0x95cbda89325db5529eaf1813e181f66b83a7d65a",{"2":{"100":1}}],["0x95fea00e689e8d1cba909836e1ef1b941d5f21b1",{"2":{"100":1}}],["0x97b50f60b60d0e658fdbf185969db0a0327bd0ae9e57cd65af2a7f9be0eeb5b0",{"2":{"93":2}}],["0x4772756763686174",{"2":{"477":2}}],["0x40002a61b0",{"2":{"383":2,"625":2}}],["0x400065ea88",{"2":{"383":10,"625":10}}],["0x400143e048",{"2":{"383":2,"625":2}}],["0x400153b240",{"2":{"383":2,"625":2}}],["0x40f8c63e0a20b399bcd9631a22e57bb988a9400e",{"2":{"101":1}}],["0x42690c204d39600fddd3celestia",{"2":{"745":1,"753":1,"758":1}}],["0x42690c204d39600fddd3",{"2":{"331":2,"332":2,"333":2,"408":2,"518":2,"519":2,"738":4,"743":5,"745":7,"746":2,"753":1,"758":1}}],["0x4270889adcb82338c5ff5e64b45c0a3d31cfd08c",{"2":{"99":1}}],["0x44b412b291fef00398501b2ca353ea912ad0fe13",{"2":{"101":1}}],["0x4888fdf44251d456bbfca92bfc6e180cfe0b096ffbea2f6da2a203a16902214f",{"2":{"93":2}}],["0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",{"2":{"536":2}}],["0x1cb54d2369752ef73511c202ff9cdfd0eadf3a77b7aef0092bea63f2b5d57659",{"2":{"536":2}}],["0x1cc4551922c069a9ade06756bf14bf0410ea44ff",{"2":{"101":1}}],["0x1b91180",{"2":{"383":2,"625":2}}],["0x1bb8add5e878b12fa37756392642eb94c53a1cf4",{"2":{"99":1,"101":1}}],["0x1ae3a8dc1e7efd37f418b2987d3df74c5a917a8b",{"2":{"101":1}}],["0x10c65b27d5031ce2351c719072e58f3153228887f027f9f6d65300d2b5b30152",{"2":{"96":1}}],["0x715ab246772c923104c556dc28d5d4fcfca0398b0a252bcd19dd5705495756accelestia",{"2":{"563":1}}],["0x715ab246772c923104c556dc28d5d4fcfca0398b0a252bcd19dd5705495756ac",{"2":{"562":2,"563":3}}],["0x71756f746573",{"2":{"562":3,"563":4}}],["0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"536":2}}],["0x7973d0b475e898082df25c1617cbce1917cfed17",{"2":{"100":1}}],["0x79751b011bcc20f413a2c4e3af019b6e2a9738b9",{"2":{"98":1,"100":1}}],["0x7cf3876f681dbb6eda8f6ffc45d66b996df08fae",{"2":{"231":1}}],["0x78f8b2941dde5a8a312814ebd29c2e2a36f25e91",{"2":{"101":1}}],["0x7fc4d9a24949680fad666feee7cd6a100e39c4f0",{"2":{"100":1}}],["0x7fbeb5bc73a11b438891022786feb2c624f275f0",{"2":{"93":2}}],["0xff00000000000000000000000000000000000901",{"2":{"537":3}}],["0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1e",{"2":{"231":1}}],["0xf6759ff933786ddacb92",{"2":{"215":2}}],["0xfill",{"2":{"211":4}}],["0xf889a3174fddd9f78e6cd250ebf4c16f1bdd1b6a",{"2":{"101":1}}],["0xfb612fb83959b8acd3e49540b29c93c5a67e05f1",{"2":{"100":1}}],["0xf47dc66514fd78e4666e35abd12df7d1ae2c79f69f7dfedb8d98e4106142ab7c",{"2":{"93":2}}],["0xf2ddc2dad90e7e2b20a772bf89f989224165659d50824b98d7340e12265abf01",{"2":{"93":2}}],["0xf31fd34f8a9d9057198d8b13e755e583766bd528459733d948d9ffbc980c9506",{"2":{"93":2}}],["0xce",{"2":{"537":2}}],["0xce3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"537":2}}],["0xce1636cfaf2bd5497c11",{"2":{"215":2}}],["0xcryptovestor",{"2":{"487":1}}],["0xc7535f078cb3880a0fd5e54fa7a3b4eaf09b3924",{"2":{"101":1}}],["0xc99eea0b8e67d5b2226ab6d37882daaf6dd7593b",{"2":{"101":1}}],["0xcd9fca5015b5ce2b06a2266e4a5dd54d9ca39f1a",{"2":{"101":1}}],["0xc61382d5609ab0ece36b2776349c8bdceeafdd13dde9624cdf3d746fb4cf7d79",{"2":{"93":2}}],["0xc3e209eb245fd59c8586777b499d6a665df3abd2",{"2":{"91":2,"97":1,"231":2}}],["0",{"2":{"82":2,"84":2,"91":6,"93":6,"96":1,"117":1,"118":2,"128":2,"139":1,"140":6,"142":2,"147":16,"152":12,"153":3,"156":2,"160":2,"163":6,"174":1,"175":6,"206":1,"274":2,"275":4,"294":10,"295":2,"296":2,"297":4,"312":1,"313":4,"332":2,"333":15,"365":3,"368":4,"371":2,"373":2,"377":20,"383":14,"408":2,"409":2,"429":14,"434":14,"435":2,"476":16,"528":2,"537":7,"538":8,"559":2,"563":2,"588":4,"589":1,"592":2,"596":2,"597":8,"614":8,"620":10,"625":14,"671":2,"708":2,"724":1,"745":8,"746":5,"748":2,"749":2,"750":10,"751":2,"752":10,"755":3,"760":14,"765":1,"771":4,"772":2,"777":4,"782":6,"784":3}}],["qo",{"2":{"378":2}}],["qgb",{"2":{"163":2,"221":1}}],["qmaezrnbtgexcryc8pcvgrbs+umukniborae4qye7osgwcrwbvys",{"2":{"752":2}}],["qm",{"2":{"147":2}}],["q5",{"2":{"42":1}}],["q4",{"2":{"42":1}}],["q3",{"2":{"42":1}}],["q2",{"2":{"42":1}}],["q1",{"2":{"42":1}}],["q",{"2":{"38":1,"53":1,"54":1,"55":1,"58":1,"264":6,"265":4,"266":4,"267":2}}],["quic",{"2":{"750":6}}],["quickly",{"2":{"371":2,"558":1,"586":1,"688":1}}],["quicker",{"2":{"370":1}}],["quick",{"0":{"372":1,"390":1,"555":1},"1":{"556":1,"557":1,"558":1,"559":1,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1},"2":{"307":1,"369":1,"372":2,"392":1,"428":1,"443":1,"555":1,"558":2,"719":1,"725":1}}],["quickstart",{"0":{"81":1,"461":1,"573":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"574":1,"575":1,"576":1},"2":{"83":1,"103":1,"566":1}}],["qubelabs",{"2":{"372":12}}],["quorum",{"2":{"266":1,"525":1}}],["quote",{"2":{"562":2}}],["quotes",{"2":{"562":2}}],["quot",{"0":{"337":2},"2":{"41":2,"47":2,"65":2,"68":2,"87":2,"90":2,"91":72,"93":12,"104":4,"110":4,"118":12,"125":44,"130":8,"136":8,"142":64,"143":24,"144":80,"147":356,"148":4,"150":24,"152":120,"161":16,"162":12,"163":84,"202":8,"204":12,"206":4,"207":4,"214":4,"256":2,"266":156,"267":40,"272":4,"274":8,"275":36,"279":16,"287":2,"291":16,"292":32,"294":66,"295":20,"296":8,"297":16,"303":20,"308":2,"312":4,"314":16,"331":8,"332":36,"333":12,"336":2,"343":8,"361":58,"364":4,"366":6,"367":6,"368":10,"371":8,"372":36,"377":8,"378":12,"380":4,"383":8,"398":4,"399":68,"403":4,"408":36,"409":20,"412":4,"429":188,"431":4,"434":64,"447":4,"451":4,"452":4,"475":4,"476":44,"477":4,"537":4,"538":60,"539":4,"544":44,"556":4,"557":16,"558":20,"559":28,"562":24,"563":40,"586":2,"591":4,"596":40,"597":64,"599":6,"602":2,"614":28,"620":36,"625":8,"649":2,"672":2,"693":2,"704":4,"705":24,"708":40,"709":4,"710":8,"743":36,"745":128,"746":16,"748":32,"749":32,"750":52,"751":20,"752":364,"753":4,"758":4,"760":76,"762":4,"765":2,"769":36,"770":12,"771":44,"772":24,"773":32,"777":32,"778":24,"779":12,"782":96,"783":2,"784":4}}],["queried",{"2":{"136":1,"143":1,"146":1,"153":1,"154":1,"160":2,"172":1,"210":2,"749":1}}],["queries",{"0":{"135":1,"137":1},"1":{"136":1,"137":1,"138":2,"139":2,"140":1,"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"154":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"164":1},"2":{"121":1,"136":1,"140":1,"142":1,"147":1,"152":2,"153":1,"163":1,"182":1,"244":2,"322":1,"380":2,"381":3,"422":2,"508":1,"638":1,"641":1,"650":3,"735":2}}],["queryable",{"2":{"160":2}}],["querysharerange",{"2":{"150":2}}],["query",{"0":{"142":1,"295":1,"296":1,"297":1,"366":1},"2":{"120":1,"121":1,"137":1,"139":1,"141":1,"144":2,"146":1,"151":2,"155":1,"156":4,"157":1,"159":4,"160":1,"161":2,"163":2,"172":1,"175":2,"183":1,"209":1,"260":6,"264":2,"266":1,"295":2,"296":2,"297":4,"309":2,"314":1,"366":1,"367":1,"380":1,"413":2,"422":1,"433":2,"465":1,"597":2,"641":1,"671":1,"748":1,"749":1,"756":1}}],["querying",{"0":{"121":1,"161":1,"209":1,"264":1,"717":1},"2":{"68":1,"126":2,"141":1,"149":1,"151":1,"160":1,"182":1,"208":1,"209":1,"210":2,"229":1,"252":1,"260":2,"295":1,"371":1,"493":1,"505":1,"506":1,"717":1}}],["question",{"2":{"42":3,"432":1,"614":1,"627":1}}],["questions",{"0":{"42":1},"2":{"16":1,"41":2}}],["quadratic",{"2":{"642":1}}],["quad",{"2":{"357":1,"533":1,"534":1}}],["quantum",{"2":{"221":1}}],["quarterly",{"2":{"36":1}}],["quarter",{"2":{"28":1}}],["quality",{"2":{"23":1,"40":1,"41":1,"58":1}}],["+stake",{"2":{"659":1}}],["+sgf6mfzmmtdkz5mllh+y7mpv9moo2x5rljle3gbfqo=",{"2":{"142":2}}],["+0x110",{"2":{"383":2,"625":2}}],["+0x1c8",{"2":{"383":2,"625":2}}],["+0x124",{"2":{"383":2,"625":2}}],["+0x2c4",{"2":{"383":2,"625":2}}],["+0x2d8",{"2":{"383":2,"625":2}}],["+0x26c",{"2":{"383":2,"625":2}}],["+0xd30",{"2":{"383":2,"625":2}}],["+0x44",{"2":{"383":2,"625":2}}],["+0x64",{"2":{"383":2,"625":2}}],["+2",{"0":{"383":1,"625":1},"2":{"383":2,"625":2}}],["+mhkrh9borgjn3oqt",{"2":{"147":2}}],["+1",{"2":{"128":2,"130":4}}],["+",{"2":{"26":2,"104":1,"128":2,"130":2,"174":1,"175":2,"329":1,"426":1,"483":1,"724":1,"782":10}}],["8545",{"2":{"536":1,"537":1}}],["8545cast",{"2":{"536":1,"537":1}}],["856",{"2":{"383":2,"625":2}}],["87",{"2":{"336":2}}],["80000",{"2":{"755":3}}],["80000celestia",{"2":{"755":1}}],["8000",{"2":{"275":1,"755":4}}],["8dxemrbwrpwj6hi+3uesz+0p5vrf3v8ssaqeabelorfgaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"152":2}}],["8woyobnjs3mt1dkfrqid8vc75oja2jnf3wn",{"2":{"147":2}}],["8449",{"2":{"93":3}}],["8",{"0":{"91":1},"2":{"22":2,"96":2,"117":1,"118":2,"152":2,"163":2,"287":4,"534":1,"586":2,"611":1,"675":1,"685":1,"705":2}}],["k×k",{"2":{"641":3,"643":1,"649":1}}],["kr",{"2":{"597":6}}],["kjnodes",{"2":{"487":1,"488":1,"489":1,"497":1,"683":1}}],["kbps",{"2":{"460":2,"533":1,"732":2}}],["kv",{"2":{"364":2,"366":3,"380":5}}],["k",{"2":{"147":2,"163":8,"555":1,"643":3}}],["kqkhkpjxmiby",{"2":{"147":2}}],["known",{"2":{"151":1,"221":1,"227":1}}],["knowing",{"2":{"42":1}}],["know",{"2":{"38":1,"39":1,"41":2,"109":1,"219":1,"367":1,"572":1,"578":1,"670":1}}],["knowledge",{"2":{"37":1,"40":1,"58":1,"118":2,"124":1,"221":1,"402":1}}],["knowledgeable",{"2":{"36":1,"37":1}}],["kept",{"2":{"628":1}}],["keplrbutton",{"2":{"782":2}}],["keplr",{"0":{"653":1,"654":1,"782":1},"1":{"654":1,"655":1,"656":1,"657":1},"2":{"278":1,"651":1,"654":2,"655":1,"656":1,"682":1,"683":1,"781":1,"782":18}}],["keeping",{"2":{"642":1}}],["keeps",{"2":{"110":1,"139":1}}],["keep",{"2":{"35":1,"36":1,"60":1,"127":1,"212":1,"276":1,"343":2,"361":1,"368":3,"451":2,"544":1,"620":1,"698":2}}],["keypair",{"2":{"557":2}}],["keymake",{"2":{"341":1}}],["keyregistry",{"2":{"322":1,"569":1}}],["keyring",{"2":{"245":2,"246":7,"261":4,"263":1,"279":6,"299":3,"303":4,"308":2,"329":3,"412":2,"422":2,"423":7,"446":2,"447":2,"449":2,"466":10,"468":7,"477":2,"516":2,"521":2,"557":6,"569":2,"597":10,"614":2,"620":2,"698":6,"699":7,"700":6,"704":2,"705":4,"722":1,"736":10}}],["keyfile",{"2":{"263":2}}],["keyforge",{"2":{"210":1}}],["keybase",{"2":{"263":1}}],["keyname",{"0":{"447":1},"2":{"246":6,"423":6,"466":6,"468":6,"516":2,"705":2,"736":6}}],["key`",{"2":{"202":4,"697":4}}],["key=sk",{"2":{"766":2}}],["key=",{"2":{"93":2,"202":2}}],["keys`",{"2":{"597":4}}],["keystore",{"2":{"519":1,"520":1}}],["keys",{"0":{"263":1,"292":1,"466":1,"698":1,"699":1,"700":1,"705":1,"736":1},"1":{"467":1},"2":{"26":1,"88":1,"202":2,"246":1,"247":1,"260":4,"261":1,"262":16,"263":6,"272":2,"279":10,"291":2,"292":2,"293":1,"299":8,"303":2,"308":4,"322":2,"329":3,"396":1,"405":1,"423":1,"424":1,"430":6,"431":1,"446":2,"448":1,"468":1,"469":1,"520":1,"540":1,"544":2,"557":2,"566":1,"569":2,"614":2,"625":1,"696":2,"698":2,"704":1,"705":8,"715":1,"734":1}}],["key",{"0":{"22":1,"108":1,"246":1,"262":1,"291":1,"392":1,"423":1,"446":1,"468":1,"516":1,"517":1,"518":1,"520":1,"521":1,"522":1,"566":2,"696":1,"701":1,"702":1,"716":1,"766":1},"1":{"109":1,"110":1,"111":1,"112":1,"263":1,"424":1,"469":1,"518":1,"519":1,"521":1,"522":1,"697":1,"698":1,"699":1,"700":1,"701":1,"703":1,"704":1,"705":1},"2":{"32":2,"37":1,"49":1,"86":3,"90":1,"93":2,"108":2,"128":2,"147":8,"156":4,"159":5,"175":3,"202":14,"203":8,"204":8,"210":10,"211":2,"218":2,"245":5,"246":9,"262":8,"263":13,"266":4,"279":2,"289":1,"290":1,"291":8,"292":6,"293":1,"295":2,"296":4,"297":4,"299":1,"322":1,"328":2,"329":3,"341":2,"380":1,"388":2,"392":1,"404":1,"422":5,"423":9,"429":12,"446":2,"447":1,"466":16,"468":9,"515":3,"516":2,"518":3,"520":2,"521":2,"522":2,"528":1,"542":1,"544":11,"557":8,"566":7,"569":1,"597":2,"640":1,"690":1,"695":2,"696":2,"697":5,"698":18,"699":13,"700":12,"701":2,"704":5,"705":11,"716":1,"736":15,"748":1,"752":4,"764":1,"765":8,"766":5,"772":5}}],["kib",{"2":{"586":1}}],["kit",{"2":{"51":2,"52":1,"57":1}}],["kickstarting",{"2":{"33":1}}],["kinds",{"2":{"182":1}}],["kindly",{"2":{"46":1}}],["kind",{"2":{"7":1}}],["kindness",{"2":{"7":1}}],["6363c68770c200fd794445668f9b18f5b1dd1125180d6e8d5ab004f7dd7a0f48",{"2":{"752":4}}],["62562",{"2":{"746":2}}],["66",{"2":{"680":3}}],["66\\taccessing",{"2":{"557":2}}],["67",{"2":{"679":1,"680":3}}],["65",{"2":{"476":4,"589":1,"590":1,"750":4}}],["64\\tsaved",{"2":{"557":2}}],["64x64",{"2":{"483":1,"586":1}}],["64",{"2":{"312":1,"342":1,"483":1,"584":1,"679":1}}],["64cpu",{"2":{"214":1,"215":1,"217":1}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2",{"2":{"294":1}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2gas",{"2":{"294":1}}],["60",{"2":{"211":1}}],["6962",{"2":{"119":1}}],["6",{"0":{"89":1},"2":{"20":1,"23":1,"26":1,"82":1,"84":1,"239":1,"383":2,"416":1,"525":1,"526":1,"528":1,"533":1,"625":2,"685":1,"782":6,"783":1,"784":1}}],["jwt",{"2":{"770":2,"771":2,"773":2}}],["jsimport",{"2":{"782":3}}],["jsx",{"2":{"782":1}}],["js",{"2":{"557":6,"782":2}}],["jsoncelestia",{"2":{"411":1}}],["jsonrpc",{"2":{"142":2,"147":2,"152":2,"538":4,"748":2,"749":2,"750":2,"751":2,"752":2,"760":4}}],["jsondocker",{"2":{"104":2}}],["json",{"0":{"450":1},"2":{"76":1,"86":2,"88":2,"89":2,"90":1,"91":1,"93":2,"94":1,"104":6,"125":2,"128":2,"142":1,"147":1,"152":1,"260":6,"266":9,"267":5,"272":1,"279":18,"361":3,"408":2,"409":1,"411":1,"448":3,"449":3,"450":6,"476":1,"538":2,"539":1,"598":1,"625":1,"717":1,"724":1,"743":2,"745":4,"746":1,"748":1,"749":1,"750":1,"751":1,"760":2}}],["jq",{"2":{"361":2,"398":10,"473":1,"475":2,"558":4,"602":4,"753":2,"755":3,"758":3}}],["jemalloc",{"2":{"341":2}}],["jemallocmake",{"2":{"341":1}}],["jail",{"2":{"281":1}}],["jailing",{"0":{"281":1},"2":{"281":1}}],["jailed",{"2":{"23":2,"24":1,"26":1,"281":2}}],["j",{"2":{"156":4,"159":4,"163":8}}],["j2pyclt4khpiqvh7b6wp9kcdmghlct9edfydr7zaq9o=",{"2":{"147":2}}],["jh0tyrmtrdtha",{"2":{"147":2}}],["journalctl",{"2":{"271":6,"602":2,"604":2,"605":2,"606":2}}],["journey",{"2":{"29":1,"44":1}}],["jotzla2v3g2q7y+18ih5j0uxk",{"2":{"152":2}}],["job",{"2":{"42":1,"275":8,"577":1,"637":1}}],["joining",{"0":{"42":1},"2":{"36":1,"41":1,"47":1,"58":1}}],["join",{"2":{"18":1,"44":1,"73":1}}],["june",{"2":{"27":1}}],["jurisdiction",{"2":{"23":1}}],["just",{"2":{"7":1,"60":1,"87":1,"93":2,"104":1,"117":1,"126":1,"275":1,"283":1,"422":1,"552":1,"556":1,"586":1,"650":1,"677":1,"682":1,"683":1,"696":1,"755":1}}],["4️⃣",{"0":{"657":1,"666":1}}],["4k",{"2":{"641":1,"642":1,"643":1,"649":1,"650":1}}],["42069",{"2":{"476":1,"477":2}}],["42069celestia",{"2":{"476":1,"477":2}}],["4hermes",{"2":{"433":1}}],["4hr",{"2":{"215":1}}],["482",{"2":{"483":1,"586":1}}],["48pm",{"2":{"383":2,"625":2}}],["48",{"2":{"383":2,"625":2}}],["478",{"2":{"483":1,"586":1}}],["47",{"2":{"214":2}}],["41",{"2":{"214":2,"679":1}}],["46",{"2":{"140":2}}],["49",{"2":{"765":4}}],["49s",{"2":{"93":2}}],["4989526079",{"2":{"93":2}}],["443export",{"2":{"301":1,"412":1}}],["443celestia",{"2":{"265":1}}],["443",{"2":{"65":1,"265":3,"301":1,"303":2,"403":1,"412":1,"413":2,"429":2,"487":1,"488":1,"489":7,"490":3,"505":1,"506":2,"508":5}}],["4094",{"2":{"586":1}}],["4094×482bytes",{"2":{"483":1}}],["4095",{"2":{"483":1,"586":1}}],["4096",{"2":{"483":1,"586":1}}],["400000",{"2":{"429":4}}],["401",{"2":{"331":4}}],["40",{"2":{"37":1,"752":2}}],["4",{"0":{"15":1,"87":1},"2":{"21":1,"22":3,"25":1,"26":1,"27":1,"65":2,"82":1,"84":1,"87":1,"91":2,"93":2,"97":1,"147":2,"163":2,"174":1,"216":1,"228":1,"412":2,"429":3,"430":2,"432":1,"433":5,"434":10,"435":3,"505":3,"506":1,"508":3,"509":8,"530":1,"537":2,"671":1,"680":1,"683":1,"705":4,"770":2,"771":2,"773":2}}],["3d96b7d238e7e0456f6af8e7cdf0a67bd6cf9c2089ecb559c659dcaa1f880353",{"2":{"752":2}}],["3dmfzfawzmtzvxhphf5txlcj+ct3evmmfopixfh+id4=",{"2":{"152":2}}],["3️⃣",{"0":{"656":1,"661":1,"665":1}}],["31\\tinitializing",{"2":{"557":2}}],["3152",{"2":{"434":2}}],["3108",{"2":{"429":2,"435":2}}],["33373",{"2":{"487":1,"490":1}}],["33554432",{"2":{"429":4}}],["33",{"2":{"314":2,"680":6}}],["3+fuhlzufkjnzd8yg",{"2":{"152":2}}],["3wl9cwxs8rqbddgupu9p8jcfj+jc77zsswdcf6pm=",{"2":{"147":2}}],["34",{"2":{"140":2,"383":14,"428":1,"625":14}}],["32cpu",{"2":{"211":1}}],["32",{"2":{"140":2,"144":6,"156":3,"159":4,"160":6,"163":14,"202":2,"204":4}}],["391",{"2":{"383":2,"625":2}}],["39",{"2":{"130":2,"144":2,"161":2,"163":2,"202":10,"260":2,"275":2,"291":4,"292":8,"294":8,"295":4,"296":8,"303":2,"361":48,"377":4,"391":2,"408":4,"435":24,"475":4,"477":4,"518":4,"519":4,"538":4,"557":4,"558":8,"562":4,"596":2,"597":8,"614":4,"620":4,"705":4,"708":2,"738":8,"743":8,"746":4,"752":2,"753":4,"758":4,"760":4,"771":2,"773":4,"777":2,"782":62}}],["30t08",{"2":{"752":2}}],["30th",{"2":{"680":1}}],["30s",{"2":{"429":4}}],["3001",{"2":{"429":2}}],["30000000",{"2":{"536":2}}],["30000",{"2":{"429":2}}],["3000",{"2":{"275":1,"429":2}}],["300xzo8tilwpnurey6ojcrkzthq4y6yy6qh0waummrc=",{"2":{"152":2}}],["30",{"2":{"93":2,"156":2,"163":2,"429":4,"671":4,"680":1}}],["362101",{"2":{"760":2}}],["3623",{"2":{"428":1}}],["3663",{"2":{"428":1}}],["36",{"2":{"22":1,"214":2}}],["35",{"2":{"22":1,"214":14,"383":14,"625":14}}],["3",{"0":{"14":1,"86":1,"372":1,"383":1,"625":1},"2":{"22":1,"27":1,"37":1,"65":2,"91":2,"93":4,"96":1,"104":2,"108":1,"139":1,"140":6,"163":2,"266":1,"274":2,"279":4,"312":1,"342":1,"383":2,"429":4,"625":2,"680":1,"705":2,"763":2,"764":1,"770":2,"771":2,"772":4,"773":6,"774":2}}],["2️⃣",{"0":{"655":1,"660":1,"664":1}}],["2k",{"2":{"643":1}}],["2k×2k",{"2":{"641":2,"649":1}}],["2s",{"2":{"578":1}}],["27t13",{"2":{"752":2}}],["27",{"2":{"528":1}}],["2727",{"2":{"434":6}}],["26",{"2":{"528":1,"679":1}}],["26660",{"2":{"274":4,"275":2}}],["26659version",{"2":{"705":1}}],["26659",{"2":{"326":1,"704":4,"705":3}}],["26658curl",{"2":{"538":1,"760":1}}],["26658",{"2":{"91":3,"326":1,"538":1,"707":2,"739":1,"760":1,"773":2,"776":2}}],["26657",{"2":{"65":1,"67":1,"91":2,"143":2,"144":2,"245":2,"313":2,"326":1,"377":4,"429":4,"475":6,"476":4,"492":1,"493":5,"504":1,"505":1,"506":3,"602":2,"760":1}}],["26656",{"2":{"65":1,"378":2,"452":1}}],["2382",{"2":{"434":4}}],["2371495",{"2":{"373":1,"530":1,"620":1}}],["2371495celestia",{"2":{"373":1,"620":1}}],["23",{"2":{"332":2}}],["25630",{"2":{"750":4}}],["256gb",{"2":{"211":1}}],["252614",{"2":{"743":3,"745":9,"758":2}}],["252607",{"2":{"743":2}}],["25231",{"2":{"333":5}}],["2585031",{"2":{"373":1,"530":1,"620":1}}],["2585031celestia",{"2":{"373":1,"620":1}}],["25",{"2":{"281":1,"383":2,"528":1,"625":2,"680":1,"784":1}}],["22t14",{"2":{"765":4}}],["2283",{"2":{"536":2}}],["22",{"2":{"163":2,"704":2,"705":2,"742":4}}],["28",{"2":{"156":5,"157":3,"163":8,"528":1,"530":1}}],["28217653",{"2":{"93":2}}],["28217647",{"2":{"93":2}}],["2zdir",{"2":{"147":2}}],["299137127z",{"2":{"752":2}}],["2990556",{"2":{"562":2,"563":2}}],["2990507",{"2":{"559":6}}],["2983850",{"2":{"558":1}}],["29",{"2":{"140":2,"156":7,"157":1,"163":2,"383":14,"563":2,"625":14}}],["2f",{"2":{"77":1}}],["2e",{"2":{"77":1}}],["2d",{"2":{"77":1}}],["2c",{"2":{"77":1,"80":1}}],["2b",{"2":{"77":1,"80":1}}],["2ae1ddf74ef7",{"2":{"140":2}}],["2a",{"2":{"77":1,"80":1}}],["24",{"2":{"24":1,"383":4,"528":1,"537":2,"625":4}}],["216\\tnew",{"2":{"557":2,"765":2}}],["211\\tno",{"2":{"557":2,"765":2}}],["21572",{"2":{"537":2}}],["21568",{"2":{"536":2}}],["214",{"2":{"383":2,"625":2}}],["2121",{"2":{"65":4,"313":2,"314":4,"326":2,"476":12,"605":2,"704":2,"705":2,"750":8}}],["21",{"2":{"22":1,"281":1,"528":1,"704":2,"705":2}}],["2019",{"2":{"478":1}}],["200",{"2":{"476":4,"750":4}}],["20000",{"2":{"429":2}}],["20000utia",{"2":{"412":2}}],["2000",{"2":{"407":1}}],["2000celestia",{"2":{"407":1}}],["2001",{"2":{"383":2,"625":2}}],["2048",{"2":{"215":4}}],["20ignition",{"2":{"214":16}}],["2023",{"2":{"752":4}}],["20210819022825",{"2":{"140":2}}],["2025",{"2":{"27":1}}],["2024",{"2":{"20":1,"27":2,"214":14,"383":1,"525":1,"530":3,"625":1,"680":2,"765":4}}],["20",{"2":{"22":1,"27":1,"37":1,"142":1,"143":2,"240":1,"358":1,"417":1,"462":1,"612":1,"679":1,"718":1}}],["2",{"0":{"13":1,"77":1,"80":1,"85":1,"145":1,"371":1,"395":1,"432":1,"519":1},"2":{"16":2,"22":2,"23":1,"26":1,"27":1,"35":1,"37":1,"42":1,"65":2,"79":1,"80":1,"82":1,"93":2,"96":4,"118":2,"139":1,"142":2,"145":1,"147":2,"152":2,"163":3,"175":1,"187":1,"206":1,"239":1,"272":2,"279":4,"281":1,"296":2,"357":1,"373":1,"383":2,"416":1,"506":1,"507":1,"508":1,"509":6,"533":2,"534":2,"536":2,"538":4,"586":1,"611":1,"615":1,"620":3,"625":2,"641":1,"643":3,"644":3,"646":1,"649":1,"678":1,"680":2,"690":1,"724":1,"748":2,"749":2,"750":2,"751":2,"752":4,"760":4,"770":2,"771":2,"773":2}}],["1️⃣",{"0":{"654":1,"659":1,"663":1}}],["1s",{"2":{"577":1,"578":1}}],["171",{"2":{"750":4}}],["172118057",{"2":{"748":2}}],["17",{"2":{"530":1,"679":1}}],["1751707",{"2":{"373":1,"530":1,"620":1}}],["1751707celestia",{"2":{"373":1,"620":1}}],["1×478bytes",{"2":{"483":1}}],["1utia",{"2":{"279":2,"597":2}}],["1usgft4=",{"2":{"147":2}}],["1hr",{"2":{"211":2}}],["19l",{"2":{"408":2}}],["19000000utia",{"2":{"265":2}}],["196\\tdetected",{"2":{"557":2}}],["196",{"2":{"214":32}}],["19",{"2":{"117":1,"118":2,"214":16,"530":1,"679":1,"752":2}}],["16002",{"2":{"508":1}}],["1606",{"2":{"383":2,"625":2}}],["16279",{"2":{"476":4}}],["1639397",{"2":{"408":2}}],["1637",{"2":{"383":2,"625":2}}],["1699638350",{"2":{"536":2}}],["169",{"2":{"383":2,"625":2}}],["1687908352",{"2":{"295":2}}],["1686748051",{"2":{"294":8,"295":2,"301":2}}],["16xlarge",{"2":{"217":1}}],["16",{"2":{"93":2,"163":2,"239":1,"357":1,"372":12,"416":1,"533":2,"534":2,"611":1}}],["147105",{"2":{"753":2}}],["1400000",{"2":{"337":1}}],["14",{"2":{"93":2,"140":2,"314":2,"328":1,"383":2,"530":3,"625":2,"738":1}}],["180000",{"2":{"429":4}}],["18",{"2":{"86":1,"140":2,"530":1}}],["1318129",{"2":{"331":2,"332":2,"333":2}}],["1317",{"2":{"65":1,"507":1}}],["1350632",{"2":{"147":2}}],["13",{"2":{"82":1,"93":2,"96":2,"342":1,"482":1,"671":2}}],["1g",{"2":{"79":1}}],["1f",{"2":{"79":1}}],["1e",{"2":{"79":1}}],["1d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af595",{"2":{"475":1,"476":1}}],["1d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af595export",{"2":{"475":1,"476":1}}],["1d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af5951d53b32acb02563e425ba1f8b5178b06a748e0f7b9748a8b1d07c34b454af595",{"2":{"475":1}}],["1d",{"2":{"79":1}}],["1container",{"2":{"704":1,"705":1}}],["1c",{"2":{"76":1,"79":1}}],["1b",{"2":{"76":1,"79":1}}],["1a",{"2":{"76":1,"79":1}}],["118",{"2":{"782":2,"783":1,"784":1}}],["11celestia",{"2":{"765":1}}],["11155111",{"2":{"544":2}}],["1117733",{"2":{"544":2}}],["1141",{"2":{"536":2}}],["115",{"2":{"314":2}}],["11036",{"2":{"275":1}}],["11",{"2":{"65":11,"68":2,"71":1,"72":1,"214":2,"245":2,"383":4,"465":2,"466":2,"516":2,"530":1,"625":4,"735":2,"752":4,"765":3,"783":2}}],["1559",{"2":{"588":1}}],["151",{"2":{"314":2}}],["15s",{"2":{"275":2}}],["15",{"2":{"27":2,"93":2,"142":1,"143":2,"152":1,"153":2,"160":1,"214":16,"275":2,"679":1,"765":4}}],["15002",{"2":{"489":1}}],["1500",{"2":{"26":1}}],["1089",{"2":{"608":1}}],["1080694",{"2":{"147":2}}],["1040676758",{"2":{"537":2}}],["10790",{"2":{"508":2}}],["106",{"2":{"476":4,"750":4}}],["10s",{"2":{"429":4}}],["103",{"2":{"266":2}}],["105",{"2":{"266":3}}],["1024cd",{"2":{"215":1}}],["1024",{"2":{"215":14}}],["1095604",{"2":{"147":2}}],["10+",{"2":{"34":1}}],["10",{"0":{"93":1},"2":{"23":3,"70":1,"91":4,"142":3,"143":2,"152":1,"153":1,"163":2,"429":4,"476":6,"510":1,"525":1,"528":1,"530":1,"544":1,"589":1,"675":1,"685":1,"743":1,"750":4,"783":1}}],["1000",{"2":{"429":2}}],["10001",{"2":{"391":4}}],["1000utia",{"2":{"279":4}}],["100000",{"2":{"294":4,"295":2,"297":2,"301":2,"429":4,"755":4}}],["100000utia",{"2":{"279":2,"294":12,"301":4}}],["10000000utia",{"2":{"447":2,"477":2}}],["100000000000utia",{"2":{"267":2}}],["1000000000",{"2":{"266":2}}],["1000000000utia",{"2":{"266":2,"267":2}}],["1000000utia",{"2":{"412":2,"614":2}}],["1000000",{"2":{"271":2,"749":2}}],["100",{"2":{"20":1,"91":2,"162":2,"429":2,"460":1,"533":1,"674":2}}],["125",{"2":{"476":6}}],["127",{"2":{"377":2,"429":4,"476":2,"538":2,"760":3}}],["1234",{"2":{"202":3}}],["1234567890",{"2":{"597":2}}],["123456",{"2":{"338":1,"558":1}}],["12345=",{"2":{"202":6}}],["12345",{"2":{"202":9}}],["128gb",{"2":{"584":1}}],["128",{"2":{"147":2}}],["120000",{"2":{"147":2}}],["12d3koowffhcaaqy56oeqy3plzudlsv4ryafvwkatzrepupdoslp",{"2":{"750":2}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22",{"2":{"605":1}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22node",{"2":{"605":1}}],["12d3koowavsz36cdczaexnnndpspcvyanbebe5epg7ajttrgfux7",{"2":{"476":4}}],["12d3koowkeertzvmpudxyszo2edqps6ms67n6lt5mpdulskpsxbq",{"2":{"314":2}}],["12d3koowlt1yssrd7xwsbjh7tu1hqanf5m64dhv6aum6cyejxmpk",{"2":{"65":1}}],["12d3koowewuqrjulanpukdfgvohw3roeuu53ec9t9v5cww3mkvdq",{"2":{"65":1}}],["12d3koowcmgm5ezwvfcn9zlavigfluwafxp5pcm78nfkb9jpbtua",{"2":{"65":1}}],["12d3koowgqwzdeqm54dce6lxzffr97bnhvm6rn7km7mfwdomfm4s",{"2":{"65":1}}],["12",{"2":{"22":2,"679":1,"720":1}}],["1",{"0":{"12":1,"76":1,"79":1,"84":1,"141":1,"370":1,"518":1},"1":{"142":1,"143":1},"2":{"16":2,"21":1,"22":7,"23":1,"24":1,"25":1,"27":4,"35":1,"42":1,"65":2,"68":2,"82":1,"84":1,"85":1,"93":4,"96":6,"104":4,"128":4,"130":2,"139":1,"140":4,"142":2,"143":6,"144":2,"145":1,"147":2,"152":5,"153":2,"156":6,"157":2,"160":2,"163":14,"206":1,"216":1,"228":2,"239":2,"245":2,"266":1,"271":2,"272":2,"281":1,"333":5,"357":2,"369":1,"373":1,"377":2,"383":2,"416":2,"429":14,"465":2,"466":2,"476":6,"483":1,"506":1,"507":1,"508":1,"509":4,"533":2,"534":2,"538":6,"539":1,"559":2,"577":2,"578":1,"586":4,"592":1,"597":2,"611":2,"620":3,"625":2,"634":1,"643":1,"675":1,"679":1,"680":9,"685":3,"693":2,"704":1,"705":1,"735":2,"748":2,"749":2,"750":6,"751":2,"752":13,"755":1,"760":7,"765":2,"770":2,"771":2,"773":2,"777":2,"782":2,"784":1}}],["ua",{"2":{"505":2,"506":1,"507":1,"508":1,"512":1}}],["uatom",{"2":{"429":2}}],["ueibxdywh1mcbslm2aec3sdvauhq2zq0rugbjgtvxmqm7la",{"2":{"476":10}}],["udp",{"2":{"313":1,"326":1,"476":10,"750":6}}],["u",{"2":{"271":6,"602":2,"604":2,"605":2,"606":2}}],["uri",{"2":{"244":8,"245":2,"246":6,"265":4,"316":4,"317":2,"318":2,"319":2,"320":8,"324":2,"422":2,"423":6,"468":6,"605":2,"606":2,"617":2,"735":6,"736":6}}],["urlcelestia",{"2":{"407":1}}],["url=rpc",{"2":{"405":2}}],["url=this",{"2":{"390":2}}],["url=https",{"2":{"301":2,"412":2}}],["url=",{"2":{"93":4,"209":2}}],["url",{"0":{"90":1},"2":{"41":2,"64":1,"67":1,"68":3,"90":5,"91":4,"93":1,"203":4,"204":12,"210":5,"211":2,"218":2,"254":1,"275":2,"301":5,"303":1,"390":9,"393":6,"407":1,"408":2,"412":3,"429":4,"477":4,"485":1,"492":1,"493":3,"503":1,"504":1,"505":1,"536":2,"537":2,"540":1,"544":2,"596":4,"707":2,"708":4,"709":4,"710":4,"711":4,"738":1,"739":1,"776":2,"777":4,"778":4,"779":4,"783":3,"784":4}}],["urls",{"0":{"252":1},"1":{"253":1,"254":1},"2":{"41":2,"90":1,"202":2,"211":1,"252":2}}],["ubuntu",{"2":{"240":1,"358":1,"388":1,"398":1,"399":2,"417":1,"462":1,"612":1,"718":1}}],["ugp0sv9ynei5poiyr7rdodswwlfbh2o3xirsmmnmbks=",{"2":{"152":2}}],["uhlbgdgo=",{"2":{"147":2}}],["uhhb3u6dpayj1pjnefrwq5he=",{"2":{"142":2}}],["utc",{"2":{"530":3}}],["ut8sjtguh+akimnqtkuuu",{"2":{"147":2}}],["utility",{"0":{"696":1,"771":1},"1":{"697":1,"698":1,"699":1,"700":1,"701":1},"2":{"341":1,"466":1,"566":1,"695":1,"696":3,"698":1,"770":1,"771":2,"772":1}}],["utilizing",{"0":{"41":1}}],["utilize",{"2":{"37":1,"39":2,"40":1,"719":1}}],["utia=tia×10−6",{"2":{"685":1}}],["utiacelestia",{"2":{"413":1}}],["utia",{"0":{"693":1,"755":1},"2":{"91":1,"266":2,"294":4,"295":2,"297":4,"407":1,"408":2,"409":2,"413":1,"429":2,"693":3,"694":1,"746":1,"748":2,"749":2,"755":6,"782":6,"783":1,"784":1}}],["uint32",{"2":{"591":4,"597":4}}],["uint8",{"2":{"157":2,"206":2}}],["uint64",{"2":{"125":8,"126":4,"128":4,"130":4,"144":10,"160":4,"163":14,"219":3,"711":2,"771":2}}],["uint256",{"2":{"118":2,"154":2,"156":4,"159":4,"160":4,"175":3,"219":1}}],["ui",{"2":{"76":1,"79":1,"80":2,"86":1}}],["ultimate",{"2":{"43":1,"477":2,"562":2,"563":2}}],["updocker",{"2":{"705":1}}],["updating",{"2":{"171":1,"210":3,"216":1,"287":2}}],["updateheaders",{"2":{"128":2}}],["update",{"2":{"86":1,"140":1,"171":1,"202":2,"210":5,"216":1,"227":3,"228":1,"234":1,"266":2,"334":4,"398":4,"450":1,"578":1,"592":1,"625":1,"628":1,"647":1,"671":1,"773":1}}],["updated",{"2":{"60":1,"93":2,"128":1,"202":1,"216":2,"228":1,"550":1,"771":1}}],["updatesudo",{"2":{"398":1}}],["updates",{"2":{"60":1,"210":1,"234":1,"479":1,"547":1,"550":1}}],["upper",{"2":{"483":1}}],["upload",{"2":{"239":1,"247":1,"357":1,"416":1,"424":1,"430":1,"460":1,"469":1,"599":1,"611":1,"720":1,"732":1}}],["upgrading",{"0":{"345":1},"2":{"210":2}}],["upgraded",{"2":{"373":1,"383":1,"620":1,"625":1}}],["upgradeexecutor",{"2":{"93":2}}],["upgrade",{"0":{"282":1,"524":1,"525":1,"526":1,"527":1,"528":1,"530":1},"1":{"525":1,"526":1,"527":2,"528":3,"529":2,"530":2},"2":{"24":1,"73":2,"93":4,"96":1,"210":2,"282":1,"345":1,"373":10,"383":2,"398":3,"498":2,"513":2,"524":4,"525":3,"526":3,"528":8,"530":3,"554":2,"620":10,"625":3,"715":1}}],["upgrades",{"0":{"60":1,"73":1,"479":1,"498":1,"513":1,"529":1,"554":1},"1":{"530":1},"2":{"23":1,"59":1,"60":1,"73":2,"266":1,"282":1,"478":1,"479":1,"498":2,"513":2,"524":4,"525":2,"526":2,"530":1,"552":2,"554":2}}],["upon",{"2":{"50":1,"128":1,"134":1,"246":1,"423":1,"468":1,"680":1,"745":1,"760":1}}],["upcoming",{"0":{"527":1},"1":{"528":1},"2":{"47":1,"152":1,"153":1,"166":1,"168":1,"221":1,"524":1}}],["ups",{"2":{"33":1}}],["up",{"0":{"93":1,"237":1,"240":1,"285":1,"290":1,"302":1,"358":1,"359":1,"361":1,"414":1,"417":1,"443":1,"458":1,"462":1,"472":1,"475":1,"476":1,"542":1,"600":1,"610":1,"612":1,"733":1,"773":1},"1":{"238":1,"239":1,"240":1,"241":2,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"286":1,"287":1,"288":1,"289":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"359":1,"360":1,"361":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1,"611":1,"612":1,"613":2,"614":2,"615":1,"616":1,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"734":1,"735":1,"736":1},"2":{"20":1,"22":1,"25":1,"30":1,"31":1,"32":1,"41":3,"42":1,"48":1,"54":1,"55":1,"90":2,"92":1,"168":2,"199":1,"237":1,"247":1,"248":2,"273":1,"275":1,"276":1,"289":1,"298":2,"301":1,"302":1,"311":1,"320":1,"338":1,"341":1,"353":1,"356":1,"370":2,"397":1,"414":1,"418":1,"424":1,"431":1,"443":1,"444":1,"455":3,"458":1,"462":2,"469":1,"470":1,"472":1,"531":1,"534":1,"540":2,"557":4,"559":2,"578":1,"601":1,"602":1,"607":1,"610":1,"612":1,"619":2,"620":1,"625":2,"636":1,"637":1,"695":1,"698":1,"704":2,"705":3,"734":1,"742":1,"764":1,"766":2,"768":1,"769":2,"774":1}}],["uptime",{"2":{"20":1,"22":1,"26":2,"258":1,"316":1,"493":1}}],["untested",{"2":{"718":1}}],["until",{"2":{"60":1,"109":1,"130":1,"428":1,"592":1,"597":2,"602":1,"636":1,"675":1,"685":1}}],["unused",{"2":{"588":1,"590":1,"769":1}}],["unexplored",{"2":{"479":1}}],["unexpectedly",{"2":{"60":1}}],["unordered",{"2":{"434":2}}],["unmarshaling",{"2":{"331":2}}],["unjail",{"2":{"270":3,"281":2}}],["unjailing",{"0":{"270":1}}],["unbonded",{"2":{"281":1}}],["unbond",{"2":{"269":3}}],["unbonding",{"2":{"208":1,"281":1}}],["unstake",{"2":{"657":1,"661":1,"666":1}}],["unstable",{"2":{"550":1}}],["unsafe",{"2":{"335":4,"375":2,"444":2}}],["unsignedtx",{"2":{"279":8}}],["unsubscribe",{"2":{"162":2}}],["unsolicited",{"2":{"13":1,"14":1}}],["unknown",{"2":{"160":1}}],["unaffected",{"2":{"581":1}}],["unavailability",{"2":{"400":1}}],["unavailable",{"0":{"174":1},"2":{"130":1,"179":1}}],["unauthorized",{"2":{"331":2}}],["unable",{"2":{"281":1,"592":1,"634":1}}],["unacceptable",{"2":{"7":1,"10":1}}],["unpacked",{"2":{"111":1}}],["unpeeled",{"2":{"110":2}}],["unprofessional",{"2":{"12":1}}],["unlocked",{"2":{"680":9}}],["unlock",{"2":{"680":4,"782":2}}],["unlocks",{"0":{"680":1},"2":{"680":5}}],["unlocking",{"2":{"49":1}}],["unlimited",{"2":{"274":2}}],["unlike",{"2":{"127":1,"169":1,"219":1,"528":1,"722":1}}],["unless",{"2":{"23":1,"199":1,"443":1,"542":1,"760":1}}],["unit",{"2":{"597":2,"602":2,"604":2,"605":2,"606":2}}],["unify",{"2":{"404":1}}],["unified",{"2":{"139":1}}],["unix",{"2":{"328":1}}],["universal",{"2":{"214":1}}],["university",{"2":{"34":1}}],["universities",{"2":{"34":2,"38":1}}],["unique",{"2":{"41":1,"86":2,"287":1,"580":1,"641":2,"643":1}}],["undelegate",{"0":{"269":1},"2":{"269":1}}],["undelegation",{"0":{"24":1}}],["underneath",{"0":{"94":1,"540":1},"1":{"541":1,"542":1,"543":1,"544":1,"545":1},"2":{"109":2,"110":1,"249":1,"455":1,"545":1,"571":1}}],["underlying",{"2":{"86":1,"93":1,"109":1,"112":1}}],["undergoes",{"2":{"60":1}}],["understand",{"2":{"41":1,"42":3,"58":1,"91":1,"121":1,"301":1,"457":1,"669":1}}],["understanding",{"0":{"349":1},"1":{"350":1,"351":1,"352":1,"353":1,"354":1,"355":1},"2":{"36":1,"58":1,"259":1,"389":2,"578":1,"675":1,"703":1}}],["under",{"2":{"23":1,"26":1,"76":2,"80":1,"90":1,"96":1,"120":1,"148":1,"194":1,"208":1,"210":1,"214":2,"215":1,"274":2,"337":1,"371":1,"525":1,"586":2,"588":1,"622":1,"696":1,"698":1,"774":1}}],["unwelcome",{"2":{"12":1}}],["usr",{"2":{"312":1,"342":1,"343":2,"383":4,"399":21,"625":4}}],["usual",{"2":{"175":1}}],["usually",{"2":{"86":1,"245":1,"353":1,"422":1,"465":1}}],["usable",{"0":{"154":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1},"2":{"121":1,"142":1,"147":1,"152":1}}],["usage",{"0":{"118":1,"194":1,"195":1,"196":1},"1":{"195":1,"196":1},"2":{"196":1,"260":2,"263":1,"264":1,"265":2,"276":1,"341":1,"770":2,"771":2,"773":2}}],["using",{"0":{"66":1,"146":1,"149":1,"333":1,"405":1,"408":1,"412":1,"696":1,"760":1},"1":{"67":1,"68":1,"147":1,"148":1,"150":1,"406":1,"407":1,"413":1,"697":1,"698":1,"699":1,"700":1,"701":1},"2":{"9":1,"30":1,"31":1,"42":1,"68":1,"69":1,"81":1,"84":1,"86":1,"90":1,"91":6,"93":1,"110":1,"112":1,"113":1,"117":3,"122":3,"126":1,"127":2,"130":1,"136":1,"137":1,"139":2,"141":1,"143":1,"145":1,"148":1,"149":2,"150":1,"153":1,"155":2,"160":2,"162":1,"163":3,"168":1,"169":1,"170":2,"172":3,"173":2,"175":6,"176":1,"178":1,"179":2,"184":1,"186":1,"188":1,"191":3,"194":1,"197":1,"199":4,"202":7,"204":1,"208":1,"209":1,"214":1,"215":1,"218":2,"221":2,"227":1,"233":1,"244":1,"246":1,"266":1,"267":1,"277":1,"278":1,"283":1,"293":1,"301":1,"306":1,"311":1,"314":1,"329":3,"333":1,"334":1,"339":2,"366":1,"368":1,"370":1,"388":3,"390":1,"392":2,"396":1,"399":1,"400":1,"406":1,"408":1,"422":1,"423":1,"427":1,"429":1,"455":2,"466":1,"467":1,"468":1,"507":2,"508":1,"510":1,"515":1,"526":2,"540":1,"544":1,"556":1,"557":3,"561":1,"566":2,"582":1,"583":1,"584":1,"591":2,"595":1,"597":4,"598":2,"614":1,"617":1,"643":1,"644":2,"646":3,"649":2,"668":1,"672":2,"688":1,"695":1,"697":1,"704":1,"705":3,"706":1,"709":3,"710":3,"711":1,"715":1,"730":1,"736":1,"737":1,"739":1,"740":1,"741":2,"742":2,"744":1,"758":1,"760":2,"763":3,"765":1,"771":8,"772":2,"773":2,"775":1,"778":1,"779":1,"782":2}}],["useful",{"2":{"42":1,"51":1,"60":1,"92":1,"361":1,"507":1,"558":1,"564":1,"565":1,"600":1,"602":1}}],["user=$user",{"2":{"602":2,"604":2,"605":2,"606":2}}],["user",{"0":{"597":1},"2":{"36":1,"41":2,"42":1,"122":2,"124":1,"275":1,"280":1,"329":8,"355":1,"391":1,"400":1,"438":2,"526":1,"577":1,"588":2,"590":3,"592":1,"597":8,"599":1,"602":2,"604":2,"605":2,"606":2,"609":1,"689":1,"692":1,"715":1,"721":1,"722":1,"739":2,"743":1,"782":4}}],["users",{"2":{"18":1,"67":1,"68":1,"86":1,"165":1,"183":1,"221":2,"388":1,"396":1,"400":1,"479":1,"492":1,"493":1,"504":1,"505":1,"506":1,"507":1,"508":1,"543":1,"547":1,"557":6,"581":1,"585":1,"588":3,"590":3,"591":1,"592":2,"593":1,"627":2,"634":2,"637":2,"638":1,"648":1,"649":1,"672":1,"681":1,"724":1,"726":1,"742":1}}],["uses",{"0":{"163":1},"2":{"34":1,"96":1,"107":1,"112":1,"126":4,"130":1,"163":4,"178":1,"182":1,"188":1,"197":1,"224":1,"225":1,"227":1,"233":1,"250":1,"274":1,"281":1,"331":1,"332":1,"371":1,"427":1,"438":1,"455":1,"588":1,"590":1,"591":1,"592":1,"596":2,"632":1,"641":1,"669":1,"675":1,"689":1,"696":1,"708":2,"725":1,"772":2}}],["use",{"0":{"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"187":1,"188":1,"189":1,"190":1,"192":1,"193":1,"199":1},"1":{"180":1,"181":1,"182":1,"184":1,"185":1,"188":1,"189":1,"191":1,"192":1,"193":1},"2":{"7":1,"12":1,"18":1,"39":1,"41":1,"42":2,"72":1,"84":1,"90":2,"91":3,"104":2,"109":1,"124":1,"125":2,"127":2,"128":1,"133":1,"137":1,"139":1,"144":2,"152":1,"153":1,"154":1,"156":2,"161":4,"162":3,"163":4,"165":1,"174":2,"175":2,"186":1,"190":1,"197":1,"199":1,"202":4,"204":3,"210":1,"211":1,"213":1,"215":1,"221":1,"227":3,"233":1,"244":1,"254":1,"266":2,"267":1,"275":2,"282":1,"284":1,"287":1,"288":1,"294":1,"299":1,"301":3,"302":1,"303":1,"311":1,"320":1,"326":1,"328":1,"339":1,"341":1,"348":1,"350":1,"371":3,"386":1,"388":1,"399":1,"402":1,"405":1,"408":1,"412":1,"422":1,"426":1,"428":1,"430":1,"432":1,"433":2,"434":1,"435":1,"445":2,"450":1,"496":1,"512":1,"516":1,"519":1,"520":1,"528":2,"540":2,"555":1,"556":2,"557":2,"558":1,"559":2,"562":2,"563":2,"565":1,"581":1,"584":1,"587":1,"588":1,"589":1,"597":6,"599":2,"607":1,"646":1,"647":1,"672":1,"687":1,"697":1,"698":1,"700":1,"707":4,"708":2,"715":2,"717":1,"726":1,"728":1,"731":2,"735":2,"738":4,"739":1,"740":1,"741":2,"743":4,"745":5,"746":2,"755":1,"756":1,"757":2,"760":1,"769":3,"771":3,"776":4,"777":5,"781":1,"782":1}}],["used",{"2":{"3":1,"59":1,"64":1,"86":2,"90":1,"91":4,"93":1,"109":3,"110":1,"125":2,"127":1,"128":2,"130":1,"136":2,"147":2,"149":1,"151":1,"156":1,"157":1,"166":2,"174":1,"187":2,"199":2,"202":5,"213":2,"214":3,"215":3,"216":1,"221":1,"227":1,"234":1,"243":1,"245":1,"266":1,"273":1,"281":1,"294":2,"308":1,"311":1,"313":1,"322":4,"326":1,"349":1,"378":1,"381":1,"391":1,"397":1,"404":1,"406":1,"422":2,"427":1,"430":1,"485":1,"503":1,"508":1,"509":1,"525":2,"540":1,"557":1,"559":1,"563":1,"588":1,"589":2,"590":1,"591":2,"614":2,"620":2,"641":1,"646":1,"649":1,"696":1,"715":1,"718":1,"720":1,"723":1,"739":2,"746":1,"758":1,"771":1}}],["us",{"2":{"7":1,"23":1,"26":1,"42":6,"111":3,"483":2,"581":1,"758":1,"770":1,"772":1,"782":1}}],["vghpcybpcybhbiblegftcgxlig9mihnvbwugymxvyibkyxrh",{"2":{"760":2}}],["vcpu",{"2":{"584":1}}],["vms",{"2":{"582":1}}],["vm",{"2":{"581":1,"582":4}}],["v3",{"2":{"528":4}}],["v3+",{"2":{"525":1,"526":1}}],["vlog",{"2":{"337":4,"569":1}}],["vs",{"0":{"223":1,"647":1},"1":{"224":1,"225":1,"226":1},"2":{"494":1}}],["vk",{"2":{"214":2}}],["vkrarg7fgtz",{"2":{"142":2}}],["v",{"2":{"104":2,"343":2,"392":11,"393":10,"537":2,"556":2,"596":2,"708":2,"710":2,"714":1,"770":2,"771":8,"773":8}}],["v1beta1",{"2":{"266":4,"294":2,"295":2,"296":2,"412":2}}],["v1",{"2":{"96":2,"140":8,"147":4,"152":1,"153":1,"163":2,"312":1,"373":1,"383":14,"412":2,"428":1,"588":2,"592":1,"620":1,"625":14,"750":6}}],["v2",{"2":{"96":1,"104":2,"150":2,"152":1,"373":10,"383":1,"525":1,"526":1,"530":1,"620":10,"625":2}}],["vulnerability",{"2":{"86":1}}],["v0",{"2":{"82":1,"96":3,"140":4,"328":1,"342":1,"383":14,"428":1,"625":14,"671":2,"738":1,"777":3,"778":2}}],["volumes",{"2":{"705":2}}],["volume",{"2":{"391":2,"392":6,"393":2,"396":1}}],["volunteer",{"2":{"30":1}}],["volunteers",{"2":{"30":1,"32":1,"46":1}}],["void",{"2":{"291":2}}],["voice",{"2":{"34":1}}],["vote",{"2":{"266":5,"267":1,"651":1,"677":2,"678":1}}],["voting",{"2":{"266":1,"526":1,"528":1,"531":1,"690":1,"752":4}}],["vouch",{"2":{"224":1}}],["vec",{"2":{"777":2}}],["venv",{"2":{"543":7}}],["venue",{"0":{"34":1},"2":{"30":2,"31":1,"34":4,"38":2,"39":2}}],["vest",{"2":{"294":1}}],["vestingcelestia",{"2":{"299":1}}],["vesting",{"0":{"283":1,"290":1,"294":1,"295":1,"301":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":2,"292":2,"293":2,"294":2,"295":2,"296":2,"297":2,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1},"2":{"283":4,"289":1,"290":1,"291":5,"292":2,"293":1,"294":19,"295":8,"297":3,"298":2,"299":4,"301":10,"304":1,"305":2,"589":1,"715":1}}],["veto",{"2":{"266":2}}],["ver=",{"2":{"399":3}}],["very",{"2":{"124":1,"217":2,"371":1,"720":1}}],["verifiable",{"2":{"227":1}}],["verified",{"2":{"137":1,"163":2,"168":1,"180":1,"183":1,"186":1,"190":1,"194":1,"202":1,"206":1,"528":1,"627":1,"628":1,"629":1,"637":1}}],["verifiercd",{"2":{"203":1}}],["verifiers",{"0":{"203":1,"215":1},"2":{"202":2,"203":5,"204":4,"214":1}}],["verifier",{"0":{"204":1,"214":1},"1":{"205":1,"206":1,"207":1},"2":{"121":1,"122":1,"132":1,"163":2,"191":1,"194":1,"202":2,"203":7,"204":10,"205":4,"206":1,"210":6,"211":5,"213":1,"214":22,"215":13,"234":1,"584":4}}],["verifies",{"2":{"120":2,"122":3,"227":2,"234":1}}],["verification",{"0":{"225":1},"2":{"91":1,"109":1,"122":1,"139":1,"160":1,"187":2,"191":1,"194":1,"199":3,"202":1,"214":1,"371":1,"589":1}}],["verifydatarootinclusion",{"2":{"144":4}}],["verifymultirowrootstodataroottupleroot",{"2":{"122":1}}],["verifyrowroottodataroottupleroot",{"2":{"122":2}}],["verifysharestodataroottupleroot",{"2":{"122":2,"163":2}}],["verifying",{"0":{"122":1},"2":{"119":2,"126":2,"127":1,"139":1,"164":1,"168":2,"179":1,"629":1,"635":1,"643":1,"715":1,"716":1}}],["verifyzkp",{"2":{"118":4}}],["verifyattestation",{"2":{"112":1,"118":2,"120":1,"144":2}}],["verify",{"0":{"431":1,"629":1},"2":{"91":2,"117":1,"118":4,"122":4,"127":1,"136":1,"144":6,"154":2,"156":6,"159":4,"160":2,"163":10,"164":1,"172":1,"175":1,"178":1,"179":1,"180":1,"182":1,"183":1,"186":1,"187":2,"191":2,"194":3,"199":2,"202":1,"203":4,"204":2,"210":2,"213":1,"233":1,"291":2,"294":1,"341":1,"343":2,"371":1,"399":1,"409":1,"428":1,"432":1,"581":2,"627":5,"629":2,"630":1,"631":1,"632":1,"637":1,"640":1,"641":1,"643":1,"644":1,"647":1,"648":2}}],["versed",{"2":{"58":1}}],["versioned",{"2":{"483":1,"528":2}}],["versiongo",{"2":{"399":1}}],["versioncelestia",{"2":{"341":1,"556":1}}],["versioncd",{"2":{"288":1}}],["versions",{"0":{"548":1,"551":1,"553":1},"2":{"91":1,"96":1,"140":2,"473":1,"524":1}}],["version",{"0":{"62":1,"288":1,"383":1,"395":1,"481":1,"501":1,"625":1,"756":1},"2":{"16":2,"96":2,"117":1,"147":2,"150":6,"152":2,"156":11,"157":11,"163":6,"215":2,"250":1,"260":6,"284":1,"288":2,"298":1,"301":1,"311":1,"332":2,"341":6,"343":9,"345":1,"371":1,"373":1,"383":3,"399":4,"427":1,"428":1,"434":12,"525":2,"526":1,"528":2,"556":3,"559":2,"563":4,"584":1,"588":2,"620":1,"625":4,"646":1,"671":1,"672":1,"715":1,"743":1,"745":8,"752":2,"756":1,"760":2,"773":1}}],["ve",{"2":{"39":1,"58":1,"297":1,"305":1,"344":1,"556":1,"557":1,"561":1,"563":1,"572":1,"578":1,"763":1,"771":2}}],["vanilla",{"2":{"646":1}}],["vastly",{"2":{"581":1}}],["vault",{"2":{"202":6}}],["var",{"2":{"128":2,"287":4}}],["vary",{"2":{"35":1,"483":1,"589":1,"675":1}}],["variable",{"2":{"93":1,"155":1,"202":2,"211":3,"287":1,"475":1,"476":1,"536":1,"537":1,"559":1,"590":1,"614":1,"669":1,"741":1,"755":1,"766":1,"772":3}}],["variablescd",{"2":{"210":1}}],["variables",{"0":{"293":1},"2":{"91":1,"202":1,"210":3,"211":1,"218":1,"293":1,"299":1,"392":1,"405":1,"528":1,"590":1}}],["variety",{"2":{"35":1,"582":1}}],["varies",{"2":{"22":1}}],["various",{"2":{"30":1,"41":1,"58":1,"322":1,"572":1}}],["valconspub",{"2":{"782":2}}],["valcons",{"2":{"782":2}}],["val",{"2":{"614":2}}],["valoperpub",{"2":{"782":2}}],["valopers",{"2":{"496":1,"512":1}}],["valoper",{"2":{"268":2,"269":4,"782":2}}],["validiums",{"2":{"628":1}}],["validity",{"2":{"186":1,"221":1,"581":3}}],["valid",{"2":{"122":2,"144":2,"168":2,"178":1,"179":1,"183":1,"187":2,"191":2,"194":2,"202":1,"210":1,"431":2,"581":1,"641":1,"647":2,"650":1}}],["validating",{"2":{"94":1,"105":1,"136":1,"524":1}}],["validation",{"0":{"105":1},"2":{"86":2,"130":2}}],["validatehermes",{"2":{"431":1}}],["validates",{"2":{"260":2,"646":1}}],["validated",{"2":{"26":1}}],["validate",{"2":{"26":1,"183":1,"238":1,"260":2,"370":1,"431":1,"550":1,"642":1,"643":1}}],["validator1",{"2":{"445":1}}],["validatorwalletcreator",{"2":{"100":1,"101":1}}],["validatorutils",{"2":{"100":1,"101":1}}],["validators",{"0":{"448":1},"2":{"18":1,"20":1,"21":1,"23":1,"25":1,"26":1,"28":1,"60":1,"86":9,"87":1,"110":1,"124":1,"125":1,"208":1,"227":2,"266":3,"448":3,"449":1,"452":1,"499":1,"524":2,"525":2,"526":1,"528":2,"550":2,"552":1,"580":1,"587":1,"632":1,"669":1,"674":1,"720":1,"752":6}}],["validator",{"0":{"102":1,"268":1,"270":1,"302":1,"474":1,"610":1,"612":1,"614":1,"620":1,"621":1,"655":1,"660":1,"664":1},"1":{"103":1,"104":1,"105":1,"611":1,"612":1,"613":2,"614":2,"615":1,"616":1,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1},"2":{"18":2,"20":2,"22":2,"23":4,"26":7,"27":5,"59":3,"65":4,"68":2,"86":2,"88":1,"93":1,"105":1,"110":1,"128":1,"238":1,"245":5,"260":2,"268":5,"269":6,"270":3,"272":2,"279":6,"281":15,"289":2,"292":2,"293":1,"297":1,"301":1,"302":2,"308":4,"310":1,"313":1,"326":1,"387":1,"422":3,"446":1,"451":4,"452":2,"465":4,"466":2,"472":1,"475":1,"477":2,"486":1,"499":1,"531":1,"534":1,"552":1,"580":1,"601":1,"610":2,"611":1,"614":7,"615":2,"620":16,"625":2,"636":1,"655":1,"660":1,"664":1,"674":3,"681":1,"689":2,"735":2,"752":4,"765":2}}],["valuable",{"2":{"34":1,"37":2,"42":1,"58":1}}],["valuelog",{"2":{"337":2}}],["values",{"0":{"314":1},"2":{"23":1,"87":1,"142":1,"147":1,"152":1,"156":1,"218":1,"314":2,"334":3,"677":1,"698":1,"743":1}}],["value",{"2":{"4":1,"38":1,"91":2,"147":8,"156":6,"157":1,"187":1,"204":1,"210":3,"266":4,"320":1,"337":3,"368":2,"380":2,"381":1,"445":2,"446":1,"537":2,"569":1,"588":1,"589":1,"590":1,"743":2,"746":1,"750":1,"752":4,"778":2}}],["vinci",{"2":{"477":2,"562":3,"563":2}}],["visualize",{"2":{"275":1}}],["visualizer",{"2":{"275":1}}],["visualization",{"0":{"275":1}}],["vision",{"2":{"688":1}}],["visited",{"2":{"782":2}}],["visit",{"2":{"81":1,"85":1,"86":1,"90":1,"92":1,"255":1,"256":1,"257":1,"258":1,"388":1,"766":1}}],["visibility",{"2":{"39":1}}],["visible",{"2":{"6":1}}],["virtual",{"2":{"251":1}}],["virtually",{"2":{"58":1}}],["vim",{"2":{"210":2,"211":2}}],["viewed",{"2":{"321":1}}],["viewing",{"0":{"348":1},"2":{"266":1}}],["view",{"0":{"701":1},"2":{"77":1,"79":1,"92":1,"250":1,"260":1,"267":1,"301":1,"312":1,"343":1,"348":1,"599":2,"721":1,"757":2,"783":1,"784":1}}],["viewpoints",{"2":{"7":1}}],["vibrant",{"2":{"49":1}}],["video",{"0":{"394":1},"1":{"395":1},"2":{"34":1,"40":1,"54":1,"55":1,"540":1}}],["videos",{"2":{"31":1,"40":1}}],["violate",{"2":{"22":1}}],["violating",{"2":{"13":1,"14":1,"23":1,"24":1}}],["violation",{"2":{"11":1,"12":1,"13":1,"14":1,"15":1}}],["via",{"0":{"132":1,"133":1,"597":1},"2":{"9":1,"39":2,"125":1,"127":1,"130":1,"137":1,"139":1,"145":1,"156":1,"157":1,"160":1,"174":1,"175":1,"191":1,"203":1,"208":1,"209":1,"219":1,"266":1,"309":1,"324":1,"383":1,"430":1,"436":1,"437":1,"552":1,"597":2,"625":1,"649":1,"651":1,"697":4,"698":1}}],["vitepress",{"2":{"1":1}}],["huzwottdmd36n1f75a9bshxnlrascnnpqiwqihdvhcu",{"2":{"752":4}}],["hub",{"2":{"251":1,"256":1,"427":1,"429":1,"430":1}}],["h",{"2":{"538":4,"760":4}}],["hzfy",{"2":{"147":2}}],["historic",{"2":{"671":1,"672":2}}],["historical",{"0":{"367":1,"637":1,"638":1},"2":{"367":1,"371":2,"634":2,"637":2,"638":2,"639":1,"670":1,"672":10}}],["history",{"2":{"68":1,"338":1,"356":1,"493":1,"494":1,"531":1,"634":1,"638":1}}],["hidden",{"2":{"126":1,"763":1}}],["hiring",{"2":{"38":1}}],["highly",{"2":{"245":1,"385":1,"422":1}}],["highlighted",{"2":{"137":1}}],["highlight",{"2":{"38":1}}],["highlights",{"2":{"32":1}}],["higher",{"2":{"86":1,"581":1,"586":1,"587":1,"592":1,"669":1,"675":1,"746":1}}],["high",{"2":{"22":1,"40":1,"58":1,"86":1,"110":1,"111":2,"122":1,"124":1,"221":1,"226":1,"227":1,"337":1,"508":1,"544":1,"607":1,"641":1,"782":2}}],["hollow",{"2":{"291":2}}],["holders",{"2":{"267":1,"677":1}}],["holds",{"2":{"88":1}}],["hold",{"2":{"36":1}}],["homebrew",{"2":{"398":4}}],["homecd",{"2":{"291":1}}],["home=",{"2":{"287":2}}],["home",{"0":{"287":1},"2":{"287":4,"291":3,"292":4,"294":12,"295":4,"296":4,"297":8,"313":1,"326":1,"329":8,"375":2,"383":2,"392":8,"393":8,"444":2,"625":3,"698":1,"739":1}}],["hood",{"2":{"96":1,"588":1,"696":1}}],["hosted",{"2":{"218":1,"249":1,"250":1,"320":1}}],["hosts",{"2":{"91":2}}],["host",{"2":{"91":8,"104":2,"303":2,"333":2,"391":3,"429":4,"433":6,"577":1,"578":1}}],["hosting",{"2":{"26":1,"37":1,"40":1,"42":2,"81":1}}],["honesty",{"2":{"634":1}}],["honest",{"2":{"86":1,"631":2,"641":1,"643":1,"650":2}}],["hour",{"2":{"42":1,"216":1,"228":2,"369":1}}],["hours",{"2":{"24":1,"79":1,"80":1,"171":1,"216":1,"228":1,"369":1}}],["hope",{"2":{"42":2}}],["however",{"2":{"38":1,"41":1,"126":1,"130":1,"175":1,"186":1,"197":1,"199":1,"266":1,"320":1,"355":1,"381":1,"558":1,"588":1,"589":1,"632":1,"642":1,"644":1,"646":1,"739":1}}],["how",{"0":{"229":1,"234":1,"271":1,"283":1,"629":1,"651":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"652":1,"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1,"662":1,"663":1,"664":1,"665":1,"666":1},"2":{"3":1,"21":1,"35":1,"36":1,"38":2,"41":1,"42":1,"54":1,"63":2,"74":1,"86":1,"91":1,"94":1,"111":1,"113":1,"121":1,"122":1,"124":1,"126":1,"127":1,"134":2,"137":1,"139":2,"172":1,"182":1,"216":1,"228":1,"235":1,"273":2,"280":1,"282":1,"283":1,"297":1,"298":2,"302":1,"305":2,"306":1,"320":1,"338":1,"356":1,"380":1,"381":1,"427":2,"484":2,"499":3,"515":2,"531":1,"540":1,"543":1,"544":1,"555":1,"563":1,"582":1,"589":2,"590":1,"591":2,"597":2,"630":1,"651":1,"668":1,"669":1,"671":1,"674":2,"675":1,"677":1,"678":1,"687":1,"689":1,"703":1,"704":1,"717":1,"728":1,"737":1,"738":2,"740":1,"763":1,"781":2,"782":2}}],["http2",{"2":{"507":1}}],["http",{"0":{"142":1,"147":1,"152":1},"2":{"90":1,"91":4,"92":1,"93":3,"136":6,"142":1,"143":4,"144":4,"150":2,"155":1,"156":1,"163":2,"253":1,"313":1,"326":2,"331":2,"333":2,"390":1,"477":4,"538":2,"707":2,"726":1,"739":1,"776":2}}],["https",{"0":{"253":1},"2":{"16":3,"64":4,"65":2,"71":1,"72":3,"89":2,"93":2,"156":2,"157":2,"160":2,"202":2,"203":2,"208":2,"211":2,"214":18,"215":2,"218":1,"251":1,"253":1,"256":1,"257":1,"265":4,"280":4,"303":2,"311":2,"312":2,"341":2,"343":4,"361":10,"371":4,"372":12,"390":1,"398":2,"399":8,"403":1,"413":2,"429":8,"430":2,"456":1,"485":4,"496":9,"497":5,"503":4,"507":12,"511":1,"512":9,"544":2,"556":2,"558":4,"584":2,"682":3,"683":3,"697":2,"771":2,"783":3,"784":4}}],["html",{"2":{"16":1,"156":2,"157":2}}],["hamburger",{"2":{"784":1}}],["halting",{"2":{"628":1}}],["halo",{"2":{"238":1}}],["had",{"2":{"163":2,"738":1}}],["handpicking",{"2":{"275":1}}],["hand",{"2":{"226":1}}],["hands",{"0":{"140":1},"1":{"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1}}],["handled",{"2":{"588":1}}],["handlemsg",{"2":{"383":2,"625":2}}],["handlecompleteproposal",{"2":{"383":2,"625":2}}],["handle",{"2":{"322":1,"523":1,"597":4,"648":1}}],["handles",{"2":{"93":1,"219":1,"455":1,"739":1}}],["handling",{"2":{"112":1,"455":1}}],["happen",{"2":{"650":1}}],["happens",{"2":{"109":1}}],["happened",{"2":{"87":1}}],["happy",{"2":{"41":1,"57":1}}],["having",{"2":{"34":2,"35":1,"86":1,"170":1,"171":1,"183":1,"193":1,"211":1,"218":1,"388":1,"630":2}}],["haven",{"2":{"344":1,"782":2}}],["have",{"2":{"4":1,"8":1,"23":3,"26":1,"34":4,"35":1,"36":1,"37":1,"39":1,"40":2,"41":1,"57":1,"80":1,"81":1,"87":1,"91":1,"92":1,"93":2,"110":2,"116":1,"124":1,"126":1,"140":1,"154":4,"169":1,"183":2,"193":1,"202":4,"208":1,"209":1,"210":1,"211":1,"214":2,"215":1,"216":1,"227":1,"235":1,"238":1,"248":1,"259":1,"281":3,"289":1,"290":1,"298":1,"309":2,"312":1,"314":1,"315":1,"326":1,"342":1,"347":1,"384":1,"390":1,"393":1,"399":1,"407":1,"408":1,"409":1,"413":2,"429":2,"430":1,"432":1,"434":1,"435":1,"444":1,"449":1,"450":1,"453":1,"459":1,"467":1,"483":1,"493":1,"499":1,"523":1,"525":1,"528":1,"540":1,"542":2,"544":1,"545":1,"557":1,"561":1,"562":1,"566":1,"582":1,"592":1,"602":1,"619":1,"620":1,"628":1,"629":2,"632":1,"638":1,"644":1,"650":2,"666":1,"672":1,"679":1,"698":1,"706":1,"720":2,"726":1,"731":2,"733":1,"737":1,"739":1,"762":1,"765":1,"766":1,"773":1,"775":1,"777":1}}],["hash=$",{"2":{"558":2}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"536":1}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7export",{"2":{"536":1}}],["hash=0xef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"147":1}}],["hash=580b3dff8a7c716968161d91116a1e171f486298d582874e93714e489c9e6e88",{"2":{"314":2}}],["hash=",{"2":{"314":2}}],["hashing",{"2":{"110":1}}],["hashes",{"2":{"110":2,"118":4,"227":1}}],["hash",{"0":{"146":1,"149":1,"199":1,"209":1,"338":1,"366":1,"558":1},"1":{"147":1,"148":1,"150":1,"339":1},"2":{"93":6,"110":2,"118":10,"125":2,"128":2,"142":2,"144":2,"146":1,"147":5,"148":2,"149":1,"150":4,"152":2,"160":1,"172":1,"199":8,"209":3,"210":5,"314":6,"338":10,"339":1,"341":1,"355":2,"366":1,"371":3,"380":2,"475":4,"536":4,"537":4,"558":13,"559":9,"599":2,"614":3,"620":2,"644":1,"731":1,"752":24,"755":1}}],["hashtags",{"2":{"39":1}}],["has",{"2":{"27":1,"41":1,"44":1,"60":1,"70":1,"86":1,"91":1,"93":3,"96":1,"109":2,"110":1,"112":2,"118":3,"168":1,"169":1,"170":1,"197":1,"199":1,"219":1,"238":1,"275":1,"277":1,"295":1,"328":2,"372":1,"373":1,"383":1,"388":1,"400":1,"422":1,"434":1,"464":1,"482":1,"483":1,"510":1,"525":1,"526":1,"549":1,"562":1,"586":1,"589":2,"602":1,"606":1,"620":1,"625":1,"627":1,"637":1,"642":1,"644":1,"671":1,"672":1,"708":1,"726":1,"738":1,"762":1,"765":2}}],["hard",{"2":{"483":2}}],["hardhat",{"2":{"93":1}}],["hardware",{"0":{"239":1,"357":1,"416":1,"440":1,"460":1,"611":1,"732":1},"2":{"26":1,"54":1,"55":1,"239":1,"357":1,"416":1,"440":1,"460":1,"611":1,"732":1}}],["harassing",{"2":{"10":1}}],["harassment",{"2":{"6":1,"7":1,"15":1}}],["harmfully",{"2":{"281":1}}],["harmful",{"2":{"8":1,"24":1}}],["helloworldblob",{"2":{"596":4,"708":4}}],["hello",{"2":{"596":4,"708":4,"743":1,"777":4}}],["helpcelestia",{"2":{"264":1,"265":1,"301":1,"311":1,"343":1,"348":1,"437":1,"757":2}}],["helpful",{"0":{"260":1},"1":{"261":1,"262":1,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1},"2":{"311":1,"312":1}}],["helper",{"2":{"132":1,"156":1,"159":1,"160":1}}],["helping",{"2":{"41":1,"260":2,"400":1,"439":1}}],["helps",{"2":{"2":1,"37":1,"40":1,"42":4,"86":1}}],["help",{"0":{"348":1,"757":1},"2":{"0":1,"29":2,"30":1,"33":1,"34":1,"35":1,"36":3,"37":2,"38":1,"39":2,"40":2,"41":3,"42":2,"51":2,"122":1,"260":6,"264":1,"265":1,"301":2,"311":2,"321":1,"343":1,"348":1,"352":1,"437":2,"499":1,"556":1,"565":1,"581":1,"689":1,"701":2,"757":4,"770":1,"772":1}}],["hermes",{"0":{"428":1,"435":1},"1":{"429":1,"430":1,"431":1},"2":{"427":2,"428":9,"429":4,"430":4,"431":2,"432":1,"436":1}}],["here",{"2":{"0":1,"21":1,"46":1,"54":1,"55":1,"110":1,"111":1,"125":1,"126":1,"128":1,"130":1,"218":1,"244":1,"245":1,"266":1,"275":2,"301":1,"317":1,"318":1,"319":1,"320":1,"321":1,"371":1,"446":2,"447":1,"449":1,"484":1,"544":1,"574":1,"597":4,"601":1,"620":1,"740":1,"743":2,"745":3,"749":1,"752":2,"755":1,"769":1,"771":2}}],["hence",{"2":{"414":1,"589":1}}],["height=$",{"2":{"558":2}}],["height=1",{"2":{"475":2}}],["height=15",{"2":{"142":1,"152":1,"160":1}}],["height=",{"2":{"209":1}}],["heightsub",{"0":{"336":1},"2":{"336":4}}],["heights",{"2":{"208":1,"217":1,"322":1}}],["height",{"0":{"752":1},"2":{"109":2,"119":1,"125":8,"126":4,"128":2,"130":6,"139":3,"141":2,"142":1,"144":16,"147":2,"150":2,"151":1,"160":17,"161":8,"163":8,"168":1,"172":2,"183":2,"187":1,"208":1,"209":4,"210":2,"212":1,"233":1,"260":4,"294":4,"338":3,"339":2,"367":1,"370":1,"371":3,"373":9,"380":2,"383":1,"408":3,"525":1,"526":1,"528":1,"530":1,"558":11,"559":3,"562":3,"563":3,"596":6,"614":2,"620":11,"625":2,"644":1,"675":1,"708":8,"709":4,"710":11,"711":7,"731":1,"743":5,"745":6,"746":3,"752":10,"753":2,"758":3,"760":1,"771":17,"773":4,"777":10,"778":13,"779":1}}],["hexadecimal",{"2":{"743":1,"771":1}}],["hexbytes",{"2":{"158":2,"163":2}}],["hextoaddress",{"2":{"144":2,"161":2,"162":2,"163":2}}],["hex",{"2":{"91":1,"148":2,"150":4,"155":1,"156":1,"157":1,"202":2,"210":1,"562":1,"594":4,"595":4,"599":1,"743":8,"745":2,"769":2,"771":11,"773":2}}],["health",{"2":{"273":1,"431":4,"493":1}}],["healthy",{"2":{"6":1,"431":1}}],["heavy",{"0":{"194":1,"195":1,"196":1},"1":{"195":1,"196":1},"2":{"196":1}}],["headerclient",{"2":{"777":2}}],["headerchan",{"2":{"710":2}}],["headerrangefunctionid",{"2":{"218":1}}],["header",{"0":{"383":1,"625":1,"752":1},"2":{"91":1,"109":2,"110":1,"118":2,"119":1,"120":1,"125":11,"126":9,"127":1,"128":18,"130":19,"150":2,"160":2,"174":1,"204":2,"208":5,"210":8,"211":10,"215":16,"217":1,"218":2,"227":2,"336":2,"371":1,"383":2,"558":9,"625":2,"641":1,"644":1,"649":1,"650":4,"668":1,"710":16,"711":7,"752":8,"753":2,"758":4,"772":2,"778":22,"779":13}}],["headers",{"0":{"134":1,"336":1,"710":1,"778":1},"2":{"91":1,"97":1,"109":1,"124":1,"128":1,"130":5,"134":1,"139":1,"221":1,"238":2,"322":1,"336":3,"338":2,"415":2,"459":3,"476":2,"559":3,"605":1,"606":1,"641":1,"642":1,"643":1,"650":5,"710":6,"778":6}}],["head",{"2":{"80":1,"122":1,"126":1,"277":1,"300":1,"370":1,"398":2,"559":6,"561":1,"571":1,"578":1,"736":1,"779":2}}],["heard",{"2":{"578":1}}],["hear",{"2":{"42":2}}],["hesitate",{"2":{"34":1,"39":1}}],["hetzner",{"2":{"23":1}}],["eprintln",{"2":{"778":4}}],["ephemeral",{"2":{"581":1}}],["eq",{"2":{"777":6}}],["equally",{"2":{"648":1}}],["equal",{"2":{"596":4,"708":4}}],["equipments",{"2":{"34":1}}],["equipment",{"2":{"30":2,"31":1,"34":2,"40":1}}],["e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",{"2":{"752":8}}],["egrep",{"2":{"372":6}}],["egg",{"2":{"291":2}}],["egeiggrjtkryaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"147":2}}],["eye",{"2":{"276":1}}],["eclipse",{"2":{"631":1}}],["ecfg",{"2":{"597":4}}],["echo",{"2":{"361":10,"399":1,"452":2,"537":2,"558":4}}],["ec2",{"2":{"217":1}}],["ecosystem",{"2":{"7":1,"20":1,"26":3,"37":3,"42":1,"44":1,"47":1,"54":1,"55":1,"58":3,"221":1,"275":1,"478":1,"678":1,"679":2,"680":2}}],["economic",{"2":{"6":1,"23":1}}],["eofsudo",{"2":{"602":1,"604":1,"605":1,"606":1}}],["eof",{"2":{"331":2,"602":3,"604":3,"605":3,"606":3}}],["eoa",{"2":{"202":2}}],["eoujy0=",{"2":{"147":2}}],["ef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"147":3}}],["efficient",{"2":{"322":1,"581":1,"591":1,"648":1}}],["efficiently",{"2":{"167":1,"627":1}}],["efficiency",{"2":{"221":1}}],["effect",{"2":{"642":1}}],["effects",{"2":{"163":2}}],["effectively",{"2":{"39":1,"51":1,"372":1}}],["effective",{"2":{"38":1,"42":1,"483":1}}],["efforts",{"2":{"41":1}}],["eight",{"2":{"644":1}}],["eip",{"2":{"588":1}}],["eip4844",{"2":{"109":1}}],["eiokkc9jzwxlc3rpys5ibg9ilnyxlk1zz1bheuzvckjsb2jzumvzcg9uc2u=",{"2":{"147":2}}],["either",{"2":{"58":1,"104":1,"169":1,"186":1,"203":2,"204":1,"211":2,"215":1,"275":3,"309":1,"312":1,"390":1,"556":1,"558":1,"588":1,"650":1,"680":1,"697":1,"736":1,"739":1,"760":1}}],["era",{"2":{"688":1}}],["erasure",{"2":{"137":1,"238":2,"631":1,"632":3,"646":1,"649":1,"668":1,"718":1}}],["err=",{"2":{"383":2,"625":2}}],["err",{"2":{"128":18,"130":12,"136":10,"143":16,"144":78,"148":8,"150":24,"153":4,"161":34,"162":26,"163":30,"383":2,"596":30,"597":50,"625":2,"708":30,"709":18,"710":24,"711":12,"770":6,"771":42,"772":6,"773":30,"778":4}}],["errorcodes",{"2":{"163":2}}],["errorf",{"2":{"130":4,"144":2,"161":2,"771":6,"772":4}}],["error",{"0":{"337":1},"2":{"95":1,"126":10,"128":4,"130":4,"144":6,"150":2,"161":2,"163":4,"328":1,"331":2,"333":2,"334":3,"337":6,"383":1,"400":3,"449":1,"596":2,"597":2,"625":1,"708":2,"709":2,"710":4,"711":2,"762":3,"771":8,"772":4,"778":4}}],["errors",{"2":{"91":1,"430":1,"542":1}}],["erc20outbox",{"2":{"100":1,"101":1}}],["erc20rollupeventinbox",{"2":{"100":1,"101":1}}],["erc20inbox",{"2":{"100":1,"101":1}}],["erc20bridge",{"2":{"100":1,"101":1}}],["erc20tokenbridge",{"2":{"93":2}}],["erc20",{"2":{"93":2}}],["earn",{"2":{"281":1,"674":1}}],["early",{"2":{"221":1,"291":2,"679":4,"680":2}}],["ease",{"0":{"580":1}}],["easily",{"2":{"406":1,"454":1}}],["easiest",{"2":{"388":2,"461":1,"725":1}}],["easier",{"2":{"42":1}}],["easy2stake",{"2":{"487":1,"488":1}}],["easy",{"2":{"41":1,"250":1,"580":1,"648":1,"688":1}}],["eager",{"2":{"42":1}}],["each",{"2":{"25":1,"27":2,"36":1,"46":1,"58":1,"63":1,"91":1,"110":1,"119":1,"125":1,"127":1,"130":1,"160":2,"166":1,"171":1,"202":4,"214":1,"281":1,"303":1,"322":1,"328":2,"329":1,"404":1,"430":2,"483":1,"484":1,"499":2,"523":1,"531":2,"586":1,"588":1,"589":3,"590":2,"591":2,"592":2,"641":1,"642":1,"648":1,"649":2,"650":1,"668":1,"669":1,"672":1,"675":1,"680":1,"715":1,"738":1,"774":1}}],["es",{"2":{"487":2,"488":2,"489":2,"490":2,"506":1,"507":1,"508":1}}],["estimates",{"2":{"590":1}}],["estimategas",{"2":{"590":2}}],["estimated",{"2":{"590":1,"597":2}}],["estimate",{"2":{"36":1,"93":8,"294":2,"590":1,"591":1}}],["estimating",{"0":{"589":1,"591":1},"2":{"36":2,"590":1,"597":2}}],["establishes",{"2":{"525":1}}],["established",{"2":{"434":1}}],["establish",{"2":{"36":1,"90":2,"427":1}}],["especially",{"2":{"34":1,"44":1,"607":1}}],["essentially",{"2":{"321":1}}],["essential",{"2":{"34":1,"39":1,"41":1,"47":1,"88":1,"90":1,"252":1,"313":1,"326":1,"398":5,"681":1,"687":1}}],["elevated",{"2":{"557":2}}],["eliminating",{"2":{"328":1}}],["eligibility",{"0":{"23":1},"2":{"20":1,"22":1}}],["else",{"2":{"144":2,"430":1,"782":2}}],["elastic",{"2":{"33":1}}],["eth0",{"2":{"378":2}}],["etherscan",{"2":{"202":6,"203":6,"208":1,"210":6}}],["ethereumclient",{"2":{"126":6,"128":4,"130":2}}],["ethereum",{"0":{"112":1,"134":1,"220":1,"400":1},"1":{"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1},"2":{"33":1,"82":3,"84":1,"85":1,"91":1,"103":2,"107":1,"108":2,"111":2,"112":4,"120":1,"124":2,"125":4,"126":12,"128":3,"130":4,"134":3,"144":12,"163":12,"216":1,"221":3,"225":1,"226":2,"227":8,"228":2,"231":1,"251":1,"255":1,"400":6,"454":2,"455":7,"540":1,"544":4,"588":1,"688":1}}],["ethcmn",{"2":{"144":2,"161":2,"162":2,"163":2}}],["ethclient",{"2":{"144":10,"161":8,"162":8,"163":8}}],["eths",{"2":{"93":2}}],["eth",{"0":{"84":1},"2":{"77":1,"82":2,"84":5,"86":1,"87":2,"90":1,"91":6,"93":7,"95":1,"544":1,"688":1}}],["ethnicity",{"2":{"6":1}}],["etc",{"2":{"30":2,"32":1,"42":1,"68":1,"137":1,"174":1,"337":2,"493":1,"505":1,"602":4,"604":4,"605":4,"606":4,"738":2}}],["evidence",{"2":{"715":1,"752":2}}],["evolution",{"2":{"478":1,"646":1}}],["evm",{"2":{"81":1,"107":1,"144":4,"161":6,"162":2,"163":4,"165":1,"202":1,"210":1,"211":2,"221":1,"231":1,"249":2,"251":2,"272":6,"543":1,"544":3,"576":1,"582":1}}],["evaluated",{"2":{"25":1}}],["evaluate",{"2":{"23":1,"32":1}}],["ever",{"2":{"291":2}}],["everything",{"2":{"57":1,"118":2,"186":1,"368":5,"431":1}}],["everyone",{"2":{"6":1,"35":1,"46":2,"443":1,"445":1,"448":1,"450":1,"499":1}}],["every",{"2":{"2":1,"21":1,"25":1,"28":1,"109":1,"211":1,"216":2,"228":2,"275":4,"287":1,"299":1,"303":1,"370":1,"443":1,"581":2,"586":1,"641":3,"642":1,"644":3,"647":1,"649":5,"650":1,"675":1,"731":1,"769":1}}],["even",{"2":{"34":2,"205":1,"391":1,"607":1,"643":1,"647":1}}],["eventually",{"2":{"592":1,"650":1}}],["eventpayforblobs",{"2":{"147":2}}],["eventschan",{"2":{"162":6}}],["eventsiterator",{"2":{"144":8,"161":8}}],["events",{"2":{"36":6,"46":1,"48":1,"50":1,"58":1,"90":3,"91":2,"144":4,"147":4,"160":2,"161":6,"162":2,"163":4,"208":2,"294":2,"381":2}}],["event",{"2":{"9":1,"23":1,"30":5,"31":2,"32":3,"34":2,"35":2,"36":1,"37":5,"38":11,"39":9,"40":5,"46":2,"50":1,"91":3,"112":1,"144":12,"161":8,"162":8,"163":2,"208":1,"219":1,"381":1,"400":2,"429":4}}],["e",{"2":{"9":1,"22":1,"32":1,"42":2,"119":1,"144":12,"160":1,"161":12,"174":2,"175":1,"187":1,"206":1,"217":1,"275":1,"325":1,"338":1,"361":10,"373":1,"378":2,"390":12,"392":12,"393":12,"403":1,"455":1,"459":1,"558":1,"584":1,"586":1,"592":1,"620":1,"630":1,"641":3,"642":1,"643":4,"644":4,"646":2,"647":6,"649":4,"650":9,"704":4,"738":1,"778":8}}],["ed25519",{"2":{"715":1}}],["eds",{"0":{"711":1,"779":1},"2":{"711":8,"779":10}}],["editing",{"2":{"337":1,"377":1,"431":1}}],["edits",{"2":{"8":1}}],["edit",{"2":{"8":1,"211":2,"303":1,"337":1,"429":2,"435":1}}],["education",{"2":{"6":1,"44":1}}],["embark",{"2":{"763":1}}],["embedded",{"2":{"238":1}}],["emvpw0p8nijmvnocp4bv6k+v6gjmwdxuku=",{"2":{"760":2}}],["emitted",{"2":{"219":1}}],["emits",{"2":{"144":2,"161":2,"163":2}}],["employ",{"2":{"627":1}}],["employed",{"2":{"281":1}}],["employees",{"2":{"41":1}}],["empty",{"2":{"210":1,"352":1,"707":1,"770":2,"771":3,"773":2,"776":1}}],["empowering",{"2":{"46":1}}],["empower",{"2":{"44":1}}],["emphasizing",{"2":{"34":1}}],["empathy",{"2":{"7":1}}],["emergency",{"2":{"23":1}}],["emails",{"0":{"48":1},"2":{"48":2}}],["email",{"2":{"7":1,"23":1,"26":1,"30":1,"39":2,"41":2,"47":1,"48":1,"57":1}}],["engine",{"2":{"389":1,"391":1}}],["engages",{"2":{"281":1}}],["engage",{"2":{"38":1,"39":1,"40":1,"44":1,"681":1}}],["engaged",{"2":{"36":1}}],["engagement",{"2":{"32":1,"37":1}}],["engaging",{"2":{"24":1,"35":1,"37":1,"41":1,"49":1,"57":1,"58":1}}],["enabling",{"2":{"320":1,"402":1,"552":1,"648":1,"782":2}}],["enabled=0",{"2":{"214":2}}],["enabled",{"2":{"202":2,"274":1,"313":1,"326":1,"429":12,"437":1,"539":1}}],["enables",{"2":{"112":1,"221":1,"255":1,"316":1,"320":1,"341":1,"400":1,"581":1,"582":1,"615":1,"640":1,"642":1,"646":2,"647":1,"648":1,"674":1}}],["enable",{"0":{"205":1,"364":1},"2":{"18":1,"91":4,"211":2,"316":1,"320":2,"363":1,"371":2,"427":1,"454":1,"539":1,"544":1,"602":3,"604":3,"605":3,"606":3,"640":1,"643":1,"646":1,"726":1,"782":2}}],["envcd",{"2":{"211":1}}],["env",{"2":{"202":4,"210":11,"211":7,"218":1,"584":1}}],["environments",{"2":{"64":1,"485":1,"503":1}}],["environment",{"0":{"397":1},"1":{"398":1,"399":1},"2":{"7":1,"46":1,"202":4,"210":3,"211":10,"251":1,"254":1,"311":1,"320":1,"341":1,"343":1,"388":1,"397":2,"457":1,"462":1,"475":1,"476":1,"478":1,"540":3,"584":1,"614":1,"647":1,"695":1,"705":2,"764":1,"766":1,"772":3}}],["enough",{"2":{"136":1,"227":1,"641":1}}],["encrypt",{"2":{"263":2}}],["encrypted",{"2":{"263":5,"699":1}}],["encapsulating",{"2":{"88":1}}],["encounter",{"2":{"334":1,"337":1,"383":1,"449":1,"479":1,"625":1,"762":1}}],["encouraging",{"2":{"44":1}}],["encouraged",{"2":{"334":1,"499":1,"735":1}}],["encourages",{"2":{"35":1,"38":1,"41":1,"86":1}}],["encourage",{"2":{"31":1,"37":1,"38":1,"39":1}}],["encode",{"2":{"155":2,"537":1,"597":2,"641":1}}],["encoded",{"2":{"125":1,"127":1,"137":1,"142":1,"147":1,"152":1,"169":2,"183":1,"190":1,"191":1,"194":1,"266":1,"537":2,"538":1,"569":1,"594":4,"595":4,"743":9,"745":2}}],["encoding",{"2":{"125":1,"150":2,"171":1,"562":1,"597":6,"632":2,"641":2,"643":8,"646":1,"649":1,"769":2}}],["encompasses",{"2":{"238":1}}],["encompass",{"2":{"41":1}}],["enjoy",{"2":{"46":1,"58":1,"93":2}}],["enjoyable",{"2":{"35":1}}],["enlightening",{"2":{"44":1}}],["endkey",{"2":{"156":3}}],["ending",{"2":{"156":2,"647":1,"765":1}}],["endshare=1",{"2":{"152":1}}],["endblock",{"2":{"144":6,"161":4}}],["end=20",{"2":{"142":1}}],["endpoints",{"0":{"64":1,"65":1,"66":1,"67":1,"68":1,"485":1,"487":1,"488":1,"489":1,"490":1,"492":1,"493":1,"494":1,"495":1,"503":1,"504":1,"505":1,"506":1,"507":1,"508":1,"509":1},"1":{"67":1,"68":1,"495":1},"2":{"65":7,"67":1,"68":3,"252":1,"301":1,"310":1,"322":1,"326":1,"371":2,"485":1,"487":1,"492":1,"493":3,"503":1,"504":1,"505":2,"507":2,"509":1,"559":1,"706":1,"717":1,"726":1,"731":1,"734":1,"775":1}}],["endpoint",{"0":{"321":1,"376":1,"735":1},"1":{"377":1,"378":1,"379":1},"2":{"63":1,"65":2,"68":1,"91":3,"109":2,"136":4,"141":1,"142":1,"143":1,"144":4,"147":1,"149":1,"151":1,"152":3,"153":1,"160":1,"161":4,"163":4,"202":1,"210":1,"211":2,"238":1,"244":1,"245":1,"275":4,"301":1,"316":6,"317":2,"318":2,"319":2,"320":4,"321":1,"338":2,"371":1,"376":1,"378":1,"390":1,"422":3,"465":3,"484":1,"493":1,"495":1,"506":1,"507":1,"508":1,"544":1,"558":2,"735":5,"743":1,"760":1}}],["end",{"2":{"38":1,"125":2,"141":1,"147":6,"151":1,"152":4,"156":3,"163":4,"172":1,"175":1,"216":2,"219":1,"294":2,"295":2,"429":4,"644":1,"649":1}}],["enhancement",{"2":{"328":1}}],["enhanced",{"2":{"59":1}}],["enhances",{"2":{"35":1,"38":1}}],["enhance",{"2":{"32":1,"650":1}}],["entails",{"2":{"643":1,"647":4,"648":1}}],["entering",{"2":{"614":1}}],["enter",{"2":{"263":2,"275":1,"281":1,"291":2,"656":1,"660":1,"700":1}}],["enters",{"2":{"23":1}}],["entrypoint",{"2":{"202":1,"210":1,"234":2,"704":2,"705":2}}],["entry",{"2":{"86":2,"254":1}}],["enthusiastic",{"2":{"43":1}}],["enthusiasts",{"2":{"37":1,"44":1}}],["entities",{"2":{"224":1,"637":1}}],["entitle",{"2":{"69":1,"510":1}}],["entity",{"2":{"26":2,"320":1,"338":2,"558":1}}],["entirely",{"2":{"134":1}}],["entire",{"2":{"29":1,"110":1,"338":1,"356":1,"372":1,"494":1,"558":1,"631":1,"640":1,"650":1,"705":1}}],["ensuring",{"2":{"18":1,"39":1,"58":1}}],["ensures",{"2":{"381":1,"400":1,"627":1,"631":1,"647":1}}],["ensure",{"2":{"2":1,"31":1,"36":1,"37":1,"39":1,"40":2,"41":1,"86":1,"88":1,"90":1,"226":1,"337":1,"400":1,"431":1,"450":1,"459":1,"479":1,"528":1,"599":1,"647":1,"670":2,"762":1}}],["enforced",{"2":{"396":1,"588":1}}],["enforce",{"2":{"46":1}}],["enforcement",{"0":{"8":1,"10":1,"11":1},"1":{"12":1,"13":1,"14":1,"15":1},"2":{"10":1,"16":1}}],["enforcing",{"2":{"8":1,"13":1,"14":1}}],["exit",{"2":{"143":6,"144":2,"163":2}}],["exist",{"2":{"201":2,"246":1,"331":1,"408":1,"423":1,"468":1,"671":1,"672":1,"682":1,"683":1}}],["exists",{"2":{"167":1,"170":1,"433":1}}],["existent",{"2":{"127":1}}],["existing",{"0":{"212":1,"522":1,"705":1},"2":{"22":1,"25":1,"36":1,"41":1,"54":1,"55":1,"91":1,"184":1,"204":1,"208":4,"210":1,"212":2,"217":1,"275":1,"311":1,"334":1,"336":1,"341":1,"432":1,"434":1,"435":1,"450":1,"455":1,"542":1,"549":1,"582":2,"592":1,"704":1,"705":2,"716":1}}],["exec",{"2":{"704":2,"705":2}}],["execstart=$",{"2":{"602":2,"604":2,"605":2,"606":2}}],["executable",{"2":{"214":2,"649":4,"668":2}}],["execution",{"2":{"130":1,"204":1,"249":1,"251":1,"455":1,"578":2,"581":3,"582":3,"640":2,"646":1,"647":7,"648":1,"688":1,"720":1}}],["executing",{"2":{"93":2,"381":1,"647":1}}],["executor",{"2":{"93":6}}],["executed",{"2":{"373":1,"620":1,"647":1,"649":1}}],["executes",{"2":{"369":2}}],["execute",{"2":{"51":1,"57":1,"204":1,"294":1,"329":1,"370":1,"398":1,"578":1,"581":1,"646":1}}],["exercises",{"2":{"126":1}}],["exhaustive",{"2":{"109":2}}],["extends",{"2":{"649":1}}],["extendeddatasquare",{"2":{"711":2,"779":2}}],["extendedheader",{"2":{"710":2}}],["extendedheaders",{"2":{"459":1}}],["extended",{"0":{"643":1,"711":1,"779":1},"2":{"174":1,"175":1,"641":4,"643":6,"649":4,"650":2,"668":1,"711":1,"758":1,"778":4,"779":1}}],["extension",{"0":{"654":1,"659":1},"2":{"294":4,"782":2}}],["external",{"0":{"378":1},"2":{"13":1,"107":1,"275":4,"378":3,"580":1,"726":1}}],["extradata",{"2":{"536":2}}],["extra",{"0":{"374":1},"1":{"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1},"2":{"91":2,"95":1,"175":1,"590":1,"623":1}}],["exact",{"2":{"483":1,"591":1,"675":1}}],["exactly",{"2":{"25":1,"275":2,"563":1,"715":1}}],["example",{"0":{"118":1,"144":1,"163":1,"182":1,"758":1},"2":{"68":2,"74":1,"90":1,"93":1,"118":1,"142":2,"147":2,"152":2,"155":1,"156":1,"157":1,"159":1,"160":3,"163":5,"172":1,"180":1,"182":1,"202":8,"210":5,"211":3,"218":1,"244":1,"245":1,"263":1,"265":2,"294":1,"301":1,"308":1,"313":1,"317":1,"318":1,"319":1,"326":1,"329":1,"331":1,"332":1,"338":2,"343":2,"361":1,"367":1,"380":1,"381":1,"391":1,"392":1,"408":1,"409":1,"412":1,"432":1,"516":1,"544":1,"557":1,"562":3,"563":1,"578":1,"589":1,"605":1,"614":1,"644":2,"647":1,"650":1,"672":1,"680":1,"704":1,"705":1,"709":1,"710":1,"735":2,"738":1,"740":1,"742":2,"743":4,"745":3,"749":1,"752":1,"755":1,"758":1,"760":2,"773":1,"778":1}}],["examples",{"0":{"330":1,"747":1},"1":{"331":1,"332":1,"333":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1},"2":{"7":2,"9":1,"134":1,"314":1,"320":1,"596":1,"746":1,"760":1}}],["exceed",{"2":{"369":1}}],["exceptions",{"0":{"720":1}}],["exceptional",{"2":{"18":1,"37":1}}],["except",{"2":{"144":2,"607":1}}],["exclusively",{"2":{"59":1}}],["exclusive",{"2":{"47":1,"58":1,"147":1}}],["exchange",{"2":{"23":1,"87":1}}],["exposes",{"2":{"507":1}}],["expose",{"0":{"377":1}}],["exposed",{"2":{"126":1,"245":1,"422":1,"465":1,"717":1,"724":1,"734":1}}],["exporter",{"0":{"276":1},"2":{"276":1}}],["exported",{"2":{"263":2}}],["exporting",{"0":{"263":1,"699":1}}],["export",{"0":{"271":1},"2":{"93":1,"260":4,"263":3,"271":1,"275":1,"293":2,"299":2,"314":15,"399":4,"405":4,"412":4,"537":3,"558":3,"699":7,"704":1,"740":2,"741":1,"742":2,"760":1,"782":10}}],["expand",{"2":{"40":1,"46":1}}],["express",{"2":{"38":1}}],["expression",{"2":{"6":1}}],["expensive",{"2":{"171":1,"183":1,"185":1,"188":1,"199":2}}],["expenses",{"2":{"38":1}}],["experimentation",{"2":{"582":1}}],["experimentalsuggestchain",{"2":{"782":4}}],["experimental",{"2":{"221":1,"341":2,"479":1,"547":1}}],["experimenting",{"2":{"574":1}}],["experiment",{"2":{"439":1}}],["experiences",{"2":{"7":1}}],["experience",{"2":{"6":2,"7":1,"26":1,"32":1,"35":1,"38":1,"46":1,"526":1,"540":1,"547":1,"722":1,"763":1}}],["experts",{"2":{"37":2,"58":1}}],["expertise",{"2":{"37":1,"42":1,"58":1}}],["expects",{"2":{"316":1,"396":1}}],["expect",{"2":{"48":1,"58":1,"124":1,"705":1,"777":10,"778":6,"779":6}}],["expectations",{"2":{"36":1}}],["expected",{"2":{"23":1,"30":1,"130":2,"204":1,"295":1,"331":1,"332":1,"333":1,"383":2,"625":2,"672":2}}],["exploring",{"2":{"259":1,"384":1}}],["exploreme",{"2":{"496":1}}],["explored",{"2":{"197":1}}],["explorer",{"0":{"92":1,"257":1},"2":{"72":1,"79":1,"92":2,"257":2,"461":1,"496":2,"512":1,"599":2,"614":1,"620":1,"683":1,"771":2,"783":2,"784":1}}],["explorers",{"0":{"72":1,"496":1,"512":1},"2":{"72":1,"496":2,"512":3,"620":1,"638":1,"713":1}}],["explore",{"2":{"34":1,"50":1,"51":1,"457":1}}],["explains",{"2":{"427":1,"515":1}}],["explained",{"2":{"183":1,"188":1,"197":1}}],["explanation",{"2":{"12":1,"630":1}}],["explicit",{"2":{"7":1}}],["pwd",{"2":{"705":2}}],["ps",{"2":{"704":1,"705":1}}],["psdocker",{"2":{"704":1,"705":1}}],["psql",{"2":{"380":2}}],["python3",{"2":{"543":2}}],["p",{"2":{"215":2,"372":6,"537":2,"558":2,"559":1,"704":2}}],["pk",{"2":{"214":2}}],["pkg",{"2":{"144":2,"150":2,"163":2,"383":14,"398":4,"597":6,"625":14}}],["pfbs",{"2":{"169":1,"183":1,"185":1,"528":2,"591":1}}],["pfb",{"0":{"149":1,"589":1,"761":1},"1":{"150":1},"2":{"93":1,"137":5,"139":1,"145":1,"149":1,"150":2,"169":4,"170":1,"171":1,"191":2,"483":2,"586":1,"589":4,"669":1,"745":3}}],["p2p",{"0":{"351":1,"361":1},"1":{"352":1,"353":1},"2":{"65":5,"68":2,"91":4,"126":1,"244":4,"245":6,"246":4,"260":2,"313":2,"314":4,"316":2,"318":2,"319":2,"320":4,"322":1,"324":4,"325":5,"326":2,"329":6,"334":4,"335":4,"336":4,"338":4,"390":12,"392":12,"393":12,"407":2,"408":2,"421":4,"422":2,"423":4,"464":4,"465":6,"466":8,"468":4,"475":4,"476":8,"509":1,"516":2,"521":2,"544":4,"557":3,"559":2,"565":2,"605":2,"646":1,"698":9,"699":6,"700":6,"704":4,"705":3,"734":4,"735":8,"736":8,"738":2,"740":4,"742":4,"750":2,"760":2,"765":4}}],["pin",{"2":{"672":1}}],["pinning",{"2":{"672":1}}],["pinnacle",{"2":{"478":1}}],["pings",{"2":{"218":1}}],["pink",{"2":{"137":1}}],["pieces",{"2":{"125":1}}],["pick",{"0":{"85":1,"90":1},"2":{"308":1,"344":1,"361":1,"620":1,"655":1,"698":1}}],["pitches",{"2":{"38":1}}],["pitch",{"2":{"38":2}}],["pizza",{"2":{"35":1}}],["phase",{"2":{"355":1}}],["phrase",{"2":{"291":2,"430":1}}],["photos",{"2":{"31":1,"32":1}}],["physical",{"2":{"7":1}}],["plugin",{"2":{"277":1}}],["plus",{"2":{"84":1,"769":1}}],["plonky2x",{"2":{"214":7,"215":3,"233":1}}],["plonk",{"2":{"202":1,"203":1,"213":1,"214":3,"215":1}}],["plw1gxabnavhwwurqswb0xh25zv9xhielqtvld0xqc4=",{"2":{"147":2}}],["plain",{"2":{"682":1,"743":1,"745":1}}],["plaintext",{"2":{"557":2,"743":1}}],["plasma",{"2":{"535":1,"540":2}}],["plastic",{"2":{"35":1}}],["play",{"2":{"385":1,"453":1,"690":1}}],["playbook",{"2":{"44":1}}],["playlist",{"2":{"40":1}}],["platform",{"0":{"41":1,"218":1},"2":{"49":1,"203":1,"211":2,"218":3,"219":1,"251":1,"388":1,"478":1}}],["platforms",{"2":{"30":1,"39":1,"40":1,"718":1}}],["planned",{"2":{"36":1,"39":1,"524":1}}],["planning",{"2":{"32":1,"42":1,"344":1}}],["plans",{"2":{"35":1}}],["plan",{"2":{"30":1,"35":1,"36":1,"39":1,"40":1,"41":1,"51":1,"57":1}}],["placement",{"2":{"22":2,"26":1}}],["place",{"2":{"22":10,"38":1,"275":1,"291":2,"432":1,"572":1,"707":1,"776":1}}],["plethora",{"2":{"276":1}}],["pledge",{"0":{"6":1},"2":{"6":2}}],["please",{"2":{"2":1,"4":1,"26":4,"30":1,"47":2,"57":1,"91":1,"124":1,"134":1,"152":1,"153":1,"163":2,"221":1,"336":2,"347":1,"387":1,"388":1,"428":2,"430":1,"483":1,"528":1,"534":1,"621":1,"698":1,"782":2}}],["panel",{"2":{"666":1}}],["panic",{"2":{"383":2,"625":2}}],["padded",{"2":{"649":1}}],["paper",{"2":{"641":1,"644":1,"650":1}}],["packet",{"2":{"429":8,"435":4}}],["packets",{"2":{"427":3,"428":1,"429":2}}],["packages",{"2":{"398":1}}],["package",{"0":{"597":1},"2":{"104":1,"143":1,"144":1,"163":1,"261":1,"275":1,"597":2,"769":1}}],["pagination",{"2":{"297":4}}],["page",{"2":{"26":1,"73":1,"77":1,"87":1,"113":1,"160":1,"244":3,"245":1,"258":1,"275":2,"277":1,"281":1,"301":1,"309":1,"311":1,"312":1,"324":1,"388":2,"390":2,"397":1,"422":2,"453":1,"462":1,"465":1,"498":1,"499":2,"513":1,"522":1,"535":1,"554":1,"556":1,"570":1,"571":2,"572":1,"586":1,"617":1,"623":1,"649":1,"654":1,"698":1,"704":2,"735":1,"736":1,"781":1}}],["pairs",{"2":{"322":1}}],["paired",{"2":{"275":1}}],["paid",{"2":{"87":1,"544":1,"672":1}}],["path=$path",{"2":{"399":4}}],["path",{"0":{"287":1},"2":{"203":2,"211":3,"215":2,"246":1,"247":1,"266":4,"267":2,"287":1,"349":1,"392":6,"393":4,"396":1,"423":1,"424":1,"468":1,"469":1,"557":4,"697":2,"739":1,"741":3,"742":5}}],["pattern",{"2":{"15":1}}],["payload",{"2":{"771":4}}],["paying",{"0":{"667":1,"687":1},"1":{"668":1,"669":1},"2":{"688":1}}],["payee",{"2":{"429":2}}],["payer",{"2":{"294":2}}],["payment",{"2":{"404":1,"668":2,"715":1}}],["payments",{"2":{"86":1}}],["payforblob",{"2":{"144":6,"150":1,"161":2,"163":2,"245":1,"422":2,"466":1,"471":1}}],["payforblobs",{"0":{"668":1},"2":{"137":1,"400":1,"465":1,"542":1,"590":1,"594":2,"649":3,"650":1,"668":3,"687":1,"736":1,"762":1}}],["pay",{"2":{"87":1,"91":1,"245":1,"404":2,"412":1,"422":1,"466":1,"544":1,"590":1,"736":1}}],["paradigm",{"2":{"647":2}}],["parallel",{"2":{"582":1}}],["param",{"2":{"266":2}}],["paramfilter",{"2":{"266":1}}],["params=",{"2":{"782":6}}],["params",{"2":{"91":1,"266":3,"355":1,"538":3,"715":1,"760":2,"782":27}}],["parameterchangeproposal",{"2":{"266":2}}],["parameters",{"0":{"482":1,"677":1,"782":1},"1":{"483":1},"2":{"93":1,"154":4,"160":2,"204":1,"266":1,"281":1,"322":1,"482":2,"523":1,"586":1,"589":2,"590":1,"650":1,"677":2,"690":1,"738":1,"781":1,"782":3,"783":1,"784":1}}],["parameter",{"2":{"86":2,"122":1,"147":1,"266":3,"337":2,"483":2,"589":1,"590":1,"591":1,"620":1}}],["parity",{"2":{"174":1,"641":1,"643":1}}],["parsing",{"2":{"169":1,"170":2,"179":1,"183":1,"194":1}}],["parsed",{"2":{"199":1,"210":1,"771":2}}],["parse",{"2":{"163":2,"169":2,"171":1,"183":1,"185":1,"199":1,"758":1,"771":2}}],["parenthash",{"2":{"536":2}}],["parent",{"2":{"86":1,"90":2,"93":18}}],["parts",{"2":{"540":1,"668":1,"690":1,"752":4}}],["party",{"2":{"372":1,"402":1,"404":1,"412":1,"637":1,"713":1}}],["partitioned",{"2":{"644":1,"649":1}}],["partitions",{"2":{"644":1,"731":1}}],["particularly",{"2":{"627":1,"718":1}}],["particular",{"2":{"227":1,"343":1,"526":1,"528":1}}],["participating",{"2":{"42":1,"46":1,"58":1,"63":1,"272":1,"445":1,"484":1,"499":1}}],["participation",{"2":{"6":1,"18":1,"23":1,"32":1,"49":1,"86":1}}],["participates",{"2":{"531":1}}],["participate",{"0":{"546":1},"1":{"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1},"2":{"38":1,"47":1,"58":1,"65":1,"86":1,"443":1,"484":1,"499":1,"531":1,"549":1,"550":1,"610":1,"620":1,"648":1}}],["participant",{"2":{"23":1,"48":1}}],["participants",{"2":{"22":1,"40":1,"42":3,"46":1,"58":1,"448":1,"450":4,"451":2,"452":1}}],["parties",{"2":{"178":1,"637":1}}],["part",{"2":{"47":1,"137":1,"139":2,"140":1,"145":1,"163":6,"174":1,"175":5,"179":1,"183":3,"187":1,"227":1,"322":1,"428":1,"482":1,"540":1,"566":1,"580":1,"615":1,"644":2,"647":1,"680":1,"687":1,"688":1}}],["partnering",{"2":{"34":1,"38":1}}],["passes",{"2":{"649":1,"739":1}}],["passed",{"2":{"246":1,"260":2,"422":1,"423":1,"465":1,"468":1,"746":1,"771":2}}],["passing",{"0":{"518":1,"519":1}}],["passionate",{"2":{"58":1}}],["passphrase",{"2":{"263":2,"614":3}}],["password",{"2":{"263":3,"275":1,"291":2}}],["pass",{"2":{"122":1,"266":1,"707":1,"739":1,"770":3,"771":3,"773":2,"776":1,"782":2}}],["pasting",{"2":{"766":1}}],["paste",{"2":{"91":1,"124":1,"765":1}}],["past",{"0":{"529":1},"1":{"530":1},"2":{"38":1,"294":1,"367":1,"444":1,"633":1,"634":3,"635":1,"637":1,"638":2}}],["policy",{"2":{"429":4,"435":4}}],["political",{"2":{"7":1}}],["polypore",{"2":{"429":6}}],["popup",{"2":{"656":1}}],["populating",{"2":{"378":1,"770":1}}],["populated",{"2":{"771":1}}],["populate",{"2":{"110":1}}],["populates",{"2":{"67":1,"68":1,"492":1,"493":1,"504":1,"505":1}}],["popularity",{"2":{"36":1}}],["popular",{"2":{"36":1,"39":1}}],["pops",{"2":{"245":2,"265":4,"301":2,"303":2,"329":2,"403":1,"405":2,"412":2,"413":2,"429":2,"465":4,"466":2,"487":1,"488":1,"489":1,"493":1,"505":1,"507":1,"508":1,"558":4,"559":3,"704":2,"705":2,"735":2,"784":2}}],["point",{"2":{"254":1,"275":2,"291":2,"338":1,"487":1,"488":1,"489":1,"506":1,"507":1,"508":1,"592":1,"647":2,"698":1}}],["pointing",{"2":{"172":1}}],["pointer",{"2":{"109":1,"112":1,"125":2,"127":1,"172":1}}],["points",{"0":{"22":1},"2":{"328":1,"519":1}}],["portid",{"2":{"434":4}}],["portions",{"2":{"630":1,"631":1,"632":1}}],["portion",{"2":{"21":1,"137":1,"298":1,"302":1,"642":1,"680":1,"689":1}}],["portrays",{"2":{"182":1}}],["portal",{"2":{"81":1,"85":3,"86":1}}],["port",{"2":{"67":1,"68":5,"91":1,"244":5,"245":1,"275":3,"276":1,"303":2,"313":2,"326":4,"328":1,"333":2,"422":1,"429":4,"434":8,"451":4,"452":3,"465":1,"475":8,"476":3,"492":1,"493":15,"504":1,"505":3,"506":1,"507":1,"508":1,"735":5,"760":2}}],["ports",{"0":{"313":1,"326":1},"2":{"65":3,"68":2,"244":2,"309":2,"313":7,"324":2,"326":7,"390":2,"422":2,"453":2,"465":2,"617":2,"704":4,"705":4,"735":2}}],["poolcelestia",{"2":{"267":1}}],["pool",{"0":{"267":1,"678":1},"2":{"36":1,"267":9,"678":2,"690":1}}],["potentially",{"2":{"36":1,"40":1,"589":1,"590":1,"718":1}}],["potential",{"2":{"30":1,"36":1,"37":2,"38":2,"49":1,"91":1,"226":1}}],["powerful",{"2":{"273":1}}],["power",{"2":{"23":1,"526":1,"528":1,"649":1,"752":4,"763":1}}],["pos",{"0":{"645":1},"1":{"646":1},"2":{"646":2}}],["possibly",{"2":{"609":1}}],["possible",{"2":{"39":1,"81":1,"108":1,"130":2,"149":1,"182":1,"208":1,"235":1,"336":1,"406":1,"581":1,"641":1,"643":1,"650":1,"670":1,"672":1,"715":1,"762":1}}],["possibilities",{"2":{"457":1,"647":1}}],["positions",{"2":{"175":1}}],["position",{"2":{"109":1}}],["positives",{"2":{"650":1}}],["positiveerror",{"2":{"334":1}}],["positive",{"2":{"7":1,"46":1,"334":3,"650":1}}],["postgresql",{"2":{"380":1}}],["poster",{"0":{"90":1},"2":{"86":4,"88":1,"90":2,"91":7,"93":3,"109":3}}],["posted",{"2":{"85":3,"86":1,"91":1,"93":2,"109":2,"112":1,"118":1,"122":1,"124":1,"125":2,"126":1,"130":3,"134":1,"136":1,"137":1,"139":1,"154":4,"168":2,"180":1,"186":1,"187":1,"191":1,"194":1,"250":1,"331":1,"455":1,"562":1,"563":3,"708":1,"730":1,"771":1,"777":1}}],["post",{"0":{"560":1,"599":1,"761":1},"1":{"561":1,"562":1,"563":1},"2":{"34":1,"37":1,"39":1,"81":1,"86":1,"91":1,"109":2,"124":1,"128":2,"165":2,"178":1,"179":1,"228":1,"333":2,"404":1,"454":1,"538":2,"542":1,"544":1,"555":3,"562":4,"563":1,"596":2,"708":2,"760":4,"761":1,"773":1}}],["posts",{"2":{"30":1,"32":1,"85":1,"455":3,"540":3}}],["postings",{"2":{"88":1}}],["posting",{"0":{"134":1,"562":1},"2":{"9":1,"86":3,"87":1,"90":2,"91":1,"109":1,"124":1,"128":1,"385":1,"400":2,"455":4,"559":1,"561":1,"774":1}}],["peerid",{"2":{"750":1}}],["peer",{"0":{"452":1},"2":{"355":3,"452":3,"476":5,"607":1,"621":1,"672":6}}],["peerexchange",{"2":{"353":1}}],["peers=$",{"2":{"361":6}}],["peers",{"0":{"353":1},"2":{"352":2,"355":3,"361":38,"371":1,"378":1,"451":3,"476":2,"509":1}}],["pending",{"2":{"77":1,"79":1}}],["percentage",{"2":{"267":1,"281":2,"674":1}}],["persist",{"2":{"391":1}}],["persisted",{"2":{"381":1,"396":1}}],["persistent",{"0":{"391":1,"452":1},"1":{"392":1,"393":1},"2":{"361":13,"393":1,"451":5,"452":1}}],["perspective",{"2":{"238":1,"650":1}}],["person",{"2":{"40":2,"58":1}}],["personal",{"2":{"6":1,"7":1,"26":1,"37":1,"38":1}}],["per",{"2":{"37":1,"70":2,"510":2,"589":2,"590":2,"591":1,"597":2,"669":1,"675":1,"685":1}}],["performs",{"2":{"649":1,"738":1}}],["performed",{"2":{"431":2,"462":1,"642":1,"719":1}}],["performing",{"2":{"252":1,"642":1,"650":2}}],["perform",{"2":{"130":2,"322":1,"458":1,"459":1,"647":2,"650":1,"671":1}}],["performance",{"2":{"18":1,"20":1,"23":1,"32":1,"59":1,"221":1,"273":1,"337":1,"341":1,"479":1,"508":1,"547":1,"582":1}}],["perfect",{"2":{"34":1}}],["permanently",{"2":{"281":1,"670":1}}],["permanent",{"0":{"15":1},"2":{"13":1,"14":1,"15":1,"322":1}}],["permissions",{"2":{"391":1,"396":2,"724":1}}],["permissioned",{"2":{"225":1}}],["permissionless",{"2":{"205":1,"206":1,"562":1,"640":1,"647":1,"689":1}}],["permission",{"0":{"407":1,"410":1},"1":{"411":1},"2":{"7":1,"406":1}}],["periods",{"2":{"23":1}}],["period",{"2":{"13":1,"14":2,"22":1,"24":1,"86":2,"208":1,"281":3,"434":2}}],["people",{"2":{"7":1,"13":1,"14":1,"34":1,"36":1,"41":1,"42":1}}],["put",{"2":{"668":1}}],["punish",{"2":{"281":1}}],["pure",{"2":{"118":2}}],["purposes",{"2":{"126":1,"343":1,"396":1,"499":1,"633":1}}],["purpose",{"2":{"46":1,"353":1,"455":1,"637":1,"670":1,"697":1}}],["purchased",{"2":{"7":1}}],["pub",{"2":{"295":2,"296":2,"752":4,"782":2}}],["pubkeyed25519",{"2":{"752":4}}],["pubkey",{"2":{"291":4,"292":8,"296":2,"705":4}}],["pubkey=$",{"2":{"272":2,"620":2}}],["pubs",{"2":{"36":1}}],["publish",{"2":{"274":1,"639":1,"668":1}}],["published",{"2":{"109":1,"121":1,"139":1,"144":2,"164":1,"225":1,"577":1,"578":1,"627":2,"670":2,"672":1}}],["publishing",{"2":{"7":1,"275":3}}],["publicnode",{"2":{"544":2}}],["publicly",{"2":{"58":1,"377":1}}],["public",{"2":{"3":1,"7":1,"9":1,"12":1,"14":2,"15":1,"37":1,"69":1,"81":1,"87":1,"118":6,"163":2,"218":2,"309":2,"371":1,"376":1,"377":1,"378":1,"448":1,"487":1,"488":1,"489":1,"493":1,"505":1,"506":1,"508":1,"510":1,"544":3,"620":1,"635":1,"671":1,"672":2,"679":1,"680":1,"726":1}}],["pulled",{"2":{"773":1}}],["pull",{"2":{"2":2,"334":1,"450":1,"534":1,"697":1}}],["push",{"2":{"2":2,"118":2,"429":4}}],["pragma",{"2":{"118":2,"163":1}}],["practices",{"0":{"672":1},"2":{"54":1}}],["prune",{"2":{"368":2,"494":1,"671":1}}],["pruned",{"2":{"23":1,"27":1,"609":1,"671":1}}],["pruning",{"0":{"362":1,"670":1,"671":1},"1":{"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"671":1,"672":1},"2":{"68":1,"367":2,"368":1,"493":1,"494":1,"670":1,"671":4}}],["predetermined",{"2":{"526":1,"630":1}}],["precompiles",{"2":{"582":1}}],["precise",{"2":{"483":1}}],["precedence",{"2":{"328":1}}],["prefixed",{"2":{"649":1,"743":1}}],["prefix",{"2":{"429":12,"537":2,"783":1,"784":1}}],["preferred",{"0":{"652":1}}],["preference",{"2":{"525":1}}],["preferences",{"2":{"312":1,"343":1}}],["prefer",{"2":{"244":1,"735":1}}],["press",{"2":{"665":1}}],["preserved",{"2":{"334":1}}],["presence",{"2":{"328":1,"607":1}}],["present",{"2":{"225":1,"322":1,"324":1,"334":1}}],["presenters",{"2":{"37":1}}],["presenting",{"2":{"37":1}}],["presentation",{"0":{"53":1,"54":1,"55":1,"56":1},"2":{"30":1,"37":1,"38":1,"53":3,"54":3,"55":3,"56":2}}],["presentations",{"2":{"30":1,"31":1,"37":1,"54":1,"55":1,"58":1}}],["presumes",{"2":{"311":1}}],["preventing",{"2":{"400":1}}],["prevent",{"2":{"302":1,"303":1,"438":1}}],["previously",{"2":{"309":1,"455":1,"620":1,"738":1}}],["previoushash",{"2":{"125":2,"128":2}}],["previous",{"0":{"232":1},"1":{"233":1,"234":1,"235":1,"236":1},"2":{"32":1,"87":1,"112":1,"125":2,"204":2,"213":1,"215":3,"216":1,"227":1,"233":1,"294":1,"298":1,"302":1,"328":1,"336":1,"449":1,"559":1,"633":1,"659":1}}],["preimage",{"0":{"110":1},"2":{"108":1,"110":3}}],["pre",{"0":{"312":1,"342":1,"347":1,"403":1},"1":{"343":1},"2":{"86":1,"204":1,"310":1,"312":3,"342":2,"525":1,"526":1,"528":1,"535":1,"556":1}}],["prerequisites",{"0":{"82":1,"103":1,"116":1,"136":1,"307":1,"389":1,"473":1,"703":1},"2":{"695":1}}],["prerequisite",{"2":{"47":1,"279":2,"695":1}}],["preparing",{"2":{"31":1}}],["prepared",{"2":{"383":1,"625":1}}],["prepare",{"2":{"30":2,"39":1,"524":1}}],["proj",{"2":{"766":2}}],["project",{"0":{"707":1,"768":1,"776":1},"2":{"163":2,"169":1,"267":2,"562":1,"707":1,"768":2,"776":1}}],["projector",{"2":{"34":1}}],["projectors",{"2":{"30":1,"34":1}}],["projects",{"2":{"23":1,"38":1,"722":1}}],["probabilistically",{"2":{"650":1}}],["probability",{"2":{"641":1}}],["probably",{"2":{"578":1}}],["problem",{"0":{"628":1,"634":1},"2":{"628":2,"637":2,"640":1,"647":1,"648":1}}],["problematic",{"2":{"627":1}}],["problems",{"2":{"570":1,"634":1,"636":1}}],["progress",{"2":{"558":1}}],["programs",{"2":{"679":1}}],["programmatic",{"2":{"723":1}}],["programmatically",{"0":{"591":1},"2":{"134":1,"597":2}}],["programmed",{"2":{"525":1,"526":1,"528":1}}],["programming",{"2":{"164":1}}],["program",{"0":{"17":1,"18":1,"20":1,"43":1,"44":1},"1":{"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1},"2":{"18":1,"20":2,"22":2,"23":4,"25":1,"26":3,"27":1,"28":2,"33":1,"36":1,"37":1,"44":1,"47":2,"48":1,"50":1,"56":3,"58":3,"228":1,"567":1,"568":1,"769":4,"770":5,"771":6,"773":2}}],["pro",{"2":{"496":1}}],["property",{"2":{"650":1,"685":1}}],["properties",{"2":{"238":1,"557":2,"581":1}}],["properly",{"2":{"355":1}}],["proposing",{"2":{"649":1}}],["proposed",{"2":{"628":1}}],["propose",{"2":{"281":1,"677":1}}],["proposer",{"2":{"266":4,"455":1,"544":4,"752":8}}],["proposal",{"2":{"266":14,"267":5,"678":1}}],["proposalscelestia",{"2":{"266":1}}],["proposals",{"2":{"266":6,"267":3,"526":1,"651":1,"677":2,"690":1}}],["proxy",{"2":{"218":1}}],["pros",{"0":{"170":1,"176":1,"180":1,"184":1,"188":1,"192":1,"195":1},"2":{"166":1,"170":1}}],["prospective",{"2":{"20":1}}],["produced",{"2":{"709":1,"710":1,"778":1}}],["producers",{"2":{"643":2,"650":1}}],["producer",{"2":{"628":2,"649":4}}],["produceblock",{"2":{"128":2}}],["producing",{"2":{"126":2,"277":1,"531":1}}],["product",{"2":{"589":1,"590":2}}],["production",{"0":{"64":1,"485":1,"503":1},"2":{"64":1,"65":2,"86":2,"238":1,"301":2,"361":1,"478":1,"485":3,"487":2,"503":3,"547":1,"580":1,"607":2,"735":2}}],["products",{"2":{"60":1}}],["provably",{"2":{"670":1}}],["provisions",{"2":{"675":1}}],["provision",{"2":{"495":1}}],["proving",{"0":{"132":1,"144":1,"174":1,"175":1,"217":1},"2":{"124":1,"145":1,"164":1,"165":1,"167":1,"169":2,"175":2,"179":4,"211":1,"217":2,"218":1,"235":1,"584":4,"627":1}}],["provides",{"2":{"41":1,"122":1,"244":1,"251":1,"273":1,"402":1,"422":1,"483":1,"572":1,"583":1,"599":1,"640":1,"644":1,"646":1,"647":1,"648":1,"672":1,"722":1,"724":1,"735":1}}],["provided",{"2":{"33":1,"37":1,"44":1,"81":1,"93":1,"157":1,"174":1,"183":1,"191":2,"202":2,"352":1,"355":1,"371":2,"644":3,"696":1,"715":1}}],["providers",{"0":{"713":1},"1":{"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"720":1},"2":{"34":1,"64":1,"65":1,"485":2,"487":1,"503":2,"580":1,"672":2,"713":1,"726":1}}],["provider",{"0":{"109":1,"715":1},"1":{"716":1,"717":1,"718":1,"719":1,"720":1},"2":{"26":1,"34":1,"64":1,"90":1,"108":1,"109":1,"208":1,"372":1,"485":1,"503":1,"540":1,"575":1,"607":1}}],["provide",{"0":{"639":1},"2":{"18":1,"26":1,"31":1,"35":1,"40":1,"41":1,"67":1,"68":2,"104":1,"111":1,"139":1,"140":1,"141":1,"145":1,"174":1,"175":2,"273":1,"294":1,"310":1,"343":1,"352":1,"373":1,"449":1,"492":1,"493":2,"497":1,"504":1,"505":2,"511":1,"534":1,"562":1,"620":2,"632":1,"637":2,"638":2,"640":1,"644":2,"672":1,"743":1}}],["providing",{"0":{"646":1},"2":{"12":1,"35":1,"44":1,"49":1,"59":1,"112":1,"199":1,"249":1,"582":1,"724":1,"760":1}}],["provers",{"2":{"205":1,"206":1,"584":1}}],["prover=network",{"2":{"584":1}}],["prover=local",{"2":{"584":1}}],["prover=",{"2":{"202":2}}],["prover",{"0":{"205":1,"207":1,"211":1},"2":{"202":7,"205":1,"206":2,"207":3,"208":2,"211":7,"212":1,"228":1,"584":1}}],["proven",{"2":{"180":1,"187":1,"216":1,"233":1}}],["proveshars`",{"2":{"163":2}}],["provesharesv2`",{"2":{"163":2}}],["provesharesv2",{"2":{"153":1}}],["proveshares",{"2":{"149":1,"151":1,"153":3,"163":2,"175":1}}],["proves",{"2":{"156":2,"221":1}}],["prove=true",{"2":{"147":1}}],["proved",{"2":{"127":1}}],["prove",{"2":{"121":1,"125":3,"128":1,"130":1,"137":1,"139":5,"141":1,"145":1,"147":1,"152":3,"154":2,"157":1,"159":1,"164":1,"165":1,"168":5,"174":2,"175":6,"178":1,"183":1,"188":1,"191":1,"211":3,"227":1,"578":1,"644":1,"649":1}}],["proofnonce",{"2":{"144":4,"161":2,"163":2}}],["proof",{"0":{"121":1,"137":1,"141":1,"145":1,"146":1,"149":1,"151":1,"161":1,"168":1,"173":1,"212":1,"674":1,"689":1},"1":{"138":1,"139":1,"142":1,"143":1,"147":1,"148":1,"150":1,"152":1,"153":1},"2":{"110":1,"118":12,"119":2,"120":1,"121":1,"122":5,"124":1,"127":5,"130":2,"132":1,"139":2,"140":1,"141":4,"142":4,"143":2,"144":14,"145":3,"146":1,"147":9,"148":2,"149":1,"151":5,"152":3,"154":9,"155":1,"156":12,"158":1,"159":14,"160":11,"163":40,"164":2,"168":6,"169":1,"170":1,"173":1,"174":6,"175":11,"179":1,"182":1,"183":3,"187":3,"188":2,"191":3,"194":5,"197":1,"199":3,"202":4,"205":1,"206":1,"208":2,"210":2,"211":1,"214":3,"216":1,"217":1,"218":2,"219":3,"224":1,"227":4,"238":1,"281":1,"581":3,"632":2,"641":1,"644":1,"650":1,"651":1,"674":3,"681":1,"689":2}}],["proofs",{"0":{"122":1,"135":1,"154":1,"169":1,"194":1,"195":1,"196":1,"218":1,"219":1,"643":1},"1":{"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"154":1,"155":2,"156":2,"157":2,"158":2,"159":2,"160":2,"161":2,"162":2,"163":2,"164":1,"195":1,"196":1},"2":{"110":1,"121":1,"122":2,"127":1,"136":1,"137":1,"139":1,"140":1,"145":1,"147":6,"151":4,"152":4,"154":4,"156":8,"159":10,"162":1,"163":15,"164":1,"168":9,"169":5,"171":1,"174":1,"175":5,"176":1,"178":1,"179":3,"180":1,"182":2,"183":4,"185":1,"186":1,"190":1,"191":1,"194":3,"196":1,"202":1,"203":1,"205":1,"206":3,"208":1,"211":6,"212":1,"213":2,"215":3,"216":1,"217":2,"221":1,"227":2,"229":1,"233":2,"234":1,"235":1,"236":1,"415":2,"427":1,"581":1,"631":1,"632":1,"641":1,"643":2,"644":1,"647":1,"650":1}}],["procedure",{"2":{"252":1,"737":1}}],["proceeding",{"2":{"87":1,"130":1,"428":1}}],["proceed",{"2":{"79":1,"86":2,"164":1,"191":1,"194":1,"448":1,"665":1,"695":1}}],["processing",{"2":{"582":1}}],["processed",{"2":{"577":1,"607":1}}],["processes",{"2":{"238":1,"427":1,"600":1,"602":1,"608":1,"638":1,"772":2}}],["process",{"0":{"19":1,"21":1,"28":1,"524":1,"526":1,"600":1},"1":{"20":1,"21":1,"22":1,"23":1,"24":1,"525":1,"526":1,"527":2,"528":2,"529":2,"530":2,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1},"2":{"21":1,"30":1,"41":1,"73":1,"81":1,"86":1,"112":1,"127":1,"130":3,"162":2,"186":1,"187":1,"227":1,"238":3,"248":1,"255":1,"321":1,"329":1,"373":1,"404":1,"425":1,"455":1,"470":1,"482":1,"498":1,"513":1,"523":1,"524":1,"526":1,"554":1,"577":1,"601":1,"606":1,"619":1,"632":1,"647":1,"695":1,"763":1,"773":2}}],["proto",{"2":{"163":2,"597":2}}],["protobuf",{"0":{"191":1},"2":{"140":4,"169":2,"170":1,"171":1,"183":2,"190":1,"191":2,"193":1,"194":2}}],["protocol",{"2":{"23":1,"37":1,"107":1,"126":1,"227":1,"233":1,"313":1,"320":1,"326":1,"427":1,"525":2,"526":1,"528":2,"588":1,"674":1,"679":1,"707":1,"776":1}}],["protection",{"2":{"724":1}}],["protect",{"2":{"24":1,"91":1,"724":1}}],["prohibited",{"2":{"23":1,"328":1}}],["prometheuslistenaddr",{"2":{"274":2}}],["prometheus",{"2":{"274":9,"275":17,"276":1,"321":1,"428":1}}],["prompts",{"2":{"774":1}}],["promptanswer",{"2":{"773":2}}],["prompting",{"0":{"772":1},"2":{"773":1}}],["prompt",{"0":{"763":1,"767":1},"1":{"764":1,"765":1,"766":1,"767":1,"768":2,"769":2,"770":2,"771":2,"772":2,"773":2,"774":1},"2":{"87":1,"727":1,"763":1,"768":2,"769":2,"770":8,"771":13,"772":2,"773":14}}],["prompted",{"2":{"85":1,"263":2,"556":1,"620":1}}],["promptly",{"2":{"10":1,"109":1}}],["prominent",{"2":{"58":1}}],["promote",{"2":{"36":1,"39":2,"40":3,"58":1,"582":1}}],["promotions",{"2":{"31":1}}],["promotional",{"2":{"30":1,"31":1}}],["promoting",{"2":{"18":1}}],["profileecho",{"2":{"399":1}}],["profile",{"2":{"399":3}}],["proficient",{"2":{"18":1}}],["professionals",{"2":{"40":1}}],["professional",{"2":{"7":1,"672":2}}],["primitive",{"2":{"629":1,"648":1}}],["primitives",{"2":{"627":1}}],["primarily",{"2":{"86":2,"722":1}}],["primary",{"2":{"18":1,"49":1,"112":1,"322":1}}],["priv",{"2":{"625":1}}],["privacy",{"2":{"10":1,"58":1}}],["privatecelestia",{"2":{"742":1}}],["privatekey",{"2":{"544":10}}],["private",{"0":{"742":1},"2":{"7":2,"12":1,"14":1,"26":1,"34":1,"86":2,"88":1,"93":2,"118":4,"202":10,"203":4,"204":8,"210":4,"211":2,"260":2,"263":4,"279":2,"289":1,"294":6,"328":1,"336":4,"582":1,"699":1,"742":7}}],["pricing",{"2":{"226":1}}],["priced",{"2":{"587":1}}],["price",{"0":{"746":1},"2":{"91":3,"429":8,"586":1,"588":4,"590":3,"597":2,"669":1,"708":3,"746":10,"771":2,"777":3}}],["prices",{"2":{"7":1,"587":1}}],["printf",{"2":{"596":4,"708":4,"709":2,"710":4,"771":6,"773":4}}],["printed",{"2":{"202":1,"210":1}}],["println",{"2":{"143":8,"144":6,"162":2,"163":2,"597":6,"777":2,"778":2}}],["print",{"2":{"30":1,"260":2}}],["priority",{"2":{"752":4}}],["prioritised",{"2":{"669":2}}],["prioritized",{"2":{"587":2}}],["prior",{"2":{"25":1,"30":1,"39":1,"279":2,"524":1}}],["pr",{"2":{"2":1}}],["n11",{"2":{"644":2}}],["n12",{"2":{"644":2}}],["n14",{"2":{"644":1}}],["n7",{"2":{"644":1}}],["n8",{"2":{"644":1}}],["n2",{"2":{"642":1,"643":1,"644":1}}],["nft",{"2":{"633":1}}],["nfts",{"2":{"37":1}}],["nsoy0rgl7hqt4vwlg441gqkjsz2fbunzxipgns8ov",{"2":{"705":2}}],["ns",{"2":{"597":6,"771":2}}],["ncdu",{"2":{"398":4}}],["ncreated",{"2":{"383":2,"625":2}}],["ntfs",{"2":{"396":1}}],["npanic",{"2":{"383":2,"625":2}}],["np5wre24w+e79",{"2":{"147":2}}],["ngithub",{"2":{"383":12,"625":12}}],["nruntime",{"2":{"383":2,"625":2}}],["nw",{"2":{"280":1}}],["n",{"2":{"271":2,"294":2,"313":1,"326":1,"338":2,"361":12,"383":20,"596":4,"620":2,"625":20,"634":1,"642":1,"643":2,"708":4,"709":2,"710":4,"771":6,"773":4}}],["nvme",{"2":{"239":1,"416":1,"533":2}}],["nyzlbfjjnskofrzur8xvjijla+wbptwm0kbyglilxlg=",{"2":{"142":2}}],["nmbwwwhpiphwagai7maqm",{"2":{"142":2}}],["nmts",{"0":{"644":1},"2":{"640":2,"644":2,"649":1,"731":1}}],["nmtproof",{"2":{"156":2,"163":2}}],["nmt",{"2":{"139":2,"151":2,"154":2,"644":2,"777":2}}],["nidstring",{"2":{"771":4}}],["nil",{"2":{"128":10,"130":6,"136":6,"143":6,"144":36,"148":4,"150":8,"153":2,"161":14,"162":12,"163":12,"596":12,"597":16,"708":12,"709":8,"710":10,"711":8,"770":2,"771":22,"772":4,"773":10}}],["nitro",{"0":{"112":1},"2":{"92":1,"96":4,"104":4,"107":1,"108":2,"109":3,"110":2,"112":2,"400":1}}],["nice",{"2":{"34":1}}],["null",{"2":{"294":4,"295":2,"297":4,"380":1,"602":2,"604":2,"605":2,"606":2,"614":2,"620":2}}],["nutshell",{"2":{"139":1}}],["numerous",{"2":{"628":1,"647":1}}],["numerator",{"2":{"429":4}}],["num",{"2":{"429":4}}],["numleaves",{"2":{"159":3,"175":2}}],["numia",{"2":{"64":4,"485":4,"487":1,"488":1,"489":1,"493":1,"503":4,"505":1,"506":1,"508":1}}],["number=26656",{"2":{"452":1}}],["number=26656ip",{"2":{"452":1}}],["numbers",{"0":{"62":1,"481":1,"501":1}}],["number",{"2":{"30":1,"36":1,"86":2,"93":8,"159":2,"165":1,"172":1,"174":2,"210":1,"221":1,"274":4,"276":1,"295":2,"296":2,"337":1,"452":2,"483":1,"526":1,"528":1,"536":2,"581":1,"589":3,"590":1,"592":1,"597":2,"631":1,"642":1,"648":2,"650":2}}],["nurturing",{"2":{"47":1}}],["never",{"2":{"557":10}}],["neither",{"2":{"331":1,"646":1}}],["necessitate",{"2":{"321":1}}],["necessity",{"2":{"320":1}}],["necessary",{"0":{"632":1},"2":{"24":1,"30":1,"34":3,"88":1,"90":1,"109":2,"110":1,"154":4,"160":2,"174":1,"183":1,"210":3,"225":1,"378":1,"398":1,"429":1,"540":1,"581":1,"607":1,"620":2,"631":1,"646":1,"650":1,"739":1}}],["netcelestia",{"2":{"466":1,"735":1}}],["net",{"2":{"291":2,"466":1,"487":2,"488":2,"489":2,"490":1,"493":2,"496":1,"497":1,"505":1,"506":1,"507":1,"508":1,"512":1,"735":1}}],["network=$network",{"2":{"390":6,"392":6,"393":6}}],["network=arabica",{"2":{"390":1,"516":2}}],["network=arabicaexport",{"2":{"390":1}}],["network=mochacelestia",{"2":{"408":1}}],["network=mocha",{"2":{"390":1,"408":1,"704":2}}],["network=mochaexport",{"2":{"390":1}}],["network=celestia",{"2":{"390":1}}],["network=celestiaexport",{"2":{"390":1}}],["network=custom",{"2":{"314":2}}],["network=",{"2":{"314":2}}],["networking",{"2":{"31":1,"35":1,"42":2}}],["networks",{"0":{"314":1,"361":1,"546":1},"1":{"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1},"2":{"26":1,"86":1,"126":1,"272":1,"324":1,"325":1,"328":1,"361":9,"371":2,"427":1,"432":1,"434":1,"452":1,"459":1,"467":1,"493":1,"499":1,"524":1,"531":1,"571":1,"620":1,"621":1,"640":1,"689":1,"781":1}}],["network",{"0":{"60":1,"61":1,"73":1,"272":1,"324":1,"375":1,"439":1,"453":1,"479":1,"480":1,"482":1,"498":1,"500":1,"513":1,"524":1,"525":1,"528":1,"530":1,"554":1,"655":1,"677":1,"742":1,"782":1},"1":{"62":1,"325":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"483":1,"525":1,"526":1,"527":1,"528":1,"529":1,"530":1},"2":{"18":2,"24":1,"37":1,"38":1,"60":1,"63":1,"67":1,"68":3,"73":3,"81":1,"85":2,"86":2,"90":3,"91":4,"93":6,"104":2,"126":1,"130":2,"140":2,"154":2,"227":1,"231":1,"238":5,"244":4,"245":9,"246":4,"248":1,"272":1,"280":1,"281":1,"282":1,"284":1,"289":1,"303":2,"304":1,"311":2,"314":8,"316":4,"318":2,"319":2,"320":8,"322":1,"324":10,"325":6,"328":2,"329":6,"334":8,"335":6,"336":10,"338":10,"341":1,"352":1,"361":1,"371":1,"373":1,"377":2,"383":3,"390":7,"392":6,"393":6,"399":1,"407":2,"421":4,"422":5,"423":4,"439":1,"445":1,"449":1,"454":1,"455":1,"458":1,"464":4,"465":6,"466":12,"468":4,"475":4,"476":4,"478":2,"479":2,"482":1,"484":1,"492":1,"493":2,"498":3,"499":2,"504":1,"505":1,"506":1,"509":1,"513":3,"521":2,"524":6,"525":2,"528":1,"530":3,"531":4,"544":1,"547":2,"552":2,"554":3,"555":1,"557":4,"559":6,"562":3,"563":1,"565":2,"569":1,"578":1,"581":1,"584":1,"596":4,"607":2,"610":1,"615":2,"619":1,"620":2,"625":4,"627":1,"636":1,"641":1,"642":1,"646":1,"647":3,"648":2,"650":4,"651":1,"655":1,"659":1,"665":1,"671":2,"672":3,"674":1,"677":1,"681":3,"687":2,"689":2,"690":1,"698":20,"699":12,"700":12,"704":3,"705":3,"708":4,"713":1,"726":1,"730":1,"734":4,"735":8,"736":13,"740":8,"742":8,"743":2,"760":3,"765":4,"769":2,"770":2,"771":10,"773":2,"777":4,"781":1,"782":4}}],["nearby",{"2":{"39":1}}],["needing",{"2":{"180":1,"294":1,"302":1,"303":1,"629":1,"640":1,"672":1}}],["need",{"2":{"41":1,"57":1,"67":1,"68":1,"84":1,"86":1,"88":1,"91":2,"109":2,"110":1,"126":5,"127":1,"136":1,"141":1,"142":1,"145":1,"147":1,"152":1,"168":1,"170":1,"175":2,"180":1,"183":2,"185":1,"187":1,"190":2,"193":1,"194":1,"201":1,"202":1,"208":1,"235":2,"245":2,"247":1,"275":4,"279":2,"290":1,"299":1,"301":2,"304":1,"307":1,"313":2,"316":1,"320":1,"325":1,"326":2,"328":1,"329":1,"337":1,"338":1,"352":1,"353":1,"363":1,"371":2,"373":1,"377":1,"378":1,"380":1,"383":1,"391":2,"392":1,"404":1,"405":1,"406":1,"422":2,"424":1,"430":2,"434":1,"435":1,"440":1,"441":1,"442":1,"446":1,"448":1,"449":1,"466":1,"469":1,"492":1,"493":1,"504":1,"505":1,"523":1,"524":1,"528":1,"543":1,"544":1,"552":1,"556":1,"558":1,"580":2,"581":1,"584":2,"614":1,"620":1,"625":1,"632":1,"642":1,"643":1,"672":1,"688":1,"697":1,"698":1,"704":1,"707":1,"736":2,"737":1,"738":1,"739":1,"740":1,"742":1,"760":1,"769":1,"770":2,"771":2,"772":1,"776":1,"782":2}}],["needs",{"2":{"38":1,"41":1,"42":1,"166":1,"168":1,"183":1,"199":1,"217":1,"234":1,"542":1,"581":1,"634":1,"644":1}}],["needed",{"2":{"30":1,"31":1,"34":1,"37":1,"88":1,"91":1,"109":1,"125":1,"136":1,"154":2,"160":2,"175":2,"210":1,"215":2,"275":1,"278":1,"350":1,"355":1,"373":1,"589":1,"590":1,"605":1,"620":1,"631":1,"632":1,"633":1,"646":1,"764":1,"766":1,"771":1}}],["negatives",{"2":{"650":1}}],["negatively",{"2":{"26":1,"38":1}}],["negotiate",{"2":{"34":1}}],["nextheaderfunctionid",{"2":{"218":1}}],["nextheight",{"2":{"130":4}}],["next",{"0":{"113":1,"259":1,"289":1,"344":1,"457":1,"571":1,"774":1},"2":{"32":1,"85":2,"86":1,"90":1,"94":1,"108":1,"109":1,"113":1,"122":1,"130":2,"142":1,"144":2,"147":1,"152":1,"161":2,"171":1,"202":1,"204":2,"210":4,"211":5,"215":2,"218":1,"229":1,"272":1,"275":1,"286":1,"297":6,"329":1,"446":1,"525":1,"571":1,"599":1,"648":1,"649":2,"704":1,"736":1,"743":1,"752":2,"770":2,"771":7,"773":2,"778":2}}],["newsubmitoptions",{"2":{"708":4}}],["newsletters",{"2":{"32":1}}],["newcredentials",{"2":{"597":2}}],["newclient",{"2":{"596":2,"708":2,"709":2,"710":2,"711":2,"770":2,"771":2,"772":2,"773":2}}],["newblob",{"2":{"597":2}}],["newblobv0",{"2":{"596":2,"708":3,"771":2}}],["newblobnamespacev0",{"2":{"596":2,"708":3,"709":2,"710":2,"771":2}}],["newblobstreamxfilterer",{"2":{"162":2}}],["newblobstreamx",{"2":{"144":2,"161":2}}],["newer",{"2":{"266":1}}],["newwrappers",{"2":{"163":2}}],["newint",{"2":{"144":8,"156":4,"159":4,"160":8,"163":16}}],["newly",{"2":{"93":1,"435":1,"628":1}}],["newmetric",{"2":{"64":2,"485":2,"488":1,"489":1,"503":2,"505":1,"506":1,"508":1}}],["new",{"0":{"162":1,"200":1,"202":1,"272":1,"291":1,"434":1,"446":1,"449":1,"521":1,"583":1,"688":1,"709":1,"710":1,"778":1},"1":{"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"584":1},"2":{"2":2,"22":2,"23":2,"25":1,"36":1,"37":1,"41":3,"42":1,"90":1,"125":1,"136":2,"143":2,"144":4,"152":1,"153":1,"161":2,"162":3,"163":2,"200":1,"201":1,"208":1,"212":1,"227":2,"228":1,"247":1,"262":2,"275":1,"281":1,"289":1,"299":1,"329":1,"334":2,"352":1,"361":1,"379":1,"380":1,"381":1,"383":1,"424":1,"427":1,"432":3,"433":1,"434":3,"435":1,"439":2,"444":1,"446":1,"449":1,"450":1,"453":1,"459":1,"469":1,"476":1,"520":1,"524":1,"526":3,"528":2,"550":1,"557":3,"580":2,"581":2,"582":1,"583":1,"584":1,"592":1,"607":1,"625":1,"627":2,"628":1,"629":2,"635":1,"648":1,"654":1,"670":1,"672":2,"709":4,"710":11,"763":1,"765":2,"768":1,"771":4,"772":1,"774":1,"777":8,"778":9,"779":2,"783":3,"784":1}}],["novel",{"2":{"640":1}}],["nor",{"2":{"331":1,"646":1}}],["normal",{"2":{"130":3,"164":1,"371":1,"589":1,"627":1}}],["normally",{"2":{"34":1}}],["now",{"2":{"87":1,"91":2,"94":1,"109":1,"163":2,"202":1,"204":1,"205":1,"211":1,"215":1,"259":1,"275":1,"289":2,"297":1,"344":1,"384":1,"390":1,"391":1,"393":1,"406":2,"408":1,"425":1,"429":1,"430":1,"434":1,"435":1,"450":1,"452":1,"453":1,"455":1,"457":1,"493":1,"523":1,"536":1,"537":2,"545":1,"561":1,"562":1,"605":1,"606":1,"620":3,"636":1,"671":1,"704":1,"705":1,"734":1,"735":1,"752":1,"765":2,"771":4,"773":4,"782":1,"783":1,"784":1}}],["none",{"2":{"177":1,"181":1,"189":1,"192":1,"195":1,"434":4,"739":1}}],["nonce",{"2":{"118":4,"120":1,"144":4,"154":4,"160":10,"161":2,"163":6,"400":1,"536":2,"537":2,"592":2,"597":2}}],["non",{"2":{"23":1,"27":1,"109":2,"127":1,"294":2,"328":1,"438":1,"524":2,"528":1,"544":1,"677":1,"741":1}}],["no",{"0":{"638":1},"2":{"13":1,"14":1,"22":1,"34":1,"68":1,"69":1,"117":2,"171":1,"186":1,"250":1,"266":5,"277":1,"325":2,"333":3,"355":1,"403":1,"493":1,"510":1,"580":1,"586":1,"588":1,"627":1,"643":1,"650":1,"688":1,"693":1,"726":1,"746":1}}],["notfound",{"2":{"762":2}}],["notable",{"0":{"720":1},"2":{"631":1}}],["notably",{"2":{"589":1}}],["nothing",{"2":{"367":3}}],["notify",{"2":{"459":1}}],["notification",{"2":{"80":1}}],["notice",{"2":{"154":4,"156":6,"157":2,"159":2,"160":4,"295":1,"296":1,"534":1,"646":1,"743":1}}],["noted",{"2":{"443":1,"720":1}}],["notes",{"0":{"304":1,"609":1,"715":1},"1":{"716":1,"717":1,"718":1,"719":1,"720":1},"2":{"48":1,"369":1,"528":1,"671":1}}],["note",{"0":{"378":1},"2":{"26":1,"47":1,"70":1,"91":2,"104":1,"105":1,"110":1,"117":1,"125":1,"126":3,"128":1,"130":2,"140":1,"142":1,"147":1,"151":1,"152":1,"163":2,"164":1,"166":1,"168":1,"172":1,"174":1,"204":1,"214":1,"215":1,"216":1,"218":1,"221":1,"227":1,"233":2,"234":1,"245":1,"266":1,"275":1,"279":2,"283":1,"287":1,"294":1,"302":1,"307":1,"316":1,"324":2,"331":1,"337":1,"343":1,"367":1,"387":1,"407":1,"422":1,"430":1,"449":1,"452":1,"483":1,"510":1,"539":1,"558":1,"584":1,"589":2,"597":2,"605":1,"644":1,"647":1,"649":2,"650":1,"680":1,"698":1,"735":1,"738":1}}],["not",{"2":{"7":1,"8":1,"22":1,"23":7,"26":1,"34":1,"35":2,"58":1,"59":1,"65":1,"68":2,"69":1,"86":2,"90":2,"91":1,"93":2,"96":1,"110":1,"112":1,"117":1,"124":2,"127":1,"128":1,"144":2,"145":1,"163":2,"168":1,"173":1,"174":1,"178":1,"179":1,"180":1,"183":2,"193":1,"199":1,"201":1,"202":3,"208":1,"210":5,"211":2,"215":2,"227":1,"234":1,"244":1,"245":1,"266":1,"275":1,"281":1,"287":1,"304":1,"307":1,"314":1,"322":6,"324":1,"325":1,"334":1,"338":1,"343":1,"355":2,"368":1,"371":1,"378":1,"381":2,"383":1,"396":1,"399":1,"400":1,"407":2,"408":2,"409":1,"414":1,"422":1,"426":1,"430":1,"485":1,"487":1,"493":1,"503":1,"505":1,"507":1,"510":1,"524":1,"528":2,"531":1,"550":1,"558":1,"588":3,"589":1,"590":1,"592":3,"597":2,"607":3,"608":1,"609":1,"615":2,"625":1,"631":1,"632":1,"637":1,"643":2,"649":1,"650":2,"670":1,"671":2,"672":2,"677":1,"698":2,"704":1,"706":1,"717":1,"718":1,"720":1,"731":1,"733":1,"735":1,"736":1,"737":1,"740":3,"746":1,"762":2,"772":2,"775":1}}],["nodeclient",{"2":{"770":2,"771":4,"773":2}}],["nodeconfig",{"2":{"88":1,"89":1,"90":1,"91":1,"104":2}}],["nodeip",{"2":{"770":4,"771":4,"773":6}}],["nodebuilder",{"2":{"334":6}}],["nodessection",{"2":{"623":1}}],["nodestake",{"2":{"487":1,"488":1,"489":1,"496":1,"512":1}}],["nodes",{"0":{"66":1,"238":1,"374":1,"386":1,"415":1,"459":1,"486":1,"491":1,"502":1,"531":1,"533":1,"534":1,"601":1,"603":1,"629":1},"1":{"67":1,"68":1,"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"487":1,"488":1,"489":1,"490":1,"492":1,"493":1,"494":1,"495":1,"503":1,"504":1,"505":1,"532":1,"533":1,"534":1,"602":1,"604":1,"605":1,"606":1},"2":{"54":1,"65":3,"67":1,"68":2,"87":1,"121":1,"125":2,"126":1,"147":2,"152":2,"156":8,"159":2,"163":4,"179":1,"183":1,"237":1,"238":4,"275":2,"310":1,"313":3,"321":1,"322":3,"326":3,"328":1,"335":1,"339":1,"352":1,"353":1,"355":2,"356":1,"361":3,"376":1,"384":1,"397":1,"406":1,"415":5,"451":2,"459":3,"484":1,"487":1,"488":1,"489":1,"492":1,"493":4,"494":3,"499":1,"504":1,"505":2,"506":3,"507":2,"508":2,"509":1,"526":1,"552":1,"581":2,"592":1,"605":1,"610":1,"615":1,"627":1,"628":1,"629":2,"630":2,"631":5,"632":5,"634":1,"639":1,"640":1,"641":6,"642":6,"643":3,"644":3,"646":1,"647":3,"648":2,"650":5,"670":1,"671":8,"672":12,"714":1,"722":1,"726":1,"734":1}}],["node",{"0":{"54":1,"67":1,"91":1,"92":1,"102":1,"104":1,"105":1,"129":1,"133":1,"237":1,"240":1,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"276":1,"302":1,"315":1,"322":1,"327":1,"338":1,"340":1,"356":1,"358":1,"363":2,"373":1,"379":1,"384":1,"385":1,"387":1,"391":1,"392":1,"393":1,"405":1,"406":1,"408":1,"414":1,"417":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"452":1,"458":1,"461":1,"462":1,"463":1,"464":1,"465":1,"468":1,"469":1,"470":1,"474":1,"475":1,"476":1,"492":1,"504":1,"509":1,"516":1,"532":1,"542":1,"556":1,"557":1,"559":1,"560":1,"561":1,"569":1,"594":1,"595":2,"596":1,"597":1,"598":1,"600":1,"604":1,"605":1,"606":1,"610":1,"612":1,"615":1,"616":1,"617":1,"618":1,"619":1,"620":1,"671":1,"695":1,"698":1,"699":1,"700":1,"704":1,"721":1,"728":1,"734":1,"741":1,"750":1,"765":2},"1":{"103":1,"104":1,"105":1,"130":1,"131":1,"132":1,"133":1,"134":1,"238":1,"239":1,"240":1,"241":2,"242":1,"243":2,"244":2,"245":2,"246":3,"247":3,"248":2,"316":1,"317":1,"318":1,"319":1,"320":1,"321":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"339":1,"341":1,"342":1,"343":1,"344":1,"345":1,"357":1,"358":1,"359":2,"360":2,"361":2,"362":1,"363":1,"364":3,"365":3,"366":1,"367":1,"368":1,"369":1,"370":1,"371":1,"372":1,"373":1,"374":1,"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"382":1,"383":1,"385":1,"386":2,"387":1,"392":1,"393":1,"406":1,"407":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":2,"421":3,"422":3,"423":2,"424":3,"425":2,"426":2,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":2,"467":2,"468":2,"469":3,"470":2,"471":1,"557":1,"558":2,"559":1,"561":1,"562":1,"563":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1,"611":1,"612":1,"613":2,"614":2,"615":1,"616":2,"617":2,"618":2,"619":3,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"722":1,"723":1,"724":1,"725":1,"726":1,"727":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":1,"741":1,"742":2,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1},"2":{"3":2,"23":2,"24":1,"26":2,"27":1,"42":1,"54":6,"63":3,"65":3,"67":2,"68":7,"82":1,"87":1,"88":1,"90":4,"91":10,"92":1,"93":1,"94":1,"96":3,"104":3,"105":3,"109":6,"110":1,"112":1,"126":13,"130":1,"133":1,"136":5,"137":1,"156":16,"163":12,"168":1,"237":1,"238":4,"239":1,"243":3,"244":4,"245":8,"246":2,"247":3,"248":2,"260":4,"265":12,"271":6,"274":1,"275":1,"276":1,"277":1,"279":4,"280":1,"286":3,"287":2,"298":1,"299":1,"301":3,"302":2,"303":3,"307":1,"309":1,"311":1,"312":1,"313":5,"314":6,"315":4,"316":6,"317":2,"318":2,"319":2,"320":4,"321":3,"322":11,"324":5,"325":1,"326":5,"328":7,"329":26,"331":4,"332":3,"333":1,"334":6,"335":2,"336":6,"337":1,"338":5,"341":17,"342":3,"343":7,"344":6,"345":1,"347":1,"349":4,"350":1,"352":1,"355":7,"356":1,"357":1,"361":10,"363":3,"367":1,"369":1,"370":1,"371":3,"372":2,"373":2,"376":1,"378":1,"380":1,"383":2,"385":2,"386":2,"387":3,"388":7,"390":30,"391":5,"392":27,"393":30,"396":1,"398":1,"399":2,"402":1,"403":3,"404":6,"405":1,"406":2,"407":1,"408":3,"409":2,"412":3,"413":2,"414":3,"416":1,"419":1,"422":12,"423":2,"424":3,"425":2,"426":2,"429":4,"445":1,"449":1,"452":7,"453":2,"455":2,"458":1,"460":1,"461":1,"463":1,"464":2,"465":6,"466":9,"468":2,"469":3,"470":1,"471":1,"472":3,"473":1,"474":3,"475":7,"476":9,"477":10,"479":1,"483":1,"484":3,"485":1,"486":2,"491":3,"492":2,"493":5,"499":10,"503":1,"504":2,"505":4,"506":1,"507":1,"508":1,"509":4,"515":2,"516":3,"521":2,"522":1,"524":1,"531":11,"533":4,"534":2,"538":2,"541":1,"542":4,"555":2,"556":7,"557":6,"558":3,"559":12,"561":2,"563":1,"564":1,"565":1,"566":3,"567":1,"568":1,"569":7,"571":1,"581":1,"588":3,"591":1,"595":1,"596":3,"597":6,"598":1,"601":1,"602":1,"604":2,"605":4,"606":6,"607":1,"610":1,"611":1,"612":1,"615":5,"616":1,"617":2,"619":2,"620":2,"621":2,"623":1,"625":5,"627":3,"630":2,"631":4,"633":1,"641":1,"642":2,"644":1,"650":8,"671":3,"672":3,"679":1,"695":1,"696":2,"697":5,"698":10,"699":6,"700":6,"703":1,"704":15,"705":9,"706":1,"707":3,"708":3,"717":2,"720":1,"721":2,"722":1,"723":1,"724":1,"725":2,"728":1,"731":1,"732":1,"733":1,"734":4,"735":3,"736":9,"737":2,"738":7,"739":6,"740":6,"741":10,"742":8,"743":7,"745":3,"748":2,"749":1,"750":2,"751":1,"756":3,"760":7,"763":2,"764":1,"765":8,"769":2,"770":3,"771":2,"774":1,"775":1,"776":3,"777":1}}],["navigating",{"2":{"208":1}}],["navigate",{"2":{"90":1,"474":1,"599":1,"654":1,"659":1,"663":1}}],["named",{"2":{"311":1,"312":1,"342":1,"515":1,"542":1}}],["name=$",{"2":{"372":6}}],["name=",{"2":{"279":2}}],["name=validator",{"2":{"272":2,"446":2}}],["name=validator1",{"2":{"272":2,"445":2}}],["namekey",{"2":{"272":1}}],["namevalidator",{"2":{"272":1}}],["names",{"2":{"215":1,"704":2,"705":2}}],["namespacebytes",{"2":{"771":2}}],["namespacehex",{"2":{"770":2,"771":4,"773":4}}],["namespaced",{"0":{"644":1},"2":{"640":1,"644":1,"646":1,"649":3,"731":1}}],["namespaceid",{"2":{"157":5,"163":8,"771":14,"773":8}}],["namespacenode",{"2":{"154":2,"156":12,"158":4,"163":10}}],["namespacemerklemultiproof",{"2":{"154":2,"156":10,"163":6}}],["namespaces",{"0":{"731":1},"2":{"147":2,"174":1,"562":1,"644":3,"649":1,"671":1,"672":1,"708":2,"731":1,"777":2}}],["namespace",{"0":{"157":1},"2":{"91":8,"93":1,"109":2,"125":8,"128":4,"139":2,"145":2,"147":4,"152":4,"154":6,"156":31,"157":21,"163":16,"175":2,"250":1,"274":4,"331":1,"332":2,"538":1,"562":5,"563":7,"594":2,"595":2,"596":10,"597":6,"599":2,"644":6,"649":5,"668":3,"672":1,"708":11,"709":6,"710":11,"728":1,"743":7,"745":12,"753":2,"758":3,"760":2,"769":2,"770":6,"771":23,"773":10,"774":2,"777":16,"778":13}}],["name",{"0":{"516":1,"517":1,"518":1},"1":{"518":1,"519":1},"2":{"26":1,"30":1,"77":1,"86":2,"202":2,"211":2,"246":7,"262":8,"263":4,"272":8,"275":6,"291":2,"292":4,"308":2,"314":2,"361":7,"372":6,"391":2,"423":7,"429":4,"445":4,"446":4,"447":4,"449":3,"466":2,"468":7,"515":1,"516":1,"518":3,"557":2,"562":1,"581":1,"614":2,"620":2,"698":7,"699":6,"700":6,"704":2,"705":2,"736":8,"765":2,"783":1,"784":1}}],["naming",{"2":{"2":1,"41":3}}],["natural",{"2":{"637":1}}],["nature",{"2":{"12":1,"226":1,"267":1,"636":1,"640":1}}],["natively",{"2":{"86":1}}],["native",{"2":{"82":1,"84":1,"93":6,"95":1,"108":1,"430":1,"437":1,"438":1,"651":1,"687":1,"693":1,"783":1}}],["nationality",{"2":{"6":1}}],["natnet",{"2":{"57":1}}],["nat",{"2":{"30":1,"378":1}}],["icon",{"2":{"784":1}}],["icons",{"2":{"52":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=celestia",{"2":{"745":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=",{"2":{"743":2,"745":11,"746":2}}],["ignore",{"2":{"644":1}}],["ignition",{"2":{"214":16}}],["ibctransfer",{"2":{"715":1}}],["ibchost",{"2":{"715":1}}],["ibc",{"0":{"427":1},"1":{"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"427":3,"428":2,"429":4,"434":1,"437":4}}],["i++",{"2":{"128":2}}],["illustrate",{"2":{"124":1}}],["illustrations",{"2":{"52":1}}],["i",{"0":{"199":1},"2":{"119":1,"128":6,"144":4,"156":4,"158":4,"159":4,"160":5,"163":32,"174":2,"175":1,"187":1,"206":1,"217":1,"325":1,"361":10,"377":2,"378":2,"455":1,"459":1,"592":1,"641":3,"642":1,"643":4,"644":3,"646":2,"647":6,"649":3,"650":8}}],["io",{"2":{"72":1,"93":2,"156":2,"157":2,"280":1,"372":12,"390":6,"392":6,"393":6,"487":1,"488":1,"489":1,"496":3,"497":1,"506":1,"507":1,"508":1,"512":3,"682":1,"704":2,"771":2,"784":1}}],["ip=",{"2":{"605":2}}],["ip=consensus",{"2":{"516":2}}],["ip6",{"2":{"476":4,"750":4}}],["ip4",{"2":{"314":4,"476":13,"605":2,"750":8}}],["ip",{"2":{"65":1,"67":2,"68":6,"91":2,"244":11,"245":6,"246":6,"314":2,"316":2,"317":2,"318":2,"319":2,"320":4,"324":2,"329":2,"334":2,"338":2,"377":2,"390":6,"393":6,"407":2,"408":2,"422":3,"423":6,"451":4,"465":7,"466":6,"468":6,"475":4,"476":4,"492":2,"493":4,"504":2,"505":2,"559":3,"605":2,"606":2,"617":2,"704":2,"705":2,"735":14,"736":6,"760":2,"765":2,"770":2,"771":2,"773":2}}],["idvalidator",{"2":{"445":1}}],["id=$",{"2":{"452":2}}],["id=",{"2":{"279":2,"614":2,"620":2}}],["id=testnet",{"2":{"272":2,"445":2}}],["ids",{"2":{"204":1,"210":2,"314":1,"325":1}}],["idaoracle",{"2":{"117":1,"118":6,"120":1,"122":1,"163":6}}],["ide",{"2":{"769":1}}],["idea",{"2":{"578":1}}],["ideas",{"2":{"35":1}}],["ideally",{"2":{"37":1}}],["ideal",{"2":{"34":1,"251":1}}],["identically",{"2":{"124":1}}],["identifiers",{"2":{"235":2,"569":1,"644":1}}],["identifier",{"2":{"86":1,"118":2}}],["identify",{"2":{"35":1,"42":1,"109":1,"125":2,"644":1}}],["identifying",{"2":{"32":1}}],["identity",{"2":{"6":2,"569":1,"649":1,"668":1}}],["id",{"0":{"247":1,"325":1,"424":1,"469":1,"750":1},"2":{"26":3,"70":1,"86":2,"91":4,"125":1,"142":2,"147":4,"152":4,"156":19,"157":13,"163":12,"202":4,"204":3,"206":2,"207":2,"209":1,"210":3,"211":10,"218":4,"245":1,"247":1,"265":6,"266":14,"268":4,"269":8,"270":4,"272":8,"275":1,"279":20,"294":6,"301":3,"303":5,"314":5,"325":2,"361":6,"412":2,"422":1,"424":1,"429":4,"434":40,"445":5,"449":4,"452":4,"469":1,"475":2,"476":3,"477":2,"510":1,"530":1,"538":4,"540":1,"544":6,"557":1,"558":2,"614":1,"649":1,"698":1,"704":9,"705":10,"736":1,"745":1,"748":2,"749":2,"750":6,"751":2,"752":10,"760":4,"769":2,"770":2,"771":2,"783":1}}],["ifconfig",{"2":{"452":2}}],["if",{"0":{"638":1},"2":{"4":1,"23":3,"24":1,"25":1,"26":5,"30":2,"31":1,"34":3,"35":1,"36":2,"37":1,"38":2,"39":1,"40":2,"41":3,"42":3,"59":1,"60":1,"81":2,"91":4,"105":1,"109":3,"112":2,"117":1,"125":1,"126":1,"127":1,"128":8,"130":10,"139":2,"148":4,"151":1,"154":4,"155":2,"156":1,"160":1,"162":6,"163":4,"168":1,"169":1,"170":1,"172":1,"174":3,"178":1,"179":2,"180":1,"183":1,"185":1,"191":1,"197":1,"199":1,"201":1,"202":12,"205":1,"208":1,"210":2,"215":6,"216":1,"217":1,"225":1,"227":1,"234":1,"244":2,"245":1,"266":1,"271":1,"274":3,"275":3,"277":1,"281":3,"283":1,"288":1,"291":2,"294":2,"301":1,"303":1,"309":2,"311":1,"313":2,"314":1,"320":1,"324":1,"326":3,"329":1,"334":1,"336":1,"339":1,"341":1,"342":1,"343":2,"344":2,"345":1,"352":2,"355":2,"361":3,"363":1,"367":1,"368":2,"371":2,"373":3,"380":1,"383":1,"387":1,"388":2,"390":1,"391":1,"398":1,"399":1,"407":1,"422":1,"425":1,"431":1,"432":2,"433":1,"438":1,"439":2,"443":1,"444":1,"448":1,"449":2,"505":1,"507":1,"534":1,"540":2,"543":1,"544":2,"556":1,"558":1,"559":1,"566":1,"567":1,"568":1,"570":1,"572":1,"578":1,"581":2,"584":1,"586":2,"588":1,"589":2,"591":1,"592":4,"597":26,"601":1,"602":3,"604":1,"605":1,"606":2,"607":1,"608":1,"609":1,"614":3,"615":1,"620":3,"625":2,"627":1,"629":1,"631":1,"632":1,"641":1,"643":2,"644":1,"650":3,"693":1,"698":2,"706":1,"707":1,"726":1,"731":3,"733":1,"735":3,"736":1,"737":1,"739":2,"740":2,"741":1,"742":1,"743":2,"746":2,"755":1,"761":1,"762":1,"763":1,"765":2,"769":1,"771":1,"772":2,"774":1,"775":1,"776":1,"782":8,"783":1}}],["inherently",{"2":{"670":1}}],["inherit",{"2":{"580":1}}],["inherits",{"2":{"278":1}}],["inheriting",{"2":{"221":1}}],["inability",{"2":{"634":1}}],["inappropriate",{"2":{"7":1,"8":1,"12":2,"14":1,"15":1}}],["innovative",{"2":{"581":1}}],["innernode",{"2":{"156":12,"163":12}}],["ini",{"2":{"337":1}}],["initiatives",{"2":{"678":1,"679":2,"680":1}}],["initialisation",{"2":{"324":1,"352":1}}],["initialise",{"2":{"68":1,"493":1}}],["initialization",{"2":{"322":1,"349":1,"355":1,"515":1}}],["initializing",{"2":{"208":1,"244":1,"557":1,"734":1,"765":1}}],["initialize",{"0":{"244":1,"392":1,"421":1,"445":1,"464":1,"557":1,"617":1,"768":1},"1":{"558":1},"2":{"117":1,"260":2,"334":1,"336":1,"338":1,"355":1,"361":1,"392":1,"404":1,"475":1,"476":1,"569":1,"580":1,"617":1,"742":2,"768":1,"769":2,"770":3,"771":2}}],["initializedinfo\\tnode\\tnodebuilder",{"2":{"557":1}}],["initialized",{"2":{"87":1,"117":1,"136":1,"347":1,"437":1,"444":1,"464":1,"557":1,"559":1,"566":1}}],["initial",{"2":{"22":1,"86":1,"266":2,"647":2,"674":1,"679":1,"680":1}}],["initcelestia",{"2":{"421":1,"464":1,"734":1,"742":1}}],["init",{"2":{"117":1,"244":8,"260":2,"272":2,"324":3,"329":3,"336":4,"338":2,"361":6,"392":9,"421":5,"445":2,"464":5,"475":2,"476":2,"557":16,"617":2,"734":5,"742":5,"765":6,"768":2}}],["initgit",{"2":{"117":1}}],["inputting",{"2":{"614":1,"620":1}}],["input=$",{"2":{"537":2}}],["input=3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"537":2}}],["inputs",{"2":{"118":2,"519":1}}],["input",{"0":{"411":1},"2":{"118":2,"187":3,"191":2,"194":2,"203":1,"316":1,"411":3,"523":1,"537":4,"538":2,"599":1}}],["inbox",{"2":{"100":1,"101":1,"110":1}}],["indeed",{"2":{"640":1,"649":1,"650":1}}],["independently",{"2":{"226":1,"647":1}}],["indexing",{"0":{"364":1},"2":{"322":1,"363":1,"366":1,"380":1,"633":1}}],["index`",{"2":{"202":2}}],["index",{"2":{"125":2,"142":2,"144":2,"147":6,"150":8,"151":2,"152":2,"159":3,"160":2,"163":4,"172":1,"174":1,"175":3,"291":2,"322":4,"332":2,"380":2,"563":4,"622":1}}],["indexers",{"2":{"638":1}}],["indexer",{"0":{"380":1,"622":1},"2":{"364":1,"366":2,"380":3,"622":1}}],["indexed",{"2":{"120":1,"380":2,"569":1}}],["indexes",{"2":{"86":1}}],["induced",{"2":{"130":1}}],["industry",{"2":{"38":1}}],["indicates",{"2":{"337":1,"408":1,"760":1}}],["indicated",{"2":{"214":1}}],["indicators",{"2":{"32":1}}],["individual",{"2":{"9":1,"15":1,"26":1,"58":1,"122":1}}],["individuals",{"2":{"7":1,"15":1,"224":1}}],["infra",{"2":{"726":1}}],["infrastructure",{"2":{"23":2,"26":1,"42":1,"93":4,"321":1,"499":1,"552":1,"672":1,"679":1}}],["inflation",{"0":{"675":1},"2":{"675":3,"685":2}}],["infocelestia",{"2":{"750":1,"756":1}}],["infocurl",{"2":{"602":1}}],["info\\tnode\\tnodebuilder",{"2":{"557":10}}],["infos",{"2":{"294":2}}],["informed",{"2":{"498":1,"513":1,"554":1}}],["inform",{"2":{"109":1}}],["informative",{"2":{"42":1,"57":1,"58":1}}],["information$",{"2":{"260":1}}],["information",{"0":{"27":1,"621":1},"2":{"7":1,"36":1,"42":2,"81":2,"87":1,"88":1,"94":1,"105":1,"109":1,"111":1,"112":1,"125":2,"126":2,"127":2,"136":1,"139":1,"142":1,"147":1,"152":1,"163":1,"172":1,"174":1,"202":1,"210":1,"233":1,"234":1,"235":1,"244":1,"245":1,"258":1,"260":1,"266":1,"275":2,"277":1,"303":2,"309":1,"322":1,"324":1,"390":1,"422":3,"437":1,"453":1,"465":2,"569":1,"591":1,"597":2,"617":1,"633":2,"634":1,"636":1,"698":1,"704":2,"735":1,"736":1,"750":1,"752":1}}],["informalsystems",{"2":{"280":1}}],["informal",{"2":{"31":1}}],["info",{"0":{"45":1},"1":{"46":1,"47":1,"48":1,"49":1,"50":1},"2":{"26":1,"147":2,"294":4,"429":2,"476":3,"528":1,"569":1,"602":1,"614":2,"620":2,"636":1,"738":1,"750":1,"756":1}}],["intuitive",{"2":{"199":1}}],["int64",{"2":{"144":8,"156":4,"160":4,"161":4,"163":8}}],["intended",{"2":{"413":1}}],["intensive",{"2":{"367":1}}],["intel",{"2":{"399":1}}],["integrating",{"2":{"229":1,"713":1}}],["integration",{"0":{"454":1,"455":1},"1":{"455":1,"456":2,"457":1},"2":{"81":2,"82":1,"96":1,"103":1,"107":2,"108":2,"109":2,"110":1,"111":2,"112":1,"221":1,"250":2,"259":1,"277":1,"455":1,"456":2,"457":2,"479":1,"540":1,"544":1}}],["integrations",{"0":{"63":1,"484":1,"781":1},"1":{"64":1,"65":1,"66":1,"67":1,"68":1,"485":1,"486":1,"487":1,"488":1,"489":1,"490":1,"491":1,"492":1,"493":1,"494":1,"495":1,"782":1,"783":1,"784":1},"2":{"277":1,"400":1}}],["integrate",{"0":{"114":1,"123":1,"228":1,"229":1,"713":1},"1":{"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"229":1,"230":1,"231":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"720":1},"2":{"228":1,"229":2,"277":1,"582":1,"763":1}}],["integrated",{"2":{"111":1}}],["integrates",{"2":{"96":1}}],["integrity",{"2":{"86":2}}],["integer",{"2":{"86":1}}],["intermediate",{"2":{"642":1,"643":1,"649":1,"650":1}}],["interruptions",{"2":{"479":1}}],["inter",{"2":{"427":1}}],["intervals",{"2":{"680":1}}],["interval",{"2":{"275":4,"334":4,"429":2}}],["interfaces",{"2":{"126":2,"377":2,"682":1,"683":1,"692":1}}],["interface",{"0":{"120":1},"2":{"109":2,"117":1,"120":3,"122":1,"126":4,"219":1,"278":1,"303":2,"599":2,"646":1,"737":1}}],["internally",{"2":{"238":1}}],["internal",{"2":{"91":5,"722":1}}],["interestingly",{"2":{"648":1}}],["interested",{"2":{"38":2,"39":3,"42":3,"535":1,"567":1,"568":1}}],["interest",{"2":{"36":2,"37":1,"47":1}}],["interests",{"2":{"36":1,"41":1,"42":1}}],["interactivecelestia",{"2":{"308":1}}],["interactive",{"2":{"58":1,"308":1}}],["interactions",{"2":{"13":1,"126":1,"252":1}}],["interaction",{"2":{"13":2,"14":3,"15":1,"31":1,"90":1,"238":1}}],["interacting",{"2":{"3":1,"134":1,"313":1,"325":1,"326":1,"721":1,"725":1,"738":2}}],["interact",{"2":{"6":1,"122":1,"136":1,"231":1,"252":1,"254":1,"396":1,"459":1,"506":1,"507":1,"508":1,"565":1,"567":1,"568":1,"599":1,"704":2,"705":2,"717":1,"721":1,"737":1,"738":2,"739":1,"740":1,"741":2}}],["intake",{"2":{"41":2}}],["introducing",{"2":{"648":1}}],["introduction",{"0":{"53":1,"56":1,"106":1,"165":1,"404":1,"454":1,"648":1,"729":1},"1":{"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"195":1,"196":1,"197":1,"198":1,"199":1,"455":1,"456":1,"457":1,"730":1,"731":1},"2":{"37":1,"53":2,"55":1,"56":3,"81":1,"82":1,"103":1,"107":1,"108":1,"250":1,"714":1}}],["introduces",{"2":{"671":1}}],["introduced",{"2":{"608":1}}],["introduce",{"2":{"31":1,"528":1}}],["into",{"0":{"564":1,"636":1},"1":{"565":1,"566":1,"567":1,"568":1,"569":1},"2":{"22":1,"25":1,"53":1,"77":1,"89":1,"93":1,"96":1,"109":1,"110":1,"111":1,"137":2,"139":1,"208":1,"214":1,"221":1,"263":1,"273":1,"277":1,"286":1,"311":1,"316":1,"325":1,"334":1,"341":1,"345":1,"430":1,"479":1,"526":1,"570":1,"588":1,"641":2,"643":1,"644":2,"647":1,"649":5,"668":3,"698":1,"731":1,"771":2}}],["incoming",{"2":{"778":2}}],["incomplete",{"2":{"644":1}}],["incorrectly",{"0":{"643":1},"2":{"631":1,"632":1,"643":2}}],["incorrect",{"2":{"91":1,"400":1,"632":1}}],["incentive",{"2":{"650":1}}],["incentives",{"2":{"37":1,"637":1}}],["incentivized",{"2":{"679":1}}],["incentivizes",{"2":{"639":1}}],["incentivize",{"0":{"637":1},"2":{"637":1}}],["inception",{"2":{"478":1}}],["incurred",{"2":{"404":1,"412":1}}],["incubators",{"2":{"34":1}}],["incredible",{"2":{"44":1}}],["increased",{"2":{"93":2}}],["increases",{"2":{"39":1,"86":1,"630":1,"648":1}}],["increase",{"2":{"38":1,"39":1,"274":2,"337":1,"647":1,"648":1}}],["increasing",{"2":{"36":1,"337":1,"642":1,"648":1}}],["incident",{"2":{"10":1,"13":1}}],["inclusion",{"0":{"122":1,"132":1,"141":1,"145":1,"146":1,"149":1,"151":1,"175":1},"1":{"142":1,"143":1,"147":1,"148":1,"150":1,"152":1,"153":1},"2":{"40":1,"117":1,"119":2,"120":1,"122":4,"125":1,"127":3,"132":1,"137":1,"139":1,"141":1,"142":1,"144":2,"146":1,"147":2,"151":1,"155":1,"156":1,"160":1,"163":1,"164":1,"168":3,"169":2,"174":2,"175":7,"188":1,"191":1,"199":2,"227":2,"608":1}}],["inclusive",{"2":{"6":1,"46":1,"216":1}}],["including",{"2":{"13":1,"14":2,"15":1,"26":1,"30":3,"31":1,"41":1,"46":1,"58":1,"86":1,"88":1,"94":1,"523":1,"540":1,"590":1,"614":1,"679":1}}],["included",{"2":{"120":2,"127":2,"128":3,"137":1,"160":2,"172":1,"174":1,"183":1,"227":1,"483":1,"526":1,"530":1,"586":2,"592":3,"596":2,"607":1,"608":1,"609":1,"668":1,"708":2,"743":1,"745":1,"746":1,"777":2}}],["includes",{"2":{"13":1,"51":1,"52":1,"87":1,"96":1,"111":1,"428":1,"450":1,"528":1,"636":1,"644":1,"668":1,"680":1,"719":1}}],["include",{"2":{"7":2,"9":1,"38":1,"172":1,"216":1,"228":1,"276":1,"322":1,"451":1,"528":1,"539":1,"582":1,"638":1,"668":1,"739":1}}],["invocations",{"2":{"373":1,"620":1}}],["involves",{"2":{"589":1,"635":1}}],["involve",{"2":{"126":2,"127":1,"540":1}}],["involvement",{"2":{"37":1}}],["involved",{"2":{"13":1,"14":1,"190":1,"455":1,"589":1,"590":1}}],["inverted",{"2":{"322":2}}],["investigations",{"2":{"185":1}}],["investigate",{"2":{"36":1,"38":1}}],["investigated",{"2":{"10":1,"170":1,"183":1,"193":1}}],["invalid",{"0":{"383":1,"625":1},"2":{"127":2,"130":2,"163":4,"174":1,"179":2,"183":2,"334":2,"383":2,"625":2,"643":2,"650":1,"777":2,"778":2}}],["invitation",{"2":{"47":1}}],["invitations",{"2":{"30":1}}],["invites",{"2":{"48":1}}],["invite",{"2":{"37":2,"39":2}}],["invisible",{"2":{"6":1}}],["inspect",{"2":{"627":1}}],["inspired",{"2":{"16":1,"178":1,"202":1}}],["insecure",{"2":{"597":4}}],["inside",{"0":{"191":1},"2":{"172":2,"187":1,"188":1,"191":2,"193":1,"194":3,"196":1,"246":1,"311":1,"383":1,"423":1,"449":1,"450":1,"451":1,"468":1,"625":2,"696":1,"698":1,"769":1,"774":1}}],["insight",{"2":{"273":1}}],["insightful",{"2":{"44":1}}],["insights",{"2":{"32":1,"37":1,"58":1,"280":1}}],["instrumentation",{"2":{"274":6}}],["instructions",{"0":{"210":1},"2":{"200":1,"211":2,"214":1,"217":1,"218":1,"245":1,"282":1,"283":1,"294":1,"312":1,"343":1,"345":1,"359":1,"388":3,"396":1,"398":2,"422":1,"499":2,"543":1,"544":1,"566":1,"583":1,"584":1,"612":1,"620":1,"622":1}}],["instead",{"2":{"104":1,"110":1,"126":1,"130":3,"161":4,"162":4,"163":4,"176":1,"194":1,"400":1,"455":1,"528":1,"588":3,"592":1,"671":1,"688":1,"745":1}}],["instability",{"2":{"479":1,"547":1}}],["instantiate",{"0":{"453":1,"734":1},"2":{"439":1,"647":1,"734":1}}],["instantiation",{"0":{"439":1},"1":{"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1}}],["instantiating",{"2":{"105":1,"734":1}}],["instantaneous",{"2":{"426":1}}],["instance",{"2":{"77":1,"92":2,"214":1,"215":1,"235":1,"240":1,"275":1,"315":1,"336":1,"358":1,"417":1,"462":1,"561":1,"584":1,"612":1}}],["instances",{"2":{"10":1}}],["installer",{"2":{"388":1}}],["installed",{"2":{"116":1,"202":1,"208":1,"287":1,"298":1,"307":1,"311":1,"342":1,"343":2,"344":1,"347":1,"384":1,"399":2,"403":1,"428":1,"429":1,"473":3,"556":2,"703":1,"764":1,"782":1}}],["installs",{"2":{"341":1,"697":2}}],["installation",{"0":{"343":1,"442":1,"697":1},"2":{"312":2,"342":2,"343":3,"695":1}}],["installmake",{"2":{"311":1,"341":1}}],["installing",{"0":{"117":1,"312":1,"341":1,"342":1},"1":{"343":1},"2":{"241":1,"243":1,"310":1,"312":1,"341":1,"342":1,"359":1,"360":1,"388":1,"396":1,"398":2,"419":1,"463":1,"616":1}}],["install",{"0":{"243":1,"310":1,"340":1,"360":1,"398":1,"399":1,"419":1,"463":1,"616":1,"765":1},"1":{"311":1,"312":1,"313":1,"341":1,"342":1,"343":1,"344":1,"345":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1},"2":{"89":2,"117":3,"203":2,"210":2,"243":1,"275":1,"277":1,"282":1,"284":1,"307":1,"311":3,"312":1,"341":3,"343":5,"345":1,"371":1,"388":1,"398":15,"399":2,"428":1,"442":1,"463":1,"556":2,"602":2,"604":2,"605":2,"606":2,"697":2,"706":1,"733":1,"737":1,"765":1,"775":1,"782":2}}],["insulting",{"2":{"7":1}}],["in",{"0":{"74":1,"75":1,"112":1,"154":1,"204":1,"336":1,"406":1,"408":1,"435":1,"461":1,"546":1,"592":1,"629":1,"671":1},"1":{"75":1,"76":2,"77":2,"78":1,"79":1,"80":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"205":1,"206":1,"207":1,"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1},"2":{"3":1,"4":2,"6":2,"7":1,"8":1,"9":1,"11":2,"12":1,"13":1,"18":1,"20":1,"22":6,"23":6,"24":3,"26":2,"28":1,"29":1,"31":1,"32":1,"33":1,"34":2,"35":4,"36":3,"37":2,"38":6,"39":7,"40":4,"42":7,"44":2,"46":2,"47":2,"48":1,"50":1,"54":1,"55":1,"58":4,"60":2,"63":2,"64":1,"65":2,"68":2,"74":2,"76":3,"77":4,"79":3,"80":3,"84":1,"85":2,"86":12,"87":4,"88":1,"89":1,"90":5,"91":10,"93":10,"94":3,"95":1,"96":1,"97":1,"104":4,"107":1,"108":2,"109":7,"110":10,"111":1,"112":3,"113":1,"119":2,"120":2,"121":1,"122":2,"125":13,"126":3,"127":12,"128":4,"130":1,"136":3,"137":8,"139":9,"140":1,"141":1,"150":2,"152":3,"153":2,"155":3,"156":13,"157":1,"158":1,"159":9,"160":8,"161":2,"162":1,"164":2,"165":1,"166":2,"167":1,"168":3,"169":4,"171":3,"172":4,"173":1,"174":9,"175":9,"179":2,"180":1,"182":2,"183":5,"184":1,"185":1,"186":1,"187":3,"188":1,"190":1,"191":2,"194":1,"197":2,"199":5,"201":1,"202":7,"203":3,"204":5,"205":1,"208":6,"210":6,"211":16,"213":2,"214":2,"215":7,"216":3,"217":2,"219":1,"221":2,"224":1,"226":1,"227":5,"228":1,"230":1,"233":2,"234":1,"235":1,"238":3,"244":1,"246":1,"247":1,"250":2,"251":1,"254":1,"263":1,"266":4,"267":2,"272":2,"275":3,"276":1,"281":3,"283":1,"287":1,"289":1,"291":3,"294":1,"295":1,"296":1,"298":2,"301":1,"303":1,"304":1,"308":1,"311":1,"312":2,"314":1,"315":1,"316":1,"320":2,"321":3,"322":4,"326":1,"328":4,"329":2,"331":1,"334":1,"336":2,"337":4,"338":1,"341":1,"343":5,"348":1,"349":1,"352":1,"353":1,"355":1,"356":1,"361":7,"363":1,"365":1,"366":1,"367":2,"368":2,"371":3,"378":1,"380":2,"381":6,"383":2,"385":1,"387":1,"388":2,"392":3,"396":1,"399":1,"400":4,"404":2,"407":1,"422":1,"423":1,"424":1,"426":2,"427":2,"428":1,"431":2,"432":5,"443":1,"444":1,"445":1,"448":3,"449":2,"450":2,"452":1,"455":3,"457":1,"461":1,"464":1,"465":1,"466":2,"467":1,"468":1,"469":1,"476":1,"478":2,"482":1,"483":6,"484":4,"485":1,"495":1,"499":3,"503":1,"505":1,"507":1,"508":1,"509":1,"516":1,"519":1,"523":1,"525":3,"526":3,"528":5,"530":1,"531":2,"535":1,"539":2,"540":4,"542":2,"544":1,"545":1,"549":1,"552":1,"555":3,"557":4,"558":4,"559":3,"562":6,"563":3,"564":1,"566":2,"567":1,"568":1,"569":3,"578":1,"580":1,"581":2,"582":2,"583":1,"584":5,"586":5,"587":1,"588":3,"589":4,"590":4,"591":2,"592":2,"593":1,"595":1,"598":1,"599":5,"602":3,"606":2,"607":2,"608":1,"609":1,"610":2,"614":2,"620":3,"625":2,"629":2,"632":1,"634":1,"635":1,"636":1,"637":1,"640":1,"641":4,"642":3,"644":1,"647":9,"648":1,"649":3,"650":3,"651":1,"654":1,"655":1,"659":1,"668":1,"669":2,"670":3,"671":3,"672":4,"674":1,"675":2,"678":1,"679":1,"680":2,"685":1,"687":1,"688":3,"689":2,"690":1,"692":1,"693":1,"696":1,"697":4,"698":2,"699":1,"704":3,"705":3,"707":1,"708":1,"709":5,"710":6,"715":1,"716":1,"717":4,"720":2,"721":1,"726":1,"728":1,"731":1,"734":1,"735":1,"736":2,"738":3,"739":1,"740":1,"741":1,"742":1,"743":4,"745":4,"746":1,"750":2,"751":1,"755":6,"758":1,"760":3,"763":1,"765":5,"766":2,"768":1,"769":1,"771":3,"776":1,"777":1,"778":4,"782":2,"783":2,"784":2}}],["imagine",{"2":{"582":1}}],["image",{"2":{"104":1,"390":1,"704":3,"705":6,"784":1}}],["imagery",{"2":{"7":1}}],["images",{"2":{"3":1,"784":1}}],["immutable",{"2":{"86":2,"118":2}}],["improperly",{"2":{"631":1}}],["improve",{"2":{"41":1}}],["improvement",{"2":{"32":1,"526":1,"642":1}}],["improvements",{"2":{"4":1,"479":1}}],["improved",{"2":{"28":1,"221":1,"273":1}}],["improves",{"2":{"23":1}}],["improving",{"2":{"2":1}}],["impractical",{"2":{"627":1}}],["importing",{"0":{"263":1,"522":1,"700":1},"2":{"161":2,"162":2,"163":2,"314":1}}],["import",{"0":{"769":1},"2":{"118":6,"143":2,"144":4,"150":1,"161":4,"162":4,"163":10,"238":1,"263":5,"275":2,"314":1,"430":1,"522":2,"566":1,"591":1,"596":1,"597":1,"700":1,"708":1,"769":4,"782":7}}],["importance",{"2":{"58":1}}],["important",{"0":{"45":1},"1":{"46":1,"47":1,"48":1,"49":1,"50":1},"2":{"23":1,"27":1,"110":1,"125":2,"275":1,"276":1,"291":2,"325":1,"524":1,"558":1,"590":1,"607":1,"646":1}}],["implement",{"2":{"526":1,"647":1,"672":2,"774":1}}],["implemented",{"2":{"164":1,"507":1,"525":1,"530":1,"584":1,"671":4}}],["implements",{"2":{"109":1}}],["implementations",{"0":{"222":1,"236":1},"2":{"126":2,"427":1}}],["implementation",{"0":{"109":1,"110":1,"111":1,"232":1,"406":1},"1":{"233":1,"234":1,"235":1,"236":1},"2":{"108":3,"122":1,"124":1,"163":4,"221":3,"222":1,"226":1,"227":2,"233":1,"236":1,"238":1,"428":1,"523":1,"583":1,"738":1}}],["impactful",{"2":{"37":1,"58":1}}],["impact",{"2":{"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"26":1,"38":1,"526":1}}],["item",{"2":{"773":1}}],["items",{"2":{"770":1,"771":1}}],["ith",{"2":{"590":2}}],["itrocket",{"2":{"487":1,"488":1,"489":1,"490":1,"493":1,"496":1,"497":1,"505":1,"506":1,"507":1,"508":1,"512":1}}],["itself",{"2":{"96":1,"275":2}}],["its",{"2":{"18":2,"26":2,"86":4,"87":2,"110":1,"139":1,"147":1,"149":1,"156":2,"157":2,"163":2,"166":1,"168":1,"172":1,"174":1,"178":1,"182":1,"183":1,"187":1,"199":1,"202":1,"209":1,"210":1,"225":1,"226":1,"259":2,"275":1,"322":1,"337":1,"478":1,"588":1,"589":1,"599":2,"602":1,"604":1,"605":1,"606":1,"629":1,"630":1,"644":2,"647":1,"681":1,"689":1,"748":1,"774":1}}],["it",{"2":{"2":2,"23":1,"29":1,"35":1,"36":1,"41":2,"42":1,"47":1,"60":5,"77":1,"86":5,"88":2,"90":1,"91":3,"92":1,"104":1,"109":6,"110":1,"112":1,"119":1,"120":1,"122":6,"124":1,"126":2,"130":2,"136":1,"137":2,"139":2,"141":2,"151":2,"155":2,"157":2,"160":1,"163":2,"165":1,"168":1,"170":1,"172":1,"174":2,"179":1,"182":1,"183":1,"187":2,"194":1,"199":1,"202":10,"203":4,"204":3,"208":1,"210":8,"211":2,"214":4,"215":5,"216":1,"217":1,"218":1,"219":1,"226":1,"227":2,"233":1,"234":3,"235":1,"244":2,"245":1,"250":1,"251":2,"254":1,"273":1,"274":2,"275":6,"276":1,"277":1,"281":1,"287":1,"291":2,"294":1,"305":1,"308":1,"312":1,"313":1,"316":1,"320":2,"322":1,"324":1,"325":1,"326":1,"333":1,"334":2,"336":2,"337":1,"339":1,"343":1,"344":1,"368":1,"372":1,"376":1,"377":2,"381":1,"383":1,"385":1,"391":2,"402":1,"406":1,"422":2,"427":1,"428":2,"430":1,"431":1,"438":1,"448":1,"450":2,"451":1,"455":1,"464":1,"478":1,"479":1,"483":1,"499":1,"505":1,"523":1,"524":1,"536":1,"537":1,"544":1,"547":1,"550":1,"552":1,"555":2,"558":1,"559":1,"562":2,"563":1,"577":1,"580":1,"586":2,"589":2,"590":4,"592":4,"596":2,"597":2,"599":1,"602":2,"607":1,"608":1,"609":1,"614":1,"615":2,"625":1,"627":5,"630":2,"631":1,"636":1,"637":1,"643":1,"644":1,"647":1,"648":1,"649":5,"650":1,"672":2,"675":1,"695":1,"697":1,"708":2,"720":1,"724":1,"726":1,"735":2,"738":1,"743":1,"752":2,"761":2,"762":1,"763":1,"765":3,"766":1,"771":7,"772":3,"773":1,"774":2,"782":4}}],["issuing",{"2":{"688":1}}],["issuance",{"2":{"675":2}}],["issues",{"2":{"8":1,"54":1,"91":1,"345":1,"456":1,"544":3,"570":1}}],["issue",{"2":{"4":1,"93":1,"428":1,"534":2,"592":1,"634":1,"675":1,"688":1}}],["isn",{"2":{"130":1,"483":1,"584":1}}],["isvalid",{"2":{"130":2}}],["isolates",{"2":{"581":1}}],["isolated",{"2":{"388":1}}],["isolate",{"2":{"126":1}}],["is",{"0":{"221":1,"227":1,"233":1,"577":1,"578":1,"627":1,"628":1,"630":1,"632":1,"633":1,"634":1,"635":1,"638":1},"1":{"222":1},"2":{"1":1,"7":1,"9":1,"14":1,"16":1,"20":1,"21":1,"23":1,"25":1,"26":2,"29":1,"31":1,"34":1,"37":1,"38":1,"39":2,"41":3,"42":1,"43":1,"46":1,"47":2,"49":2,"50":1,"51":1,"53":1,"54":2,"55":2,"58":3,"59":4,"60":1,"63":1,"70":1,"71":1,"79":1,"84":1,"85":3,"86":8,"87":1,"88":3,"90":3,"91":7,"93":10,"94":1,"96":2,"108":3,"109":7,"110":2,"111":1,"112":2,"117":2,"118":2,"119":3,"120":2,"122":6,"124":3,"125":30,"126":5,"127":6,"128":6,"130":6,"134":1,"136":1,"137":3,"139":5,"141":2,"145":1,"147":2,"148":1,"149":2,"150":1,"151":1,"152":1,"153":1,"155":2,"156":5,"157":3,"159":2,"160":12,"163":6,"164":1,"165":1,"167":1,"168":1,"169":1,"172":3,"173":1,"174":9,"175":12,"178":3,"179":6,"180":1,"183":9,"185":1,"186":1,"187":6,"188":1,"191":6,"193":1,"194":4,"197":1,"199":6,"202":13,"204":2,"205":2,"208":3,"210":4,"211":6,"212":2,"213":1,"214":8,"215":7,"218":1,"219":1,"221":4,"224":1,"225":2,"226":2,"227":3,"233":2,"234":3,"235":1,"238":5,"240":1,"244":1,"245":4,"248":1,"249":2,"250":3,"254":1,"255":1,"266":3,"273":1,"275":5,"277":2,"278":1,"281":6,"282":1,"289":3,"291":2,"294":1,"295":1,"296":1,"303":2,"308":1,"310":1,"312":2,"313":2,"314":1,"315":1,"317":1,"318":1,"319":1,"320":2,"322":4,"324":2,"325":4,"326":2,"328":1,"329":1,"331":1,"333":1,"334":3,"336":2,"337":2,"338":2,"339":1,"341":2,"342":2,"343":3,"350":1,"352":1,"353":2,"355":4,"358":1,"361":3,"363":1,"365":2,"367":1,"368":2,"370":1,"373":2,"378":3,"380":7,"381":1,"383":1,"385":1,"387":1,"388":3,"390":2,"391":1,"396":2,"399":1,"400":3,"404":1,"406":1,"413":1,"414":1,"417":1,"422":3,"426":1,"427":1,"428":4,"431":3,"437":1,"438":1,"439":1,"445":2,"447":1,"448":1,"452":2,"454":2,"455":8,"456":1,"457":1,"459":1,"461":1,"465":1,"467":1,"475":1,"477":2,"478":2,"479":2,"483":7,"484":2,"494":1,"495":1,"499":4,"506":2,"507":3,"508":3,"510":1,"524":3,"526":1,"535":1,"540":3,"542":2,"543":1,"544":1,"547":2,"550":2,"552":1,"555":2,"556":1,"557":2,"558":1,"559":5,"562":5,"563":4,"566":3,"569":1,"577":1,"578":1,"580":2,"581":1,"583":1,"586":4,"588":4,"589":4,"590":14,"591":2,"592":2,"597":8,"599":2,"600":1,"602":3,"605":1,"606":1,"607":3,"608":1,"609":1,"612":1,"615":3,"619":1,"620":3,"625":1,"627":2,"628":3,"629":1,"630":3,"631":6,"632":3,"633":2,"634":2,"635":2,"636":3,"637":3,"639":1,"640":2,"641":6,"643":7,"644":8,"646":7,"647":3,"648":3,"649":5,"650":9,"651":1,"657":1,"661":1,"666":1,"668":2,"670":5,"671":3,"672":4,"674":1,"680":3,"687":1,"688":1,"692":1,"693":4,"694":1,"695":1,"696":1,"707":1,"713":1,"715":2,"717":1,"718":1,"719":1,"720":3,"721":1,"724":1,"725":2,"726":2,"730":1,"734":1,"736":1,"738":5,"739":2,"740":2,"741":1,"742":3,"743":3,"745":3,"746":2,"748":1,"749":1,"750":2,"751":1,"752":1,"755":2,"762":1,"765":2,"769":1,"771":5,"773":2,"776":1,"782":5}}],["lcd",{"2":{"488":2}}],["luckily",{"2":{"634":1,"637":1}}],["lunaroasis",{"2":{"466":2,"487":1,"488":1,"489":1,"493":1,"735":2}}],["lumina",{"2":{"461":2,"775":1}}],["l5dhzjldczo",{"2":{"291":2,"292":2}}],["ljj6hspn0kn09qf9fy8kdyh40000gn",{"2":{"287":4}}],["lsm",{"2":{"322":3}}],["ls",{"2":{"214":2,"215":2}}],["ldflags",{"2":{"214":2}}],["lfg",{"2":{"93":2}}],["l2genesisdeltatimeoffset",{"2":{"539":1}}],["l2s",{"2":{"112":1,"221":2,"226":1,"400":2,"455":1}}],["l2",{"0":{"90":1,"544":1},"2":{"84":1,"86":2,"87":1,"88":1,"93":6,"111":1,"120":1,"122":1,"221":1,"225":2,"229":1,"400":1,"454":1,"544":2,"628":2}}],["l1",{"0":{"544":1},"2":{"84":2,"86":1,"93":8,"536":1,"537":1,"540":2,"544":4,"628":1}}],["l3s",{"2":{"112":1,"221":1,"400":1}}],["l3configuration",{"2":{"93":2}}],["l3",{"2":{"74":1,"77":1,"79":1,"88":2,"93":6}}],["lts",{"2":{"240":1,"358":1,"417":1,"462":1,"612":1,"718":1}}],["lt",{"2":{"68":6,"70":3,"77":1,"91":8,"128":2,"136":3,"142":1,"144":4,"147":1,"148":2,"150":7,"152":1,"161":4,"162":6,"203":8,"204":30,"206":4,"207":4,"209":6,"215":4,"216":1,"233":1,"244":8,"245":4,"246":12,"262":8,"263":6,"264":8,"265":18,"266":20,"267":4,"268":6,"269":16,"270":4,"271":6,"272":2,"275":2,"303":4,"314":10,"316":10,"317":4,"318":4,"319":4,"320":16,"324":10,"329":10,"334":8,"335":4,"336":8,"338":9,"393":2,"405":4,"412":4,"422":4,"423":12,"430":4,"466":6,"467":3,"468":12,"493":6,"510":3,"536":1,"569":2,"594":4,"595":4,"602":4,"604":4,"605":6,"606":6,"614":4,"617":2,"620":2,"698":13,"699":12,"700":12,"704":5,"705":8,"709":6,"710":6,"735":6,"736":21,"738":6,"740":6,"741":4,"743":8,"745":8,"749":2,"752":4,"755":6,"757":4,"770":6,"771":6,"773":12,"782":14}}],["living",{"2":{"482":1}}],["lives",{"2":{"42":1,"110":1,"289":1}}],["live",{"2":{"40":4,"76":1,"289":1,"457":1,"479":1,"544":1}}],["lifecycle",{"0":{"649":1},"1":{"650":1}}],["life",{"2":{"478":1,"668":1}}],["libp2p",{"2":{"238":1,"650":1}}],["libssl",{"2":{"398":4}}],["libs",{"2":{"163":2}}],["library",{"0":{"154":1,"706":1,"723":1,"775":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"776":1,"777":1,"778":1,"779":1,"780":1},"2":{"122":3,"154":1,"163":2,"174":1,"183":1,"191":1,"520":1,"706":1,"723":1,"724":1,"775":1}}],["libraries",{"2":{"34":2,"188":1,"716":1,"718":1,"719":1,"769":1}}],["lib",{"2":{"118":2,"122":1,"163":2}}],["license",{"2":{"118":2}}],["limit=fc+∑i=1nssn",{"2":{"590":1}}],["limit×gas",{"2":{"590":1}}],["limitnofile=65535",{"2":{"602":2}}],["limitnofile=1400000",{"2":{"337":2,"604":2,"605":2}}],["limitnofile",{"2":{"337":2}}],["limits",{"0":{"588":1},"1":{"589":1,"590":1,"591":1},"2":{"274":2,"337":1,"528":1,"647":1,"746":1}}],["limited",{"2":{"266":1,"642":2,"648":1,"715":1}}],["limitations",{"2":{"171":1}}],["limit",{"2":{"70":1,"294":2,"337":1,"407":2,"412":2,"483":1,"510":1,"528":1,"588":2,"590":4,"591":1,"597":2,"743":1,"746":1,"755":1}}],["lightdsudo",{"2":{"606":2}}],["lightd",{"2":{"606":13}}],["light$home",{"2":{"542":1}}],["lightbridgefull",{"2":{"390":1}}],["lightlink",{"2":{"163":1}}],["light",{"0":{"54":1,"91":1,"133":1,"331":1,"332":1,"338":1,"385":1,"391":1,"458":1,"459":1,"461":1,"462":1,"464":1,"465":1,"468":1,"470":1,"476":1,"502":1,"542":1,"556":1,"557":1,"559":1,"560":1,"561":1,"595":1,"606":1,"734":1,"765":1},"1":{"339":1,"386":1,"392":1,"393":1,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":2,"467":2,"468":2,"469":3,"470":2,"471":1,"503":1,"504":1,"505":1,"557":1,"558":2,"559":1,"561":1,"562":1,"563":1},"2":{"54":7,"65":1,"68":3,"82":1,"91":7,"111":1,"126":9,"133":1,"134":1,"221":2,"227":2,"238":1,"244":1,"315":2,"321":1,"322":4,"328":1,"331":1,"332":1,"335":3,"338":7,"339":1,"344":1,"348":2,"349":2,"355":6,"371":2,"385":2,"392":6,"393":6,"403":1,"405":1,"407":2,"408":4,"409":2,"415":2,"422":1,"458":1,"459":2,"460":1,"461":1,"464":6,"465":7,"466":12,"468":9,"469":3,"470":1,"471":1,"472":1,"476":10,"477":7,"491":1,"493":1,"494":2,"499":1,"516":2,"521":2,"531":2,"533":1,"542":7,"555":2,"556":1,"557":13,"558":3,"559":3,"563":1,"564":1,"565":4,"566":1,"567":1,"568":1,"569":2,"581":1,"591":1,"605":1,"606":7,"629":1,"630":4,"631":6,"632":2,"640":1,"641":5,"642":8,"643":3,"648":2,"650":9,"671":6,"696":1,"698":2,"699":2,"700":2,"704":5,"705":10,"720":1,"726":1,"732":1,"734":8,"735":14,"736":12,"740":3,"741":3,"742":12,"743":1,"760":3,"764":1,"765":10}}],["lightning",{"2":{"42":1,"454":1}}],["lisbon",{"2":{"44":1}}],["listcelestia",{"2":{"299":1,"308":1}}],["listing",{"2":{"262":2}}],["listens",{"2":{"377":1}}],["listen",{"2":{"219":1,"274":4,"275":1,"377":1,"459":1,"650":1}}],["listening",{"0":{"162":1},"2":{"162":1,"377":1}}],["listed",{"2":{"65":1,"485":1,"487":1,"503":1,"530":1,"584":1}}],["list",{"0":{"58":1,"292":1},"2":{"26":2,"30":1,"36":1,"37":2,"50":2,"58":6,"86":1,"109":3,"118":2,"156":2,"159":2,"203":1,"205":1,"206":2,"211":1,"218":1,"244":2,"245":2,"262":2,"266":1,"274":2,"292":2,"299":2,"308":1,"329":2,"361":2,"422":2,"429":4,"435":4,"451":2,"466":2,"484":1,"499":1,"620":1,"641":1,"664":1,"677":1,"704":3,"705":3,"712":1,"736":2,"780":1}}],["linear",{"2":{"590":1}}],["lines",{"2":{"271":2}}],["line",{"0":{"279":1},"2":{"244":1,"278":1,"303":1,"336":1,"350":1,"381":1,"390":1,"451":1,"735":1,"737":1}}],["lineup",{"2":{"37":1}}],["linuxdocker",{"2":{"391":1}}],["linux",{"2":{"91":1,"240":1,"312":1,"342":1,"358":1,"389":1,"396":1,"399":12,"417":1,"462":1,"612":1,"718":1}}],["linked",{"2":{"133":1}}],["link",{"2":{"63":1,"231":1,"275":2,"276":1,"484":1,"499":1,"771":2}}],["links",{"2":{"26":2,"48":1,"136":1}}],["little",{"2":{"34":1,"87":1,"449":1,"720":1}}],["likely",{"2":{"126":5,"334":1,"383":1,"625":1,"638":1,"720":2}}],["likelihood",{"2":{"39":1,"650":1}}],["like",{"2":{"13":1,"30":1,"34":2,"35":1,"40":1,"41":2,"42":1,"63":1,"73":1,"82":1,"84":1,"86":2,"91":1,"92":1,"104":1,"124":1,"125":1,"130":1,"202":3,"215":2,"246":1,"275":1,"283":1,"284":1,"288":1,"294":3,"314":2,"320":1,"326":1,"329":1,"336":1,"337":1,"339":1,"373":1,"383":1,"388":1,"390":2,"398":1,"423":1,"425":1,"431":1,"468":1,"475":1,"479":1,"484":1,"498":1,"499":2,"513":1,"528":1,"536":1,"540":3,"554":1,"572":1,"577":1,"578":2,"581":2,"625":1,"627":1,"628":1,"630":1,"636":1,"639":1,"674":1,"689":1,"704":1,"705":1,"707":1,"726":2,"731":2,"735":1,"736":1,"742":1,"745":1,"752":2,"755":3,"761":1,"762":1,"765":1,"776":1,"782":1}}],["laddr",{"2":{"313":1}}],["ladder",{"2":{"16":1}}],["lang",{"2":{"303":2}}],["languages",{"2":{"136":1,"164":1}}],["language",{"2":{"7":1,"12":1}}],["laid",{"2":{"191":1,"194":1}}],["latter",{"2":{"187":1,"648":1}}],["latency",{"2":{"429":4}}],["latestblock",{"2":{"228":1,"233":5}}],["latestblocknumber",{"2":{"144":4,"161":4}}],["latestrollupheight",{"2":{"126":2,"128":6}}],["latest",{"2":{"59":1,"60":2,"95":1,"96":1,"104":1,"126":2,"140":1,"216":2,"221":1,"227":5,"233":1,"298":1,"311":6,"312":1,"341":6,"343":5,"345":1,"383":1,"390":6,"392":6,"393":6,"422":1,"427":1,"536":2,"550":1,"556":3,"559":2,"583":1,"625":2,"628":1,"672":2,"704":2,"715":1,"779":6}}],["later",{"2":{"34":1,"215":1,"311":1,"446":1,"634":1,"649":1,"650":1}}],["large",{"2":{"171":1,"217":1,"555":1,"720":2}}],["larger",{"2":{"34":1,"36":1,"274":2,"642":1,"720":1}}],["layout",{"2":{"127":1,"137":2,"168":1}}],["layers",{"2":{"640":2,"646":1,"647":7,"670":2}}],["layer",{"0":{"640":1},"1":{"641":1,"642":1,"643":1,"644":1,"645":1,"646":1},"2":{"91":1,"107":2,"111":1,"178":2,"221":1,"227":1,"237":2,"238":1,"249":1,"250":1,"251":1,"356":1,"400":1,"455":5,"530":1,"540":1,"555":1,"577":3,"578":3,"640":3,"642":2,"644":4,"646":4,"647":6,"649":1,"650":1,"668":1,"688":1,"714":1,"717":1,"728":1,"730":1}}],["lag",{"2":{"60":1}}],["label",{"2":{"275":2,"437":1}}],["labels",{"2":{"275":4}}],["labeled",{"2":{"47":1}}],["labs",{"2":{"23":1,"37":2,"38":2,"39":2,"40":5,"41":10,"58":1,"59":1,"81":2,"93":1,"249":1,"679":1}}],["lastly",{"2":{"275":1}}],["lastblock",{"2":{"128":6}}],["last",{"2":{"26":1,"35":1,"37":1,"208":1,"216":1,"271":2,"281":1,"558":2,"752":6,"773":1}}],["law",{"2":{"24":1}}],["launching",{"2":{"36":1}}],["launch",{"0":{"20":1,"88":1},"2":{"87":1,"88":1,"250":1,"648":1,"680":2,"688":1}}],["lemongrass",{"0":{"530":1},"2":{"525":2,"528":1,"530":2}}],["lemonade",{"2":{"35":1}}],["leonardo",{"2":{"477":2,"562":3,"563":2}}],["legacy",{"2":{"266":3,"267":2}}],["ledger",{"2":{"202":2,"627":1}}],["len",{"2":{"128":8,"130":6,"144":2,"156":4,"158":2,"159":4,"160":2,"163":12,"597":4,"709":2,"710":2,"770":2,"771":2,"773":2,"777":2,"778":2}}],["length",{"2":{"125":2}}],["left",{"2":{"126":1,"179":2,"187":1,"191":1,"194":1,"637":1}}],["lets",{"2":{"581":1}}],["let",{"2":{"41":3,"87":1,"122":1,"349":1,"555":1,"557":2,"558":2,"561":1,"562":1,"563":1,"596":2,"708":2,"734":1,"735":1,"738":1,"748":1,"749":1,"752":1,"763":1,"765":1,"770":1,"777":12,"778":12,"779":4}}],["leveraging",{"2":{"434":1}}],["leverages",{"2":{"118":1}}],["leverage",{"2":{"37":1,"38":1,"39":1,"495":1}}],["levels",{"2":{"724":1}}],["leveldb",{"2":{"380":1}}],["level",{"2":{"6":1,"59":1,"122":1,"124":1,"137":1,"199":1,"215":1,"276":1,"429":2,"630":1,"681":1,"724":1}}],["lessons",{"2":{"32":1}}],["less",{"2":{"23":1,"24":1,"169":1,"183":1,"483":1,"524":1,"578":1,"672":1}}],["leapwallet",{"2":{"682":1}}],["leap",{"0":{"658":1,"659":1,"783":1},"1":{"659":1,"660":1,"661":1},"2":{"651":1,"680":1,"781":1,"783":3}}],["leave",{"2":{"602":1}}],["leaves",{"2":{"118":2,"156":6,"159":2,"649":1}}],["leaving",{"2":{"483":1}}],["leafs",{"2":{"644":1}}],["leaf",{"2":{"142":2,"147":2,"152":2,"159":2}}],["least",{"2":{"23":1,"35":1,"39":1,"82":1,"84":1,"211":1,"279":2,"371":1,"449":1,"544":1,"631":1,"641":1,"643":1,"650":2}}],["lead",{"2":{"13":1,"14":1,"37":1}}],["leaders",{"2":{"6":1,"8":2,"10":2,"11":1,"12":1}}],["learned",{"2":{"32":1,"298":1,"305":1,"563":1}}],["learning",{"2":{"3":1,"7":1,"40":1,"42":2,"457":1,"571":1}}],["learn",{"2":{"3":1,"40":1,"46":1,"50":1,"63":1,"73":1,"79":1,"81":2,"86":1,"94":1,"107":1,"113":1,"125":1,"137":1,"163":1,"227":1,"236":1,"250":1,"251":1,"261":1,"283":1,"297":1,"304":1,"311":1,"312":2,"341":1,"343":1,"388":1,"404":1,"433":1,"484":1,"495":1,"498":1,"513":1,"522":1,"528":1,"531":1,"545":1,"554":1,"555":1,"558":1,"562":1,"565":1,"571":1,"578":1,"586":1,"595":1,"598":1,"651":1,"668":1,"674":2,"677":2,"678":1,"689":1,"690":1,"704":1,"714":1,"716":1,"717":1,"725":1,"738":1,"746":1,"763":2}}],["lost",{"2":{"334":1,"391":1}}],["lose",{"2":{"281":1,"308":1}}],["loses",{"2":{"23":1}}],["locked",{"2":{"680":1,"782":2}}],["lock",{"2":{"328":1,"582":1}}],["located",{"2":{"127":1,"247":1,"322":1,"424":1,"469":1}}],["locate",{"2":{"125":1,"476":1}}],["locations",{"2":{"342":1}}],["location",{"0":{"327":1},"1":{"328":1,"329":1,"330":1,"331":1,"332":1,"333":1},"2":{"23":1,"26":1,"35":2,"58":1,"125":2,"127":1,"128":1,"172":1,"173":1,"174":3,"187":1,"260":4,"287":1,"322":1,"329":10,"343":1,"349":1,"450":1,"464":1,"742":1}}],["localroot",{"2":{"705":1}}],["localheadheight",{"2":{"558":1}}],["localhost",{"2":{"92":1,"93":3,"143":2,"144":2,"274":2,"275":4,"313":3,"326":3,"377":2,"475":6,"476":4,"477":4,"536":2,"537":2,"602":2,"707":2,"739":1,"765":1,"773":2,"776":2}}],["localized",{"2":{"158":1}}],["locally",{"2":{"81":1,"203":2,"212":1,"289":1,"320":1,"588":1}}],["local",{"0":{"211":1,"217":1,"284":1,"285":1,"472":1},"1":{"285":1,"286":2,"287":2,"288":2,"289":2,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"473":1,"474":1,"475":1,"476":1,"477":1},"2":{"2":1,"34":1,"36":1,"37":2,"38":2,"39":3,"40":2,"47":1,"77":1,"79":1,"81":1,"87":1,"93":1,"94":1,"208":2,"211":5,"217":2,"235":1,"263":2,"283":1,"288":1,"291":2,"292":4,"297":1,"298":1,"305":1,"312":1,"320":1,"342":1,"343":2,"361":2,"371":1,"383":4,"392":2,"393":2,"399":21,"472":1,"505":1,"584":2,"614":1,"625":4,"699":1,"705":1,"779":2}}],["loop",{"2":{"211":1}}],["looks",{"2":{"86":1,"745":1}}],["looking",{"2":{"42":1,"81":2,"93":1,"160":1,"227":1,"251":1,"371":1,"387":1,"388":1,"537":1,"765":1}}],["look",{"2":{"40":1,"92":1,"104":1,"122":1,"124":1,"144":2,"161":4,"163":2,"202":1,"294":1,"314":2,"337":1,"392":1,"393":1,"450":1,"476":1,"536":1,"537":1,"538":1,"641":1,"646":1,"650":1,"704":1,"705":1,"735":1,"742":1,"745":1,"748":1,"755":1}}],["load",{"2":{"77":1,"379":1,"380":1,"381":1,"597":2,"698":1,"769":2,"770":3,"771":2}}],["logfile",{"2":{"343":1}}],["log=debug",{"2":{"215":2}}],["log",{"2":{"147":2,"275":1,"294":2,"322":1,"336":1,"337":2,"343":2,"373":1,"429":2,"569":1,"614":2,"620":3,"765":1,"769":2}}],["logging",{"2":{"95":1}}],["logged",{"2":{"90":1}}],["logsbloom",{"2":{"536":2}}],["logs",{"0":{"271":1},"2":{"79":1,"93":1,"210":1,"211":1,"271":7,"294":2,"331":1,"337":1,"371":1,"539":1,"540":1,"557":1,"559":1,"602":1,"604":1,"605":1,"606":1,"614":2,"620":2}}],["logos",{"2":{"41":1}}],["logo",{"2":{"38":1,"41":1,"52":1,"783":1}}],["login",{"2":{"275":1}}],["logic",{"2":{"109":2,"112":1,"126":1,"179":1,"214":1,"229":2,"238":1,"582":1,"646":1}}],["logical",{"2":{"37":1}}],["logistics",{"0":{"33":1,"57":1},"1":{"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1},"2":{"30":1,"33":1,"37":1}}],["lowers",{"2":{"86":1}}],["lower",{"2":{"86":2}}],["low",{"2":{"26":1,"137":1,"400":1,"454":1,"607":1,"782":2,"784":1}}],["lot",{"2":{"26":1,"33":1,"34":1,"51":1,"199":1}}],["longer",{"2":{"86":1,"277":1,"544":1,"627":1,"643":1,"688":1,"720":1}}],["long",{"2":{"22":1,"87":1,"641":1,"671":1,"672":1,"675":1}}],["love",{"2":{"2":1,"42":1}}],["ll",{"2":{"0":1,"35":1,"50":1,"57":1,"58":1,"76":1,"77":1,"79":1,"84":1,"86":1,"87":1,"94":1,"109":1,"298":1,"329":1,"371":1,"373":1,"383":1,"392":1,"408":1,"446":1,"536":1,"540":3,"555":1,"556":1,"557":2,"558":2,"559":1,"562":4,"563":2,"584":1,"620":1,"625":1,"627":1,"704":1,"705":1,"738":1,"763":4,"773":1,"783":1,"784":1}}],["wget",{"2":{"378":2,"398":10,"399":8}}],["wsl",{"2":{"396":2}}],["ws",{"2":{"254":1,"429":4,"490":2,"707":2,"773":2,"776":2}}],["wss",{"0":{"254":1},"2":{"90":6,"91":6,"254":1,"490":4}}],["w",{"2":{"214":2,"771":4,"772":2}}],["wrong",{"0":{"336":1,"383":1,"625":1},"2":{"336":2,"383":2,"625":2}}],["wrapped",{"2":{"215":1,"459":1}}],["wrappers",{"2":{"163":2}}],["wrapper",{"2":{"144":4,"161":2,"211":2,"214":4,"215":2}}],["wrapping",{"0":{"773":1},"2":{"126":1}}],["wraps",{"2":{"126":2,"214":1}}],["writing",{"2":{"126":2,"134":1,"567":1,"568":1}}],["write",{"0":{"523":1},"2":{"33":1,"291":2,"523":2,"534":1,"705":1,"763":1}}],["written",{"2":{"12":1,"221":1,"399":1,"455":2}}],["won",{"2":{"90":1,"91":1,"183":1,"208":1,"371":1,"542":1,"550":1}}],["wonderful",{"2":{"33":1}}],["worry",{"2":{"109":1,"388":1}}],["world",{"2":{"43":1,"478":1,"596":4,"708":4,"763":1,"777":4}}],["words",{"2":{"120":1,"174":1,"216":1,"555":1,"562":1,"634":1,"647":1}}],["word",{"2":{"36":1,"39":1}}],["workshop",{"0":{"53":1,"54":1,"55":1,"56":1}}],["workshops",{"2":{"34":1,"37":1}}],["works",{"0":{"234":1},"2":{"35":2,"96":1,"295":1,"321":1,"589":1,"591":1,"592":1,"630":1,"674":1,"689":1}}],["working",{"0":{"444":1,"445":1},"2":{"30":1,"34":2,"274":1,"341":1,"413":1,"444":1,"456":1,"564":1,"697":2}}],["work",{"2":{"21":1,"23":1,"35":1,"68":1,"122":1,"134":1,"169":1,"371":1,"524":1,"577":1,"644":1,"718":1,"765":1}}],["wouldn",{"2":{"632":1}}],["would",{"2":{"34":1,"39":1,"42":5,"63":1,"104":1,"122":1,"124":1,"126":9,"127":1,"130":3,"183":2,"185":1,"191":2,"194":1,"203":1,"225":1,"226":1,"266":1,"284":1,"294":1,"314":1,"326":1,"361":1,"373":1,"388":1,"390":2,"425":1,"484":1,"499":2,"540":1,"584":1,"707":1,"726":1,"731":2,"736":1,"742":1,"755":1,"776":1,"782":1}}],["www",{"2":{"16":3,"64":1,"485":1,"503":1}}],["walks",{"2":{"472":1}}],["walkthrough",{"0":{"394":1},"1":{"395":1}}],["wallet=",{"2":{"614":2,"620":2}}],["wallets",{"0":{"430":1,"466":1,"736":1},"1":{"467":1},"2":{"308":1,"430":3,"651":1,"692":1,"781":1}}],["wallet",{"0":{"261":1,"299":1,"306":1,"308":1,"309":1,"613":1,"652":1,"653":1,"658":1,"662":1,"663":1,"695":1,"781":1},"1":{"307":1,"308":1,"309":1,"654":1,"655":1,"656":1,"657":1,"659":1,"660":1,"661":1,"663":1,"664":1,"665":1,"666":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"782":1,"783":1,"784":1},"2":{"77":1,"79":1,"80":1,"82":1,"85":3,"87":2,"202":6,"245":1,"265":1,"266":6,"267":2,"268":2,"269":4,"270":2,"272":1,"306":1,"308":3,"309":2,"367":1,"404":1,"422":1,"431":1,"466":1,"467":2,"522":1,"599":2,"613":1,"614":8,"620":4,"682":2,"683":1,"695":1,"722":1,"724":1,"726":1,"736":5,"782":5,"783":2,"784":2}}],["wanting",{"2":{"724":1}}],["want",{"2":{"202":9,"203":1,"205":1,"208":1,"210":1,"213":1,"219":1,"266":1,"274":2,"308":1,"321":1,"352":2,"361":1,"367":2,"368":2,"373":1,"386":1,"429":1,"439":2,"443":1,"448":1,"499":1,"550":1,"555":1,"557":1,"558":1,"559":2,"562":1,"565":1,"572":1,"578":1,"581":1,"592":1,"597":4,"599":1,"614":2,"620":2,"630":1,"638":1,"698":1,"711":2,"726":1,"738":2,"779":2,"783":1}}],["wantedby=multi",{"2":{"602":2,"604":2,"605":2,"606":2}}],["wanted",{"2":{"147":2,"294":2,"614":2,"620":2}}],["wants",{"2":{"136":1,"443":1}}],["waiting",{"2":{"93":6,"126":1,"128":1,"130":3,"171":2,"597":2,"765":1}}],["wait",{"2":{"91":1,"109":1,"130":1,"163":2,"211":1,"309":1,"592":1,"597":2,"660":1,"765":1}}],["watchopts",{"2":{"162":2}}],["watchdatacommitmentstored",{"2":{"162":3}}],["watch",{"2":{"40":1}}],["water",{"2":{"35":2}}],["warn\\tnode\\tnodebuilder",{"2":{"557":2}}],["warn",{"2":{"277":1}}],["warning",{"0":{"13":1},"2":{"12":1,"13":1,"60":1,"65":1,"69":1,"91":1,"152":1,"153":1,"326":1,"338":1,"456":1,"485":1,"487":1,"503":1,"510":1,"528":1,"726":1,"731":1}}],["warehouse",{"2":{"64":1,"485":1,"503":1}}],["warm",{"2":{"39":1}}],["way",{"2":{"38":1,"60":1,"84":1,"110":1,"140":1,"166":1,"169":2,"170":1,"171":1,"172":1,"183":2,"191":1,"199":1,"203":2,"204":1,"266":1,"275":1,"291":2,"308":1,"312":1,"342":1,"388":2,"457":1,"459":1,"461":1,"562":1,"637":1,"640":1,"720":1,"725":2,"763":1}}],["ways",{"2":{"6":1,"165":1,"230":1,"455":1,"498":1,"513":1,"531":1,"554":1,"571":1,"580":1,"593":1,"721":1,"725":1}}],["wasm",{"2":{"96":1}}],["was",{"0":{"144":1},"2":{"12":1,"81":1,"83":1,"93":5,"111":1,"121":1,"122":5,"124":1,"128":1,"130":1,"136":1,"137":1,"139":2,"144":6,"154":6,"155":1,"160":7,"163":2,"164":1,"168":2,"174":1,"180":1,"186":1,"187":1,"191":1,"194":1,"204":2,"205":1,"208":1,"214":1,"215":2,"233":1,"287":1,"289":1,"311":1,"331":1,"372":1,"383":1,"399":1,"431":1,"455":1,"462":1,"530":1,"578":1,"596":2,"597":4,"602":1,"604":1,"605":1,"606":1,"614":1,"625":1,"627":1,"644":1,"649":1,"650":1,"704":1,"708":3,"743":1,"745":2,"746":1,"771":1,"777":3}}],["windows",{"2":{"389":1,"396":2}}],["window",{"2":{"281":1,"426":1,"607":1,"608":1,"609":1,"671":5,"704":1,"705":1,"765":1,"782":8}}],["wise",{"2":{"649":1}}],["wish",{"2":{"216":1,"227":1,"588":1,"592":1,"672":1}}],["wisdom",{"2":{"50":1}}],["wiki",{"2":{"8":1}}],["willingness",{"2":{"592":1}}],["willing",{"2":{"590":1,"722":1}}],["will",{"2":{"8":2,"10":1,"11":1,"20":2,"21":2,"22":3,"23":2,"25":2,"26":1,"27":1,"28":1,"34":1,"35":1,"36":2,"37":1,"38":1,"41":1,"42":3,"44":1,"46":1,"47":2,"60":2,"63":1,"67":1,"68":2,"74":1,"79":1,"80":2,"81":2,"84":1,"85":2,"86":1,"87":2,"88":1,"90":3,"91":3,"92":3,"93":1,"104":1,"105":2,"109":5,"117":2,"124":1,"125":1,"126":3,"130":1,"136":1,"139":1,"140":1,"141":1,"144":2,"145":1,"152":1,"153":1,"154":5,"156":1,"161":2,"163":4,"165":1,"166":2,"168":1,"169":4,"171":1,"172":1,"174":4,"175":2,"183":1,"186":1,"187":1,"188":1,"190":1,"191":2,"193":1,"194":3,"200":1,"202":2,"203":2,"204":5,"208":1,"210":3,"214":1,"215":3,"216":1,"219":2,"221":1,"228":4,"235":3,"237":1,"243":1,"244":1,"245":2,"263":3,"266":1,"275":6,"279":2,"281":8,"283":1,"287":3,"290":1,"291":1,"294":2,"295":1,"296":1,"297":2,"301":3,"302":1,"303":1,"306":1,"310":1,"311":4,"312":3,"314":3,"315":1,"316":3,"321":3,"324":2,"326":1,"329":1,"331":2,"332":1,"334":1,"337":1,"338":2,"341":2,"342":2,"343":1,"349":1,"355":1,"361":1,"363":1,"367":1,"368":3,"370":2,"371":1,"375":1,"380":2,"381":2,"391":4,"392":1,"393":1,"397":1,"399":1,"404":4,"405":1,"413":1,"414":1,"422":2,"426":1,"429":1,"430":1,"438":1,"440":1,"441":1,"442":1,"445":2,"446":1,"449":3,"450":3,"458":2,"464":2,"466":2,"475":1,"476":1,"479":2,"484":1,"492":1,"493":1,"499":1,"504":1,"505":1,"516":1,"518":1,"524":1,"528":4,"536":1,"537":1,"538":1,"539":1,"540":2,"542":1,"543":1,"544":1,"550":1,"552":1,"555":1,"557":2,"558":1,"559":1,"566":1,"572":1,"580":2,"586":2,"587":1,"592":3,"597":4,"599":1,"602":1,"604":1,"605":2,"606":3,"607":1,"610":1,"614":1,"620":2,"627":2,"628":1,"630":1,"631":1,"637":1,"638":1,"650":1,"651":1,"654":1,"656":1,"657":1,"661":1,"666":1,"669":1,"670":1,"671":5,"672":2,"674":1,"679":1,"680":4,"692":1,"695":2,"697":1,"698":4,"704":1,"705":2,"706":1,"707":1,"709":2,"710":2,"720":3,"726":1,"728":1,"731":1,"734":1,"735":1,"736":2,"737":2,"738":1,"739":1,"740":3,"741":1,"742":1,"743":5,"745":6,"746":3,"748":1,"749":1,"752":3,"755":1,"760":3,"765":4,"766":1,"768":1,"769":2,"770":2,"771":3,"773":3,"775":1,"776":1,"778":4,"782":4,"783":1,"784":1}}],["withcancel",{"2":{"770":2,"771":2,"773":2}}],["withfeegranteraddress",{"2":{"708":1}}],["withsigneraddress",{"2":{"708":1}}],["withkeyname",{"2":{"708":1}}],["withgas",{"2":{"708":1}}],["withgasprice",{"2":{"708":2}}],["withheld",{"2":{"628":1}}],["withhold",{"2":{"628":1,"650":1}}],["withholding",{"2":{"628":1}}],["withtransportcredentials",{"2":{"597":2}}],["withdraw",{"0":{"79":1},"2":{"268":2}}],["withdrawalsroot",{"2":{"536":2}}],["withdrawals",{"2":{"86":1}}],["withdrawal",{"0":{"78":1,"80":1},"1":{"79":1,"80":1},"2":{"23":1,"74":2,"79":2,"80":2}}],["within",{"2":{"9":1,"15":1,"20":1,"23":4,"34":1,"37":1,"44":1,"58":1,"86":1,"396":1,"607":1,"608":1,"668":1,"671":3,"738":1}}],["without",{"2":{"7":1,"90":1,"109":1,"137":1,"170":1,"294":1,"388":1,"390":1,"402":1,"406":1,"494":1,"542":1,"580":1,"629":1,"630":1,"640":1,"648":1,"672":1,"680":1,"707":1,"741":1,"776":1}}],["with",{"0":{"66":1,"94":1,"105":1,"106":1,"114":1,"123":1,"228":1,"229":1,"246":1,"248":1,"250":1,"271":1,"283":1,"306":1,"391":1,"423":1,"425":1,"468":1,"470":1,"516":1,"517":1,"540":1,"560":1,"566":1,"600":1,"602":1,"619":1,"653":1,"658":1,"662":1,"695":1,"744":1,"781":1,"782":1},"1":{"67":1,"68":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"229":1,"230":1,"231":1,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"392":1,"393":1,"424":1,"469":1,"518":1,"519":1,"541":1,"542":1,"543":1,"544":1,"545":1,"561":1,"562":1,"563":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1,"654":1,"655":1,"656":1,"657":1,"659":1,"660":1,"661":1,"663":1,"664":1,"665":1,"666":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"782":1,"783":1,"784":1},"2":{"1":1,"2":1,"3":3,"13":3,"14":3,"23":2,"24":1,"25":1,"26":2,"30":2,"31":1,"32":2,"34":5,"36":5,"37":7,"38":2,"39":2,"40":5,"41":3,"42":1,"43":1,"44":1,"47":1,"48":2,"49":1,"55":1,"57":1,"58":1,"59":1,"60":1,"65":3,"68":4,"70":1,"81":1,"82":1,"84":1,"86":2,"87":1,"90":2,"91":2,"93":6,"96":5,"103":1,"104":2,"107":1,"108":2,"109":3,"110":2,"111":2,"112":1,"122":3,"126":3,"130":1,"134":1,"136":1,"139":1,"142":1,"144":2,"147":1,"150":1,"152":1,"156":2,"157":1,"158":1,"159":1,"160":6,"161":2,"163":2,"164":1,"165":1,"166":1,"172":1,"175":1,"178":1,"183":1,"202":1,"203":1,"208":1,"210":1,"214":1,"216":1,"217":1,"218":2,"219":1,"221":2,"225":1,"227":3,"228":1,"229":3,"231":1,"233":3,"238":3,"244":2,"245":2,"248":2,"249":3,"250":1,"252":2,"254":1,"260":2,"266":6,"268":1,"269":2,"270":1,"271":1,"275":5,"277":1,"278":1,"279":2,"281":1,"287":1,"294":2,"304":1,"309":1,"310":1,"311":1,"312":2,"313":1,"314":2,"316":1,"322":1,"325":1,"326":1,"329":3,"334":1,"335":1,"338":2,"341":2,"342":1,"355":1,"361":1,"363":1,"367":1,"373":1,"377":1,"383":1,"385":3,"390":1,"393":1,"396":1,"400":2,"402":1,"403":2,"404":2,"405":1,"422":4,"425":1,"428":1,"430":1,"437":1,"439":2,"443":1,"446":1,"448":3,"449":2,"450":2,"452":4,"453":1,"454":2,"455":2,"457":1,"459":1,"461":1,"465":2,"466":3,"470":1,"471":1,"472":1,"476":1,"479":2,"483":1,"485":1,"487":1,"493":2,"503":1,"506":1,"507":2,"508":1,"510":1,"515":1,"516":1,"518":1,"522":1,"524":2,"526":1,"528":1,"536":1,"540":2,"542":1,"544":4,"545":1,"552":1,"558":1,"559":1,"563":1,"564":1,"565":1,"567":1,"568":1,"571":1,"575":1,"578":1,"581":1,"582":2,"584":1,"586":1,"587":1,"590":1,"592":2,"599":1,"607":1,"615":1,"619":2,"620":1,"625":2,"628":1,"632":1,"633":1,"634":1,"639":1,"641":2,"642":1,"643":6,"644":2,"646":1,"647":1,"648":1,"649":4,"650":3,"654":1,"668":1,"669":1,"674":1,"681":1,"689":1,"693":1,"695":1,"698":1,"703":1,"704":3,"705":5,"706":1,"708":2,"709":2,"710":2,"714":1,"715":1,"717":1,"718":1,"721":2,"724":2,"725":2,"735":3,"736":4,"737":1,"738":5,"739":1,"740":3,"741":2,"742":2,"743":2,"745":1,"748":1,"755":1,"760":2,"762":1,"763":2,"765":2,"766":2,"769":2,"770":5,"771":6,"773":6,"774":1,"775":1,"777":2}}],["whole",{"2":{"641":1}}],["whom",{"2":{"151":1}}],["whose",{"2":{"147":1,"202":2}}],["who",{"0":{"638":1},"2":{"21":1,"23":1,"37":1,"39":2,"40":3,"58":1,"250":1,"443":1,"450":1,"550":1,"722":1,"726":1,"742":1}}],["whitelist",{"0":{"206":1},"2":{"205":1,"206":3}}],["whitelisting",{"0":{"205":1},"2":{"202":1,"205":2,"584":1}}],["whitelisted",{"2":{"202":1}}],["whiteboard",{"2":{"34":1}}],["whiteboards",{"2":{"30":1,"34":1}}],["while",{"2":{"18":1,"35":1,"93":1,"156":1,"165":1,"221":1,"227":1,"322":1,"337":4,"455":2,"479":1,"540":1,"547":1,"642":1,"647":1,"650":1,"672":1,"695":1,"715":1,"720":1,"755":1,"765":1,"778":2}}],["which",{"0":{"384":1},"1":{"385":1,"386":1,"387":1},"2":{"7":1,"26":1,"35":1,"41":1,"42":1,"63":1,"85":1,"86":3,"88":1,"90":2,"91":1,"92":1,"97":1,"104":1,"108":1,"109":1,"110":3,"111":3,"112":2,"122":1,"125":1,"126":2,"128":1,"137":2,"139":4,"141":1,"142":1,"147":1,"149":1,"151":1,"152":1,"154":2,"156":2,"157":1,"158":1,"160":5,"166":1,"168":1,"174":1,"179":1,"180":1,"184":1,"187":1,"191":1,"193":1,"194":1,"199":1,"202":3,"204":3,"205":1,"206":3,"211":2,"213":2,"214":3,"215":2,"218":1,"219":1,"221":2,"224":1,"225":1,"234":1,"235":1,"243":1,"244":1,"245":1,"266":1,"275":2,"309":1,"311":1,"314":1,"321":1,"324":1,"370":1,"377":2,"380":2,"384":1,"387":1,"390":1,"414":1,"422":2,"427":1,"428":1,"438":1,"450":2,"452":1,"453":1,"455":1,"458":1,"465":2,"483":4,"484":1,"499":1,"507":3,"524":3,"525":1,"526":1,"539":1,"562":1,"566":1,"589":1,"602":2,"604":2,"605":2,"606":2,"617":1,"622":1,"628":1,"636":1,"637":1,"647":1,"668":2,"672":1,"674":1,"690":1,"698":1,"704":1,"708":1,"715":1,"721":1,"725":1,"726":1,"735":1,"743":4,"745":4,"746":1,"748":1,"771":2,"772":1}}],["why",{"0":{"632":1,"637":1},"2":{"12":1,"26":1,"42":5,"58":1,"214":1,"524":1}}],["whenever",{"2":{"39":1,"400":1,"499":1}}],["when",{"2":{"8":1,"9":1,"36":1,"42":1,"44":1,"58":1,"90":1,"91":2,"109":2,"137":1,"139":1,"144":2,"157":1,"161":2,"163":2,"169":1,"175":1,"179":1,"186":1,"187":2,"205":1,"214":1,"219":1,"266":1,"274":2,"275":2,"313":1,"320":1,"325":1,"326":1,"329":1,"331":1,"332":1,"333":1,"337":2,"361":2,"378":1,"380":2,"392":1,"408":1,"449":1,"455":1,"467":1,"544":1,"556":1,"558":2,"564":1,"565":1,"566":1,"590":1,"591":1,"627":2,"628":1,"644":1,"680":1,"704":1,"707":1,"714":1,"736":1,"738":1,"739":1,"776":1}}],["whereas",{"2":{"86":1}}],["where",{"0":{"636":1},"2":{"7":1,"70":1,"109":2,"110":1,"127":1,"147":1,"154":2,"158":1,"201":1,"210":1,"211":1,"238":1,"261":1,"303":2,"333":1,"338":1,"426":1,"467":1,"478":1,"510":1,"558":1,"584":1,"586":1,"588":1,"589":1,"590":1,"607":1,"632":1,"643":1,"649":1,"657":1,"661":1,"666":1,"671":1,"672":3,"734":1,"736":1,"738":1,"763":1,"765":1}}],["whether",{"2":{"2":1,"36":1,"381":1,"607":1,"628":1,"634":1,"640":1,"782":3}}],["whatever",{"2":{"308":1,"571":1}}],["what",{"0":{"221":1,"227":1,"233":1,"577":1,"578":1,"627":1,"628":1,"630":1,"631":1,"633":1,"634":1,"635":1,"639":1},"1":{"222":1},"2":{"7":1,"21":1,"42":4,"53":1,"54":1,"55":1,"59":1,"79":1,"87":1,"124":1,"127":1,"130":1,"174":1,"211":2,"312":1,"316":1,"343":1,"399":1,"556":1,"572":1,"670":1,"742":1,"745":1,"755":1,"773":2}}],["went",{"2":{"614":1}}],["weak",{"2":{"371":1,"634":1}}],["we+s5gft6g944xbkvvygqb9oy+u",{"2":{"291":2,"292":2}}],["weth",{"2":{"93":2}}],["week",{"2":{"70":1,"510":1,"526":1,"528":1}}],["weeks",{"2":{"39":1,"208":1,"369":1,"370":1}}],["webrtc",{"2":{"476":10}}],["webhook",{"2":{"277":1}}],["websocket",{"0":{"490":1},"2":{"90":5,"136":2,"143":2,"144":2,"429":4,"490":4}}],["websites",{"2":{"497":1,"511":1}}],["website",{"2":{"26":1,"40":1,"90":1,"782":2}}],["web",{"0":{"71":1},"2":{"71":1,"275":1}}],["web3",{"2":{"42":1,"44":1}}],["were",{"2":{"16":1,"122":5,"154":6,"155":1,"216":1,"227":1,"680":1,"774":1}}],["well",{"2":{"13":1,"34":1,"35":2,"58":2,"109":1,"110":1,"202":1,"422":1,"428":1,"540":1,"582":1,"670":1,"718":1,"722":1}}],["welcoming",{"2":{"6":1,"34":1,"46":1}}],["welcome",{"2":{"0":1,"20":1,"31":1,"41":2,"42":1,"43":1,"48":1,"51":1,"478":1,"555":1,"763":1}}],["we",{"2":{"2":1,"4":1,"6":2,"23":1,"34":1,"42":8,"46":2,"58":2,"59":1,"85":2,"86":1,"90":1,"105":1,"109":1,"117":2,"122":1,"125":4,"126":3,"127":1,"130":4,"137":1,"139":5,"141":1,"144":2,"145":1,"154":5,"155":2,"156":6,"159":1,"161":2,"163":4,"164":1,"169":1,"172":1,"173":1,"174":4,"175":5,"186":1,"202":4,"204":4,"205":1,"208":2,"209":2,"210":10,"211":1,"214":1,"215":1,"266":2,"275":1,"277":2,"283":1,"287":1,"297":1,"298":2,"301":4,"306":1,"308":1,"316":1,"321":1,"329":1,"344":2,"350":1,"375":1,"392":2,"399":1,"429":1,"430":2,"432":1,"434":1,"435":2,"445":2,"446":1,"456":1,"479":1,"499":1,"505":1,"536":1,"544":2,"555":1,"556":1,"559":2,"561":2,"562":2,"566":2,"581":1,"584":1,"592":1,"597":12,"605":1,"670":1,"697":1,"704":1,"705":2,"709":1,"710":1,"714":1,"715":2,"716":1,"717":1,"719":1,"720":1,"728":1,"738":1,"743":6,"745":2,"748":1,"752":1,"760":1,"763":1,"765":3,"769":4,"770":8,"771":26,"772":1,"773":11,"778":3,"782":5}}],["dns",{"2":{"760":1}}],["dns4",{"2":{"65":4}}],["d85c907ce660878a8203ac74baa147ccc1f87114b45b568b72ad207b62afe45e",{"2":{"752":2}}],["d6",{"2":{"644":1}}],["d5",{"2":{"644":2}}],["d4",{"2":{"644":2}}],["d3",{"2":{"644":1}}],["dynamic",{"2":{"581":1,"589":1,"590":1}}],["dl",{"2":{"399":8}}],["db",{"2":{"383":1,"625":1}}],["dbs",{"2":{"383":1,"625":1}}],["dbbackend",{"2":{"380":1}}],["d7wrs",{"2":{"147":2}}],["dcproof",{"2":{"143":2,"144":2}}],["dfcelestia",{"2":{"104":1}}],["drop",{"2":{"592":1,"679":1}}],["dropped",{"2":{"592":1}}],["dropdown",{"2":{"76":1}}],["drafted",{"2":{"482":1}}],["drawing",{"2":{"50":1}}],["drift",{"2":{"429":4}}],["drinks",{"2":{"35":4}}],["d",{"2":{"41":2,"91":1,"92":1,"130":4,"283":1,"288":1,"294":2,"372":6,"538":2,"540":1,"596":2,"679":1,"680":2,"708":2,"709":4,"710":4,"755":1,"761":1,"771":4}}],["dah",{"2":{"752":2,"753":2,"758":2}}],["daemon",{"2":{"328":1,"337":3,"600":1,"602":6,"604":3,"605":3,"606":4,"615":1}}],["darwin",{"2":{"312":1,"342":1,"399":12}}],["daring",{"2":{"291":2}}],["dac",{"2":{"225":1,"226":1}}],["dacs",{"0":{"223":1},"1":{"224":1,"225":1,"226":1},"2":{"224":1,"226":2}}],["daverifier",{"0":{"154":1,"163":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1},"2":{"122":3,"154":1,"163":11,"174":1}}],["daser",{"2":{"338":1,"558":1}}],["das",{"0":{"641":1},"1":{"642":1,"643":1},"2":{"110":1,"221":1,"458":1,"459":1,"555":2,"556":1,"559":1,"606":1,"630":1,"640":2,"641":2,"642":4,"643":1,"650":4,"754":2}}],["dashboard",{"2":{"68":1,"275":5,"321":1,"493":2,"654":2,"655":1,"657":1,"661":1}}],["dashboards",{"2":{"23":1,"275":1,"620":1,"674":1}}],["dao",{"2":{"86":1}}],["da",{"0":{"66":1,"67":1,"68":1,"106":1,"109":1,"220":1,"386":1,"492":1,"493":1,"494":1,"502":1,"504":1,"505":1,"645":1},"1":{"67":1,"68":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1,"495":1,"503":1,"504":1,"505":1,"646":1},"2":{"65":5,"67":1,"68":5,"91":3,"96":1,"105":1,"108":2,"109":1,"112":1,"113":1,"124":1,"126":4,"127":1,"130":1,"178":2,"186":1,"221":2,"227":3,"238":1,"250":1,"338":1,"349":1,"386":1,"400":1,"403":1,"404":4,"454":1,"455":8,"458":1,"459":1,"477":2,"492":1,"493":7,"494":1,"504":1,"505":2,"509":8,"538":2,"540":1,"543":1,"544":1,"545":1,"555":2,"559":2,"562":3,"563":2,"566":1,"571":1,"640":3,"642":2,"644":4,"646":3,"647":6,"650":5,"696":1,"714":1,"722":2,"724":2,"726":1,"730":1}}],["day",{"2":{"39":1,"671":2}}],["days",{"2":{"35":1,"281":1,"671":2}}],["dat2024",{"2":{"214":1}}],["dat",{"2":{"214":31}}],["database",{"2":{"569":2}}],["datastore",{"0":{"322":1},"2":{"322":5}}],["datasharelen",{"2":{"125":4}}],["datasharestart",{"2":{"125":4}}],["datalen",{"2":{"172":2,"174":1}}],["datahash",{"2":{"144":2,"163":2}}],["datacommitmentstored",{"2":{"208":1,"219":1}}],["datacommitment",{"2":{"144":2,"161":2}}],["datarootinclusionproof",{"2":{"143":2,"144":2,"160":9,"163":10}}],["dataroot",{"2":{"118":4,"139":2,"144":2,"160":5,"163":2}}],["dataroottupleroot",{"2":{"141":1}}],["dataroottuples",{"2":{"119":5,"120":1}}],["dataroottuple",{"2":{"118":4,"119":2,"120":1,"122":1,"141":1,"144":2,"154":2,"160":7,"163":2}}],["dataavailabilityprovider",{"2":{"109":2}}],["data",{"0":{"67":1,"68":1,"119":1,"122":1,"127":1,"133":1,"141":1,"155":1,"162":1,"174":1,"175":1,"199":1,"216":1,"223":1,"335":1,"365":1,"471":1,"491":1,"492":1,"493":1,"504":1,"505":1,"533":1,"537":1,"538":1,"560":1,"562":1,"563":1,"585":1,"603":1,"626":1,"627":1,"628":1,"629":1,"630":1,"631":1,"633":1,"634":1,"635":2,"637":1,"638":1,"639":1,"640":1,"641":1,"643":1,"646":1,"650":1,"670":1,"671":1,"711":1,"743":1,"745":1,"754":1,"779":1},"1":{"142":1,"143":1,"217":1,"218":1,"219":1,"224":1,"225":1,"226":1,"492":1,"493":1,"494":1,"495":1,"561":1,"562":1,"563":1,"586":1,"587":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"604":1,"605":1,"606":1,"627":1,"628":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"641":1,"642":2,"643":2,"644":1,"645":1,"646":1,"671":1,"672":1,"744":1},"2":{"26":1,"37":1,"42":1,"53":1,"64":1,"65":1,"81":1,"85":5,"90":3,"91":1,"107":2,"109":10,"110":8,"111":5,"112":6,"118":5,"119":1,"120":1,"121":1,"122":8,"124":2,"125":31,"126":7,"127":7,"128":16,"130":10,"133":1,"136":1,"137":5,"139":9,"141":6,"142":2,"144":10,"145":3,"147":5,"149":1,"151":3,"152":2,"154":14,"155":2,"157":1,"158":1,"159":1,"160":31,"162":2,"163":14,"164":3,"165":4,"167":2,"168":8,"169":3,"170":2,"172":9,"173":1,"174":7,"175":19,"178":2,"179":7,"180":1,"182":2,"183":3,"186":2,"187":8,"190":1,"191":5,"194":5,"199":6,"214":9,"221":3,"224":2,"225":4,"226":2,"227":5,"228":1,"231":1,"233":1,"237":1,"238":3,"250":2,"252":1,"275":4,"294":2,"315":1,"316":1,"321":2,"322":7,"332":2,"335":1,"336":1,"337":4,"342":1,"363":1,"365":2,"368":3,"369":2,"372":19,"375":1,"376":2,"383":1,"385":3,"391":3,"400":2,"402":1,"412":1,"414":1,"415":1,"454":2,"455":14,"458":2,"459":1,"479":1,"485":1,"494":5,"499":1,"503":1,"531":5,"537":1,"540":5,"542":2,"555":6,"558":1,"559":1,"561":1,"562":6,"563":11,"569":3,"578":3,"581":2,"585":2,"594":2,"595":2,"597":8,"598":1,"599":2,"606":1,"614":2,"615":2,"620":2,"625":2,"627":11,"628":7,"629":7,"630":9,"631":2,"632":6,"633":4,"634":6,"635":4,"636":3,"637":9,"638":4,"639":6,"640":5,"641":11,"642":3,"643":11,"644":14,"646":5,"647":2,"648":6,"649":15,"650":9,"668":9,"670":7,"671":7,"672":12,"687":1,"688":1,"711":1,"717":3,"718":1,"728":2,"730":1,"731":3,"734":1,"743":9,"745":10,"752":2,"760":4,"763":3,"769":2,"770":2,"771":5,"773":5,"777":2,"779":1}}],["date",{"2":{"25":1,"30":1,"341":1,"530":1}}],["dumps",{"2":{"697":2}}],["dummy",{"2":{"214":3}}],["dubbing",{"2":{"646":1}}],["duty",{"2":{"291":2}}],["dues",{"2":{"41":4}}],["due",{"2":{"23":1,"58":1,"91":1,"324":1,"400":1,"589":1,"592":1,"640":1,"647":1,"650":1,"680":1}}],["duration",{"2":{"22":3,"27":1}}],["during",{"0":{"31":1},"2":{"14":1,"22":1,"24":1,"31":1,"35":1,"38":1,"160":1,"214":1,"227":1,"281":1,"312":1,"322":1,"352":1,"355":1,"373":1,"406":1,"515":1,"524":1,"607":1,"620":1,"631":1}}],["domain",{"2":{"760":1}}],["dos",{"2":{"724":1}}],["double",{"2":{"281":2,"334":1,"556":1}}],["doing",{"2":{"130":1,"156":1,"312":1,"343":1,"535":1,"556":1,"578":1}}],["downside",{"2":{"643":1}}],["down",{"2":{"349":1,"526":1,"557":2,"562":1,"563":1,"591":1,"697":1,"783":1,"784":1}}],["downtime",{"2":{"112":1,"281":1,"400":2}}],["downloads",{"2":{"275":1,"341":1,"369":4,"372":1}}],["downloading",{"0":{"130":1},"2":{"130":1,"203":1,"398":1,"629":1,"643":2}}],["downloaded",{"0":{"213":1},"1":{"214":1,"215":1},"2":{"88":1,"89":1,"203":2,"211":1,"213":1,"214":1,"215":2,"369":1,"628":1,"672":1}}],["download",{"0":{"88":1},"2":{"87":1,"88":3,"126":1,"130":10,"203":2,"211":1,"214":16,"239":1,"284":1,"312":1,"342":1,"343":1,"357":1,"361":7,"369":1,"383":1,"399":1,"416":1,"460":1,"505":2,"611":1,"625":1,"627":3,"629":2,"630":1,"640":2,"641":1,"642":3,"643":1,"644":1,"646":1,"672":1,"720":1,"731":1,"732":1,"768":1}}],["do",{"0":{"629":1,"639":1},"2":{"42":1,"60":1,"65":1,"68":1,"84":1,"124":1,"159":1,"199":1,"204":1,"210":1,"216":1,"244":1,"245":1,"275":2,"307":1,"321":1,"322":2,"324":1,"368":1,"371":1,"377":1,"396":1,"400":1,"422":1,"426":1,"430":1,"432":1,"439":1,"444":1,"485":1,"487":1,"503":1,"505":1,"528":1,"558":2,"578":1,"588":1,"606":1,"629":1,"632":1,"670":1,"671":1,"672":1,"698":2,"704":1,"717":1,"735":1,"736":1,"770":1,"783":1}}],["dont",{"2":{"558":1}}],["done",{"2":{"93":10,"124":1,"127":1,"145":1,"155":1,"162":2,"175":2,"185":1,"240":1,"266":1,"358":1,"417":1,"443":1,"552":1,"559":2,"592":1,"608":1,"612":1,"709":2,"710":2}}],["don",{"2":{"26":1,"34":1,"39":1,"40":1,"79":1,"109":2,"202":2,"233":1,"299":1,"373":1,"380":1,"432":1,"523":1,"540":1,"580":1,"581":1,"582":1,"597":2,"620":1,"632":1,"637":1,"726":1}}],["docker",{"0":{"388":1,"702":1},"1":{"389":1,"390":1,"391":1,"392":1,"393":1,"394":1,"395":1,"396":1,"703":1,"704":1,"705":1},"2":{"82":2,"91":7,"92":2,"388":7,"389":4,"391":1,"392":2,"393":2,"539":2,"703":2,"704":3,"705":4}}],["docs",{"2":{"23":1,"64":2,"90":1,"104":2,"132":1,"163":1,"168":1,"228":1,"277":1,"280":1,"312":2,"321":1,"343":4,"371":1,"485":2,"503":2,"545":1,"556":2,"598":1}}],["documented",{"2":{"162":1,"208":2}}],["documents",{"2":{"104":2}}],["document",{"2":{"22":1,"32":1,"139":1,"165":1,"200":1,"279":6,"482":1,"515":1,"583":1,"670":1,"713":1}}],["documentation",{"0":{"0":1,"131":1,"712":1,"780":1},"1":{"1":1,"2":1,"3":1,"4":1,"132":1,"133":1,"134":1},"2":{"0":1,"1":1,"3":1,"4":1,"23":1,"31":1,"63":1,"81":1,"95":1,"121":1,"122":1,"126":2,"127":3,"163":1,"175":2,"182":1,"202":1,"203":1,"208":1,"212":1,"217":1,"230":1,"234":1,"235":2,"261":2,"266":1,"274":2,"304":1,"484":1,"562":1,"566":1,"712":1,"716":1,"721":1,"780":1}}],["doesn",{"0":{"637":1},"2":{"136":1,"174":1,"199":1,"414":1,"428":1,"582":1,"739":1,"762":1}}],["does",{"0":{"636":1},"2":{"22":1,"26":1,"59":1,"69":1,"110":1,"201":1,"202":1,"287":1,"322":2,"396":1,"407":1,"408":2,"507":1,"510":1,"531":1,"588":1,"590":1,"592":1,"643":1,"649":1}}],["dimensional",{"2":{"641":1,"643":4,"646":1,"649":1}}],["dir",{"2":{"329":3}}],["directed",{"2":{"422":1,"465":1}}],["directories",{"2":{"322":2,"569":1,"672":1}}],["directory",{"0":{"3":1,"287":1,"444":1,"445":1},"2":{"76":1,"89":1,"94":1,"117":1,"246":1,"247":1,"272":1,"286":1,"287":4,"289":1,"311":1,"322":11,"336":1,"341":1,"343":5,"369":1,"372":1,"383":2,"391":4,"399":1,"423":1,"424":1,"444":2,"450":3,"466":2,"468":1,"469":1,"474":1,"542":1,"556":1,"569":2,"625":3,"697":2,"698":4,"705":5,"736":2,"739":1,"768":1,"769":1}}],["directly",{"0":{"599":1},"2":{"126":1,"130":2,"219":1,"225":1,"588":1,"590":1,"597":2,"599":1,"717":1,"741":1,"782":1}}],["direct",{"2":{"65":2,"68":1,"277":1,"476":10}}],["digest",{"2":{"156":9,"163":4,"214":2}}],["digital",{"2":{"7":1,"715":1}}],["dial",{"2":{"144":2,"161":2,"162":2,"163":2,"333":2,"378":1,"597":2}}],["diagram",{"2":{"139":1,"234":1,"675":1}}],["diagrams",{"2":{"3":1,"137":1}}],["did",{"2":{"42":2,"211":2}}],["difficulty",{"2":{"34":1,"36":1,"536":2}}],["difference",{"0":{"635":1},"2":{"104":1,"130":1,"175":1,"183":2,"194":1}}],["different",{"0":{"516":1,"517":1},"1":{"518":1,"519":1},"2":{"33":1,"63":1,"90":1,"91":1,"122":1,"130":1,"164":1,"173":2,"179":1,"182":1,"186":1,"197":1,"202":5,"216":3,"230":1,"233":1,"255":1,"266":1,"275":1,"301":1,"325":2,"329":2,"371":1,"378":1,"484":1,"515":2,"516":1,"518":1,"519":1,"531":1,"571":1,"572":1,"592":1,"636":2,"647":1,"680":1,"724":1,"765":1,"774":1}}],["differing",{"2":{"7":1}}],["div",{"2":{"782":4}}],["dividing",{"2":{"588":1}}],["divided",{"2":{"22":1,"25":1}}],["diving",{"0":{"564":1},"1":{"565":1,"566":1,"567":1,"568":1,"569":1}}],["dive",{"0":{"535":1},"1":{"536":1,"537":1,"538":1,"539":1},"2":{"535":1}}],["dives",{"2":{"42":1,"53":1}}],["diverse",{"2":{"6":1}}],["disruptions",{"2":{"400":1}}],["disruptive",{"2":{"18":1}}],["disk",{"2":{"239":1,"276":1,"357":1,"381":2,"416":1,"460":1,"533":1,"534":1,"611":1,"732":1}}],["disable",{"2":{"320":2,"752":2}}],["disables",{"2":{"320":1,"380":1}}],["disabled",{"2":{"206":1,"770":2,"771":2,"773":2}}],["disability",{"2":{"6":1}}],["distinguish",{"2":{"86":1}}],["distribution",{"2":{"69":1,"267":2,"268":2,"510":1,"715":1}}],["distributed",{"2":{"647":1}}],["distribute",{"2":{"21":1}}],["disputes",{"2":{"86":1,"647":1}}],["dispute",{"2":{"86":1,"578":1}}],["displaydenom",{"2":{"692":1}}],["displayed",{"2":{"263":1}}],["display",{"0":{"692":1},"2":{"86":1,"745":1}}],["displaying",{"2":{"31":1}}],["disparagement",{"2":{"15":1}}],["disqualify",{"2":{"23":1}}],["discard",{"0":{"381":1},"2":{"109":1,"111":1,"322":1,"381":1,"569":1}}],["disclaimer",{"2":{"79":1}}],["discussed",{"2":{"171":1}}],["discussion",{"2":{"37":2}}],["discussions",{"2":{"31":1,"44":1}}],["discuss",{"2":{"37":1,"40":1,"51":1,"186":1,"670":1}}],["discover",{"2":{"42":1}}],["discovering",{"2":{"37":1,"371":1}}],["discounts",{"2":{"34":1}}],["discord",{"0":{"49":1,"70":1},"2":{"10":1,"26":1,"39":2,"47":3,"48":1,"49":2,"70":2,"309":1,"430":3,"467":1,"498":1,"510":2,"513":1,"554":2,"561":1,"736":2}}],["discretion",{"2":{"24":1}}],["discrepancies",{"2":{"4":1}}],["denoted",{"2":{"649":2}}],["denomination",{"0":{"693":1,"694":1},"2":{"693":2}}],["denominations",{"0":{"691":1},"1":{"692":1,"693":1,"694":1}}],["denominator",{"2":{"429":4}}],["denominated",{"2":{"687":1}}],["denominate",{"2":{"87":1}}],["denom",{"2":{"266":2,"294":4,"295":2,"297":4,"408":2,"409":2,"413":2,"429":4,"748":2,"749":2,"783":1,"784":1}}],["deadbeef",{"2":{"777":2}}],["deadline",{"2":{"23":2,"25":1}}],["deal",{"2":{"650":1}}],["dealing",{"2":{"643":1}}],["derivation",{"2":{"429":4}}],["derogatory",{"2":{"7":1}}],["deducting",{"2":{"588":1}}],["deducted",{"2":{"409":2,"413":2,"588":1}}],["dedicated",{"2":{"23":1,"31":1,"47":1,"249":1,"576":1}}],["debug",{"2":{"260":2,"383":4,"625":4}}],["debugging",{"2":{"92":1,"260":2}}],["demosubmitdata",{"2":{"597":2}}],["demo",{"0":{"124":1},"2":{"122":1,"124":1,"125":1,"126":4,"597":2}}],["demonstration",{"0":{"140":1,"329":1},"1":{"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1},"2":{"446":1}}],["demonstrating",{"2":{"7":1,"15":1}}],["demonstrate",{"2":{"38":1,"782":1}}],["degree",{"2":{"110":1,"111":1}}],["defer",{"2":{"162":4,"597":2}}],["defaultgasprice",{"2":{"596":2,"771":2}}],["defaultestimategas",{"2":{"590":1,"591":2,"597":2}}],["defaults",{"2":{"86":1,"244":1,"266":1,"380":1,"590":1,"735":1}}],["default",{"0":{"516":1},"2":{"67":1,"68":2,"112":2,"202":3,"205":3,"206":2,"216":1,"244":1,"246":1,"247":1,"260":2,"274":2,"275":6,"313":1,"314":1,"324":1,"325":1,"326":1,"328":1,"349":1,"350":1,"352":2,"355":1,"365":3,"368":4,"370":1,"377":1,"380":1,"381":1,"423":1,"424":1,"429":4,"452":1,"468":1,"469":1,"492":1,"493":1,"494":1,"504":1,"505":1,"506":1,"507":1,"508":1,"515":2,"516":2,"523":1,"542":2,"581":1,"587":1,"589":1,"592":1,"596":2,"671":1,"698":3,"707":1,"708":2,"715":1,"735":1,"739":2,"741":1,"746":2,"748":1,"760":1,"771":2,"776":1,"777":3,"782":2}}],["definitions",{"2":{"680":2}}],["defining",{"0":{"125":1},"2":{"126":1}}],["defines",{"2":{"322":1,"620":1}}],["defined",{"2":{"86":1,"126":1,"142":1,"147":1,"156":1,"169":1,"171":1,"172":1,"194":1,"216":1,"526":1,"528":2,"620":1,"680":2}}],["define",{"2":{"37":1,"125":2,"151":1,"175":1,"179":2,"187":1,"191":1,"194":1,"205":1,"508":1,"526":1,"581":1}}],["defi",{"2":{"37":1}}],["deeper",{"0":{"564":1},"1":{"565":1,"566":1,"567":1,"568":1,"569":1},"2":{"681":1}}],["deepen",{"2":{"58":1}}],["deep",{"0":{"535":1},"1":{"536":1,"537":1,"538":1,"539":1},"2":{"42":1,"53":1,"535":1}}],["deemed",{"2":{"12":1}}],["deem",{"2":{"8":1,"11":1}}],["decreasing",{"2":{"685":1}}],["decreases",{"2":{"675":1}}],["decentralised",{"0":{"676":1,"690":1},"1":{"677":1,"678":1},"2":{"690":2}}],["decentralized",{"2":{"226":1,"461":1}}],["decentralization",{"0":{"224":1},"2":{"497":1}}],["decouple",{"2":{"647":1}}],["decoupling",{"2":{"581":1,"582":1,"648":1}}],["decoding",{"2":{"157":1,"429":4,"771":2}}],["decode",{"2":{"199":1,"597":2,"763":1,"771":2,"773":2,"774":1}}],["decoder",{"2":{"193":1}}],["decoded",{"2":{"156":4,"745":1}}],["decodestring",{"2":{"148":2,"150":2,"771":2}}],["decline",{"2":{"291":2}}],["declare",{"2":{"245":1,"301":1,"325":1,"422":1,"698":1,"704":1,"736":1}}],["deciding",{"0":{"384":1},"1":{"385":1,"386":1,"387":1}}],["decide",{"2":{"380":1}}],["decimal",{"2":{"210":1}}],["decimals",{"2":{"86":1,"685":1,"783":1,"784":1}}],["decisions",{"2":{"8":1}}],["deck",{"2":{"38":2}}],["desc",{"2":{"762":2}}],["descendants",{"2":{"644":2}}],["describing",{"2":{"646":1}}],["describes",{"2":{"125":2,"361":1,"427":1,"615":1}}],["described",{"2":{"20":1,"157":1,"187":1,"569":1,"649":3,"679":1,"680":1}}],["descriptor",{"2":{"337":1}}],["descriptors",{"2":{"337":1}}],["description=celestia",{"2":{"602":2,"604":2,"605":2,"606":2}}],["descriptions",{"2":{"86":2,"348":1}}],["description",{"0":{"44":1},"2":{"36":1,"38":1,"41":3,"86":1,"266":6,"267":2,"313":1,"326":1,"589":1,"679":1}}],["desert",{"2":{"557":2}}],["deserialization",{"0":{"191":1},"2":{"191":1,"194":1}}],["deserialize",{"2":{"190":1}}],["deserialized",{"2":{"109":1,"191":2}}],["desktop",{"2":{"91":1,"388":1,"389":1,"391":1}}],["destination",{"2":{"79":1,"309":1,"427":1}}],["desired",{"2":{"84":1,"234":1,"311":1,"341":1,"399":1,"660":1,"760":1}}],["desire",{"2":{"38":1}}],["designs",{"2":{"197":1}}],["design",{"0":{"321":1},"2":{"171":1,"226":1,"275":1,"316":1,"321":1,"355":1,"582":1}}],["designate",{"2":{"31":1}}],["designed",{"2":{"20":1,"43":1,"44":1,"51":1,"226":1,"499":2,"550":1,"643":1,"723":1}}],["delta",{"2":{"539":1}}],["deleted",{"2":{"391":1}}],["delete",{"2":{"262":2,"336":1,"375":1,"391":1,"696":1}}],["deleting",{"2":{"262":2}}],["delegating",{"2":{"681":1,"689":1}}],["delegation=1000000",{"2":{"620":3}}],["delegation=1",{"2":{"272":2}}],["delegations",{"2":{"20":1,"27":1}}],["delegation",{"0":{"17":1,"19":1},"1":{"18":1,"19":1,"20":2,"21":2,"22":2,"23":2,"24":2,"25":1,"26":1,"27":1,"28":1},"2":{"18":1,"22":4,"23":4,"24":1,"26":2,"260":2,"674":2}}],["delegator",{"2":{"651":1,"674":1}}],["delegators",{"2":{"281":2,"674":1}}],["delegate",{"0":{"269":1,"614":1},"2":{"269":3,"281":1,"614":5}}],["delegated",{"2":{"25":2,"281":1,"295":4,"580":1,"620":1}}],["delayedcelestia",{"2":{"301":1}}],["delayed",{"2":{"283":2,"294":7,"301":1}}],["delay",{"2":{"211":1,"429":4,"434":4}}],["delays",{"2":{"86":1}}],["delivering",{"2":{"58":1}}],["delivery",{"2":{"35":1}}],["delivers",{"2":{"18":1}}],["deprecated",{"2":{"152":1,"153":1,"163":2,"326":1,"726":1,"731":1}}],["depth",{"2":{"86":1,"564":1,"675":1}}],["depositing",{"2":{"95":1}}],["deposited",{"2":{"93":2}}],["deposit",{"0":{"75":1,"77":1},"1":{"76":1,"77":1},"2":{"74":2,"77":2,"93":5,"266":5,"267":2}}],["deployer",{"2":{"202":2,"544":4}}],["deployed",{"0":{"204":1,"231":1},"1":{"205":1,"206":1,"207":1},"2":{"42":1,"60":1,"86":2,"87":1,"91":1,"93":3,"204":2,"205":1,"211":2,"218":1,"231":1,"233":1,"234":3,"235":1,"361":1,"584":1,"726":1}}],["deployhelper",{"2":{"100":1,"101":1}}],["deployment",{"0":{"85":1,"86":1,"210":1,"212":1},"2":{"81":2,"85":3,"86":4,"87":1,"202":1,"208":4,"210":4,"212":1,"215":1,"217":1,"231":6,"234":1,"235":1,"540":1,"584":1}}],["deployments",{"0":{"97":1,"100":1,"101":1,"200":1,"583":1},"1":{"98":1,"99":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"584":1},"2":{"65":2,"91":1,"97":2,"98":1,"99":1,"202":3,"215":1,"216":1,"221":1,"227":2,"228":1,"233":1,"485":2,"487":2,"503":2,"540":1}}],["deploy",{"0":{"55":1,"81":1,"87":1,"202":1,"203":1,"208":1,"235":1,"242":1,"615":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"209":1,"210":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"616":1,"617":1,"618":1,"619":1},"2":{"55":1,"60":1,"85":1,"86":2,"87":3,"93":4,"103":1,"107":1,"113":1,"200":1,"201":1,"202":8,"203":2,"204":1,"208":1,"210":6,"212":1,"215":2,"217":2,"221":1,"227":1,"235":2,"249":1,"254":1,"454":1,"499":1,"540":3,"543":1,"544":4,"550":1,"552":1,"575":1,"576":1,"580":2,"584":2}}],["deploying",{"0":{"201":1,"543":1,"544":1,"580":1,"584":1},"1":{"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1},"2":{"3":1,"55":1,"81":1,"84":1,"202":1,"204":1,"205":1,"208":1,"210":2,"478":1,"544":1,"547":1,"572":1,"580":2,"583":1,"584":1,"688":2}}],["depends",{"2":{"369":1,"483":1}}],["dependent",{"2":{"134":1,"373":1,"590":1,"620":1}}],["dependency",{"0":{"541":1},"1":{"542":1},"2":{"117":1,"707":1,"776":1}}],["dependencies",{"0":{"241":1,"359":1,"398":1,"418":1,"441":1,"733":1,"764":1},"1":{"734":1,"735":1,"736":1,"765":1,"766":1},"2":{"89":1,"241":1,"359":1,"384":1,"388":1,"418":1,"441":1,"462":1,"706":1,"733":1,"737":1,"764":1,"775":1}}],["depend",{"2":{"91":1,"97":1,"226":1,"628":1,"631":1}}],["depending",{"2":{"34":1,"35":1,"58":1,"63":1,"171":1,"215":1,"302":1,"312":1,"342":1,"370":1,"371":1,"380":1,"386":1,"484":1,"499":1,"589":1,"769":1}}],["dependable",{"2":{"18":1}}],["deter",{"2":{"281":1}}],["deterministic",{"2":{"647":1}}],["determining",{"2":{"11":1,"589":1}}],["determined",{"2":{"128":1,"483":3,"590":1}}],["determines",{"2":{"86":1}}],["determine",{"2":{"30":1,"35":2,"37":1,"42":1,"63":1,"484":1,"499":1,"680":1,"708":1,"777":1}}],["detects",{"2":{"782":1}}],["detecting",{"2":{"371":1}}],["detection",{"2":{"328":1}}],["detected",{"2":{"130":1}}],["detect",{"2":{"126":1,"343":1}}],["details",{"0":{"26":1,"61":1,"168":1,"173":1,"295":1,"296":1,"480":1,"500":1},"1":{"62":1},"2":{"20":1,"41":1,"77":2,"79":1,"80":2,"87":1,"96":1,"137":1,"139":1,"140":1,"168":1,"169":1,"175":1,"182":1,"183":1,"187":1,"191":1,"194":4,"197":1,"234":1,"281":1,"291":1,"295":1,"296":1,"326":1,"328":1,"540":1,"590":1,"599":1,"641":1,"644":1,"646":2,"650":1,"660":1,"685":1,"726":1,"727":1,"731":1}}],["detailed",{"2":{"2":1,"21":1,"41":1,"81":1,"215":1,"266":1,"668":1}}],["devs",{"2":{"679":1}}],["devnetl1",{"2":{"539":1}}],["devnet",{"0":{"59":1,"69":1,"284":1,"285":1,"286":1,"288":1,"290":1,"294":1,"295":1,"296":1,"297":1,"319":1,"535":1,"543":1,"550":1,"551":1},"1":{"60":1,"61":1,"62":1,"63":1,"64":1,"65":1,"66":1,"67":1,"68":1,"69":1,"70":2,"71":2,"72":1,"73":1,"285":1,"286":2,"287":2,"288":2,"289":2,"290":1,"291":2,"292":2,"293":2,"294":2,"295":2,"296":2,"297":2,"536":1,"537":1,"538":1,"539":1,"551":1},"2":{"59":1,"60":1,"63":1,"65":1,"68":1,"70":1,"113":1,"244":1,"279":2,"283":1,"286":1,"287":1,"288":1,"289":4,"297":1,"298":1,"301":1,"305":1,"319":1,"350":1,"361":2,"371":1,"422":2,"465":1,"467":1,"499":1,"526":1,"539":1,"540":2,"543":2,"550":2,"617":1,"735":1,"736":1,"782":2,"783":2}}],["devrel",{"2":{"35":1,"37":1}}],["developing",{"2":{"422":1}}],["development",{"0":{"397":1},"1":{"398":1,"399":1},"2":{"81":1,"86":2,"341":1,"397":2,"499":1,"547":1,"580":1,"679":2}}],["developers",{"2":{"59":1,"60":1,"86":1,"107":2,"221":2,"228":1,"249":1,"251":2,"252":1,"402":1,"454":1,"499":1,"524":1,"550":1,"552":1,"572":1,"574":1,"581":1,"582":3,"668":1,"670":1,"672":1,"679":1,"687":2,"688":3,"722":1,"781":1}}],["developer",{"2":{"23":1,"39":1,"76":1,"166":1,"321":1,"439":1,"526":1,"572":1,"609":1,"721":1}}],["develop",{"2":{"23":1,"38":1}}],["devops",{"2":{"23":1,"320":1,"540":1}}],["dev",{"2":{"1":1,"104":1,"160":2,"398":4,"602":2,"604":2,"605":2,"606":2}}],["devyarn",{"2":{"1":1}}],["yconfirm",{"2":{"620":1}}],["ycelestia",{"2":{"268":1,"270":1}}],["yparity",{"2":{"537":2}}],["yum",{"2":{"398":4}}],["ysudo",{"2":{"398":3}}],["y",{"2":{"268":1,"270":1,"294":9,"398":3,"620":4}}],["yield",{"2":{"199":1}}],["y33zld2luvedelzzr9cf92+2etaimiwhn9pcaqaszwpqckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwoha36hewmw",{"2":{"152":2}}],["yh2zdyne9u",{"2":{"147":2}}],["yhcdb4cz7z4lrxmvrq5f8=",{"2":{"142":2}}],["y91da3zryfzmc7l",{"2":{"147":2}}],["yamlversion",{"2":{"705":1}}],["yamlextra",{"2":{"91":1}}],["yarn",{"2":{"1":2,"89":1,"93":2}}],["ymlglobal",{"2":{"275":1}}],["yml",{"2":{"91":1,"275":3,"276":1,"539":1,"705":2}}],["yet",{"2":{"93":2,"128":1,"201":1,"344":1,"370":1,"762":1}}],["yescelestia",{"2":{"412":1}}],["yesterday",{"2":{"271":2}}],["yes",{"2":{"42":1,"266":1,"279":2,"294":1,"412":1,"557":1,"674":1}}],["yearly",{"2":{"680":1}}],["years",{"2":{"547":1}}],["year",{"2":{"24":1,"25":1,"675":2,"680":14,"685":2}}],["youth",{"2":{"291":2}}],["youtube",{"2":{"34":1,"40":2,"540":1}}],["yours",{"2":{"287":1}}],["yourself",{"2":{"275":2}}],["yourprivatekey",{"2":{"93":3}}],["your",{"0":{"74":1,"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"85":1,"86":1,"87":1,"88":2,"89":1,"91":1,"92":1,"93":1,"240":1,"292":1,"294":1,"300":1,"303":1,"327":1,"334":1,"345":1,"417":1,"451":1,"452":1,"461":1,"462":1,"542":1,"560":1,"561":1,"565":1,"600":1,"621":1,"652":1,"654":1,"656":1,"657":1,"659":1,"661":1,"663":1,"665":1,"666":1,"704":1,"748":1,"750":1,"751":1,"768":1,"769":1},"1":{"75":1,"76":2,"77":2,"78":1,"79":2,"80":2,"241":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"418":1,"463":1,"561":1,"562":1,"563":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1},"2":{"2":5,"23":2,"24":1,"26":5,"29":1,"34":4,"35":7,"36":6,"37":11,"38":14,"39":15,"40":7,"41":8,"42":1,"44":1,"47":1,"49":1,"50":2,"51":1,"57":1,"58":3,"59":1,"63":1,"65":1,"68":3,"74":2,"76":2,"77":7,"79":7,"80":4,"82":1,"84":2,"85":3,"86":11,"87":13,"88":8,"89":1,"90":6,"91":16,"92":3,"93":20,"94":5,"140":1,"203":1,"204":1,"205":1,"206":2,"215":2,"229":4,"234":1,"235":1,"237":1,"244":3,"245":3,"254":1,"260":4,"263":1,"268":1,"269":1,"270":1,"271":7,"272":2,"273":1,"274":3,"275":3,"277":2,"283":1,"288":1,"289":2,"291":5,"294":1,"297":1,"299":1,"300":1,"301":1,"303":1,"308":2,"309":2,"311":1,"312":3,"313":3,"314":2,"315":2,"316":4,"321":1,"324":2,"326":3,"329":6,"334":5,"337":1,"338":1,"341":1,"342":2,"343":3,"344":2,"345":2,"352":2,"361":4,"363":2,"365":1,"366":1,"367":1,"368":2,"369":1,"371":1,"373":1,"376":1,"378":1,"380":1,"381":1,"383":5,"386":1,"388":2,"390":2,"391":2,"392":1,"396":1,"397":1,"398":1,"399":3,"405":5,"406":1,"407":1,"408":2,"412":5,"418":1,"422":7,"430":1,"439":1,"443":1,"445":1,"446":1,"448":2,"449":3,"452":3,"453":2,"457":1,"461":1,"464":2,"465":1,"466":3,"467":1,"471":1,"475":1,"484":1,"485":1,"493":3,"495":2,"499":1,"503":1,"528":1,"538":1,"539":2,"540":3,"542":2,"543":1,"544":6,"555":1,"556":1,"557":4,"558":3,"559":2,"561":1,"562":6,"563":1,"564":1,"565":3,"566":1,"567":1,"568":1,"575":1,"576":1,"578":1,"584":5,"586":2,"599":3,"602":1,"608":1,"614":2,"617":3,"620":9,"621":2,"622":1,"625":11,"655":1,"656":1,"660":1,"666":1,"674":1,"682":1,"683":1,"695":1,"698":3,"700":1,"703":1,"704":2,"705":3,"707":6,"708":1,"725":1,"734":2,"735":2,"736":6,"738":3,"739":1,"740":3,"741":5,"742":5,"745":3,"750":1,"751":1,"755":1,"756":1,"760":2,"761":1,"762":1,"765":5,"766":1,"768":1,"769":1,"776":6,"783":1,"784":1}}],["you",{"2":{"0":2,"2":1,"4":1,"23":3,"25":1,"26":6,"29":4,"30":1,"33":1,"34":4,"35":7,"36":4,"37":3,"39":1,"40":3,"41":11,"42":8,"47":2,"48":1,"50":2,"51":2,"54":1,"55":1,"57":2,"58":4,"59":1,"63":3,"65":2,"69":1,"70":1,"72":1,"76":1,"77":3,"79":3,"80":3,"81":4,"84":1,"85":1,"86":2,"87":5,"88":1,"89":1,"91":9,"92":2,"93":4,"94":1,"104":4,"105":1,"109":5,"110":2,"111":1,"117":1,"125":1,"126":2,"139":2,"163":3,"168":1,"202":13,"203":3,"204":1,"205":2,"208":1,"210":1,"211":4,"213":1,"214":1,"215":6,"216":3,"219":1,"227":1,"228":1,"231":1,"233":1,"235":2,"244":3,"245":8,"247":1,"248":1,"252":1,"254":2,"259":2,"261":1,"263":3,"266":2,"268":1,"269":2,"270":1,"271":2,"272":3,"274":6,"275":10,"277":3,"283":1,"284":1,"287":1,"288":2,"289":2,"290":2,"291":3,"294":4,"295":1,"296":1,"297":3,"298":1,"299":1,"301":3,"302":3,"303":4,"304":1,"305":1,"306":1,"307":1,"308":4,"309":2,"310":2,"311":4,"312":3,"313":3,"314":3,"315":1,"316":1,"320":1,"321":2,"324":1,"326":5,"329":5,"334":2,"336":2,"337":2,"338":5,"339":1,"341":4,"343":2,"344":3,"345":2,"347":1,"349":1,"352":3,"353":1,"356":1,"361":7,"363":1,"367":3,"368":3,"371":5,"373":7,"376":1,"377":2,"378":1,"380":3,"381":2,"383":3,"384":2,"385":1,"386":1,"387":2,"388":5,"390":4,"391":10,"392":3,"393":1,"396":1,"398":1,"399":2,"404":4,"405":1,"406":1,"408":1,"409":1,"414":1,"418":1,"419":1,"422":9,"424":1,"425":2,"429":3,"430":1,"431":1,"432":2,"433":1,"434":3,"439":3,"440":1,"441":1,"442":1,"443":2,"444":3,"445":1,"446":1,"448":2,"449":5,"450":4,"452":6,"453":2,"457":2,"458":2,"461":1,"465":1,"466":6,"467":3,"469":1,"471":1,"484":4,"493":2,"494":1,"495":2,"496":1,"499":8,"505":3,"510":2,"512":1,"518":1,"519":1,"523":2,"528":1,"531":2,"534":1,"537":1,"539":1,"540":6,"542":4,"543":2,"544":5,"545":2,"549":1,"555":2,"556":5,"557":12,"558":6,"559":5,"561":1,"562":7,"563":7,"564":1,"565":2,"566":4,"567":1,"568":1,"570":1,"572":5,"574":1,"578":3,"584":2,"591":1,"599":4,"601":1,"602":2,"604":2,"605":2,"606":1,"607":1,"610":2,"614":8,"615":2,"616":1,"619":1,"620":11,"625":4,"627":1,"651":3,"657":2,"661":2,"666":2,"674":1,"692":1,"695":3,"697":1,"698":6,"699":1,"704":4,"705":2,"706":2,"707":5,"708":1,"709":1,"710":1,"711":3,"717":1,"726":2,"731":6,"733":1,"735":5,"736":11,"737":3,"738":7,"739":1,"740":3,"741":4,"742":2,"743":1,"745":3,"746":3,"749":1,"755":3,"756":1,"760":1,"761":2,"762":2,"763":5,"765":4,"766":1,"769":1,"771":1,"773":4,"774":3,"775":2,"776":5,"777":1,"778":1,"779":3,"782":2,"783":6,"784":4}}],["a1",{"2":{"705":2}}],["await",{"2":{"777":6,"778":8,"779":6,"782":4}}],["away",{"2":{"688":1}}],["awareness",{"2":{"30":1}}],["ahzu6yr9xmpixlquhgbhj9xl3wiaoz6pe3cvml",{"2":{"292":2,"296":2}}],["ahead",{"2":{"35":1,"130":1}}],["a5jf",{"2":{"291":2,"292":2}}],["aztec",{"2":{"214":17}}],["aka",{"2":{"186":1,"208":1,"216":1,"592":1}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaecawqfbgcicra=",{"2":{"538":2,"760":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaba==",{"2":{"147":2,"152":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaap8aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaazz5aj1mijjrowjdcifyjkr0pcroiu2jigmd9bzuhzro",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqs98k+8wq2ix2bdctfohjtrqbqybtpdb1bufy",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaabxaaaacbaagroagqgaqqdaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseqovy2vszxn0awexdwc1zwt0mmnjn250dzrkdg1zzdlsn3n0ctbzn3z5ztd5btjyzhishqaaaaaaaaaaaaaaaaaaaaaaaaasexiyqkmkmoizggkxaiigrflow1m",{"2":{"152":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaacugaaacbaagrnagqfaqqcaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseaovy2vszxn0awexywxwngzwbhf5d21jnmn1adl5mzvly2xychf5cwf4mjn2z3zrczushqaaaaaaaaaaaaaaaaaaaaaaaaaaaagicagicagiggfeiiazloeqsgxg3row7sr1rkq7dvjygp3axkaqy4og6hyc0eibabjnclikrgofl2nvc21vcy5jcnlwdg8uc2vjcdi1nmsxllb1yktlerijcieca4ief8fzeabqlvc2wocefs+lhak0mdnmpnsxylkqv7qsbaoccaey5pebehekcwoedxrpyridmtyweltvbbpa7xbbsgyfrwtzcfhq3va1vhtbriczyd0elkajo6klsdooeqcwovaguwtdp55v8btf3wc7",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqaaaaaaeuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5rt0t52lwq3l0fnm6kqqka7nrxfnm8zc",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5ru6k2enim7thjqycl82hsxpinycelhed9qk+p9zbnide",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouu=",{"2":{"147":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaejpdcbnowap3dm=",{"2":{"332":2,"745":8}}],["aaaaaaaaaaaaaaaaaaaaaaaaabitejjcqyqyijkaaaaaaaaaaaaaaaaaaaaaaaaaehmsmkjdjdkimbiwnpodwizbfr0uifhpkwgy",{"2":{"152":2}}],["axtrw6s+qsnuzfgfeg37da6igop2zqck+04egqkaggbgaisewoncgr1dglheguymtawmbdq6awaqclylqpnrfod6h8mgmwxjfenhwhru39ecrvkmfknq8+hhuodhdoqig",{"2":{"152":2}}],["ai",{"2":{"487":1,"488":1,"489":1,"493":1,"497":1,"682":1,"683":1,"763":1}}],["airdrop",{"2":{"69":1,"510":1}}],["aiming",{"2":{"226":1}}],["aims",{"2":{"44":1,"715":1}}],["aim",{"2":{"37":1,"226":1}}],["aid",{"2":{"29":1,"632":1}}],["aura",{"2":{"280":2}}],["augments",{"2":{"238":1,"650":1}}],["aunt",{"2":{"144":4}}],["aunts",{"2":{"142":2,"144":4,"147":2,"152":2,"159":5,"160":4,"163":8}}],["authcelestia",{"2":{"765":1}}],["authentication",{"2":{"328":2,"724":1,"739":1,"740":5,"741":1,"772":2}}],["authenticated",{"2":{"175":1,"199":1}}],["authorization",{"2":{"538":2,"739":1,"760":2}}],["authorize",{"2":{"278":1}}],["authority",{"2":{"86":1}}],["auth",{"0":{"565":1,"740":1,"742":1},"2":{"91":10,"266":2,"294":2,"296":2,"538":2,"565":5,"589":1,"707":5,"715":1,"738":2,"739":5,"740":9,"741":2,"742":7,"743":4,"745":2,"748":1,"760":7,"765":1,"770":4,"771":4,"773":4,"776":5}}],["autogenerated",{"2":{"704":1}}],["automated",{"2":{"608":1}}],["automate",{"2":{"328":1}}],["automatically",{"2":{"23":1,"86":1,"281":1,"523":1,"525":1,"528":1,"591":1,"597":2,"708":1,"746":1,"777":1}}],["auto",{"2":{"86":2,"268":2,"270":2,"294":6,"429":2}}],["audible",{"2":{"34":1}}],["audience",{"0":{"36":1},"2":{"34":1,"36":3,"37":1,"38":1,"39":1,"40":1}}],["amd",{"2":{"399":1}}],["amd64",{"2":{"312":1,"342":1,"399":12}}],["amanda",{"2":{"263":2}}],["amazonaws",{"2":{"214":16}}],["amountceles",{"2":{"272":1}}],["amount=1000000utia",{"2":{"620":2}}],["amount=9000000utia",{"2":{"449":2}}],["amount=5000000000000utia",{"2":{"272":2}}],["amount=",{"2":{"272":2,"447":2}}],["amount",{"0":{"79":1,"664":1},"2":{"35":1,"77":1,"86":1,"217":1,"265":2,"266":2,"267":2,"269":4,"272":3,"294":8,"295":2,"297":4,"381":2,"407":3,"408":2,"409":2,"447":2,"448":1,"449":3,"589":1,"590":1,"620":1,"631":1,"639":1,"648":1,"656":1,"660":1,"664":1,"680":2,"748":2,"749":2,"755":3}}],["among",{"2":{"31":1,"35":1,"238":1,"524":1,"646":1,"647":1}}],["ample",{"2":{"39":1}}],["amp",{"0":{"4":1,"87":1,"269":1,"673":1},"1":{"674":1,"675":1,"676":1,"677":1,"678":1,"679":1,"680":1},"2":{"1":4,"2":2,"38":1,"53":1,"54":1,"55":1,"58":1,"87":1,"142":2,"144":14,"147":1,"150":2,"152":2,"156":6,"157":2,"161":10,"162":2,"163":10,"215":8,"218":1,"238":1,"275":1,"299":4,"338":2,"343":4,"398":10,"558":14,"604":4,"605":4,"679":3,"680":5,"777":10,"778":8,"779":6}}],["affect",{"2":{"337":1,"608":1}}],["affected",{"2":{"7":1}}],["affordable",{"2":{"40":1}}],["affiliated",{"2":{"38":1}}],["after=network",{"2":{"602":2,"604":2,"605":2,"606":2}}],["afterwards",{"2":{"24":1}}],["after",{"0":{"32":1,"409":1},"2":{"22":2,"23":2,"34":1,"39":1,"40":1,"77":1,"79":2,"80":2,"81":1,"86":2,"88":1,"90":1,"92":1,"96":1,"164":1,"172":1,"203":1,"204":1,"210":1,"211":1,"244":1,"263":1,"281":2,"312":1,"334":1,"342":1,"343":1,"349":1,"369":1,"373":1,"379":1,"380":1,"381":1,"391":1,"398":2,"409":1,"413":1,"429":1,"431":1,"450":1,"526":1,"528":1,"540":1,"606":1,"607":1,"614":1,"620":2,"621":1,"625":1,"657":1,"661":1,"666":1,"671":1,"735":1,"745":1,"771":2,"773":1}}],["average",{"2":{"782":2,"784":1}}],["avril14th",{"2":{"487":1,"488":1,"489":1,"506":1,"507":1,"508":1}}],["avoid",{"2":{"35":1,"38":1,"39":1,"91":1,"275":1,"391":1,"430":1,"544":2,"590":1}}],["avoiding",{"2":{"13":1,"18":1}}],["availability",{"0":{"67":1,"68":1,"223":1,"471":1,"491":1,"492":1,"493":1,"504":1,"505":1,"533":1,"603":1,"626":1,"627":1,"628":1,"629":1,"630":1,"631":1,"635":1,"640":1,"641":1,"646":1,"650":1,"754":1},"1":{"224":1,"225":1,"226":1,"492":1,"493":1,"494":1,"495":1,"604":1,"605":1,"606":1,"627":1,"628":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"641":1,"642":2,"643":2,"644":1,"645":1,"646":1},"2":{"30":1,"36":1,"37":1,"53":1,"65":1,"85":1,"107":2,"111":1,"112":2,"120":1,"122":1,"165":3,"179":1,"182":1,"194":1,"221":2,"224":2,"225":1,"226":2,"237":1,"238":2,"250":1,"315":1,"321":1,"342":1,"376":2,"385":2,"400":2,"402":1,"412":1,"454":1,"455":2,"458":2,"459":1,"479":1,"494":1,"499":1,"531":4,"540":1,"544":1,"555":2,"578":1,"581":2,"606":1,"607":1,"615":2,"627":7,"628":3,"629":5,"630":4,"631":1,"632":1,"635":1,"636":1,"637":1,"640":4,"643":1,"647":1,"648":5,"649":1,"668":1,"670":2,"671":1,"687":1,"688":1,"717":2,"728":1}}],["available",{"2":{"16":2,"21":1,"29":1,"31":1,"40":2,"50":1,"71":1,"111":1,"122":1,"174":1,"178":1,"179":1,"227":2,"260":2,"266":1,"274":2,"312":3,"342":3,"377":3,"380":1,"381":2,"483":1,"494":1,"540":1,"555":1,"565":1,"574":1,"577":1,"630":2,"635":1,"637":1,"640":1,"641":2,"646":1,"647":1,"649":3,"650":4,"668":2,"672":2,"680":2,"708":1,"712":1,"780":1}}],["ago",{"2":{"704":2,"705":2}}],["agreeing",{"2":{"647":1}}],["agree",{"2":{"647":1}}],["agreement",{"2":{"578":1}}],["agnostic",{"2":{"646":1}}],["again",{"2":{"329":1,"334":1,"435":1,"592":1,"650":1,"762":1,"765":1}}],["against",{"2":{"91":1,"119":1,"122":2,"227":1,"234":1,"336":1}}],["aggression",{"2":{"15":1}}],["agendas",{"2":{"30":1}}],["agenda",{"2":{"30":1}}],["age",{"2":{"6":1}}],["arise",{"2":{"636":1}}],["arises",{"2":{"628":1}}],["aria2",{"2":{"398":4}}],["aria2c",{"2":{"372":6}}],["arm",{"2":{"399":1}}],["arm64",{"2":{"312":1,"342":1,"399":12}}],["armored",{"2":{"263":2,"699":1}}],["architectnodes",{"2":{"429":2}}],["architecture",{"2":{"321":1,"343":1}}],["architectures",{"2":{"312":1,"342":1,"648":1}}],["archive",{"2":{"68":1,"367":1,"487":1,"488":1,"489":1,"490":1,"493":1,"506":1,"507":1,"508":1}}],["archival",{"0":{"494":1,"495":1},"1":{"495":1},"2":{"23":1,"27":1,"494":2,"495":1,"671":3,"672":5}}],["array",{"2":{"355":1,"777":3}}],["arranging",{"2":{"31":1}}],["arranges",{"2":{"649":1}}],["arrangement",{"2":{"647":1}}],["arranged",{"2":{"641":1,"647":1}}],["arrange",{"2":{"30":2,"36":1,"37":1}}],["arrived",{"2":{"309":1}}],["args",{"2":{"392":4,"393":4,"738":3,"741":2,"770":8,"771":8,"773":8}}],["arg",{"2":{"260":2}}],["argument",{"2":{"191":1,"194":1}}],["arguments",{"2":{"187":1,"562":1,"738":1,"769":2,"770":5,"771":5,"773":2}}],["artifacts",{"0":{"213":1},"1":{"214":1,"215":1},"2":{"203":1}}],["arfge6qnxuiz18vlglgewtw",{"2":{"147":4}}],["arbitrary",{"2":{"126":2,"267":1,"555":1}}],["arbitrum",{"0":{"81":1,"84":1,"98":1,"100":1,"106":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1},"2":{"74":1,"76":1,"77":3,"79":4,"81":4,"82":3,"83":1,"84":3,"85":1,"87":5,"90":6,"91":1,"93":2,"95":1,"97":1,"98":1,"103":3,"104":2,"107":5,"108":2,"109":1,"111":1,"112":2,"113":1,"216":1,"228":1,"231":2,"400":1}}],["arabicaresturl",{"2":{"782":2}}],["arabicarpcurl",{"2":{"782":2}}],["arabicachainid",{"2":{"325":1,"361":6,"372":2,"542":2,"745":1,"782":2,"783":1}}],["arabicacelestia",{"2":{"244":1,"245":1,"246":1,"319":1,"421":1,"423":1,"464":1,"465":1,"466":1,"468":1,"734":1,"735":2,"736":1,"765":1}}],["arabicaversions",{"2":{"311":2,"341":2,"390":2,"392":2,"393":2}}],["arabica",{"0":{"59":1,"69":1,"319":1,"332":1,"550":1,"551":1},"1":{"60":1,"61":1,"62":1,"63":1,"64":1,"65":1,"66":1,"67":1,"68":1,"69":1,"70":2,"71":2,"72":1,"73":1,"551":1},"2":{"59":2,"60":3,"63":1,"65":12,"68":5,"70":2,"71":1,"72":3,"244":2,"245":5,"246":1,"309":1,"319":4,"325":2,"328":1,"332":1,"338":1,"361":3,"371":2,"390":1,"421":1,"422":4,"423":1,"464":1,"465":4,"466":3,"467":1,"468":1,"499":1,"516":2,"521":2,"526":1,"530":2,"550":3,"552":1,"607":1,"617":1,"698":2,"734":1,"735":5,"736":3,"740":3,"752":2,"765":9,"771":3,"782":6,"783":6}}],["around",{"0":{"634":1},"2":{"12":1,"43":1,"321":1,"385":1,"453":1,"557":2,"628":1,"634":1,"636":1}}],["areas",{"2":{"32":1,"37":1,"42":1}}],["area",{"2":{"31":1,"36":1,"37":1,"38":1,"39":1,"42":1}}],["aren",{"2":{"29":1,"301":1}}],["are",{"0":{"336":1,"631":1,"639":1},"2":{"8":2,"10":1,"16":1,"18":1,"20":2,"22":2,"23":3,"25":1,"29":1,"30":1,"33":2,"35":1,"36":2,"42":3,"44":1,"46":1,"53":1,"58":1,"59":1,"63":1,"64":1,"69":1,"72":1,"74":1,"86":3,"87":1,"90":1,"91":4,"93":2,"109":1,"110":1,"118":2,"119":2,"125":1,"126":3,"127":1,"128":1,"130":3,"134":1,"136":1,"137":3,"139":3,"142":1,"144":2,"147":1,"151":1,"152":1,"156":1,"158":2,"159":2,"161":2,"163":2,"164":1,"168":2,"173":1,"174":1,"178":1,"179":1,"180":1,"185":1,"186":1,"187":2,"188":1,"191":1,"194":1,"197":1,"199":1,"202":5,"203":1,"204":1,"210":1,"211":2,"213":1,"215":5,"218":2,"224":1,"225":1,"231":1,"233":1,"239":1,"244":1,"245":1,"252":2,"261":2,"266":5,"267":2,"271":1,"272":1,"273":1,"274":2,"275":3,"281":1,"283":1,"289":1,"294":1,"301":2,"303":2,"309":1,"312":1,"313":3,"320":1,"322":4,"324":1,"326":3,"328":4,"334":2,"336":3,"342":1,"350":1,"352":1,"357":1,"361":1,"370":1,"371":3,"373":2,"380":1,"381":6,"387":1,"388":1,"390":1,"398":4,"399":1,"409":1,"415":1,"416":1,"422":2,"425":1,"427":1,"432":1,"448":1,"453":1,"455":2,"456":1,"460":1,"465":1,"484":1,"485":1,"496":1,"498":1,"499":3,"503":1,"505":1,"509":1,"510":1,"512":1,"513":1,"523":1,"524":2,"526":2,"528":1,"531":1,"537":1,"538":1,"543":1,"544":2,"552":1,"554":1,"572":1,"574":2,"577":2,"578":1,"580":1,"581":1,"582":1,"588":2,"589":3,"590":1,"592":1,"596":2,"599":1,"601":2,"607":2,"609":2,"611":1,"615":1,"617":1,"620":6,"629":1,"631":4,"634":1,"636":1,"637":1,"638":1,"640":3,"641":3,"642":1,"643":2,"646":1,"647":3,"649":4,"650":1,"668":1,"669":2,"671":1,"672":2,"675":1,"680":4,"698":3,"704":2,"708":3,"709":1,"710":1,"715":1,"717":1,"718":2,"720":2,"721":1,"722":1,"725":1,"732":1,"734":1,"735":3,"738":1,"739":1,"740":1,"741":1,"742":2,"762":1,"764":1,"778":1}}],["abbreviation",{"2":{"685":1}}],["abci++",{"2":{"646":1,"649":1}}],["abci",{"0":{"381":1},"2":{"381":8,"646":1}}],["abstain",{"2":{"266":1}}],["abi",{"2":{"144":2,"155":2,"163":2}}],["abigen",{"2":{"136":1}}],["ability",{"2":{"112":1,"169":1,"281":1,"422":2,"465":2,"628":1,"632":1,"633":1}}],["able",{"2":{"34":2,"35":1,"58":1,"79":2,"80":1,"90":1,"91":1,"125":2,"139":1,"169":1,"183":1,"185":1,"190":1,"204":1,"211":1,"277":1,"321":1,"540":1,"542":1,"550":1,"580":1,"592":1,"602":1,"604":1,"605":1,"606":1,"620":1,"629":1,"632":1,"644":2,"671":1,"771":1,"774":1,"783":1,"784":1}}],["abusive",{"2":{"10":1}}],["about",{"0":{"455":1},"1":{"456":1},"2":{"3":1,"7":1,"16":1,"20":1,"30":1,"36":1,"37":1,"42":5,"43":1,"58":1,"63":1,"73":1,"79":1,"81":2,"86":1,"94":1,"107":1,"109":1,"110":1,"125":2,"137":1,"211":2,"234":1,"236":1,"250":1,"260":2,"291":1,"312":1,"341":1,"343":1,"388":2,"404":1,"457":1,"484":1,"494":1,"495":1,"498":2,"513":2,"531":1,"545":1,"554":2,"562":1,"565":1,"571":2,"578":1,"591":1,"634":1,"635":1,"636":2,"690":1,"725":1,"730":1,"731":1,"738":2,"745":1,"746":1}}],["above",{"2":{"2":1,"23":1,"65":1,"68":1,"85":1,"91":1,"105":1,"130":1,"133":1,"139":3,"154":1,"155":1,"157":1,"162":1,"163":1,"164":1,"169":1,"172":1,"186":1,"191":1,"197":1,"202":1,"210":1,"238":1,"267":1,"294":1,"345":1,"391":1,"448":1,"449":1,"466":1,"557":1,"563":1,"566":1,"569":1,"589":1,"597":2,"625":1,"646":1,"649":2,"742":1,"743":1,"745":3,"748":1}}],["atomic",{"2":{"648":1}}],["atlas",{"2":{"96":1}}],["atmosphere",{"2":{"34":1,"35":1}}],["at",{"0":{"679":1,"685":1},"1":{"680":1},"2":{"9":1,"10":1,"16":3,"23":1,"26":1,"34":2,"35":2,"36":2,"37":1,"38":3,"39":1,"40":1,"42":1,"67":1,"68":1,"71":1,"82":1,"84":1,"93":1,"97":1,"122":2,"124":1,"154":2,"160":4,"180":1,"199":1,"211":1,"212":1,"215":3,"216":2,"217":1,"218":1,"221":1,"227":1,"246":1,"247":1,"251":1,"260":4,"275":2,"277":1,"279":2,"287":1,"304":1,"312":1,"313":1,"321":1,"326":1,"338":1,"342":1,"343":1,"367":1,"371":1,"423":1,"424":1,"428":1,"430":1,"448":1,"449":1,"456":1,"468":1,"469":1,"479":1,"492":1,"493":1,"504":1,"505":1,"526":1,"544":1,"550":1,"557":1,"558":1,"577":1,"586":2,"592":1,"596":2,"605":1,"631":1,"634":1,"641":3,"643":1,"646":1,"649":1,"650":3,"674":1,"675":2,"678":1,"679":1,"680":7,"681":1,"685":1,"708":3,"709":2,"710":7,"711":3,"745":1,"771":4,"777":3,"778":5,"779":1}}],["attack",{"2":{"628":3,"631":1}}],["attacks",{"2":{"7":1,"86":1}}],["attach",{"2":{"275":2}}],["attempt",{"2":{"627":1}}],["attempting",{"2":{"432":1}}],["attesting",{"2":{"160":1}}],["attestations",{"2":{"225":2,"400":1}}],["attestation",{"2":{"154":2,"160":4}}],["attestationproof",{"0":{"160":1},"2":{"154":6,"160":6,"163":4}}],["attests",{"2":{"139":1}}],["attested",{"2":{"118":2,"231":1}}],["attended",{"2":{"39":1}}],["attendees",{"2":{"30":3,"31":4,"32":3,"34":2,"35":2,"36":2,"37":2,"39":1,"40":1,"42":1,"46":1,"58":2}}],["attending",{"2":{"39":2}}],["attend",{"2":{"36":1,"40":3}}],["attendance",{"2":{"30":1,"32":1,"36":3,"39":2}}],["attention",{"2":{"7":1,"544":1}}],["attributes",{"2":{"147":4}}],["attribution",{"0":{"16":1}}],["attracting",{"2":{"39":1}}],["attract",{"2":{"36":1,"37":1}}],["algorithm",{"2":{"646":1}}],["almost",{"2":{"561":1}}],["although",{"2":{"650":3}}],["alt",{"2":{"543":1,"544":1,"545":1}}],["alternatives",{"2":{"370":1}}],["alternatively",{"2":{"130":2,"183":1,"190":1,"203":1,"209":1,"217":1,"519":1,"643":1,"650":1,"710":1,"738":1,"771":1}}],["alternative",{"2":{"112":1,"171":1,"172":1,"212":1}}],["alert",{"2":{"782":4}}],["alertmanager",{"2":{"275":2}}],["alerts",{"0":{"277":1},"2":{"275":2,"277":1}}],["alerting",{"2":{"26":1}}],["alias",{"0":{"694":1},"2":{"264":2,"557":1,"694":1}}],["align",{"2":{"38":1}}],["aligned",{"2":{"8":1,"23":1}}],["along",{"2":{"126":1,"139":1,"160":1,"163":2,"203":1,"228":1,"233":1,"322":1,"540":1,"668":1,"735":1,"763":1}}],["alongside",{"2":{"42":1,"107":1,"427":1}}],["alphab",{"2":{"487":1,"488":1,"489":1,"493":1,"497":1,"682":1,"683":1}}],["alpha",{"2":{"96":1,"140":2,"218":1}}],["alchemy",{"2":{"90":3}}],["alcohol",{"2":{"35":1}}],["already",{"2":{"23":1,"40":1,"41":1,"44":1,"91":1,"151":1,"201":1,"208":1,"216":2,"277":1,"290":1,"315":1,"352":1,"355":1,"399":1,"432":1,"433":1,"435":1,"444":1,"592":1,"644":1,"706":1,"716":1,"731":1,"733":1,"737":1,"775":1}}],["also",{"2":{"9":1,"23":1,"35":3,"38":1,"39":1,"40":2,"42":1,"77":1,"86":2,"111":1,"127":1,"130":2,"140":1,"143":1,"147":2,"168":1,"182":1,"186":1,"193":1,"208":1,"211":2,"214":1,"215":1,"227":1,"235":1,"238":2,"273":1,"276":1,"281":1,"289":1,"301":1,"320":1,"350":1,"371":2,"385":1,"386":1,"387":1,"400":1,"406":1,"448":1,"449":1,"461":1,"464":1,"499":1,"505":1,"540":1,"544":1,"552":1,"557":2,"599":1,"644":1,"649":1,"650":1,"690":1,"698":1,"704":1,"705":1,"724":1,"735":1,"738":1,"741":1,"743":1,"763":1,"771":1,"782":2}}],["allocation",{"0":{"679":1},"1":{"680":1},"2":{"679":1,"680":1}}],["allocating",{"2":{"40":1}}],["allocated",{"2":{"267":1,"679":1,"680":1}}],["allocate",{"2":{"35":1}}],["allotting",{"2":{"37":1}}],["allowance",{"0":{"407":1,"408":1,"410":1},"1":{"411":1},"2":{"405":1,"413":1}}],["allowances",{"0":{"405":1,"412":1},"1":{"406":1,"407":1,"413":1},"2":{"412":1}}],["allowing",{"2":{"41":1,"412":1,"437":1,"499":1}}],["allow",{"2":{"38":2,"67":1,"86":1,"92":1,"169":1,"197":1,"205":1,"206":1,"221":2,"227":1,"252":1,"313":1,"314":1,"321":2,"326":1,"356":1,"391":1,"429":4,"435":4,"454":1,"458":1,"492":1,"504":1,"506":1,"507":1,"508":1,"555":1,"610":1,"627":1,"672":3,"741":1,"782":2}}],["allows",{"2":{"22":1,"40":2,"41":1,"86":1,"107":1,"111":2,"112":1,"120":1,"122":1,"141":1,"151":1,"165":1,"167":1,"170":1,"172":1,"174":1,"176":1,"178":2,"206":2,"210":1,"217":1,"277":1,"310":1,"313":2,"326":2,"328":1,"337":1,"376":1,"381":1,"388":1,"404":1,"452":1,"455":1,"507":1,"540":1,"542":1,"566":1,"599":1,"642":1,"651":1,"690":1,"707":1,"717":1,"722":1,"731":1,"746":1,"776":1,"782":1}}],["allowed",{"2":{"14":1,"412":2}}],["all",{"0":{"365":1,"701":1},"2":{"9":1,"10":2,"26":2,"41":1,"42":1,"46":3,"60":1,"68":1,"93":2,"125":2,"164":1,"168":1,"202":1,"215":1,"221":1,"227":3,"260":1,"264":1,"291":2,"304":1,"308":1,"313":1,"326":1,"339":1,"348":1,"363":1,"365":2,"368":1,"369":2,"372":1,"375":3,"377":2,"388":1,"391":1,"414":1,"415":1,"431":2,"444":2,"448":2,"450":4,"478":1,"493":1,"494":1,"520":1,"523":3,"525":1,"530":1,"531":1,"578":1,"580":3,"581":2,"582":1,"589":1,"590":1,"591":1,"597":2,"609":1,"620":1,"627":3,"629":3,"630":1,"636":1,"644":3,"647":3,"650":1,"671":1,"672":1,"678":1,"680":1,"709":1,"710":5,"734":1,"739":1,"745":6,"769":1,"771":1,"777":2,"778":5}}],["always",{"2":{"2":1,"34":1,"60":1,"109":1,"204":1,"361":2,"380":2,"552":1,"589":1,"698":1}}],["ad5ezbg0",{"2":{"760":2}}],["adjusted",{"2":{"589":1,"590":1}}],["adjust",{"2":{"338":1,"582":1}}],["adventure",{"2":{"763":1}}],["advertise",{"2":{"378":1}}],["advisable",{"2":{"586":1}}],["advise",{"2":{"505":1}}],["advised",{"2":{"324":1,"361":1}}],["advantages",{"2":{"199":1}}],["advanced",{"0":{"758":1},"2":{"566":1,"774":1}}],["advance",{"2":{"35":1,"39":1}}],["advances",{"2":{"7":1,"227":1}}],["adr019",{"2":{"675":1}}],["adrs",{"2":{"238":1,"646":1}}],["adr",{"2":{"169":1,"321":2}}],["adapt",{"2":{"139":1,"154":1}}],["adapted",{"2":{"16":1,"83":1,"680":1}}],["admin",{"2":{"91":2,"275":1,"544":4,"565":2,"740":4,"742":2,"760":2}}],["administrative",{"2":{"86":1,"722":1}}],["adhere",{"2":{"46":1}}],["adhering",{"2":{"23":1}}],["addnetworkkeplr",{"2":{"782":17}}],["adds",{"2":{"338":1,"558":1,"589":1,"649":1}}],["addcustomprover",{"2":{"206":1,"207":2}}],["addblock",{"2":{"128":2,"130":4}}],["addrs",{"2":{"750":2}}],["addr",{"2":{"91":1,"274":2,"334":2,"429":8,"476":2,"597":4}}],["addresscelestia",{"2":{"408":1,"410":1,"519":1,"561":1,"751":1}}],["address=$",{"2":{"378":2,"452":2}}],["address=$evm",{"2":{"272":2}}],["address=address",{"2":{"299":4}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0d",{"2":{"755":1}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0dexport",{"2":{"755":1}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"293":1}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5export",{"2":{"293":1}}],["address=celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"293":2}}],["address=",{"2":{"272":2,"275":1,"405":4,"412":4}}],["addresses",{"2":{"86":2,"91":3,"94":1,"412":1,"520":1,"569":1,"584":1}}],["address",{"0":{"333":1,"378":1,"519":1,"749":1,"751":1},"2":{"7":1,"9":1,"23":1,"26":3,"38":1,"70":5,"86":8,"91":6,"93":4,"100":1,"101":1,"125":1,"144":2,"161":2,"162":2,"163":2,"202":9,"203":2,"204":21,"206":1,"207":4,"209":2,"210":6,"211":4,"218":2,"231":1,"244":1,"245":2,"265":10,"267":1,"272":5,"274":2,"291":3,"292":4,"293":3,"294":16,"295":5,"296":5,"297":4,"300":1,"301":4,"309":2,"313":2,"314":2,"326":1,"328":1,"333":2,"361":2,"377":1,"378":8,"405":4,"407":2,"408":3,"410":1,"412":8,"413":2,"422":2,"429":4,"446":1,"451":8,"452":4,"466":2,"467":5,"476":1,"477":6,"510":5,"516":1,"518":1,"519":3,"537":1,"557":2,"561":3,"569":1,"584":2,"597":2,"614":2,"705":4,"735":1,"736":7,"739":1,"749":9,"751":2,"752":8,"755":2,"765":4,"783":1,"784":1}}],["added",{"2":{"86":1,"93":2,"112":1,"275":2,"278":1,"448":1,"450":1,"520":1,"627":1,"774":1}}],["add",{"0":{"76":1,"89":1,"207":1,"430":1,"447":1,"452":1,"782":1},"2":{"39":1,"41":1,"76":1,"85":1,"91":2,"126":2,"130":4,"205":1,"207":1,"244":1,"260":4,"262":2,"272":5,"275":1,"279":8,"283":1,"291":2,"299":5,"308":2,"316":1,"329":1,"352":1,"399":1,"429":1,"430":6,"435":3,"446":2,"447":2,"450":1,"451":1,"466":2,"521":2,"672":1,"680":1,"696":1,"698":6,"700":6,"707":1,"717":1,"735":1,"736":2,"769":1,"776":3,"781":2,"782":6,"783":4,"784":3}}],["addition",{"2":{"34":1,"353":1,"637":1,"650":1,"688":1}}],["additionally",{"2":{"39":1,"91":1,"108":1,"109":2,"112":1,"126":1,"641":1,"677":1}}],["additional",{"0":{"100":1,"101":1,"623":1,"759":1},"1":{"760":1,"761":1,"762":1},"2":{"32":1,"38":1,"40":1,"98":1,"99":1,"107":1,"125":1,"188":1,"589":1,"623":1,"643":1,"657":1,"661":1,"666":1,"724":1,"738":1}}],["adding",{"0":{"448":1,"783":1,"784":1},"2":{"2":1,"93":2,"262":2,"276":1,"430":1,"431":1,"582":1}}],["apt",{"2":{"398":6}}],["aptyummac",{"2":{"398":1}}],["aptyum",{"2":{"398":1}}],["apache",{"2":{"118":2}}],["api",{"0":{"488":1,"507":1,"593":1,"596":1,"712":1,"721":1,"722":1,"725":1,"726":1,"727":1,"756":1,"780":1},"1":{"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"722":1,"723":2,"724":2,"725":2,"726":1,"727":2},"2":{"42":1,"64":1,"65":3,"90":1,"202":6,"203":4,"210":6,"218":3,"266":1,"315":1,"322":1,"376":1,"385":1,"428":1,"485":1,"488":14,"503":1,"507":14,"596":1,"598":2,"638":1,"672":2,"712":1,"717":2,"721":5,"722":4,"723":1,"724":1,"726":2,"727":1,"728":1,"737":1,"739":1,"740":1,"741":2,"756":1,"763":3,"764":1,"766":3,"769":2,"770":3,"771":2,"774":1,"780":1,"783":1,"784":1}}],["apology",{"2":{"12":1}}],["apologizing",{"2":{"7":1}}],["appcelestia",{"2":{"375":1,"444":1}}],["appcd",{"2":{"311":1}}],["appconsts",{"2":{"150":6,"597":4}}],["appdsudo",{"2":{"602":2}}],["appd",{"0":{"412":1},"1":{"413":1},"2":{"260":4,"261":2,"262":8,"263":6,"264":6,"265":10,"266":10,"267":4,"268":2,"269":4,"270":2,"272":10,"279":18,"287":2,"288":2,"291":2,"292":2,"294":6,"295":2,"296":2,"297":4,"299":8,"301":4,"308":6,"309":4,"311":5,"312":5,"361":12,"373":9,"375":2,"379":1,"380":1,"381":1,"383":1,"412":2,"413":2,"437":3,"444":3,"445":2,"446":2,"447":2,"449":2,"450":3,"452":2,"453":2,"477":2,"594":2,"597":2,"601":1,"602":15,"614":4,"620":13,"625":2}}],["append",{"2":{"118":2,"130":2}}],["appendix",{"0":{"95":1},"1":{"96":1,"97":1,"98":1,"99":1,"100":1,"101":1},"2":{"91":1}}],["appear",{"2":{"93":1,"275":1,"656":1}}],["appearance",{"2":{"6":1}}],["appeal",{"2":{"36":1}}],["app",{"0":{"283":1,"306":1,"310":1,"360":1,"439":1,"442":1,"594":1,"602":1,"649":1,"663":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"311":1,"312":1,"313":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"650":1},"2":{"64":1,"90":2,"144":2,"150":4,"152":1,"153":1,"156":4,"157":4,"163":6,"238":3,"260":2,"275":4,"281":1,"283":1,"284":1,"286":3,"287":8,"288":2,"291":4,"292":2,"294":6,"295":2,"296":2,"297":4,"298":1,"306":1,"307":1,"310":2,"311":12,"312":4,"313":1,"360":1,"361":13,"365":1,"367":1,"368":2,"371":5,"372":18,"373":4,"375":1,"377":2,"378":2,"380":1,"381":1,"383":1,"414":1,"427":1,"439":1,"442":1,"444":1,"448":1,"449":1,"450":3,"451":1,"473":1,"474":3,"482":1,"483":1,"485":1,"503":1,"531":1,"562":1,"588":2,"591":2,"592":1,"597":20,"602":1,"605":1,"607":1,"615":1,"620":3,"625":1,"646":6,"649":1,"650":2,"682":1,"683":1,"717":1,"752":4}}],["appreciate",{"2":{"42":1,"46":1}}],["appreciation",{"2":{"37":2}}],["approximation",{"2":{"483":1,"589":1}}],["approximately",{"2":{"79":1,"80":1}}],["approving",{"2":{"79":1}}],["approvedprovers",{"2":{"584":1}}],["approve",{"2":{"77":1,"80":1,"85":1,"599":1,"656":1}}],["approval",{"2":{"47":1,"656":1}}],["approaching",{"2":{"586":1}}],["approaches",{"2":{"164":1}}],["approach",{"2":{"36":1,"37":1,"38":1,"63":1,"186":1,"193":1,"199":1,"484":1,"499":1}}],["appropriate",{"2":{"8":2,"126":2,"337":1,"343":1,"429":1,"668":1,"708":1,"777":1}}],["apple",{"2":{"312":1,"342":1,"399":1}}],["applicable",{"2":{"24":2,"26":1,"30":1}}],["applicant",{"2":{"22":1}}],["applicants",{"2":{"22":8,"23":2,"25":2}}],["applications",{"2":{"23":1,"25":1,"27":3,"59":1,"249":1,"251":2,"254":1,"457":1,"478":1,"547":1,"577":1,"581":2,"582":2,"600":1,"602":1,"638":1,"644":1,"670":1,"672":1,"731":2}}],["application",{"0":{"25":1,"26":1},"1":{"26":1},"2":{"20":3,"23":3,"26":1,"238":1,"260":10,"276":1,"301":1,"308":1,"337":1,"372":1,"380":1,"383":1,"538":2,"565":1,"581":2,"582":1,"584":1,"588":2,"592":1,"607":1,"625":1,"644":7,"646":3,"688":1,"731":1,"735":1,"760":2}}],["applies",{"2":{"9":2,"105":1,"523":1}}],["applying",{"2":{"26":1,"32":1,"641":1}}],["apply",{"2":{"20":1,"24":1,"25":1,"316":1,"371":1,"647":1}}],["appointed",{"2":{"9":1}}],["acelestia",{"2":{"614":1}}],["achieve",{"2":{"519":1}}],["achieved",{"2":{"44":1,"276":1,"363":1}}],["acquire",{"0":{"84":1},"2":{"84":1}}],["acquaintances",{"2":{"38":1,"39":1}}],["across",{"2":{"41":2,"109":1,"156":1,"438":1,"581":1,"679":1}}],["acknowledging",{"2":{"38":1}}],["accurate",{"2":{"588":1}}],["accurately",{"2":{"333":1,"590":1}}],["accomplish",{"2":{"705":1}}],["accommodate",{"2":{"30":1}}],["accordingly",{"2":{"42":1,"91":1,"338":1,"516":1}}],["according",{"2":{"35":1,"227":1}}],["accountaddress",{"2":{"738":1}}],["accountname",{"2":{"597":2}}],["accounted",{"2":{"589":1}}],["accountexport",{"2":{"299":1}}],["accounts",{"0":{"297":1},"2":{"93":5,"144":2,"163":2,"278":4,"279":2,"297":1,"304":1,"404":1,"405":1,"589":1}}],["account",{"0":{"283":1,"290":1,"294":1,"295":1,"296":1,"300":1,"301":1,"409":1,"413":1,"447":1,"592":1,"751":1,"755":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":2,"292":2,"293":2,"294":2,"295":2,"296":2,"297":2,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1},"2":{"9":1,"86":2,"90":3,"93":9,"202":5,"260":4,"266":4,"272":3,"279":10,"283":3,"289":1,"290":1,"291":2,"294":12,"295":11,"296":6,"297":3,"298":2,"299":4,"301":4,"305":2,"325":1,"402":2,"403":2,"404":6,"405":4,"408":1,"409":2,"412":7,"413":1,"422":1,"429":4,"430":1,"447":2,"465":1,"477":6,"540":1,"542":2,"544":10,"561":3,"562":1,"569":2,"589":3,"592":1,"597":6,"636":1,"748":2,"751":3,"762":4,"765":4,"766":2,"783":1,"784":1}}],["accessing",{"2":{"634":1,"635":1}}],["accessible",{"2":{"30":1,"58":1,"227":1,"313":2,"326":2,"634":1,"697":4}}],["accessed",{"2":{"377":1}}],["access",{"0":{"68":1,"367":1,"493":1,"505":1},"2":{"36":1,"37":1,"47":2,"50":1,"58":1,"64":4,"68":2,"92":1,"136":1,"170":1,"184":1,"193":1,"202":2,"221":1,"244":1,"403":1,"422":2,"465":1,"485":4,"493":1,"503":4,"505":1,"589":1,"629":1,"633":1,"634":2,"638":2,"666":1,"672":4,"722":1,"723":1,"735":1,"760":1,"782":2}}],["accept",{"2":{"187":1,"274":2,"376":1,"588":1,"592":1,"650":1}}],["accepts",{"2":{"111":1,"211":1,"650":2}}],["accepted",{"2":{"22":1,"110":1,"557":1}}],["acceptable",{"2":{"8":1}}],["accepting",{"2":{"7":2}}],["actors",{"2":{"638":1}}],["acts",{"2":{"202":1}}],["actually",{"2":{"627":1,"720":1}}],["actual",{"2":{"126":3,"128":1,"137":1,"173":1,"214":1,"569":1,"589":1,"675":1}}],["activation",{"2":{"539":1}}],["activating",{"2":{"524":1}}],["activatecd",{"2":{"543":1}}],["activates",{"2":{"525":1}}],["activate",{"2":{"352":1,"526":2,"528":1,"543":1}}],["activity",{"2":{"92":1,"540":1}}],["activities",{"2":{"24":1,"30":1,"31":1}}],["active",{"2":{"20":1,"23":3,"26":2,"49":1,"238":1,"704":1,"705":1}}],["acting",{"2":{"9":1}}],["actions",{"2":{"13":1,"126":4}}],["action",{"2":{"8":1,"11":1,"147":2,"738":1}}],["act",{"2":{"6":1,"281":1}}],["async",{"2":{"777":2,"778":1,"779":1,"782":2}}],["aside",{"2":{"680":1}}],["ascii",{"2":{"263":2,"699":1}}],["aspects",{"2":{"41":1,"58":1}}],["asked",{"2":{"46":1,"199":1,"499":1}}],["ask",{"2":{"34":1,"37":1,"38":1,"650":1,"782":2}}],["assurances",{"0":{"639":1}}],["assumption",{"2":{"338":1,"558":1,"590":1,"631":2,"634":1}}],["assumptions",{"0":{"631":1},"2":{"224":1,"328":1,"634":1}}],["assumed",{"2":{"631":1,"693":1}}],["assumes",{"2":{"215":2,"315":1,"341":1,"590":1,"631":1,"760":1}}],["assume",{"2":{"126":1,"202":1,"581":1,"765":1}}],["assign",{"2":{"86":1,"272":1}}],["assist",{"2":{"40":1,"41":1}}],["assistance",{"2":{"39":1,"41":1}}],["associated",{"2":{"23":1,"39":1,"160":2,"322":2,"455":1,"518":1,"563":1,"649":2,"748":1}}],["asset",{"2":{"687":1}}],["assets",{"2":{"7":1,"255":1}}],["assert",{"2":{"191":1,"777":6}}],["asserted",{"2":{"187":2}}],["assertions",{"2":{"86":3}}],["assessing",{"2":{"32":1}}],["assess",{"2":{"20":1,"36":1}}],["as",{"0":{"106":1,"407":1,"408":1,"410":1,"452":1,"575":1,"600":1,"761":1},"1":{"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"411":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1},"2":{"6":1,"7":2,"9":1,"13":2,"22":1,"23":2,"30":1,"34":2,"36":1,"37":3,"38":2,"39":2,"41":1,"44":1,"48":1,"50":1,"51":1,"58":3,"60":1,"68":1,"79":1,"86":1,"87":2,"88":2,"91":1,"93":1,"108":1,"109":2,"110":2,"113":1,"117":1,"119":1,"122":1,"125":5,"126":2,"127":2,"130":1,"133":1,"136":1,"139":1,"147":1,"152":2,"153":2,"154":1,"155":1,"156":2,"157":3,"158":1,"159":1,"162":2,"163":5,"169":1,"175":1,"178":1,"180":2,"183":1,"184":1,"186":1,"187":3,"188":1,"191":6,"194":2,"197":1,"199":1,"202":3,"203":2,"204":1,"208":1,"210":3,"211":2,"213":1,"215":2,"221":1,"224":1,"226":1,"227":2,"233":2,"234":1,"238":1,"245":1,"248":1,"250":1,"254":1,"260":2,"266":1,"267":1,"273":1,"275":5,"276":1,"278":1,"287":1,"293":3,"294":1,"295":1,"299":1,"301":1,"308":2,"313":1,"320":1,"321":1,"322":6,"325":1,"326":1,"328":2,"332":1,"333":1,"355":1,"365":1,"371":1,"372":1,"373":1,"396":1,"400":2,"405":2,"413":1,"422":4,"425":1,"426":1,"428":3,"437":1,"439":1,"447":1,"451":1,"452":1,"455":5,"465":2,"470":1,"475":1,"478":1,"479":1,"482":2,"483":1,"499":1,"507":1,"525":1,"536":1,"537":2,"540":4,"550":1,"552":1,"562":1,"569":1,"580":6,"588":2,"589":1,"590":2,"592":1,"597":2,"600":1,"601":1,"602":1,"606":1,"607":1,"614":2,"615":1,"619":1,"621":1,"627":2,"630":2,"631":1,"633":1,"634":1,"637":2,"641":4,"643":3,"644":4,"646":1,"647":5,"649":3,"650":3,"651":1,"670":3,"671":4,"672":4,"674":1,"678":1,"680":2,"688":3,"689":1,"690":1,"707":3,"709":1,"710":1,"713":1,"715":2,"716":1,"722":2,"723":1,"724":2,"734":1,"738":3,"742":1,"743":2,"755":1,"760":1,"766":1,"769":1,"770":2,"771":2,"773":2,"774":1,"776":3,"777":1,"778":1}}],["annual",{"2":{"675":2}}],["annually",{"2":{"675":1,"685":1}}],["announced",{"2":{"39":1}}],["announce",{"2":{"39":1}}],["announcements",{"2":{"498":1,"513":1,"554":2}}],["announcement",{"2":{"39":1,"73":1,"498":1,"499":1,"513":1,"554":1}}],["announcing",{"2":{"39":2}}],["anger",{"2":{"291":2}}],["analytics",{"0":{"497":1,"511":1},"2":{"497":2,"511":1}}],["analysis",{"2":{"183":1}}],["analyze",{"2":{"32":1}}],["analogously",{"2":{"120":1}}],["analogous",{"2":{"119":1}}],["analog",{"2":{"118":2}}],["another",{"0":{"247":1,"424":1,"469":1,"749":1,"755":1},"2":{"86":1,"93":2,"170":1,"183":1,"244":1,"265":1,"281":1,"355":1,"400":1,"404":1,"405":1,"415":1,"438":1,"559":1,"588":1,"615":1,"649":1,"704":1,"705":1,"735":1,"749":1}}],["answer",{"2":{"42":1,"294":1,"772":1}}],["answers",{"2":{"16":1,"41":1,"627":1}}],["anticipate",{"2":{"36":1}}],["an",{"0":{"79":1,"81":1,"90":1,"212":1,"376":1,"383":1,"407":1,"522":1,"540":1,"544":1,"625":1,"711":1,"761":1,"779":1},"1":{"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"377":1,"378":1,"379":1,"541":1,"542":1,"543":1,"544":1,"545":1},"2":{"4":1,"6":1,"9":5,"12":1,"15":1,"21":1,"23":4,"26":1,"31":1,"34":1,"36":1,"37":2,"38":1,"41":1,"46":1,"47":2,"49":1,"53":1,"54":1,"55":1,"58":1,"68":2,"77":2,"79":1,"84":1,"86":2,"87":1,"90":4,"93":1,"94":1,"103":1,"107":2,"109":1,"110":1,"111":1,"112":2,"113":1,"117":1,"119":1,"122":2,"124":1,"126":4,"127":2,"136":1,"141":1,"144":2,"151":2,"155":1,"156":2,"157":1,"159":1,"160":3,"161":2,"163":4,"171":1,"172":2,"175":1,"178":2,"179":1,"182":1,"199":2,"202":6,"203":1,"208":3,"210":3,"212":1,"217":1,"218":1,"221":2,"222":1,"228":1,"238":2,"240":1,"244":2,"245":1,"249":1,"251":3,"260":4,"263":1,"267":2,"272":1,"273":1,"275":1,"276":1,"281":1,"301":3,"302":1,"308":1,"311":1,"312":1,"316":1,"317":1,"318":1,"319":1,"321":2,"324":1,"328":2,"332":1,"334":3,"337":1,"355":1,"358":1,"367":1,"380":1,"381":1,"383":3,"388":1,"390":3,"392":1,"400":2,"417":1,"422":1,"428":2,"434":1,"449":1,"462":1,"475":1,"483":1,"493":1,"544":1,"545":1,"557":1,"566":1,"581":1,"584":2,"588":1,"589":3,"591":1,"592":1,"597":2,"612":1,"614":2,"617":1,"620":1,"625":3,"628":1,"631":3,"640":1,"644":4,"646":1,"647":6,"648":1,"649":1,"650":1,"674":1,"675":1,"681":1,"685":1,"687":1,"694":1,"705":2,"707":2,"708":1,"711":1,"724":1,"735":3,"740":1,"741":1,"742":2,"743":3,"745":2,"749":1,"750":1,"751":1,"752":1,"755":1,"762":1,"763":1,"764":1,"765":1,"766":6,"770":2,"771":3,"773":2,"776":2,"777":2,"779":1}}],["anyone",{"2":{"427":1,"454":1,"627":1,"648":1}}],["anyway",{"2":{"326":1,"726":1,"731":1}}],["anything",{"2":{"180":1,"430":1,"542":1}}],["anytrust",{"2":{"85":1,"86":1,"107":1,"109":1}}],["any",{"2":{"4":1,"7":1,"8":1,"10":1,"11":1,"14":1,"15":1,"23":4,"24":1,"26":1,"30":3,"31":2,"39":2,"42":1,"69":2,"91":1,"124":1,"174":1,"199":1,"201":1,"206":1,"208":1,"221":1,"260":2,"275":4,"311":1,"334":1,"341":1,"345":1,"349":1,"355":1,"371":1,"408":1,"437":1,"479":1,"494":1,"510":2,"534":1,"542":1,"578":1,"580":1,"582":2,"584":1,"586":1,"614":1,"627":1,"642":1,"689":1,"696":1,"717":1,"719":1,"720":1,"738":1}}],["and",{"0":{"33":1,"35":1,"39":1,"60":1,"74":1,"88":1,"89":1,"92":1,"102":1,"215":1,"224":1,"226":1,"250":1,"263":1,"281":1,"314":1,"331":1,"332":1,"355":1,"362":1,"392":1,"466":1,"477":1,"479":1,"502":1,"509":1,"544":1,"560":1,"587":1,"588":1,"608":1,"635":1,"655":1,"657":1,"660":1,"661":1,"664":1,"670":1,"671":1,"702":1,"708":1,"716":1,"717":1,"736":1,"765":1,"777":1},"1":{"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"103":1,"104":1,"105":1,"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"467":1,"503":1,"504":1,"505":1,"561":1,"562":1,"563":1,"588":1,"589":2,"590":2,"591":2,"592":1,"671":1,"672":1,"703":1,"704":1,"705":1},"2":{"0":1,"1":1,"2":4,"3":2,"6":5,"7":8,"8":6,"9":1,"10":3,"12":1,"18":3,"20":2,"21":1,"22":3,"23":11,"25":1,"26":10,"27":2,"30":12,"31":7,"32":6,"33":1,"34":6,"35":9,"36":7,"37":6,"38":8,"39":11,"40":11,"41":4,"42":3,"44":4,"46":4,"47":2,"48":1,"50":2,"51":3,"52":1,"53":1,"54":1,"55":1,"56":1,"57":2,"58":10,"59":2,"65":1,"68":1,"74":3,"79":3,"80":1,"81":5,"82":3,"85":2,"86":13,"87":4,"88":3,"89":1,"90":6,"91":1,"92":2,"93":5,"94":2,"96":2,"103":1,"105":1,"107":2,"109":9,"110":3,"111":1,"119":1,"121":1,"122":9,"124":3,"125":3,"126":8,"127":3,"128":1,"130":10,"132":1,"136":1,"137":5,"139":4,"140":2,"141":1,"144":2,"145":2,"147":2,"150":1,"151":2,"156":5,"157":2,"159":3,"160":4,"161":4,"162":2,"163":4,"164":3,"165":1,"166":2,"168":3,"169":1,"172":3,"173":2,"174":2,"175":5,"178":3,"179":3,"180":2,"182":1,"183":5,"185":1,"186":2,"187":3,"191":4,"194":2,"196":1,"197":2,"199":4,"202":8,"203":4,"204":3,"205":3,"208":3,"209":1,"210":6,"211":3,"214":2,"215":5,"216":3,"217":2,"218":1,"219":1,"221":4,"226":5,"227":4,"228":1,"229":1,"233":4,"234":1,"235":4,"237":1,"238":5,"244":1,"245":1,"247":1,"251":1,"252":1,"254":1,"255":1,"256":1,"258":1,"259":2,"260":6,"263":2,"266":5,"267":2,"273":3,"275":9,"276":1,"279":2,"281":8,"282":1,"283":1,"284":2,"286":1,"287":2,"291":1,"293":1,"294":2,"295":1,"298":1,"299":1,"300":1,"303":1,"305":1,"307":1,"310":2,"311":2,"313":2,"314":1,"316":2,"321":1,"322":9,"326":3,"328":7,"331":3,"332":2,"333":2,"334":1,"335":1,"336":1,"337":2,"338":2,"339":1,"341":7,"343":1,"344":1,"345":1,"347":1,"348":1,"350":1,"352":1,"361":1,"363":1,"365":1,"367":1,"369":2,"370":1,"371":6,"372":1,"376":1,"378":1,"380":2,"381":4,"385":1,"388":2,"389":2,"391":1,"392":1,"397":1,"398":4,"399":2,"400":3,"404":1,"405":1,"408":1,"412":2,"415":2,"422":1,"424":1,"427":4,"428":1,"429":2,"430":1,"431":2,"432":5,"435":2,"438":1,"439":1,"450":1,"454":3,"455":4,"456":1,"457":2,"459":1,"463":1,"464":1,"465":1,"469":1,"472":1,"474":1,"476":2,"478":2,"479":4,"483":4,"493":2,"499":2,"505":1,"506":1,"508":2,"509":1,"515":1,"516":1,"520":1,"523":2,"524":2,"525":1,"526":2,"528":2,"530":2,"531":2,"534":1,"536":1,"537":1,"539":2,"540":7,"542":4,"543":1,"544":1,"547":4,"550":1,"555":4,"557":5,"558":3,"559":4,"561":2,"562":2,"563":2,"566":1,"569":4,"570":1,"571":1,"572":3,"574":1,"577":2,"578":4,"581":4,"582":2,"584":1,"585":1,"586":1,"588":2,"589":3,"590":6,"591":3,"592":2,"593":1,"597":14,"599":6,"602":1,"604":1,"605":3,"606":1,"608":1,"609":2,"615":1,"620":3,"621":1,"625":2,"627":2,"628":3,"631":1,"632":1,"633":3,"634":2,"635":2,"636":2,"637":4,"639":2,"640":3,"641":4,"642":1,"643":3,"644":8,"646":3,"647":9,"648":2,"649":7,"650":3,"651":2,"654":1,"655":1,"656":1,"659":1,"660":2,"663":1,"664":1,"665":1,"668":4,"669":1,"670":4,"671":1,"672":4,"674":2,"675":2,"677":4,"679":6,"680":3,"681":1,"688":1,"690":1,"692":1,"693":1,"696":1,"698":1,"699":1,"706":1,"707":1,"708":3,"710":2,"711":1,"713":1,"715":5,"716":2,"717":1,"719":2,"720":1,"721":2,"722":4,"723":1,"724":1,"725":1,"726":1,"728":1,"731":4,"733":1,"734":2,"735":1,"737":1,"738":2,"739":1,"740":2,"742":1,"743":4,"745":1,"746":2,"755":2,"757":1,"760":1,"761":1,"762":1,"763":3,"765":4,"766":2,"768":1,"769":4,"770":5,"771":19,"772":4,"773":7,"774":1,"775":1,"776":2,"777":2,"779":1,"781":3,"782":2,"783":3,"784":4}}],["a",{"0":{"42":1,"54":1,"55":1,"102":1,"104":1,"105":1,"125":1,"144":1,"179":1,"180":1,"181":1,"182":1,"191":1,"202":1,"211":1,"212":1,"237":1,"246":1,"261":1,"272":1,"283":1,"291":1,"299":1,"301":1,"302":1,"306":1,"308":1,"309":1,"312":1,"333":1,"338":2,"342":1,"358":1,"363":2,"407":1,"408":2,"410":2,"411":1,"414":1,"423":1,"432":1,"443":1,"445":1,"446":1,"452":1,"458":1,"461":1,"468":1,"472":1,"516":2,"517":1,"521":1,"536":1,"543":1,"544":1,"556":1,"574":1,"575":1,"577":1,"578":1,"580":1,"597":1,"598":1,"599":1,"600":1,"610":1,"612":1,"614":1,"645":1,"649":1,"655":1,"660":1,"664":1,"685":1,"695":1,"734":1,"735":1,"760":1,"761":1,"765":1,"783":1,"784":1},"1":{"103":1,"104":1,"105":1,"180":1,"181":1,"182":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"339":2,"343":1,"359":1,"360":1,"361":1,"364":2,"365":2,"411":2,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":2,"425":1,"426":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"459":1,"460":1,"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"467":1,"468":1,"469":2,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"518":1,"519":1,"557":1,"558":1,"559":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1,"611":1,"612":1,"613":2,"614":2,"615":1,"616":1,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"646":1,"650":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1},"2":{"2":4,"3":5,"6":1,"7":3,"12":2,"13":5,"14":4,"15":2,"18":3,"20":1,"21":2,"22":2,"23":6,"24":1,"25":1,"26":2,"27":1,"28":1,"29":2,"30":6,"31":1,"33":3,"34":12,"35":3,"36":8,"37":7,"38":7,"39":3,"40":3,"41":8,"42":4,"44":1,"46":2,"47":2,"48":1,"50":1,"51":1,"53":1,"54":7,"55":5,"58":5,"59":2,"60":2,"67":3,"68":4,"70":2,"74":2,"79":1,"80":1,"81":3,"82":3,"84":2,"85":2,"86":15,"87":3,"88":1,"90":7,"91":10,"92":1,"93":2,"94":1,"103":1,"104":2,"105":3,"107":1,"108":1,"109":21,"110":5,"111":3,"112":2,"117":1,"118":3,"119":8,"120":4,"122":13,"124":3,"125":15,"126":19,"127":3,"128":3,"130":6,"136":3,"137":10,"139":17,"141":5,"145":5,"146":1,"149":1,"151":7,"154":2,"156":4,"157":3,"159":2,"160":8,"163":2,"165":1,"167":1,"168":2,"169":5,"170":1,"171":1,"172":7,"173":1,"174":6,"175":12,"176":1,"178":3,"179":3,"180":3,"183":7,"186":1,"187":1,"188":1,"191":1,"193":2,"194":1,"197":1,"199":3,"200":1,"201":3,"202":17,"203":1,"204":6,"205":1,"206":2,"207":2,"208":11,"209":1,"210":4,"211":7,"212":2,"214":10,"215":10,"216":4,"217":5,"218":3,"219":3,"221":2,"224":2,"225":1,"226":3,"227":8,"228":2,"230":1,"233":1,"234":3,"235":3,"238":6,"244":1,"245":5,"246":2,"247":1,"248":2,"249":1,"250":3,"251":2,"254":1,"255":1,"259":1,"260":10,"263":4,"266":7,"267":4,"269":2,"271":1,"272":1,"273":2,"274":2,"275":16,"276":1,"277":3,"278":3,"279":2,"281":9,"282":2,"283":4,"287":1,"289":4,"290":1,"291":3,"294":3,"295":1,"297":2,"298":4,"299":3,"301":4,"302":2,"303":2,"304":1,"305":3,"306":1,"309":1,"310":1,"311":1,"312":2,"313":5,"314":2,"315":1,"320":6,"321":2,"322":2,"324":1,"325":1,"326":5,"328":2,"329":3,"331":4,"332":1,"333":1,"336":4,"337":1,"338":7,"341":2,"342":2,"343":2,"344":1,"349":2,"352":1,"353":1,"355":5,"356":1,"357":1,"361":4,"363":1,"367":2,"368":1,"369":2,"370":1,"371":4,"372":2,"373":2,"376":1,"377":1,"378":2,"380":1,"381":2,"383":1,"385":2,"386":2,"387":4,"388":2,"389":2,"390":1,"391":6,"392":1,"393":2,"396":3,"400":2,"402":2,"403":1,"404":4,"407":1,"408":2,"409":1,"411":1,"412":2,"414":3,"422":8,"423":2,"424":1,"425":2,"427":1,"428":2,"430":1,"432":1,"433":3,"434":17,"438":3,"439":2,"443":1,"444":2,"446":2,"452":1,"453":1,"454":2,"455":4,"456":1,"457":2,"458":1,"460":1,"461":1,"465":5,"466":1,"468":2,"469":1,"470":1,"472":2,"475":1,"476":1,"477":1,"478":1,"479":1,"482":2,"483":9,"484":1,"492":3,"493":3,"495":1,"498":1,"499":2,"504":3,"505":5,"508":2,"510":2,"513":1,"515":4,"516":2,"518":2,"519":1,"520":1,"522":1,"524":1,"525":1,"526":5,"528":4,"531":1,"534":3,"535":1,"536":4,"537":1,"540":8,"542":2,"543":3,"544":4,"550":1,"552":1,"554":1,"555":6,"556":1,"557":4,"558":3,"561":1,"562":5,"563":3,"565":1,"566":3,"567":1,"568":1,"572":1,"574":1,"575":1,"577":3,"578":5,"580":7,"581":3,"582":2,"583":1,"584":4,"585":1,"586":6,"587":1,"588":6,"589":10,"590":13,"591":4,"592":7,"596":4,"597":10,"599":3,"600":1,"601":2,"602":1,"607":4,"608":2,"609":1,"610":1,"611":1,"612":1,"613":1,"614":3,"615":4,"619":2,"620":4,"621":1,"625":2,"627":2,"628":5,"629":3,"630":6,"631":5,"632":3,"633":2,"634":4,"635":1,"636":2,"637":4,"639":1,"640":5,"641":9,"642":3,"643":7,"644":4,"646":5,"647":10,"648":3,"649":13,"650":9,"651":2,"654":1,"655":1,"656":1,"660":1,"664":1,"666":1,"668":5,"669":3,"671":3,"672":2,"674":4,"677":2,"678":1,"679":2,"680":2,"681":4,"687":1,"688":6,"689":3,"690":1,"695":1,"696":1,"698":5,"699":1,"700":1,"704":2,"705":1,"707":1,"708":7,"709":6,"710":5,"711":1,"715":1,"717":1,"720":1,"721":1,"722":2,"723":1,"724":1,"726":1,"731":1,"732":1,"734":2,"735":4,"736":2,"737":1,"738":1,"740":2,"741":3,"742":4,"743":7,"744":1,"746":2,"755":3,"757":1,"760":3,"762":1,"763":1,"765":3,"768":2,"769":5,"770":4,"771":21,"772":3,"773":4,"774":3,"776":1,"777":4,"778":1,"779":1,"782":2,"783":1,"784":1}}],["bzsidenode",{"2":{"159":6,"160":6,"163":8}}],["bip44",{"2":{"782":2}}],["bip39",{"2":{"700":1}}],["billion",{"2":{"680":1}}],["bi",{"2":{"590":2}}],["bidirectional",{"2":{"353":1}}],["bitter",{"2":{"291":2}}],["bigger",{"2":{"627":1,"631":1}}],["big",{"2":{"144":8,"156":4,"159":4,"160":8,"163":18}}],["bincd",{"2":{"214":1}}],["bin",{"2":{"209":2,"211":2,"214":5,"215":2,"279":2,"311":1,"312":1,"342":2,"343":6,"398":2,"399":9,"543":2,"556":2,"704":2,"705":2}}],["binaries",{"2":{"203":2,"211":1,"312":2,"342":2,"397":1}}],["binarymerkleproof",{"2":{"118":4,"119":1,"144":2,"154":4,"159":9,"160":5,"163":8}}],["binary",{"0":{"311":1,"312":1,"342":1,"345":1},"1":{"343":1},"2":{"96":1,"104":1,"110":2,"118":2,"119":1,"122":1,"139":1,"141":1,"145":1,"151":2,"154":2,"160":2,"174":2,"175":1,"211":5,"214":1,"215":1,"243":1,"260":2,"282":2,"287":1,"310":1,"311":5,"312":4,"341":4,"342":3,"343":1,"345":1,"383":1,"388":1,"403":1,"463":1,"473":1,"526":2,"528":3,"555":1,"556":3,"566":1,"625":2,"697":4,"765":1}}],["binding",{"2":{"144":2,"161":2,"163":2}}],["bindings",{"2":{"136":7,"144":4,"161":2,"162":2,"163":4,"228":1,"233":1}}],["bind",{"2":{"144":6,"161":2,"162":2,"163":4,"377":1}}],["blind",{"2":{"291":2}}],["blue",{"2":{"137":1}}],["blobclient",{"2":{"777":2}}],["blobchan",{"2":{"709":2}}],["blobresponse",{"2":{"709":2}}],["blobtypes",{"2":{"591":4,"597":6}}],["blobtxs",{"2":{"593":1}}],["blobtx",{"2":{"585":1,"597":4}}],["blobdata",{"2":{"562":3}}],["blobpointer",{"2":{"109":1}}],["blob",{"0":{"149":1,"167":1,"168":1,"169":1,"170":1,"171":1,"183":1,"184":1,"185":1,"190":1,"192":1,"193":1,"411":1,"586":1,"599":1,"760":1},"1":{"150":1,"168":1,"169":1,"170":1,"171":1,"184":1,"185":1,"191":1,"192":1,"193":1},"2":{"91":1,"93":1,"109":1,"110":2,"136":4,"137":2,"139":1,"144":4,"145":1,"147":6,"149":1,"150":7,"155":1,"156":1,"160":2,"161":2,"163":4,"166":1,"167":1,"168":8,"169":2,"170":1,"173":1,"175":3,"176":1,"183":5,"184":1,"186":1,"188":1,"190":1,"191":5,"194":7,"199":2,"331":4,"332":2,"333":2,"371":4,"408":4,"409":1,"411":5,"412":2,"477":3,"483":4,"518":3,"519":3,"523":1,"528":1,"555":3,"562":6,"563":6,"585":2,"586":2,"589":6,"590":6,"591":6,"594":2,"595":3,"596":24,"597":14,"598":1,"599":6,"668":1,"669":1,"671":1,"708":30,"709":5,"710":2,"738":8,"743":12,"744":1,"745":10,"746":3,"760":5,"769":8,"770":6,"771":51,"773":11,"774":1,"777":34,"778":2}}],["blobspace",{"0":{"667":1,"687":1},"1":{"668":1,"669":1}}],["blobsharerange",{"2":{"150":2,"163":4}}],["blobs",{"0":{"401":1,"514":1,"517":1,"585":1,"708":1,"709":1,"730":1,"777":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":1,"412":1,"413":1,"515":1,"516":1,"517":1,"518":2,"519":2,"520":1,"521":1,"522":1,"523":1,"586":1,"587":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1},"2":{"68":1,"109":1,"137":1,"150":1,"402":1,"404":2,"493":1,"505":1,"515":1,"538":1,"540":1,"555":1,"585":1,"586":1,"589":1,"590":3,"596":2,"599":1,"668":2,"671":1,"708":5,"709":11,"710":13,"728":1,"745":1,"771":1,"777":13,"778":17}}],["blobstreamgit",{"2":{"584":1}}],["blobstreamwrapper",{"2":{"162":4}}],["blobstreamxcd",{"2":{"208":1}}],["blobstreamxdatacommitmentstored",{"2":{"144":4,"161":4,"162":2}}],["blobstreamxwrapper",{"2":{"144":14,"161":6,"162":4}}],["blobstreamxsp1",{"2":{"136":1,"144":1,"161":1,"162":1,"163":1}}],["blobstreamx",{"0":{"208":1},"1":{"209":1,"210":1},"2":{"91":4,"109":3,"111":2,"118":1,"120":1,"136":4,"144":16,"154":2,"161":8,"162":4,"163":10,"200":1,"202":2,"203":5,"204":2,"208":5,"210":4,"211":9,"212":2,"215":7,"217":3,"233":4,"234":1}}],["blobstream",{"0":{"97":1,"111":1,"114":1,"117":1,"123":1,"124":1,"132":1,"135":1,"144":1,"165":1,"200":1,"220":1,"221":1,"222":1,"223":1,"227":1,"228":1,"229":1,"230":1,"232":2,"233":1,"234":1,"235":1,"583":1},"1":{"98":1,"99":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"154":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"164":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"195":1,"196":1,"197":1,"198":1,"199":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"221":1,"222":2,"223":1,"224":2,"225":2,"226":2,"227":1,"228":1,"229":2,"230":2,"231":2,"233":2,"234":2,"235":2,"236":2,"584":1},"2":{"26":1,"90":3,"91":6,"96":1,"97":1,"108":1,"110":1,"111":1,"112":1,"117":4,"118":22,"121":1,"122":9,"124":3,"125":2,"126":4,"127":3,"128":1,"130":2,"132":1,"136":4,"137":2,"139":5,"141":2,"144":7,"154":4,"160":6,"161":5,"162":5,"163":13,"164":1,"165":2,"166":2,"168":2,"171":1,"174":1,"175":2,"178":2,"186":1,"201":1,"203":2,"212":1,"216":3,"217":1,"218":4,"219":2,"221":11,"222":3,"224":2,"225":2,"226":3,"227":12,"228":6,"229":4,"230":2,"231":8,"233":8,"234":3,"235":3,"236":1,"400":1,"583":3,"584":6}}],["blocktimes",{"2":{"720":1}}],["blockdataroot",{"2":{"160":3,"163":8}}],["blockres",{"2":{"144":2,"150":2}}],["blocknumber",{"2":{"144":2,"161":2,"537":2}}],["block",{"0":{"92":1,"130":1,"133":1,"144":1,"365":1,"370":1,"383":2,"592":1,"625":2,"632":1,"752":1},"2":{"68":1,"91":1,"93":12,"118":16,"119":2,"120":1,"122":5,"124":1,"125":34,"126":2,"127":4,"128":17,"130":15,"137":4,"139":3,"141":3,"144":10,"149":1,"150":6,"151":1,"152":1,"160":16,"161":4,"163":6,"168":3,"171":1,"172":3,"174":1,"183":1,"187":1,"199":1,"209":4,"215":2,"216":6,"221":1,"227":2,"228":1,"233":3,"238":2,"267":1,"279":2,"322":3,"338":2,"363":1,"365":2,"368":3,"369":1,"370":2,"371":1,"381":3,"383":4,"412":2,"415":2,"429":4,"455":1,"459":1,"461":1,"475":5,"483":3,"493":1,"526":1,"528":1,"530":1,"536":3,"558":2,"586":2,"592":2,"597":2,"614":1,"620":1,"625":5,"627":3,"628":4,"629":2,"630":4,"631":4,"632":2,"635":1,"638":1,"640":1,"641":8,"642":3,"643":4,"644":3,"646":2,"648":2,"649":10,"650":13,"668":3,"670":1,"672":4,"675":3,"678":1,"690":1,"711":2,"720":1,"731":1,"743":1,"745":6,"746":1,"752":10,"760":1,"771":2,"779":2,"783":1}}],["blockscout",{"2":{"77":1,"92":2}}],["blocks",{"0":{"128":1},"2":{"67":1,"86":2,"92":1,"125":3,"126":4,"127":1,"128":12,"130":13,"139":4,"145":1,"161":2,"172":2,"178":2,"208":1,"216":1,"238":3,"281":2,"289":1,"322":4,"365":3,"368":4,"369":2,"371":3,"455":3,"492":1,"504":1,"505":2,"531":2,"592":2,"605":1,"627":1,"631":2,"632":1,"635":1,"642":1,"643":1,"671":3,"672":3,"675":1,"720":2}}],["blockchains",{"0":{"579":1,"639":1,"647":1,"720":1},"1":{"580":1,"581":1,"582":1},"2":{"53":3,"56":1,"58":1,"127":1,"255":1,"281":1,"572":2,"578":3,"580":2,"581":2,"582":1,"627":2,"629":1,"637":1,"639":1,"647":6,"648":1}}],["blockchain",{"0":{"578":1,"636":1,"645":1},"1":{"646":1},"2":{"18":1,"34":1,"51":1,"53":1,"125":3,"126":3,"130":1,"134":1,"252":3,"322":1,"356":1,"370":2,"372":1,"427":1,"454":2,"524":1,"531":1,"577":1,"578":3,"580":3,"597":2,"627":1,"628":1,"634":1,"636":1,"637":1,"639":1,"640":2,"646":3,"647":1,"648":2,"651":1,"674":2,"687":1,"688":2,"720":2,"763":3,"773":3}}],["blog",{"2":{"30":1,"32":1}}],["b",{"2":{"130":10,"163":24,"341":1,"434":8,"584":1,"679":1,"680":1,"777":4}}],["brush",{"2":{"578":1}}],["brevity",{"2":{"557":1,"647":1}}],["brew",{"2":{"275":1,"398":4}}],["breaking",{"2":{"524":4,"526":1,"530":1,"552":1,"591":1}}],["break",{"2":{"60":1,"349":1,"562":1,"563":1}}],["breaks",{"2":{"31":1,"37":1}}],["broken",{"2":{"291":2,"526":1}}],["browsers",{"2":{"726":1}}],["browser",{"0":{"461":1,"654":1,"659":1},"2":{"82":1,"275":1,"461":1,"495":1,"654":1}}],["broadcasttx",{"2":{"597":2}}],["broadcast",{"2":{"210":2,"279":4,"303":2,"412":2,"508":1,"648":1}}],["broadcasting",{"2":{"68":1,"294":2,"303":2,"493":1,"505":1,"506":1,"620":2}}],["broader",{"2":{"37":1,"40":1,"58":1,"479":1}}],["branding",{"0":{"52":1}}],["brand",{"2":{"41":1,"52":1}}],["branch",{"2":{"2":3}}],["brightlystake",{"2":{"487":1,"488":1,"489":1,"506":1,"507":1,"508":1}}],["brightest",{"2":{"58":1}}],["bridging",{"0":{"74":1},"1":{"75":1,"76":1,"77":1,"78":1,"79":1,"80":1},"2":{"74":1,"87":1,"227":2,"255":1}}],["bridgefulllight",{"2":{"698":1,"699":1,"700":1}}],["bridgecelestia",{"2":{"476":1,"477":1}}],["bridgecreator",{"2":{"100":1,"101":1}}],["bridge=",{"2":{"314":4}}],["bridgesudo",{"2":{"337":1}}],["bridges",{"2":{"227":1,"531":1}}],["bridge",{"0":{"67":1,"75":1,"78":1,"237":1,"238":1,"240":1,"242":1,"244":1,"245":1,"246":1,"248":1,"255":1,"363":1,"475":1,"492":1,"502":1,"504":1,"509":1,"605":1,"617":1,"618":1,"619":1},"1":{"76":1,"77":1,"79":1,"80":1,"238":1,"239":1,"240":1,"241":2,"242":1,"243":2,"244":2,"245":2,"246":3,"247":3,"248":2,"364":1,"365":1,"503":1,"504":1,"505":1,"619":1},"2":{"23":2,"26":3,"27":1,"65":6,"67":1,"68":2,"74":2,"76":1,"77":1,"79":1,"80":2,"84":2,"88":1,"93":8,"94":1,"100":1,"101":1,"105":1,"126":2,"163":4,"221":1,"237":2,"238":4,"239":1,"243":1,"244":9,"245":12,"246":9,"247":3,"248":2,"255":2,"313":2,"314":4,"322":1,"326":2,"328":1,"335":1,"336":4,"337":10,"349":2,"350":1,"353":1,"355":3,"363":1,"386":1,"387":1,"400":1,"472":1,"475":10,"476":2,"477":2,"491":1,"492":1,"493":2,"499":1,"504":1,"505":2,"509":7,"531":1,"533":1,"605":20,"606":1,"615":3,"617":2,"618":2,"619":2,"647":1,"696":1,"698":2,"699":2,"700":2,"734":1}}],["briefly",{"2":{"38":1,"87":1}}],["bringing",{"2":{"275":1}}],["bring",{"2":{"35":1,"58":1}}],["bonddenomalias",{"2":{"694":1}}],["bonddenom",{"2":{"693":1}}],["bonded",{"2":{"281":2}}],["bonus",{"2":{"596":2,"774":1}}],["box",{"2":{"582":1}}],["boxes",{"2":{"79":1}}],["bound",{"2":{"483":1}}],["bounds",{"2":{"174":2,"179":1}}],["bot",{"2":{"430":1}}],["both",{"2":{"22":1,"23":1,"27":1,"88":1,"93":1,"97":1,"126":1,"186":1,"204":1,"226":1,"275":1,"283":1,"303":1,"310":1,"430":1,"455":1,"519":1,"590":1,"640":1,"644":1,"647":1,"668":1,"677":1}}],["bootstrapping",{"0":{"688":1},"2":{"672":1}}],["bootstrappeers",{"2":{"352":2}}],["bootstrappers",{"2":{"352":1,"493":1}}],["bootstrapper",{"2":{"314":1,"352":3,"509":1}}],["bootstrap",{"0":{"352":1},"2":{"355":1,"688":1}}],["boolean",{"2":{"316":2,"320":1}}],["bool",{"2":{"118":2,"144":2,"163":2}}],["boost",{"2":{"40":1}}],["book",{"2":{"34":1,"134":1}}],["board",{"2":{"37":2}}],["borrowing",{"2":{"34":1}}],["body",{"2":{"6":1,"294":2}}],["bad",{"2":{"632":2}}],["bar",{"2":{"599":1}}],["bare",{"2":{"390":1}}],["barrier",{"2":{"86":2}}],["bak",{"2":{"361":10,"378":2}}],["balancecelestia",{"2":{"408":1,"409":1,"561":1,"748":1}}],["balance",{"0":{"748":1,"749":1,"755":1},"2":{"93":4,"226":1,"267":1,"297":3,"367":1,"400":1,"408":3,"409":2,"413":1,"422":1,"465":1,"561":2,"748":2,"749":7,"765":3,"783":1,"784":1}}],["balances",{"0":{"297":1,"409":1},"2":{"68":1,"244":1,"265":5,"294":1,"297":6,"309":2,"413":2,"422":1,"493":1,"505":1,"636":2,"735":1}}],["batcher",{"2":{"455":5,"537":1,"539":1,"540":1,"544":4}}],["batched",{"2":{"225":1}}],["batches",{"0":{"539":1},"2":{"86":2,"90":1,"109":1,"111":2,"119":1,"144":2,"161":2,"163":2,"171":1,"215":5,"233":2,"455":3,"539":2,"649":1}}],["batchposter",{"2":{"112":1}}],["batch",{"0":{"90":1},"2":{"86":4,"87":1,"88":2,"90":2,"91":5,"93":3,"95":1,"109":8,"120":2,"139":4,"160":1,"208":1,"216":1,"429":8,"539":4}}],["backward",{"2":{"524":2}}],["backers",{"2":{"679":2,"680":2}}],["backed",{"2":{"380":2}}],["backend=test",{"2":{"620":2}}],["backend=",{"2":{"279":2}}],["backend",{"2":{"245":2,"261":4,"279":8,"299":3,"303":4,"308":2,"320":1,"412":2,"422":2,"446":2,"447":2,"449":2,"466":4,"477":2,"521":2,"557":4,"698":6,"699":6,"700":6,"704":2,"705":2,"736":4}}],["background",{"0":{"328":1,"600":1},"1":{"601":1,"602":1,"603":1,"604":1,"605":1,"606":1},"2":{"143":2,"144":4,"150":4,"163":2,"248":1,"373":1,"425":1,"470":1,"600":1,"601":1,"602":1,"606":1,"619":1,"770":2,"771":2,"773":2}}],["back",{"2":{"80":1,"90":1,"109":1,"112":1,"130":1,"179":3,"199":1,"202":1,"247":1,"424":1,"428":1,"438":1,"455":1,"469":1,"596":2,"625":2,"708":2,"769":1,"771":2,"773":2,"774":2,"777":2}}],["basically",{"2":{"582":1}}],["basic",{"0":{"739":1},"1":{"740":1,"741":1,"742":1},"2":{"275":1,"380":1,"384":1,"389":2,"738":1,"739":1}}],["basefeepergas",{"2":{"536":1}}],["basechainhandle",{"2":{"434":8}}],["baseaccount",{"2":{"296":3}}],["base64=truecelestia",{"2":{"745":2}}],["base64=true",{"2":{"745":3}}],["base64",{"2":{"142":1,"147":1,"152":1,"156":1,"157":1,"537":3,"538":1,"743":4,"745":4,"761":1}}],["base",{"0":{"99":1,"101":1,"296":1},"2":{"84":2,"86":13,"87":6,"88":1,"91":2,"93":12,"94":1,"97":1,"99":1,"185":1,"216":1,"228":1,"231":2,"295":4,"647":2}}],["based",{"2":{"22":2,"23":1,"82":1,"122":1,"214":1,"224":1,"311":1,"341":1,"343":1,"473":1,"586":2,"589":2,"590":3,"609":1,"639":1,"651":1,"669":1,"674":1,"675":1,"688":1,"715":1,"720":2,"746":1,"763":1}}],["bashroot",{"2":{"705":1}}],["bashmoniker=",{"2":{"620":1}}],["bashmake",{"2":{"311":1,"341":4}}],["bashinfo\\tnode\\tnodebuilder",{"2":{"557":1}}],["bash$home",{"2":{"542":3}}],["bashhermes",{"2":{"430":1,"431":1,"433":3,"434":2}}],["bashvalidator",{"2":{"614":1}}],["bashvim",{"2":{"429":1}}],["bashver=",{"2":{"399":3}}],["bashzsh",{"2":{"399":1}}],["bashdocker",{"2":{"390":3,"392":3,"393":3,"704":4,"705":4}}],["bashpersistent",{"2":{"361":3}}],["bashprometheus",{"2":{"275":1}}],["bashprivate",{"2":{"93":1}}],["bashsuccess",{"2":{"431":1,"434":2}}],["bashsudo",{"2":{"337":2,"391":1,"398":4}}],["bashseeds=$",{"2":{"361":2}}],["bashnano",{"2":{"337":1}}],["bashenter",{"2":{"614":1}}],["bashecho",{"2":{"399":2}}],["basherror",{"2":{"337":1}}],["bashexport",{"2":{"287":1,"293":1,"299":1,"301":1,"314":2,"390":7,"405":1,"412":1,"475":1,"476":1,"536":1,"537":1,"558":1,"740":2,"741":1,"755":1,"760":1}}],["bashfatal",{"2":{"336":1}}],["bashfunding",{"2":{"93":1}}],["bashbash",{"2":{"312":1,"556":1}}],["bashbalances",{"2":{"297":2}}],["bashgo",{"2":{"399":1,"707":1}}],["bashgas",{"2":{"294":1}}],["bashgrafana",{"2":{"275":1}}],["bashgit",{"2":{"89":1,"311":3,"341":3}}],["bash",{"2":{"274":1,"279":1,"287":1,"291":1,"292":2,"294":3,"295":2,"296":2,"297":2,"312":1,"320":1,"329":2,"331":1,"332":1,"333":1,"343":5,"361":1,"391":1,"392":1,"393":1,"398":3,"399":4,"435":2,"474":2,"556":1,"559":2,"562":1,"563":1,"698":3,"699":3,"700":3,"704":2,"705":1,"736":2,"742":2,"760":1}}],["bashcargo",{"2":{"776":1}}],["bashcast",{"2":{"536":1,"537":1}}],["bashcontainer",{"2":{"704":1,"705":1}}],["bashcurl",{"2":{"274":1,"475":1,"538":1,"760":1}}],["bashcd",{"2":{"215":1,"286":1,"288":1,"291":1,"311":1,"341":1,"372":3,"391":1,"399":4,"474":1}}],["bashcelestia",{"2":{"68":2,"91":2,"299":3,"301":2,"314":1,"329":2,"334":2,"335":2,"341":1,"343":1,"348":1,"361":6,"407":2,"408":3,"409":1,"410":1,"411":1,"412":1,"413":1,"437":1,"475":2,"476":3,"477":4,"493":1,"556":1,"557":1,"559":1,"561":2,"562":2,"563":2,"565":1,"594":1,"595":1,"614":2,"617":1,"618":1,"734":3,"735":6,"736":3,"738":3,"741":1,"742":2,"743":4,"745":5,"746":1,"748":1,"749":2,"750":1,"751":1,"752":2,"753":1,"754":1,"755":3,"756":1,"757":2,"758":1}}],["bash2024",{"2":{"214":1,"383":1,"625":1}}],["bashyarn",{"2":{"1":1}}],["bank",{"2":{"265":10,"279":4,"297":4,"309":2,"412":2,"413":2,"477":2,"715":1}}],["bandwidth",{"2":{"239":1,"357":1,"416":1,"460":1,"533":1,"534":1,"611":1,"642":1,"720":2,"732":1}}],["banner",{"2":{"38":1}}],["banners",{"2":{"38":1}}],["ban",{"0":{"14":1,"15":1},"2":{"13":1,"14":2,"15":1}}],["buckets",{"2":{"429":8}}],["bug",{"2":{"336":2,"534":1}}],["burned",{"2":{"266":1}}],["bubs",{"0":{"249":1,"251":1},"1":{"250":1,"251":1,"252":2,"253":2,"254":2,"255":2,"256":2,"257":2,"258":2,"259":1},"2":{"249":2,"250":3,"251":2,"252":1,"253":1,"254":3,"255":2,"256":2,"257":1,"258":1,"259":1,"457":1}}],["businesses",{"2":{"38":1}}],["budget",{"2":{"35":3,"40":1}}],["button",{"2":{"87":1,"88":1,"275":1,"599":2,"659":1,"782":4}}],["but",{"2":{"7":1,"23":1,"26":1,"29":1,"34":1,"35":3,"38":1,"41":1,"42":1,"58":1,"60":1,"86":4,"109":2,"110":1,"125":1,"126":2,"161":2,"162":2,"163":2,"170":1,"208":1,"210":1,"219":1,"226":1,"227":2,"276":1,"287":1,"290":1,"322":2,"368":2,"371":1,"381":1,"383":1,"414":1,"430":1,"445":1,"479":1,"499":1,"519":1,"531":1,"540":1,"544":1,"578":1,"592":1,"615":1,"625":1,"636":1,"649":1,"671":1,"680":2,"717":1,"718":1}}],["buildmake",{"2":{"341":1}}],["builds",{"2":{"287":1}}],["builders",{"2":{"580":1}}],["builder",{"2":{"214":1}}],["buildcd",{"2":{"202":1}}],["build",{"0":{"214":1,"215":1,"769":1},"2":{"37":1,"165":1,"166":1,"178":1,"183":1,"202":2,"203":2,"211":3,"213":2,"214":14,"215":22,"221":1,"230":1,"251":1,"286":2,"287":3,"288":2,"291":2,"311":1,"341":10,"398":4,"399":1,"439":1,"566":1,"571":1,"580":1,"687":1}}],["building",{"0":{"1":1,"251":1,"311":1,"573":1,"645":1,"767":1},"1":{"252":1,"253":1,"254":1,"255":1,"256":1,"257":1,"258":1,"574":1,"575":1,"576":1,"646":1,"768":1,"769":1,"770":1,"771":1,"772":1,"773":1},"2":{"3":1,"166":1,"215":1,"341":1,"397":1,"463":1,"566":1,"574":1,"722":1,"765":1}}],["built",{"0":{"250":1,"312":1,"342":1},"1":{"343":1},"2":{"1":1,"110":1,"166":1,"168":1,"178":1,"214":2,"224":1,"233":1,"238":2,"281":1,"310":1,"312":3,"342":2,"427":2,"437":1,"454":2,"455":1,"457":1,"556":1,"646":2,"672":1,"689":1,"697":1}}],["bypassing",{"2":{"328":1}}],["bytes=",{"2":{"483":1}}],["bytes28",{"2":{"156":2,"157":2}}],["bytes1",{"2":{"156":2,"157":2}}],["bytes",{"0":{"483":1},"2":{"118":4,"154":2,"155":2,"156":5,"157":1,"158":4,"163":6,"174":1,"204":4,"482":1,"483":4,"586":4,"589":1,"596":4,"597":2,"642":2,"643":3,"649":1,"708":4,"743":1,"771":2}}],["bytes32",{"2":{"118":8,"142":1,"147":1,"152":1,"156":2,"159":3,"160":2,"163":2,"204":11,"206":3,"207":2,"219":1}}],["byte",{"2":{"91":3,"125":8,"144":10,"156":17,"157":7,"159":4,"160":6,"163":36,"202":2,"226":1,"590":1,"591":1,"596":4,"597":4,"708":4,"709":2,"710":2,"771":4}}],["by",{"0":{"144":1,"366":1,"752":1},"2":{"7":1,"16":1,"18":1,"20":1,"22":2,"23":2,"32":1,"35":1,"36":1,"37":1,"40":1,"41":1,"42":1,"54":1,"58":2,"81":1,"85":1,"86":2,"87":1,"89":1,"90":1,"91":2,"93":3,"109":1,"112":1,"118":2,"120":1,"122":7,"124":1,"125":1,"126":5,"128":2,"130":2,"139":3,"140":1,"141":1,"142":1,"144":6,"147":1,"154":4,"157":1,"160":2,"163":6,"164":1,"168":2,"171":1,"172":1,"174":2,"175":2,"178":1,"183":1,"187":1,"202":1,"204":2,"205":1,"206":2,"212":1,"214":2,"215":1,"216":3,"218":2,"219":1,"221":2,"233":1,"234":1,"236":1,"245":2,"249":1,"250":1,"260":4,"266":2,"274":1,"275":3,"276":1,"279":2,"280":1,"281":1,"295":1,"309":1,"313":3,"315":1,"326":3,"341":1,"343":1,"350":2,"352":2,"355":2,"368":1,"370":1,"371":1,"377":2,"380":2,"383":2,"391":1,"400":1,"404":1,"412":1,"422":2,"427":2,"428":1,"434":1,"441":1,"442":1,"443":1,"444":1,"451":1,"453":1,"455":2,"463":1,"466":3,"477":1,"483":4,"494":1,"506":1,"515":1,"518":2,"519":1,"531":2,"539":2,"542":1,"552":1,"556":1,"561":1,"565":1,"580":1,"581":1,"582":1,"584":1,"587":2,"588":6,"589":5,"590":6,"591":2,"592":2,"614":1,"625":2,"628":1,"629":1,"630":1,"631":1,"632":1,"641":2,"642":1,"644":2,"646":3,"648":2,"649":5,"650":3,"669":1,"671":3,"672":3,"675":1,"680":1,"681":1,"688":1,"689":1,"696":1,"704":1,"705":2,"715":1,"719":2,"720":1,"726":1,"728":1,"730":1,"736":3,"743":3,"752":4,"753":4,"758":6,"765":2,"769":1,"771":1,"778":2,"783":1}}],["bearer",{"2":{"538":2,"760":2}}],["bedrock",{"2":{"250":1}}],["belonging",{"2":{"322":1}}],["belong",{"2":{"154":2,"168":2,"174":1}}],["below",{"2":{"20":1,"21":1,"41":1,"65":1,"74":1,"86":1,"91":1,"97":1,"98":1,"99":1,"127":1,"137":1,"160":1,"171":1,"188":1,"233":1,"234":1,"309":1,"311":1,"312":1,"392":1,"393":1,"422":1,"465":1,"485":1,"487":1,"503":1,"505":1,"509":1,"537":1,"538":1,"614":1,"620":2,"646":1,"649":2,"672":1,"675":1,"679":1,"680":1,"707":1,"776":1}}],["bech32prefixconspub",{"2":{"782":2}}],["bech32prefixconsaddr",{"2":{"782":2}}],["bech32prefixvalpub",{"2":{"782":2}}],["bech32prefixvaladdr",{"2":{"782":2}}],["bech32prefixaccpub",{"2":{"782":2}}],["bech32prefixaccaddr",{"2":{"782":2}}],["bech32config",{"2":{"782":2}}],["bech",{"2":{"614":2}}],["because",{"2":{"110":1,"128":1,"173":1,"331":1,"369":1,"428":1,"582":1,"627":1,"637":1,"720":1,"765":1,"771":1}}],["becomes",{"2":{"355":1,"516":1,"627":2}}],["become",{"2":{"47":1,"50":1}}],["behalf",{"2":{"406":1}}],["behave",{"2":{"278":1}}],["behavior",{"2":{"7":2,"8":2,"10":1,"12":2,"13":1,"14":1,"15":1,"281":1,"328":1,"371":1,"459":1,"738":1}}],["behind",{"2":{"60":1,"109":1,"378":1,"552":1,"720":1}}],["beneficial",{"2":{"42":1}}],["benefit",{"2":{"38":2,"40":1,"111":1}}],["benefits",{"0":{"579":1},"1":{"580":1,"581":1,"582":1},"2":{"34":1,"38":1,"53":1,"56":1,"58":2,"572":2}}],["better",{"2":{"41":1,"42":1,"126":1,"166":1,"197":1,"199":1,"259":1,"672":1}}],["between",{"0":{"432":1,"635":1},"2":{"36":1,"37":1,"87":1,"130":1,"175":1,"183":1,"202":1,"226":1,"255":2,"313":1,"326":1,"415":1,"427":2,"428":1,"429":1,"432":1,"434":1,"531":1,"605":1,"647":1,"675":1}}],["betaarabica",{"2":{"542":1}}],["betaarabicamocha",{"2":{"468":1}}],["betamochaarabica",{"2":{"244":1,"246":1,"311":1,"341":1,"361":4,"372":1,"373":1,"390":2,"392":1,"393":1,"399":1,"421":1,"423":1,"464":1,"465":1,"466":1,"620":1,"734":1,"735":2,"736":1,"782":1}}],["beta",{"0":{"317":1,"331":1,"478":1,"547":1,"548":1,"682":1},"1":{"479":1,"480":1,"481":1,"482":1,"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1,"490":1,"491":1,"492":1,"493":1,"494":1,"495":1,"496":1,"497":1,"498":1,"548":1},"2":{"23":4,"24":1,"26":4,"27":1,"112":1,"136":1,"231":3,"245":1,"317":1,"324":1,"325":3,"328":1,"331":3,"338":1,"343":2,"361":1,"371":1,"390":1,"400":1,"422":2,"456":1,"465":1,"478":3,"479":2,"484":2,"493":1,"496":1,"498":2,"526":1,"530":2,"547":2,"554":1,"586":1,"607":1,"617":1,"682":1,"698":3,"704":1,"705":1,"735":1,"736":1,"760":1}}],["beefy",{"2":{"211":1,"214":1,"215":1}}],["beer",{"2":{"35":1}}],["been",{"2":{"26":1,"93":2,"96":1,"109":1,"112":2,"118":3,"168":1,"219":1,"281":1,"295":1,"309":1,"326":1,"328":1,"409":1,"413":2,"434":1,"464":1,"482":1,"562":1,"602":1,"606":1,"627":1,"636":1,"637":1,"672":2,"726":1,"731":1,"765":1}}],["beginkey",{"2":{"156":3,"175":2}}],["beginning",{"2":{"38":2,"156":2,"160":1,"208":1,"675":1}}],["begin",{"2":{"32":1,"130":1,"175":1,"275":1,"405":1,"770":1}}],["be",{"0":{"154":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1},"2":{"7":2,"10":2,"12":1,"20":1,"22":3,"25":3,"26":1,"28":1,"34":3,"35":3,"37":1,"38":3,"39":4,"42":4,"47":1,"58":1,"60":2,"64":1,"68":1,"79":2,"80":1,"85":1,"86":5,"87":1,"90":1,"91":4,"92":2,"97":1,"105":1,"109":3,"110":2,"111":2,"112":1,"117":1,"122":1,"125":4,"126":5,"127":2,"128":3,"130":3,"136":8,"137":2,"139":3,"140":1,"141":1,"142":2,"143":1,"145":1,"146":1,"147":2,"149":1,"151":1,"152":3,"153":2,"155":2,"156":2,"157":2,"158":1,"159":1,"160":4,"161":2,"162":1,"163":3,"164":1,"166":3,"168":3,"169":4,"170":1,"171":2,"172":4,"174":2,"175":6,"178":2,"180":3,"182":2,"183":5,"185":1,"186":1,"187":4,"188":2,"190":2,"191":2,"193":1,"194":2,"197":1,"201":1,"202":11,"203":2,"204":1,"206":2,"208":3,"209":1,"210":3,"211":2,"214":1,"215":4,"216":3,"217":1,"218":1,"219":2,"221":1,"228":2,"230":1,"233":4,"234":2,"235":1,"243":1,"244":1,"245":1,"246":1,"250":1,"263":3,"266":5,"267":1,"273":1,"274":1,"276":1,"277":1,"278":1,"279":2,"281":4,"287":1,"298":1,"304":2,"309":1,"311":2,"312":1,"313":1,"316":1,"321":2,"324":2,"326":2,"334":4,"337":1,"342":1,"350":1,"352":1,"355":2,"363":1,"366":1,"371":5,"376":1,"377":1,"380":2,"381":1,"390":1,"391":2,"397":1,"400":3,"404":1,"406":1,"422":4,"423":1,"426":2,"427":1,"429":1,"430":2,"434":2,"437":3,"438":1,"443":1,"448":1,"449":1,"450":1,"453":1,"465":2,"466":1,"468":1,"479":1,"482":1,"483":4,"485":1,"503":1,"507":1,"509":1,"518":1,"520":1,"524":1,"526":2,"528":2,"539":3,"540":1,"542":3,"544":1,"550":3,"552":2,"557":2,"562":1,"565":1,"580":4,"582":2,"584":1,"586":2,"587":1,"588":1,"589":3,"590":1,"591":2,"592":3,"597":4,"602":1,"604":2,"605":2,"606":1,"607":2,"608":2,"617":1,"620":3,"628":1,"631":1,"632":3,"634":2,"637":2,"638":1,"641":1,"642":1,"643":3,"644":1,"647":3,"649":2,"650":1,"668":2,"669":1,"670":1,"671":4,"672":3,"675":2,"680":2,"688":1,"696":1,"697":1,"698":2,"704":1,"705":1,"708":2,"715":1,"719":1,"720":3,"723":1,"726":2,"731":1,"734":1,"735":1,"736":1,"738":1,"739":2,"740":2,"743":6,"746":2,"749":1,"760":1,"763":2,"764":1,"765":4,"766":1,"769":1,"771":1,"777":2,"783":1,"784":1}}],["best",{"2":{"7":1,"54":1,"58":1,"63":1,"276":1,"484":1,"499":1,"581":1}}],["being",{"2":{"7":1,"23":1,"25":1,"86":1,"91":2,"104":1,"110":1,"128":1,"150":2,"152":1,"153":1,"156":2,"157":1,"158":1,"159":1,"160":3,"187":1,"202":1,"214":1,"238":1,"324":1,"363":1,"369":1,"438":1,"540":1,"609":1,"634":1,"650":1,"680":1,"715":1,"746":1}}],["before",{"0":{"30":1},"2":{"2":1,"23":2,"26":1,"36":2,"37":1,"39":1,"87":1,"91":2,"112":1,"127":1,"130":3,"155":1,"171":1,"211":1,"233":1,"234":1,"289":1,"294":2,"324":1,"371":2,"391":1,"428":1,"444":1,"447":1,"528":2,"543":1,"602":1,"620":2,"649":1,"738":1,"782":3}}],["rsmt2d",{"2":{"711":2}}],["rs",{"2":{"461":1}}],["rsvp",{"2":{"30":1}}],["rf",{"2":{"311":2,"336":4,"341":2,"372":6,"399":8}}],["rfc",{"2":{"119":1}}],["richer",{"2":{"722":1}}],["rickroll",{"2":{"557":1}}],["rigorous",{"2":{"478":1}}],["right",{"2":{"8":1,"76":1,"91":1,"556":1,"572":1,"599":1,"659":1,"688":1}}],["risk",{"2":{"221":1}}],["r6a",{"2":{"217":1}}],["r",{"2":{"215":2,"361":2,"475":2,"537":4,"558":4,"679":1,"680":2,"753":2,"758":2}}],["r1cs",{"2":{"214":2}}],["r1",{"2":{"137":1}}],["r0",{"2":{"137":1}}],["rm",{"2":{"104":2,"311":2,"336":4,"341":2,"372":6,"399":16}}],["rc",{"2":{"96":1,"104":2}}],["rblocks",{"2":{"88":1}}],["rpcs",{"2":{"68":1,"493":1}}],["rpc",{"0":{"64":1,"65":1,"67":1,"90":1,"252":1,"333":1,"376":1,"377":1,"485":1,"487":1,"492":1,"494":1,"502":1,"503":1,"504":1,"506":1,"598":1,"717":1,"722":1,"724":1,"725":1,"728":1,"737":1},"1":{"253":1,"254":1,"377":1,"378":1,"379":1,"495":1,"503":1,"504":1,"505":1,"723":1,"724":1,"725":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":2,"739":2,"740":2,"741":2,"742":2,"743":2,"744":2,"745":2,"746":2,"747":2,"748":2,"749":2,"750":2,"751":2,"752":2,"753":2,"754":2,"755":2,"756":2,"757":2,"758":2,"759":1,"760":1,"761":1,"762":1},"2":{"64":3,"65":4,"67":2,"68":1,"90":3,"91":18,"93":7,"109":1,"126":4,"133":1,"136":5,"137":1,"142":1,"143":2,"144":8,"147":1,"150":2,"152":1,"161":4,"162":2,"163":6,"202":7,"203":4,"204":12,"208":1,"209":5,"210":4,"211":5,"218":2,"238":1,"244":1,"245":2,"252":2,"253":1,"254":1,"265":4,"301":8,"302":1,"303":5,"310":1,"313":2,"314":1,"326":2,"328":1,"329":2,"331":2,"333":3,"338":2,"344":1,"371":4,"376":1,"377":3,"378":1,"381":3,"390":5,"403":1,"405":2,"412":5,"413":2,"422":1,"429":16,"465":5,"466":3,"475":4,"476":3,"485":3,"487":16,"488":1,"489":2,"490":1,"492":2,"493":8,"503":3,"504":2,"505":4,"506":10,"508":1,"536":2,"537":2,"540":1,"544":7,"558":4,"559":4,"598":1,"607":1,"617":1,"704":2,"705":2,"706":1,"707":1,"717":2,"721":1,"722":3,"724":3,"725":1,"728":1,"731":1,"734":1,"735":4,"737":1,"738":2,"739":4,"740":1,"741":1,"750":1,"751":1,"760":1,"762":2,"765":2,"770":2,"771":2,"773":2,"775":1,"776":4,"777":4,"778":2,"779":2,"782":10,"783":2,"784":2}}],["round",{"2":{"752":2}}],["rounds",{"2":{"630":2}}],["roughly",{"2":{"592":1,"720":1}}],["route",{"2":{"333":2}}],["router",{"2":{"313":1,"326":1}}],["routes",{"2":{"210":1,"333":1}}],["routine",{"2":{"36":1}}],["robusta",{"2":{"742":2}}],["robust",{"2":{"251":1}}],["rowproof",{"2":{"158":1,"159":1,"163":4}}],["rowproofs",{"0":{"159":1},"2":{"154":2,"159":2,"160":1,"163":2,"175":4}}],["rowroots",{"0":{"158":1},"2":{"154":4,"158":3,"163":4}}],["row",{"2":{"110":3,"122":4,"137":1,"139":6,"145":3,"147":8,"151":6,"152":8,"154":2,"156":1,"159":1,"160":1,"168":2,"174":2,"175":7,"643":1,"649":4,"752":2}}],["rows",{"2":{"110":2,"122":3,"139":1,"151":1,"154":8,"156":1,"158":1,"159":1,"168":2,"174":2,"641":1}}],["ro",{"2":{"104":2}}],["room",{"2":{"586":1}}],["rooms",{"2":{"34":1}}],["roots",{"2":{"109":1,"110":5,"111":1,"122":2,"128":1,"137":1,"139":4,"147":2,"151":3,"152":2,"154":2,"156":1,"158":8,"160":1,"163":6,"168":6,"225":1,"227":2,"238":1,"641":3,"642":1,"643":1,"649":2,"650":1,"752":4}}],["root",{"0":{"141":1},"1":{"142":1,"143":1},"2":{"76":1,"89":2,"92":1,"93":1,"96":1,"110":2,"111":2,"112":1,"118":4,"119":4,"122":10,"125":1,"127":5,"128":1,"139":9,"141":8,"142":1,"144":12,"145":5,"147":1,"151":6,"154":14,"158":4,"159":1,"160":26,"163":10,"164":2,"168":8,"169":2,"174":5,"175":15,"187":4,"191":3,"194":2,"199":2,"221":1,"227":4,"322":1,"641":1,"643":1,"644":1,"649":2,"668":1,"705":2,"739":1}}],["role",{"0":{"686":1},"1":{"687":1,"688":1,"689":1,"690":1,"691":1,"692":1,"693":1,"694":1},"2":{"54":1,"55":1,"86":1,"690":1,"772":2}}],["roles",{"2":{"30":1}}],["roll",{"2":{"540":2,"543":3}}],["rolling",{"2":{"281":1}}],["rollback",{"2":{"260":8}}],["rollkit",{"2":{"42":1,"55":2}}],["rollupinclusionproofs",{"2":{"155":1,"156":1,"157":1,"159":1,"160":1,"182":1}}],["rollupuserlogic",{"2":{"100":1,"101":1}}],["rollupadminlogic",{"2":{"100":1,"101":1}}],["rollupeventinbox",{"2":{"100":1,"101":1}}],["rollupcreator",{"2":{"91":1,"98":1,"99":1,"100":1,"101":1}}],["rollup",{"0":{"55":1,"74":1,"75":1,"77":1,"78":1,"79":1,"81":1,"124":1,"126":1,"129":1,"163":1,"199":1,"540":1,"572":1,"577":1},"1":{"75":1,"76":2,"77":2,"78":1,"79":2,"80":2,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1,"127":1,"128":1,"130":1,"131":1,"132":1,"133":1,"134":1,"541":1,"542":1,"543":1,"544":1,"545":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1},"2":{"38":1,"55":4,"74":2,"77":4,"79":1,"81":3,"84":1,"85":3,"88":2,"90":1,"92":1,"93":8,"94":2,"103":1,"113":1,"118":15,"122":1,"124":3,"125":11,"126":15,"130":4,"134":1,"137":2,"139":2,"140":1,"145":2,"149":1,"157":1,"158":1,"160":2,"163":4,"165":1,"166":1,"169":4,"170":2,"171":1,"172":7,"175":3,"178":3,"179":7,"180":2,"182":1,"183":7,"186":2,"187":5,"190":2,"191":4,"194":4,"197":1,"199":2,"227":1,"229":1,"230":1,"234":1,"250":1,"251":1,"339":1,"422":2,"455":4,"540":3,"542":1,"544":2,"545":1,"571":1,"575":1,"577":1,"578":1,"580":2,"581":1,"582":5,"644":1,"670":2,"672":7,"679":1,"687":1,"714":1}}],["rollups",{"0":{"106":1,"165":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"192":1,"193":1,"230":1,"575":1,"672":1,"688":1},"1":{"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":2,"180":3,"181":3,"182":3,"183":2,"184":3,"185":3,"186":1,"187":2,"188":3,"189":3,"190":2,"191":3,"192":3,"193":3,"194":2,"195":2,"196":2,"197":1,"198":1,"199":1},"2":{"3":1,"37":1,"42":1,"53":1,"55":1,"59":1,"60":1,"84":1,"105":1,"108":1,"124":1,"127":3,"164":1,"165":2,"166":2,"171":1,"178":3,"179":1,"186":2,"191":1,"197":2,"227":4,"230":1,"250":1,"454":1,"478":1,"499":1,"535":1,"540":1,"547":1,"550":1,"552":1,"572":1,"576":1,"577":1,"578":1,"580":2,"581":6,"582":3,"628":1,"638":1,"647":1,"670":1,"672":3,"688":1}}],["roster",{"2":{"26":1}}],["rustasync",{"2":{"778":1,"779":1}}],["rustuse",{"2":{"777":1}}],["rust",{"0":{"567":1,"775":1},"1":{"776":1,"777":1,"778":1,"779":1,"780":1},"2":{"215":2,"221":1,"227":1,"427":1,"428":1,"567":2,"583":1,"725":1,"775":1}}],["rules",{"2":{"22":1,"126":1,"205":1,"563":1,"647":1}}],["rundown",{"2":{"572":1}}],["runtime",{"2":{"383":4,"406":1,"434":8,"625":4}}],["runs",{"2":{"275":2,"287":1,"590":1}}],["runners",{"2":{"68":1}}],["running",{"0":{"102":1,"104":1,"105":1,"316":1,"516":1,"531":1,"704":1},"1":{"103":1,"104":1,"105":1,"317":1,"318":1,"319":1,"320":1,"532":1,"533":1,"534":1},"2":{"3":1,"23":1,"54":1,"63":1,"82":1,"89":1,"90":1,"91":1,"93":6,"94":1,"105":1,"109":2,"117":1,"126":1,"211":1,"212":1,"218":1,"227":1,"239":1,"245":2,"271":1,"273":1,"274":1,"275":1,"276":1,"279":2,"289":1,"301":1,"302":1,"315":2,"321":1,"328":3,"333":1,"337":1,"341":1,"355":1,"357":1,"361":2,"371":1,"373":2,"383":3,"385":1,"387":2,"390":1,"391":1,"393":1,"397":1,"398":2,"403":1,"416":1,"422":2,"425":1,"426":1,"428":1,"430":1,"444":1,"453":1,"460":1,"466":3,"471":1,"475":1,"484":1,"499":1,"505":1,"528":1,"543":1,"544":2,"545":1,"552":1,"556":1,"559":2,"561":3,"565":1,"588":1,"596":2,"600":1,"601":1,"602":2,"607":1,"611":1,"615":3,"620":2,"625":4,"631":1,"705":1,"708":2,"714":1,"731":1,"732":1,"735":1,"736":3,"739":1,"740":1,"760":1,"765":4}}],["run",{"0":{"54":1,"91":1,"92":1,"211":1,"212":1,"245":1,"246":1,"286":1,"384":1,"420":1,"423":1,"461":1,"468":1,"540":1,"556":1,"618":1,"620":1,"765":1},"1":{"246":1,"247":1,"385":1,"386":1,"387":1,"421":1,"422":1,"424":1,"469":1,"541":1,"542":1,"543":1,"544":1,"545":1,"557":1,"558":1,"559":1,"619":1},"2":{"1":1,"23":2,"26":1,"51":1,"54":2,"63":1,"65":1,"68":1,"91":1,"92":1,"93":3,"94":1,"104":4,"105":1,"126":1,"202":1,"204":1,"208":4,"209":2,"210":1,"211":6,"214":3,"215":3,"217":2,"218":2,"235":1,"238":3,"243":1,"244":1,"246":1,"260":2,"272":1,"275":4,"280":1,"286":3,"287":2,"289":1,"294":1,"303":1,"308":1,"309":1,"310":1,"311":2,"312":1,"313":2,"321":1,"326":2,"334":1,"336":1,"338":1,"344":2,"345":1,"367":1,"371":1,"372":1,"373":1,"384":1,"386":1,"387":2,"388":6,"390":9,"392":9,"393":9,"397":1,"399":2,"404":1,"405":1,"410":1,"413":1,"421":1,"423":1,"425":1,"427":1,"431":1,"445":1,"446":1,"447":1,"449":2,"450":1,"452":2,"461":2,"464":1,"468":1,"474":1,"484":2,"493":1,"499":3,"505":1,"515":1,"531":1,"540":1,"542":1,"543":1,"555":1,"556":1,"557":3,"559":1,"562":1,"563":1,"570":1,"582":2,"584":1,"614":2,"615":1,"617":1,"618":1,"620":1,"703":1,"704":3,"707":1,"722":1,"724":1,"726":1,"735":1,"737":1,"743":1,"765":1,"768":1,"770":2,"771":2,"773":8,"776":1}}],["raas",{"2":{"540":2,"575":1}}],["rates",{"2":{"675":1}}],["rate",{"2":{"675":1,"784":3}}],["rate=0",{"2":{"272":6,"620":6}}],["rather",{"2":{"59":1,"226":1,"578":1,"675":1}}],["ram",{"2":{"211":1,"214":1,"215":1,"217":1,"239":1,"341":1,"357":1,"416":1,"460":1,"533":3,"534":2,"584":1,"611":1,"732":1}}],["rawlog",{"2":{"597":4}}],["raw",{"2":{"155":1,"238":2,"294":2,"361":10,"398":2,"459":1,"614":2,"620":2,"784":1}}],["rawmessage",{"2":{"125":2,"128":2}}],["rand",{"2":{"91":1}}],["randomly",{"2":{"641":1}}],["randomness",{"2":{"214":1}}],["random",{"2":{"91":1,"183":1,"214":1,"630":1,"648":1,"650":2}}],["ranges",{"0":{"216":1},"1":{"217":1,"218":1,"219":1},"2":{"216":2,"233":3}}],["range",{"0":{"151":1},"1":{"152":1,"153":1},"2":{"91":1,"109":3,"142":1,"144":6,"147":2,"149":1,"151":3,"156":4,"158":2,"159":4,"160":2,"161":6,"163":26,"174":1,"204":1,"210":2,"211":5,"215":14,"216":1,"217":1,"218":1,"219":2,"227":1,"228":2,"644":2}}],["rapidly",{"2":{"44":1}}],["race",{"2":{"6":1}}],["raises",{"2":{"86":1}}],["raise",{"2":{"4":1,"30":1}}],["redelegate",{"2":{"657":1,"661":1,"666":1}}],["reducing",{"2":{"648":1}}],["reduces",{"2":{"523":1}}],["reduce",{"2":{"455":1,"580":1}}],["reduced",{"2":{"34":1,"180":1,"479":1,"547":1,"580":1,"650":1}}],["redundant",{"2":{"632":1}}],["reed",{"2":{"641":2,"643":5,"646":1,"649":1}}],["reinitializing",{"2":{"444":1}}],["reinitialize",{"2":{"324":1}}],["reindexing",{"2":{"381":2}}],["reindex",{"2":{"381":1}}],["rejoin",{"2":{"281":1}}],["rejects",{"2":{"650":1}}],["rejected",{"2":{"438":1,"650":1}}],["reject",{"2":{"8":1,"643":1}}],["revoke",{"0":{"410":1},"1":{"411":1},"2":{"406":1,"410":3}}],["revert",{"2":{"163":2}}],["reveal",{"2":{"110":1}}],["revisit",{"2":{"40":1}}],["reviewing",{"2":{"32":1}}],["reviewed",{"2":{"10":1,"20":1,"23":1}}],["review",{"0":{"87":1},"2":{"2":1,"30":1,"47":1,"86":1,"87":2,"660":2,"665":1}}],["retain",{"0":{"365":1},"2":{"363":1,"365":5,"368":4}}],["returning",{"2":{"708":2,"777":2}}],["returned",{"2":{"204":3,"281":1,"438":1,"614":1,"644":1,"745":1}}],["return",{"2":{"118":2,"128":10,"130":12,"162":8,"203":2,"204":3,"215":2,"475":1,"597":18,"745":3,"755":1,"772":2,"782":2}}],["returns",{"2":{"91":1,"118":2,"126":4,"172":1,"204":1,"709":1,"710":1,"711":1,"743":1,"771":1,"772":2,"778":1,"779":1}}],["retrial",{"2":{"650":1}}],["retried",{"2":{"160":1}}],["retrievability",{"0":{"639":1,"670":1,"671":1},"1":{"671":1,"672":1},"2":{"636":1,"670":1,"671":1}}],["retrievable",{"2":{"494":1,"637":1,"670":1}}],["retrieval",{"2":{"322":1,"633":1}}],["retrieving",{"0":{"563":1,"708":1,"745":1,"777":1},"2":{"109":1,"371":1,"385":1,"559":1,"633":1,"637":1}}],["retrievedblobs",{"2":{"596":2,"708":2}}],["retrieved",{"2":{"136":1,"155":1,"160":1,"634":1,"672":1,"739":1,"769":2,"770":2,"771":2,"777":8}}],["retrieve",{"0":{"560":1},"1":{"561":1,"562":1,"563":1},"2":{"109":2,"151":1,"542":2,"555":2,"558":1,"563":2,"634":1,"728":1,"745":1,"761":1,"769":2,"770":2,"771":2,"772":1,"777":2}}],["retryable",{"2":{"93":6}}],["retryables",{"2":{"93":4}}],["rebasing",{"2":{"86":1}}],["rename",{"2":{"262":2}}],["renaming",{"2":{"262":2}}],["rentals",{"2":{"40":1}}],["renewals",{"2":{"22":1}}],["renewal",{"2":{"22":1,"25":1}}],["rewards",{"0":{"268":1},"2":{"267":1,"268":3,"281":1,"657":1,"661":1,"666":1,"674":2,"678":1,"680":1,"681":1,"689":1,"690":1}}],["reward",{"0":{"638":1},"2":{"37":1,"639":1}}],["regenerate",{"0":{"214":1}}],["regenerated",{"2":{"203":1}}],["regeneration",{"2":{"211":1}}],["regenerating",{"0":{"213":1},"1":{"214":1,"215":1},"2":{"203":1}}],["regen",{"2":{"140":4}}],["regions",{"2":{"41":1}}],["registering",{"2":{"210":1}}],["registerfunction",{"2":{"204":4}}],["register",{"0":{"204":1},"1":{"205":1,"206":1,"207":1},"2":{"204":3,"215":1,"429":2}}],["registered",{"2":{"30":1,"202":1,"205":2,"211":2,"235":1}}],["registry",{"2":{"202":1,"361":3,"371":1,"784":1}}],["registration",{"2":{"30":1,"31":1,"47":1,"204":1,"210":1}}],["regular",{"2":{"36":1,"42":1,"84":1,"278":1,"646":1}}],["regardless",{"2":{"6":1,"169":1,"607":1,"609":1}}],["refund",{"2":{"588":1,"590":1}}],["refunded",{"2":{"588":1}}],["refresh",{"2":{"429":2}}],["refreshments",{"0":{"35":1},"2":{"30":1,"35":6,"38":1}}],["refers",{"2":{"174":2,"238":1,"322":1}}],["referred",{"2":{"136":1,"647":1,"649":2}}],["referrals",{"2":{"37":2}}],["referencing",{"2":{"127":1,"170":2,"172":1,"173":1,"199":2}}],["references",{"2":{"187":1}}],["referenced",{"2":{"168":1,"172":1,"183":1,"187":1,"191":1,"194":1}}],["reference",{"0":{"199":1},"2":{"0":1,"36":1,"139":1,"179":1,"182":1,"186":1,"190":1,"191":1,"199":3,"433":6,"523":1}}],["refer",{"2":{"65":1,"86":1,"136":1,"202":1,"208":1,"244":1,"245":1,"281":1,"309":1,"324":1,"345":1,"388":1,"390":2,"422":2,"453":1,"465":1,"499":1,"590":2,"596":1,"617":1,"623":1,"644":1,"675":1,"698":1,"704":2,"735":1,"736":1,"744":1,"774":1}}],["rec",{"2":{"597":4}}],["recipient",{"2":{"267":2,"755":1}}],["recency",{"2":{"671":2}}],["recent",{"2":{"109":1,"494":1,"536":1}}],["receipt",{"2":{"680":1}}],["receiptsroot",{"2":{"536":2}}],["receiving",{"2":{"26":1,"778":2}}],["receiveroutine",{"2":{"383":4,"625":4}}],["receiver",{"2":{"93":4}}],["received",{"2":{"23":1,"162":1,"459":1,"641":1,"650":2}}],["receives",{"2":{"22":3,"627":1,"678":1,"690":1}}],["receive",{"2":{"20":1,"22":1,"26":1,"28":1,"47":1,"48":1,"202":1,"479":1,"547":1,"631":1,"641":1,"681":1,"709":1,"710":1,"746":1,"778":1}}],["recap",{"2":{"48":1}}],["recruiting",{"2":{"42":2}}],["reconstructing",{"2":{"643":1}}],["reconstruction",{"0":{"632":1}}],["reconstruct",{"2":{"631":1,"632":1,"672":1}}],["recoverable",{"2":{"643":1}}],["recovered",{"2":{"641":1}}],["recover",{"2":{"291":2,"308":1,"700":6}}],["recompute",{"2":{"110":1}}],["recommend",{"2":{"59":1,"86":1,"105":1,"344":2,"499":1,"544":2,"584":1,"714":1}}],["recommends",{"2":{"41":1}}],["recommendations",{"2":{"35":1}}],["recommended",{"0":{"532":1},"2":{"23":1,"29":1,"90":1,"199":1,"202":2,"211":1,"239":1,"245":1,"266":1,"339":1,"341":1,"357":1,"385":1,"396":1,"416":1,"422":1,"460":1,"607":1,"611":1,"615":1,"650":1,"695":1,"725":1,"732":1,"782":2}}],["recognizable",{"2":{"86":1}}],["recognize",{"2":{"47":1}}],["recognition",{"2":{"37":1}}],["recorded",{"2":{"40":4}}],["record",{"2":{"34":1}}],["recordings",{"2":{"34":1,"40":3}}],["recording",{"0":{"40":1},"2":{"34":2,"40":6}}],["reactjs",{"2":{"782":1}}],["react",{"0":{"782":1},"2":{"781":1,"782":4}}],["reaching",{"2":{"685":1}}],["reaches",{"2":{"630":1,"675":1}}],["reached",{"2":{"597":2}}],["reach",{"2":{"23":1,"30":1,"37":1,"38":1,"39":1,"40":3}}],["reaped",{"2":{"592":1}}],["reapplying",{"2":{"25":1}}],["reapply",{"2":{"23":1}}],["real",{"2":{"90":1,"478":1,"540":1,"602":1,"606":1}}],["readiness",{"2":{"525":1,"528":1}}],["reading",{"2":{"126":2,"244":1,"344":1,"422":1,"455":4,"633":1,"735":1}}],["reads",{"2":{"455":2,"772":1}}],["readme",{"2":{"282":1,"543":1,"544":1,"584":1}}],["reader",{"2":{"126":1,"136":1}}],["read",{"0":{"537":1},"2":{"79":1,"81":2,"96":1,"109":1,"110":1,"125":1,"126":1,"208":1,"396":1,"494":1,"499":1,"537":1,"589":1,"726":1,"730":1,"731":1,"738":1,"745":1}}],["ready",{"2":{"26":1,"140":1,"289":1,"371":1,"559":1,"561":1,"574":1,"580":1,"620":1,"763":1}}],["reasonable",{"2":{"217":1}}],["reasonably",{"2":{"7":1}}],["reason",{"2":{"24":1,"720":1}}],["reasons",{"2":{"8":1,"199":1}}],["resubmission",{"0":{"607":1,"608":1},"1":{"608":1,"609":1},"2":{"607":1}}],["resubmitted",{"2":{"608":1}}],["resubmit",{"2":{"592":2,"609":1}}],["results",{"2":{"139":1,"140":1,"281":1,"381":4,"752":2}}],["resulting",{"2":{"139":1,"328":1,"643":1,"647":1}}],["result",{"2":{"23":2,"142":2,"147":4,"152":2,"155":1,"156":1,"209":1,"331":2,"332":3,"333":2,"396":1,"408":4,"409":2,"475":2,"476":2,"519":1,"538":3,"558":5,"559":2,"562":2,"563":2,"602":2,"641":1,"644":2,"647":3,"743":6,"745":8,"746":2,"748":2,"749":2,"750":2,"751":2,"752":2,"753":2,"755":2,"758":2,"760":3}}],["resolve",{"2":{"647":1}}],["resolved",{"2":{"428":1}}],["resolving",{"2":{"456":1}}],["resolution",{"2":{"336":1,"578":1}}],["resources",{"0":{"280":1,"374":1,"623":1,"759":1},"1":{"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"760":1,"761":1,"762":1},"2":{"39":1,"40":2,"43":1,"44":2,"50":1,"51":1,"95":1,"134":1,"623":2,"714":1}}],["resource",{"2":{"37":1,"50":1,"58":1,"226":1,"367":1,"642":2,"648":1}}],["resetting",{"0":{"334":1}}],["reset",{"0":{"375":1,"444":1},"2":{"324":1,"335":4,"375":2,"383":1,"444":2,"625":3}}],["reserved",{"2":{"174":1,"483":1,"649":2}}],["research",{"2":{"36":1,"38":1,"679":1}}],["restartsec=3",{"2":{"602":2,"604":2,"605":2,"606":2}}],["restart=on",{"2":{"602":2,"604":2,"605":2,"606":2}}],["restart",{"0":{"379":1},"2":{"274":1,"316":1,"337":3,"345":1,"379":1,"380":1,"381":1,"383":1,"406":1,"625":2}}],["restaurant",{"2":{"34":1}}],["restaurants",{"2":{"34":2}}],["restrictions",{"2":{"680":1}}],["restrict",{"2":{"205":1,"582":1}}],["rest",{"2":{"127":1,"214":1,"326":1,"428":1,"429":2,"488":2,"507":3,"726":1,"765":1,"782":10,"783":1,"784":1}}],["resides",{"2":{"110":1}}],["resilience",{"2":{"26":1}}],["resp",{"2":{"597":20,"709":6,"772":4}}],["respectively",{"2":{"218":1}}],["respective",{"2":{"27":1,"67":1,"68":1,"126":1,"130":1,"137":1,"272":1,"371":2,"492":1,"493":1,"499":1,"504":1,"505":1}}],["respect",{"2":{"10":1}}],["respectfully",{"2":{"46":1}}],["respectful",{"2":{"7":1}}],["responses",{"0":{"381":1},"2":{"42":1,"381":9,"763":1,"774":1}}],["response",{"2":{"8":1,"42":1,"142":1,"147":1,"152":1,"154":1,"156":4,"157":1,"159":4,"160":1,"331":2,"408":1,"558":1,"562":1,"563":2,"597":4,"641":1,"704":1,"705":1,"745":3,"748":1,"749":1,"750":1,"751":1,"772":2,"773":2}}],["responsible",{"2":{"8":1,"10":1,"86":1,"87":1,"90":1,"126":2,"455":1,"648":1,"672":2}}],["responsibilities",{"0":{"8":1}}],["responsibility",{"2":{"7":1,"8":1,"122":2,"609":1,"637":1}}],["requiring",{"2":{"648":1}}],["requires",{"2":{"119":1,"166":1,"171":1,"193":1,"202":1,"208":1,"217":1,"218":1,"219":1,"227":1,"229":1,"539":1,"637":1}}],["require",{"2":{"105":1,"118":4,"164":1,"169":1,"171":1,"227":1,"328":1,"367":1,"524":2,"581":1,"637":1,"638":1,"643":2,"647":2,"738":1}}],["requirement",{"2":{"35":1,"278":1,"643":1}}],["requirements",{"0":{"239":1,"357":1,"368":1,"416":1,"440":1,"460":1,"532":1,"611":1,"732":1},"2":{"23":1,"30":1,"37":1,"54":1,"55":1,"86":1,"197":1,"239":1,"357":1,"368":1,"416":1,"440":1,"460":1,"611":1,"720":2,"732":1}}],["required",{"2":{"29":1,"30":1,"86":1,"149":1,"188":1,"202":1,"211":1,"244":1,"250":1,"309":1,"313":1,"324":1,"325":2,"326":1,"371":1,"388":1,"390":1,"422":1,"453":1,"465":1,"580":1,"590":1,"615":1,"617":1,"643":1,"704":1,"735":1,"741":1,"768":1,"769":1}}],["requisites",{"0":{"347":1,"403":1}}],["requestheaderrange",{"2":{"219":1,"233":1}}],["requesting",{"0":{"216":1},"1":{"217":1,"218":1,"219":1},"2":{"218":1,"219":1,"656":1}}],["requests",{"2":{"202":2,"218":1,"219":1,"238":1,"376":1,"639":2,"644":1,"650":1,"672":1,"739":1}}],["requestedheight",{"2":{"558":2}}],["requested",{"2":{"12":1,"216":1,"218":1,"219":1,"233":1,"561":1}}],["request",{"0":{"147":1,"152":1,"218":1,"219":1},"2":{"2":2,"38":1,"70":1,"109":1,"142":1,"147":1,"152":1,"155":1,"156":1,"216":1,"218":1,"219":1,"245":1,"281":1,"328":1,"331":2,"332":2,"370":1,"422":1,"467":1,"510":1,"534":1,"561":1,"649":1,"736":1,"738":1,"740":1,"765":1,"782":2}}],["remainder",{"2":{"281":1,"287":1,"294":1,"405":1,"561":1}}],["remain",{"2":{"273":1,"365":1,"445":1,"581":1,"586":1,"670":1}}],["remaining",{"2":{"156":2,"157":1,"297":1,"413":1,"483":1,"578":1,"680":4}}],["remains",{"2":{"18":1,"199":1,"221":1,"479":1,"547":1}}],["removing",{"2":{"281":1}}],["removed",{"2":{"93":2,"152":1,"153":1,"281":2,"326":1,"557":1,"726":1,"731":1,"769":1}}],["removechainowner",{"2":{"93":2}}],["remove",{"2":{"8":1,"311":1,"335":1,"341":1,"383":2,"537":2,"625":2}}],["remote",{"2":{"40":1,"238":1,"252":1,"260":2,"275":2,"350":3,"355":1,"584":1,"737":1}}],["remember",{"2":{"34":1,"38":1,"254":1,"371":1,"380":1,"381":1,"479":1,"537":1,"582":1}}],["reminders",{"2":{"39":1}}],["reminder",{"2":{"30":1,"39":1,"79":1}}],["replicated",{"2":{"647":1}}],["replaced",{"2":{"161":2}}],["replace",{"2":{"144":2,"183":1,"287":1,"450":1,"465":1,"592":1,"740":1}}],["replaces",{"2":{"140":1,"214":1,"377":1,"646":1}}],["replacing",{"2":{"93":2,"309":1,"704":1,"705":1}}],["replaying",{"2":{"211":1,"212":1,"672":1}}],["replayer",{"0":{"212":1},"2":{"208":2}}],["replay",{"2":{"96":1,"110":1}}],["repeat",{"2":{"448":1}}],["repo",{"2":{"117":2,"202":1,"203":1,"227":1,"238":2,"272":1,"361":1,"450":1,"452":1}}],["report",{"2":{"27":1,"336":2}}],["reporting",{"2":{"23":1}}],["reporter",{"2":{"10":1}}],["reported",{"2":{"10":1}}],["repository",{"0":{"89":1,"456":1},"2":{"0":1,"1":1,"2":2,"4":1,"89":3,"92":1,"93":1,"117":1,"208":1,"211":2,"212":1,"228":1,"233":1,"250":1,"311":1,"341":1,"361":2,"456":1,"584":1,"621":1,"696":1,"697":1}}],["represent",{"2":{"137":1}}],["representation",{"2":{"126":1,"156":2,"157":2}}],["representative",{"2":{"9":1}}],["represents",{"2":{"109":2,"322":1,"738":1}}],["representing",{"2":{"9":2}}],["relies",{"2":{"371":1,"427":1}}],["religion",{"2":{"6":1}}],["reloadsudo",{"2":{"337":1}}],["reload",{"2":{"337":2}}],["released",{"2":{"428":1,"526":1}}],["release",{"2":{"211":1,"215":4,"427":1,"528":1,"556":1,"671":1}}],["releasesource",{"2":{"211":1}}],["releases",{"2":{"152":1,"153":1,"312":1,"342":1}}],["relevant",{"2":{"37":2,"39":2,"42":1,"63":2,"322":1,"383":1,"459":1,"476":1,"484":2,"499":2,"597":2,"625":2,"640":1,"650":1}}],["relevantly",{"2":{"2":1}}],["relaying",{"0":{"427":1},"1":{"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"400":1,"428":1,"430":3}}],["relayers",{"2":{"427":1}}],["relayer",{"0":{"430":1,"436":1},"2":{"206":1,"228":1,"235":1,"427":3,"428":2,"436":1}}],["relayed",{"2":{"109":2,"119":1,"120":1,"124":1,"127":1,"128":1,"219":1}}],["relay",{"2":{"109":1,"211":1,"235":1,"427":1,"429":1}}],["relays",{"2":{"97":1,"111":1,"221":1}}],["relatively",{"2":{"607":1,"720":1}}],["relative",{"0":{"720":1},"2":{"193":1,"720":1}}],["relations",{"2":{"39":1}}],["relationships",{"2":{"32":1,"36":1}}],["related",{"2":{"38":1,"42":1,"244":1,"422":2,"465":1,"636":1,"735":1}}],["relying",{"2":{"224":1,"672":1}}],["rely",{"2":{"65":2,"215":1,"225":1,"485":2,"487":2,"503":2,"672":1,"716":1}}],["re",{"2":{"2":1,"34":1,"35":1,"46":1,"81":2,"86":2,"91":1,"117":1,"139":1,"163":2,"173":1,"178":1,"183":1,"202":3,"210":6,"215":2,"227":1,"277":1,"324":1,"334":1,"336":1,"339":1,"341":1,"344":1,"383":1,"391":2,"432":1,"556":2,"559":1,"561":1,"566":1,"567":1,"568":1,"572":1,"574":1,"581":1,"584":1,"597":4,"607":1,"625":2,"705":1,"763":1,"774":1,"783":1,"784":1}}],["svg",{"0":{"761":1},"2":{"761":2,"784":1}}],["ss",{"2":{"590":1}}],["sst",{"2":{"569":1}}],["ssd",{"2":{"357":1,"460":1,"533":1,"534":2,"611":1,"732":1}}],["sgvsbg8gd28ybgqh",{"2":{"538":2}}],["snaps",{"2":{"372":12}}],["snapshot",{"2":{"369":2,"372":1,"636":1}}],["snapshots",{"2":{"368":1,"371":3,"672":4}}],["snap",{"2":{"372":24}}],["snippets",{"2":{"136":1,"140":1,"769":1}}],["s3",{"2":{"214":16}}],["skipauth",{"2":{"328":1}}],["skip",{"2":{"201":1,"215":2,"432":1,"615":1,"707":1,"731":2,"765":2,"770":2,"771":2,"773":2,"776":1}}],["skillsets",{"2":{"46":1}}],["src",{"2":{"160":2,"203":2,"383":4,"625":4,"782":8}}],["srl59gitsiwc9lqdyaszfc6tvusyy7njx8",{"2":{"152":2}}],["squaresizeupperbound",{"2":{"150":2}}],["square",{"0":{"138":1,"711":1,"779":1},"2":{"109":1,"110":2,"122":3,"127":1,"137":2,"144":2,"150":6,"163":2,"168":1,"172":2,"173":1,"174":9,"175":1,"483":4,"563":1,"649":3,"711":1,"779":1}}],["sql",{"2":{"64":1,"485":1,"503":1}}],["switching",{"2":{"324":1}}],["switch",{"2":{"85":1,"163":2,"275":1,"455":1,"782":2,"784":1}}],["swag",{"0":{"57":1},"2":{"37":1}}],["symbol",{"2":{"784":2}}],["syndtr",{"2":{"140":4}}],["sync|async|block",{"2":{"303":2}}],["syncing",{"0":{"338":1,"719":1},"1":{"339":1},"2":{"248":1,"338":1,"370":1,"558":2,"604":1,"605":2,"606":1,"619":1,"625":1,"633":1,"670":1,"719":1,"731":1}}],["synced",{"2":{"82":1,"542":1,"559":1}}],["sync",{"0":{"67":1,"369":1,"370":1,"371":1,"372":1,"492":1,"504":1},"1":{"370":1,"371":1,"372":1},"2":{"67":1,"302":1,"303":2,"338":1,"356":1,"369":4,"370":2,"371":7,"372":2,"492":1,"504":1,"531":1,"542":1,"558":4,"602":4,"606":1,"625":1,"634":1,"672":3,"719":3,"731":1}}],["systemctl",{"2":{"337":4,"602":6,"604":4,"605":4,"606":6}}],["systems",{"2":{"275":2,"312":1,"342":1,"716":1}}],["systemd",{"0":{"248":1,"271":1,"425":1,"470":1,"600":1,"602":1,"619":1},"1":{"601":1,"602":1,"603":1,"604":1,"605":1,"606":1},"2":{"248":1,"271":7,"337":2,"373":1,"425":1,"470":1,"600":1,"602":6,"604":5,"605":5,"606":4,"619":1}}],["system",{"2":{"22":1,"30":1,"224":1,"273":2,"276":1,"277":1,"322":2,"337":5,"341":1,"343":4,"388":1,"431":1,"556":1,"569":1,"589":1,"590":2,"602":4,"604":4,"605":4,"606":4,"647":2,"724":1}}],["sdk",{"2":{"63":1,"96":4,"140":7,"238":1,"260":2,"266":2,"278":1,"281":1,"428":1,"484":1,"507":1,"508":1,"582":1,"584":1,"585":1,"589":1,"597":2,"646":1,"651":1,"674":3,"678":1,"689":1,"696":1,"715":4,"716":2,"717":1,"719":1,"720":1}}],["sashabaranov",{"2":{"768":2,"769":2}}],["saying",{"2":{"558":1}}],["sanity",{"2":{"770":1}}],["sandbox",{"2":{"495":1}}],["sanctions",{"2":{"23":1}}],["sausage",{"2":{"291":2}}],["salt=",{"2":{"202":2}}],["salt",{"2":{"202":5,"204":4,"210":2}}],["sales",{"2":{"38":1,"69":1,"510":1}}],["save",{"0":{"287":1,"368":1},"2":{"202":1,"210":1,"266":1,"275":1,"308":1,"334":1,"368":1,"380":1,"381":1,"446":1,"494":1,"557":3,"765":2,"769":1}}],["saved",{"2":{"137":1,"139":1,"169":1,"184":1,"187":1}}],["saving",{"2":{"37":1,"171":1,"266":1}}],["same",{"0":{"592":1},"2":{"112":1,"125":1,"139":1,"170":1,"175":1,"184":1,"187":1,"191":2,"202":2,"204":1,"224":1,"235":1,"275":4,"281":1,"328":1,"339":3,"361":1,"445":1,"447":1,"476":1,"519":1,"525":1,"559":2,"597":2,"620":1,"647":2,"717":1,"724":1}}],["sampling",{"0":{"471":1,"630":1,"631":1,"641":1},"1":{"642":1,"643":1},"2":{"53":1,"221":1,"238":1,"458":1,"479":1,"531":1,"555":1,"559":1,"581":1,"606":1,"629":1,"630":5,"631":1,"632":1,"640":1,"641":3,"643":1,"648":2,"671":3,"720":1,"754":2}}],["sampler",{"0":{"754":1}}],["samples",{"2":{"642":1}}],["sampled",{"2":{"559":2,"631":1,"650":1}}],["samplefrom",{"2":{"338":2,"558":2}}],["sample",{"0":{"53":1,"54":1,"55":1,"56":1},"2":{"53":2,"54":2,"55":2,"56":2,"163":1,"338":1,"555":1,"558":1,"648":1,"671":1}}],["said",{"2":{"96":1}}],["safely",{"2":{"111":1,"329":1,"648":1}}],["safe",{"2":{"46":1,"280":1,"291":2,"557":3,"765":2}}],["smartstake",{"2":{"497":1}}],["smart",{"0":{"576":1},"2":{"81":1,"87":2,"90":1,"122":7,"124":1,"136":1,"139":1,"141":1,"142":1,"147":1,"152":1,"154":5,"160":2,"164":1,"169":1,"174":1,"175":2,"216":1,"227":2,"228":1,"229":1,"231":1,"233":1,"234":1,"254":1,"576":1,"578":1,"580":1,"582":1,"584":1,"636":1,"688":1}}],["smartphone",{"2":{"34":1}}],["smaller",{"2":{"586":1}}],["small",{"2":{"40":1,"109":1,"125":1,"197":1,"581":1,"630":1,"642":1,"648":1}}],["smooth",{"2":{"37":1}}],["shgo",{"2":{"773":2}}],["shgit",{"2":{"117":1,"697":1}}],["shmkdir",{"2":{"768":1}}],["shnode",{"2":{"605":1}}],["sha3uncles",{"2":{"536":2}}],["sharing",{"2":{"40":1,"58":1,"672":1}}],["shareclient",{"2":{"777":2}}],["shareversionzero",{"2":{"597":2}}],["shareindexinrowmajororder",{"2":{"175":2}}],["shareindexinrow",{"2":{"175":4}}],["shareproof",{"2":{"163":2,"175":6}}],["shareproofs",{"0":{"156":1},"2":{"154":2,"156":3,"163":4,"175":2}}],["sharesize",{"2":{"590":1}}],["sharesproof",{"2":{"154":3,"156":1,"157":1,"158":1,"159":1,"163":18}}],["shares",{"2":{"118":2,"122":5,"125":3,"127":1,"137":4,"139":3,"145":1,"151":3,"152":4,"154":14,"155":1,"156":2,"157":1,"158":1,"159":1,"163":4,"169":1,"172":1,"175":4,"180":1,"199":4,"224":1,"238":1,"415":2,"483":4,"586":2,"589":2,"590":2,"591":1,"641":5,"643":4,"644":3,"648":1,"649":4,"650":3,"745":2}}],["shared",{"2":{"58":1,"449":1}}],["share",{"0":{"151":1,"167":1,"168":1,"169":1,"170":1,"171":1,"183":1,"184":1,"185":1,"190":1,"192":1,"193":1},"1":{"152":1,"153":1,"168":1,"169":1,"170":1,"171":1,"184":1,"185":1,"191":1,"192":1,"193":1},"2":{"26":1,"30":1,"32":1,"34":1,"37":1,"39":4,"40":3,"42":1,"125":6,"137":2,"139":5,"147":5,"149":1,"151":6,"152":2,"163":2,"166":1,"167":1,"168":11,"169":2,"170":1,"172":2,"173":1,"174":2,"175":9,"176":1,"180":2,"183":7,"184":1,"186":1,"188":1,"190":1,"191":5,"194":7,"199":3,"272":1,"332":2,"334":4,"448":1,"450":1,"452":3,"483":3,"562":1,"563":7,"586":2,"589":1,"590":2,"596":6,"641":1,"649":1,"650":1,"672":2,"681":1,"708":7,"709":2,"710":4,"711":3,"743":1,"745":8,"753":2,"758":3,"760":2,"769":2,"771":7,"779":3}}],["shpeer=",{"2":{"452":1}}],["ship",{"2":{"452":1}}],["shirts",{"2":{"37":1}}],["shtia",{"2":{"447":1}}],["shutdown",{"2":{"426":1}}],["shcurl",{"2":{"602":1}}],["shcat",{"2":{"602":1,"604":1,"605":1,"606":1}}],["shcd",{"2":{"286":1,"474":1,"543":1}}],["shceles",{"2":{"272":1}}],["shcelestia",{"2":{"244":4,"245":3,"246":3,"261":1,"263":3,"264":2,"265":5,"266":5,"267":2,"268":1,"269":2,"270":1,"308":3,"309":1,"311":1,"316":1,"317":1,"318":1,"319":1,"324":1,"338":2,"373":4,"375":1,"421":3,"422":1,"423":3,"444":1,"450":1,"453":1,"464":3,"465":3,"466":3,"468":3,"516":1,"518":1,"519":1,"620":4,"765":3}}],["shsed",{"2":{"377":1}}],["shstaking",{"2":{"272":1,"449":1}}],["shsudo",{"2":{"271":1,"602":4,"604":2,"605":2,"606":4}}],["shexport",{"2":{"766":1}}],["shexternal",{"2":{"378":1}}],["sherror",{"2":{"334":1}}],["shevm",{"2":{"272":1}}],["shellsource",{"2":{"211":1}}],["shellforge",{"2":{"210":1}}],["shelltendermint",{"2":{"209":1}}],["shellcast",{"2":{"204":3,"206":1,"207":1}}],["shellcd",{"2":{"202":1,"203":1,"208":1,"210":1,"211":1,"214":1}}],["shell",{"2":{"202":2,"399":1}}],["shellgit",{"2":{"202":1,"584":1}}],["shkey",{"2":{"272":1,"446":1}}],["shvalidator",{"2":{"272":1,"445":1}}],["sh",{"2":{"202":2,"245":1,"262":1,"279":4,"286":1,"287":2,"312":2,"336":1,"343":4,"371":4,"398":2,"422":1,"466":2,"474":1,"521":1,"522":1,"556":2,"697":2,"701":1,"704":2,"705":2,"762":1}}],["shforge",{"2":{"117":1}}],["shove",{"2":{"291":2}}],["shoutout",{"2":{"38":1}}],["shouldn",{"2":{"637":1}}],["should",{"0":{"199":1},"2":{"26":1,"34":1,"38":1,"50":1,"65":1,"86":1,"87":1,"136":1,"155":1,"186":1,"187":1,"199":1,"202":3,"204":1,"208":1,"210":1,"211":1,"214":5,"215":2,"216":2,"221":1,"275":1,"312":1,"329":1,"337":1,"365":1,"367":1,"371":3,"431":1,"434":2,"439":1,"445":1,"449":1,"450":2,"485":1,"487":1,"503":1,"528":1,"539":2,"544":1,"556":1,"588":1,"589":1,"604":1,"605":1,"608":1,"614":2,"620":2,"672":1,"688":1,"698":1,"720":2,"743":1,"765":1}}],["showing",{"2":{"409":1}}],["shown",{"2":{"234":1,"332":1,"620":1}}],["shows",{"2":{"139":1,"182":1,"597":2,"644":1,"646":1,"758":1}}],["showcase",{"2":{"38":1}}],["show",{"2":{"37":1,"38":1,"63":1,"174":1,"272":2,"297":2,"329":1,"331":1,"341":1,"399":1,"413":1,"452":2,"464":2,"484":1,"499":1,"540":1,"614":2,"620":3,"760":1,"782":1}}],["shortly",{"2":{"77":1}}],["short",{"2":{"37":1,"392":1}}],["scattered",{"2":{"763":1}}],["scavenger",{"0":{"763":1,"767":1},"1":{"764":1,"765":1,"766":1,"767":1,"768":2,"769":2,"770":2,"771":2,"772":2,"773":2,"774":1},"2":{"727":1,"763":1,"768":6,"773":1}}],["scan",{"2":{"427":1}}],["scaling",{"0":{"581":1},"2":{"581":2,"627":1,"628":1,"640":1}}],["scalable",{"2":{"226":1,"455":1,"637":1,"640":1,"648":1}}],["scalability",{"0":{"226":1,"642":1},"2":{"111":1,"226":2}}],["scale",{"2":{"581":2,"642":1}}],["scaleway",{"2":{"214":1,"215":1}}],["scales",{"2":{"165":1,"221":1,"648":2}}],["scroll",{"2":{"784":1}}],["scrolling",{"2":{"783":1}}],["scratches",{"2":{"582":1}}],["scratch",{"2":{"580":1}}],["scraped",{"2":{"275":2}}],["scrape",{"2":{"275":16}}],["scripts",{"2":{"279":2,"286":2,"287":2,"371":6,"474":3}}],["script",{"0":{"89":1},"2":{"76":1,"89":5,"92":1,"93":7,"94":1,"202":2,"210":4,"218":2,"279":2,"286":1,"312":1,"342":1,"343":3,"474":1,"556":1,"566":1,"765":1,"773":1}}],["screen",{"2":{"23":1,"34":1,"599":2,"656":1,"660":1}}],["scheme",{"0":{"139":1},"2":{"168":1,"641":1,"643":1,"646":1,"649":1}}],["schemes",{"2":{"52":1,"715":1}}],["schedules",{"2":{"680":1}}],["scheduler",{"2":{"528":1}}],["schedule",{"2":{"30":1,"31":1,"35":1,"37":1,"42":1,"680":2,"685":1}}],["schools",{"2":{"38":1}}],["scene",{"2":{"36":1}}],["scope",{"0":{"9":1},"2":{"56":1,"526":1}}],["slice",{"2":{"559":2,"708":3,"771":2}}],["slightly",{"2":{"483":1}}],["slides",{"2":{"37":1}}],["slower",{"2":{"552":1}}],["slowest",{"2":{"370":1}}],["slowly",{"2":{"544":3}}],["slots",{"2":{"20":1,"22":1}}],["sl",{"2":{"312":2,"343":4,"361":8,"556":2}}],["slack",{"2":{"277":1}}],["slashboard",{"2":{"497":1}}],["slashing",{"0":{"281":1},"2":{"270":2,"281":3,"715":1}}],["slashed",{"2":{"23":1,"24":1,"26":1,"208":1,"281":4}}],["slas",{"2":{"65":1,"485":1,"487":1,"503":1}}],["soundness",{"2":{"650":1}}],["sourcing",{"2":{"580":1}}],["sources",{"2":{"275":1}}],["source",{"0":{"311":1,"341":1},"2":{"91":1,"139":1,"210":2,"267":2,"275":4,"310":1,"321":1,"399":4,"428":1,"429":4,"508":1,"543":2,"566":1}}],["sophistication",{"2":{"477":2,"562":2,"563":2}}],["software",{"0":{"62":1,"481":1,"501":1,"548":1,"551":1,"553":1},"2":{"54":1,"55":1,"60":1,"112":1,"221":1,"310":1,"397":1,"499":1,"524":2}}],["sovereign",{"0":{"55":1},"2":{"53":1,"55":5,"60":1,"422":2,"499":1,"550":1,"552":1}}],["soda",{"2":{"35":1}}],["somewhere",{"2":{"446":1,"557":3,"765":2}}],["sometimes",{"2":{"238":1,"415":1}}],["something",{"2":{"104":1,"110":1,"215":2,"275":1,"314":1,"752":2,"765":1}}],["some",{"0":{"175":1,"631":1,"639":1},"2":{"34":1,"40":1,"84":1,"92":1,"125":3,"126":1,"128":1,"154":4,"160":2,"166":1,"266":1,"267":1,"275":1,"279":4,"302":1,"304":1,"321":1,"349":1,"405":1,"434":8,"540":1,"564":1,"577":1,"581":1,"582":1,"597":2,"638":1,"639":1,"649":1,"670":1,"672":1,"680":1,"715":1,"718":1,"743":1,"763":1,"765":1,"770":2,"773":1,"777":2,"778":4,"779":2}}],["someone",{"2":{"31":1,"39":1}}],["solomon",{"2":{"641":2,"643":5,"646":1,"649":1}}],["solution",{"2":{"130":1,"165":1,"197":1,"221":1,"226":1,"640":1,"643":1,"647":1,"648":1}}],["solutions",{"2":{"111":1,"570":1,"592":1,"628":1,"640":1}}],["solidityuint256",{"2":{"175":1}}],["soliditypragma",{"2":{"163":1}}],["solidity",{"2":{"117":1,"118":4,"142":1,"147":1,"152":1,"154":1,"156":6,"157":1,"159":4,"160":2,"163":2,"164":1,"168":1,"213":1,"231":1}}],["soliciting",{"2":{"32":1}}],["sol",{"2":{"111":1,"118":7,"120":1,"122":1,"155":1,"156":1,"157":1,"159":1,"160":1,"163":4,"203":3,"210":2,"214":4,"215":4,"228":1,"233":1,"234":1}}],["solely",{"2":{"672":1}}],["sole",{"2":{"24":1}}],["so",{"2":{"22":1,"23":2,"28":1,"35":2,"39":1,"60":1,"79":1,"91":1,"117":1,"125":2,"139":2,"149":1,"150":1,"156":3,"173":1,"174":1,"187":1,"199":1,"210":1,"215":1,"244":1,"246":1,"294":1,"299":1,"334":1,"368":1,"371":1,"373":1,"375":1,"396":1,"399":1,"423":1,"439":1,"444":1,"452":2,"468":1,"493":1,"494":1,"574":1,"620":1,"629":1,"631":1,"632":2,"644":1,"650":1,"670":1,"698":1,"735":1,"739":1,"763":1,"783":1}}],["sorted",{"2":{"569":1,"609":1}}],["sort",{"2":{"14":1,"15":1}}],["social",{"2":{"9":1,"13":1,"30":1,"32":1,"39":4,"40":1,"266":1}}],["socio",{"2":{"6":1}}],["spin",{"0":{"443":1},"1":{"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1},"2":{"443":1,"540":1}}],["spinning",{"2":{"320":1}}],["splits",{"2":{"649":1}}],["split",{"2":{"137":1,"641":1,"643":1,"649":1,"668":1,"679":1}}],["sp1blobstreamwrapper",{"2":{"144":2,"161":2,"162":2,"163":2}}],["sp1blobstream",{"2":{"136":2,"228":1}}],["sp1",{"0":{"227":1,"228":1,"583":1},"1":{"229":1,"230":1,"231":1,"584":1},"2":{"136":2,"144":4,"161":4,"162":4,"163":4,"221":3,"222":1,"227":10,"228":6,"231":8,"583":3,"584":14}}],["sparsesharesneeded",{"2":{"590":1}}],["sparse",{"2":{"483":2}}],["spans",{"0":{"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"179":1,"180":1,"181":1,"182":1,"187":1,"188":1,"189":1},"1":{"173":1,"174":1,"175":1,"176":1,"177":1,"180":1,"181":1,"182":1,"188":1,"189":1},"2":{"147":1,"151":1,"166":1,"172":3,"173":1,"174":3,"175":7,"176":1,"179":4,"182":1,"183":2,"186":1,"187":5,"197":3,"199":2}}],["span",{"0":{"539":1},"2":{"125":12,"126":4,"127":2,"128":8,"130":3,"154":4,"156":1,"174":1,"539":2}}],["space",{"2":{"46":1,"276":1,"380":1,"381":2,"494":1}}],["spaces",{"2":{"9":2,"13":1,"34":5,"38":1}}],["spdx",{"2":{"118":2}}],["sponsoring",{"2":{"38":1}}],["sponsorship",{"2":{"38":5}}],["sponsors",{"0":{"38":1},"2":{"38":9,"39":1,"46":1}}],["spread",{"2":{"36":1,"39":1}}],["speed",{"2":{"369":1,"608":1}}],["spend",{"2":{"266":1,"267":7,"407":2,"412":2,"590":1,"678":1}}],["specialization",{"2":{"647":1}}],["specialized",{"2":{"647":3}}],["specialize",{"2":{"578":1}}],["specif",{"2":{"154":2,"160":2}}],["specifying",{"2":{"275":1,"518":1,"519":1,"588":1}}],["specify",{"2":{"86":1,"202":4,"244":2,"328":1,"343":1,"392":2,"523":1,"557":1,"559":1,"592":1,"698":1,"735":2,"746":1}}],["specifies",{"2":{"86":1,"407":1,"698":1}}],["specified",{"2":{"13":1,"14":1,"87":1,"202":1,"203":1,"211":2,"213":1,"215":2,"218":1,"260":2,"321":1,"407":1,"588":2,"590":1,"671":1,"693":1,"698":1,"738":1,"746":1,"760":1}}],["specifications",{"2":{"125":1,"281":1,"482":1}}],["specifically",{"2":{"58":1,"90":1,"371":1,"627":1,"636":1}}],["specific",{"0":{"151":1},"1":{"152":1,"153":1},"2":{"35":1,"37":1,"42":1,"73":1,"86":1,"109":1,"120":2,"125":2,"126":4,"128":1,"207":1,"214":2,"215":3,"217":2,"224":1,"226":1,"233":1,"276":1,"313":1,"322":1,"326":1,"328":1,"343":2,"448":1,"498":1,"513":1,"554":1,"738":2,"757":1,"782":1}}],["spec",{"2":{"495":1}}],["specs",{"2":{"137":2,"139":1,"156":2,"157":2,"160":4,"266":2,"591":1,"745":1}}],["speak",{"2":{"37":1}}],["speaking",{"2":{"36":1,"42":1}}],["speaker",{"0":{"58":1},"2":{"30":1,"34":1,"36":1,"37":3,"50":1,"58":5}}],["speakers",{"0":{"37":1},"2":{"30":3,"31":1,"32":1,"34":1,"36":5,"37":13,"38":2,"39":3,"42":2,"46":1,"56":1,"58":2}}],["sequential",{"2":{"429":4,"582":1}}],["sequence",{"0":{"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"179":1,"180":1,"181":1,"182":1,"187":1,"188":1,"189":1},"1":{"173":1,"174":1,"175":1,"176":1,"177":1,"180":1,"181":1,"182":1,"188":1,"189":1},"2":{"166":1,"172":3,"173":1,"174":3,"175":7,"176":1,"179":4,"182":1,"183":2,"186":1,"187":5,"197":3,"199":2,"295":2,"296":2,"400":1,"430":1,"589":1,"592":1,"597":2,"647":2}}],["sequencers",{"2":{"162":1,"183":1,"580":1}}],["sequencersignature",{"2":{"125":2,"128":2,"130":2}}],["sequenceraddress",{"2":{"125":2,"130":2}}],["sequencer",{"0":{"126":1},"1":{"127":1,"128":1},"2":{"110":1,"112":2,"125":3,"126":7,"127":2,"128":8,"130":8,"400":1,"544":4}}],["sequencerinbox",{"2":{"91":2,"100":2,"101":2,"111":1}}],["sed",{"2":{"361":12,"378":2}}],["semantic",{"2":{"341":1}}],["semi",{"2":{"224":1}}],["severity",{"2":{"628":1}}],["severe",{"2":{"281":1}}],["several",{"2":{"109":1,"216":1,"483":1,"512":1,"531":1,"680":1}}],["self",{"2":{"217":1,"260":2,"272":2,"620":4}}],["selecting",{"2":{"34":1,"90":1,"107":1,"284":1}}],["selection",{"0":{"324":1},"1":{"325":1},"2":{"26":1,"58":1}}],["select",{"0":{"652":1,"655":1,"660":1},"2":{"30":1,"76":2,"85":1,"162":2,"294":1,"311":1,"324":1,"368":1,"380":1,"499":3,"556":1,"599":1,"622":1,"654":1,"655":1,"656":2,"659":2,"660":1,"663":1,"664":1,"698":1}}],["selected",{"2":{"23":1,"27":1,"672":1}}],["separation",{"2":{"647":1}}],["separating",{"2":{"581":1}}],["separately",{"2":{"183":1,"566":1}}],["separate",{"2":{"156":1,"238":2,"320":1,"405":1,"566":1,"641":1,"650":1,"724":1}}],["separated",{"2":{"137":1,"211":1,"361":2,"451":2}}],["september",{"2":{"525":1}}],["sepoliaeth",{"2":{"544":1}}],["sepoliafaucet",{"2":{"84":1}}],["sepolia",{"0":{"84":1,"98":1,"99":1,"100":1,"101":1},"2":{"77":2,"79":2,"81":1,"82":1,"84":3,"85":1,"87":1,"90":4,"93":2,"97":2,"98":1,"99":1,"231":3,"251":1,"253":1,"254":1,"255":1,"256":1,"257":1,"540":2,"544":5}}],["session",{"2":{"53":1,"54":1,"55":1}}],["sessions",{"2":{"38":1,"58":1}}],["search",{"0":{"655":1,"664":1},"2":{"599":2}}],["sealfields",{"2":{"536":2}}],["seamless",{"2":{"479":1}}],["seamlessly",{"2":{"400":1}}],["seasoned",{"2":{"50":1}}],["seating",{"2":{"31":1,"34":1}}],["seats",{"2":{"27":4}}],["sentry",{"2":{"361":1,"429":6}}],["sent",{"2":{"93":2,"139":1,"309":1,"578":1,"589":1}}],["sensitive",{"2":{"88":1,"722":1}}],["sense",{"2":{"36":1,"40":1}}],["sender",{"2":{"434":16,"649":1,"668":1}}],["sendrequest",{"2":{"331":2,"333":2}}],["sending",{"2":{"211":1,"252":1,"309":1,"400":1,"649":1,"755":1}}],["sends",{"2":{"112":1}}],["send",{"2":{"30":2,"32":1,"39":3,"41":1,"202":1,"204":2,"265":6,"267":1,"279":8,"281":1,"301":1,"412":1,"415":1,"438":1,"477":3}}],["serving",{"2":{"633":1,"639":1,"672":1}}],["servicecat",{"2":{"602":1,"604":1,"605":1,"606":1}}],["servicenano",{"2":{"337":1}}],["service",{"0":{"339":1,"575":1,"713":1,"715":1},"1":{"714":1,"715":1,"716":2,"717":2,"718":2,"719":2,"720":2},"2":{"65":1,"271":7,"337":9,"377":3,"479":1,"485":1,"487":1,"503":1,"540":1,"600":1,"602":8,"604":7,"605":7,"606":7,"713":1,"724":1}}],["services",{"0":{"354":1},"1":{"355":1},"2":{"23":1,"34":1,"339":2,"497":2,"705":2}}],["served",{"2":{"274":2}}],["serves",{"2":{"238":1,"254":1,"438":1,"478":1,"650":1}}],["servergrafana",{"2":{"275":1}}],["server",{"0":{"247":1,"424":1,"469":1},"2":{"47":1,"70":1,"247":1,"275":6,"313":2,"321":1,"326":2,"424":1,"430":1,"469":1,"510":1,"597":2}}],["servers",{"2":{"26":1,"371":2}}],["serve",{"2":{"44":1,"376":1,"637":1,"639":1}}],["serialized",{"2":{"109":1}}],["serious",{"2":{"14":1}}],["series",{"2":{"13":1,"275":2,"679":1,"680":1}}],["secp256k1",{"2":{"291":2,"292":4,"296":2,"705":2,"715":1}}],["sections",{"2":{"63":1,"197":1,"229":1,"349":1,"484":1,"499":1}}],["section",{"2":{"36":1,"68":1,"83":1,"86":2,"90":1,"109":1,"122":1,"127":1,"142":1,"147":1,"152":1,"156":1,"160":1,"163":4,"166":1,"171":1,"174":1,"183":2,"186":1,"187":1,"191":1,"194":2,"199":1,"203":1,"204":2,"208":2,"210":4,"211":2,"213":2,"215":5,"244":1,"245":1,"287":1,"298":1,"309":1,"311":1,"314":1,"316":1,"324":1,"329":1,"337":1,"341":1,"345":1,"350":1,"380":1,"381":1,"387":1,"388":1,"390":1,"392":1,"422":2,"427":1,"432":1,"453":1,"465":1,"559":1,"564":1,"569":1,"572":1,"615":1,"617":1,"646":1,"698":1,"704":3,"706":1,"731":1,"735":1,"736":1,"737":1,"742":1,"744":1,"769":1,"775":1}}],["securing",{"2":{"36":1,"37":1,"38":2}}],["security",{"0":{"224":1,"631":1,"632":1},"2":{"10":1,"26":2,"221":2,"224":1,"226":1,"235":1,"343":1,"396":1,"557":2,"580":2,"627":1,"634":1}}],["securely",{"2":{"88":1,"165":1,"221":1,"400":1,"648":1}}],["secure",{"2":{"24":1,"30":1,"226":1,"320":1,"370":1,"637":1,"651":1,"681":1,"689":2}}],["seconds",{"2":{"93":2,"275":4,"704":4,"705":4,"720":1,"765":1}}],["second",{"2":{"22":4,"156":1,"183":1,"233":1,"433":1,"540":1,"561":1,"592":1,"607":1,"608":1,"609":1,"631":1}}],["setgaslimitandfee",{"2":{"597":2}}],["setwhiteliststatus",{"2":{"206":2}}],["sets",{"2":{"147":1,"740":1,"782":1}}],["settling",{"2":{"227":1}}],["settlement",{"2":{"137":1,"165":1,"171":1,"172":1,"179":1,"180":1,"183":2,"185":1,"186":2,"187":3,"190":1,"191":1,"194":1,"227":1,"455":1,"578":1,"640":2,"646":1,"647":4}}],["settles",{"2":{"107":1}}],["settle",{"2":{"81":1,"87":1,"111":1,"227":1,"454":1}}],["settled",{"2":{"77":1,"80":1}}],["settingpruning",{"2":{"368":1}}],["settingmin",{"2":{"365":1}}],["settings",{"2":{"76":1,"275":1,"322":1,"328":1,"363":1,"380":1,"381":1,"569":1}}],["setting",{"0":{"93":1,"237":1,"240":1,"285":1,"290":1,"414":1,"417":1,"458":1,"462":1,"472":1,"475":1,"476":1,"542":1,"600":1,"610":1,"612":1,"733":1,"746":1},"1":{"238":1,"239":1,"240":1,"241":2,"242":1,"243":1,"244":1,"245":1,"246":1,"247":1,"248":1,"286":1,"287":1,"288":1,"289":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"459":1,"460":1,"461":1,"462":1,"463":2,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"601":1,"602":1,"603":1,"604":1,"605":1,"606":1,"611":1,"612":1,"613":2,"614":2,"615":1,"616":1,"617":1,"618":1,"619":1,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"734":1,"735":1,"736":1},"2":{"7":1,"41":2,"54":1,"55":1,"93":8,"211":1,"237":1,"248":1,"251":1,"311":1,"337":1,"341":1,"355":1,"361":1,"365":2,"368":1,"397":1,"414":1,"418":1,"458":1,"462":1,"470":1,"472":1,"539":1,"540":1,"557":1,"558":1,"597":4,"601":1,"610":1,"612":1,"619":1,"695":1,"734":1,"741":1,"755":1,"764":1}}],["setupprivate",{"2":{"93":1}}],["setup",{"0":{"83":1,"89":1,"241":1,"274":1,"388":1,"391":1,"418":1,"441":1,"541":1,"707":1,"776":1},"1":{"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"389":1,"390":1,"391":1,"392":2,"393":2,"394":1,"395":1,"396":1,"542":1},"2":{"26":2,"30":1,"76":1,"86":1,"89":5,"92":1,"93":2,"202":2,"205":1,"206":1,"214":1,"250":1,"275":2,"277":1,"290":1,"312":1,"315":1,"343":1,"371":1,"427":1,"441":1,"597":2,"615":1,"737":1,"769":1,"778":2}}],["setupsigner",{"2":{"597":2}}],["setups",{"2":{"23":1,"328":1}}],["set",{"0":{"206":1,"293":1,"302":1,"358":1,"359":1,"361":1,"558":1},"1":{"359":1,"360":1,"361":1},"2":{"18":2,"20":1,"22":1,"23":1,"26":1,"30":1,"31":1,"36":1,"41":2,"79":1,"90":1,"91":4,"93":10,"122":1,"125":4,"128":1,"151":1,"168":1,"178":1,"202":7,"205":2,"206":1,"210":6,"211":5,"224":1,"248":1,"263":3,"275":1,"276":1,"281":3,"287":1,"293":1,"298":2,"299":2,"301":2,"302":1,"303":1,"304":1,"320":1,"337":1,"338":2,"350":1,"353":1,"356":1,"361":6,"366":1,"371":2,"380":1,"381":1,"390":3,"391":1,"392":1,"399":1,"405":1,"412":1,"431":1,"446":1,"462":1,"475":1,"476":1,"531":1,"536":1,"537":1,"539":1,"557":1,"558":3,"559":2,"580":2,"582":1,"584":3,"590":4,"619":1,"636":1,"641":1,"647":1,"674":2,"680":1,"708":1,"722":1,"724":1,"738":4,"739":2,"740":5,"741":4,"742":4,"743":1,"745":1,"746":3,"752":2,"755":1,"760":1,"766":1,"768":1,"769":1,"772":4,"777":1}}],["sees",{"2":{"628":1}}],["seeing",{"2":{"434":2,"604":1,"605":1}}],["seed",{"2":{"361":2,"430":5,"621":1,"679":1,"680":1}}],["seeds",{"2":{"361":13}}],["seeking",{"2":{"341":1}}],["seek",{"2":{"34":1,"37":1}}],["see",{"2":{"16":1,"73":1,"76":1,"77":4,"79":3,"80":1,"87":1,"91":1,"93":1,"94":1,"110":1,"111":1,"127":2,"134":1,"156":2,"157":2,"210":1,"211":1,"214":1,"227":1,"234":1,"238":3,"258":1,"264":1,"265":1,"274":1,"275":1,"282":1,"287":1,"291":1,"303":2,"309":1,"311":1,"312":1,"371":1,"373":1,"380":1,"404":1,"408":1,"428":2,"431":1,"483":1,"493":1,"498":1,"513":1,"523":1,"540":1,"543":1,"544":1,"554":1,"556":2,"557":2,"558":1,"559":2,"562":2,"563":2,"597":4,"599":1,"602":1,"604":1,"605":2,"606":1,"614":2,"620":2,"627":1,"646":1,"657":1,"661":1,"668":1,"677":1,"692":1,"707":1,"712":2,"745":1,"764":1,"765":1,"776":1,"780":2,"783":1,"784":1}}],["sexualized",{"2":{"7":1}}],["sexual",{"2":{"6":1,"7":1}}],["sex",{"2":{"6":1}}],["superior",{"2":{"722":1}}],["supply",{"0":{"673":1},"1":{"674":1,"675":1,"676":1,"677":1,"678":1,"679":1,"680":1},"2":{"238":1,"675":1,"679":1,"680":6,"685":1}}],["supporters",{"2":{"679":2}}],["supported",{"2":{"168":1,"400":1,"495":1,"599":1,"719":1}}],["supports",{"2":{"322":1,"674":1,"716":1}}],["supportive",{"2":{"46":1}}],["supporting",{"2":{"38":1,"41":1,"56":1}}],["support",{"2":{"30":1,"33":1,"35":1,"38":4,"40":1,"43":1,"44":1,"57":2,"81":2,"90":1,"110":1,"249":1,"273":1,"278":1,"396":1,"427":1,"428":1,"507":1,"528":2,"581":1,"582":2,"615":1,"672":2,"674":1}}],["sudo",{"2":{"271":4,"398":2,"399":16,"602":2,"604":4,"605":4,"606":2}}],["sudden",{"2":{"18":1}}],["suits",{"2":{"166":1}}],["suitable",{"2":{"30":1,"380":2}}],["summarize",{"2":{"137":1}}],["summarizes",{"2":{"126":4}}],["summary",{"2":{"53":1,"54":1,"55":1,"226":1}}],["surface",{"2":{"582":1}}],["sure",{"2":{"91":2,"116":1,"117":1,"139":2,"140":2,"164":1,"168":1,"175":1,"183":2,"187":2,"191":1,"194":1,"202":2,"204":1,"211":3,"214":1,"215":2,"273":1,"274":2,"298":1,"311":1,"313":3,"326":3,"347":1,"426":1,"557":1,"602":1,"698":1,"740":1,"765":1}}],["surveys",{"2":{"31":1}}],["suggest",{"2":{"782":2}}],["suggested",{"0":{"672":1},"2":{"592":1,"672":1}}],["suggests",{"2":{"41":1}}],["suggestions",{"0":{"4":1},"2":{"4":1,"34":1}}],["sustainable",{"2":{"38":1}}],["sustained",{"2":{"14":1,"15":1}}],["sufficiently",{"2":{"650":1}}],["sufficient",{"2":{"34":1,"174":1,"403":1,"643":2}}],["succinct",{"0":{"218":1},"2":{"202":4,"203":2,"204":6,"205":1,"211":5,"218":7,"219":1,"221":1,"227":1,"233":1,"235":1,"584":1}}],["succinctxgit",{"2":{"202":1}}],["succinctx",{"2":{"202":4,"214":4,"215":2}}],["succinctgateway",{"0":{"202":1,"204":1},"1":{"205":1,"206":1,"207":1},"2":{"202":7,"204":1,"205":1,"210":3,"215":1,"234":2}}],["succinctlabs",{"2":{"136":4,"144":4,"161":2,"162":2,"163":4,"202":2,"203":2,"208":2,"211":2,"214":2,"215":2,"584":2}}],["succeeds",{"2":{"109":1}}],["success",{"2":{"32":1,"44":1,"77":1,"431":3,"434":2,"745":1}}],["successful",{"2":{"29":1,"36":1,"38":1,"39":1,"51":1,"57":1,"93":1,"204":1,"540":1,"597":4,"614":1,"650":1,"760":1,"771":1}}],["successfully",{"2":{"23":1,"90":1,"122":2,"168":1,"219":1,"248":1,"309":2,"311":1,"429":1,"430":1,"434":1,"540":1,"562":1,"563":1,"602":1,"604":1,"605":1,"606":1,"619":1,"627":1,"630":1,"634":1,"708":1,"765":1,"771":2,"777":1}}],["such",{"2":{"7":1,"30":1,"36":1,"37":2,"38":1,"86":1,"125":2,"126":1,"276":1,"278":1,"313":1,"322":4,"326":1,"400":1,"422":1,"465":1,"482":1,"589":1,"597":2,"628":1,"631":1,"633":1,"634":1,"637":1,"643":1,"647":1,"649":1,"650":2,"670":1,"690":1,"707":1,"713":1,"734":1,"738":2,"774":1,"776":1}}],["subdomain",{"2":{"760":1}}],["subtract",{"2":{"717":1}}],["subtrees",{"2":{"649":1}}],["subtree",{"2":{"168":6}}],["subtreerootthreshold",{"2":{"150":2}}],["sub",{"2":{"597":2,"778":4}}],["subcommands",{"0":{"264":1},"2":{"260":6}}],["subset",{"2":{"677":1}}],["subsequently",{"2":{"124":1}}],["subsequent",{"2":{"22":1,"525":1}}],["subspace",{"2":{"266":4}}],["subscribing",{"0":{"709":1,"710":1,"778":1},"2":{"774":1,"778":2}}],["subscribes",{"2":{"710":2}}],["subscribeblobs",{"2":{"709":2}}],["subscribeheaders",{"2":{"707":1,"710":4,"776":1}}],["subscribe",{"2":{"90":3,"91":1,"709":6,"710":6,"778":6}}],["subscription",{"2":{"162":6,"707":1,"776":1,"778":1}}],["subscriptions",{"2":{"90":1}}],["submitoptions",{"2":{"777":4}}],["submitpayforblob",{"2":{"597":2,"598":1}}],["submitdata",{"2":{"597":2}}],["submitblob",{"2":{"596":4,"708":4}}],["submitblockdata",{"2":{"126":2,"128":2}}],["submitfraudproof",{"2":{"163":8}}],["submitter",{"2":{"266":1}}],["submitted",{"2":{"87":1,"125":8,"144":2,"155":2,"161":2,"163":2,"172":2,"208":1,"216":1,"267":1,"429":2,"450":1,"540":1,"592":3,"599":1,"745":1,"746":1,"771":2,"773":1}}],["submitting",{"0":{"133":1,"411":1,"517":1,"585":1,"592":1,"708":1,"743":1,"760":1,"777":1},"1":{"518":1,"519":1,"586":1,"587":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"744":1},"2":{"134":1,"157":1,"180":1,"183":1,"186":1,"187":1,"211":1,"217":1,"244":1,"266":1,"409":1,"422":1,"471":1,"477":1,"523":1,"589":1,"591":1,"599":2,"669":1,"735":1,"743":1,"744":1,"745":1,"774":1,"777":2}}],["submits",{"2":{"126":2,"427":1,"596":2,"708":2,"771":3}}],["submitheader",{"2":{"126":4,"128":2}}],["submitrollupblock",{"2":{"118":2}}],["submit",{"0":{"518":1,"519":1,"621":1,"744":1},"2":{"87":1,"133":1,"163":5,"171":1,"202":1,"205":1,"206":3,"208":1,"211":1,"215":1,"217":1,"266":10,"267":4,"402":1,"406":1,"408":3,"411":3,"422":2,"465":2,"477":2,"515":1,"518":3,"519":3,"523":1,"525":1,"542":1,"562":4,"585":2,"586":1,"590":1,"592":2,"593":1,"595":3,"596":4,"597":6,"598":2,"599":3,"621":1,"650":1,"668":2,"677":1,"678":1,"687":1,"708":5,"728":1,"738":6,"743":12,"746":2,"760":2,"762":1,"763":1,"769":2,"770":2,"771":11,"773":2,"774":2,"777":7}}],["submission",{"0":{"401":1,"409":1,"514":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":1,"412":1,"413":1,"515":1,"516":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1},"2":{"47":1,"186":1,"205":2,"206":1,"211":1,"267":1,"455":1,"746":1,"760":1}}],["submissions",{"2":{"20":1,"404":1}}],["subjectivity",{"2":{"371":1}}],["subject",{"2":{"23":1,"37":1,"60":1,"586":1,"609":1,"680":2,"715":1,"720":1}}],["s",{"0":{"86":1,"88":1,"92":1,"161":1,"413":1,"640":1},"1":{"641":1,"642":1,"643":1,"644":1,"645":1,"646":1},"2":{"7":1,"16":1,"18":1,"20":2,"21":1,"22":1,"23":2,"24":2,"26":1,"27":1,"35":1,"36":3,"38":1,"40":1,"42":1,"47":1,"50":1,"58":1,"60":1,"63":1,"67":1,"68":2,"70":1,"81":1,"82":1,"83":1,"86":9,"87":9,"88":4,"90":4,"91":1,"92":1,"93":3,"94":1,"103":1,"107":1,"110":1,"111":2,"122":4,"125":1,"128":28,"130":3,"137":1,"139":1,"165":1,"174":1,"179":1,"187":3,"199":1,"202":3,"205":1,"210":4,"211":1,"214":2,"216":1,"218":1,"221":2,"226":2,"227":4,"233":2,"245":1,"250":1,"260":2,"261":1,"266":1,"271":4,"274":3,"275":3,"276":2,"277":1,"281":1,"301":1,"303":2,"313":1,"316":1,"320":1,"322":7,"326":1,"331":1,"334":1,"337":2,"343":1,"344":1,"349":1,"361":14,"372":12,"377":2,"378":2,"380":1,"396":1,"400":1,"402":2,"404":2,"409":1,"413":1,"422":2,"427":1,"429":2,"431":1,"455":1,"458":1,"465":2,"476":1,"477":2,"478":2,"479":1,"484":1,"492":1,"493":2,"497":1,"499":1,"504":1,"505":2,"506":2,"510":1,"516":1,"519":1,"530":1,"537":2,"538":2,"540":1,"547":1,"550":1,"555":5,"557":2,"558":7,"561":1,"562":2,"563":2,"577":1,"578":1,"582":3,"584":1,"589":2,"590":2,"596":2,"597":2,"599":2,"602":2,"609":1,"634":1,"636":1,"637":1,"640":1,"641":1,"642":1,"649":1,"650":1,"668":1,"678":1,"680":2,"682":1,"683":1,"687":1,"689":1,"690":1,"708":2,"714":1,"717":1,"721":1,"730":1,"734":1,"735":1,"737":1,"738":1,"740":1,"748":1,"749":1,"750":1,"751":1,"752":1,"755":1,"756":1,"763":6,"765":1,"770":1,"771":2,"773":5,"775":1,"777":2,"782":1,"784":1}}],["situation",{"2":{"632":1}}],["site",{"0":{"0":1,"1":1},"1":{"1":1,"2":1,"3":1,"4":1},"2":{"1":1,"782":8}}],["six",{"2":{"593":1}}],["sig",{"2":{"280":1}}],["signaled",{"2":{"525":1,"526":1,"528":1}}],["signaling",{"2":{"525":2,"526":1,"528":4}}],["signal",{"2":{"178":1,"525":1,"528":1}}],["signatures",{"2":{"278":1,"294":2,"752":2}}],["signature",{"2":{"125":4,"128":4,"130":4,"589":1,"649":1,"668":1,"752":2}}],["signers",{"2":{"515":1}}],["signer",{"0":{"517":1,"519":1},"1":{"518":1,"519":1},"2":{"147":2,"202":2,"294":2,"519":4,"528":1,"596":2,"597":12,"708":2}}],["signedtx",{"2":{"279":2}}],["signed",{"2":{"128":1,"279":4,"518":1}}],["signbytes",{"2":{"128":2}}],["signs",{"2":{"127":1}}],["sign",{"2":{"90":1,"128":2,"202":2,"279":6,"597":6,"766":2}}],["significant",{"2":{"367":1,"381":1,"671":1}}],["significantly",{"2":{"38":1,"580":1,"586":1,"720":1}}],["signifies",{"2":{"328":1}}],["signing",{"0":{"272":1},"2":{"88":1,"281":2,"294":2,"620":2,"715":1,"716":1,"724":1,"726":1}}],["signup",{"0":{"47":1}}],["sidebar",{"2":{"275":2}}],["sidenode",{"2":{"159":4,"160":4,"163":8}}],["sidenodes",{"2":{"144":2,"156":6,"159":6,"160":2,"163":6}}],["side",{"2":{"156":2,"159":2,"168":2,"434":8}}],["simulated",{"2":{"400":1}}],["simulates",{"2":{"204":1}}],["simultaneous",{"2":{"274":2}}],["simplifies",{"2":{"523":1}}],["simplicity",{"2":{"172":1,"477":2,"562":2,"563":2}}],["simply",{"2":{"126":2,"238":1,"275":1,"438":1,"455":1}}],["simpler",{"2":{"176":1,"630":1}}],["simplerollup",{"2":{"163":8}}],["simple",{"2":{"124":1,"127":1,"163":1,"180":1,"188":1,"203":1,"204":1,"234":1,"580":1}}],["simplest",{"2":{"84":1,"130":1,"380":1}}],["similarly",{"2":{"187":1,"211":1,"225":1,"278":1,"646":1,"659":1,"688":1}}],["similar",{"2":{"91":1,"93":1,"144":2,"160":1,"161":2,"162":2,"163":2,"186":1,"194":1,"202":1,"210":1,"267":1,"322":1,"337":1,"339":1,"392":1,"393":1,"434":2,"476":1,"537":1,"538":1,"588":1,"614":2,"620":1,"648":1,"720":1,"745":1,"748":1}}],["since",{"2":{"90":1,"91":1,"109":1,"119":1,"144":2,"161":2,"163":2,"169":1,"186":1,"199":1,"210":6,"277":1,"301":1,"478":1,"530":1,"588":1,"590":1,"628":1,"632":1,"642":1,"643":1,"650":1,"675":1,"719":1,"770":2,"771":2,"773":2}}],["single",{"2":{"13":1,"88":1,"120":1,"126":1,"137":1,"172":1,"180":3,"279":4,"286":3,"287":2,"371":1,"460":1,"474":3,"533":1,"634":1,"637":1,"647":1,"732":1}}],["sizeofdatainbytes",{"2":{"591":2}}],["sizes",{"2":{"147":2,"197":1,"590":1}}],["size",{"0":{"586":1},"2":{"6":1,"36":2,"91":4,"122":3,"157":1,"169":1,"171":1,"174":5,"429":8,"483":9,"528":1,"536":2,"563":1,"586":2,"589":4,"590":3,"591":1,"631":2,"636":1,"642":1,"648":1,"649":2,"668":1,"669":1,"674":1,"738":1,"746":1}}],["stuck",{"2":{"400":1}}],["stub",{"2":{"118":1}}],["styles",{"2":{"782":6}}],["style",{"2":{"396":1}}],["stops",{"2":{"400":1}}],["stop",{"0":{"426":1},"2":{"136":2,"266":1,"329":1,"426":1}}],["storing",{"2":{"112":1,"569":1,"605":1,"634":1,"635":1,"637":1,"639":1,"672":2}}],["stories",{"2":{"42":1}}],["storecelestia",{"2":{"741":1}}],["storecd",{"2":{"391":1}}],["store=$home",{"2":{"741":2}}],["storesudo",{"2":{"391":1}}],["stores",{"2":{"322":4,"414":1,"531":1,"569":1,"646":1}}],["store",{"0":{"327":1,"335":1,"392":1,"569":1,"638":1,"741":1},"1":{"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"742":1},"2":{"88":1,"109":1,"112":1,"238":1,"322":1,"328":3,"329":9,"335":5,"336":4,"338":1,"381":3,"391":4,"392":9,"393":8,"415":1,"429":8,"464":2,"475":4,"476":6,"477":6,"494":1,"542":1,"557":7,"559":1,"569":2,"589":1,"633":1,"637":2,"638":1,"639":1,"642":1,"646":1,"670":1,"672":1,"734":1,"738":4,"739":7,"741":9,"742":8,"743":4,"745":2,"765":4}}],["stored",{"2":{"86":3,"109":1,"139":1,"160":1,"162":1,"219":1,"227":1,"261":1,"303":2,"381":2,"631":1,"632":1,"634":1,"670":1,"671":2,"734":1}}],["storage",{"0":{"362":1,"368":1,"391":1,"414":1,"415":1,"417":1,"420":1,"421":1,"422":1,"423":1,"425":1,"426":1,"604":1,"633":1,"634":1,"635":1,"637":1},"1":{"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"392":1,"393":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":2,"422":2,"423":1,"424":2,"425":1,"426":1},"2":{"42":1,"112":1,"218":1,"239":1,"275":2,"322":4,"357":1,"367":1,"368":1,"380":1,"381":1,"393":1,"414":1,"415":2,"416":2,"422":3,"423":2,"424":1,"425":2,"426":1,"460":1,"491":1,"494":1,"499":1,"531":1,"533":1,"604":2,"611":1,"633":2,"634":2,"635":1,"637":2,"639":2,"671":1,"732":1}}],["stick",{"2":{"172":1}}],["sticking",{"2":{"86":1}}],["still",{"2":{"60":1,"166":1,"168":2,"211":2,"328":1,"350":1,"368":1,"422":1,"479":1,"544":1,"625":1,"642":1,"646":1,"765":1,"782":1}}],["str",{"2":{"777":4,"778":4,"779":4}}],["stronger",{"0":{"639":1}}],["strong",{"2":{"637":1}}],["straight",{"2":{"495":1}}],["straightforward",{"2":{"193":1}}],["strategy",{"2":{"336":1}}],["strike",{"2":{"226":1}}],["string",{"2":{"65":1,"67":1,"68":1,"143":2,"202":2,"214":1,"244":1,"313":2,"325":2,"326":2,"422":1,"492":1,"493":1,"504":1,"505":1,"596":4,"597":2,"707":1,"708":4,"709":4,"710":4,"711":4,"739":3,"740":1,"743":2,"760":1,"770":2,"771":17,"772":4,"773":8,"776":1}}],["struct",{"2":{"109":1,"125":10,"126":6,"154":4,"156":9,"157":2,"159":5,"160":4}}],["structured",{"2":{"322":1}}],["structures",{"0":{"119":1},"2":{"110":1,"125":2,"137":1,"160":2,"597":2}}],["structure",{"0":{"3":1},"2":{"22":1,"125":2,"156":2,"159":2,"322":1}}],["streaming",{"0":{"220":1},"1":{"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1},"2":{"40":4}}],["stress",{"2":{"35":1}}],["strengthen",{"2":{"32":1}}],["steal",{"2":{"628":1}}],["steady",{"2":{"18":1,"22":1}}],["step",{"0":{"76":1,"77":1,"79":1,"80":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1},"2":{"54":2,"79":1,"85":1,"86":1,"87":2,"90":1,"125":1,"128":1,"130":1,"163":1,"175":1,"201":1,"204":1,"215":1,"280":2,"432":1,"443":1,"448":1,"449":1,"479":1,"659":1,"736":1,"771":1}}],["steps",{"0":{"113":1,"259":1,"289":1,"344":1,"457":1,"571":1,"698":1,"699":1,"700":1,"774":1},"2":{"29":1,"90":1,"104":1,"105":1,"108":1,"199":1,"201":1,"215":1,"237":1,"311":2,"312":1,"341":1,"428":1,"430":1,"439":1,"443":1,"526":1,"584":1,"599":1,"601":1,"620":3,"625":1}}],["stands",{"2":{"693":1}}],["standard",{"2":{"41":1,"341":1,"427":1,"585":1,"587":1,"643":4,"669":1,"715":2,"717":1}}],["standards",{"0":{"7":1},"2":{"8":1,"14":1,"15":1}}],["stay",{"2":{"277":1,"498":1,"513":1,"554":1}}],["stage",{"2":{"221":1,"479":1}}],["stacks",{"0":{"572":1},"1":{"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1},"2":{"571":1,"714":1}}],["stack=",{"2":{"383":2,"625":2}}],["stack",{"0":{"250":1,"454":1,"540":1,"564":1},"1":{"455":1,"456":1,"457":1,"541":1,"542":1,"543":1,"544":1,"545":1,"565":1,"566":1,"567":1,"568":1,"569":1},"2":{"107":1,"249":1,"251":1,"259":1,"383":4,"454":1,"455":1,"457":1,"540":3,"545":1,"580":2,"582":1,"625":4,"647":2}}],["stakin",{"2":{"487":1,"488":1,"489":1}}],["staking",{"0":{"673":1,"681":1,"693":1,"694":1},"1":{"674":1,"675":1,"676":1,"677":1,"678":1,"679":1,"680":1,"682":1,"683":1},"2":{"86":1,"87":1,"266":6,"269":4,"272":1,"614":2,"620":2,"651":1,"674":3,"680":1,"681":2,"682":1,"683":1,"689":1,"690":1,"693":2,"715":1}}],["stakecurrency",{"2":{"782":2}}],["staked",{"2":{"654":1,"680":1}}],["stakeflow",{"2":{"487":1,"488":1,"489":1,"496":1,"506":1,"507":1,"508":1,"512":1}}],["stakers",{"2":{"677":1,"678":1}}],["staker",{"2":{"93":3}}],["stakes",{"2":{"86":2}}],["stake",{"0":{"614":1,"651":1,"653":1,"656":1,"658":1,"660":1,"662":1,"665":1,"674":1,"689":1},"1":{"652":1,"653":1,"654":2,"655":2,"656":2,"657":2,"658":1,"659":2,"660":2,"661":2,"662":1,"663":2,"664":2,"665":2,"666":2},"2":{"18":1,"21":1,"23":1,"86":6,"224":1,"238":1,"266":1,"281":4,"614":1,"651":3,"654":1,"656":1,"657":1,"659":1,"660":1,"661":1,"663":1,"666":1,"674":4,"681":1,"682":1,"689":2}}],["statscelestia",{"2":{"754":1}}],["stats",{"0":{"754":1},"2":{"559":1,"754":1}}],["static",{"2":{"275":2,"569":1,"589":4,"590":2}}],["stateroot",{"2":{"536":2}}],["statesync",{"2":{"371":3}}],["stated",{"2":{"210":1}}],["stateless",{"2":{"122":1}}],["state",{"0":{"68":1,"367":1,"371":1,"493":1,"505":1,"636":1},"2":{"68":3,"86":4,"127":2,"130":1,"163":4,"179":3,"183":1,"187":1,"191":1,"194":1,"202":1,"210":3,"227":1,"238":2,"244":2,"260":6,"302":1,"322":2,"367":1,"368":1,"369":2,"371":7,"372":1,"381":3,"383":29,"407":2,"408":2,"409":2,"410":2,"422":3,"437":1,"455":1,"465":1,"477":4,"493":2,"505":2,"506":1,"508":1,"523":2,"561":4,"578":1,"588":1,"589":1,"590":1,"592":1,"598":1,"625":31,"628":1,"636":4,"646":3,"647":8,"649":2,"670":2,"672":2,"719":1,"720":1,"735":2,"738":2,"748":2,"749":4,"751":2,"755":6,"765":2}}],["statements",{"0":{"769":1},"2":{"769":2}}],["statement",{"2":{"26":1}}],["status",{"0":{"206":1,"258":1},"2":{"6":1,"65":1,"77":1,"205":2,"206":6,"258":2,"260":4,"282":1,"331":2,"493":2,"602":4,"606":2,"608":1,"704":2,"705":2}}],["stable",{"2":{"22":1,"479":1,"547":1}}],["stability",{"0":{"60":1,"479":1},"2":{"18":1}}],["startcelestia",{"2":{"373":1,"453":1,"618":1,"620":1}}],["starts",{"2":{"210":1,"217":1,"675":1}}],["startshare=0",{"2":{"152":1}}],["startindex",{"2":{"172":2,"174":2}}],["starting",{"0":{"474":1},"2":{"20":1,"44":1,"125":1,"141":1,"151":1,"245":1,"329":1,"339":1,"449":1,"543":1,"621":1,"647":1,"678":1,"707":1,"776":1}}],["startblock",{"2":{"144":6,"161":4,"208":1}}],["start=10",{"2":{"142":1}}],["start",{"0":{"248":1,"373":1,"390":1,"393":1,"422":1,"425":1,"436":1,"465":1,"470":1,"555":1,"559":1,"602":1,"619":1},"1":{"466":1,"467":1,"468":1,"469":1,"470":1,"556":1,"557":1,"558":1,"559":1,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1},"2":{"64":1,"68":6,"91":3,"92":1,"125":2,"126":1,"136":2,"143":2,"144":4,"147":5,"152":2,"156":3,"163":4,"172":1,"216":1,"244":1,"245":8,"246":7,"247":1,"259":1,"260":4,"279":2,"295":2,"307":1,"309":2,"314":3,"316":3,"317":2,"318":2,"319":2,"320":4,"324":2,"329":3,"334":3,"338":2,"348":2,"371":1,"373":9,"375":1,"384":1,"390":6,"392":1,"393":10,"407":3,"408":3,"422":5,"423":7,"424":1,"428":1,"429":6,"436":2,"453":2,"457":1,"465":7,"466":8,"468":7,"469":1,"475":3,"476":3,"485":1,"493":3,"503":1,"516":3,"555":1,"559":5,"561":1,"574":1,"580":1,"602":5,"604":5,"605":6,"606":7,"618":1,"620":9,"625":1,"674":1,"704":2,"705":3,"707":1,"725":1,"735":12,"736":8,"738":1,"765":4,"770":1,"776":1}}],["startup",{"2":{"34":1,"605":1}}],["started",{"0":{"115":1,"714":1},"1":{"116":1,"117":1,"118":1},"2":{"1":1,"26":1,"33":1,"41":1,"92":1,"312":1,"329":1,"342":1,"385":1,"391":1,"405":1,"544":1,"555":1,"559":2,"571":1,"602":1,"606":1,"682":1,"683":1,"704":1,"714":1,"725":2,"763":1}}],["gpt3dot5turbo",{"2":{"772":2}}],["gpt3",{"2":{"772":4,"773":2}}],["gpt",{"2":{"763":2,"764":1,"772":4,"773":4,"774":2}}],["glance",{"0":{"685":1}}],["global",{"2":{"275":3,"429":2}}],["gcpbb",{"2":{"590":1}}],["gg",{"2":{"430":2}}],["gm",{"2":{"408":2,"518":2,"519":2,"738":4,"743":3,"745":6,"746":2}}],["gz",{"2":{"399":24}}],["ghcr",{"2":{"390":6,"392":6,"393":6,"704":2}}],["gbps",{"2":{"239":2,"357":2,"416":2,"533":2,"534":2,"611":2}}],["gb",{"2":{"239":1,"357":1,"416":1,"460":1,"533":3,"534":2,"611":1,"732":1}}],["gnark",{"2":{"214":1}}],["gklcgflcsrm9caqasaapsckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwohaqdvbvupglandgtlocgsoherbafsfbb5l0wdvbjjesehegqkaggbgjjcariscgwkbhv0awesbdixotiqto9cgkcjrjcoyijj81bttfb2gudg7o8auawf0bscbhw9ppd99xpq1slpemfyq0y1joj",{"2":{"147":4}}],["gt",{"2":{"68":6,"70":3,"77":1,"91":8,"128":2,"136":3,"140":8,"142":1,"147":1,"148":2,"150":7,"152":1,"203":8,"204":30,"206":4,"207":4,"209":6,"215":2,"233":1,"244":8,"245":4,"246":12,"262":8,"263":6,"264":8,"265":18,"266":20,"267":4,"268":6,"269":16,"270":4,"271":12,"272":2,"275":2,"279":2,"287":2,"303":4,"314":10,"316":10,"317":4,"318":4,"319":4,"320":16,"324":10,"329":10,"334":8,"335":4,"336":8,"338":9,"372":12,"373":1,"393":2,"399":8,"405":4,"412":4,"422":4,"423":12,"430":4,"466":6,"467":3,"468":12,"493":6,"510":3,"536":1,"569":2,"594":4,"595":4,"602":2,"604":2,"605":4,"606":4,"614":4,"617":2,"620":3,"698":13,"699":12,"700":12,"704":5,"705":8,"735":6,"736":21,"738":6,"740":6,"741":4,"743":8,"745":8,"749":2,"752":4,"755":6,"757":4,"770":6,"771":6,"773":12,"778":8,"779":2,"782":14}}],["gobin",{"2":{"697":2}}],["google",{"2":{"597":4}}],["good",{"2":{"275":1,"391":2}}],["gonna",{"2":{"557":10}}],["gone",{"2":{"307":1}}],["go$ver",{"2":{"399":24}}],["goroutine",{"2":{"383":4,"625":4}}],["govcelestia",{"2":{"266":1}}],["gov",{"2":{"266":12,"267":2,"715":1}}],["governing",{"2":{"690":1}}],["governance",{"0":{"266":1,"673":1,"676":1,"690":1},"1":{"267":1,"674":1,"675":1,"676":1,"677":2,"678":2,"679":1,"680":1},"2":{"266":3,"267":1,"483":3,"586":1,"589":1,"590":2,"646":1,"651":1,"677":2,"678":1,"680":1,"690":3}}],["governs",{"2":{"235":1}}],["go\\t",{"2":{"161":1}}],["go\\tsharesproof",{"2":{"153":1}}],["goimport",{"2":{"150":1,"591":1,"596":1,"597":1,"708":1}}],["going",{"2":{"79":1,"289":1,"350":1,"531":1,"602":1}}],["gopackage",{"2":{"143":1,"144":1,"163":1,"769":1}}],["goleveldb",{"2":{"140":4}}],["golangnodearabica",{"2":{"399":2}}],["golangnodemocha",{"2":{"399":2}}],["golangnodemainnet",{"2":{"399":2}}],["golang",{"0":{"143":1,"148":1,"150":1,"153":1,"399":1,"568":1,"596":1,"706":1},"1":{"707":1,"708":1,"709":1,"710":1,"711":1,"712":1},"2":{"136":2,"143":1,"148":1,"149":1,"150":1,"153":1,"156":1,"158":1,"159":1,"160":1,"163":1,"228":1,"233":1,"341":1,"399":11,"568":2,"596":2,"597":4,"706":1,"723":1,"725":1,"763":2,"764":1,"773":1}}],["gogo",{"2":{"140":2}}],["gohttps",{"2":{"136":2}}],["gotten",{"2":{"155":1,"175":1}}],["got",{"2":{"130":2,"383":2,"559":1,"625":2,"745":1}}],["gotype",{"2":{"125":2,"126":1}}],["gossiped",{"2":{"588":1,"607":1,"641":1}}],["gossiping",{"2":{"130":2,"608":1}}],["gossip",{"2":{"130":1,"415":1}}],["gofunc",{"2":{"128":2,"130":1,"156":1,"157":1,"158":1,"159":1,"160":1,"709":1,"771":1,"773":1}}],["goals",{"2":{"580":1}}],["goal",{"2":{"125":1}}],["goes",{"2":{"54":1,"80":1,"179":3,"199":1,"338":1,"341":1,"717":1}}],["go",{"0":{"768":1},"2":{"44":1,"109":1,"125":1,"126":1,"134":1,"136":3,"140":5,"144":7,"148":1,"150":2,"161":1,"162":2,"163":7,"166":1,"200":1,"214":4,"228":1,"237":1,"256":1,"257":1,"261":1,"275":1,"287":2,"306":1,"311":1,"316":1,"331":1,"332":1,"336":2,"342":1,"343":3,"383":36,"391":2,"397":1,"399":18,"427":4,"432":1,"556":1,"557":14,"625":36,"647":1,"695":2,"710":1,"711":1,"738":1,"765":4,"768":10,"769":3,"770":5,"771":6,"772":1,"773":10}}],["game",{"2":{"763":2}}],["gaming",{"2":{"37":1,"581":1}}],["gather",{"2":{"316":1}}],["gateways",{"2":{"202":1}}],["gateway",{"0":{"726":1,"727":1},"1":{"727":1},"2":{"91":2,"93":2,"201":1,"202":3,"204":7,"205":1,"210":3,"211":4,"235":1,"326":3,"507":1,"721":1,"722":1,"726":3,"727":1,"731":1}}],["gas=220000",{"2":{"620":1}}],["gas=220000moniker=",{"2":{"620":1}}],["gasperblobbyte",{"2":{"589":1}}],["gasperbyte",{"2":{"589":1,"590":2}}],["gaspricestep",{"2":{"782":2}}],["gasprice",{"2":{"537":2,"588":1,"777":1}}],["gastoconsume",{"2":{"589":2,"590":1}}],["gasused",{"2":{"536":2}}],["gaslimit",{"2":{"536":2,"588":1,"591":2,"597":4,"743":4,"755":1}}],["gas",{"0":{"588":1,"589":1,"590":1,"591":1,"746":1},"1":{"589":1,"590":1,"591":1},"2":{"82":1,"84":1,"86":3,"87":2,"91":4,"147":4,"219":1,"226":1,"268":2,"270":2,"294":12,"301":2,"429":16,"523":1,"528":1,"537":2,"586":1,"587":2,"588":9,"589":9,"590":18,"591":5,"597":6,"614":4,"620":4,"669":1,"688":1,"708":3,"743":2,"746":12,"755":7,"771":2,"777":3,"784":3}}],["gaining",{"2":{"628":1}}],["gain",{"2":{"42":1,"50":1,"58":1,"634":1,"763":1}}],["gained",{"2":{"32":1}}],["gap",{"2":{"36":1}}],["gauge",{"2":{"36":1}}],["grid",{"2":{"586":1}}],["grzxooejihch93+g3mldibq6ff+nroakrbgupfu8muo=",{"2":{"147":2}}],["grpcaddr",{"2":{"597":4}}],["grpc",{"0":{"68":1,"489":1,"493":1,"505":1,"508":1,"597":1},"2":{"65":3,"68":4,"244":2,"245":1,"275":3,"313":2,"422":2,"429":12,"465":2,"475":4,"489":14,"493":9,"505":5,"507":3,"508":14,"597":10,"735":3,"760":1}}],["groundbreaking",{"2":{"479":1}}],["group",{"2":{"36":2,"39":1,"40":1,"41":13,"42":7}}],["groups",{"2":{"34":1,"36":2,"39":5,"41":2}}],["grove",{"0":{"495":1},"2":{"64":2,"485":2,"495":2,"503":2}}],["growth",{"2":{"58":1}}],["grow",{"2":{"44":1}}],["growing",{"2":{"44":1}}],["grep",{"2":{"539":1}}],["grepping",{"2":{"539":1}}],["green",{"2":{"137":1}}],["greet",{"2":{"31":1}}],["greater",{"2":{"197":1,"371":1}}],["greatly",{"2":{"40":1}}],["great",{"2":{"35":1,"457":1}}],["grant",{"0":{"407":1},"2":{"406":1,"407":3,"410":2,"412":3}}],["granting",{"0":{"405":1,"412":1},"1":{"406":1,"407":1,"413":1},"2":{"402":1,"405":1}}],["grantee",{"0":{"408":1},"2":{"403":1,"404":2,"405":5,"407":3,"412":6}}],["granter",{"0":{"407":1,"410":1,"413":1},"1":{"411":1},"2":{"294":2,"403":1,"404":2,"405":5,"408":2,"412":6,"413":1}}],["granted",{"2":{"47":1,"413":1}}],["graphical",{"2":{"278":1}}],["graphics",{"2":{"30":1}}],["grafana",{"2":{"275":3,"277":3,"321":1,"493":1}}],["gravity",{"2":{"221":1}}],["gradients",{"2":{"137":1}}],["grading",{"2":{"22":1}}],["grassroots",{"2":{"43":1}}],["gratitude",{"2":{"37":1,"38":1}}],["gracefully",{"2":{"7":1,"426":1}}],["guru",{"2":{"496":1,"506":2,"507":2,"508":2,"512":1}}],["guardian",{"2":{"202":1,"210":1}}],["guardian=",{"2":{"202":2}}],["guaranteed",{"2":{"650":1,"672":2,"718":1}}],["guaranteeing",{"2":{"648":1}}],["guarantees",{"2":{"221":2,"235":1,"672":1}}],["guarantee",{"2":{"26":1,"68":1,"493":1,"505":1,"637":1,"638":1,"641":1,"643":1,"670":1}}],["guidance",{"0":{"33":1},"1":{"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1}}],["guide",{"0":{"29":1,"346":1,"427":1,"439":1,"555":1,"737":1},"1":{"30":1,"31":1,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"347":1,"348":1,"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"556":1,"557":1,"558":1,"559":1,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"738":1,"739":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1},"2":{"43":1,"50":1,"54":1,"63":2,"74":2,"81":3,"85":1,"93":1,"217":1,"276":1,"280":2,"283":1,"306":1,"310":1,"321":1,"329":1,"338":1,"356":1,"381":1,"402":1,"405":1,"414":1,"427":1,"439":2,"441":1,"442":1,"458":1,"472":1,"478":1,"484":2,"499":2,"531":1,"540":3,"555":2,"556":1,"558":1,"561":1,"566":1,"569":1,"610":1,"697":1,"703":1,"706":1,"707":1,"725":1,"731":2,"774":1,"775":1,"776":1}}],["guidelines",{"0":{"2":1,"11":1,"52":1},"1":{"12":1,"13":1,"14":1,"15":1},"2":{"2":1,"11":1,"16":1,"33":2}}],["guides",{"2":{"0":1,"3":2,"23":2,"33":1,"94":1,"380":1,"499":1,"534":1,"572":1}}],["gi",{"2":{"142":2}}],["git",{"2":{"89":1,"117":1,"203":2,"208":2,"211":2,"214":2,"215":4,"311":7,"341":7,"398":4,"697":3}}],["gitgit",{"2":{"89":1}}],["githubusercontent",{"2":{"361":10,"398":2,"784":1}}],["github",{"0":{"456":1},"2":{"26":2,"89":2,"136":4,"140":18,"143":2,"144":16,"150":6,"156":2,"157":2,"160":2,"161":2,"162":2,"163":24,"202":2,"203":2,"208":2,"211":2,"214":2,"215":2,"280":2,"303":2,"311":2,"326":1,"341":2,"371":4,"383":16,"456":1,"534":1,"584":2,"591":2,"596":6,"597":16,"625":16,"697":2,"707":2,"708":6,"726":1,"731":1,"768":4,"769":8}}],["ginger",{"0":{"528":1},"2":{"73":1,"498":1,"513":1,"528":1,"554":1}}],["given",{"0":{"336":1},"2":{"60":1,"109":1,"146":1,"171":1,"197":1,"202":1,"209":1,"334":2,"336":2,"367":1,"483":1,"550":1,"552":1,"631":1,"644":1,"708":1,"711":3,"760":1,"771":1,"772":2,"777":1,"779":1}}],["gives",{"2":{"39":1,"58":1,"111":1,"184":1,"483":1,"674":1}}],["give",{"2":{"38":1,"391":1,"406":1,"557":2,"572":1}}],["giving",{"2":{"7":1,"34":1,"111":1}}],["gifts",{"2":{"37":1}}],["g",{"2":{"22":1,"32":1,"42":2,"275":1,"338":1,"373":1,"377":2,"403":1,"558":1,"584":1,"586":1,"620":1,"630":1,"644":1,"650":1,"738":1}}],["gem",{"0":{"662":1,"663":1},"1":{"663":1,"664":1,"665":1,"666":1},"2":{"651":1}}],["genutil",{"2":{"715":1}}],["genuine",{"2":{"47":1,"58":1}}],["genuinely",{"2":{"46":1}}],["gentx",{"2":{"260":2,"272":4,"449":5,"450":7}}],["gentxscelestia",{"2":{"450":1}}],["gentxs",{"2":{"260":2,"450":1}}],["gentle",{"2":{"81":1,"82":1,"103":1}}],["genesis",{"0":{"272":1,"447":1,"449":1,"450":1,"679":1},"1":{"680":1},"2":{"160":2,"209":2,"210":4,"260":20,"272":3,"304":1,"314":10,"355":1,"361":7,"369":1,"447":2,"448":3,"449":2,"450":5,"475":1,"530":1,"625":1,"634":1,"671":1,"678":1,"679":2,"680":1,"685":1}}],["generating",{"0":{"698":1},"2":{"168":1,"174":1,"203":1,"217":1,"557":2,"765":2}}],["generation",{"2":{"140":1,"173":1,"648":1}}],["generate",{"2":{"168":1,"199":1,"202":1,"203":1,"211":2,"213":2,"214":4,"215":3,"217":1,"227":1,"233":1,"235":1,"260":2,"272":1,"279":4,"306":1,"632":2,"643":1,"695":1,"698":1,"745":1,"763":1,"766":2}}],["generates",{"2":{"141":1}}],["generated",{"2":{"70":1,"86":4,"124":1,"136":1,"151":1,"175":1,"199":1,"211":1,"214":1,"215":4,"219":2,"245":1,"322":1,"422":1,"446":1,"449":1,"466":1,"467":1,"510":1,"557":2,"566":1,"643":1,"708":2,"736":2,"743":1,"748":1,"765":2,"771":1,"777":2}}],["generally",{"2":{"589":1}}],["generalized",{"2":{"172":1}}],["general",{"2":{"26":1,"197":1,"578":1,"589":1,"641":1,"680":1,"696":1}}],["gender",{"2":{"6":1}}],["geolocation",{"2":{"23":1}}],["getenv",{"2":{"772":2}}],["geteds",{"2":{"711":7,"779":1}}],["getbyheight",{"2":{"711":2,"752":1}}],["getblockdata",{"2":{"126":2,"130":2}}],["getaddress",{"2":{"597":2}}],["getall",{"2":{"596":2,"672":2,"708":3,"710":2,"771":1,"777":1}}],["geth",{"2":{"455":1}}],["getheader",{"2":{"126":4,"130":2}}],["getlatestblock",{"2":{"130":2}}],["getlatestrollupheight",{"2":{"126":2}}],["gets",{"2":{"109":1,"110":1,"137":1,"139":2,"172":1,"214":1,"281":1}}],["getting",{"0":{"115":1,"714":1},"1":{"116":1,"117":1,"118":1},"2":{"24":2,"93":2,"95":1,"203":1,"209":1,"281":1,"627":1,"714":1,"764":1}}],["get",{"0":{"565":1,"750":1,"751":1,"752":1,"754":1},"2":{"1":1,"26":1,"33":1,"36":1,"41":1,"109":1,"110":2,"144":8,"147":1,"161":2,"163":4,"175":2,"204":2,"218":1,"245":1,"265":1,"266":1,"276":1,"281":1,"309":1,"312":1,"331":2,"332":2,"333":2,"338":2,"342":1,"361":1,"371":1,"385":1,"400":1,"405":1,"422":2,"430":1,"465":1,"467":1,"475":3,"476":1,"477":2,"538":2,"544":1,"555":1,"558":2,"563":4,"565":1,"571":1,"577":1,"578":1,"581":1,"586":1,"590":1,"592":1,"597":2,"614":1,"627":1,"682":1,"683":1,"707":3,"711":2,"725":2,"743":1,"745":15,"750":1,"751":1,"752":6,"753":4,"757":1,"758":7,"763":1,"768":4,"770":2,"771":5,"773":4,"774":1,"776":1,"777":2,"778":2,"779":8}}],["ok",{"2":{"778":4}}],["okpajw+kyhnqkq5vch",{"2":{"147":2}}],["oil",{"2":{"291":2}}],["o",{"2":{"214":2,"372":12,"642":1,"643":2}}],["older",{"2":{"208":1,"524":1,"671":1}}],["old",{"2":{"152":1,"153":1,"324":1,"334":1,"635":1}}],["oss",{"2":{"718":1}}],["ostrich",{"2":{"291":2}}],["os|file|kwallet|pass|test|memory",{"2":{"261":1,"303":2}}],["os",{"2":{"143":2,"144":2,"163":2,"274":2,"398":1,"769":2,"770":8,"771":8,"772":2,"773":8}}],["occupied",{"2":{"483":1}}],["occurring",{"2":{"720":1}}],["occurs",{"2":{"628":1}}],["occur",{"2":{"130":1,"266":1,"680":2}}],["occasional",{"2":{"479":1,"547":1}}],["october",{"2":{"27":1,"680":2}}],["omitempty",{"2":{"125":2}}],["owners",{"2":{"93":6}}],["ownership",{"2":{"93":2}}],["owner",{"2":{"86":1,"93":5,"202":3,"204":4,"210":1}}],["own",{"2":{"65":1,"68":1,"86":1,"91":1,"217":1,"221":1,"244":1,"297":1,"301":1,"309":1,"311":1,"352":1,"422":1,"439":1,"445":1,"454":1,"485":1,"493":1,"495":1,"503":1,"540":1,"580":1,"582":1,"584":1,"614":1,"617":1,"644":1,"647":1,"648":1,"672":1,"674":1,"688":1,"689":1,"708":1,"722":1,"761":1,"766":1}}],["ovh",{"2":{"23":1}}],["overpaying",{"2":{"590":1}}],["overpay",{"2":{"588":1}}],["overhead",{"2":{"454":1,"455":1}}],["override",{"2":{"275":2}}],["over",{"0":{"434":1},"2":{"53":1,"54":1,"125":4,"127":1,"128":1,"139":3,"166":1,"167":1,"199":1,"200":1,"211":1,"228":1,"237":1,"306":1,"316":1,"338":1,"341":1,"397":1,"434":2,"557":2,"561":1,"578":1,"672":1,"690":1,"695":2,"726":1,"736":1,"738":1}}],["overview",{"0":{"107":1,"137":1,"238":1,"402":1,"415":1,"459":1,"515":1,"531":1,"669":1,"684":1},"1":{"138":1,"139":1,"532":1,"533":1,"534":1,"685":1,"686":1,"687":1,"688":1,"689":1,"690":1,"691":1,"692":1,"693":1,"694":1},"2":{"21":1,"31":1,"41":1,"53":1,"54":1,"55":1,"64":2,"77":1,"79":1,"81":1,"82":1,"96":1,"103":1,"108":1,"122":2,"321":1,"344":1,"485":2,"503":2,"657":1,"661":1,"669":1,"714":1}}],["overall",{"2":{"7":1,"35":1,"96":1}}],["otel",{"2":{"23":1,"317":2,"318":2,"319":2,"321":3}}],["otherwise",{"2":{"10":1,"91":1,"109":1,"111":1,"149":1,"183":1,"202":1,"208":1,"210":1,"213":1,"266":1,"443":1,"602":1,"743":1,"760":1,"771":1}}],["others",{"2":{"7":1,"210":1,"452":1}}],["other",{"0":{"386":1,"448":1,"720":1},"2":{"3":1,"7":2,"8":1,"12":1,"23":2,"24":1,"26":1,"34":1,"36":5,"37":2,"39":2,"41":1,"42":3,"46":1,"69":1,"86":1,"107":1,"109":1,"120":1,"125":2,"134":1,"136":1,"164":1,"178":1,"197":1,"215":1,"216":1,"226":1,"238":1,"244":1,"252":1,"322":1,"328":1,"338":1,"377":1,"406":1,"422":1,"437":1,"448":2,"449":1,"450":2,"451":2,"452":2,"510":1,"523":1,"540":1,"555":1,"562":1,"581":1,"586":2,"587":1,"590":1,"627":1,"634":1,"637":1,"644":1,"647":2,"672":3,"678":1,"689":1,"698":1,"718":2,"720":1,"722":1,"725":1,"731":1,"735":1}}],["observe",{"2":{"336":1,"540":1}}],["observer",{"2":{"317":2,"318":2,"319":2}}],["observed",{"2":{"199":1}}],["object",{"2":{"90":2,"555":1}}],["objective",{"2":{"26":1}}],["objectives",{"0":{"18":1},"2":{"18":1,"30":1}}],["obtained",{"2":{"209":1,"210":1,"764":1}}],["obtain",{"2":{"38":1,"90":1}}],["obligated",{"2":{"10":1}}],["oprexqlg9er1oey1de4mkwvmjlfnqoocg==",{"2":{"752":2}}],["opqym",{"2":{"292":2,"296":2}}],["op",{"0":{"250":1,"454":1,"540":1},"1":{"455":1,"456":1,"457":1,"541":1,"542":1,"543":1,"544":1,"545":1},"2":{"249":1,"251":1,"259":1,"454":1,"455":10,"457":1,"535":1,"539":1,"540":7,"543":3,"545":1}}],["ops",{"2":{"212":1,"558":2,"559":1}}],["opt",{"2":{"211":1,"337":4,"688":1}}],["opted",{"2":{"202":2}}],["optimize",{"2":{"720":1}}],["optimized",{"2":{"647":1}}],["optimism",{"0":{"535":1},"1":{"536":1,"537":1,"538":1,"539":1},"2":{"250":2,"454":1,"455":2,"456":1,"535":1,"545":1,"680":1}}],["optimised",{"2":{"221":1}}],["optimistically",{"2":{"178":1,"179":1}}],["optimistic",{"0":{"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1},"1":{"179":1,"180":2,"181":2,"182":2,"183":1,"184":2,"185":2},"2":{"127":1,"130":1,"165":1,"171":1,"178":4,"179":1,"182":1,"186":1,"197":1,"227":1}}],["optimally",{"2":{"647":1}}],["optimal",{"2":{"341":1}}],["option",{"0":{"370":1,"371":1,"372":1,"518":1,"519":1},"2":{"107":1,"238":1,"266":2,"275":1,"341":2,"342":1,"350":1,"380":4,"381":1,"566":1,"599":1,"620":1}}],["options",{"0":{"343":1,"380":1,"622":1,"701":1},"2":{"34":2,"35":1,"40":1,"85":1,"216":1,"260":1,"261":1,"264":1,"265":1,"266":2,"274":2,"294":4,"343":1,"371":2,"380":1,"484":1,"499":1,"519":1,"531":1,"565":1,"572":1,"574":1,"580":1,"582":1,"597":6,"622":1,"708":1}}],["optionally",{"2":{"77":1,"79":2,"361":1,"743":1}}],["optional",{"0":{"213":1,"246":1,"247":1,"248":1,"302":1,"303":1,"363":1,"367":1,"375":1,"376":1,"380":1,"381":1,"410":1,"411":1,"412":1,"413":1,"423":1,"424":1,"425":1,"444":1,"448":1,"468":1,"469":1,"470":1,"523":1,"615":1,"619":1,"622":1,"744":1},"1":{"214":1,"215":1,"364":1,"365":1,"377":1,"378":1,"379":1,"411":1,"413":1,"424":1,"469":1,"616":1,"617":1,"618":1,"619":1},"2":{"23":1,"34":1,"39":1,"294":1,"341":1,"361":1,"373":1,"523":1,"625":2,"650":1,"743":10,"783":1,"784":2}}],["opportunities",{"2":{"42":1,"58":1}}],["opportunity",{"2":{"18":1}}],["operating",{"2":{"312":1,"322":1,"337":1,"342":1,"343":1,"388":1}}],["operation",{"2":{"88":1,"322":1}}],["operations",{"2":{"59":1,"245":1,"422":1,"589":1,"649":1,"693":1}}],["operators",{"0":{"339":1},"2":{"321":1,"455":1,"479":1,"524":1,"531":1,"679":1}}],["operator",{"2":{"211":1,"215":1,"217":1,"218":3,"219":1,"273":1,"341":1,"380":1}}],["operates",{"2":{"226":1}}],["operate",{"2":{"109":1,"322":1,"647":1}}],["operated",{"2":{"23":1}}],["openaikey",{"2":{"772":6}}],["openaimkdir",{"2":{"768":1}}],["openai",{"0":{"766":1},"2":{"763":2,"764":1,"766":5,"768":1,"769":4,"772":15,"773":1}}],["opened",{"2":{"435":1}}],["opening",{"2":{"337":2}}],["opentelemetry",{"2":{"320":1,"321":1}}],["openrpcgo",{"2":{"707":1}}],["openrpc",{"2":{"96":1,"596":6,"707":2,"708":6,"724":1,"768":2,"769":6}}],["openssl",{"2":{"91":1}}],["open",{"0":{"337":1,"434":1,"654":1,"659":1,"663":1},"2":{"6":1,"22":1,"25":1,"27":3,"65":3,"68":1,"244":1,"267":2,"274":2,"275":2,"309":1,"313":3,"321":1,"324":1,"326":2,"337":9,"338":1,"390":1,"422":1,"428":1,"451":1,"453":1,"456":1,"465":1,"508":1,"558":1,"561":1,"617":1,"654":1,"704":1,"735":1}}],["opinions",{"2":{"7":1}}],["our",{"0":{"6":1,"7":1},"2":{"6":1,"7":2,"8":1,"9":1,"42":1,"46":2,"47":2,"49":1,"58":2,"73":1,"289":1,"301":2,"308":1,"344":1,"392":1,"399":1,"430":1,"446":1,"556":1,"557":1,"561":1,"743":1,"748":1,"749":1,"765":4,"769":2,"770":2,"771":5,"773":4}}],["outcome",{"2":{"649":1}}],["outsource",{"2":{"580":1}}],["outsourcing",{"2":{"580":1}}],["outside",{"2":{"196":1,"589":1,"637":1,"671":1}}],["outbound",{"2":{"427":1}}],["outbox",{"2":{"100":1,"101":1}}],["output",{"2":{"260":2,"279":6,"287":2,"291":1,"292":1,"294":1,"295":1,"296":1,"297":2,"303":4,"308":1,"311":1,"312":2,"341":1,"343":1,"398":2,"399":1,"409":1,"413":1,"431":1,"434":2,"446":1,"452":2,"464":1,"476":2,"536":1,"537":1,"614":2,"620":1,"743":3,"745":4,"752":2,"758":1,"765":1,"773":1}}],["outputs",{"2":{"214":1,"271":2}}],["outputinfo",{"2":{"76":1,"94":1}}],["outline",{"2":{"124":2,"130":1,"165":1}}],["outlined",{"2":{"22":1,"104":1,"105":1,"130":1,"183":1,"199":1}}],["out",{"0":{"74":1,"78":1},"1":{"75":1,"76":1,"77":1,"78":1,"79":2,"80":2},"2":{"0":1,"30":3,"37":1,"38":1,"39":1,"40":1,"74":2,"94":1,"109":1,"118":2,"121":1,"126":1,"169":1,"174":2,"179":1,"191":1,"194":1,"221":1,"245":1,"274":2,"275":1,"311":1,"321":1,"341":1,"399":1,"439":1,"471":1,"493":1,"499":2,"552":1,"556":1,"567":1,"568":1,"570":1,"571":1,"578":1,"582":1,"592":1,"630":1,"714":1,"727":1,"738":1,"761":1}}],["onto",{"2":{"639":1}}],["onstart",{"2":{"383":2,"625":2}}],["onclick=",{"2":{"782":2}}],["oncall",{"2":{"277":2}}],["onchain",{"0":{"219":1},"2":{"111":1,"112":1,"202":1,"203":2,"211":1,"213":1,"215":2,"221":2,"229":1,"234":1,"455":1,"581":1,"620":1,"628":1,"680":1}}],["once",{"2":{"24":1,"87":1,"90":1,"109":1,"128":1,"187":1,"194":1,"210":1,"245":1,"275":2,"294":1,"371":1,"404":1,"422":1,"426":1,"448":1,"450":2,"466":1,"475":1,"525":1,"556":1,"557":1,"559":1,"561":1,"562":1,"577":1,"599":1,"630":1,"637":1,"649":1,"670":1,"671":2,"672":1,"695":1,"736":1,"738":1,"766":1}}],["only",{"2":{"91":3,"96":2,"109":2,"110":3,"111":1,"130":2,"149":1,"166":1,"169":1,"172":1,"175":1,"180":1,"205":1,"206":2,"214":1,"227":1,"267":1,"279":2,"291":2,"308":1,"313":1,"328":1,"361":1,"373":1,"396":1,"426":1,"439":1,"493":1,"509":1,"581":1,"582":1,"586":1,"590":1,"597":2,"620":2,"632":1,"634":1,"637":1,"640":1,"641":1,"642":1,"643":2,"644":2,"646":1,"647":3,"648":2,"649":2,"671":2,"672":1,"698":1,"715":1,"717":1,"726":1,"731":1,"741":1,"771":1}}],["online",{"2":{"9":1,"31":1,"38":1,"39":1,"602":2,"604":2,"605":2,"606":2}}],["onboarding",{"0":{"42":1}}],["onecelestia",{"2":{"559":1}}],["oneexport",{"2":{"405":1}}],["ones",{"2":{"169":1,"187":1,"213":1,"432":1,"435":1}}],["onestepproofentry",{"2":{"100":1,"101":1}}],["onestepproverhostio",{"2":{"100":1,"101":1}}],["onestepprovermath",{"2":{"100":1,"101":1}}],["onestepprovermemory",{"2":{"100":1,"101":1}}],["onestepprover0",{"2":{"100":1,"101":1}}],["one",{"0":{"592":1},"2":{"39":1,"40":1,"41":1,"42":1,"74":2,"90":1,"91":1,"104":1,"107":1,"109":1,"110":1,"134":1,"152":1,"153":1,"166":1,"169":1,"178":1,"184":1,"187":1,"191":3,"199":1,"208":1,"210":1,"212":1,"214":1,"216":2,"228":1,"231":1,"244":1,"245":2,"260":4,"265":5,"266":3,"275":3,"287":1,"289":1,"290":2,"299":1,"301":2,"303":2,"328":1,"329":2,"336":1,"342":1,"355":2,"403":3,"404":1,"405":2,"412":2,"413":2,"415":1,"422":1,"427":2,"429":2,"450":1,"465":4,"466":2,"483":2,"487":1,"488":1,"489":1,"493":1,"505":1,"507":1,"508":1,"526":1,"528":1,"558":4,"559":3,"563":1,"578":1,"580":1,"581":1,"582":1,"585":1,"586":1,"589":1,"592":1,"615":1,"617":1,"631":1,"643":2,"644":1,"647":2,"649":2,"650":2,"698":1,"704":2,"705":2,"731":1,"735":2,"769":2,"772":1,"774":1,"784":2}}],["onwards",{"2":{"22":1,"163":2}}],["on",{"0":{"140":1,"251":1,"281":1,"290":1,"301":1,"368":1,"378":1,"531":1,"538":1,"573":1,"674":1,"681":1,"742":1},"1":{"141":1,"142":1,"143":1,"144":1,"145":1,"146":1,"147":1,"148":1,"149":1,"150":1,"151":1,"152":1,"153":1,"252":1,"253":1,"254":1,"255":1,"256":1,"257":1,"258":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"532":1,"533":1,"534":1,"574":1,"575":1,"576":1,"682":1,"683":1},"2":{"3":2,"7":2,"22":2,"23":5,"26":5,"30":1,"33":1,"34":3,"35":2,"37":2,"38":1,"39":4,"40":5,"41":1,"42":1,"47":1,"53":1,"54":1,"55":2,"58":1,"59":3,"60":2,"63":1,"65":2,"68":1,"70":2,"76":1,"77":2,"79":3,"81":1,"82":2,"84":1,"86":10,"87":2,"88":1,"90":1,"91":5,"92":1,"93":51,"97":1,"107":1,"109":3,"110":1,"111":4,"112":3,"120":1,"124":2,"126":6,"128":1,"136":1,"137":1,"139":2,"163":1,"165":1,"167":1,"168":3,"169":1,"170":1,"171":2,"174":2,"175":2,"178":1,"180":1,"182":1,"202":2,"204":1,"214":3,"215":4,"216":2,"218":1,"219":1,"221":2,"224":2,"225":4,"226":2,"227":5,"228":2,"230":1,"231":8,"234":1,"238":2,"240":1,"244":4,"245":4,"248":1,"249":1,"250":2,"251":1,"261":1,"266":3,"267":1,"272":1,"274":2,"275":9,"276":1,"277":2,"280":1,"281":1,"282":2,"283":1,"289":3,"297":2,"298":2,"301":2,"302":1,"305":2,"309":2,"311":2,"312":2,"313":4,"315":1,"321":3,"322":1,"324":2,"326":5,"329":1,"331":1,"341":1,"342":1,"343":1,"356":1,"358":1,"359":1,"360":1,"366":1,"368":1,"369":1,"370":1,"371":2,"373":1,"377":3,"380":4,"381":1,"383":1,"386":1,"388":1,"390":3,"391":5,"396":1,"398":1,"400":4,"402":1,"403":1,"406":1,"412":1,"417":1,"422":4,"427":3,"429":2,"438":1,"453":2,"454":1,"455":6,"456":1,"458":1,"459":1,"461":1,"462":2,"465":3,"470":1,"471":1,"473":1,"483":3,"484":1,"485":2,"487":2,"493":1,"494":1,"495":2,"498":1,"499":7,"503":2,"506":1,"510":2,"513":1,"522":1,"524":1,"526":3,"531":3,"534":1,"535":1,"536":1,"537":1,"540":4,"542":1,"543":3,"544":1,"550":3,"552":3,"555":2,"562":3,"572":2,"574":1,"576":1,"578":2,"582":1,"584":1,"586":3,"589":3,"590":6,"596":2,"597":2,"599":4,"607":1,"609":1,"610":1,"612":2,"613":1,"617":2,"619":1,"620":2,"625":2,"628":1,"630":1,"631":1,"639":1,"640":1,"641":1,"642":1,"644":1,"646":2,"647":3,"650":1,"651":2,"656":1,"660":1,"668":1,"669":3,"671":2,"672":6,"674":3,"675":1,"677":2,"680":2,"687":2,"688":2,"690":1,"695":1,"698":1,"703":2,"704":4,"705":1,"708":2,"714":1,"716":1,"718":1,"720":1,"722":2,"726":1,"731":1,"734":1,"735":2,"736":3,"740":3,"741":1,"745":1,"746":1,"760":1,"763":2,"765":1,"769":1}}],["oracle",{"0":{"110":1},"2":{"108":1,"110":3,"120":1}}],["originate",{"2":{"607":1}}],["originally",{"2":{"329":1,"588":1}}],["original",{"2":{"81":1,"174":1,"221":1,"295":2,"592":1,"641":1,"643":3,"644":1,"649":2,"650":1}}],["origin",{"2":{"79":1,"299":4,"300":1,"609":1}}],["orientation",{"2":{"6":1}}],["orbitsetupscriptconfig",{"2":{"88":1,"89":1}}],["orbit",{"0":{"74":1,"77":1,"81":1,"86":1,"87":1},"1":{"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"93":1,"94":1,"95":1,"96":1,"97":1,"98":1,"99":1,"100":1,"101":1},"2":{"74":2,"76":2,"81":5,"82":2,"83":1,"84":2,"85":1,"86":8,"87":7,"89":5,"91":1,"92":1,"93":28,"94":1,"96":4,"97":1,"103":3,"107":4,"108":1,"110":1}}],["ordered",{"2":{"328":2,"644":1,"647":2}}],["order",{"0":{"336":1},"2":{"35":1,"37":1,"63":1,"65":1,"90":1,"109":1,"110":2,"136":1,"139":1,"174":1,"175":1,"246":1,"336":2,"348":1,"392":1,"422":1,"423":1,"426":1,"448":1,"465":1,"468":1,"484":2,"505":1,"542":1,"577":1,"586":1,"588":1,"620":1,"642":1,"647":1,"670":1,"672":1,"739":1,"740":1,"741":1,"750":1,"751":1,"760":1,"766":1}}],["ordering",{"2":{"35":1,"434":2,"578":1,"648":1}}],["organizing",{"2":{"33":1,"36":2,"41":2,"46":1,"50":1,"57":1}}],["organizers",{"2":{"34":1,"37":1,"38":1,"42":2,"43":1,"44":2,"46":1,"47":1,"49":1,"50":2,"58":1}}],["organizer",{"2":{"33":1,"37":1,"41":4,"50":1,"57":1,"58":1}}],["organize",{"2":{"29":2,"36":1,"37":1}}],["organization",{"2":{"26":1}}],["org",{"0":{"5":1,"46":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1},"2":{"6":1,"10":1,"16":3,"24":1,"40":1,"41":2,"46":1,"57":1,"86":1,"312":2,"343":4,"399":8,"487":2,"488":2,"489":2,"490":1,"506":1,"507":1,"508":1,"556":2,"597":4}}],["or",{"0":{"102":1,"302":1,"544":1,"742":1},"1":{"103":1,"104":1,"105":1},"2":{"2":1,"4":1,"6":2,"7":8,"8":2,"9":2,"10":1,"12":2,"13":2,"14":2,"15":2,"22":1,"23":7,"24":4,"26":3,"30":3,"31":4,"32":1,"34":4,"35":3,"36":3,"37":5,"38":4,"39":3,"40":2,"41":1,"42":2,"58":1,"59":1,"65":1,"67":1,"68":3,"69":1,"84":1,"85":1,"86":3,"91":2,"93":5,"94":1,"96":1,"104":1,"107":1,"112":2,"122":1,"124":1,"126":1,"127":1,"130":2,"134":2,"136":1,"137":2,"139":1,"160":1,"165":1,"169":1,"174":1,"186":1,"203":2,"204":1,"205":1,"208":1,"211":3,"213":1,"215":1,"224":2,"225":1,"227":1,"238":1,"244":3,"260":4,"261":1,"272":1,"275":6,"277":3,"278":1,"281":2,"301":1,"302":2,"309":1,"320":2,"334":2,"338":4,"343":1,"361":1,"368":1,"371":1,"377":1,"386":1,"388":1,"389":1,"390":2,"392":1,"400":5,"422":3,"435":1,"439":1,"449":1,"452":1,"465":2,"466":1,"479":2,"483":1,"485":1,"492":1,"493":3,"495":1,"503":1,"504":1,"505":1,"507":1,"510":1,"524":1,"534":2,"547":1,"556":1,"558":1,"562":1,"578":2,"580":1,"581":1,"582":3,"585":1,"588":1,"589":1,"592":1,"597":4,"601":1,"607":2,"608":1,"609":1,"617":2,"628":2,"634":1,"638":1,"643":1,"647":1,"650":1,"657":1,"661":1,"666":1,"668":1,"672":2,"674":1,"680":2,"688":1,"693":1,"696":1,"697":1,"698":3,"705":1,"717":1,"726":2,"734":1,"735":2,"736":2,"738":1,"739":1,"742":2,"743":1,"760":2,"764":1}}],["often",{"2":{"34":1,"36":1,"37":1,"39":1,"524":1,"588":1,"590":1}}],["offloads",{"2":{"577":1}}],["offline",{"2":{"9":1,"281":1}}],["off",{"2":{"219":1,"275":1,"771":1}}],["offchain",{"2":{"81":2,"93":1,"226":1,"229":1,"628":1}}],["offense",{"2":{"281":1}}],["offensive",{"2":{"8":1}}],["offers",{"2":{"51":1,"85":1,"221":1,"226":1,"251":1}}],["offered",{"2":{"36":1}}],["offering",{"2":{"35":1,"107":1}}],["offer",{"2":{"34":4,"35":1,"37":1,"38":2,"226":1}}],["officially",{"2":{"9":1}}],["official",{"2":{"0":1,"9":2,"91":1}}],["of",{"0":{"5":1,"18":1,"46":1,"74":1,"137":1,"144":1,"172":1,"173":1,"174":1,"175":2,"176":1,"177":1,"179":1,"180":1,"181":1,"182":1,"187":1,"188":1,"189":1,"222":1,"225":1,"232":1,"238":1,"288":1,"297":1,"327":1,"415":1,"459":1,"579":1,"580":1,"631":1,"637":1,"639":1,"643":1,"649":1,"664":1,"674":1,"684":1,"686":1,"689":1,"749":1,"755":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"75":1,"76":1,"77":1,"78":1,"79":1,"80":1,"138":1,"139":1,"173":1,"174":1,"175":1,"176":1,"177":1,"180":1,"181":1,"182":1,"188":1,"189":1,"233":1,"234":1,"235":1,"236":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"580":1,"581":1,"582":1,"650":1,"685":1,"686":1,"687":2,"688":2,"689":2,"690":2,"691":2,"692":2,"693":2,"694":2},"2":{"0":1,"2":1,"6":2,"7":6,"8":2,"9":2,"10":3,"11":2,"12":3,"13":3,"14":4,"15":6,"16":4,"18":3,"20":1,"21":3,"22":5,"23":7,"24":1,"25":2,"26":3,"27":1,"30":2,"31":1,"32":1,"33":3,"34":3,"35":1,"36":8,"37":5,"38":6,"39":1,"40":2,"41":5,"42":4,"43":1,"44":1,"46":5,"47":2,"49":1,"50":2,"53":2,"54":1,"55":1,"56":1,"58":7,"63":1,"65":2,"68":1,"69":2,"70":1,"74":3,"76":1,"77":3,"79":1,"80":1,"81":3,"84":2,"86":6,"87":3,"89":2,"90":1,"91":3,"92":1,"93":5,"94":3,"96":1,"104":1,"107":1,"108":2,"109":8,"110":2,"111":2,"112":2,"119":3,"122":5,"125":28,"126":10,"127":3,"128":2,"130":8,"134":2,"136":1,"137":4,"139":11,"140":2,"141":2,"142":1,"145":3,"149":1,"150":3,"151":4,"152":3,"153":2,"154":8,"155":1,"156":12,"157":2,"158":1,"159":10,"160":10,"161":4,"162":2,"163":10,"164":1,"165":1,"166":1,"168":2,"169":4,"170":2,"171":1,"172":9,"173":1,"174":10,"175":20,"176":2,"178":2,"179":6,"180":1,"182":2,"183":10,"185":2,"186":1,"187":9,"188":1,"191":4,"194":4,"196":1,"197":3,"199":6,"201":1,"202":12,"203":2,"204":13,"205":2,"206":2,"208":3,"210":6,"211":8,"214":2,"215":2,"216":1,"217":1,"218":1,"219":1,"221":6,"222":1,"224":2,"225":1,"226":3,"227":5,"228":1,"233":1,"236":1,"238":3,"244":3,"245":1,"246":7,"250":2,"255":1,"259":2,"266":3,"267":1,"273":1,"274":4,"275":2,"276":1,"277":1,"278":1,"279":2,"281":7,"282":1,"287":2,"288":1,"289":1,"294":1,"297":3,"298":2,"299":4,"302":2,"309":1,"311":2,"320":1,"321":2,"322":3,"324":1,"328":3,"329":1,"336":1,"337":1,"338":3,"341":2,"342":1,"344":1,"349":2,"352":1,"353":1,"355":1,"361":2,"365":1,"367":1,"368":3,"369":1,"370":2,"371":1,"381":4,"388":1,"389":2,"390":1,"396":1,"399":2,"400":3,"405":1,"408":2,"422":3,"423":7,"427":2,"428":2,"430":1,"446":3,"450":2,"451":2,"453":1,"455":2,"457":1,"459":1,"464":1,"465":2,"468":7,"478":3,"482":1,"483":2,"484":4,"493":2,"494":1,"499":5,"505":1,"510":3,"523":1,"524":2,"525":3,"526":2,"528":2,"530":1,"531":1,"536":1,"544":2,"547":2,"556":2,"559":4,"561":2,"562":3,"563":3,"566":1,"572":1,"577":1,"578":6,"580":7,"581":6,"582":3,"583":1,"584":2,"585":1,"587":2,"588":5,"589":10,"590":8,"591":3,"592":3,"597":4,"599":1,"604":1,"605":1,"607":2,"608":1,"609":1,"614":2,"615":1,"617":2,"620":5,"623":1,"625":1,"627":2,"628":4,"630":3,"631":3,"632":1,"633":1,"634":2,"636":2,"637":4,"638":2,"639":1,"640":2,"641":5,"642":5,"643":8,"644":7,"646":7,"647":11,"648":4,"649":15,"650":4,"651":1,"655":1,"656":1,"660":1,"664":1,"668":3,"669":2,"670":3,"671":6,"672":4,"674":5,"675":3,"677":2,"678":1,"679":4,"680":6,"681":2,"685":1,"687":1,"688":2,"689":3,"690":2,"695":1,"697":2,"698":1,"703":1,"704":1,"707":1,"708":3,"710":5,"711":2,"712":1,"715":1,"718":1,"720":2,"722":3,"724":1,"731":1,"735":1,"737":1,"738":1,"739":2,"740":2,"742":1,"743":8,"745":3,"746":3,"748":1,"749":4,"752":2,"755":3,"758":1,"763":2,"765":1,"773":2,"776":1,"777":3,"778":3,"779":2,"780":1,"783":1,"784":1}}],["m",{"2":{"497":1,"543":2,"682":1}}],["mzonder",{"2":{"488":1}}],["mb",{"2":{"460":1,"533":1,"732":1}}],["my",{"2":{"391":5,"392":8,"393":8,"466":6,"515":1,"542":1,"557":2,"705":4,"765":2}}],["myrollup",{"2":{"118":2}}],["mnemonic",{"2":{"291":3,"308":1,"430":4,"557":4,"700":2,"765":2}}],["mv",{"2":{"215":2}}],["mkdir",{"2":{"214":2,"215":2,"372":6,"391":2}}],["md013",{"2":{"752":2}}],["md",{"2":{"160":2}}],["mtgbzqhrqol61okkzmhrfyq5bk6goklgwrvparpyxve=",{"2":{"147":2}}],["msgsend",{"2":{"412":2}}],["msgsubmitproposal",{"2":{"266":2}}],["msgcreatevestingaccount",{"2":{"294":2}}],["msgpayforblobs",{"2":{"147":2,"167":1,"412":2,"585":1,"590":2,"730":2}}],["msg",{"2":{"147":2,"266":1,"429":4,"649":1,"772":4}}],["mut",{"2":{"778":2}}],["mutual",{"0":{"353":1}}],["mutually",{"2":{"36":1}}],["multiaddress",{"2":{"605":1}}],["multiaddresses",{"2":{"352":1}}],["multiaccounts",{"0":{"514":1},"1":{"515":1,"516":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1}}],["multi",{"2":{"280":1}}],["multiplies",{"2":{"590":1}}],["multiplier",{"2":{"429":4}}],["multiple",{"0":{"592":1},"2":{"37":1,"72":1,"105":1,"122":1,"139":1,"150":1,"151":3,"154":8,"156":4,"172":2,"275":1,"328":1,"339":1,"496":1,"581":1,"630":1,"633":1,"638":1,"641":1,"644":1,"647":2,"649":1,"731":1}}],["multiproof",{"2":{"156":2}}],["multisign",{"2":{"279":2}}],["multisig",{"0":{"278":1},"1":{"279":1,"280":1},"2":{"86":1,"235":1,"278":3,"279":18,"280":3}}],["mustnewv0",{"2":{"597":2}}],["must",{"2":{"86":2,"91":1,"246":2,"266":1,"334":4,"366":1,"371":1,"387":1,"399":1,"422":1,"423":2,"443":1,"444":1,"445":1,"450":2,"465":1,"468":2,"483":1,"520":1,"542":2,"544":1,"588":1,"592":3,"620":1,"640":1,"642":1,"644":3,"647":2,"707":1,"776":1}}],["much",{"2":{"35":1,"91":1,"449":1,"578":1,"580":1,"581":1}}],["microtia",{"0":{"694":1},"2":{"694":1}}],["micro",{"2":{"693":1}}],["microphone",{"2":{"34":2}}],["microphones",{"2":{"30":1,"34":1}}],["mixhash",{"2":{"536":2}}],["milestone",{"2":{"499":1}}],["million",{"2":{"271":2}}],["mib",{"2":{"483":1,"586":3}}],["middleware",{"2":{"438":1}}],["mirrors",{"2":{"251":1}}],["migrate",{"0":{"247":1,"424":1,"469":1},"2":{"247":1,"260":4,"424":1,"469":1}}],["might",{"2":{"34":3,"171":1,"266":1,"337":1,"361":1,"367":1,"493":1,"550":1,"578":1,"643":1,"735":1,"738":1}}],["mint",{"2":{"715":1}}],["mintscan",{"2":{"496":1,"512":1,"784":1}}],["minor",{"2":{"715":1}}],["minority",{"2":{"266":1}}],["miner",{"2":{"536":2}}],["mined",{"2":{"93":4}}],["mins",{"2":{"211":1}}],["minns",{"2":{"156":2,"163":2}}],["minnamespace",{"2":{"156":4,"163":4}}],["min",{"2":{"156":4,"272":2,"365":1,"368":4,"429":4,"620":3}}],["minimized",{"2":{"640":1}}],["minimal",{"2":{"118":1,"180":1,"341":1,"454":1,"479":1,"715":1}}],["minimum",{"0":{"357":1},"2":{"23":1,"86":1,"93":4,"117":1,"156":2,"239":2,"357":1,"416":2,"460":2,"577":1,"588":1,"611":1,"631":1,"732":2}}],["minutes",{"2":{"37":1,"109":1,"211":1,"214":1,"215":1,"217":1,"371":1,"558":1}}],["minute",{"0":{"395":1},"2":{"35":1,"42":1,"281":1,"592":1}}],["mind",{"2":{"35":1,"361":1,"620":1,"698":2}}],["mindful",{"2":{"35":1}}],["mismatch",{"2":{"643":1}}],["misbehaviour",{"2":{"429":2}}],["misuse",{"2":{"91":1}}],["mission",{"2":{"18":1}}],["mistakes",{"2":{"7":1}}],["mock",{"2":{"540":1,"543":1}}],["mocharesturl",{"2":{"782":2}}],["mocharpcurl",{"2":{"782":2}}],["mochadocker",{"2":{"704":1}}],["mochamainnet",{"2":{"542":1}}],["mocha4",{"2":{"505":1,"506":1,"508":1}}],["mochachainid",{"2":{"325":1,"361":8,"372":2,"542":2,"557":8,"558":1,"559":2,"569":1,"614":2,"620":2,"741":3,"782":2}}],["mochacelestia",{"2":{"91":1,"244":1,"245":1,"246":1,"265":1,"318":1,"329":1,"335":1,"421":1,"423":1,"464":1,"465":1,"466":1,"468":1,"557":1,"565":1,"734":1,"735":2,"736":1}}],["mochaversions",{"2":{"311":2,"341":2,"390":2,"392":2,"393":2,"556":2,"559":2,"704":2}}],["mocha",{"0":{"91":1,"298":1,"301":1,"318":1,"331":1,"332":1,"499":1,"510":1,"543":1,"544":1,"552":1,"553":1,"683":1},"1":{"299":1,"300":1,"301":1,"302":1,"303":1,"500":1,"501":1,"502":1,"503":1,"504":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1},"2":{"23":3,"26":1,"27":1,"59":2,"60":2,"81":1,"82":2,"91":7,"97":1,"109":1,"136":2,"231":3,"244":2,"245":6,"246":1,"250":2,"265":5,"283":1,"289":1,"297":1,"298":2,"301":7,"303":4,"305":1,"309":1,"318":4,"325":2,"328":1,"329":7,"331":2,"332":2,"335":1,"338":1,"361":1,"371":2,"390":1,"402":1,"403":3,"405":2,"407":2,"412":5,"413":2,"421":1,"422":3,"423":1,"427":1,"429":9,"430":2,"432":1,"433":6,"434":6,"435":3,"464":1,"465":4,"466":3,"467":1,"468":1,"499":7,"505":6,"506":5,"507":6,"508":11,"509":16,"510":2,"511":1,"512":2,"513":2,"526":1,"530":2,"540":4,"542":2,"543":1,"552":4,"554":1,"555":1,"556":1,"557":4,"558":4,"559":6,"561":1,"563":1,"565":1,"607":1,"617":1,"620":1,"683":3,"698":3,"704":4,"705":8,"734":1,"735":5,"736":3,"782":6,"784":5}}],["mounted",{"2":{"705":1}}],["mounting",{"0":{"705":1},"2":{"391":1,"705":1}}],["mount",{"2":{"391":2,"392":1,"396":1,"542":1,"704":1,"705":1}}],["moment",{"2":{"180":1,"183":1,"321":1}}],["moved",{"2":{"450":1,"647":1}}],["move",{"2":{"77":2,"79":1,"89":1,"736":1}}],["moniker",{"2":{"620":3}}],["moniker=$moniker",{"2":{"272":2,"620":2}}],["moniker=validator",{"2":{"272":2}}],["monitors",{"2":{"282":1}}],["monitor",{"0":{"282":1},"2":{"275":4,"282":1,"321":1,"608":1,"609":1}}],["monitoring",{"0":{"608":1},"2":{"23":1,"26":1,"273":1,"277":1,"398":1}}],["monolithic",{"0":{"647":1},"2":{"53":1,"455":1,"578":2,"647":3,"714":1}}],["monthly",{"2":{"36":1,"48":1}}],["month",{"2":{"23":1,"25":1}}],["months",{"2":{"21":1,"22":6,"23":1,"25":1,"26":1,"166":1,"168":1}}],["more",{"0":{"131":1},"1":{"132":1,"133":1,"134":1},"2":{"20":1,"24":1,"34":1,"35":1,"36":1,"38":1,"73":1,"79":1,"81":3,"86":3,"87":1,"92":1,"94":1,"107":1,"110":1,"112":1,"125":2,"126":2,"127":2,"136":1,"137":2,"139":1,"142":1,"147":1,"152":1,"163":2,"168":1,"169":1,"174":1,"175":2,"182":1,"190":1,"194":1,"196":1,"199":2,"210":1,"212":1,"226":2,"227":1,"230":1,"233":1,"234":2,"235":1,"236":1,"245":1,"250":1,"251":1,"261":1,"266":1,"277":1,"281":3,"290":1,"291":1,"301":1,"303":2,"304":1,"311":1,"312":2,"326":1,"337":1,"341":1,"343":1,"371":1,"388":1,"404":1,"422":1,"455":1,"494":1,"495":1,"498":1,"513":1,"522":1,"528":1,"531":1,"544":1,"545":1,"554":1,"558":1,"562":1,"564":1,"565":1,"578":1,"581":3,"582":1,"585":1,"586":1,"590":1,"591":1,"595":1,"596":1,"598":1,"614":2,"627":1,"630":1,"631":1,"641":1,"642":3,"644":1,"646":3,"648":1,"650":1,"677":1,"690":1,"698":1,"704":1,"716":1,"725":1,"726":1,"727":1,"730":1,"731":2,"736":1,"738":2,"745":1,"746":1,"772":1,"774":1}}],["modifying",{"2":{"451":1}}],["modify",{"0":{"451":1},"2":{"337":1,"451":1,"544":1,"738":1}}],["modifications",{"2":{"715":1}}],["modifiable",{"2":{"266":1}}],["modified",{"2":{"238":1,"250":1,"644":1,"646":1,"720":1}}],["moduleencodingregisters",{"2":{"597":2}}],["modules",{"2":{"589":1,"715":2,"768":1}}],["module=consensus",{"2":{"383":2,"625":2}}],["module",{"0":{"401":1,"406":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":1,"412":1,"413":1},"2":{"266":4,"281":1,"402":1,"404":1,"413":1,"437":1,"438":1,"523":2,"591":1,"738":5,"741":2,"757":2,"782":2}}],["modularity",{"0":{"53":1},"2":{"42":1,"53":1}}],["modular",{"0":{"29":1,"42":1,"43":1,"51":1,"56":1,"220":1,"578":1,"579":1,"647":1},"1":{"30":1,"31":1,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1,"52":1,"53":1,"54":1,"55":1,"56":1,"57":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1,"580":1,"581":1,"582":1},"2":{"18":1,"29":2,"33":1,"34":1,"35":2,"36":3,"37":4,"39":1,"40":1,"41":2,"42":2,"43":2,"44":2,"47":3,"48":1,"50":2,"51":2,"53":4,"56":3,"57":1,"58":9,"227":1,"454":1,"496":1,"572":2,"578":4,"580":2,"581":2,"582":1,"627":1,"647":3,"648":2,"687":1,"688":1,"714":2,"773":2}}],["mod",{"2":{"140":3,"287":2,"383":14,"427":1,"625":14,"768":2}}],["model",{"2":{"590":1,"690":1,"772":2}}],["modern",{"2":{"508":1}}],["moderation",{"2":{"8":1}}],["mode=",{"2":{"279":2}}],["mode",{"2":{"76":2,"211":2,"279":4,"303":4,"369":1,"412":2,"429":12,"688":1}}],["mozilla",{"2":{"16":1}}],["mostly",{"2":{"422":1}}],["most",{"2":{"0":1,"37":1,"42":5,"44":1,"90":1,"199":1,"349":1,"370":1,"388":1,"459":1,"629":1,"637":1,"706":1,"718":1,"775":1}}],["mesa",{"2":{"488":1,"489":1,"505":1,"506":1,"508":1}}],["messages",{"2":{"30":1,"32":1,"190":1,"266":2,"294":2,"412":2,"525":1,"715":1,"763":1,"772":2}}],["message",{"2":{"2":1,"41":3,"109":1,"112":1,"147":2,"304":1,"309":1,"590":1,"649":2,"745":1,"772":4,"773":2,"774":1}}],["me",{"2":{"378":2,"452":2,"506":1,"507":1,"508":1}}],["met",{"2":{"588":1}}],["metric",{"2":{"316":1}}],["metricscurl",{"2":{"274":1}}],["metrics",{"0":{"273":1,"315":1,"316":1,"321":1},"1":{"274":1,"275":1,"276":1,"277":1,"316":1,"317":2,"318":2,"319":2,"320":2,"321":1},"2":{"273":3,"274":8,"275":3,"276":2,"315":2,"316":12,"317":6,"318":6,"319":6,"320":15,"321":2,"428":1}}],["meta",{"2":{"526":1}}],["metadata",{"2":{"160":2,"459":1,"569":1,"581":1,"650":1}}],["metamask",{"2":{"82":1}}],["methods",{"2":{"525":1,"598":1,"672":1,"707":2,"712":1,"738":1,"776":2,"780":1}}],["method",{"2":{"120":1,"122":2,"153":2,"157":1,"166":1,"174":1,"210":1,"233":1,"455":1,"538":2,"672":3,"708":2,"709":2,"710":2,"711":2,"719":1,"738":5,"741":2,"757":3,"758":1,"760":2,"777":2,"778":2,"779":2,"782":2}}],["mechanisms",{"2":{"87":1,"112":1,"130":1,"589":1,"590":1}}],["mechanism",{"0":{"112":1,"225":1},"2":{"87":1,"108":2,"112":4,"164":1,"199":1,"227":1,"277":1,"281":1,"370":1,"400":2,"525":1,"528":1,"629":1,"630":1,"640":1,"672":1,"674":1,"681":1}}],["measured",{"2":{"86":1}}],["meaningful",{"2":{"720":1}}],["meaning",{"2":{"168":2,"238":1,"372":1,"720":1}}],["mean",{"2":{"126":2}}],["meant",{"2":{"64":1,"485":1,"503":1,"726":1}}],["means",{"2":{"21":1,"139":1,"199":1,"205":1,"338":1,"377":2,"387":1,"388":1,"523":1,"558":1,"562":1,"581":2,"586":1,"588":1,"592":1,"642":2,"647":2,"651":1,"669":1,"671":1,"715":1,"734":1}}],["menu",{"0":{"348":1},"2":{"76":1,"301":1,"311":1,"312":1,"540":1,"556":1,"757":2,"784":1}}],["mentioned",{"2":{"104":1,"505":1}}],["mention",{"2":{"38":2}}],["mempool",{"0":{"587":1},"1":{"588":1,"589":1,"590":1,"591":1,"592":1},"2":{"400":1,"586":1,"587":2,"588":2,"592":2,"597":2,"669":1}}],["memo",{"2":{"294":2,"429":4}}],["memory",{"2":{"127":1,"163":2,"239":1,"276":1,"357":1,"416":1,"460":1,"533":1,"534":1,"611":1,"732":1}}],["memorable",{"2":{"58":1,"86":1}}],["member",{"2":{"41":1}}],["members",{"0":{"42":1},"2":{"6":1,"22":1,"30":1,"39":3,"41":2,"42":2,"225":1,"267":1,"592":1,"679":1}}],["merge",{"2":{"322":1,"334":1}}],["merkelized",{"2":{"668":1}}],["merkelizes",{"2":{"227":1}}],["merkleized",{"2":{"119":1,"139":1}}],["merkle",{"0":{"194":1,"195":1,"196":1,"644":1},"1":{"195":1,"196":1},"2":{"110":1,"119":4,"120":1,"122":1,"127":1,"139":3,"141":2,"144":4,"145":3,"151":1,"154":2,"156":4,"159":4,"160":4,"163":8,"168":6,"174":2,"175":5,"188":1,"190":1,"196":1,"225":1,"227":2,"640":1,"641":6,"642":1,"643":2,"644":2,"646":2,"649":4,"650":3,"731":1}}],["merchandise",{"2":{"57":2}}],["merely",{"2":{"26":1}}],["mev",{"2":{"42":1}}],["meetups",{"2":{"32":1,"34":4,"36":5,"37":1,"38":1,"39":1,"40":4,"41":6,"42":2,"43":1,"51":3,"57":2,"58":1}}],["meetup",{"0":{"29":1,"30":1,"31":1,"32":1,"41":1,"42":1,"43":1,"51":1,"56":1},"1":{"30":1,"31":1,"32":1,"33":1,"34":1,"35":1,"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1,"52":1,"53":1,"54":1,"55":1,"56":1,"57":1},"2":{"29":2,"30":2,"32":1,"33":3,"34":4,"35":2,"36":7,"37":9,"38":5,"39":8,"40":4,"41":10,"42":5,"43":1,"44":4,"46":1,"47":2,"48":1,"50":4,"56":2,"57":1,"58":6}}],["meet",{"2":{"21":1}}],["media",{"2":{"3":1,"9":1,"13":1,"30":1,"32":1,"39":4,"40":1}}],["magnitude",{"2":{"720":1}}],["macos",{"2":{"543":2}}],["mac",{"2":{"389":1,"391":1,"399":2}}],["machines",{"2":{"275":1,"377":1,"647":1}}],["machine",{"2":{"2":1,"82":1,"211":2,"214":1,"215":1,"217":1,"238":1,"240":1,"244":1,"251":1,"275":1,"289":2,"309":1,"313":1,"324":1,"326":1,"358":1,"388":1,"390":1,"391":3,"417":1,"422":1,"437":1,"453":1,"462":1,"465":1,"588":1,"590":1,"612":1,"617":1,"646":3,"647":1,"649":2,"703":1,"704":1,"734":1,"735":1,"765":1}}],["majority",{"2":{"643":1}}],["major",{"2":{"175":1,"646":1}}],["master",{"2":{"160":2,"361":10,"784":1}}],["malicious",{"2":{"130":1,"208":2,"281":1,"643":1}}],["mapping",{"2":{"110":1,"156":2,"159":1,"322":2,"584":1}}],["matters",{"2":{"174":1}}],["math",{"2":{"144":2,"163":2}}],["matching",{"2":{"584":1}}],["match",{"2":{"125":1,"140":1,"778":4}}],["matches",{"2":{"91":1,"199":1,"705":1}}],["matrix",{"0":{"96":1},"2":{"91":1,"641":4,"643":1,"649":5,"650":1}}],["materials",{"0":{"50":1},"2":{"0":1,"30":2,"31":1,"51":1}}],["made",{"2":{"81":1,"111":1,"227":1,"289":1,"297":1,"328":1,"582":1,"631":1,"646":1,"649":2,"650":1,"668":2,"672":1,"721":1}}],["manual",{"2":{"523":1,"672":1}}],["manually",{"2":{"328":1,"352":1,"355":1,"361":2,"592":1,"597":2,"608":1,"672":1,"738":1}}],["managing",{"2":{"404":1}}],["manager",{"2":{"275":1}}],["management",{"0":{"262":1,"265":1,"520":1,"566":1,"716":1},"1":{"263":1,"521":1,"522":1},"2":{"388":1,"566":2,"569":1,"716":1}}],["manages",{"2":{"202":1}}],["managed",{"2":{"168":1,"455":1,"671":1}}],["manage",{"0":{"657":1,"661":1,"666":1},"2":{"30":1,"36":1,"260":2,"322":2,"381":1,"540":1,"566":1,"597":2,"696":1}}],["manifest",{"2":{"322":1,"569":1}}],["many",{"0":{"337":1},"2":{"39":1,"60":1,"125":1,"134":1,"275":1,"337":2,"398":1,"531":1,"581":1,"589":1,"591":1,"647":1,"675":1,"678":1,"716":1}}],["manner",{"2":{"24":1,"396":1}}],["maximize",{"2":{"582":1}}],["maximum",{"0":{"483":1,"586":1},"2":{"156":2,"274":2,"483":8,"586":2,"590":1,"738":1}}],["maxvalidators",{"2":{"266":4}}],["maxns",{"2":{"156":2,"163":2}}],["maxnamespace",{"2":{"156":4,"163":4}}],["max",{"2":{"26":1,"156":4,"233":1,"266":3,"272":4,"274":2,"429":20,"482":1,"620":4}}],["markdownlint",{"2":{"752":2}}],["marking",{"2":{"671":1}}],["market",{"0":{"587":1,"669":1},"1":{"588":1,"589":1,"590":1,"591":1,"592":1}}],["marketing",{"0":{"39":1},"2":{"39":1}}],["marks",{"2":{"107":1,"478":1,"547":1}}],["mark",{"2":{"26":1}}],["may",{"0":{"638":1},"2":{"10":1,"12":1,"13":1,"14":1,"22":1,"23":1,"34":2,"38":2,"39":3,"85":1,"87":1,"91":1,"164":1,"302":1,"313":1,"326":1,"337":1,"371":1,"380":1,"386":1,"391":1,"479":1,"547":1,"564":1,"565":1,"589":1,"607":1,"608":1,"638":1,"650":2,"671":1,"672":1,"678":1,"680":1,"688":1,"769":1}}],["mail",{"2":{"9":1}}],["maintenance",{"2":{"679":1}}],["maintained",{"2":{"228":1}}],["maintaining",{"2":{"46":1,"54":1,"86":1,"221":1,"592":1}}],["maintains",{"2":{"22":1,"343":1}}],["maintain",{"2":{"18":1,"22":1,"23":2,"27":1,"32":1,"36":1,"37":1,"39":1,"235":1,"328":1}}],["mainly",{"2":{"215":2}}],["mainnetresturl",{"2":{"782":2}}],["mainnetrpcurl",{"2":{"782":2}}],["mainnetchainid",{"2":{"325":2,"361":8,"372":2,"782":2}}],["mainnetversions",{"2":{"311":2,"341":2,"343":2,"390":2,"392":2,"393":2}}],["mainnet",{"0":{"317":1,"331":1,"478":1,"547":1,"548":1,"682":1},"1":{"479":1,"480":1,"481":1,"482":1,"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1,"490":1,"491":1,"492":1,"493":1,"494":1,"495":1,"496":1,"497":1,"498":1,"548":1},"2":{"23":4,"24":1,"26":4,"27":1,"69":2,"112":1,"136":1,"228":2,"231":4,"244":1,"245":1,"246":1,"311":1,"317":1,"324":1,"325":3,"328":1,"331":3,"338":1,"341":1,"343":2,"361":5,"369":1,"371":2,"372":1,"373":1,"390":3,"392":1,"393":1,"399":1,"400":1,"421":1,"422":2,"423":1,"464":1,"465":2,"466":1,"468":1,"478":3,"479":2,"484":2,"487":2,"488":2,"489":2,"490":1,"493":2,"496":3,"497":3,"498":2,"510":2,"526":1,"530":2,"547":2,"554":1,"586":1,"607":1,"617":1,"620":1,"682":1,"698":3,"704":1,"705":1,"734":1,"735":3,"736":2,"760":1,"782":5}}],["main",{"0":{"770":1},"2":{"2":1,"94":1,"136":4,"143":4,"144":4,"163":4,"214":16,"215":2,"280":1,"371":4,"646":1,"738":1,"769":6,"770":5,"771":5,"773":9}}],["making",{"2":{"2":1,"41":1,"42":1,"93":1,"227":1,"251":1,"331":1,"332":1,"377":1,"378":1,"379":1,"380":1,"381":1,"647":1,"648":1,"739":1}}],["makeconfig",{"2":{"597":2}}],["makes",{"0":{"631":1},"2":{"187":1,"250":1,"587":1}}],["make",{"2":{"0":1,"2":1,"6":1,"44":1,"90":1,"91":1,"109":1,"116":1,"117":1,"121":1,"140":3,"144":2,"156":5,"158":2,"159":4,"160":2,"162":2,"163":12,"168":1,"183":1,"202":3,"204":1,"211":3,"214":1,"215":2,"227":1,"273":1,"274":2,"283":1,"294":1,"305":1,"313":3,"326":3,"347":1,"371":1,"377":1,"398":4,"534":1,"555":1,"557":2,"580":1,"581":2,"602":1,"641":1,"649":1,"672":1,"697":5,"698":1,"765":1}}],["css",{"2":{"782":2}}],["cycle",{"2":{"668":1}}],["ccv",{"2":{"429":4}}],["c4ibesqxgzc5zxj3vtugbiadqamienbyjkegcac=",{"2":{"408":2}}],["c",{"2":{"312":2,"329":1,"343":4,"372":6,"398":2,"399":8,"426":1,"556":2}}],["cgo",{"2":{"214":2,"341":1}}],["cpu",{"2":{"239":1,"357":1,"416":1,"460":1,"533":1,"534":1,"611":1,"732":1}}],["cp",{"2":{"203":2,"210":2,"211":2,"215":2}}],["cd",{"2":{"202":2,"203":2,"208":2,"211":2,"214":4,"215":2,"311":2,"341":3,"372":3,"399":4,"584":2,"697":2,"768":2}}],["cips",{"2":{"526":3,"530":1}}],["cip",{"2":{"482":2,"525":1,"526":1,"528":7,"530":2,"671":1}}],["circulation",{"2":{"680":1}}],["circulating",{"2":{"680":4}}],["circuits",{"0":{"215":1},"2":{"190":1,"203":2,"204":3,"211":2,"213":1,"214":2,"215":5,"233":3}}],["circuit",{"0":{"191":1},"2":{"169":1,"187":1,"188":1,"191":3,"193":1,"194":4,"196":1,"202":1,"204":1,"210":3,"211":2,"214":13,"215":23,"234":1}}],["ciruit",{"2":{"203":1}}],["city",{"2":{"36":1,"38":1,"39":1,"64":1,"485":1,"503":1}}],["cmd",{"2":{"148":2}}],["cqebcp4bciavy2vszxn0aweuymxvyi52ms5nc2dqyxlgb3jcbg9icxj6ci9jzwxlc3rpytf2ogvzy3u3znu5bhy4nzlrenu1dwvndwv1cnrxnxn3nmhzbtnuzridaaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"147":2}}],["ctx",{"2":{"143":2,"144":10,"153":2,"161":4,"162":6,"163":4,"596":8,"708":8,"709":8,"710":8,"711":8,"770":2,"771":9,"772":2,"773":8}}],["cfg",{"2":{"90":1,"91":2,"104":1}}],["chunk",{"2":{"563":1}}],["cherry",{"2":{"277":1}}],["cheap",{"2":{"214":1}}],["cheaper",{"2":{"212":1}}],["checking",{"0":{"409":1,"413":1,"650":1},"2":{"343":1,"644":1,"714":1}}],["checkout",{"2":{"163":1,"215":2,"311":6,"341":6,"371":1}}],["checksum",{"2":{"343":1}}],["checks",{"2":{"118":2,"122":3,"770":1}}],["check",{"0":{"288":1,"748":1,"749":1},"2":{"31":1,"79":1,"112":1,"118":1,"121":1,"122":1,"126":1,"130":2,"139":1,"142":1,"147":1,"152":1,"160":1,"163":5,"174":2,"194":1,"203":1,"212":1,"215":1,"225":1,"235":2,"274":3,"288":1,"294":1,"295":1,"296":1,"297":1,"308":1,"309":1,"311":2,"320":1,"321":1,"334":1,"341":2,"408":1,"409":1,"427":1,"431":4,"471":1,"493":1,"536":1,"556":2,"559":1,"561":1,"567":1,"568":1,"570":1,"571":1,"577":1,"597":4,"602":3,"606":2,"614":1,"630":1,"640":1,"644":1,"704":1,"705":1,"727":1,"739":1,"761":1,"765":1,"771":1}}],["checklist",{"2":{"29":1}}],["choices",{"2":{"772":2}}],["choice",{"2":{"620":2,"655":1,"660":1}}],["chown",{"2":{"391":2}}],["choosing",{"2":{"208":1,"446":1}}],["chooses",{"2":{"641":1}}],["choose",{"0":{"79":1,"574":1,"664":1},"2":{"77":1,"79":1,"86":1,"166":1,"203":1,"275":1,"294":1,"302":1,"312":2,"320":1,"329":1,"343":1,"380":1,"445":1,"660":1,"664":1,"672":1}}],["chose",{"2":{"60":1}}],["chosen",{"2":{"37":1,"87":1,"342":1,"380":2}}],["chatmessageroleuser",{"2":{"772":2}}],["chatcompletion",{"2":{"772":2}}],["chatcompletionmessage",{"2":{"772":2}}],["chatcompletionrequest",{"2":{"772":2}}],["chatgpt",{"0":{"772":1},"2":{"769":2,"770":2,"771":3,"773":1}}],["chart",{"2":{"679":1}}],["charge",{"2":{"674":1}}],["charged",{"2":{"590":1}}],["characters",{"2":{"26":1}}],["characteristics",{"2":{"6":1}}],["chainname",{"2":{"782":12}}],["chain=celestia",{"2":{"682":1}}],["chainode",{"2":{"487":1,"488":1,"489":1,"490":1}}],["chainid",{"2":{"202":2,"434":8,"782":16}}],["chainlist",{"2":{"86":1}}],["chain",{"0":{"76":1,"86":1,"87":1,"88":2,"92":1,"93":1,"125":1,"325":1,"449":1,"580":1,"783":1,"784":1},"2":{"68":1,"76":2,"79":2,"81":1,"84":1,"85":1,"86":26,"87":12,"88":7,"90":2,"91":3,"92":1,"93":56,"94":2,"107":1,"109":6,"110":1,"112":1,"120":1,"125":3,"126":1,"136":1,"171":1,"172":1,"180":1,"200":1,"201":2,"202":12,"204":1,"210":2,"211":5,"214":1,"215":1,"218":2,"219":2,"221":1,"227":2,"234":1,"245":1,"265":6,"266":12,"268":4,"269":8,"270":4,"272":6,"277":1,"279":12,"294":6,"301":3,"302":1,"303":7,"314":2,"325":3,"338":2,"361":11,"371":1,"402":1,"412":2,"422":1,"427":3,"428":1,"429":4,"430":6,"433":12,"434":22,"437":1,"438":1,"445":4,"449":3,"477":2,"493":1,"494":1,"505":1,"530":1,"540":1,"543":1,"544":8,"557":1,"558":1,"559":2,"578":1,"583":1,"584":2,"614":2,"620":2,"625":1,"627":2,"628":1,"648":1,"670":1,"688":1,"698":1,"704":1,"715":1,"717":1,"719":1,"720":1,"736":1,"752":2,"782":2,"783":5,"784":4}}],["chains",{"0":{"432":1},"2":{"26":1,"64":1,"76":1,"81":1,"82":2,"86":3,"93":1,"97":2,"103":1,"107":1,"130":1,"165":1,"202":1,"228":1,"231":1,"427":1,"428":1,"429":30,"430":1,"431":2,"432":1,"435":4,"455":1,"485":1,"503":1,"544":1,"674":1,"678":1,"682":1,"683":1,"720":1,"784":1}}],["challengemanager",{"2":{"100":1,"101":1}}],["challenge",{"2":{"86":1,"87":1,"111":1,"774":1}}],["challenges",{"2":{"42":1}}],["challenging",{"2":{"38":1}}],["changing",{"0":{"327":1},"1":{"328":1,"329":1,"330":1,"331":1,"332":1,"333":1},"2":{"368":1,"582":1}}],["changeable",{"2":{"677":2}}],["change",{"0":{"303":1},"2":{"202":2,"211":2,"266":6,"272":2,"275":1,"286":1,"311":1,"329":1,"341":1,"353":1,"361":1,"516":1,"530":1,"542":1,"586":1,"589":1,"620":2,"671":1,"677":1,"715":1,"717":1,"720":1}}],["changed",{"2":{"93":2,"542":1,"738":1}}],["changes",{"2":{"2":4,"18":1,"37":1,"39":1,"60":2,"96":2,"238":1,"266":4,"379":1,"380":1,"381":1,"422":1,"479":1,"526":1,"528":1,"550":1,"592":1,"608":1,"646":2}}],["chan",{"2":{"162":2,"709":2,"710":2}}],["channelid",{"2":{"434":4}}],["channel",{"2":{"34":1,"47":2,"48":1,"70":1,"73":1,"91":4,"309":1,"429":4,"434":13,"435":4,"498":1,"510":1,"513":1,"554":1,"561":1,"562":1,"709":3,"710":3}}],["channelside",{"2":{"434":4}}],["channels",{"0":{"435":1},"2":{"13":1,"30":1,"40":2,"42":1,"429":2,"432":1,"435":2,"736":1}}],["chances",{"2":{"38":1}}],["chance",{"2":{"26":1,"371":1}}],["cumulo",{"2":{"487":2,"488":2,"489":2,"490":2,"506":2,"507":2,"508":2}}],["culmination",{"2":{"478":1,"547":1}}],["custody",{"0":{"716":1}}],["custodians",{"2":{"713":1}}],["custodian",{"2":{"23":1}}],["custom=robusta",{"2":{"742":2}}],["custom=private",{"2":{"742":2}}],["custom=test",{"2":{"475":2,"476":2}}],["custom=",{"2":{"314":4}}],["customtargetblock",{"2":{"233":3}}],["customizations",{"2":{"582":1}}],["customization",{"2":{"582":1}}],["customizability",{"0":{"582":1},"2":{"582":1}}],["customizing",{"2":{"86":1}}],["customized",{"2":{"582":1}}],["customize",{"2":{"41":2,"86":1,"698":1}}],["custom",{"0":{"76":1,"207":1,"246":1,"314":1,"333":1,"423":1,"468":1,"742":1,"783":1,"784":1},"1":{"424":1,"469":1},"2":{"41":3,"76":1,"82":1,"84":1,"86":1,"91":1,"205":1,"206":3,"207":3,"233":1,"246":9,"314":3,"328":1,"333":2,"334":2,"338":1,"390":1,"423":9,"468":9,"475":4,"476":7,"477":6,"582":1,"584":1,"698":1,"741":3,"742":9,"781":1,"783":1,"784":3}}],["currencies",{"2":{"782":2}}],["currency",{"2":{"688":1,"784":1}}],["current",{"2":{"37":1,"97":1,"215":1,"227":2,"262":2,"343":2,"483":1,"589":1,"636":1,"697":2}}],["currently",{"2":{"22":1,"42":1,"149":1,"166":1,"215":1,"231":1,"336":1,"400":1,"408":1,"427":1,"428":1,"455":1,"549":1,"574":1,"588":1,"593":1,"682":1,"683":1,"717":1,"718":1,"726":1}}],["curious",{"2":{"556":1}}],["curl",{"0":{"744":1,"760":1},"2":{"312":2,"343":4,"361":10,"372":6,"398":6,"452":2,"475":1,"556":2,"558":4,"744":1,"760":1}}],["curated",{"2":{"37":1,"58":1}}],["cups",{"2":{"35":1}}],["ce1e5714",{"2":{"773":2,"774":1}}],["certhash",{"2":{"476":10}}],["certainty",{"2":{"110":1,"111":1}}],["certain",{"2":{"21":1,"174":1,"208":1,"266":1,"638":1}}],["cel",{"0":{"566":1,"696":1,"701":1,"702":1},"1":{"697":1,"698":1,"699":1,"700":1,"701":1,"703":1,"704":1,"705":1},"2":{"245":3,"328":1,"329":3,"341":3,"388":1,"404":1,"422":3,"466":5,"520":1,"521":2,"522":2,"566":4,"695":2,"696":1,"697":5,"698":7,"699":6,"700":6,"701":2,"704":3,"705":3,"736":4}}],["cele",{"2":{"704":2,"705":2}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hd",{"2":{"614":1}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hdenter",{"2":{"614":1}}],["celesvaloper",{"2":{"614":2}}],["celes",{"2":{"466":6,"515":1,"542":1,"557":2,"705":4,"765":2}}],["celestiatestnet",{"2":{"784":1}}],["celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p",{"2":{"614":2}}],["celestiavaloper",{"2":{"614":1}}],["celestiacelestia",{"2":{"465":1}}],["celestiacommunity",{"2":{"430":1}}],["celestialightnodeclient",{"2":{"126":6,"128":2,"130":2}}],["celestiaheight",{"2":{"125":4}}],["celestiaorg",{"2":{"89":2,"112":1,"117":2,"140":6,"144":2,"150":4,"156":2,"157":2,"160":2,"163":4,"250":1,"311":2,"341":2,"361":9,"371":4,"383":14,"390":6,"392":6,"393":6,"456":1,"535":1,"591":2,"596":6,"597":12,"608":1,"625":14,"697":2,"704":2,"707":2,"708":6,"768":2,"769":6}}],["celestiascan",{"2":{"72":1,"512":1}}],["celestia1hn25k7gkfq0fy5a0vmphs6mjma2de74gsn36ef",{"2":{"765":2}}],["celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86",{"2":{"762":2}}],["celestia1znk24rh52pgcd9z5x2x42jztjh6raaaphuvrt3",{"2":{"751":2}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umard",{"2":{"749":1}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umardcelestia",{"2":{"749":1}}],["celestia10d07y265gmmuvt4z0w9aw880jnsr700jtgz4v7",{"2":{"266":2}}],["celestia1wkhyhr7ngf0ayqlpnsnxg4d72hfs5453dvunm9",{"2":{"705":2}}],["celestia1lgvzg4ek9v499pl5vvsvqpquhwfg0jznpwd92m",{"2":{"557":2}}],["celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3",{"2":{"477":2}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxcelestia",{"2":{"309":1}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"309":2}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx$request",{"2":{"309":1}}],["celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"292":2,"294":2,"296":2}}],["celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"291":2,"292":2,"294":2,"295":2}}],["celestia17adsjkuecgjheugrdrwdqv9uh3qkrfmj9xzawx",{"2":{"267":2}}],["celestia1czpgn3hdh9sodm06d5qk23xzgpq2uyc8ggdqgw",{"2":{"265":2}}],["celestia1vdjkcetnw35kzvtk8pjhxcm4xan82wtvwcurwwtt0f6n2at9va6k2atjw3cn2umhxe58xmfndejs40vqs9",{"2":{"147":2}}],["celestia1",{"2":{"70":1,"467":1,"510":1,"736":1}}],["celestia",{"0":{"0":1,"5":1,"17":1,"43":1,"46":1,"52":1,"54":1,"94":1,"106":1,"133":1,"138":1,"144":1,"199":1,"237":1,"242":1,"243":1,"250":1,"281":1,"283":1,"306":1,"310":1,"315":1,"322":1,"340":1,"360":1,"405":1,"406":1,"408":1,"412":1,"414":1,"419":1,"439":1,"442":1,"443":1,"458":1,"463":1,"472":1,"524":1,"531":1,"532":1,"538":1,"540":1,"546":1,"573":1,"585":1,"594":1,"595":1,"596":1,"598":1,"602":1,"604":1,"605":1,"606":1,"610":1,"615":1,"616":1,"629":1,"631":1,"637":1,"640":1,"649":1,"655":1,"664":1,"671":1,"674":1,"681":1,"695":1,"713":1,"715":1,"728":1,"734":1,"765":1,"781":1,"782":1},"1":{"1":1,"2":1,"3":1,"4":1,"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"44":1,"45":1,"46":1,"47":1,"48":1,"49":1,"50":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":2,"244":2,"245":2,"246":2,"247":2,"248":2,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"311":1,"312":1,"313":1,"316":1,"317":1,"318":1,"319":1,"320":1,"321":1,"341":1,"342":1,"343":1,"344":1,"345":1,"406":1,"407":1,"413":1,"415":1,"416":1,"417":1,"418":1,"419":1,"420":2,"421":2,"422":2,"423":2,"424":2,"425":2,"426":2,"440":1,"441":1,"442":1,"443":1,"444":2,"445":2,"446":2,"447":2,"448":2,"449":2,"450":2,"451":2,"452":2,"453":2,"459":1,"460":1,"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"473":1,"474":1,"475":1,"476":1,"477":1,"525":1,"526":1,"527":1,"528":1,"529":1,"530":1,"532":1,"533":1,"534":1,"541":1,"542":1,"543":1,"544":1,"545":1,"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"574":1,"575":1,"576":1,"586":1,"587":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"611":1,"612":1,"613":1,"614":1,"615":1,"616":2,"617":2,"618":2,"619":2,"620":1,"621":1,"622":1,"623":1,"624":1,"625":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"650":1,"682":1,"683":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"714":1,"715":1,"716":2,"717":2,"718":2,"719":2,"720":2,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"782":1,"783":1,"784":1},"2":{"0":2,"3":4,"6":1,"7":1,"10":1,"18":3,"20":3,"21":1,"23":3,"24":2,"26":5,"34":2,"35":2,"36":1,"37":4,"38":2,"39":2,"40":6,"41":15,"42":5,"43":1,"44":1,"46":2,"48":1,"50":1,"51":2,"53":2,"54":4,"55":2,"56":1,"57":2,"58":4,"59":1,"60":1,"64":1,"65":11,"67":1,"68":5,"69":2,"70":4,"71":1,"72":1,"81":3,"82":1,"85":5,"90":1,"91":12,"96":5,"103":1,"104":4,"107":2,"108":2,"109":12,"110":6,"111":4,"112":3,"113":1,"118":1,"119":1,"120":1,"121":2,"122":6,"124":4,"125":20,"126":11,"127":4,"128":3,"130":4,"133":2,"136":2,"137":4,"139":4,"140":3,"144":2,"147":4,"150":2,"152":1,"153":1,"154":2,"155":1,"156":4,"157":5,"160":8,"163":6,"164":2,"165":2,"167":1,"168":5,"171":1,"172":4,"174":3,"175":2,"178":2,"179":1,"180":1,"183":2,"184":1,"186":1,"187":2,"191":1,"194":1,"199":3,"209":3,"211":1,"216":2,"218":1,"221":5,"224":2,"225":2,"226":1,"227":12,"231":1,"233":2,"237":1,"238":11,"243":2,"244":3,"245":3,"246":3,"247":2,"249":2,"250":3,"251":1,"259":1,"260":6,"262":8,"263":2,"264":3,"265":2,"266":4,"267":1,"269":2,"272":10,"273":2,"274":3,"275":5,"276":1,"278":1,"279":18,"281":2,"282":1,"283":1,"284":1,"286":3,"287":10,"288":4,"289":1,"291":4,"292":2,"294":6,"295":2,"296":2,"297":4,"298":1,"299":2,"306":2,"307":2,"309":4,"310":2,"311":10,"312":12,"313":1,"314":6,"315":2,"316":2,"317":3,"318":2,"319":2,"320":4,"321":2,"322":1,"324":3,"325":2,"326":2,"329":9,"331":2,"332":2,"333":2,"334":2,"335":1,"336":10,"337":15,"338":4,"341":11,"342":8,"343":11,"344":1,"347":1,"349":3,"350":1,"353":1,"355":6,"356":2,"360":1,"361":19,"363":1,"367":1,"371":5,"372":42,"373":4,"375":2,"377":2,"378":2,"379":1,"380":2,"381":2,"383":17,"388":6,"390":15,"392":22,"393":22,"396":1,"397":1,"399":1,"400":5,"402":1,"403":2,"404":2,"406":1,"412":3,"414":3,"415":1,"419":1,"422":2,"423":3,"424":2,"425":1,"427":2,"428":1,"429":9,"430":1,"437":3,"438":2,"439":2,"442":1,"444":3,"445":2,"446":2,"447":2,"448":1,"449":3,"450":4,"451":1,"452":2,"453":2,"454":2,"455":7,"457":1,"458":2,"459":2,"461":1,"463":2,"465":6,"466":4,"467":3,"468":3,"469":2,"472":1,"473":2,"474":3,"475":6,"476":9,"477":6,"478":3,"479":1,"482":1,"483":2,"485":1,"487":16,"488":17,"489":15,"490":4,"492":1,"493":8,"495":2,"496":8,"497":6,"499":1,"503":1,"504":1,"505":7,"506":11,"507":8,"508":12,"509":8,"510":6,"511":1,"512":7,"515":1,"516":3,"522":1,"525":1,"526":3,"530":2,"531":3,"535":1,"540":4,"541":1,"542":7,"543":2,"544":1,"545":1,"547":1,"549":1,"550":1,"555":4,"556":9,"557":7,"558":1,"559":3,"562":4,"563":2,"564":1,"565":2,"566":3,"567":1,"568":1,"569":2,"571":1,"572":1,"574":1,"577":1,"581":1,"582":1,"585":1,"587":1,"588":2,"591":3,"592":2,"594":1,"595":1,"596":7,"597":16,"598":1,"599":1,"601":1,"602":16,"604":14,"605":18,"606":16,"607":3,"608":1,"610":2,"615":4,"616":1,"617":2,"620":7,"625":19,"627":1,"629":1,"631":1,"632":2,"637":1,"640":3,"641":3,"642":4,"643":1,"644":2,"646":12,"648":4,"649":3,"650":7,"651":2,"655":1,"659":1,"663":1,"664":1,"668":3,"669":2,"670":2,"671":2,"672":5,"674":3,"675":1,"678":2,"679":6,"680":1,"681":1,"682":2,"683":3,"687":2,"688":1,"689":2,"690":2,"695":1,"696":1,"697":5,"698":3,"703":1,"704":11,"705":17,"706":1,"707":3,"708":7,"713":1,"714":4,"715":2,"716":1,"717":3,"720":2,"721":2,"722":1,"725":1,"728":1,"730":1,"731":1,"733":1,"734":2,"735":5,"736":7,"737":2,"738":5,"739":1,"740":4,"741":2,"742":13,"743":4,"745":2,"748":1,"749":1,"752":2,"753":2,"755":1,"758":4,"760":6,"761":1,"763":3,"764":1,"765":5,"768":2,"769":6,"773":1,"774":3,"775":1,"776":6,"777":5,"781":1,"782":22,"783":4,"784":5}}],["celenium",{"0":{"599":1},"2":{"72":1,"93":1,"231":7,"338":2,"461":1,"496":1,"512":1,"540":1,"562":1,"599":4,"760":1,"771":2}}],["centric",{"2":{"226":1}}],["centralized",{"2":{"126":1,"224":2,"226":1}}],["center",{"2":{"26":1,"782":2}}],["crisis",{"2":{"715":1}}],["critical",{"2":{"39":1,"273":1,"294":2,"615":1,"627":1,"690":1}}],["criteria",{"0":{"23":1,"24":1},"2":{"20":1,"21":1,"22":1,"23":3}}],["cry",{"2":{"557":2}}],["cryptech",{"2":{"505":2,"506":1,"507":1,"508":1,"512":1}}],["cryptography",{"2":{"718":1}}],["cryptographic",{"2":{"322":1}}],["cryptokass",{"2":{"236":1}}],["crypto",{"2":{"144":2,"163":2,"291":2,"292":4,"296":2,"597":2,"705":2}}],["crate",{"2":{"428":1}}],["crashed",{"2":{"277":1}}],["cross",{"2":{"427":1}}],["crs",{"2":{"214":1}}],["credentials",{"2":{"597":2}}],["credibility",{"2":{"38":1}}],["creation",{"2":{"771":1,"777":2}}],["creative",{"2":{"562":1}}],["creating",{"0":{"128":1,"261":1,"450":1,"521":1},"2":{"34":1,"90":1,"93":2,"126":1,"127":2,"128":1,"164":1,"168":1,"289":2,"337":2,"432":1,"613":1,"688":1,"777":2,"778":2,"779":2}}],["creators",{"2":{"81":1}}],["createchatcompletion",{"2":{"772":2}}],["createandsubmitblob",{"2":{"771":6,"773":2}}],["createnamespaceid",{"2":{"771":7,"773":2}}],["createpayforblob",{"2":{"597":2}}],["creates",{"2":{"515":1,"771":2}}],["create2",{"2":{"202":5,"210":2}}],["createdblob",{"2":{"771":6,"773":2}}],["created",{"2":{"58":1,"141":1,"162":1,"175":1,"278":1,"289":1,"295":1,"304":1,"309":1,"429":1,"434":1,"435":2,"448":1,"450":1,"466":1,"467":1,"526":1,"557":1,"569":1,"602":1,"604":1,"605":1,"606":1,"704":2,"705":2,"736":2,"766":1,"771":3}}],["create",{"0":{"283":1,"291":1,"294":1,"299":1,"301":1,"306":1,"308":1,"432":1,"433":1,"446":1,"449":1,"695":1},"1":{"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"307":1,"308":1,"309":1,"434":1,"435":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1},"2":{"2":3,"30":1,"38":2,"40":2,"41":2,"58":2,"90":1,"126":1,"128":1,"139":1,"160":1,"163":2,"169":1,"174":1,"178":1,"183":1,"203":2,"210":1,"211":2,"214":1,"233":2,"235":1,"245":1,"260":2,"267":1,"272":2,"275":2,"279":4,"283":1,"290":1,"291":1,"294":9,"297":1,"298":1,"301":3,"305":2,"308":1,"311":1,"391":2,"392":1,"404":1,"422":1,"427":1,"432":1,"433":7,"434":6,"446":1,"449":1,"450":1,"454":1,"466":1,"482":1,"520":1,"522":1,"557":1,"566":1,"593":1,"596":2,"597":4,"602":1,"604":1,"605":1,"614":1,"620":3,"708":2,"709":2,"710":2,"736":1,"739":1,"761":1,"769":5,"770":7,"771":15,"772":1,"773":4,"777":2,"782":1}}],["crucial",{"2":{"36":1,"38":1,"86":2,"88":2,"91":1,"479":1}}],["cause",{"2":{"483":1,"634":1,"675":1}}],["cautious",{"2":{"337":1}}],["cache",{"2":{"322":1}}],["cake",{"2":{"277":1}}],["cadence",{"2":{"216":2,"217":1,"218":1}}],["car",{"2":{"291":2}}],["carry",{"2":{"578":1}}],["carrying",{"2":{"260":2}}],["carries",{"2":{"137":1}}],["cargo",{"2":{"209":2,"211":2,"214":2,"215":2}}],["care",{"2":{"109":1}}],["capacities",{"2":{"715":1}}],["capacity",{"2":{"581":3,"642":1}}],["capability",{"2":{"427":1,"715":1}}],["capabilities",{"2":{"259":1,"337":1,"722":1}}],["capable",{"2":{"81":1}}],["capture",{"2":{"31":1}}],["catching",{"2":{"602":1}}],["catchup",{"2":{"559":2}}],["catch",{"2":{"48":1,"559":2,"782":2}}],["categories",{"2":{"679":1}}],["categorize",{"2":{"562":1,"563":1}}],["category",{"2":{"3":4,"540":1,"562":1,"679":1,"680":2}}],["cater",{"2":{"42":1}}],["catering",{"0":{"35":1},"2":{"35":1,"38":1}}],["caldera",{"2":{"249":1,"250":1,"251":1,"253":1,"254":1,"256":1,"257":1}}],["calculation",{"0":{"590":1}}],["calculating",{"2":{"122":1,"174":1,"588":1,"591":1}}],["calculates",{"2":{"589":1,"590":1}}],["calculated",{"2":{"483":1,"588":1,"590":3,"669":1,"675":1,"746":1}}],["calculate",{"2":{"156":2,"159":2,"174":1,"590":1,"675":1}}],["calendar",{"2":{"39":1,"48":1,"79":1}}],["calling",{"2":{"204":1,"206":1}}],["callopts",{"2":{"144":2}}],["called",{"2":{"125":1,"215":1,"221":1,"524":1,"585":1,"591":1,"628":1,"629":1,"650":1,"696":1,"705":1}}],["calldata",{"2":{"112":1,"118":8,"206":2,"207":2,"400":2,"455":4}}],["calls",{"2":{"48":1,"202":1,"234":1,"507":1}}],["call",{"0":{"537":1},"2":{"37":1,"47":1,"48":1,"112":1,"204":5,"219":1,"252":1,"537":1,"737":1,"750":1,"751":1,"771":1}}],["cafes",{"2":{"36":1}}],["cast",{"2":{"204":5,"206":1,"207":1}}],["caste",{"2":{"6":1}}],["cases",{"2":{"179":1,"607":1,"646":1}}],["case",{"2":{"77":1,"84":1,"111":1,"136":1,"156":1,"162":2,"171":1,"175":1,"183":1,"185":1,"186":1,"188":1,"197":1,"208":3,"211":2,"213":1,"308":1,"353":1,"371":1,"386":1,"400":1,"432":1,"455":1,"555":1,"558":1,"589":3,"614":1,"639":1,"769":1}}],["casual",{"2":{"36":2,"42":1}}],["cancel",{"2":{"770":4,"771":4,"773":4}}],["canceling",{"2":{"39":1}}],["canonical",{"2":{"110":1,"584":1,"592":1}}],["cannot",{"2":{"24":1,"40":1,"216":1,"628":2,"634":1,"647":1}}],["can",{"0":{"639":1},"2":{"7":1,"23":2,"28":1,"29":2,"30":1,"34":3,"35":5,"37":3,"38":5,"39":3,"40":5,"41":3,"42":2,"48":1,"54":1,"55":1,"58":3,"60":3,"65":2,"68":1,"70":1,"72":1,"77":2,"80":1,"86":4,"90":1,"92":1,"97":1,"104":3,"109":6,"110":5,"111":4,"112":1,"122":1,"124":1,"125":5,"126":5,"128":3,"136":4,"137":3,"139":3,"141":1,"143":1,"146":1,"149":1,"150":1,"151":2,"153":1,"155":2,"156":4,"157":2,"158":1,"159":1,"160":4,"161":2,"162":2,"163":2,"164":2,"166":3,"168":1,"169":1,"172":4,"174":2,"175":5,"178":3,"179":4,"180":2,"182":2,"183":2,"186":2,"187":2,"188":1,"191":1,"194":1,"197":1,"202":1,"203":3,"205":3,"206":2,"208":3,"209":2,"210":2,"211":3,"214":1,"215":5,"216":1,"217":2,"218":1,"221":1,"225":1,"228":2,"230":1,"231":1,"233":5,"234":1,"235":1,"238":1,"244":1,"245":3,"250":1,"252":1,"254":1,"259":1,"261":1,"266":10,"267":4,"268":1,"269":2,"270":1,"271":1,"272":2,"273":2,"274":2,"275":4,"276":1,"277":2,"278":1,"281":2,"288":1,"294":1,"297":2,"301":1,"302":1,"303":1,"304":2,"306":1,"308":2,"309":1,"311":1,"312":1,"314":1,"316":1,"321":1,"326":1,"334":1,"337":1,"343":2,"345":1,"350":1,"355":2,"361":4,"363":1,"368":1,"369":1,"371":3,"373":1,"375":1,"376":1,"377":2,"380":1,"381":2,"384":1,"385":1,"388":2,"390":1,"391":3,"392":1,"396":1,"397":1,"400":5,"406":2,"409":1,"418":1,"419":1,"422":5,"427":2,"430":1,"432":1,"433":1,"437":2,"443":1,"444":1,"448":1,"452":5,"453":1,"455":1,"457":1,"461":1,"465":1,"466":3,"467":1,"471":1,"482":1,"483":3,"484":1,"493":2,"494":1,"495":2,"496":1,"499":1,"507":1,"509":1,"510":1,"512":1,"518":1,"519":1,"523":1,"524":1,"526":1,"531":3,"539":2,"545":1,"549":1,"552":1,"561":1,"562":1,"565":1,"566":1,"580":4,"581":1,"582":4,"589":1,"591":3,"592":1,"593":1,"597":6,"599":1,"605":1,"608":1,"614":3,"615":1,"616":1,"625":1,"627":3,"628":1,"631":3,"634":2,"641":1,"642":2,"644":3,"647":2,"648":1,"649":1,"650":2,"651":1,"657":1,"661":1,"666":1,"668":1,"670":1,"672":2,"675":2,"677":1,"681":1,"688":1,"689":1,"695":1,"696":1,"697":1,"698":1,"699":1,"704":1,"707":1,"708":3,"709":1,"710":1,"711":1,"719":1,"721":1,"723":1,"726":2,"731":3,"735":1,"736":5,"738":2,"739":2,"740":1,"741":2,"743":3,"745":1,"746":1,"755":1,"756":1,"760":1,"761":1,"765":2,"771":7,"773":2,"774":1,"776":1,"777":3,"778":1,"779":1,"781":1,"782":2,"783":2,"784":1}}],["clean",{"2":{"444":1}}],["clears",{"2":{"607":1}}],["clearing",{"0":{"335":1}}],["clear",{"2":{"2":1,"37":1,"429":4}}],["clock",{"2":{"429":4}}],["cloud",{"2":{"217":1,"275":1,"313":1,"320":1,"326":1,"496":1}}],["closely",{"2":{"251":1}}],["close",{"2":{"144":4,"161":4,"162":2,"163":2,"597":2,"770":2,"771":2,"773":2}}],["closer",{"2":{"122":1}}],["cloned",{"2":{"89":1}}],["clone",{"0":{"89":1},"2":{"1":1,"2":2,"89":3,"202":3,"203":2,"208":3,"211":4,"214":2,"215":2,"311":3,"341":3,"584":3,"697":2,"777":2}}],["cli",{"0":{"260":1,"594":1,"595":1,"728":1,"737":1},"1":{"261":1,"262":1,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":2,"739":2,"740":2,"741":2,"742":2,"743":2,"744":2,"745":2,"746":2,"747":2,"748":2,"749":2,"750":2,"751":2,"752":2,"753":2,"754":2,"755":2,"756":2,"757":2,"758":2,"759":1,"760":1,"761":1,"762":1},"2":{"260":2,"303":2,"308":1,"311":1,"312":1,"314":1,"333":1,"344":1,"428":2,"437":1,"466":1,"556":1,"562":1,"725":1,"731":1,"737":1,"738":2,"739":3,"740":1,"741":1,"757":1}}],["clientid",{"2":{"434":8}}],["clients",{"0":{"433":1,"434":1},"1":{"434":1,"435":1},"2":{"126":1,"429":2,"432":2,"433":2,"434":2,"531":1,"720":1}}],["client",{"0":{"123":1,"143":1,"148":1,"150":1,"153":1,"303":1,"567":1,"568":1,"596":1,"706":1,"775":1},"1":{"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"132":1,"133":1,"134":1,"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"776":1,"777":1,"778":1,"779":1,"780":1},"2":{"91":1,"111":1,"126":2,"134":1,"136":1,"140":1,"143":3,"144":4,"148":1,"149":1,"150":3,"153":1,"156":20,"157":4,"158":4,"159":6,"160":8,"163":50,"221":2,"227":2,"229":2,"303":4,"331":2,"333":2,"371":1,"433":8,"434":8,"507":1,"565":1,"567":1,"568":1,"591":1,"596":7,"706":1,"708":6,"709":4,"710":6,"711":6,"717":1,"769":2,"770":7,"771":16,"772":5,"773":8,"774":1,"775":1,"777":12,"778":10,"779":10}}],["clicking",{"2":{"580":1,"783":2}}],["click",{"2":{"76":1,"77":3,"79":4,"80":1,"85":1,"87":1,"88":1,"256":1,"275":3,"599":2,"660":1,"783":1,"784":3}}],["clubs",{"2":{"34":2}}],["classname=",{"2":{"782":4}}],["classes",{"2":{"15":1}}],["clang",{"2":{"398":4}}],["claim",{"0":{"80":1,"268":1},"2":{"79":1,"80":3,"268":1,"657":1,"661":1,"666":1}}],["clarifying",{"2":{"8":1}}],["clarity",{"2":{"2":1,"12":1}}],["coingeckoid",{"2":{"782":6}}],["coindecimals",{"2":{"782":6}}],["coindenom",{"2":{"782":6}}],["coinminimaldenom",{"2":{"782":6}}],["cointype",{"2":{"782":2}}],["coin",{"2":{"630":1,"783":1,"784":1}}],["copied",{"2":{"372":1}}],["copies",{"2":{"215":2}}],["copy",{"2":{"91":1,"124":1,"203":3,"311":1,"341":1,"536":1,"634":1,"765":1}}],["cosmovisor",{"2":{"528":1}}],["cosmostation",{"0":{"784":1},"2":{"781":1,"784":2}}],["cosmoslist",{"2":{"497":1,"511":1}}],["cosmosnetwork",{"2":{"430":1}}],["cosmossdk",{"2":{"429":4}}],["cosmos",{"2":{"63":1,"140":7,"238":1,"260":2,"261":1,"266":5,"275":3,"278":1,"280":2,"281":1,"291":2,"292":4,"294":2,"295":2,"296":4,"304":1,"361":3,"412":2,"427":1,"428":1,"429":9,"430":1,"484":1,"507":1,"508":1,"582":1,"585":1,"589":1,"597":4,"602":2,"604":2,"605":2,"646":1,"651":1,"674":3,"678":1,"682":1,"689":3,"696":1,"705":2,"715":4,"716":2,"717":1,"719":1,"720":1,"783":1,"784":1}}],["costly",{"2":{"169":1}}],["cost",{"2":{"34":1,"84":1,"183":1,"185":1,"454":1,"580":1,"589":6,"590":5,"648":1}}],["costs",{"2":{"34":2,"35":1,"38":3,"40":1,"170":1,"193":1,"226":1,"589":3,"591":1}}],["corner",{"2":{"599":1,"783":1,"784":1}}],["coral",{"2":{"291":2}}],["correspond",{"2":{"208":1}}],["corresponds",{"2":{"194":1,"743":1}}],["corresponding",{"0":{"149":1},"1":{"150":1},"2":{"136":1,"137":1,"139":2,"141":1,"144":2,"149":2,"160":1,"161":2,"163":2,"167":1,"168":3,"172":1,"201":1,"202":2,"203":1,"204":2,"209":1,"210":1,"211":2,"214":1,"233":1,"284":1,"322":2,"427":1,"641":1,"650":2}}],["correctly",{"2":{"187":1,"191":1,"194":1,"202":1,"399":1,"428":1,"431":1,"602":1,"606":1,"647":1}}],["correct",{"2":{"110":1,"187":1,"215":1,"246":1,"247":1,"311":1,"313":2,"326":2,"371":1,"399":1,"423":1,"424":1,"439":1,"468":1,"469":1,"499":1,"641":1,"698":1}}],["correction",{"0":{"12":1}}],["corrective",{"2":{"8":1}}],["cores",{"2":{"239":1,"416":1,"533":1,"534":1,"611":1}}],["core",{"0":{"350":1,"735":1},"2":{"53":1,"65":1,"67":1,"68":7,"91":3,"109":1,"140":3,"238":8,"244":12,"245":6,"246":6,"316":2,"317":2,"318":2,"319":2,"320":4,"322":1,"324":2,"329":2,"334":2,"338":2,"350":2,"355":1,"357":1,"383":14,"390":6,"393":6,"407":2,"408":2,"422":5,"423":6,"439":1,"460":1,"465":8,"466":6,"468":6,"475":12,"476":4,"492":1,"493":5,"499":1,"504":1,"505":1,"516":2,"526":1,"533":2,"534":1,"559":3,"578":1,"606":2,"608":1,"617":2,"625":14,"646":4,"679":3,"680":1,"688":1,"704":2,"705":2,"717":1,"730":1,"732":1,"735":16,"736":6,"760":2,"765":2}}],["cooperation",{"2":{"46":1}}],["coordinating",{"2":{"525":1}}],["coordination",{"0":{"525":1},"2":{"30":1,"60":1,"524":2,"552":1}}],["coordinates",{"2":{"641":2}}],["coordinated",{"2":{"479":1}}],["coordinate",{"2":{"30":1,"40":2,"524":1}}],["coworking",{"2":{"38":1}}],["coding",{"2":{"37":1,"632":2,"646":1,"668":1}}],["codelab",{"2":{"275":2}}],["coded",{"2":{"238":1,"483":1,"631":1,"632":1}}],["codespace",{"2":{"147":2,"294":2,"597":4,"614":2,"620":2}}],["codebase",{"2":{"109":1,"550":1}}],["code",{"0":{"5":1,"46":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1},"2":{"8":2,"9":1,"11":1,"13":1,"14":1,"16":4,"24":1,"46":4,"109":2,"110":1,"124":1,"147":2,"228":1,"233":1,"238":1,"250":1,"275":1,"294":2,"483":1,"597":18,"614":1,"620":1,"762":2,"763":1,"769":1,"782":1}}],["covers",{"2":{"53":1,"54":1,"55":1,"56":1,"74":1,"81":1,"228":1,"356":1,"564":1,"781":1}}],["cover",{"2":{"38":1,"40":1,"41":1,"74":1,"84":1,"229":1,"298":1,"314":1,"402":1,"572":1,"728":1,"738":1}}],["covering",{"2":{"38":1,"41":2}}],["covered",{"2":{"36":1,"387":1}}],["covenant",{"2":{"16":4}}],["co",{"2":{"34":2,"38":2,"39":1,"41":1,"50":1,"497":1,"511":1}}],["course",{"2":{"581":1}}],["counterparty",{"2":{"429":2}}],["count",{"2":{"95":1}}],["country",{"2":{"23":1}}],["couldn",{"2":{"40":2,"144":2,"161":2}}],["could",{"2":{"7":1,"124":1,"125":1,"127":1,"130":3,"145":1,"174":1,"175":1,"277":1,"562":1,"582":1,"589":1,"590":1,"632":2,"643":1,"650":1,"672":3,"717":1,"738":1,"771":1,"773":1}}],["columns",{"2":{"122":1,"139":1,"174":1,"641":1}}],["column",{"2":{"110":1,"122":3,"137":1,"139":2,"174":1,"643":1,"649":3,"752":2}}],["collide",{"2":{"275":1}}],["collaboration",{"2":{"38":1,"44":1}}],["collaborate",{"2":{"34":1}}],["collectively",{"2":{"642":1}}],["collection",{"2":{"43":1,"50":1,"125":1}}],["collect",{"2":{"31":1,"260":4,"450":2}}],["collector",{"2":{"23":1,"93":4,"274":2,"320":2,"321":3}}],["color",{"2":{"6":1,"52":1}}],["cohorts",{"2":{"21":1,"22":3,"25":1}}],["cohort",{"0":{"21":1,"27":1},"2":{"21":3,"22":12,"23":1,"24":1,"25":1,"27":5}}],["conn",{"2":{"597":6}}],["connects",{"2":{"321":1}}],["connectivity",{"2":{"650":1}}],["connecting",{"2":{"126":2,"244":1,"422":1,"493":1,"620":1,"735":1}}],["connectionid",{"2":{"434":8}}],["connection",{"0":{"432":1,"434":1},"2":{"38":1,"90":5,"105":1,"109":1,"126":6,"238":1,"245":1,"320":5,"422":1,"432":1,"434":30,"465":1,"597":2,"735":1}}],["connectionside",{"2":{"434":4}}],["connections",{"0":{"320":1},"2":{"34":1,"36":1,"37":1,"58":1,"90":1,"274":6,"313":3,"326":3,"376":1,"427":2,"429":2,"432":2,"435":1,"451":2,"605":1}}],["connect",{"0":{"363":1,"735":1},"1":{"364":1,"365":1},"2":{"32":1,"36":1,"37":1,"49":1,"63":2,"85":1,"109":1,"144":2,"161":2,"163":2,"237":1,"238":1,"252":1,"254":1,"333":2,"361":4,"414":1,"484":2,"499":4,"531":1,"557":1,"559":1,"599":1,"620":2,"650":1,"682":1,"683":1,"760":1,"782":2}}],["connected",{"2":{"23":1,"363":1,"552":1,"631":2,"646":1,"783":1,"784":1}}],["congests",{"2":{"581":1}}],["congestion",{"2":{"581":1,"607":1,"650":1}}],["congested",{"2":{"400":1}}],["congrats",{"2":{"543":1,"545":1}}],["congratulations",{"0":{"94":1,"545":1},"2":{"289":1,"297":1,"305":1,"390":1,"393":1,"434":1,"563":1}}],["conjured",{"2":{"275":1}}],["conditions",{"2":{"191":1,"281":1}}],["conducting",{"2":{"631":1}}],["conduct",{"0":{"5":1,"46":1},"1":{"6":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1},"2":{"7":1,"8":1,"9":1,"11":1,"13":1,"14":1,"16":4,"24":1,"30":1,"46":3,"531":1,"630":1}}],["concrete",{"2":{"771":2,"773":2}}],["concerned",{"2":{"633":1}}],["concepts",{"0":{"166":1},"1":{"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1}}],["concept",{"2":{"53":1,"671":1}}],["concurrency",{"2":{"559":2}}],["conclusion",{"0":{"164":1,"197":1,"305":1}}],["concise",{"2":{"2":1}}],["conf",{"2":{"104":2}}],["confidence",{"2":{"111":1,"630":2}}],["config\\t",{"2":{"557":2}}],["configs",{"2":{"104":2,"275":4}}],["configurable",{"2":{"112":1}}],["configurations",{"0":{"362":1},"1":{"363":1,"364":1,"365":1,"366":1,"367":1,"368":1},"2":{"88":1,"328":1,"379":1,"429":1,"431":1,"739":1}}],["configuration",{"0":{"88":1,"89":1,"380":1,"381":1,"429":1,"431":1,"622":1},"2":{"86":4,"87":1,"88":3,"260":4,"274":2,"275":3,"303":3,"308":1,"314":1,"322":3,"328":2,"334":2,"367":1,"371":2,"378":1,"380":2,"381":1,"429":1,"431":2,"523":3,"540":1,"542":1,"544":1,"557":1,"569":1,"622":1}}],["configuring",{"2":{"86":2,"88":1,"388":1,"428":1}}],["configures",{"2":{"261":1}}],["configured",{"2":{"91":1,"430":1,"539":1,"588":1}}],["configure",{"0":{"86":1,"376":1,"435":1},"1":{"377":1,"378":1,"379":1},"2":{"85":1,"86":2,"91":1,"93":3,"376":1,"380":1,"381":1,"432":1,"622":1}}],["config",{"0":{"76":1,"333":1,"334":1,"346":1,"349":1,"451":1},"1":{"347":1,"348":1,"349":1,"350":2,"351":2,"352":2,"353":2,"354":2,"355":2},"2":{"76":1,"88":4,"89":1,"90":1,"91":3,"104":5,"260":2,"261":2,"274":1,"275":8,"299":2,"303":2,"308":2,"322":1,"324":2,"333":1,"334":7,"336":1,"338":3,"349":4,"353":1,"355":1,"361":27,"363":1,"366":1,"371":2,"377":5,"378":4,"380":2,"381":2,"398":4,"428":1,"429":3,"431":5,"435":1,"448":1,"449":1,"450":4,"451":2,"464":1,"544":1,"557":2,"558":2,"569":1,"597":2,"622":1}}],["confirming",{"2":{"413":1}}],["confirmed",{"2":{"110":1,"111":1,"429":2,"597":2,"657":1,"661":1,"666":1}}],["confirmations",{"2":{"225":1}}],["confirmation",{"2":{"47":1,"128":1,"309":1,"429":2,"464":1}}],["confirm",{"0":{"657":1,"661":1},"2":{"30":1,"122":1,"225":1,"275":1,"294":2,"413":1,"620":1,"665":1}}],["conferences",{"2":{"39":1}}],["conference",{"2":{"39":1}}],["conventions",{"2":{"328":1}}],["convenient",{"2":{"30":1}}],["conversion",{"2":{"156":1,"685":1}}],["conversations",{"2":{"7":1,"31":1}}],["converts",{"2":{"771":2}}],["convert",{"2":{"155":1,"156":1,"157":1,"159":1,"771":3,"773":2}}],["converting",{"0":{"154":1},"1":{"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1}}],["converted",{"2":{"142":1,"147":1,"152":1,"155":1,"158":1,"743":1}}],["consoleconfirm",{"2":{"620":1}}],["consolecode",{"2":{"614":1,"620":1}}],["console",{"2":{"538":1}}],["consoleblockhash",{"2":{"537":1}}],["consolebasefeepergas",{"2":{"536":1}}],["console$request",{"2":{"467":1}}],["console$",{"2":{"260":1}}],["cons",{"0":{"171":1,"177":1,"181":1,"185":1,"189":1,"193":1,"196":1},"2":{"166":1}}],["consumes",{"2":{"590":1}}],["consumer",{"2":{"429":4}}],["consume",{"2":{"381":1,"590":1}}],["consumed",{"2":{"140":1,"589":2}}],["consuming",{"2":{"109":1}}],["const",{"2":{"782":8}}],["construction",{"2":{"171":1,"174":1,"183":2}}],["constructions",{"2":{"164":1,"178":1,"186":1}}],["constructing",{"2":{"160":2}}],["constructive",{"2":{"7":1}}],["constructed",{"2":{"157":1,"233":1,"631":1}}],["construct",{"2":{"154":1,"156":4,"159":1,"774":1}}],["constructs",{"2":{"137":1,"166":1,"182":1,"771":1}}],["constructor",{"2":{"118":2}}],["constantly",{"2":{"402":1,"427":1}}],["constants",{"2":{"325":4,"361":22,"372":6,"399":6,"542":4,"557":8,"558":1,"559":2,"569":1,"614":2,"620":2,"741":3,"745":1,"782":18,"783":1}}],["constant",{"2":{"91":1,"483":2,"590":1}}],["consensus",{"0":{"66":1,"302":1,"356":1,"358":1,"363":1,"373":1,"374":1,"387":1,"486":1,"487":1,"534":1,"594":1,"597":1,"601":1},"1":{"67":1,"68":1,"357":1,"358":1,"359":2,"360":2,"361":2,"362":1,"363":1,"364":2,"365":2,"366":1,"367":1,"368":1,"369":1,"370":1,"371":1,"372":1,"373":1,"374":1,"375":2,"376":2,"377":2,"378":2,"379":2,"380":2,"381":2,"382":1,"383":1,"487":1,"488":1,"489":1,"490":1,"602":1},"2":{"59":1,"65":2,"67":1,"68":2,"91":2,"109":1,"121":1,"124":1,"126":1,"136":1,"137":1,"227":3,"233":1,"237":1,"238":3,"266":1,"275":1,"289":1,"298":1,"302":2,"312":1,"313":1,"338":4,"356":3,"357":1,"363":1,"370":1,"371":1,"376":1,"383":32,"387":2,"414":1,"454":1,"465":1,"466":2,"486":1,"492":1,"493":5,"499":2,"504":1,"505":7,"506":2,"508":4,"526":1,"530":1,"531":5,"534":1,"558":2,"559":1,"571":1,"578":1,"581":1,"582":1,"588":1,"597":4,"601":1,"610":1,"612":1,"615":1,"620":1,"623":2,"625":32,"643":1,"646":1,"647":6,"648":2,"674":1,"689":1,"715":1,"720":1,"735":2,"752":2,"760":2}}],["consequence",{"2":{"12":1,"13":1,"14":1,"15":1,"643":1}}],["consequences",{"2":{"11":1,"13":1,"628":2}}],["consist",{"2":{"126":1,"591":1}}],["consists",{"2":{"125":1,"322":1,"646":1,"647":1,"649":3,"668":1}}],["consistency",{"2":{"41":1}}],["consistent",{"2":{"41":2}}],["considerable",{"2":{"381":1}}],["considerations",{"0":{"321":1},"2":{"109":2,"316":1,"321":1}}],["consider",{"2":{"34":1,"36":2,"37":1,"40":3,"368":1,"557":2,"625":1,"630":1,"743":1}}],["considered",{"2":{"7":1}}],["context",{"2":{"143":4,"144":10,"148":2,"150":6,"163":8,"596":6,"597":8,"708":6,"709":4,"710":6,"711":4,"769":2,"770":4,"771":8,"772":4,"773":4}}],["contents",{"0":{"569":1},"2":{"774":1}}],["content",{"2":{"2":1,"40":2,"58":1,"266":2,"538":2,"602":1,"604":1,"605":1,"606":1,"760":2,"772":4}}],["contrastingly",{"2":{"643":1}}],["contrast",{"2":{"224":1,"635":1}}],["contract",{"0":{"97":1,"144":1,"208":1},"1":{"98":1,"99":1,"209":1,"210":1},"2":{"86":1,"87":2,"90":1,"91":4,"93":4,"100":1,"101":1,"109":2,"111":1,"118":6,"120":1,"121":1,"122":7,"124":1,"126":4,"136":3,"137":1,"139":4,"140":1,"141":2,"142":1,"144":12,"147":1,"152":1,"154":6,"160":5,"161":8,"162":6,"163":14,"164":1,"165":1,"169":2,"171":1,"172":1,"174":1,"175":2,"179":1,"183":2,"185":1,"186":2,"187":3,"190":1,"191":1,"194":1,"199":2,"201":1,"202":7,"203":3,"204":8,"205":1,"208":2,"210":9,"211":5,"212":2,"213":1,"214":4,"215":1,"216":3,"217":2,"218":4,"219":2,"225":1,"227":2,"228":5,"229":1,"231":2,"233":5,"234":5,"235":3,"544":4,"580":1,"584":1,"636":1,"688":1}}],["contracts",{"0":{"114":1,"117":1,"201":1,"231":1,"576":1,"584":1},"1":{"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"209":1,"210":1,"211":1,"212":1},"2":{"81":1,"84":1,"86":4,"87":4,"88":2,"91":2,"93":4,"94":1,"96":3,"97":1,"117":4,"118":6,"120":1,"122":1,"127":2,"128":4,"132":1,"134":2,"154":1,"180":1,"202":5,"203":4,"210":3,"221":1,"229":1,"231":2,"254":1,"576":1,"578":1,"582":1,"584":2}}],["control",{"2":{"202":1,"329":1,"381":1,"426":1,"666":1}}],["controlled",{"2":{"86":1}}],["contributor",{"2":{"16":4,"679":1}}],["contributors",{"2":{"6":1,"679":1,"680":1}}],["contributing",{"2":{"7":1}}],["contributions",{"2":{"2":1,"8":1,"20":1,"26":3}}],["contribution",{"0":{"2":1},"2":{"2":2,"37":1,"107":1}}],["contributes",{"2":{"7":1,"589":1}}],["contribute",{"2":{"6":1,"23":1,"26":2,"38":1}}],["containers",{"2":{"704":1,"705":1}}],["container",{"0":{"705":1},"2":{"391":5,"392":4,"393":2,"704":9,"705":11}}],["containerization",{"2":{"388":1}}],["contained",{"2":{"162":1,"167":1,"322":1}}],["containing",{"2":{"139":1,"144":4,"145":1,"150":1,"156":1,"158":1,"160":3,"161":2,"163":4,"172":3,"180":1,"183":1,"199":1,"202":1,"210":1,"275":2,"569":1,"596":2,"649":1,"708":2}}],["contain",{"2":{"88":1,"137":1,"139":1,"145":1,"150":1,"151":1,"156":1,"175":1,"267":1,"322":2,"404":1,"585":1,"641":1,"649":1,"672":1}}],["contains",{"2":{"63":1,"88":1,"91":1,"94":1,"125":2,"144":4,"147":1,"149":1,"154":4,"160":3,"161":2,"163":2,"267":1,"322":3,"336":1,"404":1,"484":1,"499":1,"536":1,"569":3,"586":1}}],["contacts",{"2":{"39":1,"40":1}}],["contact",{"2":{"35":1,"42":1}}],["continuing",{"2":{"620":1}}],["continuousvestingaccount",{"2":{"295":3}}],["continuous",{"2":{"283":1,"294":1}}],["continuously",{"2":{"60":1,"680":4}}],["continues",{"2":{"273":1,"547":1}}],["continue",{"2":{"79":1,"87":1,"400":1,"524":1,"599":1,"671":1,"672":1,"778":2}}],["continued",{"2":{"13":1,"38":1}}],["continually",{"2":{"28":1}}],["combines",{"2":{"763":1}}],["combined",{"0":{"753":1},"2":{"581":1}}],["coming",{"2":{"604":1,"605":1}}],["comfortable",{"2":{"341":1}}],["comexport",{"2":{"390":1}}],["cometbft",{"2":{"224":1,"227":1,"483":1,"674":1}}],["come",{"2":{"124":1,"227":1,"478":1,"572":1,"769":2}}],["comes",{"2":{"109":1}}],["comcelestia",{"2":{"68":1}}],["com",{"0":{"41":1},"2":{"39":2,"41":6,"65":11,"68":1,"71":1,"72":2,"84":1,"89":2,"91":2,"136":4,"140":18,"143":2,"144":16,"150":6,"160":2,"161":2,"162":2,"163":24,"202":2,"203":2,"208":2,"211":2,"214":18,"215":2,"245":2,"280":2,"303":2,"311":2,"341":2,"361":10,"371":4,"383":28,"390":1,"398":2,"429":4,"456":1,"465":2,"466":2,"487":7,"488":7,"489":5,"490":1,"496":1,"497":1,"505":4,"506":4,"507":5,"508":7,"509":8,"512":3,"516":2,"544":2,"584":2,"591":2,"596":6,"597":16,"625":28,"683":1,"697":2,"707":2,"708":6,"735":2,"765":2,"768":4,"769":8,"783":3,"784":1}}],["compiling",{"2":{"398":1}}],["compile",{"2":{"214":6}}],["compiler",{"2":{"117":1}}],["computing",{"2":{"720":1}}],["computation",{"2":{"226":1}}],["computed",{"2":{"175":1,"589":1,"641":1}}],["computesquaresizefromshareproof",{"2":{"122":1}}],["computesquaresizefromrowproof",{"2":{"122":1,"174":1}}],["computes",{"2":{"122":2,"589":1,"649":1}}],["compute",{"2":{"110":1,"649":1}}],["comprised",{"2":{"669":1}}],["comprises",{"2":{"160":1}}],["comprising",{"2":{"199":1}}],["comprehensive",{"2":{"0":1}}],["compatmode",{"2":{"428":2}}],["compatibility",{"0":{"96":1,"718":1},"2":{"91":1}}],["compatible",{"0":{"548":1,"551":1,"553":1},"2":{"81":1,"96":1,"249":1,"251":1,"428":1,"473":1,"524":2,"576":1,"718":1}}],["compared",{"2":{"226":1}}],["compare",{"2":{"175":1}}],["comparing",{"2":{"169":1}}],["compact",{"0":{"169":1},"2":{"169":4,"170":1,"183":1}}],["companion",{"2":{"50":1}}],["companies",{"2":{"38":3}}],["company",{"2":{"38":1}}],["compelling",{"2":{"38":1}}],["component",{"2":{"96":1,"582":1,"782":2}}],["components",{"0":{"108":1},"1":{"109":1,"110":1,"111":1,"112":1},"2":{"26":1,"33":1,"108":2,"199":1,"201":1,"229":1,"478":1,"540":1,"585":1,"591":2,"646":1,"782":8}}],["compose",{"2":{"82":1,"91":1,"92":1,"539":2,"704":2,"705":6}}],["composition",{"2":{"27":1}}],["complex",{"2":{"380":1}}],["completing",{"2":{"81":1,"620":1}}],["completely",{"2":{"742":1}}],["completes",{"2":{"630":1}}],["completed",{"2":{"311":1,"341":1,"695":1}}],["complete",{"2":{"23":1,"47":1,"87":1,"93":2,"214":1,"215":1,"644":1,"677":1,"695":1}}],["compliant",{"2":{"119":1}}],["compliance",{"2":{"23":1}}],["comply",{"2":{"24":1}}],["complaints",{"2":{"10":1}}],["comma",{"2":{"211":1,"361":2,"451":2}}],["commands",{"0":{"260":1,"753":1},"1":{"261":1,"262":1,"263":1,"264":1,"265":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1},"2":{"260":2,"266":1,"272":1,"311":1,"312":1,"334":1,"338":1,"341":1,"361":1,"398":2,"412":1,"597":2,"697":1,"739":2,"768":1}}],["command",{"0":{"279":1,"738":1},"2":{"68":1,"70":1,"91":2,"93":1,"117":1,"172":1,"244":1,"245":1,"260":4,"264":4,"266":4,"267":2,"268":1,"269":2,"270":1,"271":3,"278":1,"294":4,"299":1,"301":2,"303":1,"309":1,"312":1,"316":2,"324":1,"329":1,"334":2,"335":1,"341":1,"350":1,"372":1,"377":1,"381":1,"390":1,"392":2,"393":2,"398":2,"408":1,"421":1,"422":1,"433":2,"434":1,"444":1,"445":1,"446":2,"447":1,"448":1,"449":2,"450":2,"452":2,"453":1,"464":1,"466":3,"467":1,"510":1,"516":1,"523":1,"556":1,"557":1,"559":2,"562":1,"563":1,"614":1,"697":1,"700":1,"704":2,"705":5,"735":2,"736":4,"737":1,"738":3,"740":1,"741":1,"742":1,"743":1,"745":3,"749":1,"752":1,"756":1,"757":2,"758":1,"765":2,"766":1,"773":1}}],["commission",{"2":{"23":1,"268":2,"272":6,"620":6,"665":1}}],["commitment",{"0":{"139":1,"167":1,"168":1,"169":1,"170":1,"171":1,"216":1},"1":{"168":1,"169":1,"170":1,"171":1,"217":1,"218":1,"219":1},"2":{"139":5,"142":1,"154":2,"160":3,"162":1,"166":1,"167":3,"168":9,"169":2,"170":2,"173":2,"175":3,"176":1,"183":6,"184":1,"186":1,"187":2,"188":1,"191":5,"194":7,"199":3,"219":1,"228":1,"233":1,"332":2,"408":1,"455":5,"563":6,"596":4,"641":1,"643":1,"649":6,"668":2,"708":4,"743":5,"745":10,"746":3,"760":2,"771":4,"773":2,"777":4}}],["commitments",{"0":{"162":1,"183":1,"184":1,"185":1,"190":1,"192":1,"193":1},"1":{"184":1,"185":1,"191":1,"192":1,"193":1},"2":{"111":1,"125":6,"127":1,"128":1,"162":1,"169":1,"180":1,"183":2,"186":1,"187":1,"190":1,"221":1,"408":2,"562":2,"641":1,"650":1}}],["committment",{"2":{"562":1,"563":2}}],["committing",{"0":{"127":1},"2":{"144":2,"161":2,"163":2}}],["committees",{"0":{"223":1},"1":{"224":1,"225":1,"226":1},"2":{"224":1}}],["committee",{"2":{"85":1}}],["committedto",{"2":{"163":4}}],["committed",{"0":{"144":1,"383":1,"625":1},"2":{"41":1,"119":1,"122":9,"125":1,"130":1,"137":2,"139":4,"141":2,"144":8,"154":8,"160":6,"163":4,"164":1,"168":1,"171":1,"172":1,"174":1,"175":2,"216":1,"233":1,"383":2,"597":4,"625":2,"649":1}}],["commitforge",{"2":{"117":1}}],["commits",{"2":{"8":1,"122":1,"127":1,"154":2,"160":2,"178":1,"194":1}}],["commit",{"2":{"2":3,"96":1,"117":1,"122":1,"127":1,"139":1,"183":1,"215":2,"341":1,"752":4}}],["commonly",{"2":{"275":1,"628":1}}],["common",{"2":{"16":1,"54":1,"144":2,"163":2,"320":1,"459":1,"570":1,"647":2,"706":1,"775":1}}],["communities",{"2":{"58":1}}],["community",{"0":{"42":1,"46":1,"65":1,"236":1,"267":1,"487":1,"488":1,"489":1,"490":1,"492":1,"493":1,"504":1,"505":1,"506":1,"507":1,"508":1,"509":1,"678":1},"2":{"2":1,"3":2,"4":1,"6":2,"7":2,"8":2,"9":3,"10":2,"11":2,"12":3,"13":2,"14":3,"15":3,"16":1,"24":1,"26":1,"30":1,"32":1,"33":1,"34":4,"37":2,"39":2,"41":1,"44":1,"46":3,"47":1,"49":1,"51":1,"57":1,"58":1,"65":1,"68":1,"236":1,"266":1,"267":11,"478":1,"479":1,"485":1,"487":1,"493":1,"503":1,"524":2,"547":1,"552":1,"592":1,"674":1,"678":2,"690":2}}],["communicating",{"2":{"275":2}}],["communications",{"0":{"39":1}}],["communication",{"2":{"14":1,"39":1,"49":1,"313":1,"320":1,"326":1,"353":1,"427":1,"507":1,"605":1}}],["communicate",{"2":{"8":1,"36":1,"91":1,"615":1,"766":1}}],["comments",{"2":{"7":1,"8":1}}],["fn",{"2":{"777":2,"778":2,"779":2}}],["fsudo",{"2":{"602":1,"604":1,"605":1,"606":1}}],["fssl",{"2":{"398":2}}],["fc",{"2":{"590":2}}],["fmt",{"2":{"130":4,"143":2,"144":4,"161":2,"162":2,"163":2,"596":2,"597":8,"708":2,"769":2,"771":6,"772":4}}],["f",{"2":{"130":22,"539":1,"602":1,"604":1,"605":1,"606":1}}],["floor",{"2":{"685":1}}],["flow",{"2":{"22":1,"37":1}}],["flipping",{"2":{"630":1}}],["flat",{"2":{"588":3,"591":1,"669":1}}],["flag",{"2":{"109":1,"214":1,"244":1,"283":1,"294":2,"299":1,"303":1,"311":1,"313":1,"316":1,"320":3,"325":1,"326":1,"328":1,"329":1,"338":1,"350":1,"373":2,"392":1,"407":1,"557":1,"559":3,"620":2,"707":1,"735":1,"738":2,"739":1,"740":1,"741":1,"745":1,"746":3,"752":2,"760":2,"770":2,"771":2,"773":2,"776":1}}],["flags",{"0":{"316":1,"523":1,"739":1},"1":{"317":1,"318":1,"319":1,"320":1,"740":1,"741":1,"742":1},"2":{"91":1,"104":2,"264":4,"301":2,"314":2,"316":2,"328":2,"348":1,"390":1,"523":1,"594":2,"698":2,"738":4,"739":2}}],["flexibility",{"0":{"226":1},"2":{"197":1,"226":1,"582":1,"647":1}}],["flexible",{"2":{"35":1}}],["further",{"2":{"698":1}}],["furthermore",{"2":{"26":1,"47":1,"644":1,"647":1}}],["fulfill",{"2":{"202":2}}],["fullnodes",{"2":{"130":1}}],["fullnode",{"2":{"126":6,"130":4}}],["full",{"0":{"102":1,"104":1,"105":1,"129":1,"144":1,"331":1,"332":1,"414":1,"415":1,"417":1,"420":1,"421":1,"422":1,"423":1,"425":1,"426":1,"502":1,"509":1,"604":1},"1":{"103":1,"104":1,"105":1,"130":1,"131":1,"132":1,"133":1,"134":1,"415":1,"416":1,"417":1,"418":2,"419":1,"420":1,"421":2,"422":2,"423":1,"424":2,"425":1,"426":1,"503":1,"504":1,"505":1},"2":{"49":1,"65":2,"68":1,"90":1,"91":3,"94":2,"104":1,"105":1,"109":1,"110":1,"126":4,"130":1,"136":2,"179":1,"183":1,"202":1,"260":2,"299":1,"301":1,"322":1,"328":1,"329":4,"331":1,"332":2,"335":1,"349":2,"386":1,"393":1,"414":1,"415":2,"416":1,"421":6,"422":7,"423":9,"424":3,"425":2,"426":1,"482":1,"487":1,"488":1,"489":1,"491":1,"493":2,"499":1,"505":4,"506":1,"507":1,"508":3,"509":7,"531":2,"533":1,"604":17,"631":3,"632":4,"641":3,"650":1,"696":1,"698":2,"699":2,"700":2,"712":1,"720":1,"734":1,"780":1}}],["fully",{"2":{"23":1,"27":1,"82":1,"495":1,"542":1,"671":2,"680":1}}],["fun",{"2":{"763":1}}],["func2",{"2":{"383":2,"625":2}}],["func",{"2":{"128":2,"130":3,"136":2,"143":2,"144":6,"150":2,"156":7,"157":1,"158":1,"159":1,"160":1,"163":22,"596":2,"597":2,"708":2,"709":1,"710":2,"711":2,"769":2,"770":2,"771":5,"772":2,"773":1}}],["functionalities",{"2":{"499":1}}],["functionality",{"2":{"30":1,"96":1,"126":2,"406":1,"717":1,"726":1}}],["functional",{"2":{"479":1}}],["functionids",{"2":{"210":1}}],["functionid",{"2":{"204":3,"206":2,"207":1,"210":1,"211":2,"218":1}}],["functionverifier",{"2":{"203":5,"215":4}}],["function",{"0":{"203":1,"204":1,"215":1,"770":1},"1":{"205":1,"206":1,"207":1},"2":{"112":1,"118":4,"122":5,"163":2,"202":3,"203":10,"204":16,"205":3,"206":4,"207":2,"210":8,"211":12,"214":1,"215":4,"218":2,"235":2,"589":2,"590":7,"591":3,"597":8,"644":1,"647":1,"769":2,"770":1,"771":2,"772":1,"773":1,"782":5}}],["functions",{"0":{"771":1},"2":{"110":1,"122":4,"202":2,"281":1,"578":3,"580":1,"647":5,"770":1,"771":1}}],["fund",{"0":{"300":1,"309":1},"2":{"93":1,"245":1,"267":2,"300":1,"309":1,"422":1,"466":1,"542":1,"678":1,"736":2,"765":1}}],["funded",{"2":{"82":1,"430":1,"542":2,"544":1,"731":1,"736":1,"762":1,"765":2}}],["funds",{"2":{"40":1,"77":2,"79":1,"84":1,"266":1,"267":3,"279":4,"281":1,"400":1,"403":2,"404":1,"408":1,"467":1,"477":1,"628":1,"678":1,"736":1}}],["funding",{"0":{"477":1,"561":1},"2":{"38":1,"93":3,"402":1,"765":1}}],["future",{"2":{"21":1,"31":1,"32":2,"36":1,"37":1,"42":1,"96":1,"321":1,"326":1,"373":1,"530":1,"557":1,"582":1,"605":1,"620":1,"672":1,"679":1,"680":1,"717":1,"726":1,"731":1}}],["feasible",{"2":{"642":1}}],["feature",{"0":{"514":1},"1":{"515":1,"516":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1},"2":{"86":1,"108":1,"400":1,"582":1}}],["features",{"2":{"58":1,"341":1,"439":1,"524":1,"526":3,"528":1,"581":1,"640":2,"722":1,"724":1,"774":1}}],["federation",{"2":{"275":2}}],["fed",{"2":{"214":1}}],["fek44boeswewectexicgqiabelorfjcagrqagqhaqqeaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmsegovy2vszxn0awexdjhlc2n1n2z1owx2odc5a3p1nxvlz3vldxj0ctvzdzzoc20zbmushqaaaaaaaaaaaaaaaaaaaaaaaaaaaawey1oiszk=",{"2":{"147":2}}],["few",{"2":{"130":1,"165":1,"171":1,"301":1,"371":1,"455":1,"498":1,"513":1,"526":1,"554":1,"558":1,"574":1,"580":2,"581":1,"765":1}}],["fetches",{"2":{"710":2,"711":2,"771":1}}],["fetchedblob",{"2":{"771":2,"773":4}}],["fetched",{"2":{"110":1,"328":1,"771":3,"773":3}}],["fetcher",{"2":{"109":1}}],["fetch",{"2":{"109":1,"202":1,"596":2,"708":2,"709":1,"710":3,"711":5,"763":1,"771":5,"773":4,"777":2,"778":3,"779":3}}],["fetching",{"0":{"711":1,"779":1},"2":{"90":1,"710":2,"778":2,"779":2}}],["feecurrencies",{"2":{"782":2}}],["fee=gas",{"2":{"590":1}}],["feegrant",{"0":{"401":1,"406":1,"408":1,"410":1},"1":{"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":2,"412":1,"413":1},"2":{"402":1,"404":1,"405":2,"406":1,"408":1,"410":1,"412":4,"413":1,"589":1,"715":1}}],["fees=21000utia",{"2":{"614":1,"620":2}}],["fees=21000utiacelestia",{"2":{"614":1}}],["fees",{"0":{"588":1},"1":{"589":1,"590":1,"591":1},"2":{"279":4,"294":6,"301":2,"402":1,"404":1,"409":2,"412":3,"413":2,"429":4,"477":2,"588":3,"592":1,"607":1,"609":1,"669":3,"746":1}}],["feeling",{"2":{"562":1}}],["feel",{"2":{"201":1,"534":1}}],["fee",{"0":{"405":1,"412":1,"587":1,"590":1,"669":1},"1":{"406":1,"407":1,"413":1,"588":1,"589":1,"590":1,"591":1,"592":1},"2":{"86":1,"87":1,"93":20,"202":4,"294":2,"404":1,"405":1,"407":3,"410":2,"412":1,"413":1,"523":1,"588":5,"590":3,"669":2,"674":1,"687":1,"743":5,"755":6}}],["feedback",{"0":{"4":1,"28":1},"2":{"4":1,"7":1,"28":1,"30":1,"31":1,"32":2,"478":1,"534":1}}],["fellow",{"2":{"34":1,"44":1,"49":1}}],["february",{"2":{"20":1,"27":1}}],["fast",{"2":{"454":1,"719":1}}],["faster",{"2":{"352":1}}],["fastest",{"2":{"312":1,"342":1}}],["fatalf",{"2":{"770":2,"771":6,"773":8}}],["fatal",{"0":{"336":1},"2":{"336":2,"770":2,"771":4,"773":4}}],["favourite",{"2":{"203":1}}],["favorite",{"2":{"562":1}}],["favor",{"2":{"152":1,"153":1}}],["falsediscard",{"2":{"381":1}}],["false",{"2":{"144":2,"210":4,"294":2,"313":1,"320":2,"326":1,"350":1,"352":1,"353":1,"381":3,"429":24,"602":1,"650":3}}],["falls",{"2":{"428":1}}],["fallback",{"0":{"112":1,"400":1},"2":{"108":2,"112":6,"400":6}}],["fall",{"2":{"90":1,"112":1,"130":1}}],["faults",{"2":{"126":1}}],["faulty",{"2":{"111":1,"180":1}}],["faucets",{"2":{"430":1}}],["faucet",{"0":{"69":1,"256":1,"510":1},"1":{"70":1,"71":1},"2":{"69":1,"70":3,"71":2,"82":1,"84":1,"256":2,"300":1,"309":2,"510":4,"561":1,"736":2,"762":1,"765":1}}],["familiarity",{"2":{"82":1,"103":1}}],["family",{"2":{"39":2}}],["fact",{"2":{"110":1,"137":1,"150":1,"169":1,"175":1}}],["factories",{"2":{"91":1}}],["factory",{"2":{"87":1}}],["factors",{"2":{"36":1,"483":2}}],["facilitating",{"2":{"87":1}}],["facilitated",{"2":{"58":1}}],["facilitate",{"2":{"31":1,"646":1}}],["failed",{"2":{"331":2,"333":2,"770":2,"771":10,"773":8,"777":8,"778":4,"779":6,"782":2}}],["fail",{"2":{"211":1,"740":1}}],["failure",{"2":{"130":4,"383":2,"602":2,"604":2,"605":2,"606":2,"625":2}}],["fails",{"2":{"112":1,"333":1,"650":1}}],["failing",{"2":{"24":1}}],["fairly",{"2":{"10":1,"715":1}}],["fair",{"2":{"8":1,"18":1,"60":1}}],["faq",{"0":{"198":1,"382":1,"624":1,"626":1},"1":{"199":1,"383":1,"625":1,"627":1,"628":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1},"2":{"16":2}}],["frequently",{"2":{"550":1}}],["frequency",{"2":{"211":1,"215":3}}],["fresh",{"2":{"375":1}}],["freeze",{"2":{"210":1}}],["free",{"2":{"6":1,"34":1,"65":1,"201":1,"295":2,"485":1,"487":1,"503":1,"534":1,"672":2}}],["fraudulent",{"2":{"130":1,"371":1}}],["fraud",{"0":{"122":1,"643":1},"2":{"110":2,"122":1,"127":1,"130":3,"163":5,"164":1,"178":1,"179":4,"180":1,"183":2,"186":1,"415":2,"581":2,"631":1,"632":3,"643":1,"647":1}}],["frameworks",{"2":{"582":2}}],["framework",{"0":{"574":1},"2":{"508":1,"674":1}}],["frame",{"2":{"86":1}}],["friends",{"2":{"38":1,"39":2,"443":1}}],["friendly",{"2":{"35":2,"599":1}}],["from=$validator",{"2":{"614":2,"620":2}}],["from=",{"2":{"268":2}}],["from",{"0":{"78":1,"79":1,"212":1,"218":1,"311":1,"338":1,"341":1,"411":1,"592":1,"599":1},"1":{"79":1,"80":1,"339":1},"2":{"2":1,"4":1,"7":1,"12":1,"14":1,"15":1,"16":1,"26":2,"30":1,"31":1,"32":1,"37":1,"40":1,"41":1,"43":1,"44":1,"46":1,"48":1,"58":3,"59":1,"60":1,"67":2,"68":1,"70":1,"74":1,"76":1,"77":1,"83":1,"86":2,"87":1,"89":1,"90":2,"91":1,"92":1,"93":8,"97":1,"109":3,"110":1,"111":1,"117":1,"121":1,"122":4,"126":8,"128":1,"130":8,"136":1,"146":1,"155":2,"156":2,"157":2,"160":2,"163":4,"172":1,"173":1,"174":1,"179":1,"186":1,"199":1,"202":2,"203":1,"204":1,"208":3,"211":2,"212":1,"214":1,"216":1,"218":4,"221":1,"225":1,"227":1,"228":1,"238":2,"244":1,"245":1,"249":1,"263":1,"265":5,"266":7,"267":2,"269":4,"270":2,"275":7,"278":2,"279":14,"281":2,"287":1,"293":3,"294":8,"296":1,"299":2,"301":2,"302":1,"303":1,"310":1,"328":1,"334":1,"336":1,"338":3,"345":1,"353":1,"361":1,"369":2,"371":2,"372":3,"373":1,"376":1,"377":1,"383":1,"390":1,"398":2,"411":1,"413":1,"422":2,"430":1,"438":2,"455":6,"465":1,"467":1,"476":1,"477":1,"492":2,"493":1,"504":2,"505":3,"510":1,"536":1,"537":2,"550":1,"555":1,"558":2,"559":3,"561":1,"562":1,"563":2,"565":1,"566":2,"580":2,"581":1,"582":2,"584":1,"588":3,"592":2,"596":2,"597":6,"599":2,"605":2,"606":1,"607":1,"617":1,"620":3,"625":2,"628":1,"631":1,"632":1,"634":1,"635":1,"636":2,"644":1,"647":1,"648":2,"650":2,"664":1,"671":2,"672":2,"674":1,"680":5,"699":1,"700":1,"704":1,"708":2,"711":2,"717":1,"728":1,"731":1,"736":1,"739":3,"741":1,"742":1,"743":1,"745":3,"750":1,"752":1,"762":1,"763":1,"765":1,"769":2,"770":4,"771":7,"773":5,"774":1,"777":2,"779":4,"782":4}}],["five",{"2":{"679":1}}],["fit",{"0":{"636":1}}],["fits",{"2":{"581":1}}],["firewall",{"2":{"313":2,"326":2}}],["first",{"2":{"22":4,"37":1,"44":1,"51":1,"53":1,"63":1,"86":1,"91":2,"93":1,"107":1,"125":3,"126":1,"127":1,"128":1,"130":1,"144":2,"156":2,"157":1,"160":2,"161":2,"163":6,"165":1,"172":1,"183":1,"204":1,"215":2,"221":2,"228":1,"235":1,"249":1,"266":3,"267":1,"272":1,"275":1,"284":1,"291":1,"298":1,"308":1,"329":1,"344":1,"391":1,"398":1,"407":1,"455":2,"461":1,"474":1,"483":1,"484":1,"499":1,"528":1,"530":1,"537":1,"540":1,"556":1,"566":1,"589":2,"592":1,"612":1,"679":1,"685":1,"687":1,"695":1,"697":1,"711":2,"714":1,"755":1,"765":1,"771":5,"772":1,"779":2}}],["figure",{"2":{"399":1,"644":1,"646":1,"649":2}}],["figures",{"2":{"58":1}}],["figment",{"2":{"280":1}}],["fields",{"2":{"371":1}}],["field",{"2":{"147":1,"155":2,"156":1,"160":1,"209":1,"353":1,"378":2,"599":1,"771":1}}],["fine",{"2":{"650":1}}],["finished",{"2":{"606":1}}],["finish",{"0":{"93":1},"2":{"773":1}}],["financial",{"2":{"38":1}}],["finality",{"2":{"578":1}}],["finalizecommit",{"2":{"383":2,"625":2}}],["finalize",{"2":{"30":1,"660":1}}],["finally",{"2":{"105":1,"111":1,"160":1,"171":1,"175":1,"275":1,"526":1,"589":1,"599":1}}],["final",{"2":{"30":1,"214":1,"277":1,"279":2,"450":2,"647":3,"773":1}}],["finger",{"2":{"35":1}}],["finding",{"2":{"34":1,"38":1,"40":1,"42":2}}],["find",{"0":{"536":1,"538":1},"2":{"0":1,"4":1,"37":1,"38":1,"41":1,"54":1,"55":1,"65":1,"68":1,"90":2,"93":1,"98":1,"99":1,"109":3,"122":1,"127":2,"144":2,"161":2,"170":1,"215":2,"228":1,"233":1,"234":1,"245":1,"277":1,"287":1,"301":1,"326":1,"337":1,"349":1,"352":1,"396":1,"422":1,"448":1,"449":1,"456":1,"466":1,"493":2,"495":1,"509":1,"561":1,"564":1,"566":1,"726":1,"731":1,"735":1,"736":1}}],["fixed",{"2":{"563":1,"589":2,"590":2}}],["fixes",{"2":{"23":1}}],["fix",{"2":{"337":1,"383":1,"592":1,"625":1}}],["fixing",{"2":{"2":1}}],["fill",{"2":{"210":2,"275":1}}],["filled",{"2":{"22":1}}],["filter",{"0":{"438":1},"2":{"429":8,"435":4,"438":1,"709":2,"710":2,"778":2}}],["filteropts",{"2":{"144":2,"161":2}}],["filterdatacommitmentstored",{"2":{"144":2,"161":2}}],["filecoin",{"2":{"639":1}}],["file=",{"2":{"275":2}}],["file",{"0":{"411":1,"450":1,"451":1},"2":{"86":3,"88":3,"94":1,"104":3,"202":1,"210":2,"211":2,"215":1,"218":1,"260":6,"263":2,"266":5,"267":4,"272":1,"274":1,"275":1,"276":1,"303":2,"308":1,"311":1,"312":1,"322":3,"334":1,"336":2,"337":9,"342":1,"343":1,"355":1,"361":5,"377":1,"380":1,"381":1,"411":3,"430":9,"448":1,"449":2,"450":4,"451":2,"539":1,"540":1,"569":1,"584":1,"597":2,"599":1,"602":2,"604":2,"605":2,"606":1,"622":1,"769":2}}],["filesystem",{"2":{"396":1}}],["fileserror",{"2":{"337":1}}],["files",{"0":{"88":1,"89":1,"337":1,"431":1},"2":{"3":1,"52":1,"87":1,"88":3,"89":1,"247":2,"260":2,"322":8,"337":2,"398":1,"424":2,"450":4,"469":2,"557":1,"569":7}}],["four",{"2":{"168":1,"266":1,"578":1,"647":3}}],["foundry",{"2":{"116":1,"202":2,"204":1,"208":2}}],["found",{"2":{"68":1,"86":2,"97":1,"104":1,"110":1,"112":1,"122":1,"126":1,"136":1,"137":1,"156":1,"157":1,"159":1,"160":1,"168":1,"169":1,"172":1,"175":2,"182":2,"208":1,"210":1,"217":1,"230":1,"233":1,"250":1,"266":2,"322":1,"371":3,"437":1,"482":1,"557":2,"591":2,"675":1,"708":1,"709":2,"710":2,"740":1,"760":1,"762":2,"763":1,"765":2,"777":1,"778":2}}],["foundation",{"0":{"17":1,"19":1},"1":{"18":1,"19":1,"20":2,"21":2,"22":2,"23":2,"24":2,"25":1,"26":1,"27":1,"28":1},"2":{"18":2,"20":1,"21":2,"23":2,"24":1,"26":2,"27":1,"679":1}}],["folders",{"2":{"287":4,"375":1,"429":1}}],["folder",{"2":{"94":1,"110":1,"214":2,"215":4,"311":1}}],["followed",{"2":{"127":1,"201":1,"212":1}}],["follows",{"2":{"23":1,"126":1,"154":1,"156":2,"157":2,"158":1,"159":1,"162":1,"163":1,"169":1,"175":1,"191":1,"194":1,"275":1,"328":1,"437":1,"483":1,"738":1}}],["follow",{"2":{"11":1,"29":2,"32":1,"42":1,"90":1,"104":1,"199":1,"213":1,"217":1,"218":1,"241":1,"243":1,"248":1,"276":1,"312":1,"343":1,"359":1,"360":1,"373":1,"387":1,"388":1,"398":2,"418":1,"419":1,"425":1,"428":1,"430":1,"439":1,"440":1,"443":1,"470":1,"499":1,"540":1,"584":2,"599":1,"612":1,"613":1,"616":1,"619":1,"620":1,"622":1,"647":1}}],["following",{"2":{"1":1,"26":1,"35":1,"36":1,"46":1,"47":1,"48":1,"70":1,"85":1,"93":2,"97":1,"109":2,"116":1,"125":1,"136":1,"140":1,"154":1,"156":2,"159":1,"168":1,"172":1,"178":1,"179":1,"187":1,"191":1,"199":1,"201":1,"202":2,"211":3,"214":1,"216":1,"228":2,"231":1,"238":1,"239":1,"240":1,"244":1,"245":2,"252":1,"266":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"275":1,"281":1,"294":1,"313":1,"315":1,"316":1,"321":1,"322":1,"326":1,"329":1,"334":2,"341":1,"349":1,"357":1,"358":1,"361":1,"363":1,"371":1,"372":1,"393":1,"408":1,"412":1,"416":1,"417":1,"421":1,"422":2,"427":1,"429":1,"431":1,"433":1,"434":1,"439":1,"441":1,"442":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":3,"451":2,"452":3,"453":1,"459":1,"460":1,"464":1,"466":3,"467":1,"483":1,"497":1,"510":1,"511":1,"516":1,"556":1,"559":1,"563":1,"569":1,"598":1,"611":1,"612":1,"617":1,"618":1,"620":1,"644":1,"646":1,"647":1,"649":1,"656":1,"657":1,"660":2,"661":1,"682":1,"683":1,"695":1,"697":1,"698":1,"700":1,"705":1,"707":1,"732":1,"736":4,"739":1,"740":1,"741":1,"742":1,"743":3,"745":3,"756":1,"757":2,"764":1,"765":1,"766":1,"768":1,"773":1,"776":1,"782":1,"783":1,"784":1}}],["foster",{"2":{"46":1,"58":1}}],["fosters",{"2":{"37":1}}],["fostering",{"2":{"18":1,"35":1,"43":1}}],["focuses",{"2":{"722":1}}],["focused",{"2":{"36":2,"59":1,"226":1,"550":1,"552":1}}],["focus",{"2":{"59":1,"315":1,"688":1}}],["focusing",{"2":{"7":2,"37":1}}],["foods",{"2":{"35":1}}],["food",{"2":{"35":2}}],["forest",{"2":{"649":1}}],["forever",{"2":{"637":1}}],["fortunately",{"2":{"275":1}}],["forward",{"2":{"202":1,"602":1}}],["forget",{"2":{"79":1,"291":2}}],["forge",{"2":{"36":1,"202":2,"203":6,"210":2}}],["forces",{"2":{"36":1}}],["former",{"2":{"648":1}}],["formerly",{"2":{"221":1}}],["formula",{"2":{"591":1}}],["formatting",{"0":{"738":1}}],["format",{"2":{"154":1,"155":1,"202":2,"263":1,"266":1,"303":2,"599":2,"699":1,"738":1,"743":3,"745":1,"749":1,"752":1,"755":1,"771":1}}],["formal",{"2":{"36":1}}],["forms",{"2":{"30":1,"31":1,"125":1}}],["form",{"0":{"47":1},"2":{"26":1,"28":1,"47":1,"86":1,"218":1,"680":1}}],["fork",{"2":{"2":3,"592":1}}],["for",{"0":{"42":1,"67":1,"68":1,"90":1,"91":1,"122":1,"162":1,"272":1,"339":1,"374":1,"401":1,"407":1,"410":1,"449":1,"492":1,"493":1,"502":1,"504":1,"505":1,"514":1,"523":1,"548":1,"551":1,"553":1,"631":1,"632":1,"645":1,"655":1,"664":1,"667":1,"672":1,"687":1,"698":1,"699":1,"700":1,"701":1,"713":1},"1":{"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"402":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":1,"409":1,"410":1,"411":2,"412":1,"413":1,"503":1,"504":1,"505":1,"515":1,"516":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"646":1,"668":1,"669":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"720":1},"2":{"0":1,"2":1,"3":3,"4":1,"6":1,"7":3,"8":2,"10":1,"11":1,"13":2,"14":1,"16":1,"18":1,"21":2,"22":3,"23":5,"24":2,"25":3,"26":3,"27":2,"30":3,"31":1,"32":4,"33":1,"34":13,"35":6,"36":4,"37":6,"38":4,"39":2,"40":5,"41":8,"42":3,"43":2,"44":1,"46":2,"47":2,"50":1,"51":1,"54":2,"55":1,"57":3,"58":1,"59":2,"63":1,"64":2,"65":1,"67":1,"68":5,"72":1,"73":1,"77":3,"81":1,"82":1,"84":2,"86":15,"87":1,"88":5,"90":6,"91":13,"92":1,"93":14,"96":4,"104":1,"107":2,"109":11,"110":5,"112":3,"117":1,"118":1,"120":1,"122":1,"124":1,"125":2,"126":12,"127":4,"128":3,"130":3,"134":2,"136":8,"137":1,"139":2,"140":1,"142":2,"144":2,"147":2,"151":1,"152":3,"153":1,"155":1,"160":2,"161":4,"162":4,"163":13,"165":1,"170":1,"171":2,"172":1,"174":1,"176":1,"179":1,"180":1,"187":1,"194":1,"197":1,"202":17,"204":2,"205":2,"206":1,"207":1,"208":1,"210":3,"211":10,"212":1,"214":1,"215":7,"216":2,"218":2,"219":2,"221":3,"224":1,"226":1,"227":2,"228":2,"229":1,"233":3,"234":3,"235":2,"239":3,"241":1,"243":1,"244":1,"245":6,"250":1,"251":2,"252":2,"258":1,"260":4,"263":2,"266":1,"273":2,"274":4,"275":1,"277":1,"278":1,"281":5,"282":1,"283":3,"287":1,"289":1,"294":3,"298":2,"299":3,"301":1,"302":1,"303":5,"306":1,"307":1,"308":1,"309":2,"311":2,"312":2,"313":3,"314":1,"315":3,"317":1,"318":1,"319":1,"320":2,"321":2,"322":2,"324":1,"325":3,"326":3,"328":2,"335":1,"336":1,"337":2,"338":1,"339":2,"341":1,"342":1,"343":2,"349":4,"350":2,"353":1,"355":3,"357":3,"361":5,"367":1,"368":1,"369":1,"370":1,"371":2,"373":1,"376":1,"378":2,"380":2,"381":3,"383":3,"385":1,"387":1,"388":3,"389":2,"390":2,"391":3,"392":1,"396":3,"397":1,"398":2,"399":1,"400":2,"402":1,"404":2,"405":2,"406":1,"407":1,"412":2,"416":3,"418":1,"419":1,"422":11,"427":2,"428":1,"429":2,"430":4,"431":2,"435":2,"437":1,"439":1,"444":1,"445":3,"446":1,"448":2,"449":1,"450":1,"453":1,"455":4,"456":1,"459":1,"460":3,"465":3,"466":3,"478":2,"482":1,"483":1,"484":1,"485":3,"487":1,"492":1,"493":5,"495":1,"496":1,"497":1,"499":3,"503":3,"504":1,"505":3,"507":1,"509":1,"511":1,"512":1,"523":4,"524":1,"525":5,"526":2,"528":5,"530":1,"535":1,"536":1,"537":1,"539":1,"542":1,"543":2,"544":2,"547":1,"550":1,"556":3,"557":6,"559":2,"561":2,"562":3,"566":3,"569":2,"570":1,"571":1,"572":3,"574":1,"581":1,"582":2,"583":1,"584":4,"586":3,"588":2,"589":3,"590":12,"591":4,"592":1,"596":1,"597":4,"599":3,"600":1,"602":1,"605":1,"607":1,"611":3,"614":1,"615":1,"616":1,"617":1,"620":1,"623":2,"625":4,"627":2,"628":1,"629":3,"630":4,"631":3,"633":1,"634":1,"635":1,"637":2,"638":2,"639":2,"640":1,"641":4,"642":3,"643":2,"644":7,"646":2,"647":4,"648":2,"649":3,"650":5,"656":1,"660":1,"670":1,"671":1,"672":8,"675":2,"679":2,"680":3,"682":1,"683":1,"687":2,"688":1,"689":1,"693":1,"694":1,"696":1,"697":1,"698":5,"704":5,"705":1,"713":1,"715":2,"716":1,"717":2,"718":1,"721":1,"723":1,"724":1,"726":1,"727":1,"731":1,"732":3,"735":3,"736":5,"738":3,"739":1,"741":1,"742":1,"743":1,"745":2,"746":2,"748":1,"749":6,"757":1,"760":1,"763":1,"764":1,"765":3,"766":2,"769":2,"771":1,"773":1,"774":2,"782":2}}],["tld",{"2":{"760":1}}],["tls",{"0":{"320":1},"2":{"320":7}}],["tls=false",{"2":{"320":2}}],["tls=true",{"2":{"317":2,"318":2,"319":2,"320":2}}],["tls=",{"2":{"316":2}}],["tbd",{"2":{"715":1}}],["tb",{"2":{"239":1,"357":1,"369":1,"416":1,"533":2,"534":2,"611":1}}],["tj9wswcyhm0r0i8t+p3hpftdieuyr9wspvkl1r2s=",{"2":{"142":2}}],["tmproto",{"2":{"156":2,"163":2,"597":6}}],["tm",{"2":{"140":2,"383":14,"625":14,"715":1}}],["txoption",{"2":{"597":2}}],["txtsudo",{"2":{"271":1}}],["txt",{"2":{"263":1,"271":5,"361":8}}],["txtcelestia",{"2":{"263":1}}],["txhashcelestia",{"2":{"755":1}}],["txhash",{"2":{"148":4,"150":2,"294":2,"614":3,"620":2,"755":1}}],["txsizecost",{"2":{"590":1}}],["txsizecostperbyte",{"2":{"589":1}}],["txsharerange",{"2":{"172":1}}],["txs",{"2":{"125":4,"128":6,"150":2,"260":2}}],["tx",{"2":{"93":6,"144":14,"147":5,"148":5,"150":6,"161":4,"163":2,"260":4,"265":6,"266":6,"267":2,"268":2,"269":4,"270":2,"279":10,"294":8,"301":4,"380":4,"412":2,"429":10,"437":2,"477":2,"536":2,"537":2,"586":1,"588":1,"589":1,"594":2,"614":7,"620":6,"649":1}}],["ts",{"2":{"91":1}}],["tcp",{"2":{"65":4,"143":2,"144":2,"303":2,"313":2,"314":4,"326":1,"333":2,"377":4,"476":6,"605":2,"704":2,"705":2,"750":6}}],["tuning",{"2":{"650":1}}],["tuplerootnonce",{"0":{"161":1},"2":{"154":2,"160":5}}],["tuple",{"2":{"118":10,"119":1,"127":1,"128":1,"139":4,"141":3,"144":2,"154":14,"160":17,"164":1,"168":3,"169":1,"174":1,"175":4,"199":1}}],["tutorial",{"0":{"567":1,"568":1,"706":1,"725":1,"727":1,"728":1,"775":1},"1":{"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1,"751":1,"752":1,"753":1,"754":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"776":1,"777":1,"778":1,"779":1,"780":1},"2":{"81":1,"237":1,"240":1,"241":1,"243":1,"248":1,"283":1,"298":2,"302":1,"307":1,"310":1,"311":1,"315":5,"341":1,"344":1,"358":1,"360":1,"373":1,"385":1,"387":1,"390":1,"414":1,"417":1,"418":1,"419":1,"425":1,"429":1,"458":1,"462":1,"470":1,"471":1,"531":1,"567":1,"568":1,"595":1,"596":1,"610":1,"612":1,"613":1,"616":1,"619":1,"620":1,"651":1,"695":3,"706":1,"717":1,"725":1,"727":1,"728":1,"737":1,"761":1,"763":2,"765":2,"774":1,"775":1}}],["tutorials",{"2":{"0":1,"3":2,"23":1,"534":1,"572":1,"725":1}}],["turned",{"2":{"366":1}}],["turn",{"2":{"42":1,"76":1,"199":1}}],["twitch",{"2":{"40":1}}],["twitter",{"2":{"26":1,"39":2,"40":1,"562":1}}],["two",{"2":{"39":1,"74":1,"79":1,"137":2,"145":1,"151":1,"166":1,"168":1,"169":1,"175":1,"204":2,"215":2,"229":1,"238":1,"247":1,"266":1,"370":1,"371":1,"405":1,"424":1,"427":1,"434":1,"455":1,"467":1,"469":1,"525":1,"540":1,"549":1,"578":1,"585":1,"640":1,"644":1,"649":1,"668":1,"721":1}}],["typically",{"2":{"224":1,"692":1}}],["typical",{"2":{"127":1,"578":1,"720":2}}],["type=1",{"2":{"539":1}}],["type=spanbatch",{"2":{"539":1}}],["type=$node",{"2":{"390":6,"392":6,"393":6}}],["type=full",{"2":{"390":1}}],["type=fullexport",{"2":{"390":1}}],["type=bridge",{"2":{"390":1}}],["type=bridgeexport",{"2":{"390":1}}],["type=light",{"2":{"390":1,"704":2,"705":2}}],["type=lightexport",{"2":{"390":1}}],["type=ledger`",{"2":{"202":2}}],["type=private",{"2":{"202":4}}],["type",{"0":{"85":1},"2":{"63":1,"65":2,"68":2,"125":8,"126":7,"147":4,"156":2,"159":2,"178":1,"202":4,"245":2,"266":4,"291":4,"292":8,"294":2,"295":3,"296":5,"314":2,"316":2,"317":2,"318":2,"319":2,"320":4,"324":4,"328":2,"329":12,"334":4,"335":2,"336":4,"344":1,"349":1,"390":13,"392":8,"393":8,"399":1,"422":2,"429":12,"466":4,"484":1,"493":2,"499":3,"521":2,"528":1,"531":1,"533":1,"534":1,"538":2,"539":2,"559":2,"562":1,"569":1,"577":1,"628":2,"696":1,"698":7,"699":6,"700":6,"704":2,"705":6,"736":4,"740":4,"752":4,"760":2,"771":3,"773":2,"783":1,"784":1}}],["typescargo",{"2":{"776":1}}],["types",{"0":{"369":1},"1":{"370":1,"371":1,"372":1},"2":{"36":1,"63":1,"65":1,"163":6,"173":1,"183":1,"313":1,"326":1,"328":1,"344":1,"396":1,"484":2,"499":1,"569":1,"571":1,"581":1,"591":2,"596":4,"597":4,"638":1,"708":4,"734":1,"769":4,"776":2,"777":2}}],["typography",{"2":{"52":1}}],["typos",{"2":{"2":1}}],["tasked",{"2":{"632":1}}],["tasks",{"2":{"93":1,"398":1,"647":1}}],["tar",{"2":{"372":24,"398":4,"399":32}}],["targets",{"2":{"275":6}}],["targetblock",{"2":{"219":1}}],["target",{"2":{"140":1,"201":1,"202":1,"204":1,"210":1,"211":3,"215":3,"216":2,"221":1,"260":2,"336":1,"602":4,"604":4,"605":4,"606":4,"675":1}}],["targeting",{"2":{"90":1}}],["taking",{"2":{"109":1,"156":1,"157":1,"160":1,"169":1,"370":1}}],["taken",{"2":{"214":1}}],["takes",{"2":{"109":1,"141":1,"151":1,"214":2,"215":1,"217":1,"708":2,"711":1,"743":1,"771":1,"777":2,"779":1}}],["takeaways",{"2":{"32":1}}],["take",{"2":{"8":1,"47":1,"109":1,"122":1,"125":1,"154":1,"155":1,"159":1,"175":1,"191":1,"194":1,"199":1,"203":1,"302":1,"325":1,"328":1,"355":1,"371":1,"561":1,"641":1,"646":1,"650":1}}],["tab=staking",{"2":{"682":1}}],["tab",{"2":{"77":2,"79":2,"208":1,"256":1,"698":1}}],["tables",{"2":{"569":1}}],["table",{"2":{"68":1,"86":1,"679":1,"680":1}}],["tag",{"2":{"39":1,"311":6,"341":6,"343":2,"390":6,"392":6,"393":6,"556":2,"559":2,"704":2}}],["tags",{"2":{"30":1,"311":6,"341":6}}],["talented",{"2":{"37":1}}],["talks",{"2":{"34":1,"37":1,"40":1,"42":5}}],["talk",{"2":{"34":1,"37":1}}],["tailored",{"2":{"47":1,"58":1}}],["tailor",{"2":{"36":1,"38":1,"42":1}}],["t",{"0":{"637":1},"2":{"26":1,"29":1,"34":1,"37":1,"39":1,"40":3,"79":1,"90":1,"91":1,"109":2,"130":1,"136":1,"144":2,"155":1,"156":1,"157":1,"159":1,"160":1,"161":2,"174":1,"183":1,"199":1,"202":3,"208":1,"233":2,"287":4,"299":1,"301":1,"344":1,"371":1,"373":1,"377":1,"380":1,"383":18,"414":1,"428":1,"432":1,"483":1,"523":1,"540":1,"542":1,"550":1,"580":1,"581":1,"582":2,"584":1,"597":2,"620":1,"625":19,"631":1,"632":2,"637":2,"683":1,"726":2,"739":1,"762":1,"782":2}}],["tiny",{"2":{"784":1}}],["ti",{"2":{"704":2,"705":2}}],["tia",{"0":{"651":1,"653":1,"656":1,"657":1,"658":1,"660":1,"661":1,"662":1,"665":1,"666":1,"679":1,"684":1,"685":1,"686":1,"692":1},"1":{"652":1,"653":1,"654":2,"655":2,"656":2,"657":2,"658":1,"659":2,"660":2,"661":2,"662":1,"663":2,"664":2,"665":2,"666":2,"680":1,"685":1,"686":1,"687":2,"688":2,"689":2,"690":2,"691":2,"692":2,"693":2,"694":2},"2":{"651":3,"656":1,"674":1,"675":3,"677":1,"678":1,"679":1,"680":3,"685":2,"687":2,"688":1,"689":1,"690":1,"692":1,"693":2,"755":2,"782":6,"784":1}}],["title",{"2":{"266":6,"267":2}}],["tips",{"2":{"670":1}}],["tip",{"2":{"91":1,"216":1,"217":1,"245":1,"294":2,"309":1,"324":1,"334":2,"369":2,"371":2,"399":1,"422":1,"428":1,"453":1,"465":1,"493":1,"537":2,"542":1,"543":1,"544":1,"559":1,"562":1,"617":1,"625":1,"698":1,"704":1,"731":1,"734":1,"735":1,"736":1,"738":1,"742":1,"765":1,"769":1,"771":1}}],["timing",{"2":{"58":1,"592":1}}],["times",{"2":{"550":1,"641":1}}],["timestamps",{"2":{"557":1}}],["timestamp",{"2":{"294":3,"536":2,"614":2,"620":2,"675":1,"752":2}}],["timeseries",{"2":{"275":2}}],["timeouts",{"2":{"528":1}}],["timeout",{"2":{"294":2,"429":4,"597":2}}],["timely",{"2":{"24":1}}],["time",{"2":{"13":1,"14":1,"30":1,"39":1,"86":2,"90":1,"130":1,"211":2,"217":1,"233":1,"275":2,"281":1,"287":1,"294":2,"295":4,"302":1,"344":1,"369":2,"429":4,"431":1,"523":1,"530":1,"539":1,"540":1,"580":1,"589":1,"592":2,"597":2,"602":1,"606":1,"634":1,"649":1,"675":1,"720":1,"752":2,"769":1,"773":1}}],["tiers",{"2":{"22":1}}],["tier",{"2":{"22":1,"58":1}}],["tryfinalizecommit",{"2":{"383":2,"625":2}}],["try",{"2":{"361":1,"438":1,"738":1,"762":1,"765":1,"774":1,"782":2}}],["trying",{"2":{"109":1,"336":1,"337":1,"558":1,"762":1}}],["tr",{"2":{"361":10,"372":6}}],["treated",{"2":{"210":1,"589":1}}],["trees",{"0":{"644":1},"2":{"640":1,"644":1,"731":1}}],["tree",{"2":{"110":2,"118":2,"119":1,"139":2,"156":6,"159":6,"188":1,"644":2,"646":2,"649":1}}],["trpc",{"2":{"136":11,"143":4,"144":8,"148":2,"150":4,"153":2,"163":2}}],["tries",{"2":{"650":1}}],["triggered",{"2":{"400":3}}],["triggering",{"2":{"179":1}}],["trigger",{"2":{"179":1}}],["trick",{"2":{"110":1}}],["tripods",{"2":{"34":1}}],["truth",{"2":{"139":1}}],["true",{"2":{"91":6,"118":2,"144":2,"147":1,"148":2,"150":2,"210":1,"211":2,"274":4,"313":2,"320":1,"326":2,"352":1,"353":1,"371":3,"381":1,"429":10,"544":3,"559":4,"745":1}}],["trusts",{"2":{"355":1}}],["trustedpeers",{"2":{"355":1}}],["trustedpeer",{"0":{"355":1}}],["trustedhash",{"0":{"355":1},"2":{"355":1}}],["trusted",{"0":{"209":1,"338":1,"558":1},"1":{"339":1},"2":{"50":1,"208":3,"209":6,"210":6,"214":1,"238":2,"328":1,"338":8,"355":5,"371":2,"429":4,"476":3,"487":1,"488":1,"489":1,"506":1,"507":1,"508":1,"558":11,"559":6,"731":1}}],["trust",{"2":{"39":1,"338":3,"371":4,"429":4,"558":2,"640":1,"650":1}}],["trustworthy",{"2":{"18":1}}],["troubles",{"2":{"493":1}}],["troubleshooting",{"0":{"323":1,"396":1,"570":1,"762":1},"1":{"324":1,"325":1,"326":1,"327":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1,"336":1,"337":1},"2":{"54":1,"95":1,"244":1,"245":1,"309":1,"343":1,"345":1,"390":1,"422":2,"453":1,"465":1,"570":1,"617":1,"698":1,"704":2,"735":1,"736":1,"738":1}}],["trolling",{"2":{"7":1}}],["traditional",{"2":{"188":1,"455":1,"647":1}}],["tracking",{"2":{"339":1}}],["trackers",{"2":{"276":1}}],["track",{"2":{"30":1,"110":1,"127":1,"316":1}}],["transients",{"2":{"322":1}}],["transitions",{"2":{"130":1,"179":1,"187":1,"191":1,"194":1,"647":1}}],["transition",{"2":{"18":1,"163":4,"179":2,"183":1}}],["transcript15",{"2":{"214":4}}],["transcript14",{"2":{"214":4}}],["transcript13",{"2":{"214":4}}],["transcript12",{"2":{"214":4}}],["transcript11",{"2":{"214":4}}],["transcript06",{"2":{"214":4}}],["transcript05",{"2":{"214":4}}],["transcript04",{"2":{"214":4}}],["transact",{"2":{"400":1,"682":1}}],["transactopts",{"2":{"163":2}}],["transactionindex",{"2":{"537":2}}],["transaction",{"0":{"145":1,"146":2,"149":1,"199":1,"364":1,"380":1,"449":1,"536":1,"537":1,"607":1,"622":1,"649":1},"1":{"147":2,"148":2,"150":1,"608":1,"609":1,"650":1},"2":{"77":4,"79":3,"80":3,"85":3,"86":3,"87":4,"93":14,"127":1,"130":1,"137":3,"144":8,"145":4,"146":3,"147":3,"148":2,"149":1,"150":4,"155":1,"156":1,"161":2,"163":4,"164":1,"167":1,"172":2,"175":1,"180":2,"191":1,"199":13,"202":3,"204":2,"278":1,"279":4,"283":1,"294":3,"301":1,"303":2,"363":1,"366":1,"400":1,"402":1,"412":2,"449":1,"483":4,"518":1,"523":1,"528":1,"536":4,"537":2,"578":2,"581":2,"582":1,"585":1,"586":5,"588":2,"589":3,"590":10,"591":1,"592":8,"597":14,"599":1,"608":2,"620":3,"622":1,"627":2,"628":3,"629":1,"633":3,"634":3,"635":2,"636":2,"638":2,"639":2,"640":1,"647":1,"649":3,"656":1,"657":1,"660":2,"661":1,"666":1,"668":4,"669":2,"743":3,"745":3,"746":1,"755":1,"760":1}}],["transactions",{"0":{"366":1,"523":1,"592":1,"668":1},"2":{"68":1,"74":1,"77":2,"79":1,"80":1,"81":1,"87":2,"88":1,"92":1,"127":1,"130":1,"134":1,"137":1,"150":1,"227":1,"244":1,"245":1,"252":1,"260":2,"280":1,"366":1,"380":5,"381":1,"400":1,"406":1,"422":3,"465":1,"466":1,"471":1,"493":1,"505":1,"506":1,"508":1,"523":3,"536":3,"577":3,"578":2,"581":1,"585":2,"586":2,"587":2,"592":1,"597":4,"607":3,"608":1,"609":2,"622":1,"627":1,"634":1,"640":1,"641":1,"642":1,"646":1,"647":6,"648":1,"649":6,"650":2,"668":2,"669":2,"687":1,"693":1,"715":1,"716":1,"730":1,"735":1,"736":1,"763":1,"783":1,"784":1}}],["transferred",{"2":{"437":1}}],["transferring",{"2":{"93":2}}],["transferhermes",{"2":{"434":1}}],["transfer",{"0":{"437":1,"755":1},"1":{"438":1},"2":{"86":1,"255":1,"265":1,"427":1,"429":4,"434":7,"435":4,"437":6,"438":1,"680":1,"755":7}}],["translations",{"2":{"16":2}}],["teach",{"2":{"737":1}}],["teams",{"2":{"526":1}}],["team",{"2":{"26":1,"30":1,"35":1,"37":1,"39":1,"46":1,"81":1,"93":1,"170":1,"191":1,"194":1,"197":1,"217":1,"218":1,"238":1,"558":1,"559":1}}],["tee",{"2":{"602":2,"604":2,"605":2,"606":2}}],["territories",{"2":{"479":1}}],["term",{"2":{"675":1}}],["terminal",{"2":{"202":1,"312":2,"343":1,"426":1,"464":1,"476":1,"557":1,"559":2,"561":1,"599":1,"760":1,"765":1}}],["terms",{"2":{"13":1,"14":1,"665":1}}],["text|json",{"2":{"303":2}}],["text",{"2":{"266":1,"267":1,"303":2,"451":1,"743":2,"745":1}}],["texthttps",{"2":{"136":2}}],["text$request",{"2":{"70":1,"309":1,"510":1,"736":1}}],["temp",{"2":{"312":1,"342":1,"343":1}}],["temporarily",{"2":{"281":1}}],["temporary",{"0":{"14":1},"2":{"13":1,"14":1,"289":1,"322":1,"400":1}}],["template",{"2":{"213":1,"214":2,"539":1}}],["templates",{"2":{"91":1}}],["tendermintrpc",{"2":{"109":1}}],["tendermint",{"2":{"91":3,"136":1,"140":4,"142":1,"143":4,"144":10,"147":1,"150":4,"152":1,"163":22,"209":1,"211":1,"218":1,"238":1,"260":8,"272":2,"303":2,"375":2,"383":29,"428":2,"434":8,"444":2,"452":2,"597":6,"620":2,"625":30,"646":6,"715":2,"716":1,"717":1,"719":1,"720":2,"752":4}}],["teststaking",{"2":{"449":1}}],["testtia",{"2":{"447":1}}],["testkey2",{"2":{"518":2,"519":1}}],["testkey2celestia",{"2":{"518":1}}],["testkeycelestia",{"2":{"516":1}}],["testkey",{"2":{"446":1,"516":2,"521":2}}],["test3",{"2":{"279":4}}],["test2sig",{"2":{"279":4}}],["test2",{"2":{"279":8}}],["test1sig",{"2":{"279":4}}],["test1",{"2":{"279":8}}],["testcelestia",{"2":{"261":1,"299":1,"308":1,"475":2}}],["test",{"2":{"156":1,"157":1,"159":1,"160":1,"214":4,"245":3,"246":1,"251":2,"261":1,"275":1,"279":6,"289":1,"299":1,"303":2,"308":1,"412":2,"422":3,"423":1,"429":4,"431":1,"439":2,"446":1,"447":1,"449":1,"457":1,"466":4,"468":1,"475":2,"476":4,"477":5,"499":2,"521":2,"552":1,"569":2,"698":6,"699":6,"700":6,"704":4,"705":4,"736":4,"768":4}}],["tested",{"2":{"96":1,"526":1,"539":1,"718":1}}],["testing",{"0":{"477":1},"2":{"59":3,"60":1,"254":1,"478":1,"495":1,"547":1}}],["testnetwork",{"2":{"439":1}}],["testnets",{"0":{"549":1},"1":{"550":1,"551":1,"552":1,"553":1},"2":{"82":1,"103":1,"430":1,"526":1,"549":1,"582":1,"782":1,"784":1}}],["testnet",{"0":{"91":1,"249":1,"318":1,"443":1,"467":1,"472":1,"499":1,"510":1,"544":1,"552":1,"553":1,"683":1},"1":{"250":1,"251":1,"252":1,"253":1,"254":1,"255":1,"256":1,"257":1,"258":1,"259":1,"444":1,"445":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"473":1,"474":1,"475":1,"476":1,"477":1,"500":1,"501":1,"502":1,"503":1,"504":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1},"2":{"23":3,"26":1,"59":3,"60":1,"76":1,"81":2,"82":3,"84":5,"87":5,"90":1,"97":1,"136":1,"231":3,"244":1,"245":4,"249":2,"250":5,"251":1,"252":1,"254":3,"255":2,"256":1,"259":1,"283":1,"289":1,"297":1,"298":2,"301":1,"305":1,"318":1,"361":1,"402":1,"403":1,"422":4,"427":2,"429":11,"430":3,"432":1,"433":6,"434":8,"435":3,"439":1,"443":2,"445":1,"448":2,"453":1,"457":2,"465":1,"466":1,"467":2,"472":1,"499":1,"505":3,"506":6,"507":6,"508":6,"510":1,"511":2,"512":8,"513":1,"526":1,"540":7,"542":1,"544":2,"552":2,"555":1,"556":1,"557":2,"559":1,"563":1,"617":1,"679":1,"683":4,"704":1,"735":1,"736":2,"762":2,"765":1,"782":2,"784":5}}],["telemetry",{"2":{"429":6}}],["telegram",{"2":{"39":2,"73":1,"277":1,"498":1,"513":1,"554":1}}],["tell",{"2":{"42":1}}],["tech",{"2":{"36":2,"38":1,"107":1,"487":1,"488":1,"489":1,"490":1}}],["technologies",{"2":{"42":1,"53":1,"479":1,"581":1}}],["technology",{"2":{"7":1,"36":1,"763":1}}],["technical",{"2":{"26":1,"30":1,"42":1}}],["though",{"2":{"647":1,"649":1}}],["thought",{"2":{"125":2}}],["thorough",{"2":{"185":1}}],["those",{"2":{"7":1,"13":1,"14":1,"33":1,"34":1,"40":3,"43":1,"125":1,"126":1,"139":1,"168":1,"199":1,"204":2,"266":1,"450":1,"499":1,"523":1,"535":1,"577":2,"578":1,"636":1,"638":1,"641":1,"715":1,"719":1}}],["thus",{"2":{"90":1,"91":1,"109":1,"111":1,"643":1,"647":3,"649":2}}],["thank",{"2":{"38":1,"81":1}}],["thanks",{"2":{"33":1,"108":1}}],["thanking",{"2":{"32":1}}],["than",{"2":{"24":1,"199":1,"226":1,"274":2,"281":1,"301":1,"329":1,"337":1,"455":1,"483":1,"578":1,"586":2,"587":1,"636":1,"671":1,"672":1,"675":2,"698":1,"720":1}}],["that",{"0":{"144":1,"163":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"187":1,"188":1,"189":1,"190":1,"192":1,"193":1,"631":1},"1":{"180":1,"181":1,"182":1,"184":1,"185":1,"188":1,"189":1,"191":1,"192":1,"193":1},"2":{"6":1,"7":1,"8":2,"18":1,"21":1,"23":4,"29":1,"30":1,"31":1,"34":2,"35":1,"36":1,"38":1,"42":1,"47":2,"58":3,"59":2,"67":1,"68":1,"86":3,"87":2,"89":1,"91":6,"93":2,"96":1,"104":2,"105":1,"107":1,"109":3,"110":4,"111":4,"117":2,"118":4,"120":2,"121":1,"122":13,"124":2,"125":18,"126":18,"127":4,"128":2,"130":6,"136":3,"137":3,"139":14,"141":1,"144":6,"145":2,"149":1,"154":13,"155":2,"156":1,"157":1,"160":9,"161":2,"163":12,"164":2,"165":3,"166":2,"167":1,"168":7,"169":1,"170":1,"172":1,"174":7,"175":8,"178":6,"179":6,"180":2,"182":1,"183":4,"185":1,"186":1,"187":4,"188":2,"191":3,"194":6,"197":2,"199":1,"202":6,"203":1,"204":3,"205":3,"206":1,"208":1,"209":1,"210":3,"211":1,"212":1,"214":1,"215":7,"216":1,"217":1,"218":1,"219":1,"221":1,"225":1,"227":4,"228":2,"233":3,"234":1,"235":1,"238":1,"244":1,"245":1,"248":1,"250":1,"251":1,"252":1,"255":1,"259":1,"266":5,"267":2,"275":5,"278":1,"281":3,"282":2,"284":1,"287":1,"289":2,"295":2,"298":1,"301":1,"303":1,"309":1,"310":1,"312":1,"313":4,"314":1,"316":1,"321":1,"322":6,"326":4,"331":1,"334":2,"336":1,"337":2,"338":4,"341":1,"344":1,"347":1,"355":1,"361":2,"367":1,"369":1,"373":1,"381":1,"383":1,"384":1,"387":1,"388":2,"391":1,"398":1,"399":1,"400":1,"404":3,"407":1,"408":1,"409":1,"413":3,"414":1,"415":1,"422":2,"425":1,"427":2,"428":2,"430":3,"432":2,"434":1,"435":1,"450":1,"452":2,"454":1,"455":1,"457":1,"459":1,"464":1,"466":1,"478":1,"479":1,"483":3,"492":1,"493":1,"499":1,"504":1,"505":3,"524":1,"526":1,"536":1,"539":1,"540":3,"542":2,"549":1,"555":1,"556":2,"557":2,"558":2,"559":1,"562":1,"563":1,"564":1,"566":1,"572":1,"574":1,"577":2,"578":2,"580":1,"581":3,"582":3,"586":1,"587":1,"588":3,"589":1,"590":5,"592":2,"597":6,"602":1,"614":1,"619":1,"620":4,"625":1,"627":4,"629":1,"630":1,"631":8,"632":2,"634":1,"635":1,"636":1,"637":1,"638":6,"639":1,"640":2,"641":3,"642":2,"643":1,"644":6,"646":4,"647":9,"648":4,"649":5,"650":4,"651":1,"660":1,"669":1,"670":5,"671":2,"672":2,"680":1,"688":1,"692":1,"695":1,"696":1,"698":3,"704":1,"709":1,"710":1,"715":1,"717":1,"719":1,"720":4,"735":1,"736":1,"738":5,"739":1,"740":1,"745":1,"755":1,"762":1,"763":2,"769":2,"770":1,"771":2,"773":1,"778":1,"782":5,"783":1,"784":1}}],["think",{"2":{"125":1}}],["things",{"0":{"639":1,"773":1},"2":{"93":2,"743":1}}],["third",{"2":{"22":4,"372":1,"402":1,"404":1,"412":1,"713":1}}],["this",{"0":{"636":1},"2":{"1":1,"2":2,"4":1,"8":1,"9":1,"11":1,"13":1,"14":1,"16":2,"22":4,"23":1,"26":1,"36":2,"37":3,"38":2,"39":1,"40":2,"41":1,"42":7,"43":1,"44":1,"46":1,"47":1,"49":1,"50":2,"51":2,"53":1,"54":2,"55":2,"57":1,"58":1,"63":1,"68":1,"69":1,"74":2,"77":1,"81":4,"83":1,"84":2,"85":4,"86":7,"87":4,"88":2,"90":3,"91":1,"92":2,"93":2,"94":1,"96":3,"104":2,"105":1,"109":3,"110":3,"111":1,"117":1,"122":5,"124":4,"125":8,"126":6,"127":3,"128":3,"130":1,"139":4,"140":1,"141":2,"145":1,"147":1,"151":1,"155":3,"156":3,"160":3,"163":4,"165":1,"166":1,"167":1,"169":1,"171":2,"174":5,"175":3,"179":3,"183":2,"186":1,"187":2,"193":1,"199":3,"200":1,"202":2,"204":1,"205":1,"208":2,"213":1,"214":5,"215":5,"217":1,"218":1,"219":1,"221":2,"227":2,"237":1,"238":2,"245":1,"250":1,"254":1,"266":3,"271":2,"275":7,"276":1,"279":4,"281":2,"283":2,"287":2,"289":1,"291":2,"294":1,"298":2,"302":1,"303":5,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"314":2,"315":3,"320":2,"321":2,"322":12,"324":2,"329":2,"331":3,"332":1,"334":1,"335":1,"337":5,"338":3,"341":4,"343":2,"350":2,"353":2,"356":1,"361":2,"363":1,"365":2,"367":1,"368":3,"370":1,"371":2,"373":1,"375":1,"376":1,"377":2,"378":1,"380":7,"381":3,"383":1,"385":1,"387":1,"388":2,"391":4,"392":1,"396":1,"397":2,"398":2,"400":2,"402":1,"408":1,"413":1,"414":1,"426":1,"427":2,"429":1,"432":2,"434":2,"439":2,"443":1,"445":1,"446":2,"449":1,"450":5,"455":3,"456":2,"457":2,"458":1,"459":1,"462":1,"471":1,"472":1,"475":2,"478":1,"479":1,"483":1,"484":1,"493":1,"499":2,"507":1,"510":1,"515":1,"516":1,"518":1,"523":2,"524":1,"528":1,"531":3,"535":1,"536":1,"539":2,"540":5,"542":2,"547":1,"555":2,"556":1,"557":4,"558":5,"559":2,"561":2,"562":5,"563":1,"564":1,"566":1,"569":1,"572":2,"581":1,"582":1,"583":1,"586":2,"588":1,"589":3,"590":3,"591":3,"592":4,"597":10,"605":1,"607":1,"608":1,"610":1,"615":1,"620":2,"625":1,"627":1,"628":1,"629":1,"630":1,"631":2,"639":1,"642":2,"643":2,"644":2,"646":1,"647":4,"648":1,"649":2,"650":2,"651":2,"654":1,"669":1,"670":1,"671":2,"672":4,"680":1,"688":1,"693":1,"695":3,"697":1,"698":1,"704":1,"705":3,"706":1,"707":2,"709":2,"710":2,"711":1,"713":1,"715":1,"717":2,"719":1,"720":1,"728":1,"731":2,"734":1,"735":1,"737":1,"738":2,"741":2,"742":2,"743":1,"745":3,"750":1,"751":1,"752":2,"755":1,"758":1,"760":1,"763":2,"765":5,"768":1,"769":2,"771":1,"774":1,"775":1,"776":2,"778":2,"779":1,"781":1,"782":4}}],["thread",{"2":{"630":1}}],["threatening",{"2":{"8":1}}],["threshold",{"2":{"278":1,"279":2,"429":4,"588":1}}],["three",{"2":{"208":1,"229":1,"644":2,"647":1,"746":1}}],["throughput",{"2":{"221":1,"226":1,"227":1,"642":1,"647":2}}],["throughout",{"2":{"46":1,"763":1}}],["through",{"2":{"13":1,"32":1,"39":1,"80":1,"91":1,"93":2,"202":1,"234":1,"274":1,"275":1,"307":1,"310":1,"329":1,"414":1,"437":1,"458":1,"472":1,"528":1,"531":1,"589":1,"590":1,"604":1,"605":1,"608":1,"610":1,"614":1,"681":1,"690":1,"706":1,"763":1,"775":1}}],["theta",{"2":{"429":9,"430":2,"432":1,"433":6,"434":8,"435":3}}],["then",{"2":{"76":1,"77":1,"86":1,"87":1,"92":1,"109":1,"110":1,"124":2,"125":1,"127":2,"130":1,"139":5,"141":1,"148":1,"151":3,"156":1,"157":1,"162":1,"163":1,"164":1,"168":1,"174":1,"175":1,"179":2,"183":1,"191":3,"194":1,"197":1,"199":2,"202":3,"205":1,"208":1,"210":1,"211":2,"212":1,"214":1,"215":2,"216":1,"234":1,"235":2,"263":2,"266":2,"272":3,"275":3,"314":1,"321":2,"329":1,"334":1,"336":1,"352":1,"369":1,"371":1,"373":1,"383":1,"398":2,"407":1,"412":1,"450":1,"455":2,"555":1,"577":1,"586":1,"589":2,"590":1,"591":1,"592":1,"597":2,"599":1,"620":1,"625":1,"627":1,"641":2,"650":3,"660":1,"665":1,"668":1,"669":1,"700":1,"741":1,"745":1,"755":1,"762":1,"770":1,"771":3,"773":2,"774":1,"783":1,"784":1}}],["therefore",{"2":{"60":1,"126":1,"597":2,"627":1,"642":1}}],["there",{"0":{"638":1},"2":{"22":1,"36":1,"39":1,"44":1,"69":1,"72":1,"86":1,"130":1,"169":1,"183":1,"186":1,"199":1,"204":1,"215":1,"254":1,"266":3,"325":1,"370":1,"427":1,"455":1,"483":2,"495":1,"496":1,"498":1,"510":1,"512":1,"513":1,"528":1,"531":1,"554":1,"578":1,"580":1,"581":1,"584":1,"586":1,"588":1,"631":1,"632":2,"637":1,"638":1,"641":1,"642":1,"647":1,"717":1,"721":1,"743":1}}],["these",{"2":{"11":1,"13":1,"14":1,"29":1,"33":1,"34":1,"35":1,"39":1,"44":1,"64":1,"65":1,"67":1,"68":1,"87":1,"88":1,"90":1,"91":1,"122":2,"125":1,"126":2,"137":1,"139":1,"142":2,"147":1,"152":1,"156":1,"159":1,"168":1,"169":2,"171":1,"175":2,"182":1,"187":2,"194":1,"208":1,"211":2,"215":1,"218":1,"229":1,"233":1,"267":1,"275":2,"301":1,"312":1,"314":1,"342":2,"361":1,"371":1,"379":1,"381":1,"396":1,"398":2,"427":1,"443":1,"482":1,"483":1,"485":1,"492":1,"493":2,"503":1,"504":1,"505":1,"526":1,"578":1,"581":1,"584":1,"589":2,"591":1,"599":1,"620":1,"641":1,"647":2,"649":2,"672":1,"714":1,"720":1,"739":2,"746":1,"771":1}}],["they",{"2":{"7":1,"8":1,"11":1,"22":1,"34":1,"38":4,"39":2,"40":1,"41":1,"58":1,"60":1,"67":1,"68":1,"86":2,"88":1,"130":1,"142":1,"147":1,"152":1,"159":1,"169":1,"178":2,"179":2,"183":2,"216":1,"217":1,"252":1,"267":1,"281":3,"322":1,"371":1,"432":1,"449":1,"450":1,"452":1,"454":1,"459":2,"492":1,"493":1,"504":1,"505":1,"509":1,"528":1,"552":1,"577":2,"578":1,"580":1,"582":1,"588":1,"590":1,"592":3,"607":1,"609":1,"629":2,"631":2,"632":1,"638":1,"639":2,"642":1,"647":1,"672":1,"709":1,"710":1,"718":1,"738":1,"769":1,"778":1,"782":2}}],["their",{"2":{"7":1,"27":1,"30":1,"32":1,"34":2,"36":2,"37":2,"38":6,"39":3,"40":2,"41":2,"42":1,"47":1,"58":1,"59":1,"60":1,"67":1,"68":1,"86":2,"124":1,"139":1,"164":1,"165":3,"166":1,"173":1,"178":1,"179":1,"202":1,"217":1,"221":1,"249":1,"251":1,"275":2,"281":3,"321":1,"328":1,"348":1,"366":1,"371":1,"448":1,"450":3,"454":1,"455":1,"492":1,"493":1,"499":2,"504":1,"505":1,"524":1,"525":1,"526":1,"528":1,"535":1,"552":1,"572":1,"580":2,"581":2,"582":3,"588":1,"592":1,"609":1,"634":1,"638":1,"647":1,"648":2,"670":1,"672":4,"677":1,"688":3,"689":2,"722":1,"724":1,"728":1,"731":1}}],["theme",{"2":{"37":2}}],["them",{"2":{"2":1,"32":1,"34":1,"38":4,"39":1,"40":3,"41":3,"63":1,"104":1,"109":1,"121":1,"139":1,"156":3,"159":1,"164":1,"168":1,"172":1,"182":2,"203":2,"208":1,"211":2,"215":1,"217":1,"235":1,"281":1,"326":1,"334":1,"339":1,"371":1,"449":1,"450":1,"455":2,"484":1,"499":1,"505":1,"578":1,"640":1,"674":1,"726":1,"731":1,"769":1}}],["the",{"0":{"1":1,"17":1,"18":1,"30":1,"31":1,"32":1,"89":1,"90":1,"121":1,"130":1,"137":1,"138":1,"139":1,"146":1,"149":1,"154":2,"161":1,"163":1,"199":2,"201":1,"203":1,"204":2,"208":1,"209":1,"213":1,"214":1,"215":1,"218":1,"232":1,"241":1,"242":1,"244":1,"245":1,"246":1,"248":1,"250":1,"270":1,"285":1,"286":1,"287":1,"288":2,"295":1,"296":1,"297":2,"327":1,"335":1,"336":2,"348":1,"359":1,"361":1,"373":1,"379":1,"392":1,"393":1,"413":1,"418":1,"420":1,"421":1,"422":1,"423":1,"425":1,"426":1,"436":1,"449":1,"450":1,"453":1,"455":1,"464":1,"465":1,"468":1,"474":1,"475":1,"476":1,"537":1,"538":1,"546":1,"557":1,"558":1,"559":1,"564":1,"584":1,"592":1,"594":1,"595":1,"596":1,"597":1,"602":1,"615":1,"617":1,"618":1,"619":1,"620":1,"628":1,"631":1,"634":1,"635":1,"649":1,"664":1,"696":1,"746":1,"749":1,"767":1},"1":{"18":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"138":1,"139":1,"147":1,"148":1,"150":1,"155":2,"156":2,"157":2,"158":2,"159":2,"160":2,"161":2,"162":2,"163":2,"202":1,"203":1,"204":1,"205":3,"206":3,"207":3,"208":1,"209":2,"210":2,"211":1,"212":1,"214":1,"215":1,"233":1,"234":1,"235":1,"236":1,"243":1,"244":1,"245":1,"246":2,"247":2,"248":1,"286":1,"287":1,"288":1,"289":1,"328":1,"329":1,"330":1,"331":1,"332":1,"333":1,"421":1,"422":1,"424":1,"456":1,"466":1,"467":1,"468":1,"469":2,"470":1,"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"558":1,"565":1,"566":1,"567":1,"568":1,"569":1,"616":1,"617":1,"618":1,"619":2,"650":1,"697":1,"698":1,"699":1,"700":1,"701":1,"768":1,"769":1,"770":1,"771":1,"772":1,"773":1},"2":{"0":2,"1":2,"2":3,"3":2,"4":2,"7":4,"8":1,"9":1,"10":3,"11":1,"12":4,"13":2,"14":3,"15":1,"16":2,"18":5,"20":7,"21":3,"22":9,"23":17,"24":4,"25":3,"26":12,"27":3,"28":2,"29":1,"30":8,"31":4,"32":6,"33":2,"34":12,"35":4,"36":13,"37":15,"38":14,"39":9,"40":8,"41":7,"42":15,"43":2,"44":5,"46":5,"47":5,"48":2,"49":1,"50":2,"51":3,"53":4,"54":3,"55":3,"56":4,"57":1,"58":15,"59":2,"60":3,"63":5,"65":2,"67":1,"68":7,"70":2,"71":1,"73":2,"76":5,"77":7,"79":9,"80":6,"81":8,"84":6,"85":6,"86":40,"87":13,"88":7,"89":6,"90":12,"91":31,"92":2,"93":46,"94":3,"96":8,"97":5,"104":10,"105":2,"107":5,"108":3,"109":31,"110":18,"111":5,"112":14,"113":1,"116":1,"117":6,"118":7,"119":2,"120":4,"121":4,"122":34,"124":2,"125":54,"126":37,"127":25,"128":17,"130":34,"132":1,"133":2,"134":4,"136":11,"137":15,"139":27,"140":9,"141":8,"142":6,"143":2,"144":40,"145":10,"146":2,"147":10,"148":2,"149":5,"150":12,"151":9,"152":8,"153":6,"154":58,"155":9,"156":46,"157":12,"158":5,"159":24,"160":58,"161":26,"162":11,"163":65,"164":6,"165":3,"166":4,"167":4,"168":23,"169":15,"170":6,"171":8,"172":23,"173":3,"174":30,"175":47,"176":1,"178":4,"179":12,"180":6,"182":3,"183":23,"184":2,"185":5,"186":10,"187":29,"188":3,"190":2,"191":28,"193":1,"194":24,"196":1,"197":8,"199":31,"200":1,"201":4,"202":75,"203":23,"204":25,"205":9,"206":5,"208":16,"209":3,"210":51,"211":58,"212":6,"213":6,"214":24,"215":37,"216":9,"217":3,"218":13,"219":9,"221":11,"224":1,"225":4,"226":3,"227":20,"228":12,"229":2,"230":2,"231":3,"233":14,"234":9,"235":9,"236":1,"237":3,"238":13,"239":2,"240":1,"241":2,"243":3,"244":13,"245":9,"246":5,"247":5,"248":3,"249":1,"250":8,"252":4,"254":4,"255":2,"256":2,"257":1,"258":2,"259":1,"260":10,"261":3,"263":6,"266":22,"267":9,"268":1,"269":2,"270":1,"271":3,"272":3,"273":1,"274":7,"275":26,"276":4,"277":5,"278":3,"279":14,"281":20,"282":2,"283":2,"284":1,"286":2,"287":10,"288":1,"289":5,"291":4,"293":5,"294":15,"295":4,"296":3,"297":7,"298":3,"299":3,"300":1,"301":7,"302":4,"303":8,"304":1,"305":1,"308":3,"309":9,"310":1,"311":16,"312":10,"313":6,"314":2,"315":2,"316":6,"320":5,"321":11,"322":25,"324":3,"325":2,"326":8,"328":8,"329":4,"331":5,"332":3,"333":2,"334":4,"335":1,"336":8,"337":12,"338":13,"339":3,"341":15,"342":3,"343":10,"344":2,"345":3,"349":2,"350":3,"352":5,"353":3,"355":5,"356":2,"357":1,"358":1,"359":1,"360":1,"361":9,"363":1,"365":1,"366":1,"367":3,"368":5,"369":5,"370":6,"371":15,"372":5,"373":7,"376":1,"377":5,"378":3,"379":1,"380":6,"381":10,"383":6,"384":1,"385":1,"387":1,"388":8,"390":9,"391":7,"392":9,"393":2,"396":2,"398":5,"399":4,"400":6,"402":4,"403":2,"404":9,"405":8,"406":4,"407":6,"408":7,"409":2,"410":1,"412":4,"413":5,"414":1,"415":2,"416":2,"417":1,"418":1,"419":1,"421":1,"422":14,"423":5,"424":5,"425":2,"426":4,"427":5,"428":3,"429":5,"430":4,"431":5,"432":2,"433":2,"434":3,"435":2,"436":1,"437":5,"438":3,"439":1,"441":1,"442":1,"444":2,"445":5,"446":4,"447":2,"448":6,"449":6,"450":10,"451":4,"452":6,"453":3,"454":1,"455":15,"456":1,"457":3,"459":3,"460":1,"461":2,"462":1,"463":1,"464":4,"465":7,"466":10,"467":3,"468":5,"469":5,"470":2,"474":2,"475":3,"476":7,"477":6,"478":6,"479":2,"482":2,"483":17,"484":6,"485":1,"487":1,"492":1,"493":6,"494":2,"495":1,"497":1,"498":2,"499":10,"503":1,"504":1,"505":3,"506":4,"507":5,"508":3,"509":2,"510":2,"511":1,"513":2,"516":3,"518":1,"519":4,"520":2,"522":1,"523":6,"524":6,"525":6,"526":8,"528":9,"530":4,"531":6,"534":1,"536":2,"537":8,"538":2,"539":1,"540":15,"542":5,"543":1,"544":3,"547":3,"550":1,"552":2,"554":2,"555":1,"556":9,"557":7,"558":12,"559":16,"561":5,"562":17,"563":17,"565":1,"566":7,"567":1,"568":1,"569":6,"570":1,"571":3,"572":3,"578":4,"580":6,"581":5,"582":6,"583":2,"584":10,"586":5,"587":1,"588":10,"589":26,"590":43,"591":6,"592":13,"595":1,"596":15,"597":48,"598":3,"599":15,"601":1,"602":1,"604":2,"605":4,"606":5,"607":2,"608":1,"609":1,"610":1,"611":1,"612":2,"613":1,"614":10,"615":3,"616":1,"617":3,"618":1,"619":3,"620":17,"621":1,"622":1,"623":2,"625":14,"627":14,"628":9,"629":2,"630":2,"631":4,"632":7,"633":2,"634":3,"636":5,"637":6,"639":2,"640":4,"641":18,"642":9,"643":17,"644":32,"646":26,"647":24,"648":10,"649":47,"650":32,"651":3,"654":1,"655":2,"656":2,"657":2,"659":1,"660":4,"661":2,"664":2,"665":1,"668":16,"669":3,"670":4,"671":6,"672":10,"674":3,"675":9,"677":1,"679":3,"680":11,"681":2,"682":2,"683":2,"685":1,"687":2,"688":2,"689":1,"690":2,"692":1,"693":2,"694":1,"695":3,"696":4,"697":4,"698":13,"699":1,"700":1,"703":1,"704":13,"705":11,"706":2,"707":5,"708":23,"709":2,"710":14,"711":15,"712":2,"713":1,"715":5,"716":2,"717":7,"718":2,"719":2,"720":5,"721":5,"722":6,"723":1,"724":4,"725":6,"726":5,"727":1,"728":2,"730":1,"731":5,"732":1,"734":2,"735":9,"736":16,"737":2,"738":18,"739":10,"740":8,"741":6,"742":4,"743":21,"744":1,"745":19,"746":13,"748":4,"749":6,"750":3,"752":4,"755":4,"756":1,"757":4,"758":4,"760":8,"761":1,"762":2,"763":7,"764":1,"765":11,"766":2,"768":2,"769":14,"770":15,"771":53,"772":6,"773":21,"774":4,"775":1,"776":5,"777":19,"778":12,"779":9,"780":2,"782":19,"783":3,"784":3}}],["todo",{"2":{"597":6,"710":2,"769":2,"770":3,"771":3,"773":1}}],["today",{"2":{"231":1,"271":2}}],["too",{"0":{"337":1},"2":{"337":3,"449":2}}],["tools",{"2":{"455":1}}],["toolset",{"2":{"204":1}}],["toolkit",{"0":{"51":1},"1":{"52":1,"53":1,"54":1,"55":1,"56":1,"57":1},"2":{"50":1,"51":1}}],["tool",{"2":{"49":1,"204":1,"260":2,"273":1,"381":1,"528":1,"540":1,"566":2}}],["toolings",{"2":{"321":1}}],["tooling",{"2":{"23":1,"166":1,"168":1,"184":1}}],["tomlvim",{"2":{"429":1}}],["tomldiscard",{"2":{"381":1}}],["tomlexternal",{"2":{"378":1}}],["tomlsed",{"2":{"377":1}}],["tomlseeds=$",{"2":{"361":2}}],["tomlrpc",{"2":{"371":1}}],["tomlpruning",{"2":{"367":1,"368":1}}],["tomlpersistent",{"2":{"361":3}}],["tomlmin",{"2":{"365":1}}],["tomlindexer",{"2":{"364":1,"366":1,"380":1}}],["toml`",{"2":{"361":2}}],["toml",{"0":{"303":1,"346":1,"349":1},"1":{"347":1,"348":1,"349":1,"350":2,"351":2,"352":2,"353":2,"354":2,"355":2},"2":{"274":1,"275":1,"303":8,"322":1,"338":3,"349":4,"361":7,"363":1,"365":1,"366":1,"367":1,"368":2,"371":2,"377":2,"378":1,"380":2,"381":2,"429":3,"431":1,"435":1,"451":1,"544":2,"557":2,"558":2,"569":1,"622":1}}],["tombstoned",{"2":{"24":1}}],["toattestationproof",{"2":{"160":2,"163":4}}],["torowproofs",{"2":{"159":2,"163":4}}],["torowroots",{"2":{"158":2,"163":4}}],["tonamespacenode",{"2":{"156":4,"158":2,"163":6}}],["tonamespacemerklemultiproofs",{"2":{"156":2,"163":4}}],["tosliceofbytes",{"2":{"150":2}}],["token=$",{"2":{"740":4,"742":2,"760":2}}],["tokencelestia",{"2":{"738":1}}],["tokenbridgeretryablesender",{"2":{"98":1,"99":1}}],["tokenbridgecreator",{"2":{"98":1,"99":1}}],["tokenbridgedeployment",{"2":{"93":2}}],["token",{"0":{"265":1,"438":1,"565":1,"692":1,"740":1,"742":1},"2":{"82":1,"84":2,"86":8,"88":1,"91":8,"93":13,"95":1,"265":1,"267":1,"328":1,"437":1,"438":3,"538":2,"565":2,"596":4,"651":1,"688":3,"707":4,"708":4,"709":4,"710":4,"711":4,"738":7,"739":9,"740":6,"741":3,"742":2,"743":4,"748":1,"760":3,"770":2,"771":2,"773":2,"776":4,"777":4,"778":4,"779":4}}],["tokens",{"0":{"269":1,"467":1,"656":1,"665":1},"2":{"7":1,"37":1,"69":2,"70":1,"82":1,"86":1,"87":1,"245":3,"265":1,"269":2,"294":1,"309":2,"422":3,"427":1,"430":2,"438":1,"466":1,"467":1,"510":3,"561":2,"562":1,"614":1,"620":1,"651":1,"656":1,"657":1,"661":1,"664":1,"666":1,"679":1,"680":6,"736":2,"755":1,"762":2,"765":2}}],["touch",{"2":{"58":1}}],["together",{"2":{"46":1,"275":1,"454":1,"641":1,"647":1,"649":1,"650":1}}],["topology",{"2":{"371":1}}],["topic",{"2":{"30":1,"36":1,"37":1,"266":1,"636":1}}],["topics",{"2":{"2":1,"30":1,"37":2,"42":2,"229":1,"564":1}}],["top",{"2":{"23":2,"58":1,"76":1,"287":1,"487":1,"488":1,"489":1,"496":1,"512":1,"599":1,"646":1,"647":1,"659":1,"722":1,"783":1,"784":1}}],["totaldifficulty",{"2":{"536":2}}],["total",{"2":{"20":1,"21":1,"142":2,"144":2,"147":2,"152":2,"159":3,"160":2,"163":4,"174":1,"297":4,"483":5,"586":2,"588":1,"589":2,"590":6,"675":1,"679":1,"685":1,"752":4}}],["towards",{"2":{"18":1,"24":1,"38":1,"281":1}}],["toward",{"2":{"7":1,"15":1}}],["to",{"0":{"53":1,"75":1,"77":1,"79":1,"106":1,"127":1,"133":1,"134":1,"144":1,"154":1,"165":1,"199":1,"220":1,"229":1,"247":1,"271":1,"283":1,"336":1,"363":1,"384":1,"424":1,"454":1,"469":1,"531":1,"543":1,"544":1,"585":1,"597":1,"598":1,"614":1,"639":1,"651":1,"705":1,"709":1,"710":1,"720":1,"735":1,"755":1,"778":1,"782":1,"783":1,"784":1},"1":{"76":1,"77":1,"107":1,"108":1,"109":1,"110":1,"111":1,"112":1,"113":1,"155":1,"156":1,"157":1,"158":1,"159":1,"160":1,"161":1,"162":1,"163":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1,"174":1,"175":1,"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"195":1,"196":1,"197":1,"198":1,"199":1,"221":1,"222":1,"223":1,"224":1,"225":1,"226":1,"227":1,"228":1,"229":1,"230":1,"231":1,"284":1,"285":1,"286":1,"287":1,"288":1,"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":1,"300":1,"301":1,"302":1,"303":1,"304":1,"305":1,"364":1,"365":1,"385":1,"386":1,"387":1,"455":1,"456":1,"457":1,"532":1,"533":1,"534":1,"586":1,"587":1,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"652":1,"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1,"662":1,"663":1,"664":1,"665":1,"666":1},"2":{"0":2,"1":1,"2":4,"3":1,"6":3,"7":3,"8":3,"10":2,"13":1,"14":1,"16":1,"18":5,"20":5,"21":1,"22":1,"23":7,"24":3,"25":4,"26":5,"27":1,"29":3,"30":7,"31":1,"32":3,"33":2,"34":7,"35":4,"36":8,"37":14,"38":14,"39":10,"40":7,"41":14,"42":13,"43":1,"44":3,"46":4,"47":4,"48":2,"49":2,"50":2,"51":4,"53":2,"54":1,"55":1,"56":2,"57":1,"58":6,"60":3,"63":9,"64":1,"65":2,"67":3,"68":6,"69":1,"73":1,"74":1,"77":3,"79":7,"80":3,"81":3,"84":5,"85":7,"86":19,"87":10,"88":5,"90":15,"91":21,"92":2,"93":21,"94":1,"96":1,"97":1,"104":2,"105":3,"107":2,"108":2,"109":15,"110":6,"111":4,"112":8,"113":1,"116":1,"117":1,"118":6,"119":2,"120":1,"121":4,"122":21,"124":8,"125":23,"126":21,"127":8,"128":8,"130":13,"133":2,"134":1,"136":8,"137":5,"139":17,"140":5,"141":8,"142":4,"144":16,"145":5,"147":5,"151":8,"152":3,"154":27,"155":3,"156":12,"157":4,"159":7,"160":19,"161":10,"162":2,"163":22,"164":3,"165":4,"166":1,"168":24,"169":6,"170":3,"171":4,"172":5,"174":10,"175":18,"178":6,"179":6,"180":5,"182":2,"183":14,"184":1,"185":2,"186":3,"187":8,"188":1,"190":5,"191":5,"193":3,"194":8,"199":8,"200":2,"201":4,"202":44,"203":9,"204":11,"205":3,"206":4,"208":7,"210":14,"211":17,"212":3,"213":3,"214":7,"215":9,"216":5,"217":5,"218":1,"219":2,"221":5,"224":1,"225":1,"226":4,"227":17,"228":1,"230":1,"231":1,"233":3,"234":3,"235":5,"237":1,"238":5,"243":1,"244":7,"245":7,"246":1,"247":3,"249":2,"250":2,"251":2,"252":2,"254":3,"255":1,"256":2,"257":2,"258":1,"260":6,"263":4,"264":1,"265":6,"266":12,"267":10,"269":2,"273":2,"274":6,"275":23,"276":3,"277":4,"278":2,"279":8,"280":2,"281":10,"282":1,"283":3,"284":1,"287":1,"288":1,"289":3,"290":1,"291":2,"293":3,"294":8,"295":1,"297":1,"298":2,"299":3,"300":1,"301":6,"302":2,"303":3,"304":1,"305":2,"307":1,"308":2,"309":6,"310":1,"311":5,"312":4,"313":6,"314":1,"316":4,"320":10,"321":6,"322":8,"324":4,"325":2,"326":6,"328":2,"329":3,"331":2,"332":1,"333":3,"334":3,"336":4,"337":6,"338":5,"339":1,"341":1,"342":1,"343":2,"344":2,"345":2,"348":1,"350":1,"352":4,"353":3,"355":1,"356":2,"361":9,"363":2,"366":2,"367":2,"368":3,"369":2,"370":2,"371":8,"372":1,"373":4,"376":2,"377":3,"378":2,"379":1,"380":12,"381":9,"383":3,"384":1,"385":1,"386":1,"387":1,"388":10,"390":5,"391":9,"392":6,"393":2,"396":3,"397":1,"398":1,"399":4,"400":7,"402":3,"403":1,"404":4,"405":4,"406":3,"407":1,"408":1,"409":1,"410":1,"411":1,"412":2,"413":1,"414":1,"415":1,"422":14,"423":1,"424":3,"425":1,"426":2,"427":3,"428":2,"429":2,"430":7,"431":1,"432":2,"433":2,"434":4,"435":1,"437":2,"438":4,"439":4,"440":1,"441":1,"442":1,"443":2,"446":1,"448":3,"449":1,"450":4,"451":6,"452":2,"453":3,"454":4,"455":9,"457":1,"458":1,"459":1,"461":1,"465":6,"466":2,"467":2,"468":1,"469":3,"474":1,"476":1,"477":1,"478":2,"479":2,"482":1,"483":2,"484":10,"485":1,"492":3,"493":7,"494":1,"498":2,"499":21,"503":1,"504":3,"505":4,"506":2,"507":2,"508":3,"509":1,"510":1,"513":2,"515":2,"516":1,"519":1,"520":2,"523":2,"524":4,"525":1,"526":2,"528":3,"531":3,"534":1,"537":5,"538":1,"539":1,"540":10,"542":7,"543":2,"544":7,"547":1,"550":3,"552":3,"554":2,"555":6,"556":4,"557":4,"558":8,"559":7,"561":2,"562":7,"563":5,"565":2,"566":2,"567":1,"568":1,"571":4,"572":2,"574":1,"577":3,"578":5,"580":6,"581":6,"582":4,"583":1,"584":7,"585":2,"586":3,"588":3,"589":4,"590":9,"592":8,"596":7,"597":26,"599":6,"601":1,"602":2,"604":1,"605":1,"606":1,"607":1,"609":2,"610":1,"614":7,"615":4,"617":2,"620":13,"621":1,"622":3,"623":1,"625":6,"627":7,"628":3,"629":4,"630":2,"631":3,"632":7,"633":1,"634":5,"637":7,"638":4,"640":7,"641":4,"642":3,"643":6,"644":6,"646":9,"647":8,"648":8,"649":11,"650":8,"651":2,"654":1,"659":2,"660":1,"663":1,"665":1,"666":1,"668":6,"670":2,"671":3,"672":18,"674":3,"675":4,"677":3,"678":3,"679":2,"680":9,"681":2,"682":1,"683":1,"687":1,"688":5,"689":2,"690":1,"695":1,"696":1,"697":1,"698":6,"700":1,"703":1,"704":7,"705":4,"707":7,"708":7,"709":5,"710":7,"711":2,"712":1,"714":2,"715":3,"717":2,"718":1,"720":3,"722":2,"724":3,"725":3,"726":4,"728":2,"730":2,"731":5,"735":9,"736":8,"737":2,"738":10,"739":3,"740":5,"741":6,"742":1,"743":8,"744":1,"745":9,"746":4,"748":1,"750":1,"751":1,"755":1,"756":1,"757":2,"758":2,"760":4,"761":2,"762":1,"763":7,"764":1,"765":5,"766":3,"768":1,"769":2,"770":6,"771":25,"772":3,"773":12,"774":8,"776":7,"777":7,"778":3,"779":4,"780":1,"781":4,"782":14,"783":4,"784":3}}]],"serializationVersion":2}';export{e as default}; diff --git a/pr-1815/assets/chunks/VPLocalSearchBox.0e80d22f.js b/pr-1815/assets/chunks/VPLocalSearchBox.a2ac4698.js similarity index 99% rename from pr-1815/assets/chunks/VPLocalSearchBox.0e80d22f.js rename to pr-1815/assets/chunks/VPLocalSearchBox.a2ac4698.js index 158f3ff4f..f77e1df24 100644 --- a/pr-1815/assets/chunks/VPLocalSearchBox.0e80d22f.js +++ b/pr-1815/assets/chunks/VPLocalSearchBox.a2ac4698.js @@ -1,4 +1,4 @@ -import{X as pt,h as ie,x as Be,ah as kt,ai as Nt,d as It,E as be,aj as et,g as we,ak as Dt,al as _t,y as Ot,am as Rt,j as De,O as de,V as xe,an as Mt,S as Lt,U as Pt,ao as zt,Y as Bt,s as Vt,ap as $t,o as X,b as Wt,k as F,a1 as jt,l as U,aq as Kt,ar as Jt,as as Ut,c as te,n as tt,e as Fe,D as rt,F as nt,a as he,t as ve,at as Ht,p as Gt,m as qt,au as at,av as Qt,a7 as Yt,ad as Zt,_ as Xt}from"./framework.2959b752.js";import{u as er,c as tr}from"./theme.7287e00e.js";const rr={root:()=>pt(()=>import("./@localSearchIndexroot.ad8eddd0.js"),[])};/*! +import{X as pt,h as ie,x as Be,ah as kt,ai as Nt,d as It,E as be,aj as et,g as we,ak as Dt,al as _t,y as Ot,am as Rt,j as De,O as de,V as xe,an as Mt,S as Lt,U as Pt,ao as zt,Y as Bt,s as Vt,ap as $t,o as X,b as Wt,k as F,a1 as jt,l as U,aq as Kt,ar as Jt,as as Ut,c as te,n as tt,e as Fe,D as rt,F as nt,a as he,t as ve,at as Ht,p as Gt,m as qt,au as at,av as Qt,a7 as Yt,ad as Zt,_ as Xt}from"./framework.2959b752.js";import{u as er,c as tr}from"./theme.b7c4765b.js";const rr={root:()=>pt(()=>import("./@localSearchIndexroot.4cbbec6e.js"),[])};/*! * tabbable 6.2.0 * @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE */var mt=["input:not([inert])","select:not([inert])","textarea:not([inert])","a[href]:not([inert])","button:not([inert])","[tabindex]:not(slot):not([inert])","audio[controls]:not([inert])","video[controls]:not([inert])",'[contenteditable]:not([contenteditable="false"]):not([inert])',"details>summary:first-of-type:not([inert])","details:not([inert])"],Ae=mt.join(","),yt=typeof Element>"u",se=yt?function(){}:Element.prototype.matches||Element.prototype.msMatchesSelector||Element.prototype.webkitMatchesSelector,Te=!yt&&Element.prototype.getRootNode?function(o){var e;return o==null||(e=o.getRootNode)===null||e===void 0?void 0:e.call(o)}:function(o){return o==null?void 0:o.ownerDocument},Ce=function o(e,t){var r;t===void 0&&(t=!0);var a=e==null||(r=e.getAttribute)===null||r===void 0?void 0:r.call(e,"inert"),n=a===""||a==="true",i=n||t&&e&&o(e.parentNode);return i},nr=function(e){var t,r=e==null||(t=e.getAttribute)===null||t===void 0?void 0:t.call(e,"contenteditable");return r===""||r==="true"},gt=function(e,t,r){if(Ce(e))return[];var a=Array.prototype.slice.apply(e.querySelectorAll(Ae));return t&&se.call(e,Ae)&&a.unshift(e),a=a.filter(r),a},bt=function o(e,t,r){for(var a=[],n=Array.from(e);n.length;){var i=n.shift();if(!Ce(i,!1))if(i.tagName==="SLOT"){var s=i.assignedElements(),u=s.length?s:i.children,l=o(u,!0,r);r.flatten?a.push.apply(a,l):a.push({scopeParent:i,candidates:l})}else{var d=se.call(i,Ae);d&&r.filter(i)&&(t||!e.includes(i))&&a.push(i);var h=i.shadowRoot||typeof r.getShadowRoot=="function"&&r.getShadowRoot(i),v=!Ce(h,!1)&&(!r.shadowRootFilter||r.shadowRootFilter(i));if(h&&v){var y=o(h===!0?i.children:h.children,!0,r);r.flatten?a.push.apply(a,y):a.push({scopeParent:i,candidates:y})}else n.unshift.apply(n,i.children)}}return a},wt=function(e){return!isNaN(parseInt(e.getAttribute("tabindex"),10))},oe=function(e){if(!e)throw new Error("No node provided");return e.tabIndex<0&&(/^(AUDIO|VIDEO|DETAILS)$/.test(e.tagName)||nr(e))&&!wt(e)?0:e.tabIndex},ar=function(e,t){var r=oe(e);return r<0&&t&&!wt(e)?0:r},ir=function(e,t){return e.tabIndex===t.tabIndex?e.documentOrder-t.documentOrder:e.tabIndex-t.tabIndex},xt=function(e){return e.tagName==="INPUT"},or=function(e){return xt(e)&&e.type==="hidden"},sr=function(e){var t=e.tagName==="DETAILS"&&Array.prototype.slice.apply(e.children).some(function(r){return r.tagName==="SUMMARY"});return t},ur=function(e,t){for(var r=0;rsummary:first-of-type"),i=n?e.parentElement:e;if(se.call(i,"details:not([open]) *"))return!0;if(!r||r==="full"||r==="legacy-full"){if(typeof a=="function"){for(var s=e;e;){var u=e.parentElement,l=Te(e);if(u&&!u.shadowRoot&&a(u)===!0)return it(e);e.assignedSlot?e=e.assignedSlot:!u&&l!==e.ownerDocument?e=l.host:e=u}e=s}if(dr(e))return!e.getClientRects().length;if(r!=="legacy-full")return!0}else if(r==="non-zero-area")return it(e);return!1},vr=function(e){if(/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(e.tagName))for(var t=e.parentElement;t;){if(t.tagName==="FIELDSET"&&t.disabled){for(var r=0;r=0)},mr=function o(e){var t=[],r=[];return e.forEach(function(a,n){var i=!!a.scopeParent,s=i?a.scopeParent:a,u=ar(s,i),l=i?o(a.candidates):s;u===0?i?t.push.apply(t,l):t.push(s):r.push({documentOrder:n,tabIndex:u,item:a,isScope:i,content:l})}),r.sort(ir).reduce(function(a,n){return n.isScope?a.push.apply(a,n.content):a.push(n.content),a},[]).concat(t)},yr=function(e,t){t=t||{};var r;return t.getShadowRoot?r=bt([e],t.includeContainer,{filter:Ve.bind(null,t),flatten:!1,getShadowRoot:t.getShadowRoot,shadowRootFilter:pr}):r=gt(e,t.includeContainer,Ve.bind(null,t)),mr(r)},gr=function(e,t){t=t||{};var r;return t.getShadowRoot?r=bt([e],t.includeContainer,{filter:ke.bind(null,t),flatten:!0,getShadowRoot:t.getShadowRoot}):r=gt(e,t.includeContainer,ke.bind(null,t)),r},ue=function(e,t){if(t=t||{},!e)throw new Error("No node provided");return se.call(e,Ae)===!1?!1:Ve(t,e)},br=mt.concat("iframe").join(","),_e=function(e,t){if(t=t||{},!e)throw new Error("No node provided");return se.call(e,br)===!1?!1:ke(t,e)};/*! diff --git a/pr-1815/assets/chunks/theme.7287e00e.js b/pr-1815/assets/chunks/theme.b7c4765b.js similarity index 99% rename from pr-1815/assets/chunks/theme.7287e00e.js rename to pr-1815/assets/chunks/theme.b7c4765b.js index 9684abfe0..35320a578 100644 --- a/pr-1815/assets/chunks/theme.7287e00e.js +++ b/pr-1815/assets/chunks/theme.b7c4765b.js @@ -1 +1 @@ -import{d as b,o as a,c as i,r as u,n as T,a as x,t as L,_ as m,b as $,w as v,e as f,T as ce,u as ze,i as De,f as ue,g as k,h as M,j as G,k as c,l,p as H,m as z,q as O,s as K,v as re,x as U,y as te,z as de,A as Ve,B as Ee,C as j,F as N,D as A,E as _e,G as Y,H as h,I as F,J as we,K as se,L as Z,M as ne,N as Fe,O as Oe,P as Le,Q as Ge,R as Ue,S as je,U as Re,V as ke,W as qe,X as Ke,Y as Se,Z as Me,$ as We,a0 as Ye,a1 as Je,a2 as Xe}from"./framework.2959b752.js";const Ze=b({__name:"VPBadge",props:{text:{},type:{default:"tip"}},setup(s){return(e,t)=>(a(),i("span",{class:T(["VPBadge",e.type])},[u(e.$slots,"default",{},()=>[x(L(e.text),1)],!0)],2))}});const Qe=m(Ze,[["__scopeId","data-v-ea5b2908"]]),et={key:0,class:"VPBackdrop"},tt=b({__name:"VPBackdrop",props:{show:{type:Boolean}},setup(s){return(e,t)=>(a(),$(ce,{name:"fade"},{default:v(()=>[e.show?(a(),i("div",et)):f("",!0)]),_:1}))}});const st=m(tt,[["__scopeId","data-v-54a304ca"]]),P=ze;function nt(s,e){let t,n=!1;return()=>{t&&clearTimeout(t),n?t=setTimeout(s,e):(s(),(n=!0)&&setTimeout(()=>n=!1,e))}}function le(s){return/^\//.test(s)?s:`/${s}`}function J(s){const{pathname:e,search:t,hash:n,protocol:o}=new URL(s,"http://a.com");if(De(s)||s.startsWith("#")||!o.startsWith("http")||/\.(?!html|md)\w+($|\?)/i.test(s))return s;const{site:r}=P(),d=e.endsWith("/")||e.endsWith(".html")?s:s.replace(/(?:(^\.+)\/)?.*$/,`$1${e.replace(/(\.md)?$/,r.value.cleanUrls?"":".html")}${t}${n}`);return ue(d)}function X({removeCurrent:s=!0,correspondingLink:e=!1}={}){const{site:t,localeIndex:n,page:o,theme:r}=P(),d=k(()=>{var _,g;return{label:(_=t.value.locales[n.value])==null?void 0:_.label,link:((g=t.value.locales[n.value])==null?void 0:g.link)||(n.value==="root"?"/":`/${n.value}/`)}});return{localeLinks:k(()=>Object.entries(t.value.locales).flatMap(([_,g])=>s&&d.value.label===g.label?[]:{text:g.label,link:ot(g.link||(_==="root"?"/":`/${_}/`),r.value.i18nRouting!==!1&&e,o.value.relativePath.slice(d.value.link.length-1),!t.value.cleanUrls)})),currentLang:d}}function ot(s,e,t,n){return e?s.replace(/\/$/,"")+le(t.replace(/(^|\/)index\.md$/,"$1").replace(/\.md$/,n?".html":"")):s}const at=s=>(H("data-v-b9c0c15a"),s=s(),z(),s),rt={class:"NotFound"},lt={class:"code"},it={class:"title"},ct=at(()=>c("div",{class:"divider"},null,-1)),ut={class:"quote"},dt={class:"action"},_t=["href","aria-label"],vt=b({__name:"NotFound",setup(s){const{site:e,theme:t}=P(),{localeLinks:n}=X({removeCurrent:!1}),o=M("/");return G(()=>{var d;const r=window.location.pathname.replace(e.value.base,"").replace(/(^.*?\/).*$/,"/$1");n.value.length&&(o.value=((d=n.value.find(({link:p})=>p.startsWith(r)))==null?void 0:d.link)||n.value[0].link)}),(r,d)=>{var p,_,g,V,y;return a(),i("div",rt,[c("p",lt,L(((p=l(t).notFound)==null?void 0:p.code)??"404"),1),c("h1",it,L(((_=l(t).notFound)==null?void 0:_.title)??"PAGE NOT FOUND"),1),ct,c("blockquote",ut,L(((g=l(t).notFound)==null?void 0:g.quote)??"But if you don't change your direction, and if you keep looking, you may end up where you are heading."),1),c("div",dt,[c("a",{class:"link",href:l(ue)(o.value),"aria-label":((V=l(t).notFound)==null?void 0:V.linkLabel)??"go to home"},L(((y=l(t).notFound)==null?void 0:y.linkText)??"Take me home"),9,_t)])])}}});const pt=m(vt,[["__scopeId","data-v-b9c0c15a"]]);function Ne(s,e){if(Array.isArray(s))return Q(s);if(s==null)return[];e=le(e);const t=Object.keys(s).sort((o,r)=>r.split("/").length-o.split("/").length).find(o=>e.startsWith(le(o))),n=t?s[t]:[];return Array.isArray(n)?Q(n):Q(n.items,n.base)}function ht(s){const e=[];let t=0;for(const n in s){const o=s[n];if(o.items){t=e.push(o);continue}e[t]||e.push({items:[]}),e[t].items.push(o)}return e}function ft(s){const e=[];function t(n){for(const o of n)o.text&&o.link&&e.push({text:o.text,link:o.link,docFooterText:o.docFooterText}),o.items&&t(o.items)}return t(s),e}function ie(s,e){return Array.isArray(e)?e.some(t=>ie(s,t)):O(s,e.link)?!0:e.items?ie(s,e.items):!1}function Q(s,e){return[...s].map(t=>{const n={...t},o=n.base||e;return o&&n.link&&(n.link=o+n.link),n.items&&(n.items=Q(n.items,o)),n})}function D(){const{frontmatter:s,page:e,theme:t}=P(),n=re("(min-width: 960px)"),o=M(!1),r=k(()=>{const B=t.value.sidebar,w=e.value.relativePath;return B?Ne(B,w):[]}),d=M(r.value);U(r,(B,w)=>{JSON.stringify(B)!==JSON.stringify(w)&&(d.value=r.value)});const p=k(()=>s.value.sidebar!==!1&&d.value.length>0&&s.value.layout!=="home"),_=k(()=>g?s.value.aside==null?t.value.aside==="left":s.value.aside==="left":!1),g=k(()=>s.value.layout==="home"?!1:s.value.aside!=null?!!s.value.aside:t.value.aside!==!1),V=k(()=>p.value&&n.value),y=k(()=>p.value?ht(d.value):[]);function I(){o.value=!0}function S(){o.value=!1}function C(){o.value?S():I()}return{isOpen:o,sidebar:d,sidebarGroups:y,hasSidebar:p,hasAside:g,leftAside:_,isSidebarEnabled:V,open:I,close:S,toggle:C}}function mt(s,e){let t;te(()=>{t=s.value?document.activeElement:void 0}),G(()=>{window.addEventListener("keyup",n)}),de(()=>{window.removeEventListener("keyup",n)});function n(o){o.key==="Escape"&&s.value&&(e(),t==null||t.focus())}}const Ie=M(K?location.hash:"");K&&window.addEventListener("hashchange",()=>{Ie.value=location.hash});function gt(s){const{page:e}=P(),t=M(!1),n=k(()=>s.value.collapsed!=null),o=k(()=>!!s.value.link),r=M(!1),d=()=>{r.value=O(e.value.relativePath,s.value.link)};U([e,s,Ie],d),G(d);const p=k(()=>r.value?!0:s.value.items?ie(e.value.relativePath,s.value.items):!1),_=k(()=>!!(s.value.items&&s.value.items.length));te(()=>{t.value=!!(n.value&&s.value.collapsed)}),Ve(()=>{(r.value||p.value)&&(t.value=!1)});function g(){n.value&&(t.value=!t.value)}return{collapsed:t,collapsible:n,isLink:o,isActiveLink:r,hasActiveLink:p,hasChildren:_,toggle:g}}function bt(){const{hasSidebar:s}=D(),e=re("(min-width: 960px)"),t=re("(min-width: 1280px)");return{isAsideEnabled:k(()=>!t.value&&!e.value?!1:s.value?t.value:e.value)}}const $t=71;function ve(s){return typeof s.outline=="object"&&!Array.isArray(s.outline)&&s.outline.label||s.outlineTitle||"On this page"}function pe(s){const e=[...document.querySelectorAll(".VPDoc :where(h1,h2,h3,h4,h5,h6)")].filter(t=>t.id&&t.hasChildNodes()).map(t=>{const n=Number(t.tagName[1]);return{title:kt(t),link:"#"+t.id,level:n}});return yt(e,s)}function kt(s){let e="";for(const t of s.childNodes)if(t.nodeType===1){if(t.classList.contains("VPBadge")||t.classList.contains("header-anchor"))continue;e+=t.textContent}else t.nodeType===3&&(e+=t.textContent);return e.trim()}function yt(s,e){if(e===!1)return[];const t=(typeof e=="object"&&!Array.isArray(e)?e.level:e)||2,[n,o]=typeof t=="number"?[t,t]:t==="deep"?[2,6]:t;s=s.filter(d=>d.level>=n&&d.level<=o);const r=[];e:for(let d=0;d=0;_--){const g=s[_];if(g.level{requestAnimationFrame(r),window.addEventListener("scroll",n)}),Ee(()=>{d(location.hash)}),de(()=>{window.removeEventListener("scroll",n)});function r(){if(!t.value)return;const p=[].slice.call(s.value.querySelectorAll(".outline-link")),_=[].slice.call(document.querySelectorAll(".content .header-anchor")).filter(S=>p.some(C=>C.hash===S.hash&&S.offsetParent!==null)),g=window.scrollY,V=window.innerHeight,y=document.body.offsetHeight,I=Math.abs(g+V-y)<1;if(_.length&&I){d(_[_.length-1].hash);return}for(let S=0;S<_.length;S++){const C=_[S],B=_[S+1],[w,R]=Vt(S,C,B);if(w){d(R);return}}}function d(p){o&&o.classList.remove("active"),p==null?o=null:o=s.value.querySelector(`a[href="${decodeURIComponent(p)}"]`);const _=o;_?(_.classList.add("active"),e.value.style.top=_.offsetTop+33+"px",e.value.style.opacity="1"):(e.value.style.top="33px",e.value.style.opacity="0")}}function ye(s){return s.parentElement.offsetTop-$t}function Vt(s,e,t){const n=window.scrollY;return s===0&&n===0?[!0,null]:n{const o=j("VPDocOutlineItem",!0);return a(),i("ul",{class:T(t.root?"root":"nested")},[(a(!0),i(N,null,A(t.headers,({children:r,link:d,title:p})=>(a(),i("li",null,[c("a",{class:"outline-link",href:d,onClick:e,title:p},L(p),9,wt),r!=null&&r.length?(a(),$(o,{key:0,headers:r},null,8,["headers"])):f("",!0)]))),256))],2)}}});const he=m(Lt,[["__scopeId","data-v-463da30f"]]),St=s=>(H("data-v-3a6c4994"),s=s(),z(),s),Mt={class:"content"},Nt={class:"outline-title",role:"heading","aria-level":"2"},It={"aria-labelledby":"doc-outline-aria-label"},Tt=St(()=>c("span",{class:"visually-hidden",id:"doc-outline-aria-label"}," Table of Contents for current page ",-1)),Ct=b({__name:"VPDocAsideOutline",setup(s){const{frontmatter:e,theme:t}=P(),n=_e([]);Y(()=>{n.value=pe(e.value.outline??t.value.outline)});const o=M(),r=M();return Pt(o,r),(d,p)=>(a(),i("div",{class:T(["VPDocAsideOutline",{"has-outline":n.value.length>0}]),ref_key:"container",ref:o,role:"navigation"},[c("div",Mt,[c("div",{class:"outline-marker",ref_key:"marker",ref:r},null,512),c("div",Nt,L(l(ve)(l(t))),1),c("nav",It,[Tt,h(he,{headers:n.value,root:!0},null,8,["headers"])])])],2))}});const Bt=m(Ct,[["__scopeId","data-v-3a6c4994"]]),At={class:"VPDocAsideCarbonAds"},xt=b({__name:"VPDocAsideCarbonAds",props:{carbonAds:{}},setup(s){const e=()=>null;return(t,n)=>(a(),i("div",At,[h(l(e),{"carbon-ads":t.carbonAds},null,8,["carbon-ads"])]))}}),Ht=s=>(H("data-v-cb998dce"),s=s(),z(),s),zt={class:"VPDocAside"},Dt=Ht(()=>c("div",{class:"spacer"},null,-1)),Et=b({__name:"VPDocAside",setup(s){const{theme:e}=P();return(t,n)=>(a(),i("div",zt,[u(t.$slots,"aside-top",{},void 0,!0),u(t.$slots,"aside-outline-before",{},void 0,!0),h(Bt),u(t.$slots,"aside-outline-after",{},void 0,!0),Dt,u(t.$slots,"aside-ads-before",{},void 0,!0),l(e).carbonAds?(a(),$(xt,{key:0,"carbon-ads":l(e).carbonAds},null,8,["carbon-ads"])):f("",!0),u(t.$slots,"aside-ads-after",{},void 0,!0),u(t.$slots,"aside-bottom",{},void 0,!0)]))}});const Ft=m(Et,[["__scopeId","data-v-cb998dce"]]);function Ot(){const{theme:s,page:e}=P();return k(()=>{const{text:t="Edit this page",pattern:n=""}=s.value.editLink||{};let o;return typeof n=="function"?o=n(e.value):o=n.replace(/:path/g,e.value.filePath),{url:o,text:t}})}function Gt(){const{page:s,theme:e,frontmatter:t}=P();return k(()=>{var _,g,V,y,I,S,C,B;const n=Ne(e.value.sidebar,s.value.relativePath),o=ft(n),r=o.findIndex(w=>O(s.value.relativePath,w.link)),d=((_=e.value.docFooter)==null?void 0:_.prev)===!1&&!t.value.prev||t.value.prev===!1,p=((g=e.value.docFooter)==null?void 0:g.next)===!1&&!t.value.next||t.value.next===!1;return{prev:d?void 0:{text:(typeof t.value.prev=="string"?t.value.prev:typeof t.value.prev=="object"?t.value.prev.text:void 0)??((V=o[r-1])==null?void 0:V.docFooterText)??((y=o[r-1])==null?void 0:y.text),link:(typeof t.value.prev=="object"?t.value.prev.link:void 0)??((I=o[r-1])==null?void 0:I.link)},next:p?void 0:{text:(typeof t.value.next=="string"?t.value.next:typeof t.value.next=="object"?t.value.next.text:void 0)??((S=o[r+1])==null?void 0:S.docFooterText)??((C=o[r+1])==null?void 0:C.text),link:(typeof t.value.next=="object"?t.value.next.link:void 0)??((B=o[r+1])==null?void 0:B.link)}}})}const Ut={},jt={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},Rt=c("path",{d:"M18,23H4c-1.7,0-3-1.3-3-3V6c0-1.7,1.3-3,3-3h7c0.6,0,1,0.4,1,1s-0.4,1-1,1H4C3.4,5,3,5.4,3,6v14c0,0.6,0.4,1,1,1h14c0.6,0,1-0.4,1-1v-7c0-0.6,0.4-1,1-1s1,0.4,1,1v7C21,21.7,19.7,23,18,23z"},null,-1),qt=c("path",{d:"M8,17c-0.3,0-0.5-0.1-0.7-0.3C7,16.5,6.9,16.1,7,15.8l1-4c0-0.2,0.1-0.3,0.3-0.5l9.5-9.5c1.2-1.2,3.2-1.2,4.4,0c1.2,1.2,1.2,3.2,0,4.4l-9.5,9.5c-0.1,0.1-0.3,0.2-0.5,0.3l-4,1C8.2,17,8.1,17,8,17zM9.9,12.5l-0.5,2.1l2.1-0.5l9.3-9.3c0.4-0.4,0.4-1.1,0-1.6c-0.4-0.4-1.2-0.4-1.6,0l0,0L9.9,12.5z M18.5,2.5L18.5,2.5L18.5,2.5z"},null,-1),Kt=[Rt,qt];function Wt(s,e){return a(),i("svg",jt,Kt)}const Yt=m(Ut,[["render",Wt]]),E=b({__name:"VPLink",props:{tag:{},href:{},noIcon:{type:Boolean},target:{},rel:{}},setup(s){const e=s,t=k(()=>e.tag??(e.href?"a":"span")),n=k(()=>e.href&&we.test(e.href));return(o,r)=>(a(),$(F(t.value),{class:T(["VPLink",{link:o.href,"vp-external-link-icon":n.value,"no-icon":o.noIcon}]),href:o.href?l(J)(o.href):void 0,target:o.target??(n.value?"_blank":void 0),rel:o.rel??(n.value?"noreferrer":void 0)},{default:v(()=>[u(o.$slots,"default")]),_:3},8,["class","href","target","rel"]))}}),Jt={class:"VPLastUpdated"},Xt=["datetime"],Zt=b({__name:"VPDocFooterLastUpdated",setup(s){const{theme:e,page:t,frontmatter:n,lang:o}=P(),r=k(()=>new Date(n.value.lastUpdated??t.value.lastUpdated)),d=k(()=>r.value.toISOString()),p=M("");return G(()=>{te(()=>{var _,g,V;p.value=new Intl.DateTimeFormat((g=(_=e.value.lastUpdated)==null?void 0:_.formatOptions)!=null&&g.forceLocale?o.value:void 0,((V=e.value.lastUpdated)==null?void 0:V.formatOptions)??{dateStyle:"short",timeStyle:"short"}).format(r.value)})}),(_,g)=>{var V;return a(),i("p",Jt,[x(L(((V=l(e).lastUpdated)==null?void 0:V.text)||l(e).lastUpdatedText||"Last updated")+": ",1),c("time",{datetime:d.value},L(p.value),9,Xt)])}}});const Qt=m(Zt,[["__scopeId","data-v-19a7ae4e"]]),es={key:0,class:"VPDocFooter"},ts={key:0,class:"edit-info"},ss={key:0,class:"edit-link"},ns={key:1,class:"last-updated"},os={key:1,class:"prev-next"},as={class:"pager"},rs=["href"],ls=["innerHTML"],is=["innerHTML"],cs={class:"pager"},us=["href"],ds=["innerHTML"],_s=["innerHTML"],vs=b({__name:"VPDocFooter",setup(s){const{theme:e,page:t,frontmatter:n}=P(),o=Ot(),r=Gt(),d=k(()=>e.value.editLink&&n.value.editLink!==!1),p=k(()=>t.value.lastUpdated&&n.value.lastUpdated!==!1),_=k(()=>d.value||p.value||r.value.prev||r.value.next);return(g,V)=>{var y,I,S,C,B,w;return _.value?(a(),i("footer",es,[u(g.$slots,"doc-footer-before",{},void 0,!0),d.value||p.value?(a(),i("div",ts,[d.value?(a(),i("div",ss,[h(E,{class:"edit-link-button",href:l(o).url,"no-icon":!0},{default:v(()=>[h(Yt,{class:"edit-link-icon","aria-label":"edit icon"}),x(" "+L(l(o).text),1)]),_:1},8,["href"])])):f("",!0),p.value?(a(),i("div",ns,[h(Qt)])):f("",!0)])):f("",!0),(y=l(r).prev)!=null&&y.link||(I=l(r).next)!=null&&I.link?(a(),i("nav",os,[c("div",as,[(S=l(r).prev)!=null&&S.link?(a(),i("a",{key:0,class:"pager-link prev",href:l(J)(l(r).prev.link)},[c("span",{class:"desc",innerHTML:((C=l(e).docFooter)==null?void 0:C.prev)||"Previous page"},null,8,ls),c("span",{class:"title",innerHTML:l(r).prev.text},null,8,is)],8,rs)):f("",!0)]),c("div",cs,[(B=l(r).next)!=null&&B.link?(a(),i("a",{key:0,class:"pager-link next",href:l(J)(l(r).next.link)},[c("span",{class:"desc",innerHTML:((w=l(e).docFooter)==null?void 0:w.next)||"Next page"},null,8,ds),c("span",{class:"title",innerHTML:l(r).next.text},null,8,_s)],8,us)):f("",!0)])])):f("",!0)])):f("",!0)}}});const ps=m(vs,[["__scopeId","data-v-a2d931e4"]]),hs={},fs={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},ms=c("path",{d:"M9,19c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l5.3-5.3L8.3,6.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l6,6c0.4,0.4,0.4,1,0,1.4l-6,6C9.5,18.9,9.3,19,9,19z"},null,-1),gs=[ms];function bs(s,e){return a(),i("svg",fs,gs)}const fe=m(hs,[["render",bs]]),$s={key:0,class:"VPDocOutlineDropdown"},ks={key:0,class:"items"},ys=b({__name:"VPDocOutlineDropdown",setup(s){const{frontmatter:e,theme:t}=P(),n=M(!1);Y(()=>{n.value=!1});const o=_e([]);return Y(()=>{o.value=pe(e.value.outline??t.value.outline)}),(r,d)=>o.value.length>0?(a(),i("div",$s,[c("button",{onClick:d[0]||(d[0]=p=>n.value=!n.value),class:T({open:n.value})},[x(L(l(ve)(l(t)))+" ",1),h(fe,{class:"icon"})],2),n.value?(a(),i("div",ks,[h(he,{headers:o.value},null,8,["headers"])])):f("",!0)])):f("",!0)}});const Ps=m(ys,[["__scopeId","data-v-95bb0785"]]),Vs=s=>(H("data-v-a3c25e27"),s=s(),z(),s),ws={class:"container"},Ls=Vs(()=>c("div",{class:"aside-curtain"},null,-1)),Ss={class:"aside-container"},Ms={class:"aside-content"},Ns={class:"content"},Is={class:"content-container"},Ts={class:"main"},Cs=b({__name:"VPDoc",setup(s){const{theme:e}=P(),t=se(),{hasSidebar:n,hasAside:o,leftAside:r}=D(),d=k(()=>t.path.replace(/[./]+/g,"_").replace(/_html$/,""));return(p,_)=>{const g=j("Content");return a(),i("div",{class:T(["VPDoc",{"has-sidebar":l(n),"has-aside":l(o)}])},[u(p.$slots,"doc-top",{},void 0,!0),c("div",ws,[l(o)?(a(),i("div",{key:0,class:T(["aside",{"left-aside":l(r)}])},[Ls,c("div",Ss,[c("div",Ms,[h(Ft,null,{"aside-top":v(()=>[u(p.$slots,"aside-top",{},void 0,!0)]),"aside-bottom":v(()=>[u(p.$slots,"aside-bottom",{},void 0,!0)]),"aside-outline-before":v(()=>[u(p.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(p.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(p.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(p.$slots,"aside-ads-after",{},void 0,!0)]),_:3})])])],2)):f("",!0),c("div",Ns,[c("div",Is,[u(p.$slots,"doc-before",{},void 0,!0),h(Ps),c("main",Ts,[h(g,{class:T(["vp-doc",[d.value,l(e).externalLinkIcon&&"external-link-icon-enabled"]])},null,8,["class"])]),h(ps,null,{"doc-footer-before":v(()=>[u(p.$slots,"doc-footer-before",{},void 0,!0)]),_:3}),u(p.$slots,"doc-after",{},void 0,!0)])])]),u(p.$slots,"doc-bottom",{},void 0,!0)],2)}}});const Bs=m(Cs,[["__scopeId","data-v-a3c25e27"]]),As=b({__name:"VPButton",props:{tag:{},size:{default:"medium"},theme:{default:"brand"},text:{},href:{}},setup(s){const e=s,t=k(()=>e.href&&we.test(e.href)),n=k(()=>e.tag||e.href?"a":"button");return(o,r)=>(a(),$(F(n.value),{class:T(["VPButton",[o.size,o.theme]]),href:o.href?l(J)(o.href):void 0,target:t.value?"_blank":void 0,rel:t.value?"noreferrer":void 0},{default:v(()=>[x(L(o.text),1)]),_:1},8,["class","href","target","rel"]))}});const xs=m(As,[["__scopeId","data-v-1e76fe75"]]),Hs=["src","alt"],zs=b({inheritAttrs:!1,__name:"VPImage",props:{image:{},alt:{}},setup(s){return(e,t)=>{const n=j("VPImage",!0);return e.image?(a(),i(N,{key:0},[typeof e.image=="string"||"src"in e.image?(a(),i("img",Z({key:0,class:"VPImage"},typeof e.image=="string"?e.$attrs:{...e.image,...e.$attrs},{src:l(ue)(typeof e.image=="string"?e.image:e.image.src),alt:e.alt??(typeof e.image=="string"?"":e.image.alt||"")}),null,16,Hs)):(a(),i(N,{key:1},[h(n,Z({class:"dark",image:e.image.dark,alt:e.image.alt},e.$attrs),null,16,["image","alt"]),h(n,Z({class:"light",image:e.image.light,alt:e.image.alt},e.$attrs),null,16,["image","alt"])],64))],64)):f("",!0)}}});const ee=m(zs,[["__scopeId","data-v-ab19afbb"]]),Ds=s=>(H("data-v-5a3e9999"),s=s(),z(),s),Es={class:"container"},Fs={class:"main"},Os={key:0,class:"name"},Gs=["innerHTML"],Us=["innerHTML"],js=["innerHTML"],Rs={key:0,class:"actions"},qs={key:0,class:"image"},Ks={class:"image-container"},Ws=Ds(()=>c("div",{class:"image-bg"},null,-1)),Ys=b({__name:"VPHero",props:{name:{},text:{},tagline:{},image:{},actions:{}},setup(s){const e=ne("hero-image-slot-exists");return(t,n)=>(a(),i("div",{class:T(["VPHero",{"has-image":t.image||l(e)}])},[c("div",Es,[c("div",Fs,[u(t.$slots,"home-hero-info",{},()=>[t.name?(a(),i("h1",Os,[c("span",{innerHTML:t.name,class:"clip"},null,8,Gs)])):f("",!0),t.text?(a(),i("p",{key:1,innerHTML:t.text,class:"text"},null,8,Us)):f("",!0),t.tagline?(a(),i("p",{key:2,innerHTML:t.tagline,class:"tagline"},null,8,js)):f("",!0)],!0),t.actions?(a(),i("div",Rs,[(a(!0),i(N,null,A(t.actions,o=>(a(),i("div",{key:o.link,class:"action"},[h(xs,{tag:"a",size:"medium",theme:o.theme,text:o.text,href:o.link},null,8,["theme","text","href"])]))),128))])):f("",!0)]),t.image||l(e)?(a(),i("div",qs,[c("div",Ks,[Ws,u(t.$slots,"home-hero-image",{},()=>[t.image?(a(),$(ee,{key:0,class:"image-src",image:t.image},null,8,["image"])):f("",!0)],!0)])])):f("",!0)])],2))}});const Js=m(Ys,[["__scopeId","data-v-5a3e9999"]]),Xs=b({__name:"VPHomeHero",setup(s){const{frontmatter:e}=P();return(t,n)=>l(e).hero?(a(),$(Js,{key:0,class:"VPHomeHero",name:l(e).hero.name,text:l(e).hero.text,tagline:l(e).hero.tagline,image:l(e).hero.image,actions:l(e).hero.actions},{"home-hero-info":v(()=>[u(t.$slots,"home-hero-info")]),"home-hero-image":v(()=>[u(t.$slots,"home-hero-image")]),_:3},8,["name","text","tagline","image","actions"])):f("",!0)}}),Zs={},Qs={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},en=c("path",{d:"M19.9,12.4c0.1-0.2,0.1-0.5,0-0.8c-0.1-0.1-0.1-0.2-0.2-0.3l-7-7c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4l5.3,5.3H5c-0.6,0-1,0.4-1,1s0.4,1,1,1h11.6l-5.3,5.3c-0.4,0.4-0.4,1,0,1.4c0.2,0.2,0.5,0.3,0.7,0.3s0.5-0.1,0.7-0.3l7-7C19.8,12.6,19.9,12.5,19.9,12.4z"},null,-1),tn=[en];function sn(s,e){return a(),i("svg",Qs,tn)}const nn=m(Zs,[["render",sn]]),on={class:"box"},an={key:0,class:"icon"},rn=["innerHTML"],ln=["innerHTML"],cn=["innerHTML"],un={key:4,class:"link-text"},dn={class:"link-text-value"},_n=b({__name:"VPFeature",props:{icon:{},title:{},details:{},link:{},linkText:{},rel:{},target:{}},setup(s){return(e,t)=>(a(),$(E,{class:"VPFeature",href:e.link,rel:e.rel,target:e.target,"no-icon":!0,tag:e.link?"a":"div"},{default:v(()=>[c("article",on,[typeof e.icon=="object"&&e.icon.wrap?(a(),i("div",an,[h(ee,{image:e.icon,alt:e.icon.alt,height:e.icon.height||48,width:e.icon.width||48},null,8,["image","alt","height","width"])])):typeof e.icon=="object"?(a(),$(ee,{key:1,image:e.icon,alt:e.icon.alt,height:e.icon.height||48,width:e.icon.width||48},null,8,["image","alt","height","width"])):e.icon?(a(),i("div",{key:2,class:"icon",innerHTML:e.icon},null,8,rn)):f("",!0),c("h2",{class:"title",innerHTML:e.title},null,8,ln),e.details?(a(),i("p",{key:3,class:"details",innerHTML:e.details},null,8,cn)):f("",!0),e.linkText?(a(),i("div",un,[c("p",dn,[x(L(e.linkText)+" ",1),h(nn,{class:"link-text-icon"})])])):f("",!0)])]),_:1},8,["href","rel","target","tag"]))}});const vn=m(_n,[["__scopeId","data-v-ee984185"]]),pn={key:0,class:"VPFeatures"},hn={class:"container"},fn={class:"items"},mn=b({__name:"VPFeatures",props:{features:{}},setup(s){const e=s,t=k(()=>{const n=e.features.length;if(n){if(n===2)return"grid-2";if(n===3)return"grid-3";if(n%3===0)return"grid-6";if(n>3)return"grid-4"}else return});return(n,o)=>n.features?(a(),i("div",pn,[c("div",hn,[c("div",fn,[(a(!0),i(N,null,A(n.features,r=>(a(),i("div",{key:r.title,class:T(["item",[t.value]])},[h(vn,{icon:r.icon,title:r.title,details:r.details,link:r.link,"link-text":r.linkText,rel:r.rel,target:r.target},null,8,["icon","title","details","link","link-text","rel","target"])],2))),128))])])])):f("",!0)}});const gn=m(mn,[["__scopeId","data-v-b1eea84a"]]),bn=b({__name:"VPHomeFeatures",setup(s){const{frontmatter:e}=P();return(t,n)=>l(e).features?(a(),$(gn,{key:0,class:"VPHomeFeatures",features:l(e).features},null,8,["features"])):f("",!0)}}),$n={class:"VPHome"},kn=b({__name:"VPHome",setup(s){return(e,t)=>{const n=j("Content");return a(),i("div",$n,[u(e.$slots,"home-hero-before",{},void 0,!0),h(Xs,null,{"home-hero-info":v(()=>[u(e.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(e.$slots,"home-hero-image",{},void 0,!0)]),_:3}),u(e.$slots,"home-hero-after",{},void 0,!0),u(e.$slots,"home-features-before",{},void 0,!0),h(bn),u(e.$slots,"home-features-after",{},void 0,!0),h(n)])}}});const yn=m(kn,[["__scopeId","data-v-20eabd3a"]]),Pn={},Vn={class:"VPPage"};function wn(s,e){const t=j("Content");return a(),i("div",Vn,[u(s.$slots,"page-top"),h(t),u(s.$slots,"page-bottom")])}const Ln=m(Pn,[["render",wn]]),Sn=b({__name:"VPContent",setup(s){const{page:e,frontmatter:t}=P(),{hasSidebar:n}=D();return(o,r)=>(a(),i("div",{class:T(["VPContent",{"has-sidebar":l(n),"is-home":l(t).layout==="home"}]),id:"VPContent"},[l(e).isNotFound?u(o.$slots,"not-found",{key:0},()=>[h(pt)],!0):l(t).layout==="page"?(a(),$(Ln,{key:1},{"page-top":v(()=>[u(o.$slots,"page-top",{},void 0,!0)]),"page-bottom":v(()=>[u(o.$slots,"page-bottom",{},void 0,!0)]),_:3})):l(t).layout==="home"?(a(),$(yn,{key:2},{"home-hero-before":v(()=>[u(o.$slots,"home-hero-before",{},void 0,!0)]),"home-hero-info":v(()=>[u(o.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(o.$slots,"home-hero-image",{},void 0,!0)]),"home-hero-after":v(()=>[u(o.$slots,"home-hero-after",{},void 0,!0)]),"home-features-before":v(()=>[u(o.$slots,"home-features-before",{},void 0,!0)]),"home-features-after":v(()=>[u(o.$slots,"home-features-after",{},void 0,!0)]),_:3})):l(t).layout&&l(t).layout!=="doc"?(a(),$(F(l(t).layout),{key:3})):(a(),$(Bs,{key:4},{"doc-top":v(()=>[u(o.$slots,"doc-top",{},void 0,!0)]),"doc-bottom":v(()=>[u(o.$slots,"doc-bottom",{},void 0,!0)]),"doc-footer-before":v(()=>[u(o.$slots,"doc-footer-before",{},void 0,!0)]),"doc-before":v(()=>[u(o.$slots,"doc-before",{},void 0,!0)]),"doc-after":v(()=>[u(o.$slots,"doc-after",{},void 0,!0)]),"aside-top":v(()=>[u(o.$slots,"aside-top",{},void 0,!0)]),"aside-outline-before":v(()=>[u(o.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(o.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(o.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(o.$slots,"aside-ads-after",{},void 0,!0)]),"aside-bottom":v(()=>[u(o.$slots,"aside-bottom",{},void 0,!0)]),_:3}))],2))}});const Mn=m(Sn,[["__scopeId","data-v-3cf691b6"]]),Nn={class:"container"},In=["innerHTML"],Tn=["innerHTML"],Cn=b({__name:"VPFooter",setup(s){const{theme:e,frontmatter:t}=P(),{hasSidebar:n}=D();return(o,r)=>l(e).footer&&l(t).footer!==!1?(a(),i("footer",{key:0,class:T(["VPFooter",{"has-sidebar":l(n)}])},[c("div",Nn,[l(e).footer.message?(a(),i("p",{key:0,class:"message",innerHTML:l(e).footer.message},null,8,In)):f("",!0),l(e).footer.copyright?(a(),i("p",{key:1,class:"copyright",innerHTML:l(e).footer.copyright},null,8,Tn)):f("",!0)])],2)):f("",!0)}});const Bn=m(Cn,[["__scopeId","data-v-e4279f1c"]]),An={class:"header"},xn={class:"outline"},Hn=b({__name:"VPLocalNavOutlineDropdown",props:{headers:{},navHeight:{}},setup(s){const e=s,{theme:t}=P(),n=M(!1),o=M(0),r=M();Y(()=>{n.value=!1});function d(){n.value=!n.value,o.value=window.innerHeight+Math.min(window.scrollY-e.navHeight,0)}function p(g){g.target.classList.contains("outline-link")&&(r.value&&(r.value.style.transition="none"),Oe(()=>{n.value=!1}))}function _(){n.value=!1,window.scrollTo({top:0,left:0,behavior:"smooth"})}return(g,V)=>(a(),i("div",{class:"VPLocalNavOutlineDropdown",style:Fe({"--vp-vh":o.value+"px"})},[g.headers.length>0?(a(),i("button",{key:0,onClick:d,class:T({open:n.value})},[x(L(l(ve)(l(t)))+" ",1),h(fe,{class:"icon"})],2)):(a(),i("button",{key:1,onClick:_},L(l(t).returnToTopLabel||"Return to top"),1)),h(ce,{name:"flyout"},{default:v(()=>[n.value?(a(),i("div",{key:0,ref_key:"items",ref:r,class:"items",onClick:p},[c("div",An,[c("a",{class:"top-link",href:"#",onClick:_},L(l(t).returnToTopLabel||"Return to top"),1)]),c("div",xn,[h(he,{headers:g.headers},null,8,["headers"])])],512)):f("",!0)]),_:1})],4))}});const zn=m(Hn,[["__scopeId","data-v-24251f6f"]]),Dn={},En={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Fn=c("path",{d:"M17,11H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h14c0.6,0,1,0.4,1,1S17.6,11,17,11z"},null,-1),On=c("path",{d:"M21,7H3C2.4,7,2,6.6,2,6s0.4-1,1-1h18c0.6,0,1,0.4,1,1S21.6,7,21,7z"},null,-1),Gn=c("path",{d:"M21,15H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h18c0.6,0,1,0.4,1,1S21.6,15,21,15z"},null,-1),Un=c("path",{d:"M17,19H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h14c0.6,0,1,0.4,1,1S17.6,19,17,19z"},null,-1),jn=[Fn,On,Gn,Un];function Rn(s,e){return a(),i("svg",En,jn)}const qn=m(Dn,[["render",Rn]]),Kn=["aria-expanded"],Wn={class:"menu-text"},Yn=b({__name:"VPLocalNav",props:{open:{type:Boolean}},emits:["open-menu"],setup(s){const{theme:e,frontmatter:t}=P(),{hasSidebar:n}=D(),{y:o}=Le(),r=_e([]),d=M(0);G(()=>{d.value=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--vp-nav-height"))}),Y(()=>{r.value=pe(t.value.outline??e.value.outline)});const p=k(()=>r.value.length===0&&!n.value),_=k(()=>({VPLocalNav:!0,fixed:p.value,"reached-top":o.value>=d.value}));return(g,V)=>l(t).layout!=="home"&&(!p.value||l(o)>=d.value)?(a(),i("div",{key:0,class:T(_.value)},[l(n)?(a(),i("button",{key:0,class:"menu","aria-expanded":g.open,"aria-controls":"VPSidebarNav",onClick:V[0]||(V[0]=y=>g.$emit("open-menu"))},[h(qn,{class:"menu-icon"}),c("span",Wn,L(l(e).sidebarMenuLabel||"Menu"),1)],8,Kn)):f("",!0),h(zn,{headers:r.value,navHeight:d.value},null,8,["headers","navHeight"])],2)):f("",!0)}});const Jn=m(Yn,[["__scopeId","data-v-9e669cc1"]]);function Xn(){const s=M(!1);function e(){s.value=!0,window.addEventListener("resize",o)}function t(){s.value=!1,window.removeEventListener("resize",o)}function n(){s.value?t():e()}function o(){window.outerWidth>=768&&t()}const r=se();return U(()=>r.path,t),{isScreenOpen:s,openScreen:e,closeScreen:t,toggleScreen:n}}const Zn={},Qn={class:"VPSwitch",type:"button",role:"switch"},eo={class:"check"},to={key:0,class:"icon"};function so(s,e){return a(),i("button",Qn,[c("span",eo,[s.$slots.default?(a(),i("span",to,[u(s.$slots,"default",{},void 0,!0)])):f("",!0)])])}const no=m(Zn,[["render",so],["__scopeId","data-v-1c29e291"]]),oo={},ao={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},ro=c("path",{d:"M12.1,22c-0.3,0-0.6,0-0.9,0c-5.5-0.5-9.5-5.4-9-10.9c0.4-4.8,4.2-8.6,9-9c0.4,0,0.8,0.2,1,0.5c0.2,0.3,0.2,0.8-0.1,1.1c-2,2.7-1.4,6.4,1.3,8.4c2.1,1.6,5,1.6,7.1,0c0.3-0.2,0.7-0.3,1.1-0.1c0.3,0.2,0.5,0.6,0.5,1c-0.2,2.7-1.5,5.1-3.6,6.8C16.6,21.2,14.4,22,12.1,22zM9.3,4.4c-2.9,1-5,3.6-5.2,6.8c-0.4,4.4,2.8,8.3,7.2,8.7c2.1,0.2,4.2-0.4,5.8-1.8c1.1-0.9,1.9-2.1,2.4-3.4c-2.5,0.9-5.3,0.5-7.5-1.1C9.2,11.4,8.1,7.7,9.3,4.4z"},null,-1),lo=[ro];function io(s,e){return a(),i("svg",ao,lo)}const co=m(oo,[["render",io]]),uo={},_o={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},vo=Ge('',9),po=[vo];function ho(s,e){return a(),i("svg",_o,po)}const fo=m(uo,[["render",ho]]),mo=b({__name:"VPSwitchAppearance",setup(s){const{isDark:e}=P(),t=ne("toggle-appearance",()=>{e.value=!e.value});return(n,o)=>(a(),$(no,{title:"toggle dark mode",class:"VPSwitchAppearance","aria-checked":l(e),onClick:l(t)},{default:v(()=>[h(fo,{class:"sun"}),h(co,{class:"moon"})]),_:1},8,["aria-checked","onClick"]))}});const me=m(mo,[["__scopeId","data-v-3329432d"]]),go={key:0,class:"VPNavBarAppearance"},bo=b({__name:"VPNavBarAppearance",setup(s){const{site:e}=P();return(t,n)=>l(e).appearance&&l(e).appearance!=="force-dark"?(a(),i("div",go,[h(me)])):f("",!0)}});const $o=m(bo,[["__scopeId","data-v-283b26e9"]]),ge=M();let Te=!1,ae=0;function ko(s){const e=M(!1);if(K){!Te&&yo(),ae++;const t=U(ge,n=>{var o,r,d;n===s.el.value||(o=s.el.value)!=null&&o.contains(n)?(e.value=!0,(r=s.onFocus)==null||r.call(s)):(e.value=!1,(d=s.onBlur)==null||d.call(s))});de(()=>{t(),ae--,ae||Po()})}return Ue(e)}function yo(){document.addEventListener("focusin",Ce),Te=!0,ge.value=document.activeElement}function Po(){document.removeEventListener("focusin",Ce)}function Ce(){ge.value=document.activeElement}const Vo={},wo={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Lo=c("path",{d:"M12,16c-0.3,0-0.5-0.1-0.7-0.3l-6-6c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l5.3,5.3l5.3-5.3c0.4-0.4,1-0.4,1.4,0s0.4,1,0,1.4l-6,6C12.5,15.9,12.3,16,12,16z"},null,-1),So=[Lo];function Mo(s,e){return a(),i("svg",wo,So)}const Be=m(Vo,[["render",Mo]]),No={},Io={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},To=c("circle",{cx:"12",cy:"12",r:"2"},null,-1),Co=c("circle",{cx:"19",cy:"12",r:"2"},null,-1),Bo=c("circle",{cx:"5",cy:"12",r:"2"},null,-1),Ao=[To,Co,Bo];function xo(s,e){return a(),i("svg",Io,Ao)}const Ho=m(No,[["render",xo]]),zo={class:"VPMenuLink"},Do=b({__name:"VPMenuLink",props:{item:{}},setup(s){const{page:e}=P();return(t,n)=>(a(),i("div",zo,[h(E,{class:T({active:l(O)(l(e).relativePath,t.item.activeMatch||t.item.link,!!t.item.activeMatch)}),href:t.item.link,target:t.item.target,rel:t.item.rel},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["class","href","target","rel"])]))}});const oe=m(Do,[["__scopeId","data-v-f51f088d"]]),Eo={class:"VPMenuGroup"},Fo={key:0,class:"title"},Oo=b({__name:"VPMenuGroup",props:{text:{},items:{}},setup(s){return(e,t)=>(a(),i("div",Eo,[e.text?(a(),i("p",Fo,L(e.text),1)):f("",!0),(a(!0),i(N,null,A(e.items,n=>(a(),i(N,null,["link"in n?(a(),$(oe,{key:0,item:n},null,8,["item"])):f("",!0)],64))),256))]))}});const Go=m(Oo,[["__scopeId","data-v-a6b0397c"]]),Uo={class:"VPMenu"},jo={key:0,class:"items"},Ro=b({__name:"VPMenu",props:{items:{}},setup(s){return(e,t)=>(a(),i("div",Uo,[e.items?(a(),i("div",jo,[(a(!0),i(N,null,A(e.items,n=>(a(),i(N,{key:n.text},["link"in n?(a(),$(oe,{key:0,item:n},null,8,["item"])):(a(),$(Go,{key:1,text:n.text,items:n.items},null,8,["text","items"]))],64))),128))])):f("",!0),u(e.$slots,"default",{},void 0,!0)]))}});const qo=m(Ro,[["__scopeId","data-v-e42ed9b3"]]),Ko=["aria-expanded","aria-label"],Wo={key:0,class:"text"},Yo=["innerHTML"],Jo={class:"menu"},Xo=b({__name:"VPFlyout",props:{icon:{},button:{},label:{},items:{}},setup(s){const e=M(!1),t=M();ko({el:t,onBlur:n});function n(){e.value=!1}return(o,r)=>(a(),i("div",{class:"VPFlyout",ref_key:"el",ref:t,onMouseenter:r[1]||(r[1]=d=>e.value=!0),onMouseleave:r[2]||(r[2]=d=>e.value=!1)},[c("button",{type:"button",class:"button","aria-haspopup":"true","aria-expanded":e.value,"aria-label":o.label,onClick:r[0]||(r[0]=d=>e.value=!e.value)},[o.button||o.icon?(a(),i("span",Wo,[o.icon?(a(),$(F(o.icon),{key:0,class:"option-icon"})):f("",!0),o.button?(a(),i("span",{key:1,innerHTML:o.button},null,8,Yo)):f("",!0),h(Be,{class:"text-icon"})])):(a(),$(Ho,{key:1,class:"icon"}))],8,Ko),c("div",Jo,[h(qo,{items:o.items},{default:v(()=>[u(o.$slots,"default",{},void 0,!0)]),_:3},8,["items"])])],544))}});const be=m(Xo,[["__scopeId","data-v-aa8de344"]]),Zo={discord:'Discord',facebook:'Facebook',github:'GitHub',instagram:'Instagram',linkedin:'LinkedIn',mastodon:'Mastodon',slack:'Slack',twitter:'Twitter',x:'X',youtube:'YouTube'},Qo=["href","aria-label","innerHTML"],ea=b({__name:"VPSocialLink",props:{icon:{},link:{},ariaLabel:{}},setup(s){const e=s,t=k(()=>typeof e.icon=="object"?e.icon.svg:Zo[e.icon]);return(n,o)=>(a(),i("a",{class:"VPSocialLink no-icon",href:n.link,"aria-label":n.ariaLabel??(typeof n.icon=="string"?n.icon:""),target:"_blank",rel:"noopener",innerHTML:t.value},null,8,Qo))}});const ta=m(ea,[["__scopeId","data-v-16cf740a"]]),sa={class:"VPSocialLinks"},na=b({__name:"VPSocialLinks",props:{links:{}},setup(s){return(e,t)=>(a(),i("div",sa,[(a(!0),i(N,null,A(e.links,({link:n,icon:o,ariaLabel:r})=>(a(),$(ta,{key:n,icon:o,link:n,ariaLabel:r},null,8,["icon","link","ariaLabel"]))),128))]))}});const $e=m(na,[["__scopeId","data-v-e71e869c"]]),oa={key:0,class:"group translations"},aa={class:"trans-title"},ra={key:1,class:"group"},la={class:"item appearance"},ia={class:"label"},ca={class:"appearance-action"},ua={key:2,class:"group"},da={class:"item social-links"},_a=b({__name:"VPNavBarExtra",setup(s){const{site:e,theme:t}=P(),{localeLinks:n,currentLang:o}=X({correspondingLink:!0}),r=k(()=>n.value.length&&o.value.label||e.value.appearance||t.value.socialLinks);return(d,p)=>r.value?(a(),$(be,{key:0,class:"VPNavBarExtra",label:"extra navigation"},{default:v(()=>[l(n).length&&l(o).label?(a(),i("div",oa,[c("p",aa,L(l(o).label),1),(a(!0),i(N,null,A(l(n),_=>(a(),$(oe,{key:_.link,item:_},null,8,["item"]))),128))])):f("",!0),l(e).appearance?(a(),i("div",ra,[c("div",la,[c("p",ia,L(l(t).darkModeSwitchLabel||"Appearance"),1),c("div",ca,[h(me)])])])):f("",!0),l(t).socialLinks?(a(),i("div",ua,[c("div",da,[h($e,{class:"social-links-list",links:l(t).socialLinks},null,8,["links"])])])):f("",!0)]),_:1})):f("",!0)}});const va=m(_a,[["__scopeId","data-v-c8c2ae4b"]]),pa=s=>(H("data-v-6bee1efd"),s=s(),z(),s),ha=["aria-expanded"],fa=pa(()=>c("span",{class:"container"},[c("span",{class:"top"}),c("span",{class:"middle"}),c("span",{class:"bottom"})],-1)),ma=[fa],ga=b({__name:"VPNavBarHamburger",props:{active:{type:Boolean}},emits:["click"],setup(s){return(e,t)=>(a(),i("button",{type:"button",class:T(["VPNavBarHamburger",{active:e.active}]),"aria-label":"mobile navigation","aria-expanded":e.active,"aria-controls":"VPNavScreen",onClick:t[0]||(t[0]=n=>e.$emit("click"))},ma,10,ha))}});const ba=m(ga,[["__scopeId","data-v-6bee1efd"]]),$a=["innerHTML"],ka=b({__name:"VPNavBarMenuLink",props:{item:{}},setup(s){const{page:e}=P();return(t,n)=>(a(),$(E,{class:T({VPNavBarMenuLink:!0,active:l(O)(l(e).relativePath,t.item.activeMatch||t.item.link,!!t.item.activeMatch)}),href:t.item.link,target:t.item.target,rel:t.item.rel,tabindex:"0"},{default:v(()=>[c("span",{innerHTML:t.item.text},null,8,$a)]),_:1},8,["class","href","target","rel"]))}});const ya=m(ka,[["__scopeId","data-v-cb318fec"]]),Pa=b({__name:"VPNavBarMenuGroup",props:{item:{}},setup(s){const e=s,{page:t}=P(),n=r=>"link"in r?O(t.value.relativePath,r.link,!!e.item.activeMatch):r.items.some(n),o=k(()=>n(e.item));return(r,d)=>(a(),$(be,{class:T({VPNavBarMenuGroup:!0,active:l(O)(l(t).relativePath,r.item.activeMatch,!!r.item.activeMatch)||o.value}),button:r.item.text,items:r.item.items},null,8,["class","button","items"]))}}),Va=s=>(H("data-v-f732b5d0"),s=s(),z(),s),wa={key:0,"aria-labelledby":"main-nav-aria-label",class:"VPNavBarMenu"},La=Va(()=>c("span",{id:"main-nav-aria-label",class:"visually-hidden"},"Main Navigation",-1)),Sa=b({__name:"VPNavBarMenu",setup(s){const{theme:e}=P();return(t,n)=>l(e).nav?(a(),i("nav",wa,[La,(a(!0),i(N,null,A(l(e).nav,o=>(a(),i(N,{key:o.text},["link"in o?(a(),$(ya,{key:0,item:o},null,8,["item"])):(a(),$(Pa,{key:1,item:o},null,8,["item"]))],64))),128))])):f("",!0)}});const Ma=m(Sa,[["__scopeId","data-v-f732b5d0"]]);function Na(s,e){const{localeIndex:t}=P();function n(o){var S,C;const r=o.split("."),d=s&&typeof s=="object",p=d&&((C=(S=s.locales)==null?void 0:S[t.value])==null?void 0:C.translations)||null,_=d&&s.translations||null;let g=p,V=_,y=e;const I=r.pop();for(const B of r){let w=null;const R=y==null?void 0:y[B];R&&(w=y=R);const W=V==null?void 0:V[B];W&&(w=V=W);const q=g==null?void 0:g[B];q&&(w=g=q),R||(y=w),W||(V=w),q||(g=w)}return(g==null?void 0:g[I])??(V==null?void 0:V[I])??(y==null?void 0:y[I])??""}return n}const Ia=["aria-label"],Ta={class:"DocSearch-Button-Container"},Ca=c("svg",{class:"DocSearch-Search-Icon",width:"20",height:"20",viewBox:"0 0 20 20","aria-label":"search icon"},[c("path",{d:"M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z",stroke:"currentColor",fill:"none","fill-rule":"evenodd","stroke-linecap":"round","stroke-linejoin":"round"})],-1),Ba={class:"DocSearch-Button-Placeholder"},Aa=c("span",{class:"DocSearch-Button-Keys"},[c("kbd",{class:"DocSearch-Button-Key"}),c("kbd",{class:"DocSearch-Button-Key"},"K")],-1),Pe=b({__name:"VPNavBarSearchButton",setup(s){const{theme:e}=P(),t={button:{buttonText:"Search",buttonAriaLabel:"Search"}},n=je(Na)(Re(()=>{var o;return(o=e.value.search)==null?void 0:o.options}),t);return(o,r)=>(a(),i("button",{type:"button",class:"DocSearch DocSearch-Button","aria-label":l(n)("button.buttonAriaLabel")},[c("span",Ta,[Ca,c("span",Ba,L(l(n)("button.buttonText")),1)]),Aa],8,Ia))}});const xa={class:"VPNavBarSearch"},Ha={id:"local-search"},za={key:1,id:"docsearch"},Da=b({__name:"VPNavBarSearch",setup(s){const e=qe(()=>Ke(()=>import("./VPLocalSearchBox.0e80d22f.js"),["assets/chunks/VPLocalSearchBox.0e80d22f.js","assets/chunks/framework.2959b752.js"])),t=()=>null,{theme:n}=P(),o=M(!1),r=M(!1);G(()=>{});function d(){o.value||(o.value=!0,setTimeout(p,16))}function p(){const y=new Event("keydown");y.key="k",y.metaKey=!0,window.dispatchEvent(y),setTimeout(()=>{document.querySelector(".DocSearch-Modal")||p()},16)}function _(y){const I=y.target,S=I.tagName;return I.isContentEditable||S==="INPUT"||S==="SELECT"||S==="TEXTAREA"}const g=M(!1);ke("k",y=>{(y.ctrlKey||y.metaKey)&&(y.preventDefault(),g.value=!0)}),ke("/",y=>{_(y)||(y.preventDefault(),g.value=!0)});const V="local";return(y,I)=>{var S;return a(),i("div",xa,[l(V)==="local"?(a(),i(N,{key:0},[g.value?(a(),$(l(e),{key:0,onClose:I[0]||(I[0]=C=>g.value=!1)})):f("",!0),c("div",Ha,[h(Pe,{onClick:I[1]||(I[1]=C=>g.value=!0)})])],64)):l(V)==="algolia"?(a(),i(N,{key:1},[o.value?(a(),$(l(t),{key:0,algolia:((S=l(n).search)==null?void 0:S.options)??l(n).algolia,onVnodeBeforeMount:I[2]||(I[2]=C=>r.value=!0)},null,8,["algolia"])):f("",!0),r.value?f("",!0):(a(),i("div",za,[h(Pe,{onClick:d})]))],64)):f("",!0)])}}});const Ea=b({__name:"VPNavBarSocialLinks",setup(s){const{theme:e}=P();return(t,n)=>l(e).socialLinks?(a(),$($e,{key:0,class:"VPNavBarSocialLinks",links:l(e).socialLinks},null,8,["links"])):f("",!0)}});const Fa=m(Ea,[["__scopeId","data-v-ef6192dc"]]),Oa=["href"],Ga=b({__name:"VPNavBarTitle",setup(s){const{site:e,theme:t}=P(),{hasSidebar:n}=D(),{currentLang:o}=X();return(r,d)=>(a(),i("div",{class:T(["VPNavBarTitle",{"has-sidebar":l(n)}])},[c("a",{class:"title",href:l(t).logoLink??l(J)(l(o).link)},[u(r.$slots,"nav-bar-title-before",{},void 0,!0),l(t).logo?(a(),$(ee,{key:0,class:"logo",image:l(t).logo},null,8,["image"])):f("",!0),l(t).siteTitle?(a(),i(N,{key:1},[x(L(l(t).siteTitle),1)],64)):l(t).siteTitle===void 0?(a(),i(N,{key:2},[x(L(l(e).title),1)],64)):f("",!0),u(r.$slots,"nav-bar-title-after",{},void 0,!0)],8,Oa)],2))}});const Ua=m(Ga,[["__scopeId","data-v-2973dbb4"]]),ja={},Ra={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},qa=c("path",{d:"M0 0h24v24H0z",fill:"none"},null,-1),Ka=c("path",{d:" M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z ",class:"css-c4d79v"},null,-1),Wa=[qa,Ka];function Ya(s,e){return a(),i("svg",Ra,Wa)}const Ae=m(ja,[["render",Ya]]),Ja={class:"items"},Xa={class:"title"},Za=b({__name:"VPNavBarTranslations",setup(s){const{theme:e}=P(),{localeLinks:t,currentLang:n}=X({correspondingLink:!0});return(o,r)=>l(t).length&&l(n).label?(a(),$(be,{key:0,class:"VPNavBarTranslations",icon:Ae,label:l(e).langMenuLabel||"Change language"},{default:v(()=>[c("div",Ja,[c("p",Xa,L(l(n).label),1),(a(!0),i(N,null,A(l(t),d=>(a(),$(oe,{key:d.link,item:d},null,8,["item"]))),128))])]),_:1},8,["label"])):f("",!0)}});const Qa=m(Za,[["__scopeId","data-v-ff4524ae"]]),er=s=>(H("data-v-f1abbc6e"),s=s(),z(),s),tr={class:"container"},sr={class:"title"},nr={class:"content"},or=er(()=>c("div",{class:"curtain"},null,-1)),ar={class:"content-body"},rr=b({__name:"VPNavBar",props:{isScreenOpen:{type:Boolean}},emits:["toggle-screen"],setup(s){const{y:e}=Le(),{hasSidebar:t}=D(),{frontmatter:n}=P(),o=M({});return Ve(()=>{o.value={"has-sidebar":t.value,top:n.value.layout==="home"&&e.value===0}}),(r,d)=>(a(),i("div",{class:T(["VPNavBar",o.value])},[c("div",tr,[c("div",sr,[h(Ua,null,{"nav-bar-title-before":v(()=>[u(r.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(r.$slots,"nav-bar-title-after",{},void 0,!0)]),_:3})]),c("div",nr,[or,c("div",ar,[u(r.$slots,"nav-bar-content-before",{},void 0,!0),h(Da,{class:"search"}),h(Ma,{class:"menu"}),h(Qa,{class:"translations"}),h($o,{class:"appearance"}),h(Fa,{class:"social-links"}),h(va,{class:"extra"}),u(r.$slots,"nav-bar-content-after",{},void 0,!0),h(ba,{class:"hamburger",active:r.isScreenOpen,onClick:d[0]||(d[0]=p=>r.$emit("toggle-screen"))},null,8,["active"])])])])],2))}});const lr=m(rr,[["__scopeId","data-v-f1abbc6e"]]),ir={key:0,class:"VPNavScreenAppearance"},cr={class:"text"},ur=b({__name:"VPNavScreenAppearance",setup(s){const{site:e,theme:t}=P();return(n,o)=>l(e).appearance?(a(),i("div",ir,[c("p",cr,L(l(t).darkModeSwitchLabel||"Appearance"),1),h(me)])):f("",!0)}});const dr=m(ur,[["__scopeId","data-v-0dc5cf49"]]),_r=b({__name:"VPNavScreenMenuLink",props:{item:{}},setup(s){const e=ne("close-screen");return(t,n)=>(a(),$(E,{class:"VPNavScreenMenuLink",href:t.item.link,target:t.item.target,rel:t.item.rel,onClick:l(e)},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["href","target","rel","onClick"]))}});const vr=m(_r,[["__scopeId","data-v-fe523e3d"]]),pr={},hr={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},fr=c("path",{d:"M18.9,10.9h-6v-6c0-0.6-0.4-1-1-1s-1,0.4-1,1v6h-6c-0.6,0-1,0.4-1,1s0.4,1,1,1h6v6c0,0.6,0.4,1,1,1s1-0.4,1-1v-6h6c0.6,0,1-0.4,1-1S19.5,10.9,18.9,10.9z"},null,-1),mr=[fr];function gr(s,e){return a(),i("svg",hr,mr)}const br=m(pr,[["render",gr]]),$r=b({__name:"VPNavScreenMenuGroupLink",props:{item:{}},setup(s){const e=ne("close-screen");return(t,n)=>(a(),$(E,{class:"VPNavScreenMenuGroupLink",href:t.item.link,target:t.item.target,rel:t.item.rel,onClick:l(e)},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["href","target","rel","onClick"]))}});const xe=m($r,[["__scopeId","data-v-aea78dd1"]]),kr={class:"VPNavScreenMenuGroupSection"},yr={key:0,class:"title"},Pr=b({__name:"VPNavScreenMenuGroupSection",props:{text:{},items:{}},setup(s){return(e,t)=>(a(),i("div",kr,[e.text?(a(),i("p",yr,L(e.text),1)):f("",!0),(a(!0),i(N,null,A(e.items,n=>(a(),$(xe,{key:n.text,item:n},null,8,["item"]))),128))]))}});const Vr=m(Pr,[["__scopeId","data-v-f60dbfa7"]]),wr=["aria-controls","aria-expanded"],Lr={class:"button-text"},Sr=["id"],Mr={key:1,class:"group"},Nr=b({__name:"VPNavScreenMenuGroup",props:{text:{},items:{}},setup(s){const e=s,t=M(!1),n=k(()=>`NavScreenGroup-${e.text.replace(" ","-").toLowerCase()}`);function o(){t.value=!t.value}return(r,d)=>(a(),i("div",{class:T(["VPNavScreenMenuGroup",{open:t.value}])},[c("button",{class:"button","aria-controls":n.value,"aria-expanded":t.value,onClick:o},[c("span",Lr,L(r.text),1),h(br,{class:"button-icon"})],8,wr),c("div",{id:n.value,class:"items"},[(a(!0),i(N,null,A(r.items,p=>(a(),i(N,{key:p.text},["link"in p?(a(),i("div",{key:p.text,class:"item"},[h(xe,{item:p},null,8,["item"])])):(a(),i("div",Mr,[h(Vr,{text:p.text,items:p.items},null,8,["text","items"])]))],64))),128))],8,Sr)],2))}});const Ir=m(Nr,[["__scopeId","data-v-c2c554ed"]]),Tr={key:0,class:"VPNavScreenMenu"},Cr=b({__name:"VPNavScreenMenu",setup(s){const{theme:e}=P();return(t,n)=>l(e).nav?(a(),i("nav",Tr,[(a(!0),i(N,null,A(l(e).nav,o=>(a(),i(N,{key:o.text},["link"in o?(a(),$(vr,{key:0,item:o},null,8,["item"])):(a(),$(Ir,{key:1,text:o.text||"",items:o.items},null,8,["text","items"]))],64))),128))])):f("",!0)}}),Br=b({__name:"VPNavScreenSocialLinks",setup(s){const{theme:e}=P();return(t,n)=>l(e).socialLinks?(a(),$($e,{key:0,class:"VPNavScreenSocialLinks",links:l(e).socialLinks},null,8,["links"])):f("",!0)}}),Ar={class:"list"},xr=b({__name:"VPNavScreenTranslations",setup(s){const{localeLinks:e,currentLang:t}=X({correspondingLink:!0}),n=M(!1);function o(){n.value=!n.value}return(r,d)=>l(e).length&&l(t).label?(a(),i("div",{key:0,class:T(["VPNavScreenTranslations",{open:n.value}])},[c("button",{class:"title",onClick:o},[h(Ae,{class:"icon lang"}),x(" "+L(l(t).label)+" ",1),h(Be,{class:"icon chevron"})]),c("ul",Ar,[(a(!0),i(N,null,A(l(e),p=>(a(),i("li",{key:p.link,class:"item"},[h(E,{class:"link",href:p.link},{default:v(()=>[x(L(p.text),1)]),_:2},1032,["href"])]))),128))])],2)):f("",!0)}});const Hr=m(xr,[["__scopeId","data-v-41505286"]]),zr={class:"container"},Dr=b({__name:"VPNavScreen",props:{open:{type:Boolean}},setup(s){const e=M(null),t=Se(K?document.body:null);return(n,o)=>(a(),$(ce,{name:"fade",onEnter:o[0]||(o[0]=r=>t.value=!0),onAfterLeave:o[1]||(o[1]=r=>t.value=!1)},{default:v(()=>[n.open?(a(),i("div",{key:0,class:"VPNavScreen",ref_key:"screen",ref:e,id:"VPNavScreen"},[c("div",zr,[u(n.$slots,"nav-screen-content-before",{},void 0,!0),h(Cr,{class:"menu"}),h(Hr,{class:"translations"}),h(dr,{class:"appearance"}),h(Br,{class:"social-links"}),u(n.$slots,"nav-screen-content-after",{},void 0,!0)])],512)):f("",!0)]),_:3}))}});const Er=m(Dr,[["__scopeId","data-v-57cce842"]]),Fr={key:0,class:"VPNav"},Or=b({__name:"VPNav",setup(s){const{isScreenOpen:e,closeScreen:t,toggleScreen:n}=Xn(),{frontmatter:o}=P(),r=k(()=>o.value.navbar!==!1);return Me("close-screen",t),te(()=>{K&&document.documentElement.classList.toggle("hide-nav",!r.value)}),(d,p)=>r.value?(a(),i("header",Fr,[h(lr,{"is-screen-open":l(e),onToggleScreen:l(n)},{"nav-bar-title-before":v(()=>[u(d.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(d.$slots,"nav-bar-title-after",{},void 0,!0)]),"nav-bar-content-before":v(()=>[u(d.$slots,"nav-bar-content-before",{},void 0,!0)]),"nav-bar-content-after":v(()=>[u(d.$slots,"nav-bar-content-after",{},void 0,!0)]),_:3},8,["is-screen-open","onToggleScreen"]),h(Er,{open:l(e)},{"nav-screen-content-before":v(()=>[u(d.$slots,"nav-screen-content-before",{},void 0,!0)]),"nav-screen-content-after":v(()=>[u(d.$slots,"nav-screen-content-after",{},void 0,!0)]),_:3},8,["open"])])):f("",!0)}});const Gr=m(Or,[["__scopeId","data-v-7ad780c2"]]),Ur=s=>(H("data-v-bd01e0d5"),s=s(),z(),s),jr=["role","tabindex"],Rr=Ur(()=>c("div",{class:"indicator"},null,-1)),qr={key:1,class:"items"},Kr=b({__name:"VPSidebarItem",props:{item:{},depth:{}},setup(s){const e=s,{collapsed:t,collapsible:n,isLink:o,isActiveLink:r,hasActiveLink:d,hasChildren:p,toggle:_}=gt(k(()=>e.item)),g=k(()=>p.value?"section":"div"),V=k(()=>o.value?"a":"div"),y=k(()=>p.value?e.depth+2===7?"p":`h${e.depth+2}`:"p"),I=k(()=>o.value?void 0:"button"),S=k(()=>[[`level-${e.depth}`],{collapsible:n.value},{collapsed:t.value},{"is-link":o.value},{"is-active":r.value},{"has-active":d.value}]);function C(w){"key"in w&&w.key!=="Enter"||!e.item.link&&_()}function B(){e.item.link&&_()}return(w,R)=>{const W=j("VPSidebarItem",!0);return a(),$(F(g.value),{class:T(["VPSidebarItem",S.value])},{default:v(()=>[w.item.text?(a(),i("div",Z({key:0,class:"item",role:I.value},We(w.item.items?{click:C,keydown:C}:{},!0),{tabindex:w.item.items&&0}),[Rr,w.item.link?(a(),$(E,{key:0,tag:V.value,class:"link",href:w.item.link,rel:w.item.rel,target:w.item.target},{default:v(()=>[(a(),$(F(y.value),{class:"text",innerHTML:w.item.text},null,8,["innerHTML"]))]),_:1},8,["tag","href","rel","target"])):(a(),$(F(y.value),{key:1,class:"text",innerHTML:w.item.text},null,8,["innerHTML"])),w.item.collapsed!=null?(a(),i("div",{key:2,class:"caret",role:"button","aria-label":"toggle section",onClick:B,onKeydown:Ye(B,["enter"]),tabindex:"0"},[h(fe,{class:"caret-icon"})],32)):f("",!0)],16,jr)):f("",!0),w.item.items&&w.item.items.length?(a(),i("div",qr,[w.depth<5?(a(!0),i(N,{key:0},A(w.item.items,q=>(a(),$(W,{key:q.text,item:q,depth:w.depth+1},null,8,["item","depth"]))),128)):f("",!0)])):f("",!0)]),_:1},8,["class"])}}});const Wr=m(Kr,[["__scopeId","data-v-bd01e0d5"]]),He=s=>(H("data-v-ee2efba5"),s=s(),z(),s),Yr=He(()=>c("div",{class:"curtain"},null,-1)),Jr={class:"nav",id:"VPSidebarNav","aria-labelledby":"sidebar-aria-label",tabindex:"-1"},Xr=He(()=>c("span",{class:"visually-hidden",id:"sidebar-aria-label"}," Sidebar Navigation ",-1)),Zr=b({__name:"VPSidebar",props:{open:{type:Boolean}},setup(s){const{sidebarGroups:e,hasSidebar:t}=D(),n=s,o=M(null),r=Se(K?document.body:null);return U([n,o],()=>{var d;n.open?(r.value=!0,(d=o.value)==null||d.focus()):r.value=!1},{immediate:!0,flush:"post"}),(d,p)=>l(t)?(a(),i("aside",{key:0,class:T(["VPSidebar",{open:d.open}]),ref_key:"navEl",ref:o,onClick:p[0]||(p[0]=Je(()=>{},["stop"]))},[Yr,c("nav",Jr,[Xr,u(d.$slots,"sidebar-nav-before",{},void 0,!0),(a(!0),i(N,null,A(l(e),_=>(a(),i("div",{key:_.text,class:"group"},[h(Wr,{item:_,depth:0},null,8,["item"])]))),128)),u(d.$slots,"sidebar-nav-after",{},void 0,!0)])],2)):f("",!0)}});const Qr=m(Zr,[["__scopeId","data-v-ee2efba5"]]),el=b({__name:"VPSkipLink",setup(s){const e=se(),t=M();U(()=>e.path,()=>t.value.focus());function n({target:o}){const r=document.getElementById(decodeURIComponent(o.hash).slice(1));if(r){const d=()=>{r.removeAttribute("tabindex"),r.removeEventListener("blur",d)};r.setAttribute("tabindex","-1"),r.addEventListener("blur",d),r.focus(),window.scrollTo(0,0)}}return(o,r)=>(a(),i(N,null,[c("span",{ref_key:"backToTop",ref:t,tabindex:"-1"},null,512),c("a",{href:"#VPContent",class:"VPSkipLink visually-hidden",onClick:n}," Skip to content ")],64))}});const tl=m(el,[["__scopeId","data-v-c8291ffa"]]),sl=b({__name:"Layout",setup(s){const{isOpen:e,open:t,close:n}=D(),o=se();U(()=>o.path,n),mt(e,n);const{frontmatter:r}=P(),d=Xe(),p=k(()=>!!d["home-hero-image"]);return Me("hero-image-slot-exists",p),(_,g)=>{const V=j("Content");return l(r).layout!==!1?(a(),i("div",{key:0,class:T(["Layout",l(r).pageClass])},[u(_.$slots,"layout-top",{},void 0,!0),h(tl),h(st,{class:"backdrop",show:l(e),onClick:l(n)},null,8,["show","onClick"]),h(Gr,null,{"nav-bar-title-before":v(()=>[u(_.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(_.$slots,"nav-bar-title-after",{},void 0,!0)]),"nav-bar-content-before":v(()=>[u(_.$slots,"nav-bar-content-before",{},void 0,!0)]),"nav-bar-content-after":v(()=>[u(_.$slots,"nav-bar-content-after",{},void 0,!0)]),"nav-screen-content-before":v(()=>[u(_.$slots,"nav-screen-content-before",{},void 0,!0)]),"nav-screen-content-after":v(()=>[u(_.$slots,"nav-screen-content-after",{},void 0,!0)]),_:3}),h(Jn,{open:l(e),onOpenMenu:l(t)},null,8,["open","onOpenMenu"]),h(Qr,{open:l(e)},{"sidebar-nav-before":v(()=>[u(_.$slots,"sidebar-nav-before",{},void 0,!0)]),"sidebar-nav-after":v(()=>[u(_.$slots,"sidebar-nav-after",{},void 0,!0)]),_:3},8,["open"]),h(Mn,null,{"page-top":v(()=>[u(_.$slots,"page-top",{},void 0,!0)]),"page-bottom":v(()=>[u(_.$slots,"page-bottom",{},void 0,!0)]),"not-found":v(()=>[u(_.$slots,"not-found",{},void 0,!0)]),"home-hero-before":v(()=>[u(_.$slots,"home-hero-before",{},void 0,!0)]),"home-hero-info":v(()=>[u(_.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(_.$slots,"home-hero-image",{},void 0,!0)]),"home-hero-after":v(()=>[u(_.$slots,"home-hero-after",{},void 0,!0)]),"home-features-before":v(()=>[u(_.$slots,"home-features-before",{},void 0,!0)]),"home-features-after":v(()=>[u(_.$slots,"home-features-after",{},void 0,!0)]),"doc-footer-before":v(()=>[u(_.$slots,"doc-footer-before",{},void 0,!0)]),"doc-before":v(()=>[u(_.$slots,"doc-before",{},void 0,!0)]),"doc-after":v(()=>[u(_.$slots,"doc-after",{},void 0,!0)]),"doc-top":v(()=>[u(_.$slots,"doc-top",{},void 0,!0)]),"doc-bottom":v(()=>[u(_.$slots,"doc-bottom",{},void 0,!0)]),"aside-top":v(()=>[u(_.$slots,"aside-top",{},void 0,!0)]),"aside-bottom":v(()=>[u(_.$slots,"aside-bottom",{},void 0,!0)]),"aside-outline-before":v(()=>[u(_.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(_.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(_.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(_.$slots,"aside-ads-after",{},void 0,!0)]),_:3}),h(Bn),u(_.$slots,"layout-bottom",{},void 0,!0)],2)):(a(),$(V,{key:1}))}}});const nl=m(sl,[["__scopeId","data-v-9d8abc1e"]]);const al={Layout:nl,enhanceApp:({app:s})=>{s.component("Badge",Qe)}};export{Na as c,al as t,P as u}; +import{d as b,o as a,c as i,r as u,n as T,a as x,t as L,_ as m,b as $,w as v,e as f,T as ce,u as ze,i as De,f as ue,g as k,h as M,j as G,k as c,l,p as H,m as z,q as O,s as K,v as re,x as U,y as te,z as de,A as Ve,B as Ee,C as j,F as N,D as A,E as _e,G as Y,H as h,I as F,J as we,K as se,L as Z,M as ne,N as Fe,O as Oe,P as Le,Q as Ge,R as Ue,S as je,U as Re,V as ke,W as qe,X as Ke,Y as Se,Z as Me,$ as We,a0 as Ye,a1 as Je,a2 as Xe}from"./framework.2959b752.js";const Ze=b({__name:"VPBadge",props:{text:{},type:{default:"tip"}},setup(s){return(e,t)=>(a(),i("span",{class:T(["VPBadge",e.type])},[u(e.$slots,"default",{},()=>[x(L(e.text),1)],!0)],2))}});const Qe=m(Ze,[["__scopeId","data-v-ea5b2908"]]),et={key:0,class:"VPBackdrop"},tt=b({__name:"VPBackdrop",props:{show:{type:Boolean}},setup(s){return(e,t)=>(a(),$(ce,{name:"fade"},{default:v(()=>[e.show?(a(),i("div",et)):f("",!0)]),_:1}))}});const st=m(tt,[["__scopeId","data-v-54a304ca"]]),P=ze;function nt(s,e){let t,n=!1;return()=>{t&&clearTimeout(t),n?t=setTimeout(s,e):(s(),(n=!0)&&setTimeout(()=>n=!1,e))}}function le(s){return/^\//.test(s)?s:`/${s}`}function J(s){const{pathname:e,search:t,hash:n,protocol:o}=new URL(s,"http://a.com");if(De(s)||s.startsWith("#")||!o.startsWith("http")||/\.(?!html|md)\w+($|\?)/i.test(s))return s;const{site:r}=P(),d=e.endsWith("/")||e.endsWith(".html")?s:s.replace(/(?:(^\.+)\/)?.*$/,`$1${e.replace(/(\.md)?$/,r.value.cleanUrls?"":".html")}${t}${n}`);return ue(d)}function X({removeCurrent:s=!0,correspondingLink:e=!1}={}){const{site:t,localeIndex:n,page:o,theme:r}=P(),d=k(()=>{var _,g;return{label:(_=t.value.locales[n.value])==null?void 0:_.label,link:((g=t.value.locales[n.value])==null?void 0:g.link)||(n.value==="root"?"/":`/${n.value}/`)}});return{localeLinks:k(()=>Object.entries(t.value.locales).flatMap(([_,g])=>s&&d.value.label===g.label?[]:{text:g.label,link:ot(g.link||(_==="root"?"/":`/${_}/`),r.value.i18nRouting!==!1&&e,o.value.relativePath.slice(d.value.link.length-1),!t.value.cleanUrls)})),currentLang:d}}function ot(s,e,t,n){return e?s.replace(/\/$/,"")+le(t.replace(/(^|\/)index\.md$/,"$1").replace(/\.md$/,n?".html":"")):s}const at=s=>(H("data-v-b9c0c15a"),s=s(),z(),s),rt={class:"NotFound"},lt={class:"code"},it={class:"title"},ct=at(()=>c("div",{class:"divider"},null,-1)),ut={class:"quote"},dt={class:"action"},_t=["href","aria-label"],vt=b({__name:"NotFound",setup(s){const{site:e,theme:t}=P(),{localeLinks:n}=X({removeCurrent:!1}),o=M("/");return G(()=>{var d;const r=window.location.pathname.replace(e.value.base,"").replace(/(^.*?\/).*$/,"/$1");n.value.length&&(o.value=((d=n.value.find(({link:p})=>p.startsWith(r)))==null?void 0:d.link)||n.value[0].link)}),(r,d)=>{var p,_,g,V,y;return a(),i("div",rt,[c("p",lt,L(((p=l(t).notFound)==null?void 0:p.code)??"404"),1),c("h1",it,L(((_=l(t).notFound)==null?void 0:_.title)??"PAGE NOT FOUND"),1),ct,c("blockquote",ut,L(((g=l(t).notFound)==null?void 0:g.quote)??"But if you don't change your direction, and if you keep looking, you may end up where you are heading."),1),c("div",dt,[c("a",{class:"link",href:l(ue)(o.value),"aria-label":((V=l(t).notFound)==null?void 0:V.linkLabel)??"go to home"},L(((y=l(t).notFound)==null?void 0:y.linkText)??"Take me home"),9,_t)])])}}});const pt=m(vt,[["__scopeId","data-v-b9c0c15a"]]);function Ne(s,e){if(Array.isArray(s))return Q(s);if(s==null)return[];e=le(e);const t=Object.keys(s).sort((o,r)=>r.split("/").length-o.split("/").length).find(o=>e.startsWith(le(o))),n=t?s[t]:[];return Array.isArray(n)?Q(n):Q(n.items,n.base)}function ht(s){const e=[];let t=0;for(const n in s){const o=s[n];if(o.items){t=e.push(o);continue}e[t]||e.push({items:[]}),e[t].items.push(o)}return e}function ft(s){const e=[];function t(n){for(const o of n)o.text&&o.link&&e.push({text:o.text,link:o.link,docFooterText:o.docFooterText}),o.items&&t(o.items)}return t(s),e}function ie(s,e){return Array.isArray(e)?e.some(t=>ie(s,t)):O(s,e.link)?!0:e.items?ie(s,e.items):!1}function Q(s,e){return[...s].map(t=>{const n={...t},o=n.base||e;return o&&n.link&&(n.link=o+n.link),n.items&&(n.items=Q(n.items,o)),n})}function D(){const{frontmatter:s,page:e,theme:t}=P(),n=re("(min-width: 960px)"),o=M(!1),r=k(()=>{const B=t.value.sidebar,w=e.value.relativePath;return B?Ne(B,w):[]}),d=M(r.value);U(r,(B,w)=>{JSON.stringify(B)!==JSON.stringify(w)&&(d.value=r.value)});const p=k(()=>s.value.sidebar!==!1&&d.value.length>0&&s.value.layout!=="home"),_=k(()=>g?s.value.aside==null?t.value.aside==="left":s.value.aside==="left":!1),g=k(()=>s.value.layout==="home"?!1:s.value.aside!=null?!!s.value.aside:t.value.aside!==!1),V=k(()=>p.value&&n.value),y=k(()=>p.value?ht(d.value):[]);function I(){o.value=!0}function S(){o.value=!1}function C(){o.value?S():I()}return{isOpen:o,sidebar:d,sidebarGroups:y,hasSidebar:p,hasAside:g,leftAside:_,isSidebarEnabled:V,open:I,close:S,toggle:C}}function mt(s,e){let t;te(()=>{t=s.value?document.activeElement:void 0}),G(()=>{window.addEventListener("keyup",n)}),de(()=>{window.removeEventListener("keyup",n)});function n(o){o.key==="Escape"&&s.value&&(e(),t==null||t.focus())}}const Ie=M(K?location.hash:"");K&&window.addEventListener("hashchange",()=>{Ie.value=location.hash});function gt(s){const{page:e}=P(),t=M(!1),n=k(()=>s.value.collapsed!=null),o=k(()=>!!s.value.link),r=M(!1),d=()=>{r.value=O(e.value.relativePath,s.value.link)};U([e,s,Ie],d),G(d);const p=k(()=>r.value?!0:s.value.items?ie(e.value.relativePath,s.value.items):!1),_=k(()=>!!(s.value.items&&s.value.items.length));te(()=>{t.value=!!(n.value&&s.value.collapsed)}),Ve(()=>{(r.value||p.value)&&(t.value=!1)});function g(){n.value&&(t.value=!t.value)}return{collapsed:t,collapsible:n,isLink:o,isActiveLink:r,hasActiveLink:p,hasChildren:_,toggle:g}}function bt(){const{hasSidebar:s}=D(),e=re("(min-width: 960px)"),t=re("(min-width: 1280px)");return{isAsideEnabled:k(()=>!t.value&&!e.value?!1:s.value?t.value:e.value)}}const $t=71;function ve(s){return typeof s.outline=="object"&&!Array.isArray(s.outline)&&s.outline.label||s.outlineTitle||"On this page"}function pe(s){const e=[...document.querySelectorAll(".VPDoc :where(h1,h2,h3,h4,h5,h6)")].filter(t=>t.id&&t.hasChildNodes()).map(t=>{const n=Number(t.tagName[1]);return{title:kt(t),link:"#"+t.id,level:n}});return yt(e,s)}function kt(s){let e="";for(const t of s.childNodes)if(t.nodeType===1){if(t.classList.contains("VPBadge")||t.classList.contains("header-anchor"))continue;e+=t.textContent}else t.nodeType===3&&(e+=t.textContent);return e.trim()}function yt(s,e){if(e===!1)return[];const t=(typeof e=="object"&&!Array.isArray(e)?e.level:e)||2,[n,o]=typeof t=="number"?[t,t]:t==="deep"?[2,6]:t;s=s.filter(d=>d.level>=n&&d.level<=o);const r=[];e:for(let d=0;d=0;_--){const g=s[_];if(g.level{requestAnimationFrame(r),window.addEventListener("scroll",n)}),Ee(()=>{d(location.hash)}),de(()=>{window.removeEventListener("scroll",n)});function r(){if(!t.value)return;const p=[].slice.call(s.value.querySelectorAll(".outline-link")),_=[].slice.call(document.querySelectorAll(".content .header-anchor")).filter(S=>p.some(C=>C.hash===S.hash&&S.offsetParent!==null)),g=window.scrollY,V=window.innerHeight,y=document.body.offsetHeight,I=Math.abs(g+V-y)<1;if(_.length&&I){d(_[_.length-1].hash);return}for(let S=0;S<_.length;S++){const C=_[S],B=_[S+1],[w,R]=Vt(S,C,B);if(w){d(R);return}}}function d(p){o&&o.classList.remove("active"),p==null?o=null:o=s.value.querySelector(`a[href="${decodeURIComponent(p)}"]`);const _=o;_?(_.classList.add("active"),e.value.style.top=_.offsetTop+33+"px",e.value.style.opacity="1"):(e.value.style.top="33px",e.value.style.opacity="0")}}function ye(s){return s.parentElement.offsetTop-$t}function Vt(s,e,t){const n=window.scrollY;return s===0&&n===0?[!0,null]:n{const o=j("VPDocOutlineItem",!0);return a(),i("ul",{class:T(t.root?"root":"nested")},[(a(!0),i(N,null,A(t.headers,({children:r,link:d,title:p})=>(a(),i("li",null,[c("a",{class:"outline-link",href:d,onClick:e,title:p},L(p),9,wt),r!=null&&r.length?(a(),$(o,{key:0,headers:r},null,8,["headers"])):f("",!0)]))),256))],2)}}});const he=m(Lt,[["__scopeId","data-v-463da30f"]]),St=s=>(H("data-v-3a6c4994"),s=s(),z(),s),Mt={class:"content"},Nt={class:"outline-title",role:"heading","aria-level":"2"},It={"aria-labelledby":"doc-outline-aria-label"},Tt=St(()=>c("span",{class:"visually-hidden",id:"doc-outline-aria-label"}," Table of Contents for current page ",-1)),Ct=b({__name:"VPDocAsideOutline",setup(s){const{frontmatter:e,theme:t}=P(),n=_e([]);Y(()=>{n.value=pe(e.value.outline??t.value.outline)});const o=M(),r=M();return Pt(o,r),(d,p)=>(a(),i("div",{class:T(["VPDocAsideOutline",{"has-outline":n.value.length>0}]),ref_key:"container",ref:o,role:"navigation"},[c("div",Mt,[c("div",{class:"outline-marker",ref_key:"marker",ref:r},null,512),c("div",Nt,L(l(ve)(l(t))),1),c("nav",It,[Tt,h(he,{headers:n.value,root:!0},null,8,["headers"])])])],2))}});const Bt=m(Ct,[["__scopeId","data-v-3a6c4994"]]),At={class:"VPDocAsideCarbonAds"},xt=b({__name:"VPDocAsideCarbonAds",props:{carbonAds:{}},setup(s){const e=()=>null;return(t,n)=>(a(),i("div",At,[h(l(e),{"carbon-ads":t.carbonAds},null,8,["carbon-ads"])]))}}),Ht=s=>(H("data-v-cb998dce"),s=s(),z(),s),zt={class:"VPDocAside"},Dt=Ht(()=>c("div",{class:"spacer"},null,-1)),Et=b({__name:"VPDocAside",setup(s){const{theme:e}=P();return(t,n)=>(a(),i("div",zt,[u(t.$slots,"aside-top",{},void 0,!0),u(t.$slots,"aside-outline-before",{},void 0,!0),h(Bt),u(t.$slots,"aside-outline-after",{},void 0,!0),Dt,u(t.$slots,"aside-ads-before",{},void 0,!0),l(e).carbonAds?(a(),$(xt,{key:0,"carbon-ads":l(e).carbonAds},null,8,["carbon-ads"])):f("",!0),u(t.$slots,"aside-ads-after",{},void 0,!0),u(t.$slots,"aside-bottom",{},void 0,!0)]))}});const Ft=m(Et,[["__scopeId","data-v-cb998dce"]]);function Ot(){const{theme:s,page:e}=P();return k(()=>{const{text:t="Edit this page",pattern:n=""}=s.value.editLink||{};let o;return typeof n=="function"?o=n(e.value):o=n.replace(/:path/g,e.value.filePath),{url:o,text:t}})}function Gt(){const{page:s,theme:e,frontmatter:t}=P();return k(()=>{var _,g,V,y,I,S,C,B;const n=Ne(e.value.sidebar,s.value.relativePath),o=ft(n),r=o.findIndex(w=>O(s.value.relativePath,w.link)),d=((_=e.value.docFooter)==null?void 0:_.prev)===!1&&!t.value.prev||t.value.prev===!1,p=((g=e.value.docFooter)==null?void 0:g.next)===!1&&!t.value.next||t.value.next===!1;return{prev:d?void 0:{text:(typeof t.value.prev=="string"?t.value.prev:typeof t.value.prev=="object"?t.value.prev.text:void 0)??((V=o[r-1])==null?void 0:V.docFooterText)??((y=o[r-1])==null?void 0:y.text),link:(typeof t.value.prev=="object"?t.value.prev.link:void 0)??((I=o[r-1])==null?void 0:I.link)},next:p?void 0:{text:(typeof t.value.next=="string"?t.value.next:typeof t.value.next=="object"?t.value.next.text:void 0)??((S=o[r+1])==null?void 0:S.docFooterText)??((C=o[r+1])==null?void 0:C.text),link:(typeof t.value.next=="object"?t.value.next.link:void 0)??((B=o[r+1])==null?void 0:B.link)}}})}const Ut={},jt={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},Rt=c("path",{d:"M18,23H4c-1.7,0-3-1.3-3-3V6c0-1.7,1.3-3,3-3h7c0.6,0,1,0.4,1,1s-0.4,1-1,1H4C3.4,5,3,5.4,3,6v14c0,0.6,0.4,1,1,1h14c0.6,0,1-0.4,1-1v-7c0-0.6,0.4-1,1-1s1,0.4,1,1v7C21,21.7,19.7,23,18,23z"},null,-1),qt=c("path",{d:"M8,17c-0.3,0-0.5-0.1-0.7-0.3C7,16.5,6.9,16.1,7,15.8l1-4c0-0.2,0.1-0.3,0.3-0.5l9.5-9.5c1.2-1.2,3.2-1.2,4.4,0c1.2,1.2,1.2,3.2,0,4.4l-9.5,9.5c-0.1,0.1-0.3,0.2-0.5,0.3l-4,1C8.2,17,8.1,17,8,17zM9.9,12.5l-0.5,2.1l2.1-0.5l9.3-9.3c0.4-0.4,0.4-1.1,0-1.6c-0.4-0.4-1.2-0.4-1.6,0l0,0L9.9,12.5z M18.5,2.5L18.5,2.5L18.5,2.5z"},null,-1),Kt=[Rt,qt];function Wt(s,e){return a(),i("svg",jt,Kt)}const Yt=m(Ut,[["render",Wt]]),E=b({__name:"VPLink",props:{tag:{},href:{},noIcon:{type:Boolean},target:{},rel:{}},setup(s){const e=s,t=k(()=>e.tag??(e.href?"a":"span")),n=k(()=>e.href&&we.test(e.href));return(o,r)=>(a(),$(F(t.value),{class:T(["VPLink",{link:o.href,"vp-external-link-icon":n.value,"no-icon":o.noIcon}]),href:o.href?l(J)(o.href):void 0,target:o.target??(n.value?"_blank":void 0),rel:o.rel??(n.value?"noreferrer":void 0)},{default:v(()=>[u(o.$slots,"default")]),_:3},8,["class","href","target","rel"]))}}),Jt={class:"VPLastUpdated"},Xt=["datetime"],Zt=b({__name:"VPDocFooterLastUpdated",setup(s){const{theme:e,page:t,frontmatter:n,lang:o}=P(),r=k(()=>new Date(n.value.lastUpdated??t.value.lastUpdated)),d=k(()=>r.value.toISOString()),p=M("");return G(()=>{te(()=>{var _,g,V;p.value=new Intl.DateTimeFormat((g=(_=e.value.lastUpdated)==null?void 0:_.formatOptions)!=null&&g.forceLocale?o.value:void 0,((V=e.value.lastUpdated)==null?void 0:V.formatOptions)??{dateStyle:"short",timeStyle:"short"}).format(r.value)})}),(_,g)=>{var V;return a(),i("p",Jt,[x(L(((V=l(e).lastUpdated)==null?void 0:V.text)||l(e).lastUpdatedText||"Last updated")+": ",1),c("time",{datetime:d.value},L(p.value),9,Xt)])}}});const Qt=m(Zt,[["__scopeId","data-v-19a7ae4e"]]),es={key:0,class:"VPDocFooter"},ts={key:0,class:"edit-info"},ss={key:0,class:"edit-link"},ns={key:1,class:"last-updated"},os={key:1,class:"prev-next"},as={class:"pager"},rs=["href"],ls=["innerHTML"],is=["innerHTML"],cs={class:"pager"},us=["href"],ds=["innerHTML"],_s=["innerHTML"],vs=b({__name:"VPDocFooter",setup(s){const{theme:e,page:t,frontmatter:n}=P(),o=Ot(),r=Gt(),d=k(()=>e.value.editLink&&n.value.editLink!==!1),p=k(()=>t.value.lastUpdated&&n.value.lastUpdated!==!1),_=k(()=>d.value||p.value||r.value.prev||r.value.next);return(g,V)=>{var y,I,S,C,B,w;return _.value?(a(),i("footer",es,[u(g.$slots,"doc-footer-before",{},void 0,!0),d.value||p.value?(a(),i("div",ts,[d.value?(a(),i("div",ss,[h(E,{class:"edit-link-button",href:l(o).url,"no-icon":!0},{default:v(()=>[h(Yt,{class:"edit-link-icon","aria-label":"edit icon"}),x(" "+L(l(o).text),1)]),_:1},8,["href"])])):f("",!0),p.value?(a(),i("div",ns,[h(Qt)])):f("",!0)])):f("",!0),(y=l(r).prev)!=null&&y.link||(I=l(r).next)!=null&&I.link?(a(),i("nav",os,[c("div",as,[(S=l(r).prev)!=null&&S.link?(a(),i("a",{key:0,class:"pager-link prev",href:l(J)(l(r).prev.link)},[c("span",{class:"desc",innerHTML:((C=l(e).docFooter)==null?void 0:C.prev)||"Previous page"},null,8,ls),c("span",{class:"title",innerHTML:l(r).prev.text},null,8,is)],8,rs)):f("",!0)]),c("div",cs,[(B=l(r).next)!=null&&B.link?(a(),i("a",{key:0,class:"pager-link next",href:l(J)(l(r).next.link)},[c("span",{class:"desc",innerHTML:((w=l(e).docFooter)==null?void 0:w.next)||"Next page"},null,8,ds),c("span",{class:"title",innerHTML:l(r).next.text},null,8,_s)],8,us)):f("",!0)])])):f("",!0)])):f("",!0)}}});const ps=m(vs,[["__scopeId","data-v-a2d931e4"]]),hs={},fs={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},ms=c("path",{d:"M9,19c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l5.3-5.3L8.3,6.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l6,6c0.4,0.4,0.4,1,0,1.4l-6,6C9.5,18.9,9.3,19,9,19z"},null,-1),gs=[ms];function bs(s,e){return a(),i("svg",fs,gs)}const fe=m(hs,[["render",bs]]),$s={key:0,class:"VPDocOutlineDropdown"},ks={key:0,class:"items"},ys=b({__name:"VPDocOutlineDropdown",setup(s){const{frontmatter:e,theme:t}=P(),n=M(!1);Y(()=>{n.value=!1});const o=_e([]);return Y(()=>{o.value=pe(e.value.outline??t.value.outline)}),(r,d)=>o.value.length>0?(a(),i("div",$s,[c("button",{onClick:d[0]||(d[0]=p=>n.value=!n.value),class:T({open:n.value})},[x(L(l(ve)(l(t)))+" ",1),h(fe,{class:"icon"})],2),n.value?(a(),i("div",ks,[h(he,{headers:o.value},null,8,["headers"])])):f("",!0)])):f("",!0)}});const Ps=m(ys,[["__scopeId","data-v-95bb0785"]]),Vs=s=>(H("data-v-a3c25e27"),s=s(),z(),s),ws={class:"container"},Ls=Vs(()=>c("div",{class:"aside-curtain"},null,-1)),Ss={class:"aside-container"},Ms={class:"aside-content"},Ns={class:"content"},Is={class:"content-container"},Ts={class:"main"},Cs=b({__name:"VPDoc",setup(s){const{theme:e}=P(),t=se(),{hasSidebar:n,hasAside:o,leftAside:r}=D(),d=k(()=>t.path.replace(/[./]+/g,"_").replace(/_html$/,""));return(p,_)=>{const g=j("Content");return a(),i("div",{class:T(["VPDoc",{"has-sidebar":l(n),"has-aside":l(o)}])},[u(p.$slots,"doc-top",{},void 0,!0),c("div",ws,[l(o)?(a(),i("div",{key:0,class:T(["aside",{"left-aside":l(r)}])},[Ls,c("div",Ss,[c("div",Ms,[h(Ft,null,{"aside-top":v(()=>[u(p.$slots,"aside-top",{},void 0,!0)]),"aside-bottom":v(()=>[u(p.$slots,"aside-bottom",{},void 0,!0)]),"aside-outline-before":v(()=>[u(p.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(p.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(p.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(p.$slots,"aside-ads-after",{},void 0,!0)]),_:3})])])],2)):f("",!0),c("div",Ns,[c("div",Is,[u(p.$slots,"doc-before",{},void 0,!0),h(Ps),c("main",Ts,[h(g,{class:T(["vp-doc",[d.value,l(e).externalLinkIcon&&"external-link-icon-enabled"]])},null,8,["class"])]),h(ps,null,{"doc-footer-before":v(()=>[u(p.$slots,"doc-footer-before",{},void 0,!0)]),_:3}),u(p.$slots,"doc-after",{},void 0,!0)])])]),u(p.$slots,"doc-bottom",{},void 0,!0)],2)}}});const Bs=m(Cs,[["__scopeId","data-v-a3c25e27"]]),As=b({__name:"VPButton",props:{tag:{},size:{default:"medium"},theme:{default:"brand"},text:{},href:{}},setup(s){const e=s,t=k(()=>e.href&&we.test(e.href)),n=k(()=>e.tag||e.href?"a":"button");return(o,r)=>(a(),$(F(n.value),{class:T(["VPButton",[o.size,o.theme]]),href:o.href?l(J)(o.href):void 0,target:t.value?"_blank":void 0,rel:t.value?"noreferrer":void 0},{default:v(()=>[x(L(o.text),1)]),_:1},8,["class","href","target","rel"]))}});const xs=m(As,[["__scopeId","data-v-1e76fe75"]]),Hs=["src","alt"],zs=b({inheritAttrs:!1,__name:"VPImage",props:{image:{},alt:{}},setup(s){return(e,t)=>{const n=j("VPImage",!0);return e.image?(a(),i(N,{key:0},[typeof e.image=="string"||"src"in e.image?(a(),i("img",Z({key:0,class:"VPImage"},typeof e.image=="string"?e.$attrs:{...e.image,...e.$attrs},{src:l(ue)(typeof e.image=="string"?e.image:e.image.src),alt:e.alt??(typeof e.image=="string"?"":e.image.alt||"")}),null,16,Hs)):(a(),i(N,{key:1},[h(n,Z({class:"dark",image:e.image.dark,alt:e.image.alt},e.$attrs),null,16,["image","alt"]),h(n,Z({class:"light",image:e.image.light,alt:e.image.alt},e.$attrs),null,16,["image","alt"])],64))],64)):f("",!0)}}});const ee=m(zs,[["__scopeId","data-v-ab19afbb"]]),Ds=s=>(H("data-v-5a3e9999"),s=s(),z(),s),Es={class:"container"},Fs={class:"main"},Os={key:0,class:"name"},Gs=["innerHTML"],Us=["innerHTML"],js=["innerHTML"],Rs={key:0,class:"actions"},qs={key:0,class:"image"},Ks={class:"image-container"},Ws=Ds(()=>c("div",{class:"image-bg"},null,-1)),Ys=b({__name:"VPHero",props:{name:{},text:{},tagline:{},image:{},actions:{}},setup(s){const e=ne("hero-image-slot-exists");return(t,n)=>(a(),i("div",{class:T(["VPHero",{"has-image":t.image||l(e)}])},[c("div",Es,[c("div",Fs,[u(t.$slots,"home-hero-info",{},()=>[t.name?(a(),i("h1",Os,[c("span",{innerHTML:t.name,class:"clip"},null,8,Gs)])):f("",!0),t.text?(a(),i("p",{key:1,innerHTML:t.text,class:"text"},null,8,Us)):f("",!0),t.tagline?(a(),i("p",{key:2,innerHTML:t.tagline,class:"tagline"},null,8,js)):f("",!0)],!0),t.actions?(a(),i("div",Rs,[(a(!0),i(N,null,A(t.actions,o=>(a(),i("div",{key:o.link,class:"action"},[h(xs,{tag:"a",size:"medium",theme:o.theme,text:o.text,href:o.link},null,8,["theme","text","href"])]))),128))])):f("",!0)]),t.image||l(e)?(a(),i("div",qs,[c("div",Ks,[Ws,u(t.$slots,"home-hero-image",{},()=>[t.image?(a(),$(ee,{key:0,class:"image-src",image:t.image},null,8,["image"])):f("",!0)],!0)])])):f("",!0)])],2))}});const Js=m(Ys,[["__scopeId","data-v-5a3e9999"]]),Xs=b({__name:"VPHomeHero",setup(s){const{frontmatter:e}=P();return(t,n)=>l(e).hero?(a(),$(Js,{key:0,class:"VPHomeHero",name:l(e).hero.name,text:l(e).hero.text,tagline:l(e).hero.tagline,image:l(e).hero.image,actions:l(e).hero.actions},{"home-hero-info":v(()=>[u(t.$slots,"home-hero-info")]),"home-hero-image":v(()=>[u(t.$slots,"home-hero-image")]),_:3},8,["name","text","tagline","image","actions"])):f("",!0)}}),Zs={},Qs={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},en=c("path",{d:"M19.9,12.4c0.1-0.2,0.1-0.5,0-0.8c-0.1-0.1-0.1-0.2-0.2-0.3l-7-7c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4l5.3,5.3H5c-0.6,0-1,0.4-1,1s0.4,1,1,1h11.6l-5.3,5.3c-0.4,0.4-0.4,1,0,1.4c0.2,0.2,0.5,0.3,0.7,0.3s0.5-0.1,0.7-0.3l7-7C19.8,12.6,19.9,12.5,19.9,12.4z"},null,-1),tn=[en];function sn(s,e){return a(),i("svg",Qs,tn)}const nn=m(Zs,[["render",sn]]),on={class:"box"},an={key:0,class:"icon"},rn=["innerHTML"],ln=["innerHTML"],cn=["innerHTML"],un={key:4,class:"link-text"},dn={class:"link-text-value"},_n=b({__name:"VPFeature",props:{icon:{},title:{},details:{},link:{},linkText:{},rel:{},target:{}},setup(s){return(e,t)=>(a(),$(E,{class:"VPFeature",href:e.link,rel:e.rel,target:e.target,"no-icon":!0,tag:e.link?"a":"div"},{default:v(()=>[c("article",on,[typeof e.icon=="object"&&e.icon.wrap?(a(),i("div",an,[h(ee,{image:e.icon,alt:e.icon.alt,height:e.icon.height||48,width:e.icon.width||48},null,8,["image","alt","height","width"])])):typeof e.icon=="object"?(a(),$(ee,{key:1,image:e.icon,alt:e.icon.alt,height:e.icon.height||48,width:e.icon.width||48},null,8,["image","alt","height","width"])):e.icon?(a(),i("div",{key:2,class:"icon",innerHTML:e.icon},null,8,rn)):f("",!0),c("h2",{class:"title",innerHTML:e.title},null,8,ln),e.details?(a(),i("p",{key:3,class:"details",innerHTML:e.details},null,8,cn)):f("",!0),e.linkText?(a(),i("div",un,[c("p",dn,[x(L(e.linkText)+" ",1),h(nn,{class:"link-text-icon"})])])):f("",!0)])]),_:1},8,["href","rel","target","tag"]))}});const vn=m(_n,[["__scopeId","data-v-ee984185"]]),pn={key:0,class:"VPFeatures"},hn={class:"container"},fn={class:"items"},mn=b({__name:"VPFeatures",props:{features:{}},setup(s){const e=s,t=k(()=>{const n=e.features.length;if(n){if(n===2)return"grid-2";if(n===3)return"grid-3";if(n%3===0)return"grid-6";if(n>3)return"grid-4"}else return});return(n,o)=>n.features?(a(),i("div",pn,[c("div",hn,[c("div",fn,[(a(!0),i(N,null,A(n.features,r=>(a(),i("div",{key:r.title,class:T(["item",[t.value]])},[h(vn,{icon:r.icon,title:r.title,details:r.details,link:r.link,"link-text":r.linkText,rel:r.rel,target:r.target},null,8,["icon","title","details","link","link-text","rel","target"])],2))),128))])])])):f("",!0)}});const gn=m(mn,[["__scopeId","data-v-b1eea84a"]]),bn=b({__name:"VPHomeFeatures",setup(s){const{frontmatter:e}=P();return(t,n)=>l(e).features?(a(),$(gn,{key:0,class:"VPHomeFeatures",features:l(e).features},null,8,["features"])):f("",!0)}}),$n={class:"VPHome"},kn=b({__name:"VPHome",setup(s){return(e,t)=>{const n=j("Content");return a(),i("div",$n,[u(e.$slots,"home-hero-before",{},void 0,!0),h(Xs,null,{"home-hero-info":v(()=>[u(e.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(e.$slots,"home-hero-image",{},void 0,!0)]),_:3}),u(e.$slots,"home-hero-after",{},void 0,!0),u(e.$slots,"home-features-before",{},void 0,!0),h(bn),u(e.$slots,"home-features-after",{},void 0,!0),h(n)])}}});const yn=m(kn,[["__scopeId","data-v-20eabd3a"]]),Pn={},Vn={class:"VPPage"};function wn(s,e){const t=j("Content");return a(),i("div",Vn,[u(s.$slots,"page-top"),h(t),u(s.$slots,"page-bottom")])}const Ln=m(Pn,[["render",wn]]),Sn=b({__name:"VPContent",setup(s){const{page:e,frontmatter:t}=P(),{hasSidebar:n}=D();return(o,r)=>(a(),i("div",{class:T(["VPContent",{"has-sidebar":l(n),"is-home":l(t).layout==="home"}]),id:"VPContent"},[l(e).isNotFound?u(o.$slots,"not-found",{key:0},()=>[h(pt)],!0):l(t).layout==="page"?(a(),$(Ln,{key:1},{"page-top":v(()=>[u(o.$slots,"page-top",{},void 0,!0)]),"page-bottom":v(()=>[u(o.$slots,"page-bottom",{},void 0,!0)]),_:3})):l(t).layout==="home"?(a(),$(yn,{key:2},{"home-hero-before":v(()=>[u(o.$slots,"home-hero-before",{},void 0,!0)]),"home-hero-info":v(()=>[u(o.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(o.$slots,"home-hero-image",{},void 0,!0)]),"home-hero-after":v(()=>[u(o.$slots,"home-hero-after",{},void 0,!0)]),"home-features-before":v(()=>[u(o.$slots,"home-features-before",{},void 0,!0)]),"home-features-after":v(()=>[u(o.$slots,"home-features-after",{},void 0,!0)]),_:3})):l(t).layout&&l(t).layout!=="doc"?(a(),$(F(l(t).layout),{key:3})):(a(),$(Bs,{key:4},{"doc-top":v(()=>[u(o.$slots,"doc-top",{},void 0,!0)]),"doc-bottom":v(()=>[u(o.$slots,"doc-bottom",{},void 0,!0)]),"doc-footer-before":v(()=>[u(o.$slots,"doc-footer-before",{},void 0,!0)]),"doc-before":v(()=>[u(o.$slots,"doc-before",{},void 0,!0)]),"doc-after":v(()=>[u(o.$slots,"doc-after",{},void 0,!0)]),"aside-top":v(()=>[u(o.$slots,"aside-top",{},void 0,!0)]),"aside-outline-before":v(()=>[u(o.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(o.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(o.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(o.$slots,"aside-ads-after",{},void 0,!0)]),"aside-bottom":v(()=>[u(o.$slots,"aside-bottom",{},void 0,!0)]),_:3}))],2))}});const Mn=m(Sn,[["__scopeId","data-v-3cf691b6"]]),Nn={class:"container"},In=["innerHTML"],Tn=["innerHTML"],Cn=b({__name:"VPFooter",setup(s){const{theme:e,frontmatter:t}=P(),{hasSidebar:n}=D();return(o,r)=>l(e).footer&&l(t).footer!==!1?(a(),i("footer",{key:0,class:T(["VPFooter",{"has-sidebar":l(n)}])},[c("div",Nn,[l(e).footer.message?(a(),i("p",{key:0,class:"message",innerHTML:l(e).footer.message},null,8,In)):f("",!0),l(e).footer.copyright?(a(),i("p",{key:1,class:"copyright",innerHTML:l(e).footer.copyright},null,8,Tn)):f("",!0)])],2)):f("",!0)}});const Bn=m(Cn,[["__scopeId","data-v-e4279f1c"]]),An={class:"header"},xn={class:"outline"},Hn=b({__name:"VPLocalNavOutlineDropdown",props:{headers:{},navHeight:{}},setup(s){const e=s,{theme:t}=P(),n=M(!1),o=M(0),r=M();Y(()=>{n.value=!1});function d(){n.value=!n.value,o.value=window.innerHeight+Math.min(window.scrollY-e.navHeight,0)}function p(g){g.target.classList.contains("outline-link")&&(r.value&&(r.value.style.transition="none"),Oe(()=>{n.value=!1}))}function _(){n.value=!1,window.scrollTo({top:0,left:0,behavior:"smooth"})}return(g,V)=>(a(),i("div",{class:"VPLocalNavOutlineDropdown",style:Fe({"--vp-vh":o.value+"px"})},[g.headers.length>0?(a(),i("button",{key:0,onClick:d,class:T({open:n.value})},[x(L(l(ve)(l(t)))+" ",1),h(fe,{class:"icon"})],2)):(a(),i("button",{key:1,onClick:_},L(l(t).returnToTopLabel||"Return to top"),1)),h(ce,{name:"flyout"},{default:v(()=>[n.value?(a(),i("div",{key:0,ref_key:"items",ref:r,class:"items",onClick:p},[c("div",An,[c("a",{class:"top-link",href:"#",onClick:_},L(l(t).returnToTopLabel||"Return to top"),1)]),c("div",xn,[h(he,{headers:g.headers},null,8,["headers"])])],512)):f("",!0)]),_:1})],4))}});const zn=m(Hn,[["__scopeId","data-v-24251f6f"]]),Dn={},En={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Fn=c("path",{d:"M17,11H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h14c0.6,0,1,0.4,1,1S17.6,11,17,11z"},null,-1),On=c("path",{d:"M21,7H3C2.4,7,2,6.6,2,6s0.4-1,1-1h18c0.6,0,1,0.4,1,1S21.6,7,21,7z"},null,-1),Gn=c("path",{d:"M21,15H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h18c0.6,0,1,0.4,1,1S21.6,15,21,15z"},null,-1),Un=c("path",{d:"M17,19H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h14c0.6,0,1,0.4,1,1S17.6,19,17,19z"},null,-1),jn=[Fn,On,Gn,Un];function Rn(s,e){return a(),i("svg",En,jn)}const qn=m(Dn,[["render",Rn]]),Kn=["aria-expanded"],Wn={class:"menu-text"},Yn=b({__name:"VPLocalNav",props:{open:{type:Boolean}},emits:["open-menu"],setup(s){const{theme:e,frontmatter:t}=P(),{hasSidebar:n}=D(),{y:o}=Le(),r=_e([]),d=M(0);G(()=>{d.value=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--vp-nav-height"))}),Y(()=>{r.value=pe(t.value.outline??e.value.outline)});const p=k(()=>r.value.length===0&&!n.value),_=k(()=>({VPLocalNav:!0,fixed:p.value,"reached-top":o.value>=d.value}));return(g,V)=>l(t).layout!=="home"&&(!p.value||l(o)>=d.value)?(a(),i("div",{key:0,class:T(_.value)},[l(n)?(a(),i("button",{key:0,class:"menu","aria-expanded":g.open,"aria-controls":"VPSidebarNav",onClick:V[0]||(V[0]=y=>g.$emit("open-menu"))},[h(qn,{class:"menu-icon"}),c("span",Wn,L(l(e).sidebarMenuLabel||"Menu"),1)],8,Kn)):f("",!0),h(zn,{headers:r.value,navHeight:d.value},null,8,["headers","navHeight"])],2)):f("",!0)}});const Jn=m(Yn,[["__scopeId","data-v-9e669cc1"]]);function Xn(){const s=M(!1);function e(){s.value=!0,window.addEventListener("resize",o)}function t(){s.value=!1,window.removeEventListener("resize",o)}function n(){s.value?t():e()}function o(){window.outerWidth>=768&&t()}const r=se();return U(()=>r.path,t),{isScreenOpen:s,openScreen:e,closeScreen:t,toggleScreen:n}}const Zn={},Qn={class:"VPSwitch",type:"button",role:"switch"},eo={class:"check"},to={key:0,class:"icon"};function so(s,e){return a(),i("button",Qn,[c("span",eo,[s.$slots.default?(a(),i("span",to,[u(s.$slots,"default",{},void 0,!0)])):f("",!0)])])}const no=m(Zn,[["render",so],["__scopeId","data-v-1c29e291"]]),oo={},ao={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},ro=c("path",{d:"M12.1,22c-0.3,0-0.6,0-0.9,0c-5.5-0.5-9.5-5.4-9-10.9c0.4-4.8,4.2-8.6,9-9c0.4,0,0.8,0.2,1,0.5c0.2,0.3,0.2,0.8-0.1,1.1c-2,2.7-1.4,6.4,1.3,8.4c2.1,1.6,5,1.6,7.1,0c0.3-0.2,0.7-0.3,1.1-0.1c0.3,0.2,0.5,0.6,0.5,1c-0.2,2.7-1.5,5.1-3.6,6.8C16.6,21.2,14.4,22,12.1,22zM9.3,4.4c-2.9,1-5,3.6-5.2,6.8c-0.4,4.4,2.8,8.3,7.2,8.7c2.1,0.2,4.2-0.4,5.8-1.8c1.1-0.9,1.9-2.1,2.4-3.4c-2.5,0.9-5.3,0.5-7.5-1.1C9.2,11.4,8.1,7.7,9.3,4.4z"},null,-1),lo=[ro];function io(s,e){return a(),i("svg",ao,lo)}const co=m(oo,[["render",io]]),uo={},_o={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},vo=Ge('',9),po=[vo];function ho(s,e){return a(),i("svg",_o,po)}const fo=m(uo,[["render",ho]]),mo=b({__name:"VPSwitchAppearance",setup(s){const{isDark:e}=P(),t=ne("toggle-appearance",()=>{e.value=!e.value});return(n,o)=>(a(),$(no,{title:"toggle dark mode",class:"VPSwitchAppearance","aria-checked":l(e),onClick:l(t)},{default:v(()=>[h(fo,{class:"sun"}),h(co,{class:"moon"})]),_:1},8,["aria-checked","onClick"]))}});const me=m(mo,[["__scopeId","data-v-3329432d"]]),go={key:0,class:"VPNavBarAppearance"},bo=b({__name:"VPNavBarAppearance",setup(s){const{site:e}=P();return(t,n)=>l(e).appearance&&l(e).appearance!=="force-dark"?(a(),i("div",go,[h(me)])):f("",!0)}});const $o=m(bo,[["__scopeId","data-v-283b26e9"]]),ge=M();let Te=!1,ae=0;function ko(s){const e=M(!1);if(K){!Te&&yo(),ae++;const t=U(ge,n=>{var o,r,d;n===s.el.value||(o=s.el.value)!=null&&o.contains(n)?(e.value=!0,(r=s.onFocus)==null||r.call(s)):(e.value=!1,(d=s.onBlur)==null||d.call(s))});de(()=>{t(),ae--,ae||Po()})}return Ue(e)}function yo(){document.addEventListener("focusin",Ce),Te=!0,ge.value=document.activeElement}function Po(){document.removeEventListener("focusin",Ce)}function Ce(){ge.value=document.activeElement}const Vo={},wo={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Lo=c("path",{d:"M12,16c-0.3,0-0.5-0.1-0.7-0.3l-6-6c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l5.3,5.3l5.3-5.3c0.4-0.4,1-0.4,1.4,0s0.4,1,0,1.4l-6,6C12.5,15.9,12.3,16,12,16z"},null,-1),So=[Lo];function Mo(s,e){return a(),i("svg",wo,So)}const Be=m(Vo,[["render",Mo]]),No={},Io={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},To=c("circle",{cx:"12",cy:"12",r:"2"},null,-1),Co=c("circle",{cx:"19",cy:"12",r:"2"},null,-1),Bo=c("circle",{cx:"5",cy:"12",r:"2"},null,-1),Ao=[To,Co,Bo];function xo(s,e){return a(),i("svg",Io,Ao)}const Ho=m(No,[["render",xo]]),zo={class:"VPMenuLink"},Do=b({__name:"VPMenuLink",props:{item:{}},setup(s){const{page:e}=P();return(t,n)=>(a(),i("div",zo,[h(E,{class:T({active:l(O)(l(e).relativePath,t.item.activeMatch||t.item.link,!!t.item.activeMatch)}),href:t.item.link,target:t.item.target,rel:t.item.rel},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["class","href","target","rel"])]))}});const oe=m(Do,[["__scopeId","data-v-f51f088d"]]),Eo={class:"VPMenuGroup"},Fo={key:0,class:"title"},Oo=b({__name:"VPMenuGroup",props:{text:{},items:{}},setup(s){return(e,t)=>(a(),i("div",Eo,[e.text?(a(),i("p",Fo,L(e.text),1)):f("",!0),(a(!0),i(N,null,A(e.items,n=>(a(),i(N,null,["link"in n?(a(),$(oe,{key:0,item:n},null,8,["item"])):f("",!0)],64))),256))]))}});const Go=m(Oo,[["__scopeId","data-v-a6b0397c"]]),Uo={class:"VPMenu"},jo={key:0,class:"items"},Ro=b({__name:"VPMenu",props:{items:{}},setup(s){return(e,t)=>(a(),i("div",Uo,[e.items?(a(),i("div",jo,[(a(!0),i(N,null,A(e.items,n=>(a(),i(N,{key:n.text},["link"in n?(a(),$(oe,{key:0,item:n},null,8,["item"])):(a(),$(Go,{key:1,text:n.text,items:n.items},null,8,["text","items"]))],64))),128))])):f("",!0),u(e.$slots,"default",{},void 0,!0)]))}});const qo=m(Ro,[["__scopeId","data-v-e42ed9b3"]]),Ko=["aria-expanded","aria-label"],Wo={key:0,class:"text"},Yo=["innerHTML"],Jo={class:"menu"},Xo=b({__name:"VPFlyout",props:{icon:{},button:{},label:{},items:{}},setup(s){const e=M(!1),t=M();ko({el:t,onBlur:n});function n(){e.value=!1}return(o,r)=>(a(),i("div",{class:"VPFlyout",ref_key:"el",ref:t,onMouseenter:r[1]||(r[1]=d=>e.value=!0),onMouseleave:r[2]||(r[2]=d=>e.value=!1)},[c("button",{type:"button",class:"button","aria-haspopup":"true","aria-expanded":e.value,"aria-label":o.label,onClick:r[0]||(r[0]=d=>e.value=!e.value)},[o.button||o.icon?(a(),i("span",Wo,[o.icon?(a(),$(F(o.icon),{key:0,class:"option-icon"})):f("",!0),o.button?(a(),i("span",{key:1,innerHTML:o.button},null,8,Yo)):f("",!0),h(Be,{class:"text-icon"})])):(a(),$(Ho,{key:1,class:"icon"}))],8,Ko),c("div",Jo,[h(qo,{items:o.items},{default:v(()=>[u(o.$slots,"default",{},void 0,!0)]),_:3},8,["items"])])],544))}});const be=m(Xo,[["__scopeId","data-v-aa8de344"]]),Zo={discord:'Discord',facebook:'Facebook',github:'GitHub',instagram:'Instagram',linkedin:'LinkedIn',mastodon:'Mastodon',slack:'Slack',twitter:'Twitter',x:'X',youtube:'YouTube'},Qo=["href","aria-label","innerHTML"],ea=b({__name:"VPSocialLink",props:{icon:{},link:{},ariaLabel:{}},setup(s){const e=s,t=k(()=>typeof e.icon=="object"?e.icon.svg:Zo[e.icon]);return(n,o)=>(a(),i("a",{class:"VPSocialLink no-icon",href:n.link,"aria-label":n.ariaLabel??(typeof n.icon=="string"?n.icon:""),target:"_blank",rel:"noopener",innerHTML:t.value},null,8,Qo))}});const ta=m(ea,[["__scopeId","data-v-16cf740a"]]),sa={class:"VPSocialLinks"},na=b({__name:"VPSocialLinks",props:{links:{}},setup(s){return(e,t)=>(a(),i("div",sa,[(a(!0),i(N,null,A(e.links,({link:n,icon:o,ariaLabel:r})=>(a(),$(ta,{key:n,icon:o,link:n,ariaLabel:r},null,8,["icon","link","ariaLabel"]))),128))]))}});const $e=m(na,[["__scopeId","data-v-e71e869c"]]),oa={key:0,class:"group translations"},aa={class:"trans-title"},ra={key:1,class:"group"},la={class:"item appearance"},ia={class:"label"},ca={class:"appearance-action"},ua={key:2,class:"group"},da={class:"item social-links"},_a=b({__name:"VPNavBarExtra",setup(s){const{site:e,theme:t}=P(),{localeLinks:n,currentLang:o}=X({correspondingLink:!0}),r=k(()=>n.value.length&&o.value.label||e.value.appearance||t.value.socialLinks);return(d,p)=>r.value?(a(),$(be,{key:0,class:"VPNavBarExtra",label:"extra navigation"},{default:v(()=>[l(n).length&&l(o).label?(a(),i("div",oa,[c("p",aa,L(l(o).label),1),(a(!0),i(N,null,A(l(n),_=>(a(),$(oe,{key:_.link,item:_},null,8,["item"]))),128))])):f("",!0),l(e).appearance?(a(),i("div",ra,[c("div",la,[c("p",ia,L(l(t).darkModeSwitchLabel||"Appearance"),1),c("div",ca,[h(me)])])])):f("",!0),l(t).socialLinks?(a(),i("div",ua,[c("div",da,[h($e,{class:"social-links-list",links:l(t).socialLinks},null,8,["links"])])])):f("",!0)]),_:1})):f("",!0)}});const va=m(_a,[["__scopeId","data-v-c8c2ae4b"]]),pa=s=>(H("data-v-6bee1efd"),s=s(),z(),s),ha=["aria-expanded"],fa=pa(()=>c("span",{class:"container"},[c("span",{class:"top"}),c("span",{class:"middle"}),c("span",{class:"bottom"})],-1)),ma=[fa],ga=b({__name:"VPNavBarHamburger",props:{active:{type:Boolean}},emits:["click"],setup(s){return(e,t)=>(a(),i("button",{type:"button",class:T(["VPNavBarHamburger",{active:e.active}]),"aria-label":"mobile navigation","aria-expanded":e.active,"aria-controls":"VPNavScreen",onClick:t[0]||(t[0]=n=>e.$emit("click"))},ma,10,ha))}});const ba=m(ga,[["__scopeId","data-v-6bee1efd"]]),$a=["innerHTML"],ka=b({__name:"VPNavBarMenuLink",props:{item:{}},setup(s){const{page:e}=P();return(t,n)=>(a(),$(E,{class:T({VPNavBarMenuLink:!0,active:l(O)(l(e).relativePath,t.item.activeMatch||t.item.link,!!t.item.activeMatch)}),href:t.item.link,target:t.item.target,rel:t.item.rel,tabindex:"0"},{default:v(()=>[c("span",{innerHTML:t.item.text},null,8,$a)]),_:1},8,["class","href","target","rel"]))}});const ya=m(ka,[["__scopeId","data-v-cb318fec"]]),Pa=b({__name:"VPNavBarMenuGroup",props:{item:{}},setup(s){const e=s,{page:t}=P(),n=r=>"link"in r?O(t.value.relativePath,r.link,!!e.item.activeMatch):r.items.some(n),o=k(()=>n(e.item));return(r,d)=>(a(),$(be,{class:T({VPNavBarMenuGroup:!0,active:l(O)(l(t).relativePath,r.item.activeMatch,!!r.item.activeMatch)||o.value}),button:r.item.text,items:r.item.items},null,8,["class","button","items"]))}}),Va=s=>(H("data-v-f732b5d0"),s=s(),z(),s),wa={key:0,"aria-labelledby":"main-nav-aria-label",class:"VPNavBarMenu"},La=Va(()=>c("span",{id:"main-nav-aria-label",class:"visually-hidden"},"Main Navigation",-1)),Sa=b({__name:"VPNavBarMenu",setup(s){const{theme:e}=P();return(t,n)=>l(e).nav?(a(),i("nav",wa,[La,(a(!0),i(N,null,A(l(e).nav,o=>(a(),i(N,{key:o.text},["link"in o?(a(),$(ya,{key:0,item:o},null,8,["item"])):(a(),$(Pa,{key:1,item:o},null,8,["item"]))],64))),128))])):f("",!0)}});const Ma=m(Sa,[["__scopeId","data-v-f732b5d0"]]);function Na(s,e){const{localeIndex:t}=P();function n(o){var S,C;const r=o.split("."),d=s&&typeof s=="object",p=d&&((C=(S=s.locales)==null?void 0:S[t.value])==null?void 0:C.translations)||null,_=d&&s.translations||null;let g=p,V=_,y=e;const I=r.pop();for(const B of r){let w=null;const R=y==null?void 0:y[B];R&&(w=y=R);const W=V==null?void 0:V[B];W&&(w=V=W);const q=g==null?void 0:g[B];q&&(w=g=q),R||(y=w),W||(V=w),q||(g=w)}return(g==null?void 0:g[I])??(V==null?void 0:V[I])??(y==null?void 0:y[I])??""}return n}const Ia=["aria-label"],Ta={class:"DocSearch-Button-Container"},Ca=c("svg",{class:"DocSearch-Search-Icon",width:"20",height:"20",viewBox:"0 0 20 20","aria-label":"search icon"},[c("path",{d:"M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z",stroke:"currentColor",fill:"none","fill-rule":"evenodd","stroke-linecap":"round","stroke-linejoin":"round"})],-1),Ba={class:"DocSearch-Button-Placeholder"},Aa=c("span",{class:"DocSearch-Button-Keys"},[c("kbd",{class:"DocSearch-Button-Key"}),c("kbd",{class:"DocSearch-Button-Key"},"K")],-1),Pe=b({__name:"VPNavBarSearchButton",setup(s){const{theme:e}=P(),t={button:{buttonText:"Search",buttonAriaLabel:"Search"}},n=je(Na)(Re(()=>{var o;return(o=e.value.search)==null?void 0:o.options}),t);return(o,r)=>(a(),i("button",{type:"button",class:"DocSearch DocSearch-Button","aria-label":l(n)("button.buttonAriaLabel")},[c("span",Ta,[Ca,c("span",Ba,L(l(n)("button.buttonText")),1)]),Aa],8,Ia))}});const xa={class:"VPNavBarSearch"},Ha={id:"local-search"},za={key:1,id:"docsearch"},Da=b({__name:"VPNavBarSearch",setup(s){const e=qe(()=>Ke(()=>import("./VPLocalSearchBox.a2ac4698.js"),["assets/chunks/VPLocalSearchBox.a2ac4698.js","assets/chunks/framework.2959b752.js"])),t=()=>null,{theme:n}=P(),o=M(!1),r=M(!1);G(()=>{});function d(){o.value||(o.value=!0,setTimeout(p,16))}function p(){const y=new Event("keydown");y.key="k",y.metaKey=!0,window.dispatchEvent(y),setTimeout(()=>{document.querySelector(".DocSearch-Modal")||p()},16)}function _(y){const I=y.target,S=I.tagName;return I.isContentEditable||S==="INPUT"||S==="SELECT"||S==="TEXTAREA"}const g=M(!1);ke("k",y=>{(y.ctrlKey||y.metaKey)&&(y.preventDefault(),g.value=!0)}),ke("/",y=>{_(y)||(y.preventDefault(),g.value=!0)});const V="local";return(y,I)=>{var S;return a(),i("div",xa,[l(V)==="local"?(a(),i(N,{key:0},[g.value?(a(),$(l(e),{key:0,onClose:I[0]||(I[0]=C=>g.value=!1)})):f("",!0),c("div",Ha,[h(Pe,{onClick:I[1]||(I[1]=C=>g.value=!0)})])],64)):l(V)==="algolia"?(a(),i(N,{key:1},[o.value?(a(),$(l(t),{key:0,algolia:((S=l(n).search)==null?void 0:S.options)??l(n).algolia,onVnodeBeforeMount:I[2]||(I[2]=C=>r.value=!0)},null,8,["algolia"])):f("",!0),r.value?f("",!0):(a(),i("div",za,[h(Pe,{onClick:d})]))],64)):f("",!0)])}}});const Ea=b({__name:"VPNavBarSocialLinks",setup(s){const{theme:e}=P();return(t,n)=>l(e).socialLinks?(a(),$($e,{key:0,class:"VPNavBarSocialLinks",links:l(e).socialLinks},null,8,["links"])):f("",!0)}});const Fa=m(Ea,[["__scopeId","data-v-ef6192dc"]]),Oa=["href"],Ga=b({__name:"VPNavBarTitle",setup(s){const{site:e,theme:t}=P(),{hasSidebar:n}=D(),{currentLang:o}=X();return(r,d)=>(a(),i("div",{class:T(["VPNavBarTitle",{"has-sidebar":l(n)}])},[c("a",{class:"title",href:l(t).logoLink??l(J)(l(o).link)},[u(r.$slots,"nav-bar-title-before",{},void 0,!0),l(t).logo?(a(),$(ee,{key:0,class:"logo",image:l(t).logo},null,8,["image"])):f("",!0),l(t).siteTitle?(a(),i(N,{key:1},[x(L(l(t).siteTitle),1)],64)):l(t).siteTitle===void 0?(a(),i(N,{key:2},[x(L(l(e).title),1)],64)):f("",!0),u(r.$slots,"nav-bar-title-after",{},void 0,!0)],8,Oa)],2))}});const Ua=m(Ga,[["__scopeId","data-v-2973dbb4"]]),ja={},Ra={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},qa=c("path",{d:"M0 0h24v24H0z",fill:"none"},null,-1),Ka=c("path",{d:" M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z ",class:"css-c4d79v"},null,-1),Wa=[qa,Ka];function Ya(s,e){return a(),i("svg",Ra,Wa)}const Ae=m(ja,[["render",Ya]]),Ja={class:"items"},Xa={class:"title"},Za=b({__name:"VPNavBarTranslations",setup(s){const{theme:e}=P(),{localeLinks:t,currentLang:n}=X({correspondingLink:!0});return(o,r)=>l(t).length&&l(n).label?(a(),$(be,{key:0,class:"VPNavBarTranslations",icon:Ae,label:l(e).langMenuLabel||"Change language"},{default:v(()=>[c("div",Ja,[c("p",Xa,L(l(n).label),1),(a(!0),i(N,null,A(l(t),d=>(a(),$(oe,{key:d.link,item:d},null,8,["item"]))),128))])]),_:1},8,["label"])):f("",!0)}});const Qa=m(Za,[["__scopeId","data-v-ff4524ae"]]),er=s=>(H("data-v-f1abbc6e"),s=s(),z(),s),tr={class:"container"},sr={class:"title"},nr={class:"content"},or=er(()=>c("div",{class:"curtain"},null,-1)),ar={class:"content-body"},rr=b({__name:"VPNavBar",props:{isScreenOpen:{type:Boolean}},emits:["toggle-screen"],setup(s){const{y:e}=Le(),{hasSidebar:t}=D(),{frontmatter:n}=P(),o=M({});return Ve(()=>{o.value={"has-sidebar":t.value,top:n.value.layout==="home"&&e.value===0}}),(r,d)=>(a(),i("div",{class:T(["VPNavBar",o.value])},[c("div",tr,[c("div",sr,[h(Ua,null,{"nav-bar-title-before":v(()=>[u(r.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(r.$slots,"nav-bar-title-after",{},void 0,!0)]),_:3})]),c("div",nr,[or,c("div",ar,[u(r.$slots,"nav-bar-content-before",{},void 0,!0),h(Da,{class:"search"}),h(Ma,{class:"menu"}),h(Qa,{class:"translations"}),h($o,{class:"appearance"}),h(Fa,{class:"social-links"}),h(va,{class:"extra"}),u(r.$slots,"nav-bar-content-after",{},void 0,!0),h(ba,{class:"hamburger",active:r.isScreenOpen,onClick:d[0]||(d[0]=p=>r.$emit("toggle-screen"))},null,8,["active"])])])])],2))}});const lr=m(rr,[["__scopeId","data-v-f1abbc6e"]]),ir={key:0,class:"VPNavScreenAppearance"},cr={class:"text"},ur=b({__name:"VPNavScreenAppearance",setup(s){const{site:e,theme:t}=P();return(n,o)=>l(e).appearance?(a(),i("div",ir,[c("p",cr,L(l(t).darkModeSwitchLabel||"Appearance"),1),h(me)])):f("",!0)}});const dr=m(ur,[["__scopeId","data-v-0dc5cf49"]]),_r=b({__name:"VPNavScreenMenuLink",props:{item:{}},setup(s){const e=ne("close-screen");return(t,n)=>(a(),$(E,{class:"VPNavScreenMenuLink",href:t.item.link,target:t.item.target,rel:t.item.rel,onClick:l(e)},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["href","target","rel","onClick"]))}});const vr=m(_r,[["__scopeId","data-v-fe523e3d"]]),pr={},hr={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},fr=c("path",{d:"M18.9,10.9h-6v-6c0-0.6-0.4-1-1-1s-1,0.4-1,1v6h-6c-0.6,0-1,0.4-1,1s0.4,1,1,1h6v6c0,0.6,0.4,1,1,1s1-0.4,1-1v-6h6c0.6,0,1-0.4,1-1S19.5,10.9,18.9,10.9z"},null,-1),mr=[fr];function gr(s,e){return a(),i("svg",hr,mr)}const br=m(pr,[["render",gr]]),$r=b({__name:"VPNavScreenMenuGroupLink",props:{item:{}},setup(s){const e=ne("close-screen");return(t,n)=>(a(),$(E,{class:"VPNavScreenMenuGroupLink",href:t.item.link,target:t.item.target,rel:t.item.rel,onClick:l(e)},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["href","target","rel","onClick"]))}});const xe=m($r,[["__scopeId","data-v-aea78dd1"]]),kr={class:"VPNavScreenMenuGroupSection"},yr={key:0,class:"title"},Pr=b({__name:"VPNavScreenMenuGroupSection",props:{text:{},items:{}},setup(s){return(e,t)=>(a(),i("div",kr,[e.text?(a(),i("p",yr,L(e.text),1)):f("",!0),(a(!0),i(N,null,A(e.items,n=>(a(),$(xe,{key:n.text,item:n},null,8,["item"]))),128))]))}});const Vr=m(Pr,[["__scopeId","data-v-f60dbfa7"]]),wr=["aria-controls","aria-expanded"],Lr={class:"button-text"},Sr=["id"],Mr={key:1,class:"group"},Nr=b({__name:"VPNavScreenMenuGroup",props:{text:{},items:{}},setup(s){const e=s,t=M(!1),n=k(()=>`NavScreenGroup-${e.text.replace(" ","-").toLowerCase()}`);function o(){t.value=!t.value}return(r,d)=>(a(),i("div",{class:T(["VPNavScreenMenuGroup",{open:t.value}])},[c("button",{class:"button","aria-controls":n.value,"aria-expanded":t.value,onClick:o},[c("span",Lr,L(r.text),1),h(br,{class:"button-icon"})],8,wr),c("div",{id:n.value,class:"items"},[(a(!0),i(N,null,A(r.items,p=>(a(),i(N,{key:p.text},["link"in p?(a(),i("div",{key:p.text,class:"item"},[h(xe,{item:p},null,8,["item"])])):(a(),i("div",Mr,[h(Vr,{text:p.text,items:p.items},null,8,["text","items"])]))],64))),128))],8,Sr)],2))}});const Ir=m(Nr,[["__scopeId","data-v-c2c554ed"]]),Tr={key:0,class:"VPNavScreenMenu"},Cr=b({__name:"VPNavScreenMenu",setup(s){const{theme:e}=P();return(t,n)=>l(e).nav?(a(),i("nav",Tr,[(a(!0),i(N,null,A(l(e).nav,o=>(a(),i(N,{key:o.text},["link"in o?(a(),$(vr,{key:0,item:o},null,8,["item"])):(a(),$(Ir,{key:1,text:o.text||"",items:o.items},null,8,["text","items"]))],64))),128))])):f("",!0)}}),Br=b({__name:"VPNavScreenSocialLinks",setup(s){const{theme:e}=P();return(t,n)=>l(e).socialLinks?(a(),$($e,{key:0,class:"VPNavScreenSocialLinks",links:l(e).socialLinks},null,8,["links"])):f("",!0)}}),Ar={class:"list"},xr=b({__name:"VPNavScreenTranslations",setup(s){const{localeLinks:e,currentLang:t}=X({correspondingLink:!0}),n=M(!1);function o(){n.value=!n.value}return(r,d)=>l(e).length&&l(t).label?(a(),i("div",{key:0,class:T(["VPNavScreenTranslations",{open:n.value}])},[c("button",{class:"title",onClick:o},[h(Ae,{class:"icon lang"}),x(" "+L(l(t).label)+" ",1),h(Be,{class:"icon chevron"})]),c("ul",Ar,[(a(!0),i(N,null,A(l(e),p=>(a(),i("li",{key:p.link,class:"item"},[h(E,{class:"link",href:p.link},{default:v(()=>[x(L(p.text),1)]),_:2},1032,["href"])]))),128))])],2)):f("",!0)}});const Hr=m(xr,[["__scopeId","data-v-41505286"]]),zr={class:"container"},Dr=b({__name:"VPNavScreen",props:{open:{type:Boolean}},setup(s){const e=M(null),t=Se(K?document.body:null);return(n,o)=>(a(),$(ce,{name:"fade",onEnter:o[0]||(o[0]=r=>t.value=!0),onAfterLeave:o[1]||(o[1]=r=>t.value=!1)},{default:v(()=>[n.open?(a(),i("div",{key:0,class:"VPNavScreen",ref_key:"screen",ref:e,id:"VPNavScreen"},[c("div",zr,[u(n.$slots,"nav-screen-content-before",{},void 0,!0),h(Cr,{class:"menu"}),h(Hr,{class:"translations"}),h(dr,{class:"appearance"}),h(Br,{class:"social-links"}),u(n.$slots,"nav-screen-content-after",{},void 0,!0)])],512)):f("",!0)]),_:3}))}});const Er=m(Dr,[["__scopeId","data-v-57cce842"]]),Fr={key:0,class:"VPNav"},Or=b({__name:"VPNav",setup(s){const{isScreenOpen:e,closeScreen:t,toggleScreen:n}=Xn(),{frontmatter:o}=P(),r=k(()=>o.value.navbar!==!1);return Me("close-screen",t),te(()=>{K&&document.documentElement.classList.toggle("hide-nav",!r.value)}),(d,p)=>r.value?(a(),i("header",Fr,[h(lr,{"is-screen-open":l(e),onToggleScreen:l(n)},{"nav-bar-title-before":v(()=>[u(d.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(d.$slots,"nav-bar-title-after",{},void 0,!0)]),"nav-bar-content-before":v(()=>[u(d.$slots,"nav-bar-content-before",{},void 0,!0)]),"nav-bar-content-after":v(()=>[u(d.$slots,"nav-bar-content-after",{},void 0,!0)]),_:3},8,["is-screen-open","onToggleScreen"]),h(Er,{open:l(e)},{"nav-screen-content-before":v(()=>[u(d.$slots,"nav-screen-content-before",{},void 0,!0)]),"nav-screen-content-after":v(()=>[u(d.$slots,"nav-screen-content-after",{},void 0,!0)]),_:3},8,["open"])])):f("",!0)}});const Gr=m(Or,[["__scopeId","data-v-7ad780c2"]]),Ur=s=>(H("data-v-bd01e0d5"),s=s(),z(),s),jr=["role","tabindex"],Rr=Ur(()=>c("div",{class:"indicator"},null,-1)),qr={key:1,class:"items"},Kr=b({__name:"VPSidebarItem",props:{item:{},depth:{}},setup(s){const e=s,{collapsed:t,collapsible:n,isLink:o,isActiveLink:r,hasActiveLink:d,hasChildren:p,toggle:_}=gt(k(()=>e.item)),g=k(()=>p.value?"section":"div"),V=k(()=>o.value?"a":"div"),y=k(()=>p.value?e.depth+2===7?"p":`h${e.depth+2}`:"p"),I=k(()=>o.value?void 0:"button"),S=k(()=>[[`level-${e.depth}`],{collapsible:n.value},{collapsed:t.value},{"is-link":o.value},{"is-active":r.value},{"has-active":d.value}]);function C(w){"key"in w&&w.key!=="Enter"||!e.item.link&&_()}function B(){e.item.link&&_()}return(w,R)=>{const W=j("VPSidebarItem",!0);return a(),$(F(g.value),{class:T(["VPSidebarItem",S.value])},{default:v(()=>[w.item.text?(a(),i("div",Z({key:0,class:"item",role:I.value},We(w.item.items?{click:C,keydown:C}:{},!0),{tabindex:w.item.items&&0}),[Rr,w.item.link?(a(),$(E,{key:0,tag:V.value,class:"link",href:w.item.link,rel:w.item.rel,target:w.item.target},{default:v(()=>[(a(),$(F(y.value),{class:"text",innerHTML:w.item.text},null,8,["innerHTML"]))]),_:1},8,["tag","href","rel","target"])):(a(),$(F(y.value),{key:1,class:"text",innerHTML:w.item.text},null,8,["innerHTML"])),w.item.collapsed!=null?(a(),i("div",{key:2,class:"caret",role:"button","aria-label":"toggle section",onClick:B,onKeydown:Ye(B,["enter"]),tabindex:"0"},[h(fe,{class:"caret-icon"})],32)):f("",!0)],16,jr)):f("",!0),w.item.items&&w.item.items.length?(a(),i("div",qr,[w.depth<5?(a(!0),i(N,{key:0},A(w.item.items,q=>(a(),$(W,{key:q.text,item:q,depth:w.depth+1},null,8,["item","depth"]))),128)):f("",!0)])):f("",!0)]),_:1},8,["class"])}}});const Wr=m(Kr,[["__scopeId","data-v-bd01e0d5"]]),He=s=>(H("data-v-ee2efba5"),s=s(),z(),s),Yr=He(()=>c("div",{class:"curtain"},null,-1)),Jr={class:"nav",id:"VPSidebarNav","aria-labelledby":"sidebar-aria-label",tabindex:"-1"},Xr=He(()=>c("span",{class:"visually-hidden",id:"sidebar-aria-label"}," Sidebar Navigation ",-1)),Zr=b({__name:"VPSidebar",props:{open:{type:Boolean}},setup(s){const{sidebarGroups:e,hasSidebar:t}=D(),n=s,o=M(null),r=Se(K?document.body:null);return U([n,o],()=>{var d;n.open?(r.value=!0,(d=o.value)==null||d.focus()):r.value=!1},{immediate:!0,flush:"post"}),(d,p)=>l(t)?(a(),i("aside",{key:0,class:T(["VPSidebar",{open:d.open}]),ref_key:"navEl",ref:o,onClick:p[0]||(p[0]=Je(()=>{},["stop"]))},[Yr,c("nav",Jr,[Xr,u(d.$slots,"sidebar-nav-before",{},void 0,!0),(a(!0),i(N,null,A(l(e),_=>(a(),i("div",{key:_.text,class:"group"},[h(Wr,{item:_,depth:0},null,8,["item"])]))),128)),u(d.$slots,"sidebar-nav-after",{},void 0,!0)])],2)):f("",!0)}});const Qr=m(Zr,[["__scopeId","data-v-ee2efba5"]]),el=b({__name:"VPSkipLink",setup(s){const e=se(),t=M();U(()=>e.path,()=>t.value.focus());function n({target:o}){const r=document.getElementById(decodeURIComponent(o.hash).slice(1));if(r){const d=()=>{r.removeAttribute("tabindex"),r.removeEventListener("blur",d)};r.setAttribute("tabindex","-1"),r.addEventListener("blur",d),r.focus(),window.scrollTo(0,0)}}return(o,r)=>(a(),i(N,null,[c("span",{ref_key:"backToTop",ref:t,tabindex:"-1"},null,512),c("a",{href:"#VPContent",class:"VPSkipLink visually-hidden",onClick:n}," Skip to content ")],64))}});const tl=m(el,[["__scopeId","data-v-c8291ffa"]]),sl=b({__name:"Layout",setup(s){const{isOpen:e,open:t,close:n}=D(),o=se();U(()=>o.path,n),mt(e,n);const{frontmatter:r}=P(),d=Xe(),p=k(()=>!!d["home-hero-image"]);return Me("hero-image-slot-exists",p),(_,g)=>{const V=j("Content");return l(r).layout!==!1?(a(),i("div",{key:0,class:T(["Layout",l(r).pageClass])},[u(_.$slots,"layout-top",{},void 0,!0),h(tl),h(st,{class:"backdrop",show:l(e),onClick:l(n)},null,8,["show","onClick"]),h(Gr,null,{"nav-bar-title-before":v(()=>[u(_.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(_.$slots,"nav-bar-title-after",{},void 0,!0)]),"nav-bar-content-before":v(()=>[u(_.$slots,"nav-bar-content-before",{},void 0,!0)]),"nav-bar-content-after":v(()=>[u(_.$slots,"nav-bar-content-after",{},void 0,!0)]),"nav-screen-content-before":v(()=>[u(_.$slots,"nav-screen-content-before",{},void 0,!0)]),"nav-screen-content-after":v(()=>[u(_.$slots,"nav-screen-content-after",{},void 0,!0)]),_:3}),h(Jn,{open:l(e),onOpenMenu:l(t)},null,8,["open","onOpenMenu"]),h(Qr,{open:l(e)},{"sidebar-nav-before":v(()=>[u(_.$slots,"sidebar-nav-before",{},void 0,!0)]),"sidebar-nav-after":v(()=>[u(_.$slots,"sidebar-nav-after",{},void 0,!0)]),_:3},8,["open"]),h(Mn,null,{"page-top":v(()=>[u(_.$slots,"page-top",{},void 0,!0)]),"page-bottom":v(()=>[u(_.$slots,"page-bottom",{},void 0,!0)]),"not-found":v(()=>[u(_.$slots,"not-found",{},void 0,!0)]),"home-hero-before":v(()=>[u(_.$slots,"home-hero-before",{},void 0,!0)]),"home-hero-info":v(()=>[u(_.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(_.$slots,"home-hero-image",{},void 0,!0)]),"home-hero-after":v(()=>[u(_.$slots,"home-hero-after",{},void 0,!0)]),"home-features-before":v(()=>[u(_.$slots,"home-features-before",{},void 0,!0)]),"home-features-after":v(()=>[u(_.$slots,"home-features-after",{},void 0,!0)]),"doc-footer-before":v(()=>[u(_.$slots,"doc-footer-before",{},void 0,!0)]),"doc-before":v(()=>[u(_.$slots,"doc-before",{},void 0,!0)]),"doc-after":v(()=>[u(_.$slots,"doc-after",{},void 0,!0)]),"doc-top":v(()=>[u(_.$slots,"doc-top",{},void 0,!0)]),"doc-bottom":v(()=>[u(_.$slots,"doc-bottom",{},void 0,!0)]),"aside-top":v(()=>[u(_.$slots,"aside-top",{},void 0,!0)]),"aside-bottom":v(()=>[u(_.$slots,"aside-bottom",{},void 0,!0)]),"aside-outline-before":v(()=>[u(_.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(_.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(_.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(_.$slots,"aside-ads-after",{},void 0,!0)]),_:3}),h(Bn),u(_.$slots,"layout-bottom",{},void 0,!0)],2)):(a(),$(V,{key:1}))}}});const nl=m(sl,[["__scopeId","data-v-9d8abc1e"]]);const al={Layout:nl,enhanceApp:({app:s})=>{s.component("Badge",Qe)}};export{Na as c,al as t,P as u}; diff --git a/pr-1815/assets/community_coc.md.24e8f6e5.js b/pr-1815/assets/community_coc.md.59c70f94.js similarity index 99% rename from pr-1815/assets/community_coc.md.24e8f6e5.js rename to pr-1815/assets/community_coc.md.59c70f94.js index 659444eae..9a01bfd8b 100644 --- a/pr-1815/assets/community_coc.md.24e8f6e5.js +++ b/pr-1815/assets/community_coc.md.59c70f94.js @@ -1 +1 @@ -import{_ as e,o,c as t,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse(`{"title":"Celestia.org Code of Conduct","description":"Fundamental shared values and special norms that distinguish Celestia's community.","frontmatter":{"description":"Fundamental shared values and special norms that distinguish Celestia's community.","head":[["meta",{"property":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"}],["meta",{"property":"og:description","content":"Fundamental shared values and special norms that distinguish Celestia's community."}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1732776394000}`),n={name:"community/coc.md"},i=a('

Celestia.org Code of Conduct

Our Pledge

We as Celestia.org members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, caste, color, religion, or sexual identity and orientation.

We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

Our Standards

Examples of behavior that contributes to a positive environment for our community include:

  • Demonstrating empathy and kindness toward other people
  • Being respectful of differing opinions, viewpoints, and experiences
  • Giving and gracefully accepting constructive feedback
  • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
  • Focusing on what is best not just for us as individuals, but for the overall community
  • Contributing to conversations about Celestia’s technology and ecosystem

Examples of unacceptable behavior include:

  • The use of sexualized language or imagery, and sexual attention or advances of any kind
  • Trolling, insulting or derogatory comments, and personal or political attacks
  • Public or private harassment
  • Publishing others' private information, such as a physical or email address, without their explicit permission
  • Focusing on the prices of digital assets or tokens, or where they can be purchased
  • Other conduct which could reasonably be considered inappropriate in a professional setting

Enforcement Responsibilities

Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

Scope

This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at Celestia.org Discord. All complaints will be reviewed and investigated promptly and fairly.

All community leaders are obligated to respect the privacy and security of the reporter of any incident.

Enforcement Guidelines

Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

1. Correction

Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

2. Warning

Community Impact: A violation through a single incident or series of actions.

Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

3. Temporary Ban

Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

4. Permanent Ban

Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

Consequence: A permanent ban from any sort of public interaction within the community.

Attribution

This Code of Conduct is adapted from the Contributor Covenant, version 2.1, available at https://www.contributor-covenant.org/version/2/1/code_of_conduct.html.

Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

',35),r=[i];function s(c,l,d,p,u,h){return o(),t("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; +import{_ as e,o,c as t,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse(`{"title":"Celestia.org Code of Conduct","description":"Fundamental shared values and special norms that distinguish Celestia's community.","frontmatter":{"description":"Fundamental shared values and special norms that distinguish Celestia's community.","head":[["meta",{"property":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"}],["meta",{"property":"og:description","content":"Fundamental shared values and special norms that distinguish Celestia's community."}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1732777479000}`),n={name:"community/coc.md"},i=a('

Celestia.org Code of Conduct

Our Pledge

We as Celestia.org members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, caste, color, religion, or sexual identity and orientation.

We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

Our Standards

Examples of behavior that contributes to a positive environment for our community include:

  • Demonstrating empathy and kindness toward other people
  • Being respectful of differing opinions, viewpoints, and experiences
  • Giving and gracefully accepting constructive feedback
  • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
  • Focusing on what is best not just for us as individuals, but for the overall community
  • Contributing to conversations about Celestia’s technology and ecosystem

Examples of unacceptable behavior include:

  • The use of sexualized language or imagery, and sexual attention or advances of any kind
  • Trolling, insulting or derogatory comments, and personal or political attacks
  • Public or private harassment
  • Publishing others' private information, such as a physical or email address, without their explicit permission
  • Focusing on the prices of digital assets or tokens, or where they can be purchased
  • Other conduct which could reasonably be considered inappropriate in a professional setting

Enforcement Responsibilities

Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

Scope

This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at Celestia.org Discord. All complaints will be reviewed and investigated promptly and fairly.

All community leaders are obligated to respect the privacy and security of the reporter of any incident.

Enforcement Guidelines

Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

1. Correction

Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

2. Warning

Community Impact: A violation through a single incident or series of actions.

Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

3. Temporary Ban

Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

4. Permanent Ban

Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

Consequence: A permanent ban from any sort of public interaction within the community.

Attribution

This Code of Conduct is adapted from the Contributor Covenant, version 2.1, available at https://www.contributor-covenant.org/version/2/1/code_of_conduct.html.

Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

',35),r=[i];function s(c,l,d,p,u,h){return o(),t("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; diff --git a/pr-1815/assets/community_coc.md.24e8f6e5.lean.js b/pr-1815/assets/community_coc.md.59c70f94.lean.js similarity index 92% rename from pr-1815/assets/community_coc.md.24e8f6e5.lean.js rename to pr-1815/assets/community_coc.md.59c70f94.lean.js index e6de99e0e..dd1e97100 100644 --- a/pr-1815/assets/community_coc.md.24e8f6e5.lean.js +++ b/pr-1815/assets/community_coc.md.59c70f94.lean.js @@ -1 +1 @@ -import{_ as e,o,c as t,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse(`{"title":"Celestia.org Code of Conduct","description":"Fundamental shared values and special norms that distinguish Celestia's community.","frontmatter":{"description":"Fundamental shared values and special norms that distinguish Celestia's community.","head":[["meta",{"property":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"}],["meta",{"property":"og:description","content":"Fundamental shared values and special norms that distinguish Celestia's community."}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1732776394000}`),n={name:"community/coc.md"},i=a("",35),r=[i];function s(c,l,d,p,u,h){return o(),t("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; +import{_ as e,o,c as t,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse(`{"title":"Celestia.org Code of Conduct","description":"Fundamental shared values and special norms that distinguish Celestia's community.","frontmatter":{"description":"Fundamental shared values and special norms that distinguish Celestia's community.","head":[["meta",{"property":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"}],["meta",{"property":"og:description","content":"Fundamental shared values and special norms that distinguish Celestia's community."}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1732777479000}`),n={name:"community/coc.md"},i=a("",35),r=[i];function s(c,l,d,p,u,h){return o(),t("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; diff --git a/pr-1815/assets/community_foundation-delegation-program.md.4ddabdc6.js b/pr-1815/assets/community_foundation-delegation-program.md.6742c73d.js similarity index 99% rename from pr-1815/assets/community_foundation-delegation-program.md.4ddabdc6.js rename to pr-1815/assets/community_foundation-delegation-program.md.6742c73d.js index 5ac7d1aca..f54948abf 100644 --- a/pr-1815/assets/community_foundation-delegation-program.md.4ddabdc6.js +++ b/pr-1815/assets/community_foundation-delegation-program.md.6742c73d.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1815/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1732776394000}'),n={name:"community/foundation-delegation-program.md"},l=i('

The Celestia Foundation Delegation Program

Delegation program banner

Objectives of the program

The primary objectives of the Celestia Foundation Delegation Program are:

  • To provide a fair opportunity for Celestia’s users to join the validator set, while ensuring the validator set remains proficient, trustworthy, and dependable.
  • To maintain network stability by promoting a steady transition of validators and avoiding sudden and disruptive changes in participation.
  • To enable the Celestia Foundation to use its stake towards its mission of fostering a modular blockchain network that delivers exceptional performance.

Foundation delegation process

Program launch

Prospective validators are welcome to apply to the program starting February 6, 2024. The application is designed to assess a validator’s uptime performance and contributions to the Celestia ecosystem. Of the 100 total slots in Celestia’s active validator set, up to 50 will receive delegations within the program.

Application submissions will be reviewed by the Celestia Foundation. More details about the application and eligibility criteria are described below.

Cohort process

cohort timeline

Every 4 months, the Celestia Foundation will distribute a portion of the Foundation’s total available stake to a cohort of validators who meet certain criteria, detailed below. Here is an overview of how the cohort process will work for Cohort 1 and what that means for future cohorts.

Key Points

  • Initial Cohort (Cohort 1): 50 applicants will be accepted
    • Grading System: Applicants in Cohort 1 are divided into first, second, and third place based on eligibility criteria outlined in this document.
    • Delegation Duration: This varies based on the applicant’s placement in Cohort 1. First place receives 12 months of delegation, second place receives 8 months, third place receives 4 months.
TierPlacementDelegation DurationRenewal By Cohort
First PlaceApplicants 1-2012 monthsCohort 4
Second PlaceApplicants 21-358 monthsCohort 3
Third PlaceApplicants 36-504 monthsCohort 2
  • Subsequent Cohorts (Cohorts 2-onwards):
    • After Cohort 1, open slots may be filled by Cohort 1 members up for renewals or new applicants. There will be no Tiers (e.g. First Place, Second Place, Third Place) in cohorts after Cohort 1. This structure allows for a steady flow of both existing applicants and new applicants to maintain a stable set of participants in the program.

During this period, so long as the validator maintains high uptime and does not violate the rules of the program, the validator will receive the delegation for the duration of the cohort they are currently in.

Eligibility criteria

The minimum requirements for participation in the program are as follows:

  • Run an active Mainnet Beta validator or an active Mocha testnet validator for at least 1 month before application deadline
  • Run a bridge node (on Mainnet Beta if you are already an active Mainnet Beta validator or on Mocha testnet if not) that is connected and reporting to the Celestia Labs OTEL collector (for new applicants - on testnet, so that we can evaluate performance)
  • Not jailed or slashed in the 6 months before application deadline
  • Not associated with an exchange or custodian
  • Not in the top 10 validators by delegation power, unless it enters the top 10 as a result of the Foundation’s delegation under this program
  • Have 10% or less commission
  • Not based within the US, within any country subject to economic sanctions, or within any other prohibited jurisdiction, and successfully complete a compliance screen
  • Dedicated email address so that the Foundation can reach you in the event of emergency upgrades and fixes
  • Maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha if selected for the program
  • Not running your infrastructure in Hetzner or OVH

Not adhering to any of the criteria above will automatically disqualify your application, and violating any of the criteria after you have received delegation will result in withdrawal of the delegation. A participant who loses stake due to being jailed by the protocol may reapply to the program after 2 cohort periods.

Applicants are also expected to have reviewed Celestia docs and recommended guides on devops and monitoring setups.

Other optional but important criteria:

  • Develop and maintain developer tooling, services, applications, and dashboards
  • Work on projects aligned with Celestia's values
  • Contribute to documentation and new guides and tutorials
  • Quality of infrastructure
  • Operated within a location that improves geolocation of the validator set

Undelegation criteria

  • Getting slashed/tombstoned (cannot apply for 1 year afterwards)
  • Getting jailed more than once during the cohort’s applicable delegation period
  • Violating the Celestia.org Community Code of Conduct or engaging in harmful activities towards the network
  • Failing to upgrade your node in a timely manner (24 hours or less)
  • If necessary to protect or secure Mainnet Beta or to comply with applicable law
  • For any other reason, in the Celestia Foundation’s sole discretion

Application

The program will be divided into cohorts with applications open for new applicants and renewal of existing applicants every 4 months. Validators will be delegated for up to a year. For each cohort, the deadline to apply/be evaluated (if you are reapplying) is exactly 1 month prior to the date of being delegated to.

Application details

Before applying, be ready to share the following:

  • General info
    • Security Email
    • Validator Entity Name
    • Discord ID
    • Mark if entity or individual
    • Website if any
    • Github page of your organization
    • Team experience and roster (including Twitter + Github links)
    • Which networks you validate on Mainnet Beta + links to your validators
    • A personal statement why you should receive delegation from the Foundation (max 1500 characters)
  • Infrastructure
    • Validator address and bridge node ID on Mainnet Beta
    • If you don't run an active Mainnet Beta validator, please provide us with validator address, bridge node ID and blobstream address on Mocha-4
    • Have you been slashed or jailed in the last 6 months on Celestia or other chains you validated on.
    • Hosting provider and Data Center location (Mainnet Beta and testnet if applicable)
    • Setup of the 2 components (validator and bridge)
      • Hardware
      • Security setup (servers, private keys)
      • Monitoring and alerting
  • Contributions
    • Please list all technical contributions for Celestia and its ecosystem
    • Please list all community contributions for Celestia and its ecosystem

Please note, the objective of the program is to contribute to Celestia’s resilience and uptime. If you contribute a lot to the Celestia ecosystem, but your validator uptime is low, this will negatively impact your chance at selection for the program. Furthermore, merely receiving delegation from the Foundation under the program does not guarantee your placement in the active validator set.

Get Started with the Application Form

Cohort information

The Foundation will report each cohort’s composition and the duration of their respective delegations.

  • Cohort 1: 50 Validator Seats
  • Cohort 2: 15 Validator Seats (Applications open June 1, 2024)
  • Cohort 3: 15 Validator Seats (Applications open October 1, 2024)
  • Cohort 4: 20 Validator Seats (Applications open February 1, 2025)

IMPORTANT: Each validator selected for the program has to maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha.

Feedback process

Validators in the program will receive a feedback form every quarter, so the program can be continually improved.

',39),s=[l];function d(c,h,p,u,m,g){return t(),a("div",null,s)}const y=e(n,[["render",d]]);export{b as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1815/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1732777479000}'),n={name:"community/foundation-delegation-program.md"},l=i('

The Celestia Foundation Delegation Program

Delegation program banner

Objectives of the program

The primary objectives of the Celestia Foundation Delegation Program are:

  • To provide a fair opportunity for Celestia’s users to join the validator set, while ensuring the validator set remains proficient, trustworthy, and dependable.
  • To maintain network stability by promoting a steady transition of validators and avoiding sudden and disruptive changes in participation.
  • To enable the Celestia Foundation to use its stake towards its mission of fostering a modular blockchain network that delivers exceptional performance.

Foundation delegation process

Program launch

Prospective validators are welcome to apply to the program starting February 6, 2024. The application is designed to assess a validator’s uptime performance and contributions to the Celestia ecosystem. Of the 100 total slots in Celestia’s active validator set, up to 50 will receive delegations within the program.

Application submissions will be reviewed by the Celestia Foundation. More details about the application and eligibility criteria are described below.

Cohort process

cohort timeline

Every 4 months, the Celestia Foundation will distribute a portion of the Foundation’s total available stake to a cohort of validators who meet certain criteria, detailed below. Here is an overview of how the cohort process will work for Cohort 1 and what that means for future cohorts.

Key Points

  • Initial Cohort (Cohort 1): 50 applicants will be accepted
    • Grading System: Applicants in Cohort 1 are divided into first, second, and third place based on eligibility criteria outlined in this document.
    • Delegation Duration: This varies based on the applicant’s placement in Cohort 1. First place receives 12 months of delegation, second place receives 8 months, third place receives 4 months.
TierPlacementDelegation DurationRenewal By Cohort
First PlaceApplicants 1-2012 monthsCohort 4
Second PlaceApplicants 21-358 monthsCohort 3
Third PlaceApplicants 36-504 monthsCohort 2
  • Subsequent Cohorts (Cohorts 2-onwards):
    • After Cohort 1, open slots may be filled by Cohort 1 members up for renewals or new applicants. There will be no Tiers (e.g. First Place, Second Place, Third Place) in cohorts after Cohort 1. This structure allows for a steady flow of both existing applicants and new applicants to maintain a stable set of participants in the program.

During this period, so long as the validator maintains high uptime and does not violate the rules of the program, the validator will receive the delegation for the duration of the cohort they are currently in.

Eligibility criteria

The minimum requirements for participation in the program are as follows:

  • Run an active Mainnet Beta validator or an active Mocha testnet validator for at least 1 month before application deadline
  • Run a bridge node (on Mainnet Beta if you are already an active Mainnet Beta validator or on Mocha testnet if not) that is connected and reporting to the Celestia Labs OTEL collector (for new applicants - on testnet, so that we can evaluate performance)
  • Not jailed or slashed in the 6 months before application deadline
  • Not associated with an exchange or custodian
  • Not in the top 10 validators by delegation power, unless it enters the top 10 as a result of the Foundation’s delegation under this program
  • Have 10% or less commission
  • Not based within the US, within any country subject to economic sanctions, or within any other prohibited jurisdiction, and successfully complete a compliance screen
  • Dedicated email address so that the Foundation can reach you in the event of emergency upgrades and fixes
  • Maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha if selected for the program
  • Not running your infrastructure in Hetzner or OVH

Not adhering to any of the criteria above will automatically disqualify your application, and violating any of the criteria after you have received delegation will result in withdrawal of the delegation. A participant who loses stake due to being jailed by the protocol may reapply to the program after 2 cohort periods.

Applicants are also expected to have reviewed Celestia docs and recommended guides on devops and monitoring setups.

Other optional but important criteria:

  • Develop and maintain developer tooling, services, applications, and dashboards
  • Work on projects aligned with Celestia's values
  • Contribute to documentation and new guides and tutorials
  • Quality of infrastructure
  • Operated within a location that improves geolocation of the validator set

Undelegation criteria

  • Getting slashed/tombstoned (cannot apply for 1 year afterwards)
  • Getting jailed more than once during the cohort’s applicable delegation period
  • Violating the Celestia.org Community Code of Conduct or engaging in harmful activities towards the network
  • Failing to upgrade your node in a timely manner (24 hours or less)
  • If necessary to protect or secure Mainnet Beta or to comply with applicable law
  • For any other reason, in the Celestia Foundation’s sole discretion

Application

The program will be divided into cohorts with applications open for new applicants and renewal of existing applicants every 4 months. Validators will be delegated for up to a year. For each cohort, the deadline to apply/be evaluated (if you are reapplying) is exactly 1 month prior to the date of being delegated to.

Application details

Before applying, be ready to share the following:

  • General info
    • Security Email
    • Validator Entity Name
    • Discord ID
    • Mark if entity or individual
    • Website if any
    • Github page of your organization
    • Team experience and roster (including Twitter + Github links)
    • Which networks you validate on Mainnet Beta + links to your validators
    • A personal statement why you should receive delegation from the Foundation (max 1500 characters)
  • Infrastructure
    • Validator address and bridge node ID on Mainnet Beta
    • If you don't run an active Mainnet Beta validator, please provide us with validator address, bridge node ID and blobstream address on Mocha-4
    • Have you been slashed or jailed in the last 6 months on Celestia or other chains you validated on.
    • Hosting provider and Data Center location (Mainnet Beta and testnet if applicable)
    • Setup of the 2 components (validator and bridge)
      • Hardware
      • Security setup (servers, private keys)
      • Monitoring and alerting
  • Contributions
    • Please list all technical contributions for Celestia and its ecosystem
    • Please list all community contributions for Celestia and its ecosystem

Please note, the objective of the program is to contribute to Celestia’s resilience and uptime. If you contribute a lot to the Celestia ecosystem, but your validator uptime is low, this will negatively impact your chance at selection for the program. Furthermore, merely receiving delegation from the Foundation under the program does not guarantee your placement in the active validator set.

Get Started with the Application Form

Cohort information

The Foundation will report each cohort’s composition and the duration of their respective delegations.

  • Cohort 1: 50 Validator Seats
  • Cohort 2: 15 Validator Seats (Applications open June 1, 2024)
  • Cohort 3: 15 Validator Seats (Applications open October 1, 2024)
  • Cohort 4: 20 Validator Seats (Applications open February 1, 2025)

IMPORTANT: Each validator selected for the program has to maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha.

Feedback process

Validators in the program will receive a feedback form every quarter, so the program can be continually improved.

',39),s=[l];function d(c,h,p,u,m,g){return t(),a("div",null,s)}const y=e(n,[["render",d]]);export{b as __pageData,y as default}; diff --git a/pr-1815/assets/community_foundation-delegation-program.md.4ddabdc6.lean.js b/pr-1815/assets/community_foundation-delegation-program.md.6742c73d.lean.js similarity index 92% rename from pr-1815/assets/community_foundation-delegation-program.md.4ddabdc6.lean.js rename to pr-1815/assets/community_foundation-delegation-program.md.6742c73d.lean.js index f5fa4b666..95fb9387f 100644 --- a/pr-1815/assets/community_foundation-delegation-program.md.4ddabdc6.lean.js +++ b/pr-1815/assets/community_foundation-delegation-program.md.6742c73d.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1815/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1732776394000}'),n={name:"community/foundation-delegation-program.md"},l=i("",39),s=[l];function d(c,h,p,u,m,g){return t(),a("div",null,s)}const y=e(n,[["render",d]]);export{b as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1815/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1732777479000}'),n={name:"community/foundation-delegation-program.md"},l=i("",39),s=[l];function d(c,h,p,u,m,g){return t(),a("div",null,s)}const y=e(n,[["render",d]]);export{b as __pageData,y as default}; diff --git a/pr-1815/assets/community_modular-meetup-guide.md.b2c75b9f.js b/pr-1815/assets/community_modular-meetup-guide.md.67b2cbce.js similarity index 99% rename from pr-1815/assets/community_modular-meetup-guide.md.b2c75b9f.js rename to pr-1815/assets/community_modular-meetup-guide.md.67b2cbce.js index 39b6938c0..f2d65b955 100644 --- a/pr-1815/assets/community_modular-meetup-guide.md.b2c75b9f.js +++ b/pr-1815/assets/community_modular-meetup-guide.md.67b2cbce.js @@ -1 +1 @@ -import{_ as e,o as t,c as i,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup guide","description":"A guide that helps in organizing a successful Modular Meetup.","frontmatter":{"description":"A guide that helps in organizing a successful Modular Meetup.","head":[["meta",{"property":"og:title","content":"Modular Meetup guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps in organizing a successful Modular Meetup."}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1732776394000}'),a={name:"community/modular-meetup-guide.md"},n=o('

Modular Meetup guide

These are recommended steps you can follow that can help you organize a successful Modular Meetup. You aren’t required to follow the entire checklist but it is available to help aid you in your journey to organize a Modular Meetup.

Before the Meetup

  1. Determine the meetup topic and objectives.
  2. Select a suitable date and time for the event.
  3. Secure a convenient and accessible venue that can accommodate the expected number of attendees.
  4. Finalize a schedule or agenda for the event, including speakers, presentations, and activities.
  5. Prepare and send out invitations to potential attendees using various channels (email, social media, community platforms, etc.).
  6. Create and share promotional materials (graphics, blog posts, etc.) to raise awareness about the meetup.
  7. Confirm speakers, including their availability, presentation topics, and technical requirements. If you are working from a Speaker List, please reach out to Nat for any support needed on coordination with speakers.
  8. Arrange any necessary equipment, such as microphones, projectors, and whiteboards.
  9. Plan and arrange refreshments, if applicable.
  10. Prepare and print any required materials, like agendas, name tags, and feedback forms.
  11. Coordinate with volunteers or team members to help manage the event.
  12. Set up a registration system or RSVP process to track attendance.
  13. Send out reminder messages to registered attendees prior to the event.
  14. Conduct a final review of the event logistics, including venue setup, equipment functionality, and volunteer roles.

During the Meetup

  1. Set up the venue, including arranging seating, preparing equipment, and displaying any promotional materials.
  2. Designate a registration area and ensure that someone is available to greet and check-in attendees.
  3. Welcome the attendees and provide an overview of the event schedule.
  4. Introduce speakers and facilitate any presentations or discussions.
  5. Encourage networking and interaction among attendees during breaks or dedicated activities.
  6. Capture the event with photos or videos for future promotions and documentation.
  7. Collect feedback from attendees using forms, online surveys, or informal conversations if needed.

After the Meetup

  1. Send follow-up messages to attendees, thanking them for their participation and soliciting additional feedback.
  2. Evaluate the success of the event by reviewing feedback and assessing key performance indicators (e.g., attendance, engagement, etc.).
  3. Analyze and document lessons learned, identifying areas for improvement in future meetups.
  4. Share event highlights, photos, and key takeaways with the community through social media, blog posts, or newsletters.
  5. Connect with speakers, attendees, and volunteers to maintain and strengthen relationships.
  6. Begin planning for the next meetup, applying insights gained from the previous event to enhance the experience for future attendees.

Logistics and guidance

These are provided guidelines for different components of kickstarting a Modular Meetup to help you get started on the logistics of organizing a meetup. A lot of those guidelines are thanks to the wonderful write ups in Ethereum Meetup Support Program and Elastic Community Organizer Guides.

Venue

Selecting the perfect venue for your Modular Meetup is essential in creating a welcoming atmosphere for the Celestia community.

  1. Startup Incubators
    • Often they would have spaces for meetups.
  2. Libraries
    • Libraries can normally have spaces for meetups at little to no costs
  3. Co-working spaces:
    • Co-working spaces might be able to offer necessary equipment like microphones, projectors, and whiteboards.
  4. Restaurants:
    • Restaurants might have private rooms for larger groups of people that you can book, depending on the restaurant.
  5. Universities and Blockchain Clubs:
    • Partnering with universities and their local university clubs can offer you a lot of spaces for meetups, as well as necessary equipments if needed for giving a talk.
  6. Other options:
    • If you're having difficulty finding a venue, don't hesitate to ask for help within the Celestia community. Your fellow organizers and attendees may have valuable suggestions or connections.

An ideal venue should offer:

  • Sufficient seating for the audience
  • A projector and screen
  • A microphone (especially for meetups with 10+ attendees)
  • Optional: A whiteboard for speakers or workshops (not always necessary, but a nice addition)

Consider recording the event, even with a smartphone, to share with the community later. If the speaker uses a microphone, their voice will be more audible in the video. We might be able to post those recordings of the meetup talks on a meetup youtube channel after.

Remember to negotiate on costs and seek discounts, emphasizing that your meetup benefits the community.

Collaborate with your venue provider to explore options like borrowing recording equipment, tripods, or even having them record the event for you. Some providers may offer these services for free or at a reduced cost.

Catering and refreshments

Providing refreshments or catering for your Modular Meetup enhances the overall experience and encourages networking among attendees.

  1. Determine your budget
    • Identify the amount you can allocate for food and drinks at your event which will help you determine how much you can bring in refreshments. You can also contact the Celestia Devrel team for ideas and support. Costs for refreshments and drinks can vary depending on your location, so be mindful to be flexible on your plans according to your specific location and budget.
  2. Offer a variety of refreshments
    • If you're ordering in, pizza and finger foods work well, but you can also have more budget-friendly options for food.
    • Offering drinks like beer, soda, or lemonade are great, but water also works. Keep in mind that not everyone drinks alcohol so it’s not a requirement. But having at least water and plastic cups works well.
  3. Plan ahead
    • Order refreshments 1 or 2 days in advance and schedule delivery to avoid last-minute stress during the event.

By following these recommendations, you'll be able to provide enjoyable refreshments for your Celestia Modular Meetup attendees while fostering a friendly and engaging atmosphere.

Audience

Understanding your audience and estimating attendance are crucial for organizing successful Modular Meetups for Celestia.

  1. Research the local tech scene:
    • Investigate the types of meetups and events popular in your area. Attend other technology-focused events to get a sense of the audience size and interests. This information will help you tailor your meetup to attract a larger audience.
  2. Assess the availability of speakers:
    • Before organizing a meetup, ensure that you have access to a pool of knowledgeable speakers. If you anticipate difficulty in securing speakers, consider joining forces with an existing meetup group or speaking at other events before launching a new group. This approach will help spread the word about your planned Modular Meetup and gauge interest. Speakers are covered in the following section with a reference to Speaker List offered by the Modular Meetup program.
  3. Establish connections with other user groups:
    • Forge relationships with other tech-focused meetup groups to mutually promote each other's events, potentially increasing attendance.
  4. Set a regular routine for your meetup:
    • Communicate how often you plan to hold meetups, whether it's monthly or quarterly, to help attendees manage their expectations and maintain their interest.
  5. Organize casual meetups:
    • If there's a gap between more formal events, arrange casual meetups at pubs or cafes to keep people engaged and connect with potential speakers for future events.
  6. Estimate the number of attendees:
    • Consider factors such as the size of your city, the popularity of the topic, and the appeal of the event description when estimating attendance.

Speakers

Securing engaging and knowledgeable speakers is key to hosting an exceptional Celestia Modular Meetup.

  1. Define your event topic
    • Determine the theme of your event, focusing on areas such as DeFi, Gaming, NFTs, coding workshops, protocol changes, rollups, data availability, or other topics relevant to the Modular ecosystem. This will help you find speakers with expertise in the chosen subject.
  2. Utilize the Speaker List provided by the Modular Meetup program
    • As a meetup organizer, you have access to a curated list of talented speakers from Celestia Labs and the broader Modular ecosystem. This valuable resource can connect you with experts who can share their knowledge with your meetup attendees.
  3. Aim for multiple speakers
    • Ideally, invite 2-3 speakers to your event, allotting 20-40 minutes per talk. Schedule short breaks between presentations to maintain audience engagement.
  4. Organize the speaker lineup
    • Discuss the topics and slides with your speakers before the event to ensure a smooth flow. Arrange the talks in a logical order, saving the most impactful presentation for last.
  5. Invite local speakers
    • For your first meetup, consider presenting an introduction to the Celestia ecosystem or a specific area of interest. Encourage local experts or enthusiasts to speak at future meetups. This approach fosters community involvement and helps build a network of potential speakers.
  6. Seek speaker referrals
    • Ask your current speakers, attendees, or other meetup organizers for referrals. Personal connections often lead to discovering new speakers with valuable insights.
  7. Leverage your meetup discussion board
    • Post a call for speakers on your meetup discussion board to reach out to potential presenters within your community. Be clear about the event theme and requirements to attract relevant speakers.
  8. Offer incentives and appreciation
    • Reward speakers with tokens of gratitude, such as T-shirts, gifts, or public recognition, to show your appreciation for their contribution to the meetup. The Celestia Labs Devrel team can help with swag logistics if needed.

Sponsors

Finding sponsors for your meetup can be challenging, but securing financial support is crucial for covering costs related to venue and refreshments.

  1. Leverage Celestia Labs' support
    • Celestia Labs may offer co-sponsorship for your meetup. However, they also encourage organizers to find local co-sponsors to help cover costs and create a more sustainable event.
  2. Offer value to your sponsors:
    • Show potential sponsors how partnering with your event will benefit them. Include their logo on event banners, mention them in the event description, and give them a shoutout at the beginning of the event. If they desire, allow them to place a rollup banner at the venue.
  3. Reach out to your network
    • Ask friends and acquaintances if they know of coworking spaces, schools, universities, or companies interested in sponsorship. A personal connection can significantly increase the chances of securing support.
  4. Approach speakers for sponsorship
    • Request speakers or their affiliated projects to contribute towards the event's expenses, such as catering costs. This can be an effective way to obtain additional funding.
  5. Create a sponsorship deck
    • Develop a compelling sponsorship deck to pitch your event to tech companies in your city or potential online sponsors. This presentation should highlight the benefits of supporting your event and showcase past successful meetups.
  6. Research local companies
    • Investigate businesses in your area that may be interested in sponsoring your event. Tailor your pitch to align with their industry and demonstrate how the meetup can benefit their company.
  7. Engage sponsors during the event
    • Allow sponsors to briefly address the audience, participate in Q&A sessions, or mention their hiring needs. Remember to avoid sales pitches, as they can negatively impact the meetup experience.
  8. Thank your sponsors
    • Express gratitude to your sponsors at the beginning and end of the meetup. Acknowledging their support encourages continued collaboration and enhances the credibility of your event.

Communications and marketing

Effectively marketing and announcing your Modular Meetup is essential for attracting attendees and ensuring a successful event.

  1. Plan your announcement
    • Announce your meetup at least two weeks prior. This gives your audience ample time to prepare and increases the likelihood of their attendance.
  2. Utilize Celestia Labs' resources
    • Celestia Labs can help co-promote your meetup on social media and Discord. They can also add your event to their online calendar, email local contacts, and share the event via their Developer Relations Team on Twitter. Don't hesitate to reach out to them for assistance.
  3. Share on social media
    • Promote your event on Twitter and any other popular social media platforms in your area. Tag speakers, sponsors, and use relevant hashtags to increase visibility.
  4. Leverage local community groups
    • Post your event in local Telegram, Discord, or other community groups relevant to your city. These groups often have many members who may be interested in attending your event.
  5. Engage speakers and the venue
    • Maintain communication with speakers and the venue to ensure any changes can be announced in advance. Trust is critical, so avoid canceling planned meetups whenever possible.
  6. Send reminders via meetup.com (optional)
    • After announcing your event, send a warm invite to your meetup group members through meetup.com. Additionally, send a reminder email one day before the event to encourage attendance.
  7. Share with friends and family
    • Invite your friends, family, and acquaintances to the meetup, as they may help spread the word or know someone interested in the event.
  8. Utilize conference groups
    • If you've attended conferences, share your meetup in the associated Telegram or social media groups, as there may be members nearby who would be interested in attending.

Recording

Recording and live-streaming your Modular Meetup can greatly benefit those who cannot attend in person and expand the reach of your event.

  1. Plan for recording
    • Consider recording your meetup to create additional learning resources and share the knowledge with a broader audience.
  2. Consider live-streaming
    • Live-streaming your event on platforms like Twitch, YouTube, or Twitter allows remote participants to watch and engage in the meetup. This can also boost your event's reach and create a sense of inclusion for those who couldn't attend in person.
  3. Coordinate with Celestia Labs
    • Celestia Labs can potentially help cover recording costs and promote recorded meetups. Reach out to them at meetups@celestia.org to discuss available options and support. They can also assist with finding local contacts for recording if you don't have one already.
  4. Utilize available resources
    • If you have a small budget, consider allocating some funds for recording and live-streaming your event. Look for local professionals or affordable equipment rentals to ensure high-quality recordings.
  5. Share recordings on Celestia Labs' channels
    • Celestia Labs can help promote recorded meetups by sharing videos in their meetups playlist on YouTube and hosting them on their website. Ensure you coordinate with Celestia Labs to provide them with the recorded video.
  6. Promote recorded content
    • Share the recordings on your social media channels and meetup group after the event. This helps attendees revisit the content and allows those who couldn't attend to learn from the talks.

Utilizing Meetup.com platform

Celestia Labs is committed to supporting your meetup efforts by helping you with meetup.com, from setting up the group to covering organizer dues. Below is a detailed overview of how Celestia Labs can assist you.

  1. Meetup.com organizer dues
    • Celestia Labs is happy to cover organizer dues for meetup.com. To get started, send an email to meetups@celestia.org and let them help you with the process.
  2. Co-organizing existing groups
    • If you already have a meetup.com group but need Celestia Labs' assistance with organizing or covering dues, email meetups@celestia.org to add one of their employees as the Organizer.
  3. Setting up groups on Meetup.com
    • Celestia Labs will help you set up your meetup group, including logos, naming, custom URLs, group description, and other essential details. They provide a unique logo for Celestia Modular Meetups, which you can use for your group.
  4. User group naming
    • Celestia Labs recommends naming your group "Celestia Modular Meetup" to encompass various aspects of the Celestia community and create a consistent brand.
  5. Custom URL for the group
    • Meetup.com allows you to create a custom URL for your user group. Celestia Labs encourages consistent URLs across regions, making it easy for people to find your meetup group.
  6. Group description
    • Celestia Labs has a standard group description to ensure consistency across all meetups. However, if you'd like to customize it, let them know.
  7. New member intake questions
    • To improve the quality of your meetups, Celestia Labs suggests a set of intake questions for new members. The answers can help you better understand their needs and interests, allowing you to plan engaging meetups.
  8. Welcome message
    • Celestia Labs provides a welcome message for new members joining your group. If you'd like to customize this message, let them know.

Onboarding questions for community members joining a Modular Meetup

  1. Q1: How did you hear about this Modular Meetup?
    • Why: This information helps us understand the most effective channels for recruiting new participants to the meetup.
  2. Q2: What do you hope to gain by participating in this meetup? (e.g., networking, learning about Celestia, learning about Modularity, finding a job, etc.)
    • Why: This information helps us cater to the needs of the user group members. If most attendees are looking for networking opportunities, we can schedule casual meetups alongside informative talks.
  3. Q3: Are you currently using or planning to use Celestia, Rollkit, Celestia’s Node API or any of the rollups deployed on Celestia? Tell us all about it. We will use your response to help us better understand what talks would be most beneficial to the group.
    • Why: Responses to this question help us determine the most relevant talks for the group members. If we discover that most participants are interested in a specific area, we can tailor the talks accordingly.
  4. Q4: We love Celestia and the modular ecosystem, but we also appreciate other Web3 technologies. What other topics would you like to hear about? (e.g., Infrastructure, Data Storage, DID, MEV)
    • Why: Knowing our group participants' interests in other technical areas helps us understand what related topics would be useful and valuable to the group, which in turn helps when recruiting speakers.
  5. Q5: Would you be interested in speaking at a future meetup? We welcome 2-minute lightning talks to 1-hour deep dives. Would you be interested in hosting a meetup? If you answer yes to this question, the group organizers will contact you to follow up.
    • Why: One of the challenges in hosting regular meetups is finding speakers. We hope this question will identify people eager to share their stories and expertise with the group, making the lives of organizers easier.
',42),r=[n];function s(l,u,c,d,p,h){return t(),i("div",null,r)}const f=e(a,[["render",s]]);export{g as __pageData,f as default}; +import{_ as e,o as t,c as i,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup guide","description":"A guide that helps in organizing a successful Modular Meetup.","frontmatter":{"description":"A guide that helps in organizing a successful Modular Meetup.","head":[["meta",{"property":"og:title","content":"Modular Meetup guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps in organizing a successful Modular Meetup."}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1732777479000}'),a={name:"community/modular-meetup-guide.md"},n=o('

Modular Meetup guide

These are recommended steps you can follow that can help you organize a successful Modular Meetup. You aren’t required to follow the entire checklist but it is available to help aid you in your journey to organize a Modular Meetup.

Before the Meetup

  1. Determine the meetup topic and objectives.
  2. Select a suitable date and time for the event.
  3. Secure a convenient and accessible venue that can accommodate the expected number of attendees.
  4. Finalize a schedule or agenda for the event, including speakers, presentations, and activities.
  5. Prepare and send out invitations to potential attendees using various channels (email, social media, community platforms, etc.).
  6. Create and share promotional materials (graphics, blog posts, etc.) to raise awareness about the meetup.
  7. Confirm speakers, including their availability, presentation topics, and technical requirements. If you are working from a Speaker List, please reach out to Nat for any support needed on coordination with speakers.
  8. Arrange any necessary equipment, such as microphones, projectors, and whiteboards.
  9. Plan and arrange refreshments, if applicable.
  10. Prepare and print any required materials, like agendas, name tags, and feedback forms.
  11. Coordinate with volunteers or team members to help manage the event.
  12. Set up a registration system or RSVP process to track attendance.
  13. Send out reminder messages to registered attendees prior to the event.
  14. Conduct a final review of the event logistics, including venue setup, equipment functionality, and volunteer roles.

During the Meetup

  1. Set up the venue, including arranging seating, preparing equipment, and displaying any promotional materials.
  2. Designate a registration area and ensure that someone is available to greet and check-in attendees.
  3. Welcome the attendees and provide an overview of the event schedule.
  4. Introduce speakers and facilitate any presentations or discussions.
  5. Encourage networking and interaction among attendees during breaks or dedicated activities.
  6. Capture the event with photos or videos for future promotions and documentation.
  7. Collect feedback from attendees using forms, online surveys, or informal conversations if needed.

After the Meetup

  1. Send follow-up messages to attendees, thanking them for their participation and soliciting additional feedback.
  2. Evaluate the success of the event by reviewing feedback and assessing key performance indicators (e.g., attendance, engagement, etc.).
  3. Analyze and document lessons learned, identifying areas for improvement in future meetups.
  4. Share event highlights, photos, and key takeaways with the community through social media, blog posts, or newsletters.
  5. Connect with speakers, attendees, and volunteers to maintain and strengthen relationships.
  6. Begin planning for the next meetup, applying insights gained from the previous event to enhance the experience for future attendees.

Logistics and guidance

These are provided guidelines for different components of kickstarting a Modular Meetup to help you get started on the logistics of organizing a meetup. A lot of those guidelines are thanks to the wonderful write ups in Ethereum Meetup Support Program and Elastic Community Organizer Guides.

Venue

Selecting the perfect venue for your Modular Meetup is essential in creating a welcoming atmosphere for the Celestia community.

  1. Startup Incubators
    • Often they would have spaces for meetups.
  2. Libraries
    • Libraries can normally have spaces for meetups at little to no costs
  3. Co-working spaces:
    • Co-working spaces might be able to offer necessary equipment like microphones, projectors, and whiteboards.
  4. Restaurants:
    • Restaurants might have private rooms for larger groups of people that you can book, depending on the restaurant.
  5. Universities and Blockchain Clubs:
    • Partnering with universities and their local university clubs can offer you a lot of spaces for meetups, as well as necessary equipments if needed for giving a talk.
  6. Other options:
    • If you're having difficulty finding a venue, don't hesitate to ask for help within the Celestia community. Your fellow organizers and attendees may have valuable suggestions or connections.

An ideal venue should offer:

  • Sufficient seating for the audience
  • A projector and screen
  • A microphone (especially for meetups with 10+ attendees)
  • Optional: A whiteboard for speakers or workshops (not always necessary, but a nice addition)

Consider recording the event, even with a smartphone, to share with the community later. If the speaker uses a microphone, their voice will be more audible in the video. We might be able to post those recordings of the meetup talks on a meetup youtube channel after.

Remember to negotiate on costs and seek discounts, emphasizing that your meetup benefits the community.

Collaborate with your venue provider to explore options like borrowing recording equipment, tripods, or even having them record the event for you. Some providers may offer these services for free or at a reduced cost.

Catering and refreshments

Providing refreshments or catering for your Modular Meetup enhances the overall experience and encourages networking among attendees.

  1. Determine your budget
    • Identify the amount you can allocate for food and drinks at your event which will help you determine how much you can bring in refreshments. You can also contact the Celestia Devrel team for ideas and support. Costs for refreshments and drinks can vary depending on your location, so be mindful to be flexible on your plans according to your specific location and budget.
  2. Offer a variety of refreshments
    • If you're ordering in, pizza and finger foods work well, but you can also have more budget-friendly options for food.
    • Offering drinks like beer, soda, or lemonade are great, but water also works. Keep in mind that not everyone drinks alcohol so it’s not a requirement. But having at least water and plastic cups works well.
  3. Plan ahead
    • Order refreshments 1 or 2 days in advance and schedule delivery to avoid last-minute stress during the event.

By following these recommendations, you'll be able to provide enjoyable refreshments for your Celestia Modular Meetup attendees while fostering a friendly and engaging atmosphere.

Audience

Understanding your audience and estimating attendance are crucial for organizing successful Modular Meetups for Celestia.

  1. Research the local tech scene:
    • Investigate the types of meetups and events popular in your area. Attend other technology-focused events to get a sense of the audience size and interests. This information will help you tailor your meetup to attract a larger audience.
  2. Assess the availability of speakers:
    • Before organizing a meetup, ensure that you have access to a pool of knowledgeable speakers. If you anticipate difficulty in securing speakers, consider joining forces with an existing meetup group or speaking at other events before launching a new group. This approach will help spread the word about your planned Modular Meetup and gauge interest. Speakers are covered in the following section with a reference to Speaker List offered by the Modular Meetup program.
  3. Establish connections with other user groups:
    • Forge relationships with other tech-focused meetup groups to mutually promote each other's events, potentially increasing attendance.
  4. Set a regular routine for your meetup:
    • Communicate how often you plan to hold meetups, whether it's monthly or quarterly, to help attendees manage their expectations and maintain their interest.
  5. Organize casual meetups:
    • If there's a gap between more formal events, arrange casual meetups at pubs or cafes to keep people engaged and connect with potential speakers for future events.
  6. Estimate the number of attendees:
    • Consider factors such as the size of your city, the popularity of the topic, and the appeal of the event description when estimating attendance.

Speakers

Securing engaging and knowledgeable speakers is key to hosting an exceptional Celestia Modular Meetup.

  1. Define your event topic
    • Determine the theme of your event, focusing on areas such as DeFi, Gaming, NFTs, coding workshops, protocol changes, rollups, data availability, or other topics relevant to the Modular ecosystem. This will help you find speakers with expertise in the chosen subject.
  2. Utilize the Speaker List provided by the Modular Meetup program
    • As a meetup organizer, you have access to a curated list of talented speakers from Celestia Labs and the broader Modular ecosystem. This valuable resource can connect you with experts who can share their knowledge with your meetup attendees.
  3. Aim for multiple speakers
    • Ideally, invite 2-3 speakers to your event, allotting 20-40 minutes per talk. Schedule short breaks between presentations to maintain audience engagement.
  4. Organize the speaker lineup
    • Discuss the topics and slides with your speakers before the event to ensure a smooth flow. Arrange the talks in a logical order, saving the most impactful presentation for last.
  5. Invite local speakers
    • For your first meetup, consider presenting an introduction to the Celestia ecosystem or a specific area of interest. Encourage local experts or enthusiasts to speak at future meetups. This approach fosters community involvement and helps build a network of potential speakers.
  6. Seek speaker referrals
    • Ask your current speakers, attendees, or other meetup organizers for referrals. Personal connections often lead to discovering new speakers with valuable insights.
  7. Leverage your meetup discussion board
    • Post a call for speakers on your meetup discussion board to reach out to potential presenters within your community. Be clear about the event theme and requirements to attract relevant speakers.
  8. Offer incentives and appreciation
    • Reward speakers with tokens of gratitude, such as T-shirts, gifts, or public recognition, to show your appreciation for their contribution to the meetup. The Celestia Labs Devrel team can help with swag logistics if needed.

Sponsors

Finding sponsors for your meetup can be challenging, but securing financial support is crucial for covering costs related to venue and refreshments.

  1. Leverage Celestia Labs' support
    • Celestia Labs may offer co-sponsorship for your meetup. However, they also encourage organizers to find local co-sponsors to help cover costs and create a more sustainable event.
  2. Offer value to your sponsors:
    • Show potential sponsors how partnering with your event will benefit them. Include their logo on event banners, mention them in the event description, and give them a shoutout at the beginning of the event. If they desire, allow them to place a rollup banner at the venue.
  3. Reach out to your network
    • Ask friends and acquaintances if they know of coworking spaces, schools, universities, or companies interested in sponsorship. A personal connection can significantly increase the chances of securing support.
  4. Approach speakers for sponsorship
    • Request speakers or their affiliated projects to contribute towards the event's expenses, such as catering costs. This can be an effective way to obtain additional funding.
  5. Create a sponsorship deck
    • Develop a compelling sponsorship deck to pitch your event to tech companies in your city or potential online sponsors. This presentation should highlight the benefits of supporting your event and showcase past successful meetups.
  6. Research local companies
    • Investigate businesses in your area that may be interested in sponsoring your event. Tailor your pitch to align with their industry and demonstrate how the meetup can benefit their company.
  7. Engage sponsors during the event
    • Allow sponsors to briefly address the audience, participate in Q&A sessions, or mention their hiring needs. Remember to avoid sales pitches, as they can negatively impact the meetup experience.
  8. Thank your sponsors
    • Express gratitude to your sponsors at the beginning and end of the meetup. Acknowledging their support encourages continued collaboration and enhances the credibility of your event.

Communications and marketing

Effectively marketing and announcing your Modular Meetup is essential for attracting attendees and ensuring a successful event.

  1. Plan your announcement
    • Announce your meetup at least two weeks prior. This gives your audience ample time to prepare and increases the likelihood of their attendance.
  2. Utilize Celestia Labs' resources
    • Celestia Labs can help co-promote your meetup on social media and Discord. They can also add your event to their online calendar, email local contacts, and share the event via their Developer Relations Team on Twitter. Don't hesitate to reach out to them for assistance.
  3. Share on social media
    • Promote your event on Twitter and any other popular social media platforms in your area. Tag speakers, sponsors, and use relevant hashtags to increase visibility.
  4. Leverage local community groups
    • Post your event in local Telegram, Discord, or other community groups relevant to your city. These groups often have many members who may be interested in attending your event.
  5. Engage speakers and the venue
    • Maintain communication with speakers and the venue to ensure any changes can be announced in advance. Trust is critical, so avoid canceling planned meetups whenever possible.
  6. Send reminders via meetup.com (optional)
    • After announcing your event, send a warm invite to your meetup group members through meetup.com. Additionally, send a reminder email one day before the event to encourage attendance.
  7. Share with friends and family
    • Invite your friends, family, and acquaintances to the meetup, as they may help spread the word or know someone interested in the event.
  8. Utilize conference groups
    • If you've attended conferences, share your meetup in the associated Telegram or social media groups, as there may be members nearby who would be interested in attending.

Recording

Recording and live-streaming your Modular Meetup can greatly benefit those who cannot attend in person and expand the reach of your event.

  1. Plan for recording
    • Consider recording your meetup to create additional learning resources and share the knowledge with a broader audience.
  2. Consider live-streaming
    • Live-streaming your event on platforms like Twitch, YouTube, or Twitter allows remote participants to watch and engage in the meetup. This can also boost your event's reach and create a sense of inclusion for those who couldn't attend in person.
  3. Coordinate with Celestia Labs
    • Celestia Labs can potentially help cover recording costs and promote recorded meetups. Reach out to them at meetups@celestia.org to discuss available options and support. They can also assist with finding local contacts for recording if you don't have one already.
  4. Utilize available resources
    • If you have a small budget, consider allocating some funds for recording and live-streaming your event. Look for local professionals or affordable equipment rentals to ensure high-quality recordings.
  5. Share recordings on Celestia Labs' channels
    • Celestia Labs can help promote recorded meetups by sharing videos in their meetups playlist on YouTube and hosting them on their website. Ensure you coordinate with Celestia Labs to provide them with the recorded video.
  6. Promote recorded content
    • Share the recordings on your social media channels and meetup group after the event. This helps attendees revisit the content and allows those who couldn't attend to learn from the talks.

Utilizing Meetup.com platform

Celestia Labs is committed to supporting your meetup efforts by helping you with meetup.com, from setting up the group to covering organizer dues. Below is a detailed overview of how Celestia Labs can assist you.

  1. Meetup.com organizer dues
    • Celestia Labs is happy to cover organizer dues for meetup.com. To get started, send an email to meetups@celestia.org and let them help you with the process.
  2. Co-organizing existing groups
    • If you already have a meetup.com group but need Celestia Labs' assistance with organizing or covering dues, email meetups@celestia.org to add one of their employees as the Organizer.
  3. Setting up groups on Meetup.com
    • Celestia Labs will help you set up your meetup group, including logos, naming, custom URLs, group description, and other essential details. They provide a unique logo for Celestia Modular Meetups, which you can use for your group.
  4. User group naming
    • Celestia Labs recommends naming your group "Celestia Modular Meetup" to encompass various aspects of the Celestia community and create a consistent brand.
  5. Custom URL for the group
    • Meetup.com allows you to create a custom URL for your user group. Celestia Labs encourages consistent URLs across regions, making it easy for people to find your meetup group.
  6. Group description
    • Celestia Labs has a standard group description to ensure consistency across all meetups. However, if you'd like to customize it, let them know.
  7. New member intake questions
    • To improve the quality of your meetups, Celestia Labs suggests a set of intake questions for new members. The answers can help you better understand their needs and interests, allowing you to plan engaging meetups.
  8. Welcome message
    • Celestia Labs provides a welcome message for new members joining your group. If you'd like to customize this message, let them know.

Onboarding questions for community members joining a Modular Meetup

  1. Q1: How did you hear about this Modular Meetup?
    • Why: This information helps us understand the most effective channels for recruiting new participants to the meetup.
  2. Q2: What do you hope to gain by participating in this meetup? (e.g., networking, learning about Celestia, learning about Modularity, finding a job, etc.)
    • Why: This information helps us cater to the needs of the user group members. If most attendees are looking for networking opportunities, we can schedule casual meetups alongside informative talks.
  3. Q3: Are you currently using or planning to use Celestia, Rollkit, Celestia’s Node API or any of the rollups deployed on Celestia? Tell us all about it. We will use your response to help us better understand what talks would be most beneficial to the group.
    • Why: Responses to this question help us determine the most relevant talks for the group members. If we discover that most participants are interested in a specific area, we can tailor the talks accordingly.
  4. Q4: We love Celestia and the modular ecosystem, but we also appreciate other Web3 technologies. What other topics would you like to hear about? (e.g., Infrastructure, Data Storage, DID, MEV)
    • Why: Knowing our group participants' interests in other technical areas helps us understand what related topics would be useful and valuable to the group, which in turn helps when recruiting speakers.
  5. Q5: Would you be interested in speaking at a future meetup? We welcome 2-minute lightning talks to 1-hour deep dives. Would you be interested in hosting a meetup? If you answer yes to this question, the group organizers will contact you to follow up.
    • Why: One of the challenges in hosting regular meetups is finding speakers. We hope this question will identify people eager to share their stories and expertise with the group, making the lives of organizers easier.
',42),r=[n];function s(l,u,c,d,p,h){return t(),i("div",null,r)}const f=e(a,[["render",s]]);export{g as __pageData,f as default}; diff --git a/pr-1815/assets/community_modular-meetup-guide.md.b2c75b9f.lean.js b/pr-1815/assets/community_modular-meetup-guide.md.67b2cbce.lean.js similarity index 92% rename from pr-1815/assets/community_modular-meetup-guide.md.b2c75b9f.lean.js rename to pr-1815/assets/community_modular-meetup-guide.md.67b2cbce.lean.js index 08c90088f..ef63c701a 100644 --- a/pr-1815/assets/community_modular-meetup-guide.md.b2c75b9f.lean.js +++ b/pr-1815/assets/community_modular-meetup-guide.md.67b2cbce.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as i,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup guide","description":"A guide that helps in organizing a successful Modular Meetup.","frontmatter":{"description":"A guide that helps in organizing a successful Modular Meetup.","head":[["meta",{"property":"og:title","content":"Modular Meetup guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps in organizing a successful Modular Meetup."}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1732776394000}'),a={name:"community/modular-meetup-guide.md"},n=o("",42),r=[n];function s(l,u,c,d,p,h){return t(),i("div",null,r)}const f=e(a,[["render",s]]);export{g as __pageData,f as default}; +import{_ as e,o as t,c as i,Q as o}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup guide","description":"A guide that helps in organizing a successful Modular Meetup.","frontmatter":{"description":"A guide that helps in organizing a successful Modular Meetup.","head":[["meta",{"property":"og:title","content":"Modular Meetup guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps in organizing a successful Modular Meetup."}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1732777479000}'),a={name:"community/modular-meetup-guide.md"},n=o("",42),r=[n];function s(l,u,c,d,p,h){return t(),i("div",null,r)}const f=e(a,[["render",s]]);export{g as __pageData,f as default}; diff --git a/pr-1815/assets/community_modular-meetup-intro.md.3c6093e3.js b/pr-1815/assets/community_modular-meetup-intro.md.3fda013b.js similarity index 98% rename from pr-1815/assets/community_modular-meetup-intro.md.3c6093e3.js rename to pr-1815/assets/community_modular-meetup-intro.md.3fda013b.js index 761066ff9..f3ccae22f 100644 --- a/pr-1815/assets/community_modular-meetup-intro.md.3c6093e3.js +++ b/pr-1815/assets/community_modular-meetup-intro.md.3fda013b.js @@ -1 +1 @@ -import{_ as e,o,c as a,Q as t}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Modular_meetup2.jpg",f=JSON.parse('{"title":"Celestia Modular Meetup program","description":"The ultimate guide for Modular Meetup organizers!","frontmatter":{"description":"The ultimate guide for Modular Meetup organizers!","head":[["meta",{"property":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"}],["meta",{"property":"og:description","content":"The ultimate guide for Modular Meetup organizers!"}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1732776394000}'),i={name:"community/modular-meetup-intro.md"},n=t('

Celestia Modular Meetup program

Modular Meetup Banner

Welcome to the ultimate guide for Modular Meetup organizers! This collection of resources is designed for those enthusiastic about fostering grassroots Modular Meetups with support from Celestia around the world.

Program description

The Celestia Modular Meetup Program aims to empower meetup organizers, providing education and support, and encouraging collaboration within the Web3 ecosystem. This rapidly growing community has already achieved incredible success with the first Modular Meetup in Lisbon, and will grow from there.

Join fellow enthusiasts, engage in enlightening discussions, and make the most of the insightful resources provided. These resources are designed to serve as a go-to playbook for meetup organizers, especially when starting your journey.

Important info

Celestia.org Community Code of Conduct

The purpose of our Community Code of Conduct is to foster an inclusive, welcoming, and supportive environment for everyone participating in Celestia community events. We're all here to learn from each other, expand our skillsets, and enjoy a positive experience together.

All meetup attendees, speakers, sponsors, and volunteers, including the event organizing team, are kindly asked to adhere to the following Code of Conduct. Organizers will respectfully enforce this code throughout the event. We genuinely appreciate the cooperation of all participants in maintaining a safe and empowering space for everyone.

Signup form

To become part of the program, please complete the registration form.

Following the review and approval of your submission, you will receive an email confirmation and an invitation to participate in the upcoming Modular Meetup call. Furthermore, you will be granted access to the exclusive Discord channel labeled "#modular-meetup" on our Discord server. Please take note that joining our Discord is a prerequisite for channel access. It's essential to recognize that this program is tailored for dedicated organizers with a genuine interest in nurturing their local modular ecosystem community.

Emails

As a participant in the Celestia Modular Meetup Program, you can expect to receive the following emails:

  1. Welcome email with links to calendar events and Discord channel
  2. Monthly Catch-up call invites
  3. Recap emails with notes from calls

Discord

Your active participation is key to unlocking the full potential of this vibrant community. Our primary communication tool is Discord, providing an engaging platform to connect with fellow organizers:

Materials

As a meetup organizer, you'll gain access to the Celestia Modular Meetup Program's list of resources. This collection should become your trusted companion in organizing events. Drawing upon the wisdom of seasoned event organizers, this resource is available for you and your co-organizers to explore and learn.

',23),s=[n];function l(u,c,d,p,m,h){return o(),a("div",null,s)}const y=e(i,[["render",l]]);export{f as __pageData,y as default}; +import{_ as e,o,c as a,Q as t}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Modular_meetup2.jpg",f=JSON.parse('{"title":"Celestia Modular Meetup program","description":"The ultimate guide for Modular Meetup organizers!","frontmatter":{"description":"The ultimate guide for Modular Meetup organizers!","head":[["meta",{"property":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"}],["meta",{"property":"og:description","content":"The ultimate guide for Modular Meetup organizers!"}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1732777479000}'),i={name:"community/modular-meetup-intro.md"},n=t('

Celestia Modular Meetup program

Modular Meetup Banner

Welcome to the ultimate guide for Modular Meetup organizers! This collection of resources is designed for those enthusiastic about fostering grassroots Modular Meetups with support from Celestia around the world.

Program description

The Celestia Modular Meetup Program aims to empower meetup organizers, providing education and support, and encouraging collaboration within the Web3 ecosystem. This rapidly growing community has already achieved incredible success with the first Modular Meetup in Lisbon, and will grow from there.

Join fellow enthusiasts, engage in enlightening discussions, and make the most of the insightful resources provided. These resources are designed to serve as a go-to playbook for meetup organizers, especially when starting your journey.

Important info

Celestia.org Community Code of Conduct

The purpose of our Community Code of Conduct is to foster an inclusive, welcoming, and supportive environment for everyone participating in Celestia community events. We're all here to learn from each other, expand our skillsets, and enjoy a positive experience together.

All meetup attendees, speakers, sponsors, and volunteers, including the event organizing team, are kindly asked to adhere to the following Code of Conduct. Organizers will respectfully enforce this code throughout the event. We genuinely appreciate the cooperation of all participants in maintaining a safe and empowering space for everyone.

Signup form

To become part of the program, please complete the registration form.

Following the review and approval of your submission, you will receive an email confirmation and an invitation to participate in the upcoming Modular Meetup call. Furthermore, you will be granted access to the exclusive Discord channel labeled "#modular-meetup" on our Discord server. Please take note that joining our Discord is a prerequisite for channel access. It's essential to recognize that this program is tailored for dedicated organizers with a genuine interest in nurturing their local modular ecosystem community.

Emails

As a participant in the Celestia Modular Meetup Program, you can expect to receive the following emails:

  1. Welcome email with links to calendar events and Discord channel
  2. Monthly Catch-up call invites
  3. Recap emails with notes from calls

Discord

Your active participation is key to unlocking the full potential of this vibrant community. Our primary communication tool is Discord, providing an engaging platform to connect with fellow organizers:

Materials

As a meetup organizer, you'll gain access to the Celestia Modular Meetup Program's list of resources. This collection should become your trusted companion in organizing events. Drawing upon the wisdom of seasoned event organizers, this resource is available for you and your co-organizers to explore and learn.

',23),s=[n];function l(u,c,d,p,m,h){return o(),a("div",null,s)}const y=e(i,[["render",l]]);export{f as __pageData,y as default}; diff --git a/pr-1815/assets/community_modular-meetup-intro.md.3c6093e3.lean.js b/pr-1815/assets/community_modular-meetup-intro.md.3fda013b.lean.js similarity index 92% rename from pr-1815/assets/community_modular-meetup-intro.md.3c6093e3.lean.js rename to pr-1815/assets/community_modular-meetup-intro.md.3fda013b.lean.js index 6ad700a9b..8558452bc 100644 --- a/pr-1815/assets/community_modular-meetup-intro.md.3c6093e3.lean.js +++ b/pr-1815/assets/community_modular-meetup-intro.md.3fda013b.lean.js @@ -1 +1 @@ -import{_ as e,o,c as a,Q as t}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Modular_meetup2.jpg",f=JSON.parse('{"title":"Celestia Modular Meetup program","description":"The ultimate guide for Modular Meetup organizers!","frontmatter":{"description":"The ultimate guide for Modular Meetup organizers!","head":[["meta",{"property":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"}],["meta",{"property":"og:description","content":"The ultimate guide for Modular Meetup organizers!"}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1732776394000}'),i={name:"community/modular-meetup-intro.md"},n=t("",23),s=[n];function l(u,c,d,p,m,h){return o(),a("div",null,s)}const y=e(i,[["render",l]]);export{f as __pageData,y as default}; +import{_ as e,o,c as a,Q as t}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Modular_meetup2.jpg",f=JSON.parse('{"title":"Celestia Modular Meetup program","description":"The ultimate guide for Modular Meetup organizers!","frontmatter":{"description":"The ultimate guide for Modular Meetup organizers!","head":[["meta",{"property":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"}],["meta",{"property":"og:description","content":"The ultimate guide for Modular Meetup organizers!"}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1732777479000}'),i={name:"community/modular-meetup-intro.md"},n=t("",23),s=[n];function l(u,c,d,p,m,h){return o(),a("div",null,s)}const y=e(i,[["render",l]]);export{f as __pageData,y as default}; diff --git a/pr-1815/assets/community_modular-meetup-toolkit.md.67ff3975.js b/pr-1815/assets/community_modular-meetup-toolkit.md.ac790481.js similarity index 98% rename from pr-1815/assets/community_modular-meetup-toolkit.md.67ff3975.js rename to pr-1815/assets/community_modular-meetup-toolkit.md.ac790481.js index 2de099af4..e3640f4d4 100644 --- a/pr-1815/assets/community_modular-meetup-toolkit.md.67ff3975.js +++ b/pr-1815/assets/community_modular-meetup-toolkit.md.ac790481.js @@ -1 +1 @@ -import{_ as e,o,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"property":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"}],["meta",{"property":"og:description","content":"A toolkit for Modular Meetups."}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1732776394000}'),l={name:"community/modular-meetup-toolkit.md"},a=i('

Modular Meetup Toolkit

Welcome to the Modular Meetups Toolkit! This kit is designed to help you run successful meetups for the Celestia community. As the first modular blockchain, Celestia offers a lot to discuss and explore. This kit includes useful resources and materials to help you plan and execute your meetups effectively.

Celestia branding guidelines

  • Brand kit
    1. Includes logo files, color schemes, typography, icons and illustrations

Sample “Introduction to Modularity” workshop presentation

  • Sample presentation - introduction to modularity
  • Summary: This is an overview presentation on Modular blockchains and dives deep into Celestia core technologies.
  • The sample presentation covers:
    1. What are modular blockchains?
    2. The benefits of modular over monolithic blockchains
    3. Introduction to Celestia: The first modular blockchain
    4. The concept of Data Availability Sampling
    5. Sovereign Rollups
    6. Q&A session

Sample “Run a Celestia light node” workshop presentation

  • Sample presentation - run a light node
  • Summary: This is an overview presentation goes over running a Celestia light node. You can find existing video presentations for this here:
  • The sample presentation covers:
    1. What is a Celestia light node?
    2. The role of light nodes in the Celestia ecosystem
    3. Setting up a light node: hardware and software requirements
    4. Step-by-step guide on how to run a Celestia light node
    5. Troubleshooting common issues
    6. Best practices for maintaining a light node
    7. Q&A session

Sample “Deploy a Sovereign Rollup” workshop presentation

  • Sample presentation - deploy a sovereign rollup
  • Summary: This is an overview presentation on deploying a sovereign rollup with Rollkit on Celestia. You can find existing video presentations for this here:
  • The sample presentation covers:
    1. What is a sovereign rollup?
    2. The role of sovereign rollups in the Celestia ecosystem
    3. Introduction to Rollkit
    4. Setting up a sovereign rollup: hardware and software requirements
    5. Q&A session

Sample “Modular Meetup Introduction” workshop presentation

Swag logistics

With this Modular Meetups Organizer Kit, you’ll have everything you need to plan and execute engaging, informative, and successful meetups for the Celestia community. Happy organizing!

',15),r=[a];function n(s,p,u,d,h,c){return o(),t("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; +import{_ as e,o,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"property":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"}],["meta",{"property":"og:description","content":"A toolkit for Modular Meetups."}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1732777479000}'),l={name:"community/modular-meetup-toolkit.md"},a=i('

Modular Meetup Toolkit

Welcome to the Modular Meetups Toolkit! This kit is designed to help you run successful meetups for the Celestia community. As the first modular blockchain, Celestia offers a lot to discuss and explore. This kit includes useful resources and materials to help you plan and execute your meetups effectively.

Celestia branding guidelines

  • Brand kit
    1. Includes logo files, color schemes, typography, icons and illustrations

Sample “Introduction to Modularity” workshop presentation

  • Sample presentation - introduction to modularity
  • Summary: This is an overview presentation on Modular blockchains and dives deep into Celestia core technologies.
  • The sample presentation covers:
    1. What are modular blockchains?
    2. The benefits of modular over monolithic blockchains
    3. Introduction to Celestia: The first modular blockchain
    4. The concept of Data Availability Sampling
    5. Sovereign Rollups
    6. Q&A session

Sample “Run a Celestia light node” workshop presentation

  • Sample presentation - run a light node
  • Summary: This is an overview presentation goes over running a Celestia light node. You can find existing video presentations for this here:
  • The sample presentation covers:
    1. What is a Celestia light node?
    2. The role of light nodes in the Celestia ecosystem
    3. Setting up a light node: hardware and software requirements
    4. Step-by-step guide on how to run a Celestia light node
    5. Troubleshooting common issues
    6. Best practices for maintaining a light node
    7. Q&A session

Sample “Deploy a Sovereign Rollup” workshop presentation

  • Sample presentation - deploy a sovereign rollup
  • Summary: This is an overview presentation on deploying a sovereign rollup with Rollkit on Celestia. You can find existing video presentations for this here:
  • The sample presentation covers:
    1. What is a sovereign rollup?
    2. The role of sovereign rollups in the Celestia ecosystem
    3. Introduction to Rollkit
    4. Setting up a sovereign rollup: hardware and software requirements
    5. Q&A session

Sample “Modular Meetup Introduction” workshop presentation

Swag logistics

With this Modular Meetups Organizer Kit, you’ll have everything you need to plan and execute engaging, informative, and successful meetups for the Celestia community. Happy organizing!

',15),r=[a];function n(s,p,u,d,h,c){return o(),t("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; diff --git a/pr-1815/assets/community_modular-meetup-toolkit.md.67ff3975.lean.js b/pr-1815/assets/community_modular-meetup-toolkit.md.ac790481.lean.js similarity index 91% rename from pr-1815/assets/community_modular-meetup-toolkit.md.67ff3975.lean.js rename to pr-1815/assets/community_modular-meetup-toolkit.md.ac790481.lean.js index c2c521e92..d26087ce3 100644 --- a/pr-1815/assets/community_modular-meetup-toolkit.md.67ff3975.lean.js +++ b/pr-1815/assets/community_modular-meetup-toolkit.md.ac790481.lean.js @@ -1 +1 @@ -import{_ as e,o,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"property":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"}],["meta",{"property":"og:description","content":"A toolkit for Modular Meetups."}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1732776394000}'),l={name:"community/modular-meetup-toolkit.md"},a=i("",15),r=[a];function n(s,p,u,d,h,c){return o(),t("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; +import{_ as e,o,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"property":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"}],["meta",{"property":"og:description","content":"A toolkit for Modular Meetups."}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1732777479000}'),l={name:"community/modular-meetup-toolkit.md"},a=i("",15),r=[a];function n(s,p,u,d,h,c){return o(),t("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; diff --git a/pr-1815/assets/community_speaker-list.md.43e3f62d.js b/pr-1815/assets/community_speaker-list.md.d01ce1fd.js similarity index 97% rename from pr-1815/assets/community_speaker-list.md.43e3f62d.js rename to pr-1815/assets/community_speaker-list.md.d01ce1fd.js index fb4f6aab1..c617af699 100644 --- a/pr-1815/assets/community_speaker-list.md.43e3f62d.js +++ b/pr-1815/assets/community_speaker-list.md.d01ce1fd.js @@ -1 +1 @@ -import{_ as t,o as a,c as o,k as e,a as s}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Speaker list","description":"Invite a speaker from the ecosystem to your Modular Meetup.","frontmatter":{"description":"Invite a speaker from the ecosystem to your Modular Meetup.","head":[["meta",{"property":"og:title","content":"Speaker list | Celestia Docs"}],["meta",{"property":"og:description","content":"Invite a speaker from the ecosystem to your Modular Meetup."}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1732776394000}'),i={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[s("Speaker list "),e("a",{class:"header-anchor",href:"#speaker-list","aria-label":'Permalink to "Speaker list"'},"​")],-1),n=e("p",null,"As a Modular Meetup organizer, we understand the importance of delivering engaging and informative content to your attendees. That's why we've created an exclusive Speaker List specifically tailored for organizers participating in the Modular Meetup Program. This resource gives you access to a curated selection of top-tier speakers who are passionate about Celestia and the modular ecosystem. Due to privacy, the list is not shared publicly but is accessible to participants of the Modular Meetup program when they create a meetup.",-1),l=e("p",null,"The Speaker List features experts from Celestia Labs, as well as prominent figures from the broader Celestia and modular communities. Each individual is well-versed in various aspects of the modular ecosystem, ensuring that your meetup attendees gain valuable insights and deepen their understanding of modular blockchains.",-1),p=e("p",null,"By joining the Modular Meetup Program, you can enjoy the benefits of our Speaker List and bring a touch of expertise to your events. The speakers can participate either in person or virtually, depending on location and timing.",-1),c=e("p",null,"You can expect benefits from the Speaker List including high-quality presentations, interactive Q&A sessions, and knowledge-sharing opportunities facilitated by the best and brightest in the Celestia ecosystem. With our Speaker List, you'll be able to create memorable and impactful Modular Meetups that foster genuine connections and promote growth within the community.",-1),u=[r,n,l,p,c];function d(h,m,f,y,g,k){return a(),o("div",null,u)}const v=t(i,[["render",d]]);export{b as __pageData,v as default}; +import{_ as t,o as a,c as o,k as e,a as s}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Speaker list","description":"Invite a speaker from the ecosystem to your Modular Meetup.","frontmatter":{"description":"Invite a speaker from the ecosystem to your Modular Meetup.","head":[["meta",{"property":"og:title","content":"Speaker list | Celestia Docs"}],["meta",{"property":"og:description","content":"Invite a speaker from the ecosystem to your Modular Meetup."}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1732777479000}'),i={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[s("Speaker list "),e("a",{class:"header-anchor",href:"#speaker-list","aria-label":'Permalink to "Speaker list"'},"​")],-1),n=e("p",null,"As a Modular Meetup organizer, we understand the importance of delivering engaging and informative content to your attendees. That's why we've created an exclusive Speaker List specifically tailored for organizers participating in the Modular Meetup Program. This resource gives you access to a curated selection of top-tier speakers who are passionate about Celestia and the modular ecosystem. Due to privacy, the list is not shared publicly but is accessible to participants of the Modular Meetup program when they create a meetup.",-1),l=e("p",null,"The Speaker List features experts from Celestia Labs, as well as prominent figures from the broader Celestia and modular communities. Each individual is well-versed in various aspects of the modular ecosystem, ensuring that your meetup attendees gain valuable insights and deepen their understanding of modular blockchains.",-1),p=e("p",null,"By joining the Modular Meetup Program, you can enjoy the benefits of our Speaker List and bring a touch of expertise to your events. The speakers can participate either in person or virtually, depending on location and timing.",-1),c=e("p",null,"You can expect benefits from the Speaker List including high-quality presentations, interactive Q&A sessions, and knowledge-sharing opportunities facilitated by the best and brightest in the Celestia ecosystem. With our Speaker List, you'll be able to create memorable and impactful Modular Meetups that foster genuine connections and promote growth within the community.",-1),u=[r,n,l,p,c];function d(h,m,f,y,g,k){return a(),o("div",null,u)}const v=t(i,[["render",d]]);export{b as __pageData,v as default}; diff --git a/pr-1815/assets/community_speaker-list.md.43e3f62d.lean.js b/pr-1815/assets/community_speaker-list.md.d01ce1fd.lean.js similarity index 97% rename from pr-1815/assets/community_speaker-list.md.43e3f62d.lean.js rename to pr-1815/assets/community_speaker-list.md.d01ce1fd.lean.js index fb4f6aab1..c617af699 100644 --- a/pr-1815/assets/community_speaker-list.md.43e3f62d.lean.js +++ b/pr-1815/assets/community_speaker-list.md.d01ce1fd.lean.js @@ -1 +1 @@ -import{_ as t,o as a,c as o,k as e,a as s}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Speaker list","description":"Invite a speaker from the ecosystem to your Modular Meetup.","frontmatter":{"description":"Invite a speaker from the ecosystem to your Modular Meetup.","head":[["meta",{"property":"og:title","content":"Speaker list | Celestia Docs"}],["meta",{"property":"og:description","content":"Invite a speaker from the ecosystem to your Modular Meetup."}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1732776394000}'),i={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[s("Speaker list "),e("a",{class:"header-anchor",href:"#speaker-list","aria-label":'Permalink to "Speaker list"'},"​")],-1),n=e("p",null,"As a Modular Meetup organizer, we understand the importance of delivering engaging and informative content to your attendees. That's why we've created an exclusive Speaker List specifically tailored for organizers participating in the Modular Meetup Program. This resource gives you access to a curated selection of top-tier speakers who are passionate about Celestia and the modular ecosystem. Due to privacy, the list is not shared publicly but is accessible to participants of the Modular Meetup program when they create a meetup.",-1),l=e("p",null,"The Speaker List features experts from Celestia Labs, as well as prominent figures from the broader Celestia and modular communities. Each individual is well-versed in various aspects of the modular ecosystem, ensuring that your meetup attendees gain valuable insights and deepen their understanding of modular blockchains.",-1),p=e("p",null,"By joining the Modular Meetup Program, you can enjoy the benefits of our Speaker List and bring a touch of expertise to your events. The speakers can participate either in person or virtually, depending on location and timing.",-1),c=e("p",null,"You can expect benefits from the Speaker List including high-quality presentations, interactive Q&A sessions, and knowledge-sharing opportunities facilitated by the best and brightest in the Celestia ecosystem. With our Speaker List, you'll be able to create memorable and impactful Modular Meetups that foster genuine connections and promote growth within the community.",-1),u=[r,n,l,p,c];function d(h,m,f,y,g,k){return a(),o("div",null,u)}const v=t(i,[["render",d]]);export{b as __pageData,v as default}; +import{_ as t,o as a,c as o,k as e,a as s}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Speaker list","description":"Invite a speaker from the ecosystem to your Modular Meetup.","frontmatter":{"description":"Invite a speaker from the ecosystem to your Modular Meetup.","head":[["meta",{"property":"og:title","content":"Speaker list | Celestia Docs"}],["meta",{"property":"og:description","content":"Invite a speaker from the ecosystem to your Modular Meetup."}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1732777479000}'),i={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[s("Speaker list "),e("a",{class:"header-anchor",href:"#speaker-list","aria-label":'Permalink to "Speaker list"'},"​")],-1),n=e("p",null,"As a Modular Meetup organizer, we understand the importance of delivering engaging and informative content to your attendees. That's why we've created an exclusive Speaker List specifically tailored for organizers participating in the Modular Meetup Program. This resource gives you access to a curated selection of top-tier speakers who are passionate about Celestia and the modular ecosystem. Due to privacy, the list is not shared publicly but is accessible to participants of the Modular Meetup program when they create a meetup.",-1),l=e("p",null,"The Speaker List features experts from Celestia Labs, as well as prominent figures from the broader Celestia and modular communities. Each individual is well-versed in various aspects of the modular ecosystem, ensuring that your meetup attendees gain valuable insights and deepen their understanding of modular blockchains.",-1),p=e("p",null,"By joining the Modular Meetup Program, you can enjoy the benefits of our Speaker List and bring a touch of expertise to your events. The speakers can participate either in person or virtually, depending on location and timing.",-1),c=e("p",null,"You can expect benefits from the Speaker List including high-quality presentations, interactive Q&A sessions, and knowledge-sharing opportunities facilitated by the best and brightest in the Celestia ecosystem. With our Speaker List, you'll be able to create memorable and impactful Modular Meetups that foster genuine connections and promote growth within the community.",-1),u=[r,n,l,p,c];function d(h,m,f,y,g,k){return a(),o("div",null,u)}const v=t(i,[["render",d]]);export{b as __pageData,v as default}; diff --git a/pr-1815/assets/how-to-guides_arabica-devnet.md.99c9281a.js b/pr-1815/assets/how-to-guides_arabica-devnet.md.a7bda01d.js similarity index 99% rename from pr-1815/assets/how-to-guides_arabica-devnet.md.99c9281a.js rename to pr-1815/assets/how-to-guides_arabica-devnet.md.a7bda01d.js index 3bc286b2b..39df6c381 100644 --- a/pr-1815/assets/how-to-guides_arabica-devnet.md.99c9281a.js +++ b/pr-1815/assets/how-to-guides_arabica-devnet.md.a7bda01d.js @@ -1,3 +1,3 @@ import{A as d}from"./chunks/ArabicaVersionTags.bc287822.js";import{c as p}from"./chunks/constants.b02263eb.js";import{_ as h,o,c as r,k as e,t as a,H as s,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";const b="/docs-preview/pr-1815/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),m=e("td",null,"Chain ID",-1),f=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),v=e("td",null,"Genesis file",-1),E=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(i,l,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[m,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),f,e("tr",null,[v,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.arabicaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+a(t.constants.arabicaChainId)+"/genesis.json ",9,E)])]),e("tr",null,[k,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.arabicaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+a(t.constants.arabicaChainId)+"/peers.txt ",9,w)])]),_])}const A=h(g,[["render",C]]),D=n('

Arabica devnet

arabica-devnet

Arabica devnet is a testnet from Celestia Labs that is focused exclusively on providing developers with enhanced performance and the latest upgrades for testing their rollups and applications.

Arabica does not focus on validator or consensus-level testing, rather, that is what Mocha testnet is used for. If you are a validator, we recommend testing your validator operations on the Mocha testnet.

Network stability and upgrades

Arabica has the latest updates from all Celestia's products deployed on it, it can be subject to many changes. Therefore, as a fair warning, Arabica can break unexpectedly, but given it will be continuously updated, it is a useful way to keep testing the latest changes in the software.

Developers can still deploy on Mocha testnet their sovereign rollups if they chose to do so, it just will always lag behind Arabica devnet until Mocha undergoes network upgrades in coordination with validators.

Network details

',8),F=e("h3",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n(`

Integrations

This guide contains the relevant sections for how to connect to Arabica devnet, depending on the type of node you are running. Your best approach to participating is to first determine which node you would like to run. Each node’s guide will link to the relevant network in order to show you how to connect to them. Learn about the different endpoint types in the Cosmos SDK documentation.

Production RPC endpoints

These RPC providers are meant to be used in production environments.

ProviderURL
NewMetrichttps://app.newmetric.xyz/start
NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
Grovehttps://www.grove.city/

Community RPC endpoints

WARNING

Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

RPC endpoints and types of nodes you can run in order to participate in Arabica devnet:

Node typeEndpoint typeEndpoint
Consensus nodes (full)Consensus RPChttps://rpc.celestia-arabica-11.com
APIhttps://api.celestia-arabica-11.com
gRPCgrpc.celestia-arabica-11.com:443
Direct endpoints with open portsOpen ports: 26656 (p2p), 26657 (RPC), 1317 (API), 9090 (GRPC)
validator-1.celestia-arabica-11.com
validator-2.celestia-arabica-11.com
validator-3.celestia-arabica-11.com
validator-4.celestia-arabica-11.com
Data availability nodesDA Bridge Node Endpoints/dns4/da-bridge-1.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWGqwzdEqM54Dce6LXzfFr97Bnhvm6rN7KM7MFwdomfm4S
(light, bridge, full)/dns4/da-bridge-2.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWCMGM5eZWVfCN9ZLAViGfLUWAfXP5pCm78NFKb9jpBtua
/dns4/da-bridge-3.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWEWuqrjULANpukDFGVoHW3RoeUU53Ec9t9v5cwW3MkVdQ
/dns4/da-bridge-4.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWLT1ysSrD7XWSBjh7tU1HQanF5M64dHV6AuM6cYEJxMPk
--core.ip string endpointsRefer to "Direct endpoints with open ports" above

You can find the status of these endpoints.

Using consensus endpoints with DA nodes

Data availability (DA) RPC endpoints for bridge node sync

These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

Data availability (DA) gRPC endpoints for state access

These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

EXAMPLE

bash
celestia <da_type> start –core.ip <url> -–core.grpc.port <port>
celestia <da_type> start –core.ip <url> -–core.grpc.port <port>

RPCs for DA nodes to initialise or start your celestia-node to Arabica devnet with can be found in the table in the "Direct endpoints with open ports" section above.

As an example, this command will work to start a light node with state access, using default ports:

bash
celestia light start --p2p.network arabica \\
   --core.ip validator-1.celestia-arabica-11.com
celestia light start --p2p.network arabica \\
-  --core.ip validator-1.celestia-arabica-11.com

Bridge node runners

Not all of the RPC endpoints do not guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

Arabica devnet faucet

WARNING

USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

Discord

You can request from Arabica devnet Faucet on the #arabica-faucet channel on Celestia's Discord server with the following command:

text
$request <CELESTIA-ADDRESS>
$request <CELESTIA-ADDRESS>

Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

NOTE

Faucet has a limit of 10 tokens per week per address/Discord ID.

Web

The web faucet is available at https://faucet.celestia-arabica-11.com/.

Explorers

There are multiple explorers you can use for Arabica:

Network upgrades

Join our Telegram announcement channel for network upgrades.

See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

`,35),B=JSON.parse('{"title":"Arabica devnet","description":"A guide to Arabica devnet.","frontmatter":{"description":"A guide to Arabica devnet.","head":[["meta",{"property":"og:title","content":"Arabica devnet | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to Arabica devnet."}]]},"headers":[],"relativePath":"how-to-guides/arabica-devnet.md","filePath":"how-to-guides/arabica-devnet.md","lastUpdated":1732776394000}'),T={name:"how-to-guides/arabica-devnet.md"},L=Object.assign(T,{setup(i){return(l,c)=>(o(),r("div",null,[D,s(A),F,s(d),P]))}});export{B as __pageData,L as default}; + --core.ip validator-1.celestia-arabica-11.com

Bridge node runners

Not all of the RPC endpoints do not guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

Arabica devnet faucet

WARNING

USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

Discord

You can request from Arabica devnet Faucet on the #arabica-faucet channel on Celestia's Discord server with the following command:

text
$request <CELESTIA-ADDRESS>
$request <CELESTIA-ADDRESS>

Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

NOTE

Faucet has a limit of 10 tokens per week per address/Discord ID.

Web

The web faucet is available at https://faucet.celestia-arabica-11.com/.

Explorers

There are multiple explorers you can use for Arabica:

Network upgrades

Join our Telegram announcement channel for network upgrades.

See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

`,35),B=JSON.parse('{"title":"Arabica devnet","description":"A guide to Arabica devnet.","frontmatter":{"description":"A guide to Arabica devnet.","head":[["meta",{"property":"og:title","content":"Arabica devnet | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to Arabica devnet."}]]},"headers":[],"relativePath":"how-to-guides/arabica-devnet.md","filePath":"how-to-guides/arabica-devnet.md","lastUpdated":1732777479000}'),T={name:"how-to-guides/arabica-devnet.md"},L=Object.assign(T,{setup(i){return(l,c)=>(o(),r("div",null,[D,s(A),F,s(d),P]))}});export{B as __pageData,L as default}; diff --git a/pr-1815/assets/how-to-guides_arabica-devnet.md.99c9281a.lean.js b/pr-1815/assets/how-to-guides_arabica-devnet.md.a7bda01d.lean.js similarity index 97% rename from pr-1815/assets/how-to-guides_arabica-devnet.md.99c9281a.lean.js rename to pr-1815/assets/how-to-guides_arabica-devnet.md.a7bda01d.lean.js index 16be6df49..2b914b3f3 100644 --- a/pr-1815/assets/how-to-guides_arabica-devnet.md.99c9281a.lean.js +++ b/pr-1815/assets/how-to-guides_arabica-devnet.md.a7bda01d.lean.js @@ -1 +1 @@ -import{A as d}from"./chunks/ArabicaVersionTags.bc287822.js";import{c as p}from"./chunks/constants.b02263eb.js";import{_ as h,o,c as r,k as e,t as a,H as s,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";const b="/docs-preview/pr-1815/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),m=e("td",null,"Chain ID",-1),f=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),v=e("td",null,"Genesis file",-1),E=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(i,l,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[m,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),f,e("tr",null,[v,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.arabicaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+a(t.constants.arabicaChainId)+"/genesis.json ",9,E)])]),e("tr",null,[k,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.arabicaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+a(t.constants.arabicaChainId)+"/peers.txt ",9,w)])]),_])}const A=h(g,[["render",C]]),D=n("",8),F=e("h3",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n("",35),B=JSON.parse('{"title":"Arabica devnet","description":"A guide to Arabica devnet.","frontmatter":{"description":"A guide to Arabica devnet.","head":[["meta",{"property":"og:title","content":"Arabica devnet | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to Arabica devnet."}]]},"headers":[],"relativePath":"how-to-guides/arabica-devnet.md","filePath":"how-to-guides/arabica-devnet.md","lastUpdated":1732776394000}'),T={name:"how-to-guides/arabica-devnet.md"},L=Object.assign(T,{setup(i){return(l,c)=>(o(),r("div",null,[D,s(A),F,s(d),P]))}});export{B as __pageData,L as default}; +import{A as d}from"./chunks/ArabicaVersionTags.bc287822.js";import{c as p}from"./chunks/constants.b02263eb.js";import{_ as h,o,c as r,k as e,t as a,H as s,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";const b="/docs-preview/pr-1815/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),m=e("td",null,"Chain ID",-1),f=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),v=e("td",null,"Genesis file",-1),E=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(i,l,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[m,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),f,e("tr",null,[v,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.arabicaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+a(t.constants.arabicaChainId)+"/genesis.json ",9,E)])]),e("tr",null,[k,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.arabicaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+a(t.constants.arabicaChainId)+"/peers.txt ",9,w)])]),_])}const A=h(g,[["render",C]]),D=n("",8),F=e("h3",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n("",35),B=JSON.parse('{"title":"Arabica devnet","description":"A guide to Arabica devnet.","frontmatter":{"description":"A guide to Arabica devnet.","head":[["meta",{"property":"og:title","content":"Arabica devnet | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to Arabica devnet."}]]},"headers":[],"relativePath":"how-to-guides/arabica-devnet.md","filePath":"how-to-guides/arabica-devnet.md","lastUpdated":1732777479000}'),T={name:"how-to-guides/arabica-devnet.md"},L=Object.assign(T,{setup(i){return(l,c)=>(o(),r("div",null,[D,s(A),F,s(d),P]))}});export{B as __pageData,L as default}; diff --git a/pr-1815/assets/how-to-guides_arbitrum-bridge.md.67821b72.js b/pr-1815/assets/how-to-guides_arbitrum-bridge.md.fc2c9c1e.js similarity index 99% rename from pr-1815/assets/how-to-guides_arbitrum-bridge.md.67821b72.js rename to pr-1815/assets/how-to-guides_arbitrum-bridge.md.fc2c9c1e.js index 8ef7fd14e..c5a84c004 100644 --- a/pr-1815/assets/how-to-guides_arbitrum-bridge.md.67821b72.js +++ b/pr-1815/assets/how-to-guides_arbitrum-bridge.md.fc2c9c1e.js @@ -1 +1 @@ -import{_ as r,o as t,c as o,Q as e}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1815/arbitrum/bridge-settings.png",n="/docs-preview/pr-1815/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1815/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1815/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1815/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1815/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1815/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1815/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1815/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1815/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1815/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1815/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1815/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1815/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1815/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1815/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1815/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1815/arbitrum/bridge-out-claim-success-withdrawal.png",D=JSON.parse('{"title":"Bridging in and out of your Orbit rollup","description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","frontmatter":{"description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","next":{"text":"Intro to OP Stack integration","link":"/how-to-guides/intro-to-op-stack"},"head":[["meta",{"property":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to bridge in and out of your Arbitrum Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-bridge.md","filePath":"how-to-guides/arbitrum-bridge.md","lastUpdated":1732776394000}'),A={name:"how-to-guides/arbitrum-bridge.md"},k=e('

Bridging in and out of your Orbit rollup

This guide covers how to bridge in (deposit) and bridge out (withdrawal) from your Arbitrum Orbit L3 rollup.

This guide will cover bridging in and out of your Orbit rollup.

Below are two example transactions, one of a deposit and one of a withdrawal:

bridge-overview-deposit-and-withdrawal-l3

Bridge in (deposit) to your rollup

Step 1: Add your custom chain config

(1a) In the Arbitrum Bridge UI, click the menu dropdown in the top right. Select Settings.

bridge-settings

(1b) Under Developer Mode, select Turn on testnet mode. Add your custom chain config from outputInfo.json in the root of your orbit-setup-script directory.

add-testnet-orbit-chain

(1c) You'll then see the chain under Live Orbit Chains:

live-orbit-chains

Step 2: Deposit to your Orbit rollup

(2a) Choose an amount of Arbitrum Sepolia ETH to bridge into your rollup. Click Move funds to <YOUR_ROLLUP_NAME>, in this case Move funds to Arbitrum L3 Rollup. Approve the transaction in your wallet.

bridge-in-start

(2b) You'll then see it load in the Pending transactions tab:

bridge-in-pending

(2c) Shortly after, in the Settled transactions tab you can see the transaction status. Click Success.

bridge-in-settled-txs

(2d) View the transaction on your local instance of Blockscout for your rollup:

bridge-in-explorer-rollup-tx

(2e) Optionally, click See Details for an overview of your deposit:

bridge-in-success

(2f) From the details page, you can also see the transaction for your deposit on Arbitrum Sepolia:

bridge-in-sepolia-tx-explorer

Bridge out (withdrawal) from your rollup

Step 1: Choose an amount to withdraw from your rollup

(1a) In the Arbitrum Bridge UI, choose your origin chain to your Arbitrum L3 Rollup and the destination chain as Arbitrum Sepolia.

bridge-out-small-screenshot

(1b) Click Move funds to Arbitrum Sepolia and read the disclaimer, check the boxes, and click Continue.

bridge-out-begin

(1c) Optionally, set a reminder on your calendar so you don't forget.

(1d) After approving the transaction in your wallet, you'll be able to see the transaction in the Pending transactions tab:

bridge-out-pending

After approximately two hours, you will be able to proceed to Step 2: Claim your withdrawal.

(1e) Click See details to see an overview of your withdrawal:

bridge-out-begin-overview

(1f) Optionally, view the transaction on your local explorer.

bridge-out-tx-details

(1g) To learn more about what is going on, click the Logs tab:

bridge-out-logs-details-1

bridge-out-logs-explorer-2

Step 2: Claim your withdrawal

After approximately 2 hours, you will be able to claim your withdrawal.

(2a) Head back to the bridge UI and you will have a notification to claim your withdrawal. Click Claim in the details of the transaction:

bridge-out-claim-withdrawal

(2b) Approve the transaction in your wallet.

(2c) After your transaction goes through, you can see the details in the bridge UI under Settled transactions:

bridge-out-claim-success-withdrawal

',50),S=[k];function O(C,B,P,q,T,I){return t(),o("div",null,S)}const L=r(A,[["render",O]]);export{D as __pageData,L as default}; +import{_ as r,o as t,c as o,Q as e}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1815/arbitrum/bridge-settings.png",n="/docs-preview/pr-1815/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1815/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1815/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1815/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1815/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1815/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1815/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1815/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1815/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1815/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1815/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1815/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1815/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1815/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1815/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1815/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1815/arbitrum/bridge-out-claim-success-withdrawal.png",D=JSON.parse('{"title":"Bridging in and out of your Orbit rollup","description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","frontmatter":{"description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","next":{"text":"Intro to OP Stack integration","link":"/how-to-guides/intro-to-op-stack"},"head":[["meta",{"property":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to bridge in and out of your Arbitrum Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-bridge.md","filePath":"how-to-guides/arbitrum-bridge.md","lastUpdated":1732777479000}'),A={name:"how-to-guides/arbitrum-bridge.md"},k=e('

Bridging in and out of your Orbit rollup

This guide covers how to bridge in (deposit) and bridge out (withdrawal) from your Arbitrum Orbit L3 rollup.

This guide will cover bridging in and out of your Orbit rollup.

Below are two example transactions, one of a deposit and one of a withdrawal:

bridge-overview-deposit-and-withdrawal-l3

Bridge in (deposit) to your rollup

Step 1: Add your custom chain config

(1a) In the Arbitrum Bridge UI, click the menu dropdown in the top right. Select Settings.

bridge-settings

(1b) Under Developer Mode, select Turn on testnet mode. Add your custom chain config from outputInfo.json in the root of your orbit-setup-script directory.

add-testnet-orbit-chain

(1c) You'll then see the chain under Live Orbit Chains:

live-orbit-chains

Step 2: Deposit to your Orbit rollup

(2a) Choose an amount of Arbitrum Sepolia ETH to bridge into your rollup. Click Move funds to <YOUR_ROLLUP_NAME>, in this case Move funds to Arbitrum L3 Rollup. Approve the transaction in your wallet.

bridge-in-start

(2b) You'll then see it load in the Pending transactions tab:

bridge-in-pending

(2c) Shortly after, in the Settled transactions tab you can see the transaction status. Click Success.

bridge-in-settled-txs

(2d) View the transaction on your local instance of Blockscout for your rollup:

bridge-in-explorer-rollup-tx

(2e) Optionally, click See Details for an overview of your deposit:

bridge-in-success

(2f) From the details page, you can also see the transaction for your deposit on Arbitrum Sepolia:

bridge-in-sepolia-tx-explorer

Bridge out (withdrawal) from your rollup

Step 1: Choose an amount to withdraw from your rollup

(1a) In the Arbitrum Bridge UI, choose your origin chain to your Arbitrum L3 Rollup and the destination chain as Arbitrum Sepolia.

bridge-out-small-screenshot

(1b) Click Move funds to Arbitrum Sepolia and read the disclaimer, check the boxes, and click Continue.

bridge-out-begin

(1c) Optionally, set a reminder on your calendar so you don't forget.

(1d) After approving the transaction in your wallet, you'll be able to see the transaction in the Pending transactions tab:

bridge-out-pending

After approximately two hours, you will be able to proceed to Step 2: Claim your withdrawal.

(1e) Click See details to see an overview of your withdrawal:

bridge-out-begin-overview

(1f) Optionally, view the transaction on your local explorer.

bridge-out-tx-details

(1g) To learn more about what is going on, click the Logs tab:

bridge-out-logs-details-1

bridge-out-logs-explorer-2

Step 2: Claim your withdrawal

After approximately 2 hours, you will be able to claim your withdrawal.

(2a) Head back to the bridge UI and you will have a notification to claim your withdrawal. Click Claim in the details of the transaction:

bridge-out-claim-withdrawal

(2b) Approve the transaction in your wallet.

(2c) After your transaction goes through, you can see the details in the bridge UI under Settled transactions:

bridge-out-claim-success-withdrawal

',50),S=[k];function O(C,B,P,q,T,I){return t(),o("div",null,S)}const L=r(A,[["render",O]]);export{D as __pageData,L as default}; diff --git a/pr-1815/assets/how-to-guides_arbitrum-bridge.md.67821b72.lean.js b/pr-1815/assets/how-to-guides_arbitrum-bridge.md.fc2c9c1e.lean.js similarity index 97% rename from pr-1815/assets/how-to-guides_arbitrum-bridge.md.67821b72.lean.js rename to pr-1815/assets/how-to-guides_arbitrum-bridge.md.fc2c9c1e.lean.js index 33417792c..2b046e163 100644 --- a/pr-1815/assets/how-to-guides_arbitrum-bridge.md.67821b72.lean.js +++ b/pr-1815/assets/how-to-guides_arbitrum-bridge.md.fc2c9c1e.lean.js @@ -1 +1 @@ -import{_ as r,o as t,c as o,Q as e}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1815/arbitrum/bridge-settings.png",n="/docs-preview/pr-1815/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1815/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1815/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1815/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1815/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1815/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1815/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1815/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1815/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1815/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1815/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1815/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1815/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1815/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1815/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1815/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1815/arbitrum/bridge-out-claim-success-withdrawal.png",D=JSON.parse('{"title":"Bridging in and out of your Orbit rollup","description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","frontmatter":{"description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","next":{"text":"Intro to OP Stack integration","link":"/how-to-guides/intro-to-op-stack"},"head":[["meta",{"property":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to bridge in and out of your Arbitrum Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-bridge.md","filePath":"how-to-guides/arbitrum-bridge.md","lastUpdated":1732776394000}'),A={name:"how-to-guides/arbitrum-bridge.md"},k=e("",50),S=[k];function O(C,B,P,q,T,I){return t(),o("div",null,S)}const L=r(A,[["render",O]]);export{D as __pageData,L as default}; +import{_ as r,o as t,c as o,Q as e}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1815/arbitrum/bridge-settings.png",n="/docs-preview/pr-1815/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1815/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1815/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1815/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1815/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1815/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1815/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1815/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1815/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1815/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1815/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1815/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1815/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1815/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1815/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1815/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1815/arbitrum/bridge-out-claim-success-withdrawal.png",D=JSON.parse('{"title":"Bridging in and out of your Orbit rollup","description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","frontmatter":{"description":"A guide on how to bridge in and out of your Arbitrum Orbit rollup.","next":{"text":"Intro to OP Stack integration","link":"/how-to-guides/intro-to-op-stack"},"head":[["meta",{"property":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to bridge in and out of your Arbitrum Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-bridge.md","filePath":"how-to-guides/arbitrum-bridge.md","lastUpdated":1732777479000}'),A={name:"how-to-guides/arbitrum-bridge.md"},k=e("",50),S=[k];function O(C,B,P,q,T,I){return t(),o("div",null,S)}const L=r(A,[["render",O]]);export{D as __pageData,L as default}; diff --git a/pr-1815/assets/how-to-guides_arbitrum-deploy.md.ab7e5910.js b/pr-1815/assets/how-to-guides_arbitrum-deploy.md.f0ee059a.js similarity index 99% rename from pr-1815/assets/how-to-guides_arbitrum-deploy.md.ab7e5910.js rename to pr-1815/assets/how-to-guides_arbitrum-deploy.md.f0ee059a.js index 00a7c3e6f..12499872d 100644 --- a/pr-1815/assets/how-to-guides_arbitrum-deploy.md.ab7e5910.js +++ b/pr-1815/assets/how-to-guides_arbitrum-deploy.md.f0ee059a.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const e="/docs-preview/pr-1815/arbitrum/choose_da.png",t="/docs-preview/pr-1815/arbitrum/configuration.png",l="/docs-preview/pr-1815/arbitrum/download-config.png",p="/docs-preview/pr-1815/arbitrum/blockscout.png",r="/docs-preview/pr-1815/arbitrum/explorer-view.png",g=JSON.parse('{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","frontmatter":{"description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","head":[["meta",{"property":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-deploy.md","filePath":"how-to-guides/arbitrum-deploy.md","lastUpdated":1732776394000}'),c={name:"how-to-guides/arbitrum-deploy.md"},i=n('

Quickstart: Deploy an Arbitrum Orbit rollup

This guide covers deploying a rollup using the Celestia Orbit chain deployment portal.

After completing this tutorial, you will have a local development network rollup capable of hosting EVM-compatible smart contracts. This rollup will process transactions locally, settle on the public Arbitrum Sepolia testnet, and post data to Celestia's Mocha testnet.

If you're looking to learn more about the integration of Celestia and Orbit, read the Arbitrum Orbit integration overview. If you're looking to learn more about Orbit, read A gentle introduction: Orbit chains.

Thank you, Offchain Labs!

This guide was made possible with the support and information provided by the Offchain Labs team, the creators of Arbitrum. For more detailed information and support, visit Arbitrum documentation and the original deployment guide.

Prerequisites

Setup

This section was adapted from Arbitrum's Orbit quickstart.

Step 1: Acquire Arbitrum Sepolia ETH

You'll need at least 1 testnet ETH for a regular Orbit rollup or 0.6 ETH plus 0.4 of your desired native token for Orbit rollups with a custom gas token. The funds will cover the cost of deploying the base contracts to the base chain, in this case, Arbitrum Sepolia.

The simplest way to do this is to:

  1. Use an L1 testnet ETH faucet like sepoliafaucet.com to acquire some testnet ETH on Ethereum Sepolia testnet.
  2. Bridge your L1 testnet ETH to L2 Arbitrum Sepolia using the Arbitrum bridge.

Step 2: Pick your deployment type

Visit the Celestia Orbit chain deployment portal. This portal offers the following options:

  1. Celestia Rollup: Transaction data is posted to Celestia
  2. Rollup: Transaction data is posted to Ethereum
  3. AnyTrust: Transaction data is posted by a Data Availability Committee

Connect your wallet to the deployment portal. You may be prompted to add the Arbitrum Sepolia network to your wallet and/or switch your wallet to this network; approve this.

In this guide, we will select Celestia ✨ and deploy a rollup which posts data to Celestia (1 above).

Choose Celestia for DA

Click Next. In the next step, we will configure the deployment.

Step 3: Configure your Orbit chain's deployment

The deployment portal will then display a form that looks like this:

configuration

Parameter descriptions can be found in the table below (more in-depth descriptions can be found in the deployment UI). We recommend sticking to the defaults; to learn more about customizing your Orbit chain's deployment configuration, visit How to customize your Orbit chain's deployment configuration:

ParameterDescription
Chain IDThis is a unique integer identifier for your chain's network, primarily used on chain indexes like Chainlist.org. It's not crucial for development networks, but in production, you'll need to choose a unique ID.
Chain NameThe name you assign to your Orbit chain, which helps users and developers distinguish it from other chains. It should be memorable and recognizable.
Challenge Period BlocksDetermines the time frame within which validators can dispute the state of the chain posted to the base chain. It's measured in blocks on the underlying L1 chain. A longer period allows more time for disputes but also delays withdrawals.
Stake TokenSpecifies the token that validators must stake to participate in the validation process, using the token's contract address on the base chain. This can be ETH or another token, defined by its address.
Base StakeThe minimum amount of stake token required for validators to post state assertions. A lower base stake lowers the barrier to entry but increases vulnerability to attacks, whereas a higher stake encourages honest participation but raises the entry barrier.
OwnerThe account address that has the authority to deploy, own, and update the base contracts of your Orbit chain on its base chain. In production, this is usually a high-stakes address controlled by a DAO or a multisig setup. For development chains, it's a lower-stakes administrative account.
Gas TokenThe token used for gas payments on the network, which must be natively deployed on the parent chain. There are specific requirements for custom gas tokens, such as having 18 decimals and not being a rebasing or fee-on-transfer token. This feature is primarily for Orbit AnyTrust chains.
ValidatorsThis is the number of validators for your chain, including their addresses. The first validator is auto-generated and immutable. Validators are crucial for maintaining the integrity of the chain and posting state assertions to the base chain.
Batch PosterResponsible for posting transaction batches from your Orbit chain to the base chain. An address for this role is automatically generated, with the private key stored in a configuration file.

In the Configure Validators section, specify the number of validators and their addresses for your chain. The initial validator's address is pre-generated and immutable, with its key stored in a JSON file. Validators ensure transaction integrity and state assertions on the base chain. They're added to an allow-list for validation and staking. Base contracts refer to your Orbit chain's L2 contracts, and base chain to the L2 chain they're deployed on.

In the Configure Batch Poster section, a batch poster address is auto-generated for posting transaction batches to the base contracts on the base chain. The address and its private key are also stored in a JSON configuration file. After configuring, proceed to review and deploy your Orbit chain.

After configuring your batch poster, proceed to the next step.

Step 4: Review & Deploy your Orbit chain

Now, deploy your chain's base contracts to Arbitrum Sepolia!

Click the Deploy button on the Review & Deploy page. Your wallet should prompt you to submit a transaction to the Arbitrum testnet. You'll have to pay a little gas; your wallet may denominate this in ETH; as long as you see your chosen Arbitrum testnet in the transaction details, this gas fee will be paid in testnet ETH.

Before proceeding, let's briefly review what just happened:

  1. You submitted a deployment transaction to an Orbit "factory" smart contract on the Arbitrum testnet, the public L2 chain that your local Orbit chain will settle transactions to.
  2. This Orbit smart contract then initialized your Orbit chain's base contracts with the values that you specified in the previous step, and deployed these base contracts to the Arbitrum testnet.

Your Orbit chain's base contracts are responsible for facilitating the exchange of information between your chain's node(s) and its base chain's nodes. This includes the batch posting of transactions from your Orbit chain to its base chain, the staking of tokens by your Orbit chain's validators the challenge mechanism, bridging mechanisms, and more.

Once your transaction is complete, continue to Step 4 to download your chain's configuration files and launch your chain.

Step 5: Download your chain's configuration files and launch your chain

After configuring your chain, you will need to download the necessary configuration files to launch your chain. Click the Download zip files button to download both the Rollup Config and L3 Config in a single ZIP file.

  • Rollup Config: This is the nodeConfig.json file, encapsulating your chain's node configuration. It is crucial as it contains the private keys for your validator and batch poster, essential for signing transactions for RBlocks and batch postings to your chain's base contracts on the L2 chain.

  • L3 Config: This is the orbitSetupScriptConfig.json file, which holds your chain's configuration, including configurations needed for your Token Bridge contracts.

Ensure to securely store these downloaded files as they contain sensitive information crucial for your chain's operation.

download config

Step 6: Clone the setup script repository and add your configuration files

  1. Clone the orbit-setup-script repository:

    bash
    git clone https://github.com/celestiaorg/orbit-setup-script.git
    git clone https://github.com/celestiaorg/orbit-setup-script.git
  2. Move the nodeConfig.json and orbitSetupScriptConfig.json files that you downloaded into the config directory in the root of your cloned orbit-setup-script repository.

  3. Install dependencies by running yarn install from the root of the orbit-setup-script repository.

Step 7: Pick an L2 RPC URL for the Batch Poster

In order for the Batch Poster, which is responsible for posting batches of data, to subscribe to Blobstream's smart contract events, the node most use a WebSocket connection, since an HTTP one will not support subscriptions. This RPC URL is different from the parent-chain.connection.url object used in the node config, and is not necessary when running a full node. WebSocket (WSS) URLs which are essential for real-time data fetching and interaction with the Arbitrum Sepolia network.

To establish a WebSocket connection for your rollup to Arbitrum Sepolia, it's recommended to find an RPC provider with WSS connections from Arbitrum's docs.

For this example, we will make an account on Alchemy. Follow these steps to set up your account and obtain a WSS URL using Alchemy:

  1. Visit Alchemy's website and sign up for an account.
  2. Once logged in, create a new app by selecting the Arbitrum network, specifically targeting the Arbitrum Sepolia testnet.
  3. After creating your app, navigate to the "API key" section to find your WebSocket (WSS) URL.
  4. In the next step, use this WSS URL in your nodeConfig.json under the celestia-cfg.eth-rpc object to ensure your node can establish a WebSocket connection to the Arbitrum Sepolia network and successfully subscribe to Blobstream events.

Without a WSS connection, the Batch Poster won't be able to subscribe to Blobstream events, and thus will fall back to posting data to parent chain.

Step 8: Run your light node for Mocha testnet

First, be sure that your light node is running, using a command similar to:

TIP

If you are on Linux (or are not using Docker desktop), you may need to add the extra flags: --rpc.addr 0.0.0.0 and --rpc.port 26658 to your start command for your light node.

Additionally, you will need to add host.docker.internal as a host in your docker-compose.yml:

yaml
extra_hosts:
+import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const e="/docs-preview/pr-1815/arbitrum/choose_da.png",t="/docs-preview/pr-1815/arbitrum/configuration.png",l="/docs-preview/pr-1815/arbitrum/download-config.png",p="/docs-preview/pr-1815/arbitrum/blockscout.png",r="/docs-preview/pr-1815/arbitrum/explorer-view.png",g=JSON.parse('{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","frontmatter":{"description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","head":[["meta",{"property":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-deploy.md","filePath":"how-to-guides/arbitrum-deploy.md","lastUpdated":1732777479000}'),c={name:"how-to-guides/arbitrum-deploy.md"},i=n('

Quickstart: Deploy an Arbitrum Orbit rollup

This guide covers deploying a rollup using the Celestia Orbit chain deployment portal.

After completing this tutorial, you will have a local development network rollup capable of hosting EVM-compatible smart contracts. This rollup will process transactions locally, settle on the public Arbitrum Sepolia testnet, and post data to Celestia's Mocha testnet.

If you're looking to learn more about the integration of Celestia and Orbit, read the Arbitrum Orbit integration overview. If you're looking to learn more about Orbit, read A gentle introduction: Orbit chains.

Thank you, Offchain Labs!

This guide was made possible with the support and information provided by the Offchain Labs team, the creators of Arbitrum. For more detailed information and support, visit Arbitrum documentation and the original deployment guide.

Prerequisites

Setup

This section was adapted from Arbitrum's Orbit quickstart.

Step 1: Acquire Arbitrum Sepolia ETH

You'll need at least 1 testnet ETH for a regular Orbit rollup or 0.6 ETH plus 0.4 of your desired native token for Orbit rollups with a custom gas token. The funds will cover the cost of deploying the base contracts to the base chain, in this case, Arbitrum Sepolia.

The simplest way to do this is to:

  1. Use an L1 testnet ETH faucet like sepoliafaucet.com to acquire some testnet ETH on Ethereum Sepolia testnet.
  2. Bridge your L1 testnet ETH to L2 Arbitrum Sepolia using the Arbitrum bridge.

Step 2: Pick your deployment type

Visit the Celestia Orbit chain deployment portal. This portal offers the following options:

  1. Celestia Rollup: Transaction data is posted to Celestia
  2. Rollup: Transaction data is posted to Ethereum
  3. AnyTrust: Transaction data is posted by a Data Availability Committee

Connect your wallet to the deployment portal. You may be prompted to add the Arbitrum Sepolia network to your wallet and/or switch your wallet to this network; approve this.

In this guide, we will select Celestia ✨ and deploy a rollup which posts data to Celestia (1 above).

Choose Celestia for DA

Click Next. In the next step, we will configure the deployment.

Step 3: Configure your Orbit chain's deployment

The deployment portal will then display a form that looks like this:

configuration

Parameter descriptions can be found in the table below (more in-depth descriptions can be found in the deployment UI). We recommend sticking to the defaults; to learn more about customizing your Orbit chain's deployment configuration, visit How to customize your Orbit chain's deployment configuration:

ParameterDescription
Chain IDThis is a unique integer identifier for your chain's network, primarily used on chain indexes like Chainlist.org. It's not crucial for development networks, but in production, you'll need to choose a unique ID.
Chain NameThe name you assign to your Orbit chain, which helps users and developers distinguish it from other chains. It should be memorable and recognizable.
Challenge Period BlocksDetermines the time frame within which validators can dispute the state of the chain posted to the base chain. It's measured in blocks on the underlying L1 chain. A longer period allows more time for disputes but also delays withdrawals.
Stake TokenSpecifies the token that validators must stake to participate in the validation process, using the token's contract address on the base chain. This can be ETH or another token, defined by its address.
Base StakeThe minimum amount of stake token required for validators to post state assertions. A lower base stake lowers the barrier to entry but increases vulnerability to attacks, whereas a higher stake encourages honest participation but raises the entry barrier.
OwnerThe account address that has the authority to deploy, own, and update the base contracts of your Orbit chain on its base chain. In production, this is usually a high-stakes address controlled by a DAO or a multisig setup. For development chains, it's a lower-stakes administrative account.
Gas TokenThe token used for gas payments on the network, which must be natively deployed on the parent chain. There are specific requirements for custom gas tokens, such as having 18 decimals and not being a rebasing or fee-on-transfer token. This feature is primarily for Orbit AnyTrust chains.
ValidatorsThis is the number of validators for your chain, including their addresses. The first validator is auto-generated and immutable. Validators are crucial for maintaining the integrity of the chain and posting state assertions to the base chain.
Batch PosterResponsible for posting transaction batches from your Orbit chain to the base chain. An address for this role is automatically generated, with the private key stored in a configuration file.

In the Configure Validators section, specify the number of validators and their addresses for your chain. The initial validator's address is pre-generated and immutable, with its key stored in a JSON file. Validators ensure transaction integrity and state assertions on the base chain. They're added to an allow-list for validation and staking. Base contracts refer to your Orbit chain's L2 contracts, and base chain to the L2 chain they're deployed on.

In the Configure Batch Poster section, a batch poster address is auto-generated for posting transaction batches to the base contracts on the base chain. The address and its private key are also stored in a JSON configuration file. After configuring, proceed to review and deploy your Orbit chain.

After configuring your batch poster, proceed to the next step.

Step 4: Review & Deploy your Orbit chain

Now, deploy your chain's base contracts to Arbitrum Sepolia!

Click the Deploy button on the Review & Deploy page. Your wallet should prompt you to submit a transaction to the Arbitrum testnet. You'll have to pay a little gas; your wallet may denominate this in ETH; as long as you see your chosen Arbitrum testnet in the transaction details, this gas fee will be paid in testnet ETH.

Before proceeding, let's briefly review what just happened:

  1. You submitted a deployment transaction to an Orbit "factory" smart contract on the Arbitrum testnet, the public L2 chain that your local Orbit chain will settle transactions to.
  2. This Orbit smart contract then initialized your Orbit chain's base contracts with the values that you specified in the previous step, and deployed these base contracts to the Arbitrum testnet.

Your Orbit chain's base contracts are responsible for facilitating the exchange of information between your chain's node(s) and its base chain's nodes. This includes the batch posting of transactions from your Orbit chain to its base chain, the staking of tokens by your Orbit chain's validators the challenge mechanism, bridging mechanisms, and more.

Once your transaction is complete, continue to Step 4 to download your chain's configuration files and launch your chain.

Step 5: Download your chain's configuration files and launch your chain

After configuring your chain, you will need to download the necessary configuration files to launch your chain. Click the Download zip files button to download both the Rollup Config and L3 Config in a single ZIP file.

  • Rollup Config: This is the nodeConfig.json file, encapsulating your chain's node configuration. It is crucial as it contains the private keys for your validator and batch poster, essential for signing transactions for RBlocks and batch postings to your chain's base contracts on the L2 chain.

  • L3 Config: This is the orbitSetupScriptConfig.json file, which holds your chain's configuration, including configurations needed for your Token Bridge contracts.

Ensure to securely store these downloaded files as they contain sensitive information crucial for your chain's operation.

download config

Step 6: Clone the setup script repository and add your configuration files

  1. Clone the orbit-setup-script repository:

    bash
    git clone https://github.com/celestiaorg/orbit-setup-script.git
    git clone https://github.com/celestiaorg/orbit-setup-script.git
  2. Move the nodeConfig.json and orbitSetupScriptConfig.json files that you downloaded into the config directory in the root of your cloned orbit-setup-script repository.

  3. Install dependencies by running yarn install from the root of the orbit-setup-script repository.

Step 7: Pick an L2 RPC URL for the Batch Poster

In order for the Batch Poster, which is responsible for posting batches of data, to subscribe to Blobstream's smart contract events, the node most use a WebSocket connection, since an HTTP one will not support subscriptions. This RPC URL is different from the parent-chain.connection.url object used in the node config, and is not necessary when running a full node. WebSocket (WSS) URLs which are essential for real-time data fetching and interaction with the Arbitrum Sepolia network.

To establish a WebSocket connection for your rollup to Arbitrum Sepolia, it's recommended to find an RPC provider with WSS connections from Arbitrum's docs.

For this example, we will make an account on Alchemy. Follow these steps to set up your account and obtain a WSS URL using Alchemy:

  1. Visit Alchemy's website and sign up for an account.
  2. Once logged in, create a new app by selecting the Arbitrum network, specifically targeting the Arbitrum Sepolia testnet.
  3. After creating your app, navigate to the "API key" section to find your WebSocket (WSS) URL.
  4. In the next step, use this WSS URL in your nodeConfig.json under the celestia-cfg.eth-rpc object to ensure your node can establish a WebSocket connection to the Arbitrum Sepolia network and successfully subscribe to Blobstream events.

Without a WSS connection, the Batch Poster won't be able to subscribe to Blobstream events, and thus will fall back to posting data to parent chain.

Step 8: Run your light node for Mocha testnet

First, be sure that your light node is running, using a command similar to:

TIP

If you are on Linux (or are not using Docker desktop), you may need to add the extra flags: --rpc.addr 0.0.0.0 and --rpc.port 26658 to your start command for your light node.

Additionally, you will need to add host.docker.internal as a host in your docker-compose.yml:

yaml
extra_hosts:
       - "host.docker.internal:host-gateway"
extra_hosts:
       - "host.docker.internal:host-gateway"
bash
celestia light start --p2p.network mocha --core.ip <RPC_URL>
celestia light start --p2p.network mocha --core.ip <RPC_URL>

To set your light node's auth token, you will use the auth token that returns when you run:

bash
celestia light auth admin --p2p.network mocha
celestia light auth admin --p2p.network mocha

Since the contracts deployed through the factories above are already configured to communicate with Blobstream, you now only have to configure your node accordingly. First understand the different variables that will be set in the config:

  • enable: set it to true if you are using Celestia DA 😁
  • rpc: RPC endpoint for celestia-node
  • tendermint-rpc: a celestia-core endpoint from a full node (NOTE: only needed for a batch poster node)
  • eth-rpc: Ethereum Client WSS RPC endpoint, only used when the node is a batch poster. The eth-rpc must be WSS. Otherwise, it won't be able to subscribe to events for Blobstream.
  • namespace-id: namespace being used to post data to Celestia
  • auth-token: auth token for your Celestia Node
  • is-poster: is the node with Celestia DA the batch poster, set to true if so.
  • gas-price: how much to pay for gas (in uTIA)
  • event-channel-size: size of the events channel used by the batch poster to wait for a range of headers that contains the header for the block in which it posted a blob, before posting the batch to the base layer for verification on Blobstream X.
  • blobstreamx-address: address of the Blobstream X contract on the base chain.
    • Note that the SequencerInbox contract for each chain has a constant address for the BlobstreamX contract, thus make sure that the Blobstream X address in the SequencerInbox being used for the templates in RollupCreator matches the one in your config.

Now enable Celestia DA in your Arbitrum chain params in config/nodeConfig.json. If you'd like to use your own namespace, use a custom 10 byte value or random value using openssl rand -hex 10 for namespace-id:

WARNING

The Orbit contracts depend on the existing Blobstream X deployments. Before using these addresses, please verify the contract addresses on the official source below to avoid any issues due to incorrect addresses. This is crucial to protect against potential misuse by copy-paste errors.

ts
"celestia-cfg": {
   "enable": true,
diff --git a/pr-1815/assets/how-to-guides_arbitrum-deploy.md.ab7e5910.lean.js b/pr-1815/assets/how-to-guides_arbitrum-deploy.md.f0ee059a.lean.js
similarity index 95%
rename from pr-1815/assets/how-to-guides_arbitrum-deploy.md.ab7e5910.lean.js
rename to pr-1815/assets/how-to-guides_arbitrum-deploy.md.f0ee059a.lean.js
index fc3696322..e5221f88e 100644
--- a/pr-1815/assets/how-to-guides_arbitrum-deploy.md.ab7e5910.lean.js
+++ b/pr-1815/assets/how-to-guides_arbitrum-deploy.md.f0ee059a.lean.js
@@ -1 +1 @@
-import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const e="/docs-preview/pr-1815/arbitrum/choose_da.png",t="/docs-preview/pr-1815/arbitrum/configuration.png",l="/docs-preview/pr-1815/arbitrum/download-config.png",p="/docs-preview/pr-1815/arbitrum/blockscout.png",r="/docs-preview/pr-1815/arbitrum/explorer-view.png",g=JSON.parse('{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","frontmatter":{"description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","head":[["meta",{"property":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-deploy.md","filePath":"how-to-guides/arbitrum-deploy.md","lastUpdated":1732776394000}'),c={name:"how-to-guides/arbitrum-deploy.md"},i=n("",95),y=[i];function E(d,F,h,u,b,C){return a(),o("div",null,y)}const B=s(c,[["render",E]]);export{g as __pageData,B as default};
+import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const e="/docs-preview/pr-1815/arbitrum/choose_da.png",t="/docs-preview/pr-1815/arbitrum/configuration.png",l="/docs-preview/pr-1815/arbitrum/download-config.png",p="/docs-preview/pr-1815/arbitrum/blockscout.png",r="/docs-preview/pr-1815/arbitrum/explorer-view.png",g=JSON.parse('{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","frontmatter":{"description":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet.","head":[["meta",{"property":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to deploy an Arbitrum Orbit rollup using the Arbitrum Orbit deployment UI and deploying the rollup to Mocha testnet."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-deploy.md","filePath":"how-to-guides/arbitrum-deploy.md","lastUpdated":1732777479000}'),c={name:"how-to-guides/arbitrum-deploy.md"},i=n("",95),y=[i];function E(d,F,h,u,b,C){return a(),o("div",null,y)}const B=s(c,[["render",E]]);export{g as __pageData,B as default};
diff --git a/pr-1815/assets/how-to-guides_arbitrum-full-node.md.db590a7b.js b/pr-1815/assets/how-to-guides_arbitrum-full-node.md.59ec28dd.js
similarity index 98%
rename from pr-1815/assets/how-to-guides_arbitrum-full-node.md.db590a7b.js
rename to pr-1815/assets/how-to-guides_arbitrum-full-node.md.59ec28dd.js
index ba85ea4ba..756028d34 100644
--- a/pr-1815/assets/how-to-guides_arbitrum-full-node.md.db590a7b.js
+++ b/pr-1815/assets/how-to-guides_arbitrum-full-node.md.59ec28dd.js
@@ -1,3 +1,3 @@
-import{_ as n,o,c as e,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Running a full node and/or validator","description":"A guide on how to run a full node or validating full node on your Orbit rollup.","frontmatter":{"description":"A guide on how to run a full node or validating full node on your Orbit rollup.","head":[["meta",{"property":"og:title","content":"Running a full node and/or validator | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run a full node or validating full node on your Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-full-node.md","filePath":"how-to-guides/arbitrum-full-node.md","lastUpdated":1732776394000}'),t={name:"how-to-guides/arbitrum-full-node.md"},r=a(`

Running a full node and/or validator

Prerequisites

Running a full node

To run a full node, you can follow the steps outlined in the Arbitrum docs, with the difference being that you will use this image: dfcelestia/nitro-node-dev:latest instead of the one mentioned in the Arbitrum docs.

Note that you can either use the flags in the nitro binary + the flags found in the celestia package, or you can just provide a node config.json file with the celestia-cfg for them to run it, which would look something like this:

json
docker run --rm -v "$HOME/Documents/configs/nodeConfig.json:/config.json:ro" \\
+import{_ as n,o,c as e,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Running a full node and/or validator","description":"A guide on how to run a full node or validating full node on your Orbit rollup.","frontmatter":{"description":"A guide on how to run a full node or validating full node on your Orbit rollup.","head":[["meta",{"property":"og:title","content":"Running a full node and/or validator | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run a full node or validating full node on your Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-full-node.md","filePath":"how-to-guides/arbitrum-full-node.md","lastUpdated":1732777479000}'),t={name:"how-to-guides/arbitrum-full-node.md"},r=a(`

Running a full node and/or validator

Prerequisites

Running a full node

To run a full node, you can follow the steps outlined in the Arbitrum docs, with the difference being that you will use this image: dfcelestia/nitro-node-dev:latest instead of the one mentioned in the Arbitrum docs.

Note that you can either use the flags in the nitro binary + the flags found in the celestia package, or you can just provide a node config.json file with the celestia-cfg for them to run it, which would look something like this:

json
docker run --rm -v "$HOME/Documents/configs/nodeConfig.json:/config.json:ro" \\
   --network host celestia-nitro:v2.3.1-rc.1 --conf.file /config.json
docker run --rm -v "$HOME/Documents/configs/nodeConfig.json:/config.json:ro" \\
   --network host celestia-nitro:v2.3.1-rc.1 --conf.file /config.json

Running a full node with validation

The information above applies to the steps outlined to run a validating full node (validator).

Finally, note that this will require connection to a DA node, and we recommend running a Bridge node if you will be instantiating multiple rollups.

`,10),i=[r];function l(s,d,u,c,p,h){return o(),e("div",null,i)}const b=n(t,[["render",l]]);export{g as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_arbitrum-full-node.md.db590a7b.lean.js b/pr-1815/assets/how-to-guides_arbitrum-full-node.md.59ec28dd.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_arbitrum-full-node.md.db590a7b.lean.js rename to pr-1815/assets/how-to-guides_arbitrum-full-node.md.59ec28dd.lean.js index c7ce01f3f..2b46f52e3 100644 --- a/pr-1815/assets/how-to-guides_arbitrum-full-node.md.db590a7b.lean.js +++ b/pr-1815/assets/how-to-guides_arbitrum-full-node.md.59ec28dd.lean.js @@ -1 +1 @@ -import{_ as n,o,c as e,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Running a full node and/or validator","description":"A guide on how to run a full node or validating full node on your Orbit rollup.","frontmatter":{"description":"A guide on how to run a full node or validating full node on your Orbit rollup.","head":[["meta",{"property":"og:title","content":"Running a full node and/or validator | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run a full node or validating full node on your Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-full-node.md","filePath":"how-to-guides/arbitrum-full-node.md","lastUpdated":1732776394000}'),t={name:"how-to-guides/arbitrum-full-node.md"},r=a("",10),i=[r];function l(s,d,u,c,p,h){return o(),e("div",null,i)}const b=n(t,[["render",l]]);export{g as __pageData,b as default}; +import{_ as n,o,c as e,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Running a full node and/or validator","description":"A guide on how to run a full node or validating full node on your Orbit rollup.","frontmatter":{"description":"A guide on how to run a full node or validating full node on your Orbit rollup.","head":[["meta",{"property":"og:title","content":"Running a full node and/or validator | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run a full node or validating full node on your Orbit rollup."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-full-node.md","filePath":"how-to-guides/arbitrum-full-node.md","lastUpdated":1732777479000}'),t={name:"how-to-guides/arbitrum-full-node.md"},r=a("",10),i=[r];function l(s,d,u,c,p,h){return o(),e("div",null,i)}const b=n(t,[["render",l]]);export{g as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_arbitrum-integration.md.eea707b4.js b/pr-1815/assets/how-to-guides_arbitrum-integration.md.6c060e19.js similarity index 99% rename from pr-1815/assets/how-to-guides_arbitrum-integration.md.eea707b4.js rename to pr-1815/assets/how-to-guides_arbitrum-integration.md.6c060e19.js index 951c88bf9..f244a34db 100644 --- a/pr-1815/assets/how-to-guides_arbitrum-integration.md.eea707b4.js +++ b/pr-1815/assets/how-to-guides_arbitrum-integration.md.6c060e19.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia-Arbitrum.png",f=JSON.parse('{"title":"Introduction to Arbitrum rollups with Celestia as DA","description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","frontmatter":{"description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","head":[["meta",{"property":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-integration.md","filePath":"how-to-guides/arbitrum-integration.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/arbitrum-integration.md"},n=i('

Introduction to Arbitrum rollups with Celestia as DA

Celestia_Arbitrum

Overview

The integration of Celestia with Arbitrum Orbit and the Nitro tech stack marks the first external contribution to the Arbitrum Orbit protocol layer, offering developers an additional option for selecting a data availability layer alongside Arbitrum AnyTrust. The integration allows developers to deploy an Orbit Chain that uses Celestia for data availability and settles on Arbitrum One, Ethereum, or other EVM chains.

Learn more about Orbit in Arbitrum's introduction.

Key components

The integration of Celestia with Arbitrum orbit is possible thanks to 3 key components:

Additionally, the Ethereum fallback mechanism is a feature of the integration, which is native in Nitro.

DA provider implementation

The Arbitrum Nitro code has a DataAvailabilityProvider interface that is used across the codebase to store and retrieve data from a specific provider (eip4844 blobs, Anytrust, and now Celestia).

This integration implements the DataAvailabilityProvider interface for Celestia DA

Additionally, this integration comes with the necessary code for a Nitro chain node to post and retrieve data from Celestia.

The core logic behind posting and retrieving data happens in celestia.go where data is stored on Celestia and serialized into a small batch of data that gets published once the necessary range of headers (data roots) has been relayed to the BlobstreamX contract. Then the Read logic takes care of taking the deserialized Blob Pointer struct and consuming it in order to fetch the data from Celestia and additionally inform the fetcher about the position of the data on Celestia (we'll get back to this in the next section).

The following represents a non-exhaustive list of considerations when running a Batch Poster node for a chain with Celestia underneath:

  • You will need to use a consensus node RPC endpoint, you can find a list of them for Mocha
  • The Batch Poster will only post a Celestia batch to the underlying chain if the height for which it posted is in a recent range in BlobstreamX and if the verification succeeds, otherwise it will discard the batch. Since it will wait until a range is relayed, it can take several minutes for a batch to be posted, but one can always make an on-chain request for the BlobstreamX contract to relay a header promptly.

The following represents a non-exhaustive list of considerations when running a Nitro node for a chain with Celestia underneath:

  • The TendermintRpc endpoint is only needed by the batch poster, every other node can operate without a connection to a full node.
  • The message header flag for Celestia batches is 0x0c.
  • You will need to know the namespace for the chain that you are trying to connect to, but don't worry if you don't find it, as the information in the BlobPointer can be used to identify where a batch of data is in the Celestia Data Square for a given height, and thus can be used to find out the namespace as well!

Preimage Oracle Implementation

In order to support fraud proofs, this integration has the necessary code for a Nitro validator to populate its preimage mapping with Celestia hashes that then get "unpeeled" in order to reveal the full data for a Blob. You can read more about the "Hash Oracle Trick".

The data structures and hashing functions for this can be found in the nitro/das/celestia/tree folder

You can see where the preimage oracle gets used in the fraud proof replay binary here

Something important to note is that the preimage oracle only keeps track of hashes for the rows in the Celestia data square in which a blob resides in, this way each Orbit chain with Celestia underneath does not need validators to recompute an entire Celestia Data Square, but instead, only have to compute the row roots for the rows in which it's data lives in, and the header data root, which is the binary merkle tree hash built using the row roots and column roots fetched from a Celestia node. Because only data roots that can be confirmed on Blobstream get accepted into the sequencer inbox, one can have a high degree of certainty that the canonical data root being unpeeled as well as the row roots are in fact correct.

Blobstream X implementation

Finally, the integration only accepts batches with information that can be confirmed on BlobstreamX, which gives us a high certainty that data was made available on Celestia.

You can see how BlobstreamX is integrated into the SequencerInbox.sol contract here, which allows us to discard batches with otherwise faulty data roots, thus giving us a high degree of confidence that the data root can be safely unpacked in case of a challenge.

The Celestia and Arbitrum integration also includes Blobstream, which relays commitments to Celestia’s data root to an onchain light client on Ethereum. This allows L2 solutions that settle on Ethereum to benefit from the scalability Celestia’s data availability layer can provide.

Ethereum fallback mechanism in Nitro

By default in Arbitrum Nitro, the Ethereum fallback mechanism in the BatchPoster function is handling the process of storing data, with a fallback mechanism to store data onchain if the primary data availability storage fails.

The @celestiaorg/nitro integration uses the same fallback mechanism.

More information can be found on the Ethereum fallback mechanisms for Celestia, which enables Ethereum L2s (or L3s) to “fall back” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta.

The fallback logic for Celestia DA is configurable, providing an alternative to the previous default fallback mechanism. Additionally, an ability has been added to the Arbitrum node software which allows the sequencer to call VerifyAttestation to check if a data root has been posted on Blobstream or not, before it sends the sequencer message (data pointer) to the underlying chain.

Next steps

In the next page, learn how to deploy an Arbitrum rollup devnet using Celestia as DA.

',34),l=[n];function s(h,c,d,m,b,u){return t(),a("div",null,l)}const g=e(o,[["render",s]]);export{f as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia-Arbitrum.png",f=JSON.parse('{"title":"Introduction to Arbitrum rollups with Celestia as DA","description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","frontmatter":{"description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","head":[["meta",{"property":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-integration.md","filePath":"how-to-guides/arbitrum-integration.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/arbitrum-integration.md"},n=i('

Introduction to Arbitrum rollups with Celestia as DA

Celestia_Arbitrum

Overview

The integration of Celestia with Arbitrum Orbit and the Nitro tech stack marks the first external contribution to the Arbitrum Orbit protocol layer, offering developers an additional option for selecting a data availability layer alongside Arbitrum AnyTrust. The integration allows developers to deploy an Orbit Chain that uses Celestia for data availability and settles on Arbitrum One, Ethereum, or other EVM chains.

Learn more about Orbit in Arbitrum's introduction.

Key components

The integration of Celestia with Arbitrum orbit is possible thanks to 3 key components:

Additionally, the Ethereum fallback mechanism is a feature of the integration, which is native in Nitro.

DA provider implementation

The Arbitrum Nitro code has a DataAvailabilityProvider interface that is used across the codebase to store and retrieve data from a specific provider (eip4844 blobs, Anytrust, and now Celestia).

This integration implements the DataAvailabilityProvider interface for Celestia DA

Additionally, this integration comes with the necessary code for a Nitro chain node to post and retrieve data from Celestia.

The core logic behind posting and retrieving data happens in celestia.go where data is stored on Celestia and serialized into a small batch of data that gets published once the necessary range of headers (data roots) has been relayed to the BlobstreamX contract. Then the Read logic takes care of taking the deserialized Blob Pointer struct and consuming it in order to fetch the data from Celestia and additionally inform the fetcher about the position of the data on Celestia (we'll get back to this in the next section).

The following represents a non-exhaustive list of considerations when running a Batch Poster node for a chain with Celestia underneath:

  • You will need to use a consensus node RPC endpoint, you can find a list of them for Mocha
  • The Batch Poster will only post a Celestia batch to the underlying chain if the height for which it posted is in a recent range in BlobstreamX and if the verification succeeds, otherwise it will discard the batch. Since it will wait until a range is relayed, it can take several minutes for a batch to be posted, but one can always make an on-chain request for the BlobstreamX contract to relay a header promptly.

The following represents a non-exhaustive list of considerations when running a Nitro node for a chain with Celestia underneath:

  • The TendermintRpc endpoint is only needed by the batch poster, every other node can operate without a connection to a full node.
  • The message header flag for Celestia batches is 0x0c.
  • You will need to know the namespace for the chain that you are trying to connect to, but don't worry if you don't find it, as the information in the BlobPointer can be used to identify where a batch of data is in the Celestia Data Square for a given height, and thus can be used to find out the namespace as well!

Preimage Oracle Implementation

In order to support fraud proofs, this integration has the necessary code for a Nitro validator to populate its preimage mapping with Celestia hashes that then get "unpeeled" in order to reveal the full data for a Blob. You can read more about the "Hash Oracle Trick".

The data structures and hashing functions for this can be found in the nitro/das/celestia/tree folder

You can see where the preimage oracle gets used in the fraud proof replay binary here

Something important to note is that the preimage oracle only keeps track of hashes for the rows in the Celestia data square in which a blob resides in, this way each Orbit chain with Celestia underneath does not need validators to recompute an entire Celestia Data Square, but instead, only have to compute the row roots for the rows in which it's data lives in, and the header data root, which is the binary merkle tree hash built using the row roots and column roots fetched from a Celestia node. Because only data roots that can be confirmed on Blobstream get accepted into the sequencer inbox, one can have a high degree of certainty that the canonical data root being unpeeled as well as the row roots are in fact correct.

Blobstream X implementation

Finally, the integration only accepts batches with information that can be confirmed on BlobstreamX, which gives us a high certainty that data was made available on Celestia.

You can see how BlobstreamX is integrated into the SequencerInbox.sol contract here, which allows us to discard batches with otherwise faulty data roots, thus giving us a high degree of confidence that the data root can be safely unpacked in case of a challenge.

The Celestia and Arbitrum integration also includes Blobstream, which relays commitments to Celestia’s data root to an onchain light client on Ethereum. This allows L2 solutions that settle on Ethereum to benefit from the scalability Celestia’s data availability layer can provide.

Ethereum fallback mechanism in Nitro

By default in Arbitrum Nitro, the Ethereum fallback mechanism in the BatchPoster function is handling the process of storing data, with a fallback mechanism to store data onchain if the primary data availability storage fails.

The @celestiaorg/nitro integration uses the same fallback mechanism.

More information can be found on the Ethereum fallback mechanisms for Celestia, which enables Ethereum L2s (or L3s) to “fall back” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta.

The fallback logic for Celestia DA is configurable, providing an alternative to the previous default fallback mechanism. Additionally, an ability has been added to the Arbitrum node software which allows the sequencer to call VerifyAttestation to check if a data root has been posted on Blobstream or not, before it sends the sequencer message (data pointer) to the underlying chain.

Next steps

In the next page, learn how to deploy an Arbitrum rollup devnet using Celestia as DA.

',34),l=[n];function s(h,c,d,m,b,u){return t(),a("div",null,l)}const g=e(o,[["render",s]]);export{f as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_arbitrum-integration.md.eea707b4.lean.js b/pr-1815/assets/how-to-guides_arbitrum-integration.md.6c060e19.lean.js similarity index 94% rename from pr-1815/assets/how-to-guides_arbitrum-integration.md.eea707b4.lean.js rename to pr-1815/assets/how-to-guides_arbitrum-integration.md.6c060e19.lean.js index 44745c203..e808d7899 100644 --- a/pr-1815/assets/how-to-guides_arbitrum-integration.md.eea707b4.lean.js +++ b/pr-1815/assets/how-to-guides_arbitrum-integration.md.6c060e19.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia-Arbitrum.png",f=JSON.parse('{"title":"Introduction to Arbitrum rollups with Celestia as DA","description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","frontmatter":{"description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","head":[["meta",{"property":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-integration.md","filePath":"how-to-guides/arbitrum-integration.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/arbitrum-integration.md"},n=i("",34),l=[n];function s(h,c,d,m,b,u){return t(),a("div",null,l)}const g=e(o,[["render",s]]);export{f as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia-Arbitrum.png",f=JSON.parse('{"title":"Introduction to Arbitrum rollups with Celestia as DA","description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","frontmatter":{"description":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism.","head":[["meta",{"property":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the integration of Arbitrum Nitro with Celestia, detailing the key features and benefits, including the Ethereum fallback mechanism."}]]},"headers":[],"relativePath":"how-to-guides/arbitrum-integration.md","filePath":"how-to-guides/arbitrum-integration.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/arbitrum-integration.md"},n=i("",34),l=[n];function s(h,c,d,m,b,u){return t(),a("div",null,l)}const g=e(o,[["render",s]]);export{f as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_blobstream-contracts.md.f87f3793.js b/pr-1815/assets/how-to-guides_blobstream-contracts.md.72c1a84f.js similarity index 99% rename from pr-1815/assets/how-to-guides_blobstream-contracts.md.f87f3793.js rename to pr-1815/assets/how-to-guides_blobstream-contracts.md.72c1a84f.js index 6b1939003..ef03a8e15 100644 --- a/pr-1815/assets/how-to-guides_blobstream-contracts.md.f87f3793.js +++ b/pr-1815/assets/how-to-guides_blobstream-contracts.md.72c1a84f.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const d=JSON.parse(`{"title":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","frontmatter":{"sidebar_label":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","prev":{"text":"Overview of Blobstream","link":"/how-to-guides/blobstream"},"head":[["meta",{"property":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's onchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-contracts.md","filePath":"how-to-guides/blobstream-contracts.md","lastUpdated":1732776394000}`),n={name:"how-to-guides/blobstream-contracts.md"},l=e(`

Integrate with Blobstream contracts

Getting started

Prerequisites

Make sure to have the following installed:

Installing Blobstream contracts

We will be using the IDAOracle interface to verify inclusion. So, we will install the Blobstream contracts repo as a dependency:

sh
forge install celestiaorg/blobstream-contracts --no-commit
forge install celestiaorg/blobstream-contracts --no-commit

Make sure that the directory you're running this command from is an initialized git repository. If not, just initialize the repo using:

sh
git init
git init

Note that the minimum Solidity compiler version for using the Blobstream contracts is 0.8.19.

Example usage

Example minimal Solidity contract for a stub ZK rollup that leverages the BlobstreamX.sol contract to check that data has been posted to Celestia:

solidity
// SPDX-License-Identifier: Apache-2.0
+import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const d=JSON.parse(`{"title":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","frontmatter":{"sidebar_label":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","prev":{"text":"Overview of Blobstream","link":"/how-to-guides/blobstream"},"head":[["meta",{"property":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's onchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-contracts.md","filePath":"how-to-guides/blobstream-contracts.md","lastUpdated":1732777479000}`),n={name:"how-to-guides/blobstream-contracts.md"},l=e(`

Integrate with Blobstream contracts

Getting started

Prerequisites

Make sure to have the following installed:

Installing Blobstream contracts

We will be using the IDAOracle interface to verify inclusion. So, we will install the Blobstream contracts repo as a dependency:

sh
forge install celestiaorg/blobstream-contracts --no-commit
forge install celestiaorg/blobstream-contracts --no-commit

Make sure that the directory you're running this command from is an initialized git repository. If not, just initialize the repo using:

sh
git init
git init

Note that the minimum Solidity compiler version for using the Blobstream contracts is 0.8.19.

Example usage

Example minimal Solidity contract for a stub ZK rollup that leverages the BlobstreamX.sol contract to check that data has been posted to Celestia:

solidity
// SPDX-License-Identifier: Apache-2.0
 pragma solidity ^0.8.19;
 
 import "blobstream-contracts/IDAOracle.sol";
diff --git a/pr-1815/assets/how-to-guides_blobstream-contracts.md.f87f3793.lean.js b/pr-1815/assets/how-to-guides_blobstream-contracts.md.72c1a84f.lean.js
similarity index 93%
rename from pr-1815/assets/how-to-guides_blobstream-contracts.md.f87f3793.lean.js
rename to pr-1815/assets/how-to-guides_blobstream-contracts.md.72c1a84f.lean.js
index 71ca7a0b8..d514f67ba 100644
--- a/pr-1815/assets/how-to-guides_blobstream-contracts.md.f87f3793.lean.js
+++ b/pr-1815/assets/how-to-guides_blobstream-contracts.md.72c1a84f.lean.js
@@ -1 +1 @@
-import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const d=JSON.parse(`{"title":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","frontmatter":{"sidebar_label":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","prev":{"text":"Overview of Blobstream","link":"/how-to-guides/blobstream"},"head":[["meta",{"property":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's onchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-contracts.md","filePath":"how-to-guides/blobstream-contracts.md","lastUpdated":1732776394000}`),n={name:"how-to-guides/blobstream-contracts.md"},l=e("",27),t=[l];function r(p,c,i,y,E,h){return a(),o("div",null,t)}const u=s(n,[["render",r]]);export{d as __pageData,u as default};
+import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const d=JSON.parse(`{"title":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","frontmatter":{"sidebar_label":"Integrate with Blobstream contracts","description":"Learn how to integrate your L2's onchain logic with Blobstream","prev":{"text":"Overview of Blobstream","link":"/how-to-guides/blobstream"},"head":[["meta",{"property":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's onchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-contracts.md","filePath":"how-to-guides/blobstream-contracts.md","lastUpdated":1732777479000}`),n={name:"how-to-guides/blobstream-contracts.md"},l=e("",27),t=[l];function r(p,c,i,y,E,h){return a(),o("div",null,t)}const u=s(n,[["render",r]]);export{d as __pageData,u as default};
diff --git a/pr-1815/assets/how-to-guides_blobstream-offchain.md.a1784f7d.js b/pr-1815/assets/how-to-guides_blobstream-offchain.md.b3a72b46.js
similarity index 99%
rename from pr-1815/assets/how-to-guides_blobstream-offchain.md.a1784f7d.js
rename to pr-1815/assets/how-to-guides_blobstream-offchain.md.b3a72b46.js
index 1f95df72e..c03723486 100644
--- a/pr-1815/assets/how-to-guides_blobstream-offchain.md.a1784f7d.js
+++ b/pr-1815/assets/how-to-guides_blobstream-offchain.md.b3a72b46.js
@@ -1,4 +1,4 @@
-import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse(`{"title":"Integrate with Blobstream client","description":"Learn how to integrate your L2's offchain logic with Blobstream","frontmatter":{"description":"Learn how to integrate your L2's offchain logic with Blobstream","head":[["meta",{"property":"og:title","content":"Integrate with Blobstream client | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's offchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-offchain.md","filePath":"how-to-guides/blobstream-offchain.md","lastUpdated":1732776394000}`),e={name:"how-to-guides/blobstream-offchain.md"},o=l(`

Integrate with Blobstream client

Blobstream demo rollup

Rollups can use Blobstream for DA by posting their data to Celestia and then proving that it was posted on Ethereum. This is done identically to how any rollup or user would post data to Celestia. Then, a zero-knowledge proof that Celestia validators have come to consensus on Celestia block headers is generated, and subsequently relayed to Ethereum to the Blobstream smart contract.

This demo rollup will outline (the outline is not an implementation! Please do not expect to copy and paste this code 🙂) a very simple Blobstream rollup to illustrate at a high level what this could look like.

Defining a chain

The first step to starting a new chain is to define the structure of the commitments that each block consists of.

go
type Block struct {
+import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse(`{"title":"Integrate with Blobstream client","description":"Learn how to integrate your L2's offchain logic with Blobstream","frontmatter":{"description":"Learn how to integrate your L2's offchain logic with Blobstream","head":[["meta",{"property":"og:title","content":"Integrate with Blobstream client | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's offchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-offchain.md","filePath":"how-to-guides/blobstream-offchain.md","lastUpdated":1732777479000}`),e={name:"how-to-guides/blobstream-offchain.md"},o=l(`

Integrate with Blobstream client

Blobstream demo rollup

Rollups can use Blobstream for DA by posting their data to Celestia and then proving that it was posted on Ethereum. This is done identically to how any rollup or user would post data to Celestia. Then, a zero-knowledge proof that Celestia validators have come to consensus on Celestia block headers is generated, and subsequently relayed to Ethereum to the Blobstream smart contract.

This demo rollup will outline (the outline is not an implementation! Please do not expect to copy and paste this code 🙂) a very simple Blobstream rollup to illustrate at a high level what this could look like.

Defining a chain

The first step to starting a new chain is to define the structure of the commitments that each block consists of.

go
type Block struct {
     // Data is the data of a block that is submitted to Celestia.
     Data \`json:"Data"\`
     // Header is the set of commitments over a block that is submitted to
diff --git a/pr-1815/assets/how-to-guides_blobstream-offchain.md.a1784f7d.lean.js b/pr-1815/assets/how-to-guides_blobstream-offchain.md.b3a72b46.lean.js
similarity index 92%
rename from pr-1815/assets/how-to-guides_blobstream-offchain.md.a1784f7d.lean.js
rename to pr-1815/assets/how-to-guides_blobstream-offchain.md.b3a72b46.lean.js
index 778417d24..f03b68dba 100644
--- a/pr-1815/assets/how-to-guides_blobstream-offchain.md.a1784f7d.lean.js
+++ b/pr-1815/assets/how-to-guides_blobstream-offchain.md.b3a72b46.lean.js
@@ -1 +1 @@
-import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse(`{"title":"Integrate with Blobstream client","description":"Learn how to integrate your L2's offchain logic with Blobstream","frontmatter":{"description":"Learn how to integrate your L2's offchain logic with Blobstream","head":[["meta",{"property":"og:title","content":"Integrate with Blobstream client | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's offchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-offchain.md","filePath":"how-to-guides/blobstream-offchain.md","lastUpdated":1732776394000}`),e={name:"how-to-guides/blobstream-offchain.md"},o=l("",42),p=[o];function t(r,c,i,E,y,h){return a(),n("div",null,p)}const b=s(e,[["render",t]]);export{u as __pageData,b as default};
+import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse(`{"title":"Integrate with Blobstream client","description":"Learn how to integrate your L2's offchain logic with Blobstream","frontmatter":{"description":"Learn how to integrate your L2's offchain logic with Blobstream","head":[["meta",{"property":"og:title","content":"Integrate with Blobstream client | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2's offchain logic with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-offchain.md","filePath":"how-to-guides/blobstream-offchain.md","lastUpdated":1732777479000}`),e={name:"how-to-guides/blobstream-offchain.md"},o=l("",42),p=[o];function t(r,c,i,E,y,h){return a(),n("div",null,p)}const b=s(e,[["render",t]]);export{u as __pageData,b as default};
diff --git a/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.4afa5c35.js b/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.b36c2659.js
similarity index 99%
rename from pr-1815/assets/how-to-guides_blobstream-proof-queries.md.4afa5c35.js
rename to pr-1815/assets/how-to-guides_blobstream-proof-queries.md.b36c2659.js
index ab156a173..ca8d14d9d 100644
--- a/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.4afa5c35.js
+++ b/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.b36c2659.js
@@ -1,4 +1,4 @@
-import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1815/img/blobstream/blobstream-commitment-diagram.png",h=JSON.parse('{"title":"Blobstream proofs queries","description":"Learn how to query the inclusion proofs used in Blobstream","frontmatter":{"description":"Learn how to query the inclusion proofs used in Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream proofs queries | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to query the inclusion proofs used in Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-proof-queries.md","filePath":"how-to-guides/blobstream-proof-queries.md","lastUpdated":1732776394000}'),e={name:"how-to-guides/blobstream-proof-queries.md"},t=l(`

Blobstream proofs queries

Prerequisites

  • Access to a Celestia consensus node RPC endpoint (or full node). The node doesn't need to be a validating node in order for the proofs to be queried. A full node is enough.

For golang snippets, the tendermint RPC client, referred to as trpc, will be used for the queries. It can be initialized using:

go
    trpc, err := http.New("<rpc_endpoint>", "/websocket")
+import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1815/img/blobstream/blobstream-commitment-diagram.png",h=JSON.parse('{"title":"Blobstream proofs queries","description":"Learn how to query the inclusion proofs used in Blobstream","frontmatter":{"description":"Learn how to query the inclusion proofs used in Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream proofs queries | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to query the inclusion proofs used in Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-proof-queries.md","filePath":"how-to-guides/blobstream-proof-queries.md","lastUpdated":1732777479000}'),e={name:"how-to-guides/blobstream-proof-queries.md"},t=l(`

Blobstream proofs queries

Prerequisites

  • Access to a Celestia consensus node RPC endpoint (or full node). The node doesn't need to be a validating node in order for the proofs to be queried. A full node is enough.

For golang snippets, the tendermint RPC client, referred to as trpc, will be used for the queries. It can be initialized using:

go
    trpc, err := http.New("<rpc_endpoint>", "/websocket")
 	if err != nil {
 		...
 	}
@@ -24,7 +24,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o=
 		if err != nil {
 			...
 		}
-	}(trpc)

The <rpc_endpoint> can be retrieved from Mainnet Beta for and Mocha for the Mocha testnet.

In case the reader wants to interact with an on-chain contract that can be used to verify that data was posted to Celestia, the bindings of that contract are needed.

For Blobstream, the golang bindings can be found in the following links:

text
https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
text
https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go
https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go

For other languages, the corresponding smart contract bindings should be generated. Refer to abigen for more information.

Overview of the proof queries

To prove the inclusion of PayForBlobs (PFB) transactions, blobs or shares, committed to in a Celestia block, we use the Celestia consensus node's RPC to query for proofs that can be verified in a rollup settlement contract via Blobstream. In fact, when a PFB transaction is included in a block, it gets separated into a PFB transaction (without the blob), and the actual data blob that it carries. These two are split into shares, which are the low level constructs of a Celestia block, and saved to the corresponding Celestia block. Learn more about shares in the shares specs.

The two diagrams below summarize how a single share, which can contain a PFB transaction, or a part of the rollup data that was posted using a PFB, is committed to in Blobstream.

The share is highlighted in green. R0, R1 etc, represent the respective row and column roots, the blue and pink gradients are erasure encoded data. More details on the square layout can be found in the data square layout and data structures portion of the specs.

The Celestia square

Square

The commitment scheme

Blobstream Commitment Diagram

So to prove inclusion of a share to a Celestia block, we use Blobstream as a source of truth. In a nutshell, Blobstream attests to the data posted to Celestia in the zk-Blobstream contract via verifying a zk-proof of the headers of a batch of Celestia blocks. Then, it keeps reference of that batch of blocks using the merkleized commitment of their (dataRoot, height) resulting in a data root tuple root. Check the above diagram which shows:

  • 0: those are the shares, that when unified, contain the PFB or the rollup data blob.
  • 1: the row and column roots are the namespace merkle tree roots over the shares. More information on the NMT in the NMT specs. These commit to the rows and columns containing the above shares.
  • 2: the data roots: which are the binary merkle tree commitment over the row and column roots. This means that if you can prove that a share is part of a row, using a namespace merkle proof. Then prove that this row is committed to by the data root. Then you can be sure that that share was published to the corresponding block.
  • 3: in order to batch multiple blocks into the same commitment, we create a commitment over the (dataRoot, height) tuple for a batch of blocks, which results in a data root tuple root. It's this commitment that gets stored in the Blobstream smart contract.

So, if we're able to prove:

  • That a share is part of a row, then that row is committed to by a data root.
  • Then, prove that that data root along with its height is committed to by the data root tuple root, which gets saved to the Blobstream contract.

We can be sure that that share was committed to in the corresponding Celestia block.

In this document, we will provide details on how to query the above proofs, and how to adapt them to be sent to a rollup contract for verification.

Hands-on demonstration

This part will provide the details of proof generation, and the way to make the results of the proofs queries ready to be consumed by the target rollup contract.

NOTE

For the go client snippets, make sure to have the following replaces in your go.mod:

go
// go.mod
+	}(trpc)

The <rpc_endpoint> can be retrieved from Mainnet Beta for and Mocha for the Mocha testnet.

In case the reader wants to interact with an on-chain contract that can be used to verify that data was posted to Celestia, the bindings of that contract are needed.

For Blobstream, the golang bindings can be found in the following links:

text
https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
text
https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go
https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go

For other languages, the corresponding smart contract bindings should be generated. Refer to abigen for more information.

Overview of the proof queries

To prove the inclusion of PayForBlobs (PFB) transactions, blobs or shares, committed to in a Celestia block, we use the Celestia consensus node's RPC to query for proofs that can be verified in a rollup settlement contract via Blobstream. In fact, when a PFB transaction is included in a block, it gets separated into a PFB transaction (without the blob), and the actual data blob that it carries. These two are split into shares, which are the low level constructs of a Celestia block, and saved to the corresponding Celestia block. Learn more about shares in the shares specs.

The two diagrams below summarize how a single share, which can contain a PFB transaction, or a part of the rollup data that was posted using a PFB, is committed to in Blobstream.

The share is highlighted in green. R0, R1 etc, represent the respective row and column roots, the blue and pink gradients are erasure encoded data. More details on the square layout can be found in the data square layout and data structures portion of the specs.

The Celestia square

Square

The commitment scheme

Blobstream Commitment Diagram

So to prove inclusion of a share to a Celestia block, we use Blobstream as a source of truth. In a nutshell, Blobstream attests to the data posted to Celestia in the zk-Blobstream contract via verifying a zk-proof of the headers of a batch of Celestia blocks. Then, it keeps reference of that batch of blocks using the merkleized commitment of their (dataRoot, height) resulting in a data root tuple root. Check the above diagram which shows:

  • 0: those are the shares, that when unified, contain the PFB or the rollup data blob.
  • 1: the row and column roots are the namespace merkle tree roots over the shares. More information on the NMT in the NMT specs. These commit to the rows and columns containing the above shares.
  • 2: the data roots: which are the binary merkle tree commitment over the row and column roots. This means that if you can prove that a share is part of a row, using a namespace merkle proof. Then prove that this row is committed to by the data root. Then you can be sure that that share was published to the corresponding block.
  • 3: in order to batch multiple blocks into the same commitment, we create a commitment over the (dataRoot, height) tuple for a batch of blocks, which results in a data root tuple root. It's this commitment that gets stored in the Blobstream smart contract.

So, if we're able to prove:

  • That a share is part of a row, then that row is committed to by a data root.
  • Then, prove that that data root along with its height is committed to by the data root tuple root, which gets saved to the Blobstream contract.

We can be sure that that share was committed to in the corresponding Celestia block.

In this document, we will provide details on how to query the above proofs, and how to adapt them to be sent to a rollup contract for verification.

Hands-on demonstration

This part will provide the details of proof generation, and the way to make the results of the proofs queries ready to be consumed by the target rollup contract.

NOTE

For the go client snippets, make sure to have the following replaces in your go.mod:

go
// go.mod
     github.com/cosmos/cosmos-sdk => github.com/celestiaorg/cosmos-sdk v1.18.3-sdk-v0.46.14
     github.com/gogo/protobuf => github.com/regen-network/protobuf v1.3.3-alpha.regen.1
     github.com/syndtr/goleveldb => github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7
@@ -122,7 +122,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o=
 		os.Exit(1)
 	}
 	fmt.Println(dcProof.Proof.String())
-}

Full example of proving that a Celestia block was committed to by Blobstream contract

go
package main
+}

Full example of proving that a Celestia block was committed to by Blobstream contract

go
package main
 
 import (
 	"context"
@@ -1122,7 +1122,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o=
 			NumLeaves: big.NewInt(dataRootInclusionProof.Total),
 		},
 	}
-}

With the nonce being the attestation nonce, which can be retrieved using Blobstream contract events. Check below for an example. And height being the Celestia Block height that contains the rollup data, along with the blockDataRoot being the data root of the block height. Finally, dataRootInclusionProof is the Celestia block data root inclusion proof to the data root tuple root that was queried at the beginning of this page.

If the dataRoot or the tupleRootNonce is unknown during the verification:

  • dataRoot: can be queried using the /block?height=15 query (15 in this example endpoint), and taking the data_hash field from the response.
  • tupleRootNonce: can be retried via querying the data commitment stored events from the Blobstream contract and looking for the nonce attesting to the corresponding data.

Querying the proof's tupleRootNonce

go
	// get the nonce corresponding to the block height that contains the PayForBlob transaction
+}

With the nonce being the attestation nonce, which can be retrieved using Blobstream contract events. Check below for an example. And height being the Celestia Block height that contains the rollup data, along with the blockDataRoot being the data root of the block height. Finally, dataRootInclusionProof is the Celestia block data root inclusion proof to the data root tuple root that was queried at the beginning of this page.

If the dataRoot or the tupleRootNonce is unknown during the verification:

  • dataRoot: can be queried using the /block?height=15 query (15 in this example endpoint), and taking the data_hash field from the response.
  • tupleRootNonce: can be retried via querying the data commitment stored events from the Blobstream contract and looking for the nonce attesting to the corresponding data.

Querying the proof's tupleRootNonce

go
	// get the nonce corresponding to the block height that contains the PayForBlob transaction
 	// since BlobstreamX emits events when new batches are submitted, we will query the events
 	// and look for the range committing to the blob
 	// first, connect to an EVM RPC endpoint
@@ -1246,7 +1246,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o=
 import {
     sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
 } 
-// and use the \`BlobstreamDataCommitmentStored\` event instead.

Listening for new data commitments

For listening for new data commitment stored events, sequencers can use the WatchDataCommitmentStored as follows:

go
    ethClient, err := ethclient.Dial("evm_rpc")
+// and use the \`BlobstreamDataCommitmentStored\` event instead.

Listening for new data commitments

For listening for new data commitment stored events, sequencers can use the WatchDataCommitmentStored as follows:

go
    ethClient, err := ethclient.Dial("evm_rpc")
     if err != nil {
 	    return err
     }
@@ -1364,7 +1364,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o=
         // (4) verify invalid state transition
         // (5) effects
     }
-}

Then, you can submit the fraud proof using golang as follows:

go
package main
+}

Then, you can submit the fraud proof using golang as follows:

go
package main
 
 import (
 	"context"
diff --git a/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.4afa5c35.lean.js b/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.b36c2659.lean.js
similarity index 93%
rename from pr-1815/assets/how-to-guides_blobstream-proof-queries.md.4afa5c35.lean.js
rename to pr-1815/assets/how-to-guides_blobstream-proof-queries.md.b36c2659.lean.js
index 81d3109ae..e92e64424 100644
--- a/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.4afa5c35.lean.js
+++ b/pr-1815/assets/how-to-guides_blobstream-proof-queries.md.b36c2659.lean.js
@@ -1 +1 @@
-import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1815/img/blobstream/blobstream-commitment-diagram.png",h=JSON.parse('{"title":"Blobstream proofs queries","description":"Learn how to query the inclusion proofs used in Blobstream","frontmatter":{"description":"Learn how to query the inclusion proofs used in Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream proofs queries | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to query the inclusion proofs used in Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-proof-queries.md","filePath":"how-to-guides/blobstream-proof-queries.md","lastUpdated":1732776394000}'),e={name:"how-to-guides/blobstream-proof-queries.md"},t=l("",158),c=[t];function r(E,y,i,A,F,d){return n(),a("div",null,c)}const m=s(e,[["render",r]]);export{h as __pageData,m as default};
+import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1815/img/blobstream/blobstream-commitment-diagram.png",h=JSON.parse('{"title":"Blobstream proofs queries","description":"Learn how to query the inclusion proofs used in Blobstream","frontmatter":{"description":"Learn how to query the inclusion proofs used in Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream proofs queries | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to query the inclusion proofs used in Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream-proof-queries.md","filePath":"how-to-guides/blobstream-proof-queries.md","lastUpdated":1732777479000}'),e={name:"how-to-guides/blobstream-proof-queries.md"},t=l("",158),c=[t];function r(E,y,i,A,F,d){return n(),a("div",null,c)}const m=s(e,[["render",r]]);export{h as __pageData,m as default};
diff --git a/pr-1815/assets/how-to-guides_blobstream-rollups.md.dc1ba5fc.js b/pr-1815/assets/how-to-guides_blobstream-rollups.md.5bb93b32.js
similarity index 99%
rename from pr-1815/assets/how-to-guides_blobstream-rollups.md.dc1ba5fc.js
rename to pr-1815/assets/how-to-guides_blobstream-rollups.md.5bb93b32.js
index ab5c37bf1..806a03ce1 100644
--- a/pr-1815/assets/how-to-guides_blobstream-rollups.md.dc1ba5fc.js
+++ b/pr-1815/assets/how-to-guides_blobstream-rollups.md.5bb93b32.js
@@ -1,3 +1,3 @@
-import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction to Blobstream rollups","description":"Learn how to build rollups that use Blobstream.","frontmatter":{"description":"Learn how to build rollups that use Blobstream.","prev":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/how-to-guides/submit-data"},"head":[["meta",{"property":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to build rollups that use Blobstream."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-rollups.md","filePath":"how-to-guides/blobstream-rollups.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/blobstream-rollups.md"},r=a(`

Introduction to Blobstream rollups

Blobstream is the first data availability solution for EVM chains that securely scales with the number of users. It allows rollups to post their data on Celestia while proving their availability in the rollup settlement contract.

This document will outline a few ways to build optimistic or zk-rollups that post their data to Celestia and use Blobstream to prove that data's availability.

Concepts

This section will go over two constructs that can be used in building Blobstream rollups. Each with its pros and cons and the rollup developer can choose which one suits their needs better.

Note: Only the sequence of spans method can be used currently to build Blobstream rollups. The blob share commitment way still requires some tooling that will be built in the upcoming months.

Blob share commitment

The blob share commitment is a commitment over the data contained in the MsgPayForBlobs transaction. This commitment allows proving that the corresponding data exists on Celestia efficiently.

Blob share commitment: Proof details

To prove that the data corresponding to a blob share commitment was posted to Celestia using Blobstream, the following proofs need to be verified:

  1. share inclusion proof to the blob share commitment: meaning creating two merkle proofs:
    1. share merkle proof up to the subtree root corresponding to that share
    2. subtree root merkle proof to the blob share commitment
  2. blob share commitment inclusion proof to the data root tuple root: meaning four merkle proofs:
    1. subtree roots merkle proofs to the blob share commitment: to make sure the subtree roots are valid
    2. subtree roots merkle proofs up to the row roots: to prove that the subtree roots belong to a set of rows in the Celestia block
    3. row roots proofs to the data root: to prove that those rows belong to the Celestia Block
    4. data root tuple proof to the data root tuple: to prove that the Celestia block referenced by its height and data root, was committed to by Blobstream.

More details on the blob share commitment inclusion proof can be found in the commitment scheme docs and also the data square layout.

If all of these proofs are valid, then you successfully managed to prove that the data corresponding to that blob share commitment has been posted to Celestia.

NOTE

Generating/verifying blob share commitment proofs is still not supported. It still needs tooling to generate the proofs on the node side, and verifying them on the Solidity side which will be built in the upcoming months.

Blob share commitment: Compact proofs

There is a way to have compact proofs, when using blob share commitments, unlike the ones defined above; that allow less costly inclusion proofs. These require the ability to parse the protobuf encoded PFBs.

In fact, if the rollup project has a way to parse the protobuf encoded PFB, either in a smart contract or a zk-circuit, they will be able to create compact proofs of the rollup data.

These proofs will work as follows:

  • Parsing the PFB and taking out the blob share commitment
  • Comparing the PFB commitment to the one saved in the rollup contract
  • Proving inclusion of the PFB to the data root tuple root. This will be a compact proof since we will only be proving two shares regardless of the size of the rollup data.

More details on compact proofs can be found in ADR-011.

Blob share commitment: Pros

The pros of referencing rollup data using a blob share commitment:

  • Using the same commitment that exists on the PFB, without having to find another way of referencing the rollup data.
  • If the team has access to protobuf parsing, it allows for compact proof, but the parsing costs need to be investigated.

Blob share commitment: Cons

  • Large/expensive proofs in the case of having no way to parse the protobuf PFB encoding.
  • In the optimistic rollups construction, defined below, this requires waiting for the Celestia block to be committed to by Blobstream before saving updating the settlement contract. This might require waiting for a few hours, depending on the batches size on each chain, to finally submit the rollup update.

Given these limitations, an alternative design will be discussed in the next section.

Sequence of spans

An alternative way of referencing rollup data in the rollup settlement contract is using a sequence of spans.

A sequence of spans is a data pointer that allows pointing to the rollup data inside a Celestia square using its location inside the square. It can be defined using the following information:

  • height: The height of the Celestia block containing the rollup data.
  • startIndex: The index of the first share containing the rollup data.
  • dataLen: The number of shares containing the rollup data.

The startIndex and the dataLen can be queried from Celestia after the corresponding transaction gets included in a block and committed to the chain. An example of how to query them can be found in the verify command. The TxShareRange returns the start and end share of the data referenced by a transaction hash.

NOTE

If the rollup data is submitted in multiple blocks, the above sequence of spans can be generalized to include multiple blocks. For simplicity, we will stick with the data only submitted to a single Celestia block.

Sequence of spans: Proof details

Using sequence of spans is different from using the blob share commitment because we're referencing a location in the square, and not actual data commitment. So, the proof types and their generation are different.

Sequence of spans: Proving unavailable data

By construction, if the sequence of spans refers to a certain location in the square, that location is the data. This location can be in the reserved namespaces, the parity bytes, etc. What matters is that it's part of the square. So to prove that the sequence of spans is invalid, i.e., refers to data that is not available on Celestia, it is necessary and sufficient to show that the sequence of spans doesn't belong to the Celestia block, i.e., the span is out of bounds.

We could create this proof via generating a binary Merkle proof of any row/column to the Celestia data root. This proof will provide the total which is the number of rows/columns in the extended data square. This can be used to calculate the square size. The computeSquareSizeFromRowProof method in the DAVerifier library allows calculating the square size from a row proof or a share proof.

Then, we will use that information to check if the provided share index, in the header, is out of the square size bounds. In order words, we will check if the startIndex and the startIndex + dataLen are included in the range [0, 4*square_size].

NOTE

The square size is the number of rows of the original square.

For the data root, we will use a binary Merkle proof to prove its inclusion in a data root tuple root that was committed to by the Blobstream smart contract. More on this in the data root inclusion proofs section.

Sequence of spans: Proving inclusion of some data

The difference between using a blob share commitment and a sequence of spans is that when using a blob share commitment, an extra merkle proof is needed to prove inclusion of the share to the blob share commitment. However, in the case of a sequence of spans, only the usual inclusion proof of a share to the data root tuple root is needed. The inclusion of the share to the sequence of spans is gotten using the same proof.

In fact, proving that a share is part of the sequence of spans, i.e., part of the rollup data is done as follows:

  1. Prove that the data root tuple is committed to by the Blobstream smart contract:

    To prove the data root is committed to by the Blobstream smart contract, we will need to provide a Merkle proof of the data root tuple to a data root tuple root. This can be created using the data_root_inclusion_proof query. More on this can be found in the data root inclusion proofs documentation.

  2. Verify inclusion proof of the data to Celestia data root:

    To prove that the data is part of the data root, we will need to provide two proofs: a namespace Merkle proof of the data to a row root. This could be done via proving the shares that contain the data to the row root using a namespace Merkle proof. And, a binary Merkle proof of the row root to the data root.

    These proofs can be generated using the ProveShares query.

    More details on these proofs can be found in the transaction inclusion proof documentation.

  3. Prove that the data is in the sequence spans:

    To prove that the data is part of the rollup sequence of spans, we take the authenticated share proofs in step (2) and use the shares begin/end key to define the shares' positions in the row.

    Then, we use the row proof to get the row index in the extended Celestia square and get the index of the share in row major order:

    solidity
    uint256 shareIndexInRow = shareProof.shareProofs[0].beginKey;
    +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction to Blobstream rollups","description":"Learn how to build rollups that use Blobstream.","frontmatter":{"description":"Learn how to build rollups that use Blobstream.","prev":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/how-to-guides/submit-data"},"head":[["meta",{"property":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to build rollups that use Blobstream."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-rollups.md","filePath":"how-to-guides/blobstream-rollups.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/blobstream-rollups.md"},r=a(`

    Introduction to Blobstream rollups

    Blobstream is the first data availability solution for EVM chains that securely scales with the number of users. It allows rollups to post their data on Celestia while proving their availability in the rollup settlement contract.

    This document will outline a few ways to build optimistic or zk-rollups that post their data to Celestia and use Blobstream to prove that data's availability.

    Concepts

    This section will go over two constructs that can be used in building Blobstream rollups. Each with its pros and cons and the rollup developer can choose which one suits their needs better.

    Note: Only the sequence of spans method can be used currently to build Blobstream rollups. The blob share commitment way still requires some tooling that will be built in the upcoming months.

    Blob share commitment

    The blob share commitment is a commitment over the data contained in the MsgPayForBlobs transaction. This commitment allows proving that the corresponding data exists on Celestia efficiently.

    Blob share commitment: Proof details

    To prove that the data corresponding to a blob share commitment was posted to Celestia using Blobstream, the following proofs need to be verified:

    1. share inclusion proof to the blob share commitment: meaning creating two merkle proofs:
      1. share merkle proof up to the subtree root corresponding to that share
      2. subtree root merkle proof to the blob share commitment
    2. blob share commitment inclusion proof to the data root tuple root: meaning four merkle proofs:
      1. subtree roots merkle proofs to the blob share commitment: to make sure the subtree roots are valid
      2. subtree roots merkle proofs up to the row roots: to prove that the subtree roots belong to a set of rows in the Celestia block
      3. row roots proofs to the data root: to prove that those rows belong to the Celestia Block
      4. data root tuple proof to the data root tuple: to prove that the Celestia block referenced by its height and data root, was committed to by Blobstream.

    More details on the blob share commitment inclusion proof can be found in the commitment scheme docs and also the data square layout.

    If all of these proofs are valid, then you successfully managed to prove that the data corresponding to that blob share commitment has been posted to Celestia.

    NOTE

    Generating/verifying blob share commitment proofs is still not supported. It still needs tooling to generate the proofs on the node side, and verifying them on the Solidity side which will be built in the upcoming months.

    Blob share commitment: Compact proofs

    There is a way to have compact proofs, when using blob share commitments, unlike the ones defined above; that allow less costly inclusion proofs. These require the ability to parse the protobuf encoded PFBs.

    In fact, if the rollup project has a way to parse the protobuf encoded PFB, either in a smart contract or a zk-circuit, they will be able to create compact proofs of the rollup data.

    These proofs will work as follows:

    • Parsing the PFB and taking out the blob share commitment
    • Comparing the PFB commitment to the one saved in the rollup contract
    • Proving inclusion of the PFB to the data root tuple root. This will be a compact proof since we will only be proving two shares regardless of the size of the rollup data.

    More details on compact proofs can be found in ADR-011.

    Blob share commitment: Pros

    The pros of referencing rollup data using a blob share commitment:

    • Using the same commitment that exists on the PFB, without having to find another way of referencing the rollup data.
    • If the team has access to protobuf parsing, it allows for compact proof, but the parsing costs need to be investigated.

    Blob share commitment: Cons

    • Large/expensive proofs in the case of having no way to parse the protobuf PFB encoding.
    • In the optimistic rollups construction, defined below, this requires waiting for the Celestia block to be committed to by Blobstream before saving updating the settlement contract. This might require waiting for a few hours, depending on the batches size on each chain, to finally submit the rollup update.

    Given these limitations, an alternative design will be discussed in the next section.

    Sequence of spans

    An alternative way of referencing rollup data in the rollup settlement contract is using a sequence of spans.

    A sequence of spans is a data pointer that allows pointing to the rollup data inside a Celestia square using its location inside the square. It can be defined using the following information:

    • height: The height of the Celestia block containing the rollup data.
    • startIndex: The index of the first share containing the rollup data.
    • dataLen: The number of shares containing the rollup data.

    The startIndex and the dataLen can be queried from Celestia after the corresponding transaction gets included in a block and committed to the chain. An example of how to query them can be found in the verify command. The TxShareRange returns the start and end share of the data referenced by a transaction hash.

    NOTE

    If the rollup data is submitted in multiple blocks, the above sequence of spans can be generalized to include multiple blocks. For simplicity, we will stick with the data only submitted to a single Celestia block.

    Sequence of spans: Proof details

    Using sequence of spans is different from using the blob share commitment because we're referencing a location in the square, and not actual data commitment. So, the proof types and their generation are different.

    Sequence of spans: Proving unavailable data

    By construction, if the sequence of spans refers to a certain location in the square, that location is the data. This location can be in the reserved namespaces, the parity bytes, etc. What matters is that it's part of the square. So to prove that the sequence of spans is invalid, i.e., refers to data that is not available on Celestia, it is necessary and sufficient to show that the sequence of spans doesn't belong to the Celestia block, i.e., the span is out of bounds.

    We could create this proof via generating a binary Merkle proof of any row/column to the Celestia data root. This proof will provide the total which is the number of rows/columns in the extended data square. This can be used to calculate the square size. The computeSquareSizeFromRowProof method in the DAVerifier library allows calculating the square size from a row proof or a share proof.

    Then, we will use that information to check if the provided share index, in the header, is out of the square size bounds. In order words, we will check if the startIndex and the startIndex + dataLen are included in the range [0, 4*square_size].

    NOTE

    The square size is the number of rows of the original square.

    For the data root, we will use a binary Merkle proof to prove its inclusion in a data root tuple root that was committed to by the Blobstream smart contract. More on this in the data root inclusion proofs section.

    Sequence of spans: Proving inclusion of some data

    The difference between using a blob share commitment and a sequence of spans is that when using a blob share commitment, an extra merkle proof is needed to prove inclusion of the share to the blob share commitment. However, in the case of a sequence of spans, only the usual inclusion proof of a share to the data root tuple root is needed. The inclusion of the share to the sequence of spans is gotten using the same proof.

    In fact, proving that a share is part of the sequence of spans, i.e., part of the rollup data is done as follows:

    1. Prove that the data root tuple is committed to by the Blobstream smart contract:

      To prove the data root is committed to by the Blobstream smart contract, we will need to provide a Merkle proof of the data root tuple to a data root tuple root. This can be created using the data_root_inclusion_proof query. More on this can be found in the data root inclusion proofs documentation.

    2. Verify inclusion proof of the data to Celestia data root:

      To prove that the data is part of the data root, we will need to provide two proofs: a namespace Merkle proof of the data to a row root. This could be done via proving the shares that contain the data to the row root using a namespace Merkle proof. And, a binary Merkle proof of the row root to the data root.

      These proofs can be generated using the ProveShares query.

      More details on these proofs can be found in the transaction inclusion proof documentation.

    3. Prove that the data is in the sequence spans:

      To prove that the data is part of the rollup sequence of spans, we take the authenticated share proofs in step (2) and use the shares begin/end key to define the shares' positions in the row.

      Then, we use the row proof to get the row index in the extended Celestia square and get the index of the share in row major order:

      solidity
      uint256 shareIndexInRow = shareProof.shareProofs[0].beginKey;
       uint256 shareIndexInRowMajorOrder = shareIndexInRow + shareProof.rowProofs[0].numLeaves * shareProof.rowProofs[0].key;
      uint256 shareIndexInRow = shareProof.shareProofs[0].beginKey;
       uint256 shareIndexInRowMajorOrder = shareIndexInRow + shareProof.rowProofs[0].numLeaves * shareProof.rowProofs[0].key;

    Finally, we can compare the computed index with the sequence of spans, and be sure that the data/shares is part of the rollup data.

    Sequence of spans: Pros

    • Using a sequence of spans instead of the blob share commitment allows for simpler proofs

    Sequence of spans: Cons

    None

    Optimistic rollups

    One type of rollups that can be built with Blobstream is optimistic rollups. An optimistic rollup is a rollup that commits optimistically to a set of blocks, and allows the other parties to verify that the blocks are valid, and if they're not, they can create fraud proofs to signal that.

    Celestia allows optimistic rollups to post their data on its DA layer, and to prove that the data is available using Blobstream.

    To build an optimistic rollup that uses Celestia as a DA layer, the following constructions can be inspired by.

    Optimistic rollups that use a sequence of spans

    Optimistic rollups can post their data in Celestia, then in the rollup settlement contract, they can reference optimistically that data using a sequence of spans. Then, rollup full nodes can verify if that data is valid. If not, they can trigger a fraud proof.

    When using a sequence of spans, triggering the data availability fraud proofs, which are different from the state transitions fraud proofs (left for the rollup to define), goes back to the following cases:

    Optimistic rollups that use a sequence of spans: Pros

    • Not needing to verify anything at the moment of submitting the commitments to the rollup settlement contracts
    • The fraud proofs are simple and can be reduced to a single share: if, for example, a single transaction in the rollup data that was posted to Celestia is faulty, only the shares containing that transaction, which can be as minimal as a single share, need to be proven on chain and verified.

    Optimistic rollups that use a sequence of spans: Cons

    None

    Optimistic rollups that use a sequence of spans: Example

    An example optimistic rollup that uses sequence of spans to reference its data can be found in the RollupInclusionProofs. It portrays the different possible data availability proofs, constructs them and shows how to verify them.

    Also, more details on querying these kinds of proofs can be found in the proof queries documentation.

    Optimistic rollups that use blob share commitments

    Another way to build a rollup is to replace the sequence of spans with a height and a blob share commitment. Then, users/rollup full nodes will be able to query that data and validate it. If the rollup data is not valid, they can create a fraud proof.

    The first difference between the sequence of spans construction and the share commitment construction is having to verify that the provided blob share commitment is part of the Celestia block, referenced by its height in the moment of submitting the rollup commitments to the settlement contract. This is necessary to make sure that the commitment is part of Celestia. Otherwise, rollup sequencers can commit to random blob share commitments and there won't be a way to prove they're invalid.

    The second difference is the proof types. In the case of a fraud proof, the proofs outlined in the proofs details of blob share commitment section would need to be verified to be sure that the share containing the invalid state transition is part of the rollup data. Alternatively, the rollup settlement contract would need to have a library to parse protobuf encoded PFBs, as explained in the compact proofs of blob share commitment section, to have less expensive proofs. The cost of parsing the protobuf is not included in this analysis and needs to be investigated separately.

    Optimistic rollups that use blob share commitments: Pros

    • Using the same blob share commitment as the one saved in Celestia which gives access to existing tooling

    Optimistic rollups that use blob share commitments: Cons

    • The proofs are expensive in the base case. And if the settlement contract is able to parse the PFBs, thorough investigations of the cost of that would need to be done.

    Zk-rollups

    Zk-rollups, aka validity rollups, can also use Celestia as a DA and Blobstream to verify that the data was posted. However, the submission process is different from the above constructions, since there are no fraud proofs, and everything should be verified when submitting the commitment to the settlement contract.

    Similar to the optimistic case, the rollup settlement contract can reference the rollup data using either the sequence of spans approach or the blob share commitments. We will discuss both in this section.

    Zk-rollups that use sequence of spans

    When submitting the commitments to the rollup settlement contract, this latter will need to verify the following:

    1. Zk-proof of the state transitions, which is left for the rollup to define.
    2. Verify that the sequence of spans is valid, i.e., is part of the Celestia block referenced by its height, as described in the proof details section.
    3. Zk-proof of the rollup data to the data root. The verification process of this should accept a commitment as input so that the settlement contract makes sure it's the correct value that's being saved. The commitment can be the data root and the sequence of spans. And, when the rollup data is proven inside the circuit to the data root, the used data root is asserted to be the input one. Similarly, the data's location is asserted to be the same as the input sequence of spans. These arguments are the ones used in the sequence of spans verification in (2).

    Once these are valid, the settlement contract can be sure that the rollup data was posted to Celestia, and the sequence of spans references it correctly.

    Zk-rollups that use sequence of spans: Pros

    • The inclusion proof inside the zk-circuit is a simple proof that uses traditional merkle tree. In the case of using blob share commitment, as will be explained below, additional libraries that can be expensive to prove are required.

    Zk-rollups that use sequence of spans: Cons

    None

    Zk-rollups that use blob share commitments

    To use blob share commitments to reference rollup data in the zk-rollup settlement contract, the zk-circuits need to be able to deserialize protobuf encoded messages. Alternatively, more involved merkle proofs will need to be verified.

    Protobuf deserialization inside a zk-circuit

    One way of using the blob share commitment to reference the rollup data in zk-rollups is via using a protobuf deserialization library inside the zk-circuit. And the verification would proceed as follows:

    1. Zk-proof of the state transitions, which is left to the rollup team to define.
    2. Verify that the blob share commitment is valid using the proofs laid out in the proof details of blob share commitment section.
    3. The zk-proof verifier would take as argument the data root and the blob share commitment. Then, inside the circuit, the protobuf encoded PFB transaction will be deserialized and then verify the following:
    • The deserialized blob share commitment is the same as the one provided as input
    • The circuit will prove the inclusion of the PFB to the data root, then assert that the data root is the same as the one provided as input.

    If the above conditions are valid, the rollup settlement contract can be sure that the rollup data was posted to Celestia and is correctly referenced.

    Zk-rollups that use blob share commitments: Pros

    None

    Zk-rollups that use blob share commitments: Cons

    • This approach requires having access to a protobuf decoder inside a zk-circuit which is not straightforward to have. Also, the relative costs will need to be investigated.

    Heavy merkle proofs usage

    Similar to Protobuf deserialization inside a zk-circuit, the zk-circuit will proceed to the verification of the availability of the data. The difference is that instead of parsing the encoded protobuf, the proofs defined under the blob share commitment proof details section will need to be verified inside the zk-circuit as follows:

    1. Zk-proof of the state transitions, which is left to the rollup team to define.
    2. Verify that the blob share commitment is valid using the proofs laid out in the blob share commitment proof details section.
    3. The zk-proof verifier would take as argument the data root and the blob share commitment. Then, inside the circuit:
    • It will verify that the input blob share commitment corresponds to the rollup data.
    • Verify that the input data root commits to that blob share commitment. Check the blob share commitment proof details for more details

    Once these proofs are valid, the rollup settlement contract can be sure that the rollup data was posted to Celestia and is correctly referenced.

    heavy merkle proofs usage: Pros

    None

    heavy merkle proofs usage: Cons

    • More heavy usage of merkle proofs inside and outside the zk-circuit.

    Conclusion

    Given the above details, using the sequence of spans is the better solution in the general case as explained in the optimistic rollups that uses a sequence of spans and zk-rollups that use sequence of spans sections. The proof sizes are small and allow for greater flexibility. However, if the rollup team has different requirements, then the other designs can be explored.

    FAQ

    Should I use the Celestia transaction hash to reference the rollup data?

    This is asked a lot since it's the most intuitive way of referencing data. However, in Celestia, referencing the data using the transaction hash is not recommended.

    A transaction proof in Celestia goes back to providing an inclusion proof of the shares containing the transaction. This means if the transaction hash is used to reference data in a Celestia block, the rollup verification mechanism should do the following:

    • Verify an inclusion proof of the shares comprising the transaction up to the data root tuple root
    • Decode those shares and parse the transaction, then hash its components to generate the transaction hash
    • Verify that the generated transaction hash matches the one used to reference the data

    At this level, the transaction hash is authenticated and the verification contract has the shares of the transaction. Then, the verification contract needs to take the share commitment from the parsed transaction and follow the steps outlined in the blob share commitment section.

    As observed, using the transaction hash is expensive and doesn't yield any advantages over using the blob share commitment, which in turn is more expensive than using the sequence of spans.

    So, unless there are more reasons to use the transaction hash to reference the rollup data, the sequence of spans approach remains better.

    `,113),i=[r];function n(l,h,c,p,u,d){return t(),o("div",null,i)}const b=e(s,[["render",n]]);export{f as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_blobstream-rollups.md.dc1ba5fc.lean.js b/pr-1815/assets/how-to-guides_blobstream-rollups.md.5bb93b32.lean.js similarity index 93% rename from pr-1815/assets/how-to-guides_blobstream-rollups.md.dc1ba5fc.lean.js rename to pr-1815/assets/how-to-guides_blobstream-rollups.md.5bb93b32.lean.js index 9a2f9a72e..85bdc9691 100644 --- a/pr-1815/assets/how-to-guides_blobstream-rollups.md.dc1ba5fc.lean.js +++ b/pr-1815/assets/how-to-guides_blobstream-rollups.md.5bb93b32.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction to Blobstream rollups","description":"Learn how to build rollups that use Blobstream.","frontmatter":{"description":"Learn how to build rollups that use Blobstream.","prev":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/how-to-guides/submit-data"},"head":[["meta",{"property":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to build rollups that use Blobstream."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-rollups.md","filePath":"how-to-guides/blobstream-rollups.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/blobstream-rollups.md"},r=a("",113),i=[r];function n(l,h,c,p,u,d){return t(),o("div",null,i)}const b=e(s,[["render",n]]);export{f as __pageData,b as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction to Blobstream rollups","description":"Learn how to build rollups that use Blobstream.","frontmatter":{"description":"Learn how to build rollups that use Blobstream.","prev":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/how-to-guides/submit-data"},"head":[["meta",{"property":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to build rollups that use Blobstream."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-rollups.md","filePath":"how-to-guides/blobstream-rollups.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/blobstream-rollups.md"},r=a("",113),i=[r];function n(l,h,c,p,u,d){return t(),o("div",null,i)}const b=e(s,[["render",n]]);export{f as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.230cb897.js b/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.c70d2786.js similarity index 99% rename from pr-1815/assets/how-to-guides_blobstream-x-deploy.md.230cb897.js rename to pr-1815/assets/how-to-guides_blobstream-x-deploy.md.c70d2786.js index c64dac97e..f5f176ead 100644 --- a/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.230cb897.js +++ b/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.c70d2786.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/tutorials/celestia-node-key"},"head":[["meta",{"property":"og:title","content":"New Blobstream X deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-deploy.md","filePath":"how-to-guides/blobstream-x-deploy.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/blobstream-x-deploy.md"},l=e(`

    New Blobstream X deployments

    This document will go over the instructions to deploy BlobstreamX to a new chain.

    Deploying the contracts

    To deploy a Blobstream X to a new chain, where a Gateway contract does not exist yet, the following steps need to be followed.

    If any of the components already exist in the target chain, feel free to skip the corresponding step.

    Deploy a new SuccinctGateway

    The SuccinctGateway is a contract that acts as a registry for onchain circuit verifiers and manages their access control. It is the entrypoint for proof verification and does the following:

    1. Receive a PLONK proof from the prover
    2. Fetch the address of the target function verifier
    3. Verify if the prover is whitelisted, if whitelisting is enabled
    4. Forward the proof to the function verifier to be verified
    5. If the proof is valid, it calls back the BlobstreamX contract to update its state

    The BlobstreamX requires the update to be provided through the SuccinctGateway. Otherwise, the contract can't be updated.

    To deploy a SuccinctGateway contract, you need to have foundry installed. If not, refer to foundry documentation.

    Then, clone the succinctx repo:

    shell
    git clone https://github.com/succinctlabs/succinctx
    +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/tutorials/celestia-node-key"},"head":[["meta",{"property":"og:title","content":"New Blobstream X deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-deploy.md","filePath":"how-to-guides/blobstream-x-deploy.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/blobstream-x-deploy.md"},l=e(`

    New Blobstream X deployments

    This document will go over the instructions to deploy BlobstreamX to a new chain.

    Deploying the contracts

    To deploy a Blobstream X to a new chain, where a Gateway contract does not exist yet, the following steps need to be followed.

    If any of the components already exist in the target chain, feel free to skip the corresponding step.

    Deploy a new SuccinctGateway

    The SuccinctGateway is a contract that acts as a registry for onchain circuit verifiers and manages their access control. It is the entrypoint for proof verification and does the following:

    1. Receive a PLONK proof from the prover
    2. Fetch the address of the target function verifier
    3. Verify if the prover is whitelisted, if whitelisting is enabled
    4. Forward the proof to the function verifier to be verified
    5. If the proof is valid, it calls back the BlobstreamX contract to update its state

    The BlobstreamX requires the update to be provided through the SuccinctGateway. Otherwise, the contract can't be updated.

    To deploy a SuccinctGateway contract, you need to have foundry installed. If not, refer to foundry documentation.

    Then, clone the succinctx repo:

    shell
    git clone https://github.com/succinctlabs/succinctx
     cd succinctx
    git clone https://github.com/succinctlabs/succinctx
     cd succinctx

    Next, build the contracts:

    shell
    cd contracts
     forge build
    cd contracts
    diff --git a/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.230cb897.lean.js b/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.c70d2786.lean.js
    similarity index 91%
    rename from pr-1815/assets/how-to-guides_blobstream-x-deploy.md.230cb897.lean.js
    rename to pr-1815/assets/how-to-guides_blobstream-x-deploy.md.c70d2786.lean.js
    index 1cd61461f..add8f1b05 100644
    --- a/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.230cb897.lean.js
    +++ b/pr-1815/assets/how-to-guides_blobstream-x-deploy.md.c70d2786.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/tutorials/celestia-node-key"},"head":[["meta",{"property":"og:title","content":"New Blobstream X deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-deploy.md","filePath":"how-to-guides/blobstream-x-deploy.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/blobstream-x-deploy.md"},l=e("",112),t=[l];function p(c,r,i,y,d,E){return a(),n("div",null,t)}const F=s(o,[["render",p]]);export{u as __pageData,F as default};
    +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/tutorials/celestia-node-key"},"head":[["meta",{"property":"og:title","content":"New Blobstream X deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-deploy.md","filePath":"how-to-guides/blobstream-x-deploy.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/blobstream-x-deploy.md"},l=e("",112),t=[l];function p(c,r,i,y,d,E){return a(),n("div",null,t)}const F=s(o,[["render",p]]);export{u as __pageData,F as default};
    diff --git a/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.js b/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.js
    similarity index 98%
    rename from pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.js
    rename to pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.js
    index 9a25f1649..86862db7d 100644
    --- a/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.js
    +++ b/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.js
    @@ -1 +1 @@
    -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"Requesting data commitment ranges | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","filePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1732776394000}'),r={name:"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md"},n=a('

    Requesting data commitment ranges

    By default, the Blobstream X deployments on Ethereum will be updated every 4 hours, and on Arbitrum One and Base, updating every 1 hour. If you wish for the Blobstream X contract to be updated at a different cadence, then you have several different options for how to update the smart contract.

    To request proofs to be submitted to the Blobstream X contract at a different cadence, you can do one of the following:

    NOTE: The requested proof ranges cannot include blocks that were already used in a previous batch. The ranges should start from the last proven block, aka, latest_block and they should end in a block already committed by Celestia. In other words, it's the end-inclusive range defined by [latest_block, target_block] with target_block <= Celestia tip.

    Local proving

    To run the Blobstream X operator with local proving, follow this guide.

    Local proving allows self-generating the proofs and submitting them to an existing BlobstreamX contract. Alternatively, if a team needs a very specific cadence that starts at very specific heights, they can deploy their own BlobstreamX contract and submit proofs to it. Deployment instructions can be found in the BlobstreamX deploy documentation.

    TIP

    Requires a large cloud machine to run in a reasonable amount of time. EC2 r6a.16xlarge, i.e., 64CPU 512GB RAM, takes ~30 minutes to generate a header range proof.

    Request proofs from the Succinct platform

    NOTE: Requesting a proof from the succinct platform requires having a Succinct API key. It can be requested using this form.

    Run the Blobstream X operator with hosted proving on the Succinct platform, by running an operator script that pings the platform with proof requests at a specified cadence.

    Follow these instructions to run the operator script.

    Here are example values for the .env file:

    1. TENDERMINT_RPC_URL from the public Celestia list.
    2. SUCCINCT_RPC_URL = https://alpha.succinct.xyz/api
    3. Request for SUCCINCT_API_KEY from the Succinct team.
    4. CHAIN_ID is the chain ID of the deployed Blobstream X contract.
    5. CONTRACT_ADDRESS: Blobstream X proxy contract address.
    6. NEXT_HEADER_FUNCTION_ID & HEADER_RANGE_FUNCTION_ID: Get the functionId's from the Blobstream X contract by using the nextHeaderFunctionId and headerRangeFunctionId respectively, which are public storage variables.

    Request proofs onchain

    Directly request a proof via the Blobstream X contract interface. Unlike the Blobstream X operator which handles requests off-chain, requesting on-chain requires gas, but the proof will be generated and relayed by the Succinct platform.

    1. Call requestHeaderRange(uint64 _targetBlock) with the end of the range you want a commitment for.

    2. A DataCommitmentStored(uint256, uint64, uint64, bytes32) will be emitted for the requested range when it is stored in the contract. Listen to this event to know that the proof has been generated successfully.

    ',17),s=[n];function c(i,l,d,h,p,m){return t(),o("div",null,s)}const b=e(r,[["render",c]]);export{f as __pageData,b as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"Requesting data commitment ranges | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","filePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1732777479000}'),r={name:"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md"},n=a('

    Requesting data commitment ranges

    By default, the Blobstream X deployments on Ethereum will be updated every 4 hours, and on Arbitrum One and Base, updating every 1 hour. If you wish for the Blobstream X contract to be updated at a different cadence, then you have several different options for how to update the smart contract.

    To request proofs to be submitted to the Blobstream X contract at a different cadence, you can do one of the following:

    NOTE: The requested proof ranges cannot include blocks that were already used in a previous batch. The ranges should start from the last proven block, aka, latest_block and they should end in a block already committed by Celestia. In other words, it's the end-inclusive range defined by [latest_block, target_block] with target_block <= Celestia tip.

    Local proving

    To run the Blobstream X operator with local proving, follow this guide.

    Local proving allows self-generating the proofs and submitting them to an existing BlobstreamX contract. Alternatively, if a team needs a very specific cadence that starts at very specific heights, they can deploy their own BlobstreamX contract and submit proofs to it. Deployment instructions can be found in the BlobstreamX deploy documentation.

    TIP

    Requires a large cloud machine to run in a reasonable amount of time. EC2 r6a.16xlarge, i.e., 64CPU 512GB RAM, takes ~30 minutes to generate a header range proof.

    Request proofs from the Succinct platform

    NOTE: Requesting a proof from the succinct platform requires having a Succinct API key. It can be requested using this form.

    Run the Blobstream X operator with hosted proving on the Succinct platform, by running an operator script that pings the platform with proof requests at a specified cadence.

    Follow these instructions to run the operator script.

    Here are example values for the .env file:

    1. TENDERMINT_RPC_URL from the public Celestia list.
    2. SUCCINCT_RPC_URL = https://alpha.succinct.xyz/api
    3. Request for SUCCINCT_API_KEY from the Succinct team.
    4. CHAIN_ID is the chain ID of the deployed Blobstream X contract.
    5. CONTRACT_ADDRESS: Blobstream X proxy contract address.
    6. NEXT_HEADER_FUNCTION_ID & HEADER_RANGE_FUNCTION_ID: Get the functionId's from the Blobstream X contract by using the nextHeaderFunctionId and headerRangeFunctionId respectively, which are public storage variables.

    Request proofs onchain

    Directly request a proof via the Blobstream X contract interface. Unlike the Blobstream X operator which handles requests off-chain, requesting on-chain requires gas, but the proof will be generated and relayed by the Succinct platform.

    1. Call requestHeaderRange(uint64 _targetBlock) with the end of the range you want a commitment for.

    2. A DataCommitmentStored(uint256, uint64, uint64, bytes32) will be emitted for the requested range when it is stored in the contract. Listen to this event to know that the proof has been generated successfully.

    ',17),s=[n];function c(i,l,d,h,p,m){return t(),o("div",null,s)}const b=e(r,[["render",c]]);export{f as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.lean.js b/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.lean.js rename to pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.lean.js index 9380c71d4..ca142a88f 100644 --- a/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.07985aad.lean.js +++ b/pr-1815/assets/how-to-guides_blobstream-x-requesting-data-commitment-ranges.md.1e42197f.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"Requesting data commitment ranges | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","filePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1732776394000}'),r={name:"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md"},n=a("",17),s=[n];function c(i,l,d,h,p,m){return t(),o("div",null,s)}const b=e(r,[["render",c]]);export{f as __pageData,b as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"Requesting data commitment ranges | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","filePath":"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1732777479000}'),r={name:"how-to-guides/blobstream-x-requesting-data-commitment-ranges.md"},n=a("",17),s=[n];function c(i,l,d,h,p,m){return t(),o("div",null,s)}const b=e(r,[["render",c]]);export{f as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_blobstream.md.2b135046.js b/pr-1815/assets/how-to-guides_blobstream.md.3a35dd4c.js similarity index 99% rename from pr-1815/assets/how-to-guides_blobstream.md.2b135046.js rename to pr-1815/assets/how-to-guides_blobstream.md.3a35dd4c.js index f62b6c3a4..b1839bb03 100644 --- a/pr-1815/assets/how-to-guides_blobstream.md.2b135046.js +++ b/pr-1815/assets/how-to-guides_blobstream.md.3a35dd4c.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream_logo.png",f=JSON.parse('{"title":"Blobstream: Streaming modular DA to Ethereum","description":"Learn how to integrate your L2 with Blobstream","frontmatter":{"description":"Learn how to integrate your L2 with Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2 with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream.md","filePath":"how-to-guides/blobstream.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/blobstream.md"},i=r('

    Blobstream: Streaming modular DA to Ethereum

    Blobstream logo

    What is Blobstream?

    Blobstream is the first data availability solution for Ethereum that securely scales with the number of users. Formerly known as the Quantum Gravity Bridge (QGB), Blobstream relays commitments to Celestia's data root to an onchain light client on Ethereum, for integration by developers into L2 contracts. This enables Ethereum developers to build high-throughput L2s using Celestia's optimised DA layer, the first with Data Availability Sampling (DAS). Any ecosystem can deploy a Blobstream light client onchain to allow L2s and L3s to access DA from Celestia.

    An implementation of Blobstream, by Succinct, called Blobstream X, is out and will be used in the upcoming deployments. This implementation proves the validity of Celestia block headers on a target EVM chain using zero-knowledge (ZK) proofs, which allow inheriting all the security guarantees of Celestia.

    The latest implementation of Blobstream X is SP1 Blobstream, which is written in Rust for the SP1 zkVM. SP1 Blobstream offers improved performance and efficiency while maintaining the security guarantees of the original Blobstream X.

    Please note: Blobstream remains early-stage, experimental software and users should use Blobstream at their own risk.

    Implementations of Blobstream

    Blobstream vs. data availability committees (DACs)

    Decentralization and security

    Blobstream is built on Celestia, which uses a CometBFT-based proof-of-stake system. Blobstream shares the same security assumptions as Celestia. In contrast, data availability committees (DACs), are typically centralized or semi-centralized, relying on a specific set of entities or individuals to vouch for data availability.

    Mechanism of verification

    Blobstream uses data availability attestations, which are Merkle roots of the batched L2 data, to confirm that the necessary data is present on Celestia. The L2 contract on Ethereum can check directly with Blobstream if the data is published on Celestia. Similarly, a DAC would rely on attestations or confirmations from its permissioned members.

    Flexibility and scalability

    Blobstream is designed to offer high-throughput data availability for Ethereum L2s, aiming to strike a balance between scalability and security. It operates independently of Ethereum's gas costs, as Celestia's resource pricing is more byte-focused rather than computation-centric. On the other hand, the scalability and flexibility of a DAC would depend on its specific design and implementation.

    In summary, both Blobstream and DACs aim to ensure offchain data availability, but Blobstream offers a more decentralized, secure, and scalable solution compared to the potential centralized nature of DACs.

    What is SP1 Blobstream?

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    SP1 Blobstream is the latest implementation of Blobstream with a ZK light client that bridges Celestia’s modular DA layer to Ethereum to allow high-throughput rollups to use Celestia’s DA while settling on Ethereum.

    Optimistic or ZK rollups that settle on Ethereum, but wish to use Celestia for DA, require a mechanism for bridging Celestia’s data root to Ethereum as part of the settlement process. This data root is used during inclusion proofs to prove that particular rollup transactions were included and made available in the Celestia network.

    Bridging Celestia’s data root to Ethereum requires running a Celestia light client as a smart contract on Ethereum, to make the latest state of the Celestia chain known on Ethereum and available to rollups. SP1 Blobstream uses the latest advances in ZK proofs to generate a succinct proof that enough Celestia validators have come to consensus (according to the CometBFT consensus protocol) on a block header, and verifies this proof in the SP1 Blobstream Ethereum smart contract to update it with the latest Celestia header.

    The SP1 Blobstream ZK proof not only verifies the consensus of Celestia validators, but it also merkelizes and hashes all the data roots in the block range from the previous update to the current update, making accessible all Celestia data roots (verifiable with a Merkle inclusion proof against the stored Merkle root) to rollups.

    If you're looking to deploy SP1 blobstream to a new chain, see new Sp1 Blobstream deployments.

    Learn more at the sp1-blobstream repo.

    NOTE

    The current Blobstream deployments all use SP1 Blobstream.

    Integrate with SP1 Blobstream

    The following docs go over how developers can integrate SP1 Blobstream.

    You can find the repository for SP1 Blobstream along with code for:

    The first deployments of SP1 Blobstream will be maintained on the following chains: Arbitrum One, Base and Ethereum Mainnet. Every 1 hour, the prover/relayer will post an update to the Blobstream contract that will include a new data commitment range that covers a 1-hour block range from the latestBlock in the contract. On Ethereum Mainnet, the contract will be updated every 4 hours.

    How to integrate with Blobstream

    Integrating your L2 with Blobstream requires two components: your onchain smart contract logic, and your offchain client logic for your rollup. The next three sections cover these topics:

    Blobstream rollups

    More on the different ways to build a blobstream rollup can be found in the blobstream rollups documentation.

    Deployed contracts

    You can interact with the SP1 Blobstream contracts today. The SP1 Blobstream Solidity smart contracts are currently deployed on the following chains:

    ContractEVM networkContract addressAttested data on CelestiaLink to Celenium
    SP1 BlobstreamEthereum Mainnet0x7Cf3876F681Dbb6EdA8f6FfC45D66B996Df08fAeMainnet BetaDeployment on Celenium
    SP1 BlobstreamArbitrum One0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamBase0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamSepolia0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1eMocha testnetDeployment on Celenium
    SP1 BlobstreamArbitrum Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    SP1 BlobstreamBase Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    ',39),l=[i];function n(h,c,m,b,d,u){return t(),a("div",null,l)}const g=e(s,[["render",n]]);export{f as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream_logo.png",f=JSON.parse('{"title":"Blobstream: Streaming modular DA to Ethereum","description":"Learn how to integrate your L2 with Blobstream","frontmatter":{"description":"Learn how to integrate your L2 with Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2 with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream.md","filePath":"how-to-guides/blobstream.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/blobstream.md"},i=r('

    Blobstream: Streaming modular DA to Ethereum

    Blobstream logo

    What is Blobstream?

    Blobstream is the first data availability solution for Ethereum that securely scales with the number of users. Formerly known as the Quantum Gravity Bridge (QGB), Blobstream relays commitments to Celestia's data root to an onchain light client on Ethereum, for integration by developers into L2 contracts. This enables Ethereum developers to build high-throughput L2s using Celestia's optimised DA layer, the first with Data Availability Sampling (DAS). Any ecosystem can deploy a Blobstream light client onchain to allow L2s and L3s to access DA from Celestia.

    An implementation of Blobstream, by Succinct, called Blobstream X, is out and will be used in the upcoming deployments. This implementation proves the validity of Celestia block headers on a target EVM chain using zero-knowledge (ZK) proofs, which allow inheriting all the security guarantees of Celestia.

    The latest implementation of Blobstream X is SP1 Blobstream, which is written in Rust for the SP1 zkVM. SP1 Blobstream offers improved performance and efficiency while maintaining the security guarantees of the original Blobstream X.

    Please note: Blobstream remains early-stage, experimental software and users should use Blobstream at their own risk.

    Implementations of Blobstream

    Blobstream vs. data availability committees (DACs)

    Decentralization and security

    Blobstream is built on Celestia, which uses a CometBFT-based proof-of-stake system. Blobstream shares the same security assumptions as Celestia. In contrast, data availability committees (DACs), are typically centralized or semi-centralized, relying on a specific set of entities or individuals to vouch for data availability.

    Mechanism of verification

    Blobstream uses data availability attestations, which are Merkle roots of the batched L2 data, to confirm that the necessary data is present on Celestia. The L2 contract on Ethereum can check directly with Blobstream if the data is published on Celestia. Similarly, a DAC would rely on attestations or confirmations from its permissioned members.

    Flexibility and scalability

    Blobstream is designed to offer high-throughput data availability for Ethereum L2s, aiming to strike a balance between scalability and security. It operates independently of Ethereum's gas costs, as Celestia's resource pricing is more byte-focused rather than computation-centric. On the other hand, the scalability and flexibility of a DAC would depend on its specific design and implementation.

    In summary, both Blobstream and DACs aim to ensure offchain data availability, but Blobstream offers a more decentralized, secure, and scalable solution compared to the potential centralized nature of DACs.

    What is SP1 Blobstream?

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    SP1 Blobstream is the latest implementation of Blobstream with a ZK light client that bridges Celestia’s modular DA layer to Ethereum to allow high-throughput rollups to use Celestia’s DA while settling on Ethereum.

    Optimistic or ZK rollups that settle on Ethereum, but wish to use Celestia for DA, require a mechanism for bridging Celestia’s data root to Ethereum as part of the settlement process. This data root is used during inclusion proofs to prove that particular rollup transactions were included and made available in the Celestia network.

    Bridging Celestia’s data root to Ethereum requires running a Celestia light client as a smart contract on Ethereum, to make the latest state of the Celestia chain known on Ethereum and available to rollups. SP1 Blobstream uses the latest advances in ZK proofs to generate a succinct proof that enough Celestia validators have come to consensus (according to the CometBFT consensus protocol) on a block header, and verifies this proof in the SP1 Blobstream Ethereum smart contract to update it with the latest Celestia header.

    The SP1 Blobstream ZK proof not only verifies the consensus of Celestia validators, but it also merkelizes and hashes all the data roots in the block range from the previous update to the current update, making accessible all Celestia data roots (verifiable with a Merkle inclusion proof against the stored Merkle root) to rollups.

    If you're looking to deploy SP1 blobstream to a new chain, see new Sp1 Blobstream deployments.

    Learn more at the sp1-blobstream repo.

    NOTE

    The current Blobstream deployments all use SP1 Blobstream.

    Integrate with SP1 Blobstream

    The following docs go over how developers can integrate SP1 Blobstream.

    You can find the repository for SP1 Blobstream along with code for:

    The first deployments of SP1 Blobstream will be maintained on the following chains: Arbitrum One, Base and Ethereum Mainnet. Every 1 hour, the prover/relayer will post an update to the Blobstream contract that will include a new data commitment range that covers a 1-hour block range from the latestBlock in the contract. On Ethereum Mainnet, the contract will be updated every 4 hours.

    How to integrate with Blobstream

    Integrating your L2 with Blobstream requires two components: your onchain smart contract logic, and your offchain client logic for your rollup. The next three sections cover these topics:

    Blobstream rollups

    More on the different ways to build a blobstream rollup can be found in the blobstream rollups documentation.

    Deployed contracts

    You can interact with the SP1 Blobstream contracts today. The SP1 Blobstream Solidity smart contracts are currently deployed on the following chains:

    ContractEVM networkContract addressAttested data on CelestiaLink to Celenium
    SP1 BlobstreamEthereum Mainnet0x7Cf3876F681Dbb6EdA8f6FfC45D66B996Df08fAeMainnet BetaDeployment on Celenium
    SP1 BlobstreamArbitrum One0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamBase0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamSepolia0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1eMocha testnetDeployment on Celenium
    SP1 BlobstreamArbitrum Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    SP1 BlobstreamBase Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    ',39),l=[i];function n(h,c,m,b,d,u){return t(),a("div",null,l)}const g=e(s,[["render",n]]);export{f as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_blobstream.md.2b135046.lean.js b/pr-1815/assets/how-to-guides_blobstream.md.3a35dd4c.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_blobstream.md.2b135046.lean.js rename to pr-1815/assets/how-to-guides_blobstream.md.3a35dd4c.lean.js index 0f2c300ff..e941b368e 100644 --- a/pr-1815/assets/how-to-guides_blobstream.md.2b135046.lean.js +++ b/pr-1815/assets/how-to-guides_blobstream.md.3a35dd4c.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream_logo.png",f=JSON.parse('{"title":"Blobstream: Streaming modular DA to Ethereum","description":"Learn how to integrate your L2 with Blobstream","frontmatter":{"description":"Learn how to integrate your L2 with Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2 with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream.md","filePath":"how-to-guides/blobstream.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/blobstream.md"},i=r("",39),l=[i];function n(h,c,m,b,d,u){return t(),a("div",null,l)}const g=e(s,[["render",n]]);export{f as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/blobstream/blobstream_logo.png",f=JSON.parse('{"title":"Blobstream: Streaming modular DA to Ethereum","description":"Learn how to integrate your L2 with Blobstream","frontmatter":{"description":"Learn how to integrate your L2 with Blobstream","head":[["meta",{"property":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to integrate your L2 with Blobstream"}]]},"headers":[],"relativePath":"how-to-guides/blobstream.md","filePath":"how-to-guides/blobstream.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/blobstream.md"},i=r("",39),l=[i];function n(h,c,m,b,d,u){return t(),a("div",null,l)}const g=e(s,[["render",n]]);export{f as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_blobstreamx.md.139d5ab9.js b/pr-1815/assets/how-to-guides_blobstreamx.md.1dcae78a.js similarity index 99% rename from pr-1815/assets/how-to-guides_blobstreamx.md.139d5ab9.js rename to pr-1815/assets/how-to-guides_blobstreamx.md.1dcae78a.js index aa9ac0aa4..b213146ed 100644 --- a/pr-1815/assets/how-to-guides_blobstreamx.md.139d5ab9.js +++ b/pr-1815/assets/how-to-guides_blobstreamx.md.1dcae78a.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X1b.png",s="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X2b.png",g=JSON.parse('{"title":"Blobstream X: the previous zk implementation of Blobstream","description":"What is BlobstreamX","frontmatter":{"description":"What is BlobstreamX","prev":{"text":"New SP1 Blobstream deployments","link":"/how-to-guides/sp1-blobstream-deploy"},"head":[["meta",{"property":"og:title","content":"Blobstream X: the previous zk implementation of Blobstream | Celestia Docs"}],["meta",{"property":"og:description","content":"What is BlobstreamX"}]]},"headers":[],"relativePath":"how-to-guides/blobstreamx.md","filePath":"how-to-guides/blobstreamx.md","lastUpdated":1732776394000}'),c={name:"how-to-guides/blobstreamx.md"},l=a('

    Blobstream X: the previous zk implementation of Blobstream

    blobstream x draft diagram

    What is Blobstream X?

    Blobstream X is the previous implementation of Blobstream. It uses plonky2x to create circuits that verify the Celestia consensus and generate the corresponding proofs.

    Blobstream X is built and deployed with Succinct's protocol.

    NOTE

    The Blobstream deployments below don't use the BlobstreamX circuits.

    You can find the repository for Blobstream X along with code for:

    NOTE

    Custom ranges can be requested using the BlobstreamX contract to create proofs for specific Celestia block batches. These ranges can be constructed as [latestBlock, customTargetBlock), with latestBlock as the latest block height that was committed to by the BlobstreamX contract, and latestBlock > customTargetBlock, and customTargetBlock - latestBlock <= DATA_COMMITMENT_MAX.

    Block ranges that are before the contract's latestBlock can't be proven a second time in different batches.

    More information can be found in the requestHeaderRange(...) method.

    How Blobstream X works

    As shown in the diagram below, the entrypoint for updates to the Blobstream X contract is through the SuccinctGateway smart contract, which is a simple entrypoint contract that verifies proofs (against a deployed onchain verifier for the Blobstream X circuit) and then calls the BlobstreamX.sol contract to update it. Find more information about the SuccinctGateway.

    blobstream x overview diagram draft

    NOTE

    If the Blobstream X contract is not deployed on a desired chain, it needs to be deployed before it can be used by your rollup. See the deployment documentation for more details.

    Deploy Blobstream X

    It is possible to deploy and maintain a Blobstream x instance and have the same security guarantees.

    First, you will need to create a multisig that governs the Blobstream X contract and also the function identifiers. The function identifiers can be registered in the Succinct gateway.

    Then, check the deployment documentation for how to deploy the contract.

    Then, you will need to run a relayer, which will generate the proofs and relay them to your deployed Blobstream X contract. Check the local proving documentation for more information.

    Community implementations

    Learn more about the community implementation of Blobstream proofs by CryptoKass.

    ',20),i=[l];function n(m,b,h,p,d,u){return t(),o("div",null,i)}const y=e(c,[["render",n]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X1b.png",s="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X2b.png",g=JSON.parse('{"title":"Blobstream X: the previous zk implementation of Blobstream","description":"What is BlobstreamX","frontmatter":{"description":"What is BlobstreamX","prev":{"text":"New SP1 Blobstream deployments","link":"/how-to-guides/sp1-blobstream-deploy"},"head":[["meta",{"property":"og:title","content":"Blobstream X: the previous zk implementation of Blobstream | Celestia Docs"}],["meta",{"property":"og:description","content":"What is BlobstreamX"}]]},"headers":[],"relativePath":"how-to-guides/blobstreamx.md","filePath":"how-to-guides/blobstreamx.md","lastUpdated":1732777479000}'),c={name:"how-to-guides/blobstreamx.md"},l=a('

    Blobstream X: the previous zk implementation of Blobstream

    blobstream x draft diagram

    What is Blobstream X?

    Blobstream X is the previous implementation of Blobstream. It uses plonky2x to create circuits that verify the Celestia consensus and generate the corresponding proofs.

    Blobstream X is built and deployed with Succinct's protocol.

    NOTE

    The Blobstream deployments below don't use the BlobstreamX circuits.

    You can find the repository for Blobstream X along with code for:

    NOTE

    Custom ranges can be requested using the BlobstreamX contract to create proofs for specific Celestia block batches. These ranges can be constructed as [latestBlock, customTargetBlock), with latestBlock as the latest block height that was committed to by the BlobstreamX contract, and latestBlock > customTargetBlock, and customTargetBlock - latestBlock <= DATA_COMMITMENT_MAX.

    Block ranges that are before the contract's latestBlock can't be proven a second time in different batches.

    More information can be found in the requestHeaderRange(...) method.

    How Blobstream X works

    As shown in the diagram below, the entrypoint for updates to the Blobstream X contract is through the SuccinctGateway smart contract, which is a simple entrypoint contract that verifies proofs (against a deployed onchain verifier for the Blobstream X circuit) and then calls the BlobstreamX.sol contract to update it. Find more information about the SuccinctGateway.

    blobstream x overview diagram draft

    NOTE

    If the Blobstream X contract is not deployed on a desired chain, it needs to be deployed before it can be used by your rollup. See the deployment documentation for more details.

    Deploy Blobstream X

    It is possible to deploy and maintain a Blobstream x instance and have the same security guarantees.

    First, you will need to create a multisig that governs the Blobstream X contract and also the function identifiers. The function identifiers can be registered in the Succinct gateway.

    Then, check the deployment documentation for how to deploy the contract.

    Then, you will need to run a relayer, which will generate the proofs and relay them to your deployed Blobstream X contract. Check the local proving documentation for more information.

    Community implementations

    Learn more about the community implementation of Blobstream proofs by CryptoKass.

    ',20),i=[l];function n(m,b,h,p,d,u){return t(),o("div",null,i)}const y=e(c,[["render",n]]);export{g as __pageData,y as default}; diff --git a/pr-1815/assets/how-to-guides_blobstreamx.md.139d5ab9.lean.js b/pr-1815/assets/how-to-guides_blobstreamx.md.1dcae78a.lean.js similarity index 93% rename from pr-1815/assets/how-to-guides_blobstreamx.md.139d5ab9.lean.js rename to pr-1815/assets/how-to-guides_blobstreamx.md.1dcae78a.lean.js index d739b5cde..a6eec1368 100644 --- a/pr-1815/assets/how-to-guides_blobstreamx.md.139d5ab9.lean.js +++ b/pr-1815/assets/how-to-guides_blobstreamx.md.1dcae78a.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X1b.png",s="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X2b.png",g=JSON.parse('{"title":"Blobstream X: the previous zk implementation of Blobstream","description":"What is BlobstreamX","frontmatter":{"description":"What is BlobstreamX","prev":{"text":"New SP1 Blobstream deployments","link":"/how-to-guides/sp1-blobstream-deploy"},"head":[["meta",{"property":"og:title","content":"Blobstream X: the previous zk implementation of Blobstream | Celestia Docs"}],["meta",{"property":"og:description","content":"What is BlobstreamX"}]]},"headers":[],"relativePath":"how-to-guides/blobstreamx.md","filePath":"how-to-guides/blobstreamx.md","lastUpdated":1732776394000}'),c={name:"how-to-guides/blobstreamx.md"},l=a("",20),i=[l];function n(m,b,h,p,d,u){return t(),o("div",null,i)}const y=e(c,[["render",n]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X1b.png",s="/docs-preview/pr-1815/img/blobstream/Celestia_Blobstream_X2b.png",g=JSON.parse('{"title":"Blobstream X: the previous zk implementation of Blobstream","description":"What is BlobstreamX","frontmatter":{"description":"What is BlobstreamX","prev":{"text":"New SP1 Blobstream deployments","link":"/how-to-guides/sp1-blobstream-deploy"},"head":[["meta",{"property":"og:title","content":"Blobstream X: the previous zk implementation of Blobstream | Celestia Docs"}],["meta",{"property":"og:description","content":"What is BlobstreamX"}]]},"headers":[],"relativePath":"how-to-guides/blobstreamx.md","filePath":"how-to-guides/blobstreamx.md","lastUpdated":1732777479000}'),c={name:"how-to-guides/blobstreamx.md"},l=a("",20),i=[l];function n(m,b,h,p,d,u){return t(),o("div",null,i)}const y=e(c,[["render",n]]);export{g as __pageData,y as default}; diff --git a/pr-1815/assets/how-to-guides_bridge-node.md.f12e478d.js b/pr-1815/assets/how-to-guides_bridge-node.md.51e7c8f0.js similarity index 97% rename from pr-1815/assets/how-to-guides_bridge-node.md.f12e478d.js rename to pr-1815/assets/how-to-guides_bridge-node.md.51e7c8f0.js index 3718474cd..d69538c34 100644 --- a/pr-1815/assets/how-to-guides_bridge-node.md.f12e478d.js +++ b/pr-1815/assets/how-to-guides_bridge-node.md.51e7c8f0.js @@ -1,7 +1,7 @@ -import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/nodes/BridgeNodes.png",u=JSON.parse('{"title":"Setting up a Celestia bridge node","description":"","frontmatter":{"\\\\description":"Learn how to set up your Celestia bridge node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/bridge-node.md","filePath":"how-to-guides/bridge-node.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/bridge-node.md"},t=o('

    Setting up a Celestia bridge node

    This tutorial will go over the steps to setting up your Celestia bridge node.

    Bridge nodes connect the data availability layer and the consensus layer.

    Overview of bridge nodes

    A Celestia bridge node has the following properties:

    1. Import and process “raw” headers & blocks from a trusted core process (meaning a trusted RPC connection to a celestia-core node) in the Consensus network. Bridge nodes can run this core process internally (embedded) or simply connect to a remote endpoint. Bridge nodes also have the option of being an active validator in the consensus network.
    2. Validate and erasure code the “raw” blocks
    3. Supply block shares with data availability headers to light nodes in the DA network.

    bridge-node-diagram

    From an implementation perspective, Bridge nodes run two separate processes:

    1. celestia-app with celestia-core (see repo)

      • celestia-app is the state machine where the application and the proof-of-stake logic is run. celestia-app is built on Cosmos SDK and also encompasses celestia-core.
      • celestia-core is the state interaction, consensus and block production layer. celestia-core is built on Tendermint Core, modified to store data roots of erasure coded blocks among other changes (see ADRs).
    2. celestia-node (see repo)

      • celestia-node augments the above with a separate libp2p network that serves data availability sampling requests. The team sometimes refers to this as the “halo” network.

    Hardware requirements

    The following hardware minimum requirements are recommended for running the bridge node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your bridge node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    Follow the tutorial for installing the dependencies.

    Deploy the Celestia bridge node

    Install Celestia Node

    Install the celestia-node binary, which will be used to run the bridge node.

    Follow the tutorial for installing celestia-node.

    Initialize the bridge node

    Run the following:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from the list on the Mocha testnet page or list on the Arabica devnet page, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Here is an example of initializing the bridge node:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>
    sh
    celestia bridge init --core.ip <URI> --p2p.network mocha
    celestia bridge init --core.ip <URI> --p2p.network mocha
    sh
    celestia bridge init --core.ip <URI> --p2p.network arabica
    celestia bridge init --core.ip <URI> --p2p.network arabica

    Run the bridge node

    Start the bridge node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    sh
    celestia bridge start --core.ip <URI>
    celestia bridge start --core.ip <URI>

    Here is an example of starting the bridge node on Mocha:

    sh
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha

    And on Arabica:

    sh
    celestia bridge start --core.ip validator-1.celestia-arabica-11.com \\
    +import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/nodes/BridgeNodes.png",u=JSON.parse('{"title":"Setting up a Celestia bridge node","description":"","frontmatter":{"\\\\description":"Learn how to set up your Celestia bridge node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/bridge-node.md","filePath":"how-to-guides/bridge-node.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/bridge-node.md"},t=o('

    Setting up a Celestia bridge node

    This tutorial will go over the steps to setting up your Celestia bridge node.

    Bridge nodes connect the data availability layer and the consensus layer.

    Overview of bridge nodes

    A Celestia bridge node has the following properties:

    1. Import and process “raw” headers & blocks from a trusted core process (meaning a trusted RPC connection to a celestia-core node) in the Consensus network. Bridge nodes can run this core process internally (embedded) or simply connect to a remote endpoint. Bridge nodes also have the option of being an active validator in the consensus network.
    2. Validate and erasure code the “raw” blocks
    3. Supply block shares with data availability headers to light nodes in the DA network.

    bridge-node-diagram

    From an implementation perspective, Bridge nodes run two separate processes:

    1. celestia-app with celestia-core (see repo)

      • celestia-app is the state machine where the application and the proof-of-stake logic is run. celestia-app is built on Cosmos SDK and also encompasses celestia-core.
      • celestia-core is the state interaction, consensus and block production layer. celestia-core is built on Tendermint Core, modified to store data roots of erasure coded blocks among other changes (see ADRs).
    2. celestia-node (see repo)

      • celestia-node augments the above with a separate libp2p network that serves data availability sampling requests. The team sometimes refers to this as the “halo” network.

    Hardware requirements

    The following hardware minimum requirements are recommended for running the bridge node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your bridge node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    Follow the tutorial for installing the dependencies.

    Deploy the Celestia bridge node

    Install Celestia Node

    Install the celestia-node binary, which will be used to run the bridge node.

    Follow the tutorial for installing celestia-node.

    Initialize the bridge node

    Run the following:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from the list on the Mocha testnet page or list on the Arabica devnet page, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Here is an example of initializing the bridge node:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>
    sh
    celestia bridge init --core.ip <URI> --p2p.network mocha
    celestia bridge init --core.ip <URI> --p2p.network mocha
    sh
    celestia bridge init --core.ip <URI> --p2p.network arabica
    celestia bridge init --core.ip <URI> --p2p.network arabica

    Run the bridge node

    Start the bridge node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    sh
    celestia bridge start --core.ip <URI>
    celestia bridge start --core.ip <URI>

    Here is an example of starting the bridge node on Mocha:

    sh
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha

    And on Arabica:

    sh
    celestia bridge start --core.ip validator-1.celestia-arabica-11.com \\
       --p2p.network arabica
    celestia bridge start --core.ip validator-1.celestia-arabica-11.com \\
    -  --p2p.network arabica

    You can create your key for your node by following the cel-key instructions.

    Once you start the bridge node, a wallet key will be generated for you. You will need to fund that address with Testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a bridge node for your validator it is highly recommended to request Mocha testnet tokens as this is the testnet used to test out validator operations.

    Optional: run the bridge node with a custom key

    In order to run a bridge node using a custom key:

    1. The custom key must exist inside the celestia bridge node directory at the correct path (default: ~/.celestia-bridge/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \\
    +  --p2p.network arabica

    You can create your key for your node by following the cel-key instructions.

    Once you start the bridge node, a wallet key will be generated for you. You will need to fund that address with Testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a bridge node for your validator it is highly recommended to request Mocha testnet tokens as this is the testnet used to test out validator operations.

    Optional: run the bridge node with a custom key

    In order to run a bridge node using a custom key:

    1. The custom key must exist inside the celestia bridge node directory at the correct path (default: ~/.celestia-bridge/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \\
       --p2p.network mocha
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \\
       --p2p.network mocha
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \\
       --p2p.network arabica
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \\
    -  --p2p.network arabica

    Optional: Migrate node id to another server

    To migrate a bridge node ID:

    1. You need to back up two files located in the celestia-bridge node directory at the correct path (default: ~/.celestia-bridge/keys).
    2. Upload the files to the new server and start the node.

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    `,53),p=[t];function r(c,i,d,y,E,h){return e(),a("div",null,p)}const b=s(l,[["render",r]]);export{u as __pageData,b as default}; + --p2p.network arabica

    Optional: Migrate node id to another server

    To migrate a bridge node ID:

    1. You need to back up two files located in the celestia-bridge node directory at the correct path (default: ~/.celestia-bridge/keys).
    2. Upload the files to the new server and start the node.

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    `,53),p=[t];function r(c,i,d,y,h,E){return e(),a("div",null,p)}const b=s(l,[["render",r]]);export{u as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_bridge-node.md.f12e478d.lean.js b/pr-1815/assets/how-to-guides_bridge-node.md.51e7c8f0.lean.js similarity index 83% rename from pr-1815/assets/how-to-guides_bridge-node.md.f12e478d.lean.js rename to pr-1815/assets/how-to-guides_bridge-node.md.51e7c8f0.lean.js index 700021970..46eca8ca2 100644 --- a/pr-1815/assets/how-to-guides_bridge-node.md.f12e478d.lean.js +++ b/pr-1815/assets/how-to-guides_bridge-node.md.51e7c8f0.lean.js @@ -1 +1 @@ -import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/nodes/BridgeNodes.png",u=JSON.parse('{"title":"Setting up a Celestia bridge node","description":"","frontmatter":{"\\\\description":"Learn how to set up your Celestia bridge node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/bridge-node.md","filePath":"how-to-guides/bridge-node.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/bridge-node.md"},t=o("",53),p=[t];function r(c,i,d,y,E,h){return e(),a("div",null,p)}const b=s(l,[["render",r]]);export{u as __pageData,b as default}; +import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/nodes/BridgeNodes.png",u=JSON.parse('{"title":"Setting up a Celestia bridge node","description":"","frontmatter":{"\\\\description":"Learn how to set up your Celestia bridge node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/bridge-node.md","filePath":"how-to-guides/bridge-node.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/bridge-node.md"},t=o("",53),p=[t];function r(c,i,d,y,h,E){return e(),a("div",null,p)}const b=s(l,[["render",r]]);export{u as __pageData,b as default}; diff --git a/pr-1815/assets/how-to-guides_bubs-testnet.md.b721ea5a.js b/pr-1815/assets/how-to-guides_bubs-testnet.md.7c4ccf62.js similarity index 98% rename from pr-1815/assets/how-to-guides_bubs-testnet.md.b721ea5a.js rename to pr-1815/assets/how-to-guides_bubs-testnet.md.7c4ccf62.js index 4e732c2f2..e37be1cb3 100644 --- a/pr-1815/assets/how-to-guides_bubs-testnet.md.b721ea5a.js +++ b/pr-1815/assets/how-to-guides_bubs-testnet.md.7c4ccf62.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as s}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Bubs_Testnet.jpg",m=JSON.parse('{"title":"Bubs testnet","description":"The first testnet built with OP Stack and Celestia.","frontmatter":{"description":"The first testnet built with OP Stack and Celestia.","next":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"head":[["meta",{"property":"og:title","content":"Bubs testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first testnet built with OP Stack and Celestia."}]]},"headers":[],"relativePath":"how-to-guides/bubs-testnet.md","filePath":"how-to-guides/bubs-testnet.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/bubs-testnet.md"},i=s('

    Bubs testnet

    Bubs testnet

    Bubs Testnet is a the first OP Stack testnet with Celestia underneath hosted by Caldera with support from Celestia Labs. Bubs is dedicated to providing developers with an EVM-compatible execution layer to deploy their EVM applications on.

    Built with the OP Stack and Celestia

    The Bubs Testnet is a testnet rollup, a modified version of optimism-bedrock that uses Celestia as a data availability (DA) layer. This integration can be found in the @celestiaorg/optimism repository. The testnet is hosted by Caldera, who makes it easy to launch rollups with no code required. Bubs' data is posted to Celestia on the Mocha testnet. View the namespace for Bubs on Celestia's Mocha testnet.

    Learn more about the setup of the integration in the introduction.

    Building on Bubs

    Bubs Testnet provides a robust environment for developers to test their Ethereum Virtual Machine (EVM) applications. It offers an EVM-compatible execution layer, making it an ideal platform for developers looking to build and test applications in a setting that closely mirrors an OP Stack rollup on Celestia.

    Learn more at https://bubs-sepolia.hub.caldera.xyz/.

    RPC URLs

    Remote Procedure Call (RPC) URLs are endpoints that allow developers to interact with the blockchain. They are essential for sending transactions, querying blockchain data, and performing other interactions with the blockchain.

    For the Bubs Testnet, you can connect to the following RPC URLs:

    HTTPS

    • https://bubs-sepolia.rpc.caldera.xyz/http

    WSS

    • wss://bubs-sepolia.rpc.caldera.xyz/ws

    This URL serves as the entry point to the Bubs Testnet. You can use it in your applications to connect to the testnet and interact with the smart contracts you deploy there.

    Remember, Bubs Testnet is a testing environment!

    Bridge

    Bridging is a process that enables the transfer of assets between different blockchains.

    To bridge between Ethereum Sepolia and Bubs Testnet, visit the Bubs Testnet bridge.

    Faucet

    To visit the Bubs testnet faucet, go to https://bubs-sepolia.hub.caldera.xyz/ and click the "Faucet" tab.

    Explorer

    To visit the explorer, go to https://bubs-sepolia.explorer.caldera.xyz/.

    Status

    To see the status and uptime information for Bubs, visit the status page.

    Next steps

    Now that you have a better understanding of the Bubs Testnet and its integration of OP Stack and Celestia, you can start exploring its capabilities.

    ',29),n=[i];function l(h,c,u,d,p,b){return t(),a("div",null,n)}const g=e(o,[["render",l]]);export{m as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as s}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Bubs_Testnet.jpg",m=JSON.parse('{"title":"Bubs testnet","description":"The first testnet built with OP Stack and Celestia.","frontmatter":{"description":"The first testnet built with OP Stack and Celestia.","next":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"head":[["meta",{"property":"og:title","content":"Bubs testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first testnet built with OP Stack and Celestia."}]]},"headers":[],"relativePath":"how-to-guides/bubs-testnet.md","filePath":"how-to-guides/bubs-testnet.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/bubs-testnet.md"},i=s('

    Bubs testnet

    Bubs testnet

    Bubs Testnet is a the first OP Stack testnet with Celestia underneath hosted by Caldera with support from Celestia Labs. Bubs is dedicated to providing developers with an EVM-compatible execution layer to deploy their EVM applications on.

    Built with the OP Stack and Celestia

    The Bubs Testnet is a testnet rollup, a modified version of optimism-bedrock that uses Celestia as a data availability (DA) layer. This integration can be found in the @celestiaorg/optimism repository. The testnet is hosted by Caldera, who makes it easy to launch rollups with no code required. Bubs' data is posted to Celestia on the Mocha testnet. View the namespace for Bubs on Celestia's Mocha testnet.

    Learn more about the setup of the integration in the introduction.

    Building on Bubs

    Bubs Testnet provides a robust environment for developers to test their Ethereum Virtual Machine (EVM) applications. It offers an EVM-compatible execution layer, making it an ideal platform for developers looking to build and test applications in a setting that closely mirrors an OP Stack rollup on Celestia.

    Learn more at https://bubs-sepolia.hub.caldera.xyz/.

    RPC URLs

    Remote Procedure Call (RPC) URLs are endpoints that allow developers to interact with the blockchain. They are essential for sending transactions, querying blockchain data, and performing other interactions with the blockchain.

    For the Bubs Testnet, you can connect to the following RPC URLs:

    HTTPS

    • https://bubs-sepolia.rpc.caldera.xyz/http

    WSS

    • wss://bubs-sepolia.rpc.caldera.xyz/ws

    This URL serves as the entry point to the Bubs Testnet. You can use it in your applications to connect to the testnet and interact with the smart contracts you deploy there.

    Remember, Bubs Testnet is a testing environment!

    Bridge

    Bridging is a process that enables the transfer of assets between different blockchains.

    To bridge between Ethereum Sepolia and Bubs Testnet, visit the Bubs Testnet bridge.

    Faucet

    To visit the Bubs testnet faucet, go to https://bubs-sepolia.hub.caldera.xyz/ and click the "Faucet" tab.

    Explorer

    To visit the explorer, go to https://bubs-sepolia.explorer.caldera.xyz/.

    Status

    To see the status and uptime information for Bubs, visit the status page.

    Next steps

    Now that you have a better understanding of the Bubs Testnet and its integration of OP Stack and Celestia, you can start exploring its capabilities.

    ',29),n=[i];function l(h,c,u,d,p,b){return t(),a("div",null,n)}const g=e(o,[["render",l]]);export{m as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_bubs-testnet.md.b721ea5a.lean.js b/pr-1815/assets/how-to-guides_bubs-testnet.md.7c4ccf62.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_bubs-testnet.md.b721ea5a.lean.js rename to pr-1815/assets/how-to-guides_bubs-testnet.md.7c4ccf62.lean.js index 521367c18..0ccd567c8 100644 --- a/pr-1815/assets/how-to-guides_bubs-testnet.md.b721ea5a.lean.js +++ b/pr-1815/assets/how-to-guides_bubs-testnet.md.7c4ccf62.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as s}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Bubs_Testnet.jpg",m=JSON.parse('{"title":"Bubs testnet","description":"The first testnet built with OP Stack and Celestia.","frontmatter":{"description":"The first testnet built with OP Stack and Celestia.","next":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"head":[["meta",{"property":"og:title","content":"Bubs testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first testnet built with OP Stack and Celestia."}]]},"headers":[],"relativePath":"how-to-guides/bubs-testnet.md","filePath":"how-to-guides/bubs-testnet.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/bubs-testnet.md"},i=s("",29),n=[i];function l(h,c,u,d,p,b){return t(),a("div",null,n)}const g=e(o,[["render",l]]);export{m as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as s}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/Celestia_Bubs_Testnet.jpg",m=JSON.parse('{"title":"Bubs testnet","description":"The first testnet built with OP Stack and Celestia.","frontmatter":{"description":"The first testnet built with OP Stack and Celestia.","next":{"text":"Ethereum fallback mechanism","link":"/how-to-guides/ethereum-fallback"},"head":[["meta",{"property":"og:title","content":"Bubs testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first testnet built with OP Stack and Celestia."}]]},"headers":[],"relativePath":"how-to-guides/bubs-testnet.md","filePath":"how-to-guides/bubs-testnet.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/bubs-testnet.md"},i=s("",29),n=[i];function l(h,c,u,d,p,b){return t(),a("div",null,n)}const g=e(o,[["render",l]]);export{m as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app-commands.md.e2443b6e.js b/pr-1815/assets/how-to-guides_celestia-app-commands.md.cf34f1c2.js similarity index 99% rename from pr-1815/assets/how-to-guides_celestia-app-commands.md.e2443b6e.js rename to pr-1815/assets/how-to-guides_celestia-app-commands.md.cf34f1c2.js index 7c3979946..c20e0d76a 100644 --- a/pr-1815/assets/how-to-guides_celestia-app-commands.md.e2443b6e.js +++ b/pr-1815/assets/how-to-guides_celestia-app-commands.md.cf34f1c2.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Helpful CLI commands","description":"Some of the most helpful celestia-app CLI commands.","frontmatter":{"description":"Some of the most helpful celestia-app CLI commands.","head":[["meta",{"property":"og:title","content":"Helpful CLI commands | Celestia Docs"}],["meta",{"property":"og:description","content":"Some of the most helpful celestia-app CLI commands."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-commands.md","filePath":"how-to-guides/celestia-app-commands.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/celestia-app-commands.md"},o=l(`

    Helpful CLI commands

    View all options:

    console
    $ celestia-appd --help
    +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Helpful CLI commands","description":"Some of the most helpful celestia-app CLI commands.","frontmatter":{"description":"Some of the most helpful celestia-app CLI commands.","head":[["meta",{"property":"og:title","content":"Helpful CLI commands | Celestia Docs"}],["meta",{"property":"og:description","content":"Some of the most helpful celestia-app CLI commands."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-commands.md","filePath":"how-to-guides/celestia-app-commands.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/celestia-app-commands.md"},o=l(`

    Helpful CLI commands

    View all options:

    console
    $ celestia-appd --help
     Start celestia-app
     
     Usage:
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-commands.md.e2443b6e.lean.js b/pr-1815/assets/how-to-guides_celestia-app-commands.md.cf34f1c2.lean.js
    similarity index 92%
    rename from pr-1815/assets/how-to-guides_celestia-app-commands.md.e2443b6e.lean.js
    rename to pr-1815/assets/how-to-guides_celestia-app-commands.md.cf34f1c2.lean.js
    index 01cf6542c..b838eba08 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-commands.md.e2443b6e.lean.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-commands.md.cf34f1c2.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Helpful CLI commands","description":"Some of the most helpful celestia-app CLI commands.","frontmatter":{"description":"Some of the most helpful celestia-app CLI commands.","head":[["meta",{"property":"og:title","content":"Helpful CLI commands | Celestia Docs"}],["meta",{"property":"og:description","content":"Some of the most helpful celestia-app CLI commands."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-commands.md","filePath":"how-to-guides/celestia-app-commands.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/celestia-app-commands.md"},o=l("",84),e=[o];function t(c,r,y,E,i,F){return a(),n("div",null,e)}const g=s(p,[["render",t]]);export{u as __pageData,g as default};
    +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Helpful CLI commands","description":"Some of the most helpful celestia-app CLI commands.","frontmatter":{"description":"Some of the most helpful celestia-app CLI commands.","head":[["meta",{"property":"og:title","content":"Helpful CLI commands | Celestia Docs"}],["meta",{"property":"og:description","content":"Some of the most helpful celestia-app CLI commands."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-commands.md","filePath":"how-to-guides/celestia-app-commands.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/celestia-app-commands.md"},o=l("",84),e=[o];function t(c,r,y,E,i,F){return a(),n("div",null,e)}const g=s(p,[["render",t]]);export{u as __pageData,g as default};
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-metrics.md.c57e7d35.js b/pr-1815/assets/how-to-guides_celestia-app-metrics.md.120ee0a3.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_celestia-app-metrics.md.c57e7d35.js
    rename to pr-1815/assets/how-to-guides_celestia-app-metrics.md.120ee0a3.js
    index 28a218adb..6287e429d 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-metrics.md.c57e7d35.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-metrics.md.120ee0a3.js
    @@ -1,4 +1,4 @@
    -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Metrics","description":"A guide on how to monitor the health and performance of your system.","frontmatter":{"description":"A guide on how to monitor the health and performance of your system.","prev":{"text":"Troubleshooting","link":"/how-to-guides/celestia-node-troubleshooting"},"head":[["meta",{"property":"og:title","content":"Metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to monitor the health and performance of your system."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-metrics.md","filePath":"how-to-guides/celestia-app-metrics.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/celestia-app-metrics.md"},l=e(`

    Metrics

    Metrics are a powerful tool for monitoring the health and performance of a system. Celestia provides support for metrics to make sure, as an operator, your system continues to remain up and running. Metrics can also provide critical insight into how Celestia is used and how it can be improved.

    Setup

    Celestia uses Prometheus to publish metrics. It can be enabled through the config.toml file.

    bash
    #######################################################
    +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Metrics","description":"A guide on how to monitor the health and performance of your system.","frontmatter":{"description":"A guide on how to monitor the health and performance of your system.","prev":{"text":"Troubleshooting","link":"/how-to-guides/celestia-node-troubleshooting"},"head":[["meta",{"property":"og:title","content":"Metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to monitor the health and performance of your system."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-metrics.md","filePath":"how-to-guides/celestia-app-metrics.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/celestia-app-metrics.md"},l=e(`

    Metrics

    Metrics are a powerful tool for monitoring the health and performance of a system. Celestia provides support for metrics to make sure, as an operator, your system continues to remain up and running. Metrics can also provide critical insight into how Celestia is used and how it can be improved.

    Setup

    Celestia uses Prometheus to publish metrics. It can be enabled through the config.toml file.

    bash
    #######################################################
     ###       Instrumentation Configuration Options     ###
     #######################################################
     [instrumentation]
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-metrics.md.c57e7d35.lean.js b/pr-1815/assets/how-to-guides_celestia-app-metrics.md.120ee0a3.lean.js
    similarity index 93%
    rename from pr-1815/assets/how-to-guides_celestia-app-metrics.md.c57e7d35.lean.js
    rename to pr-1815/assets/how-to-guides_celestia-app-metrics.md.120ee0a3.lean.js
    index a67fe97c8..acf79756f 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-metrics.md.c57e7d35.lean.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-metrics.md.120ee0a3.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Metrics","description":"A guide on how to monitor the health and performance of your system.","frontmatter":{"description":"A guide on how to monitor the health and performance of your system.","prev":{"text":"Troubleshooting","link":"/how-to-guides/celestia-node-troubleshooting"},"head":[["meta",{"property":"og:title","content":"Metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to monitor the health and performance of your system."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-metrics.md","filePath":"how-to-guides/celestia-app-metrics.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/celestia-app-metrics.md"},l=e("",27),t=[l];function p(r,c,i,y,h,u){return a(),n("div",null,t)}const E=s(o,[["render",p]]);export{m as __pageData,E as default};
    +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Metrics","description":"A guide on how to monitor the health and performance of your system.","frontmatter":{"description":"A guide on how to monitor the health and performance of your system.","prev":{"text":"Troubleshooting","link":"/how-to-guides/celestia-node-troubleshooting"},"head":[["meta",{"property":"og:title","content":"Metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to monitor the health and performance of your system."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-metrics.md","filePath":"how-to-guides/celestia-app-metrics.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/celestia-app-metrics.md"},l=e("",27),t=[l];function p(r,c,i,y,h,u){return a(),n("div",null,t)}const E=s(o,[["render",p]]);export{m as __pageData,E as default};
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-multisig.md.0242053f.js b/pr-1815/assets/how-to-guides_celestia-app-multisig.md.e890db6c.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_celestia-app-multisig.md.0242053f.js
    rename to pr-1815/assets/how-to-guides_celestia-app-multisig.md.e890db6c.js
    index 95bae5cb4..360ced177 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-multisig.md.0242053f.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-multisig.md.e890db6c.js
    @@ -1,4 +1,4 @@
    -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Multisig | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-multisig.md","filePath":"how-to-guides/celestia-app-multisig.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/celestia-app-multisig.md"},o=l(`

    Multisig

    Celestia inherits support for multisig accounts from the Cosmos SDK. Multisig accounts behave similarly to regular accounts with the added requirement that a threshold of signatures is needed to authorize a transaction.

    Multisig accounts can be created from the command line or using a graphical interface such as Keplr.

    Command line

    bash
    #!/bin/sh
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Multisig | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-multisig.md","filePath":"how-to-guides/celestia-app-multisig.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/celestia-app-multisig.md"},o=l(`

    Multisig

    Celestia inherits support for multisig accounts from the Cosmos SDK. Multisig accounts behave similarly to regular accounts with the added requirement that a threshold of signatures is needed to authorize a transaction.

    Multisig accounts can be created from the command line or using a graphical interface such as Keplr.

    Command line

    bash
    #!/bin/sh
     
     # Prerequisite: prior to running this script, start a single node devnet with ./scripts/single-node.sh
     CHAIN_ID="private"
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-multisig.md.0242053f.lean.js b/pr-1815/assets/how-to-guides_celestia-app-multisig.md.e890db6c.lean.js
    similarity index 90%
    rename from pr-1815/assets/how-to-guides_celestia-app-multisig.md.0242053f.lean.js
    rename to pr-1815/assets/how-to-guides_celestia-app-multisig.md.e890db6c.lean.js
    index fb2f5d190..8b4756278 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-multisig.md.0242053f.lean.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-multisig.md.e890db6c.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Multisig | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-multisig.md","filePath":"how-to-guides/celestia-app-multisig.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/celestia-app-multisig.md"},o=l("",7),e=[o];function t(c,r,y,E,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{d as __pageData,u as default};
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Multisig | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-multisig.md","filePath":"how-to-guides/celestia-app-multisig.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/celestia-app-multisig.md"},o=l("",7),e=[o];function t(c,r,y,E,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{d as __pageData,u as default};
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-slashing.md.d65d1c8a.js b/pr-1815/assets/how-to-guides_celestia-app-slashing.md.4d08bcea.js
    similarity index 97%
    rename from pr-1815/assets/how-to-guides_celestia-app-slashing.md.d65d1c8a.js
    rename to pr-1815/assets/how-to-guides_celestia-app-slashing.md.4d08bcea.js
    index 22c2bcd93..0f29221c8 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-slashing.md.d65d1c8a.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-slashing.md.4d08bcea.js
    @@ -1 +1 @@
    -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Jailing and slashing on Celestia","description":"This section covers the jailing and slashing mechanics for validators in Celestia.","frontmatter":{"description":"This section covers the jailing and slashing mechanics for validators in Celestia.","head":[["meta",{"property":"og:title","content":"Jailing and slashing on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"This section covers the jailing and slashing mechanics for validators in Celestia."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-slashing.md","filePath":"how-to-guides/celestia-app-slashing.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/celestia-app-slashing.md"},o=i('

    Jailing and slashing on Celestia

    Slashing is a mechanism employed in proof of stake blockchains that is used to deter and punish malicious behavior. It functions by removing a percentage of a validator's stake each time they act harmfully towards the network.

    Celestia is built with the Cosmos SDK and uses the x/slashing module.

    If a validator gets slashed, delegators bonded to that validator will also have the same percentage of their delegated funds slashed.

    The following are the conditions for a validator to get jailed or slashed:

    1. Downtime: If a validator is offline for more than 25% of a rolling window of the last 5,000 blocks, they will be jailed for 1 minute. During this period, the validator is removed from the validator set temporarily, and will be unable to propose new blocks or earn rewards. After the jail period, the validator can send an unjail request to rejoin the validator set.

    2. Double signing: This is a more severe offense and results in getting slashed. If a validator engages in double signing, the validator will lose 2% of their stake and the remainder of their stake will be returned to them. The validator will be permanently removed from the validator set and will not have the ability to unjail. Delegators bonded to that validator will automatically enter the unbonding period for 21 days, and can delegate to another validator after they have been unbonded.

    For more details on the jailing and slashing parameters, refer to the celestia-app specifications page.

    ',7),n=[o];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(s,[["render",l]]);export{f as __pageData,u as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Jailing and slashing on Celestia","description":"This section covers the jailing and slashing mechanics for validators in Celestia.","frontmatter":{"description":"This section covers the jailing and slashing mechanics for validators in Celestia.","head":[["meta",{"property":"og:title","content":"Jailing and slashing on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"This section covers the jailing and slashing mechanics for validators in Celestia."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-slashing.md","filePath":"how-to-guides/celestia-app-slashing.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/celestia-app-slashing.md"},o=i('

    Jailing and slashing on Celestia

    Slashing is a mechanism employed in proof of stake blockchains that is used to deter and punish malicious behavior. It functions by removing a percentage of a validator's stake each time they act harmfully towards the network.

    Celestia is built with the Cosmos SDK and uses the x/slashing module.

    If a validator gets slashed, delegators bonded to that validator will also have the same percentage of their delegated funds slashed.

    The following are the conditions for a validator to get jailed or slashed:

    1. Downtime: If a validator is offline for more than 25% of a rolling window of the last 5,000 blocks, they will be jailed for 1 minute. During this period, the validator is removed from the validator set temporarily, and will be unable to propose new blocks or earn rewards. After the jail period, the validator can send an unjail request to rejoin the validator set.

    2. Double signing: This is a more severe offense and results in getting slashed. If a validator engages in double signing, the validator will lose 2% of their stake and the remainder of their stake will be returned to them. The validator will be permanently removed from the validator set and will not have the ability to unjail. Delegators bonded to that validator will automatically enter the unbonding period for 21 days, and can delegate to another validator after they have been unbonded.

    For more details on the jailing and slashing parameters, refer to the celestia-app specifications page.

    ',7),n=[o];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(s,[["render",l]]);export{f as __pageData,u as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app-slashing.md.d65d1c8a.lean.js b/pr-1815/assets/how-to-guides_celestia-app-slashing.md.4d08bcea.lean.js similarity index 93% rename from pr-1815/assets/how-to-guides_celestia-app-slashing.md.d65d1c8a.lean.js rename to pr-1815/assets/how-to-guides_celestia-app-slashing.md.4d08bcea.lean.js index 40cdf65f6..f18929786 100644 --- a/pr-1815/assets/how-to-guides_celestia-app-slashing.md.d65d1c8a.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-app-slashing.md.4d08bcea.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Jailing and slashing on Celestia","description":"This section covers the jailing and slashing mechanics for validators in Celestia.","frontmatter":{"description":"This section covers the jailing and slashing mechanics for validators in Celestia.","head":[["meta",{"property":"og:title","content":"Jailing and slashing on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"This section covers the jailing and slashing mechanics for validators in Celestia."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-slashing.md","filePath":"how-to-guides/celestia-app-slashing.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/celestia-app-slashing.md"},o=i("",7),n=[o];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(s,[["render",l]]);export{f as __pageData,u as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Jailing and slashing on Celestia","description":"This section covers the jailing and slashing mechanics for validators in Celestia.","frontmatter":{"description":"This section covers the jailing and slashing mechanics for validators in Celestia.","head":[["meta",{"property":"og:title","content":"Jailing and slashing on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"This section covers the jailing and slashing mechanics for validators in Celestia."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-slashing.md","filePath":"how-to-guides/celestia-app-slashing.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/celestia-app-slashing.md"},o=i("",7),n=[o];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(s,[["render",l]]);export{f as __pageData,u as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.js b/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.js similarity index 95% rename from pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.js rename to pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.js index fc3d8b6b9..22681e792 100644 --- a/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.js +++ b/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.js @@ -1 +1 @@ -import{_ as o,o as a,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Upgrade Monitor","description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","frontmatter":{"description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","head":[["meta",{"property":"og:title","content":"Upgrade Monitor | Celestia Docs"}],["meta",{"property":"og:description","content":"upgrade-monitor is a tool to monitor upgrades on a Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-upgrade-monitor.md","filePath":"how-to-guides/celestia-app-upgrade-monitor.md","lastUpdated":1732776394000}'),n={name:"how-to-guides/celestia-app-upgrade-monitor.md"},i=e("h1",{id:"upgrade-monitor",tabindex:"-1"},[t("Upgrade Monitor "),e("a",{class:"header-anchor",href:"#upgrade-monitor","aria-label":'Permalink to "Upgrade Monitor"'},"​")],-1),s=e("p",null,[t("Upgrade monitor is a binary that monitors that status of upgrades on a Celestia network. See the "),e("a",{href:"https://github.com/celestiaorg/upgrade-monitor",target:"_blank",rel:"noreferrer"},"README"),t(" for instructions on how to install and use the binary.")],-1),p=[i,s];function d(c,l,g,m,u,h){return a(),r("div",null,p)}const k=o(n,[["render",d]]);export{f as __pageData,k as default}; +import{_ as o,o as a,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Upgrade Monitor","description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","frontmatter":{"description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","head":[["meta",{"property":"og:title","content":"Upgrade Monitor | Celestia Docs"}],["meta",{"property":"og:description","content":"upgrade-monitor is a tool to monitor upgrades on a Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-upgrade-monitor.md","filePath":"how-to-guides/celestia-app-upgrade-monitor.md","lastUpdated":1732777479000}'),n={name:"how-to-guides/celestia-app-upgrade-monitor.md"},i=e("h1",{id:"upgrade-monitor",tabindex:"-1"},[t("Upgrade Monitor "),e("a",{class:"header-anchor",href:"#upgrade-monitor","aria-label":'Permalink to "Upgrade Monitor"'},"​")],-1),s=e("p",null,[t("Upgrade monitor is a binary that monitors that status of upgrades on a Celestia network. See the "),e("a",{href:"https://github.com/celestiaorg/upgrade-monitor",target:"_blank",rel:"noreferrer"},"README"),t(" for instructions on how to install and use the binary.")],-1),p=[i,s];function d(c,l,g,m,u,h){return a(),r("div",null,p)}const k=o(n,[["render",d]]);export{f as __pageData,k as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.lean.js b/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.lean.js similarity index 95% rename from pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.lean.js rename to pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.lean.js index fc3d8b6b9..22681e792 100644 --- a/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.8386e67a.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-app-upgrade-monitor.md.2dd4f678.lean.js @@ -1 +1 @@ -import{_ as o,o as a,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Upgrade Monitor","description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","frontmatter":{"description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","head":[["meta",{"property":"og:title","content":"Upgrade Monitor | Celestia Docs"}],["meta",{"property":"og:description","content":"upgrade-monitor is a tool to monitor upgrades on a Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-upgrade-monitor.md","filePath":"how-to-guides/celestia-app-upgrade-monitor.md","lastUpdated":1732776394000}'),n={name:"how-to-guides/celestia-app-upgrade-monitor.md"},i=e("h1",{id:"upgrade-monitor",tabindex:"-1"},[t("Upgrade Monitor "),e("a",{class:"header-anchor",href:"#upgrade-monitor","aria-label":'Permalink to "Upgrade Monitor"'},"​")],-1),s=e("p",null,[t("Upgrade monitor is a binary that monitors that status of upgrades on a Celestia network. See the "),e("a",{href:"https://github.com/celestiaorg/upgrade-monitor",target:"_blank",rel:"noreferrer"},"README"),t(" for instructions on how to install and use the binary.")],-1),p=[i,s];function d(c,l,g,m,u,h){return a(),r("div",null,p)}const k=o(n,[["render",d]]);export{f as __pageData,k as default}; +import{_ as o,o as a,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Upgrade Monitor","description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","frontmatter":{"description":"upgrade-monitor is a tool to monitor upgrades on a Celestia network.","head":[["meta",{"property":"og:title","content":"Upgrade Monitor | Celestia Docs"}],["meta",{"property":"og:description","content":"upgrade-monitor is a tool to monitor upgrades on a Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-upgrade-monitor.md","filePath":"how-to-guides/celestia-app-upgrade-monitor.md","lastUpdated":1732777479000}'),n={name:"how-to-guides/celestia-app-upgrade-monitor.md"},i=e("h1",{id:"upgrade-monitor",tabindex:"-1"},[t("Upgrade Monitor "),e("a",{class:"header-anchor",href:"#upgrade-monitor","aria-label":'Permalink to "Upgrade Monitor"'},"​")],-1),s=e("p",null,[t("Upgrade monitor is a binary that monitors that status of upgrades on a Celestia network. See the "),e("a",{href:"https://github.com/celestiaorg/upgrade-monitor",target:"_blank",rel:"noreferrer"},"README"),t(" for instructions on how to install and use the binary.")],-1),p=[i,s];function d(c,l,g,m,u,h){return a(),r("div",null,p)}const k=o(n,[["render",d]]);export{f as __pageData,k as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b7b33049.js b/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b9f23b75.js similarity index 99% rename from pr-1815/assets/how-to-guides_celestia-app-vesting.md.b7b33049.js rename to pr-1815/assets/how-to-guides_celestia-app-vesting.md.b9f23b75.js index 7eee3f960..ab601e220 100644 --- a/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b7b33049.js +++ b/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b9f23b75.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"How to create a vesting account with celestia-app","description":"Learn how to generate a vesting account using celestia-app.","frontmatter":{"description":"Learn how to generate a vesting account using celestia-app.","head":[["meta",{"property":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a vesting account using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-vesting.md","filePath":"how-to-guides/celestia-app-vesting.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/celestia-app-vesting.md"},p=o(`

    How to create a vesting account with celestia-app

    In this guide, we will learn how to create a vesting account using celestia-app for both a local devnet and on Mocha testnet.

    note

    The instructions for this tutorial are for a continuous vesting account, if you'd like to make a delayed vesting account, just add the --delayed flag to your vesting transaction.

    Local devnet

    First, download and install celestia-app, selecting the network and corresponding version that you would like to use.

    Setting up the local devnet

    Run the devnet

    Next, change into the $HOME/celestia-app directory and run the single-node-devnet script.

    bash
    cd $HOME/celestia-app
    +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"How to create a vesting account with celestia-app","description":"Learn how to generate a vesting account using celestia-app.","frontmatter":{"description":"Learn how to generate a vesting account using celestia-app.","head":[["meta",{"property":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a vesting account using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-vesting.md","filePath":"how-to-guides/celestia-app-vesting.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/celestia-app-vesting.md"},p=o(`

    How to create a vesting account with celestia-app

    In this guide, we will learn how to create a vesting account using celestia-app for both a local devnet and on Mocha testnet.

    note

    The instructions for this tutorial are for a continuous vesting account, if you'd like to make a delayed vesting account, just add the --delayed flag to your vesting transaction.

    Local devnet

    First, download and install celestia-app, selecting the network and corresponding version that you would like to use.

    Setting up the local devnet

    Run the devnet

    Next, change into the $HOME/celestia-app directory and run the single-node-devnet script.

    bash
    cd $HOME/celestia-app
     ./scripts/build-run-single-node.sh
    cd $HOME/celestia-app
     ./scripts/build-run-single-node.sh

    Save the home directory path

    At the top of the output, you will see a path to the "Home directory", find yours from the output (it will be unique every time):

    bash
    ./scripts/build-run-single-node.sh
     Home directory: /var/folders/_8/ljj6hspn0kn09qf9fy8kdyh40000gn/T/celestia_app_XXXXXXXXXXXXX.XV92a3qx
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b7b33049.lean.js b/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b9f23b75.lean.js
    similarity index 92%
    rename from pr-1815/assets/how-to-guides_celestia-app-vesting.md.b7b33049.lean.js
    rename to pr-1815/assets/how-to-guides_celestia-app-vesting.md.b9f23b75.lean.js
    index 4de31be5d..431877dbe 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b7b33049.lean.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-vesting.md.b9f23b75.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"How to create a vesting account with celestia-app","description":"Learn how to generate a vesting account using celestia-app.","frontmatter":{"description":"Learn how to generate a vesting account using celestia-app.","head":[["meta",{"property":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a vesting account using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-vesting.md","filePath":"how-to-guides/celestia-app-vesting.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/celestia-app-vesting.md"},p=o("",99),e=[p];function t(c,r,y,E,i,F){return a(),n("div",null,e)}const h=s(l,[["render",t]]);export{u as __pageData,h as default};
    +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"How to create a vesting account with celestia-app","description":"Learn how to generate a vesting account using celestia-app.","frontmatter":{"description":"Learn how to generate a vesting account using celestia-app.","head":[["meta",{"property":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a vesting account using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-vesting.md","filePath":"how-to-guides/celestia-app-vesting.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/celestia-app-vesting.md"},p=o("",99),e=[p];function t(c,r,y,E,i,F){return a(),n("div",null,e)}const h=s(l,[["render",t]]);export{u as __pageData,h as default};
    diff --git a/pr-1815/assets/how-to-guides_celestia-app-wallet.md.98ae1a8e.js b/pr-1815/assets/how-to-guides_celestia-app-wallet.md.81ff3a65.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_celestia-app-wallet.md.98ae1a8e.js
    rename to pr-1815/assets/how-to-guides_celestia-app-wallet.md.81ff3a65.js
    index 65aec688b..0ddc384a6 100644
    --- a/pr-1815/assets/how-to-guides_celestia-app-wallet.md.98ae1a8e.js
    +++ b/pr-1815/assets/how-to-guides_celestia-app-wallet.md.81ff3a65.js
    @@ -1,3 +1,3 @@
    -import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Create a wallet with celestia-app","description":"Learn how to generate a Celestia wallet using celestia-app.","frontmatter":{"description":"Learn how to generate a Celestia wallet using celestia-app.","head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a Celestia wallet using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-wallet.md","filePath":"how-to-guides/celestia-app-wallet.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/celestia-app-wallet.md"},o=t(`

    Create a wallet with celestia-app

    For this guide, we will go over how you can generate a Celestia wallet using celestia-app.

    Prerequisites

    Note, you do not need to install celestia-node for this tutorial.

    Create a wallet

    First, create an application CLI configuration file:

    sh
    celestia-appd config keyring-backend test
    celestia-appd config keyring-backend test

    You can pick whatever wallet name you want. For our example we used "validator" as the wallet name:

    sh
    celestia-appd keys add validator --interactive
    celestia-appd keys add validator --interactive

    Save the mnemonic output as this is the only way to recover your validator wallet in case you lose it!

    To check all your wallets you can run:

    sh
    celestia-appd keys list
    celestia-appd keys list

    Fund a wallet

    For the public celestia address, you can fund the previously created wallet via Discord by sending this message to either the #mocha-faucet or #arabica-faucet channel:

    text
    $request celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    $request celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

    Wait to see if you get a confirmation that the tokens have been successfully sent. To check if tokens have arrived successfully to the destination wallet run the command below replacing the public address with your own:

    sh
    celestia-appd start
    +import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Create a wallet with celestia-app","description":"Learn how to generate a Celestia wallet using celestia-app.","frontmatter":{"description":"Learn how to generate a Celestia wallet using celestia-app.","head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a Celestia wallet using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-wallet.md","filePath":"how-to-guides/celestia-app-wallet.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/celestia-app-wallet.md"},o=t(`

    Create a wallet with celestia-app

    For this guide, we will go over how you can generate a Celestia wallet using celestia-app.

    Prerequisites

    Note, you do not need to install celestia-node for this tutorial.

    Create a wallet

    First, create an application CLI configuration file:

    sh
    celestia-appd config keyring-backend test
    celestia-appd config keyring-backend test

    You can pick whatever wallet name you want. For our example we used "validator" as the wallet name:

    sh
    celestia-appd keys add validator --interactive
    celestia-appd keys add validator --interactive

    Save the mnemonic output as this is the only way to recover your validator wallet in case you lose it!

    To check all your wallets you can run:

    sh
    celestia-appd keys list
    celestia-appd keys list

    Fund a wallet

    For the public celestia address, you can fund the previously created wallet via Discord by sending this message to either the #mocha-faucet or #arabica-faucet channel:

    text
    $request celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    $request celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

    Wait to see if you get a confirmation that the tokens have been successfully sent. To check if tokens have arrived successfully to the destination wallet run the command below replacing the public address with your own:

    sh
    celestia-appd start
     celestia-appd query bank balances celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    celestia-appd start
     celestia-appd query bank balances celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    `,19),p=[o];function n(c,i,r,x,d,h){return e(),s("div",null,p)}const E=a(l,[["render",n]]);export{u as __pageData,E as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app-wallet.md.98ae1a8e.lean.js b/pr-1815/assets/how-to-guides_celestia-app-wallet.md.81ff3a65.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_celestia-app-wallet.md.98ae1a8e.lean.js rename to pr-1815/assets/how-to-guides_celestia-app-wallet.md.81ff3a65.lean.js index 21f518b37..c813848c1 100644 --- a/pr-1815/assets/how-to-guides_celestia-app-wallet.md.98ae1a8e.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-app-wallet.md.81ff3a65.lean.js @@ -1 +1 @@ -import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Create a wallet with celestia-app","description":"Learn how to generate a Celestia wallet using celestia-app.","frontmatter":{"description":"Learn how to generate a Celestia wallet using celestia-app.","head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a Celestia wallet using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-wallet.md","filePath":"how-to-guides/celestia-app-wallet.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/celestia-app-wallet.md"},o=t("",19),p=[o];function n(c,i,r,x,d,h){return e(),s("div",null,p)}const E=a(l,[["render",n]]);export{u as __pageData,E as default}; +import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"Create a wallet with celestia-app","description":"Learn how to generate a Celestia wallet using celestia-app.","frontmatter":{"description":"Learn how to generate a Celestia wallet using celestia-app.","head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to generate a Celestia wallet using celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app-wallet.md","filePath":"how-to-guides/celestia-app-wallet.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/celestia-app-wallet.md"},o=t("",19),p=[o];function n(c,i,r,x,d,h){return e(),s("div",null,p)}const E=a(l,[["render",n]]);export{u as __pageData,E as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app.md.a9e559b1.js b/pr-1815/assets/how-to-guides_celestia-app.md.e81846ef.js similarity index 90% rename from pr-1815/assets/how-to-guides_celestia-app.md.a9e559b1.js rename to pr-1815/assets/how-to-guides_celestia-app.md.e81846ef.js index da7629409..8aebbe3af 100644 --- a/pr-1815/assets/how-to-guides_celestia-app.md.a9e559b1.js +++ b/pr-1815/assets/how-to-guides_celestia-app.md.e81846ef.js @@ -4,4 +4,4 @@ import{a as o}from"./chunks/arabica_versions.8cd8d43b.js";import{m as l}from"./c cd celestia-app
    cd $HOME
     rm -rf celestia-app
     git clone https://github.com/celestiaorg/celestia-app.git
    -cd celestia-app
  4. `,1),d=s("p",null,"Check out to the desired version, based on the network you will use:",-1),h={class:"vp-code-group vp-adaptive-theme"},_=a('
    ',1),u={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),g=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},m={class:"line"},F=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),v=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),f=s("span",{style:{color:"#E1E4E8"}}," ",-1),k={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},w={class:"line"},T=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),I=s("span",{style:{color:"#032F62"}},"checkout",-1),A=s("span",{style:{color:"#24292E"}}," ",-1),S={style:{color:"#032F62"}},V={class:"language-bash vp-adaptive-theme"},q=s("button",{title:"Copy Code",class:"copy"},null,-1),D=s("span",{class:"lang"},"bash",-1),L={class:"shiki github-dark vp-code-dark"},M={class:"line"},x=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),N=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),O=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},U={class:"line"},Y=s("span",{style:{color:"#6F42C1"}},"git",-1),j=s("span",{style:{color:"#24292E"}}," ",-1),z=s("span",{style:{color:"#032F62"}},"checkout",-1),J=s("span",{style:{color:"#24292E"}}," ",-1),Q={style:{color:"#032F62"}},W={class:"language-bash vp-adaptive-theme"},G=s("button",{title:"Copy Code",class:"copy"},null,-1),K=s("span",{class:"lang"},"bash",-1),X={class:"shiki github-dark vp-code-dark"},Z={class:"line"},ss=s("span",{style:{color:"#B392F0"}},"git",-1),es=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},ps=s("span",{style:{color:"#6F42C1"}},"git",-1),is=s("span",{style:{color:"#24292E"}}," ",-1),cs=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=a('
  5. Build and install the celestia-appd binary:

    bash
    make install
    make install
  6. To check if the binary was successfully installed you can run the binary using the --help flag:

    sh
    celestia-appd --help
    celestia-appd --help
  7. ',2),_s=a('

    You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia consensus node. Releases after celestia-app v1.3.0 should have these binaries available.

    The steps below will download a binary file named celestia-appd. Depending on the setup that you choose during installation, the celestia-appd binary will be available at either:

    • $HOME/celestia-app-temp/celestia-appd
    • /usr/local/bin/celestia-appd

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    To install the latest pre-built binary you can run this command in your terminal:

    bash
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"

    Follow the instructions in the terminal output to choose your installation preferences.

    You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    View the script to learn more about what it is doing.

    Ports

    When interacting with a consensus node, you may need to open ports on your machine to allow communication between nodes, such as bridge nodes. It is essential that specific ports are accessible. Make sure that your firewall allows connections to the correct ports.

    If you run a node on a cloud server, make sure that the ports are open on the server's firewall. If you run a node at home, make sure that your router allows connections to the correct ports.

    For example, validator ports 9090 and 26657 need to be accessible by the bridge, and port 2121 is required for P2P connections for all node types.

    The following ports are used by Celestia app nodes:

    PortProtocolAddressDescriptionEnabled by default on nodeFlag
    2121TCP/UDPlocalhostP2PtrueN/A
    9090HTTP0.0.0.0gRPCtrue--grpc.address string
    26657TCPlocalhostRPCfalse (only open to localhost)--rpc.laddr string
    ',18),vs=JSON.parse('{"title":"Install celestia-app","description":"Learn how you can build celestia-app.","frontmatter":{"description":"Learn how you can build celestia-app.","head":[["meta",{"property":"og:title","content":"Install celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how you can build celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app.md","filePath":"how-to-guides/celestia-app.md","lastUpdated":1732776394000}'),us={name:"how-to-guides/celestia-app.md"},fs=Object.assign(us,{setup(ys){return(bs,gs)=>(p(),i("div",null,[c,s("ol",null,[r,s("li",null,[d,s("div",h,[_,s("div",u,[s("div",y,[b,g,s("pre",E,[s("code",null,[s("span",m,[F,C,v,f,s("span",k,"tags/"+e(t(n)["app-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",w,[T,P,I,A,s("span",S,"tags/"+e(t(n)["app-latest-tag"]),1)])])])]),s("div",V,[q,D,s("pre",L,[s("code",null,[s("span",M,[x,R,N,O,s("span",$,"tags/"+e(t(l)["app-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",U,[Y,j,z,J,s("span",Q,"tags/"+e(t(l)["app-latest-tag"]),1)])])])]),s("div",W,[G,K,s("pre",X,[s("code",null,[s("span",Z,[ss,es,ts,as,s("span",os,"tags/"+e(t(o)["app-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[ps,is,cs,rs,s("span",ds,"tags/"+e(t(o)["app-latest-tag"]),1)])])])])])])]),hs]),_s]))}});export{vs as __pageData,fs as default}; +cd celestia-app
`,1),d=s("p",null,"Check out to the desired version, based on the network you will use:",-1),h={class:"vp-code-group vp-adaptive-theme"},_=a('
',1),u={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),g=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},m={class:"line"},F=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),v=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),f=s("span",{style:{color:"#E1E4E8"}}," ",-1),k={style:{color:"#9ECBFF"}},w={class:"shiki github-light vp-code-light"},T={class:"line"},B=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),I=s("span",{style:{color:"#032F62"}},"checkout",-1),A=s("span",{style:{color:"#24292E"}}," ",-1),S={style:{color:"#032F62"}},V={class:"language-bash vp-adaptive-theme"},q=s("button",{title:"Copy Code",class:"copy"},null,-1),D=s("span",{class:"lang"},"bash",-1),L={class:"shiki github-dark vp-code-dark"},x={class:"line"},R=s("span",{style:{color:"#B392F0"}},"git",-1),N=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),O=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},Y={class:"line"},Q=s("span",{style:{color:"#6F42C1"}},"git",-1),W=s("span",{style:{color:"#24292E"}}," ",-1),G=s("span",{style:{color:"#032F62"}},"checkout",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),j={style:{color:"#032F62"}},J={class:"language-bash vp-adaptive-theme"},z=s("button",{title:"Copy Code",class:"copy"},null,-1),K=s("span",{class:"lang"},"bash",-1),X={class:"shiki github-dark vp-code-dark"},Z={class:"line"},ss=s("span",{style:{color:"#B392F0"}},"git",-1),es=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},ps=s("span",{style:{color:"#6F42C1"}},"git",-1),is=s("span",{style:{color:"#24292E"}}," ",-1),cs=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=a('
  • Build and install the celestia-appd binary:

    bash
    make install
    make install
  • To check if the binary was successfully installed you can run the binary using the --help flag:

    sh
    celestia-appd --help
    celestia-appd --help
  • ',2),_s=a('

    You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia consensus node. Releases after celestia-app v1.3.0 should have these binaries available.

    The steps below will download a binary file named celestia-appd. Depending on the setup that you choose during installation, the celestia-appd binary will be available at either:

    • $HOME/celestia-app-temp/celestia-appd
    • /usr/local/bin/celestia-appd

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    To install the latest pre-built binary you can run this command in your terminal:

    bash
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"

    Follow the instructions in the terminal output to choose your installation preferences.

    You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    View the script to learn more about what it is doing.

    Ports

    When interacting with a consensus node, you may need to open ports on your machine to allow communication between nodes, such as bridge nodes. It is essential that specific ports are accessible. Make sure that your firewall allows connections to the correct ports.

    If you run a node on a cloud server, make sure that the ports are open on the server's firewall. If you run a node at home, make sure that your router allows connections to the correct ports.

    For example, validator ports 9090 and 26657 need to be accessible by the bridge, and port 2121 is required for P2P connections for all node types.

    The following ports are used by Celestia app nodes:

    PortProtocolAddressDescriptionEnabled by default on nodeFlag
    2121TCP/UDPlocalhostP2PtrueN/A
    9090HTTP0.0.0.0gRPCtrue--grpc.address string
    26657TCPlocalhostRPCfalse (only open to localhost)--rpc.laddr string
    ',18),vs=JSON.parse('{"title":"Install celestia-app","description":"Learn how you can build celestia-app.","frontmatter":{"description":"Learn how you can build celestia-app.","head":[["meta",{"property":"og:title","content":"Install celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how you can build celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app.md","filePath":"how-to-guides/celestia-app.md","lastUpdated":1732777479000}'),us={name:"how-to-guides/celestia-app.md"},fs=Object.assign(us,{setup(ys){return(bs,gs)=>(p(),i("div",null,[c,s("ol",null,[r,s("li",null,[d,s("div",h,[_,s("div",u,[s("div",y,[b,g,s("pre",E,[s("code",null,[s("span",m,[F,C,v,f,s("span",k,"tags/"+e(t(n)["app-latest-tag"]),1)])])]),s("pre",w,[s("code",null,[s("span",T,[B,P,I,A,s("span",S,"tags/"+e(t(n)["app-latest-tag"]),1)])])])]),s("div",V,[q,D,s("pre",L,[s("code",null,[s("span",x,[R,N,M,O,s("span",$,"tags/"+e(t(l)["app-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",Y,[Q,W,G,U,s("span",j,"tags/"+e(t(l)["app-latest-tag"]),1)])])])]),s("div",J,[z,K,s("pre",X,[s("code",null,[s("span",Z,[ss,es,ts,as,s("span",os,"tags/"+e(t(o)["app-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[ps,is,cs,rs,s("span",ds,"tags/"+e(t(o)["app-latest-tag"]),1)])])])])])])]),hs]),_s]))}});export{vs as __pageData,fs as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-app.md.a9e559b1.lean.js b/pr-1815/assets/how-to-guides_celestia-app.md.e81846ef.lean.js similarity index 73% rename from pr-1815/assets/how-to-guides_celestia-app.md.a9e559b1.lean.js rename to pr-1815/assets/how-to-guides_celestia-app.md.e81846ef.lean.js index 208525036..b09f328d4 100644 --- a/pr-1815/assets/how-to-guides_celestia-app.md.a9e559b1.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-app.md.e81846ef.lean.js @@ -1 +1 @@ -import{a as o}from"./chunks/arabica_versions.8cd8d43b.js";import{m as l}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as n}from"./chunks/mainnet_versions.f2c187e6.js";import{o as p,c as i,k as s,t as e,l as t,Q as a}from"./chunks/framework.2959b752.js";const c=a("",6),r=a("",1),d=s("p",null,"Check out to the desired version, based on the network you will use:",-1),h={class:"vp-code-group vp-adaptive-theme"},_=a("",1),u={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),g=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},m={class:"line"},F=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),v=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),f=s("span",{style:{color:"#E1E4E8"}}," ",-1),k={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},w={class:"line"},T=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),I=s("span",{style:{color:"#032F62"}},"checkout",-1),A=s("span",{style:{color:"#24292E"}}," ",-1),S={style:{color:"#032F62"}},V={class:"language-bash vp-adaptive-theme"},q=s("button",{title:"Copy Code",class:"copy"},null,-1),D=s("span",{class:"lang"},"bash",-1),L={class:"shiki github-dark vp-code-dark"},M={class:"line"},x=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),N=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),O=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},U={class:"line"},Y=s("span",{style:{color:"#6F42C1"}},"git",-1),j=s("span",{style:{color:"#24292E"}}," ",-1),z=s("span",{style:{color:"#032F62"}},"checkout",-1),J=s("span",{style:{color:"#24292E"}}," ",-1),Q={style:{color:"#032F62"}},W={class:"language-bash vp-adaptive-theme"},G=s("button",{title:"Copy Code",class:"copy"},null,-1),K=s("span",{class:"lang"},"bash",-1),X={class:"shiki github-dark vp-code-dark"},Z={class:"line"},ss=s("span",{style:{color:"#B392F0"}},"git",-1),es=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},ps=s("span",{style:{color:"#6F42C1"}},"git",-1),is=s("span",{style:{color:"#24292E"}}," ",-1),cs=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=a("",2),_s=a("",18),vs=JSON.parse('{"title":"Install celestia-app","description":"Learn how you can build celestia-app.","frontmatter":{"description":"Learn how you can build celestia-app.","head":[["meta",{"property":"og:title","content":"Install celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how you can build celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app.md","filePath":"how-to-guides/celestia-app.md","lastUpdated":1732776394000}'),us={name:"how-to-guides/celestia-app.md"},fs=Object.assign(us,{setup(ys){return(bs,gs)=>(p(),i("div",null,[c,s("ol",null,[r,s("li",null,[d,s("div",h,[_,s("div",u,[s("div",y,[b,g,s("pre",E,[s("code",null,[s("span",m,[F,C,v,f,s("span",k,"tags/"+e(t(n)["app-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",w,[T,P,I,A,s("span",S,"tags/"+e(t(n)["app-latest-tag"]),1)])])])]),s("div",V,[q,D,s("pre",L,[s("code",null,[s("span",M,[x,R,N,O,s("span",$,"tags/"+e(t(l)["app-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",U,[Y,j,z,J,s("span",Q,"tags/"+e(t(l)["app-latest-tag"]),1)])])])]),s("div",W,[G,K,s("pre",X,[s("code",null,[s("span",Z,[ss,es,ts,as,s("span",os,"tags/"+e(t(o)["app-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[ps,is,cs,rs,s("span",ds,"tags/"+e(t(o)["app-latest-tag"]),1)])])])])])])]),hs]),_s]))}});export{vs as __pageData,fs as default}; +import{a as o}from"./chunks/arabica_versions.8cd8d43b.js";import{m as l}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as n}from"./chunks/mainnet_versions.f2c187e6.js";import{o as p,c as i,k as s,t as e,l as t,Q as a}from"./chunks/framework.2959b752.js";const c=a("",6),r=a("",1),d=s("p",null,"Check out to the desired version, based on the network you will use:",-1),h={class:"vp-code-group vp-adaptive-theme"},_=a("",1),u={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),g=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},m={class:"line"},F=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),v=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),f=s("span",{style:{color:"#E1E4E8"}}," ",-1),k={style:{color:"#9ECBFF"}},w={class:"shiki github-light vp-code-light"},T={class:"line"},B=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),I=s("span",{style:{color:"#032F62"}},"checkout",-1),A=s("span",{style:{color:"#24292E"}}," ",-1),S={style:{color:"#032F62"}},V={class:"language-bash vp-adaptive-theme"},q=s("button",{title:"Copy Code",class:"copy"},null,-1),D=s("span",{class:"lang"},"bash",-1),L={class:"shiki github-dark vp-code-dark"},x={class:"line"},R=s("span",{style:{color:"#B392F0"}},"git",-1),N=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),O=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},Y={class:"line"},Q=s("span",{style:{color:"#6F42C1"}},"git",-1),W=s("span",{style:{color:"#24292E"}}," ",-1),G=s("span",{style:{color:"#032F62"}},"checkout",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),j={style:{color:"#032F62"}},J={class:"language-bash vp-adaptive-theme"},z=s("button",{title:"Copy Code",class:"copy"},null,-1),K=s("span",{class:"lang"},"bash",-1),X={class:"shiki github-dark vp-code-dark"},Z={class:"line"},ss=s("span",{style:{color:"#B392F0"}},"git",-1),es=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},ps=s("span",{style:{color:"#6F42C1"}},"git",-1),is=s("span",{style:{color:"#24292E"}}," ",-1),cs=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=a("",2),_s=a("",18),vs=JSON.parse('{"title":"Install celestia-app","description":"Learn how you can build celestia-app.","frontmatter":{"description":"Learn how you can build celestia-app.","head":[["meta",{"property":"og:title","content":"Install celestia-app | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how you can build celestia-app."}]]},"headers":[],"relativePath":"how-to-guides/celestia-app.md","filePath":"how-to-guides/celestia-app.md","lastUpdated":1732777479000}'),us={name:"how-to-guides/celestia-app.md"},fs=Object.assign(us,{setup(ys){return(bs,gs)=>(p(),i("div",null,[c,s("ol",null,[r,s("li",null,[d,s("div",h,[_,s("div",u,[s("div",y,[b,g,s("pre",E,[s("code",null,[s("span",m,[F,C,v,f,s("span",k,"tags/"+e(t(n)["app-latest-tag"]),1)])])]),s("pre",w,[s("code",null,[s("span",T,[B,P,I,A,s("span",S,"tags/"+e(t(n)["app-latest-tag"]),1)])])])]),s("div",V,[q,D,s("pre",L,[s("code",null,[s("span",x,[R,N,M,O,s("span",$,"tags/"+e(t(l)["app-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",Y,[Q,W,G,U,s("span",j,"tags/"+e(t(l)["app-latest-tag"]),1)])])])]),s("div",J,[z,K,s("pre",X,[s("code",null,[s("span",Z,[ss,es,ts,as,s("span",os,"tags/"+e(t(o)["app-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[ps,is,cs,rs,s("span",ds,"tags/"+e(t(o)["app-latest-tag"]),1)])])])])])])]),hs]),_s]))}});export{vs as __pageData,fs as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.a43d9768.js b/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.3d44971b.js similarity index 99% rename from pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.a43d9768.js rename to pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.3d44971b.js index 172dcb078..56e272d0d 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.a43d9768.js +++ b/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.3d44971b.js @@ -1 +1 @@ -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const F=JSON.parse('{"title":"Custom networks and values","description":"Learn about custom networks and values on celestia-node.","frontmatter":{"description":"Learn about custom networks and values on celestia-node.","head":[["meta",{"property":"og:title","content":"Custom networks and values | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about custom networks and values on celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-custom-networks.md","filePath":"how-to-guides/celestia-node-custom-networks.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/celestia-node-custom-networks.md"},l=n('

    Custom networks and values

    This section will cover importing bootstrapper IDs, chain ID, and network ID. This will allow you to import custom values for a chain that is not in the default configuration.

    If you have a custom network you can export CELESTIA_CUSTOM, which will look something like:

    bash
    export BRIDGE="/ip4/<ip-address>/tcp/2121/p2p/<node-ID>"\nexport GENESIS_HASH=<genesis-hash>\nexport NETWORK=<network-name>\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"
    export BRIDGE="/ip4/<ip-address>/tcp/2121/p2p/<node-ID>"\nexport GENESIS_HASH=<genesis-hash>\nexport NETWORK=<network-name>\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"

    Query your node ID using the RPC CLI. These values with examples would look like:

    bash
    export BRIDGE="/ip4/151.115.14.33/tcp/2121/p2p/12D3KooWKEeRtzVMPUdxYsZo2edqps6mS67n6LT5mPdULSkPSxBQ"\nexport GENESIS_HASH=580B3DFF8A7C716968161D91116A1E171F486298D582874E93714E489C9E6E88\nexport NETWORK=custom\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"
    export BRIDGE="/ip4/151.115.14.33/tcp/2121/p2p/12D3KooWKEeRtzVMPUdxYsZo2edqps6mS67n6LT5mPdULSkPSxBQ"\nexport GENESIS_HASH=580B3DFF8A7C716968161D91116A1E171F486298D582874E93714E489C9E6E88\nexport NETWORK=custom\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"

    Then, start your node with:

    bash
    celestia <node-type> start [flags...]
    celestia <node-type> start [flags...]
    ',8),e=[l];function t(c,r,E,y,i,d){return a(),o("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default}; +import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const F=JSON.parse('{"title":"Custom networks and values","description":"Learn about custom networks and values on celestia-node.","frontmatter":{"description":"Learn about custom networks and values on celestia-node.","head":[["meta",{"property":"og:title","content":"Custom networks and values | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about custom networks and values on celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-custom-networks.md","filePath":"how-to-guides/celestia-node-custom-networks.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/celestia-node-custom-networks.md"},l=n('

    Custom networks and values

    This section will cover importing bootstrapper IDs, chain ID, and network ID. This will allow you to import custom values for a chain that is not in the default configuration.

    If you have a custom network you can export CELESTIA_CUSTOM, which will look something like:

    bash
    export BRIDGE="/ip4/<ip-address>/tcp/2121/p2p/<node-ID>"\nexport GENESIS_HASH=<genesis-hash>\nexport NETWORK=<network-name>\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"
    export BRIDGE="/ip4/<ip-address>/tcp/2121/p2p/<node-ID>"\nexport GENESIS_HASH=<genesis-hash>\nexport NETWORK=<network-name>\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"

    Query your node ID using the RPC CLI. These values with examples would look like:

    bash
    export BRIDGE="/ip4/151.115.14.33/tcp/2121/p2p/12D3KooWKEeRtzVMPUdxYsZo2edqps6mS67n6LT5mPdULSkPSxBQ"\nexport GENESIS_HASH=580B3DFF8A7C716968161D91116A1E171F486298D582874E93714E489C9E6E88\nexport NETWORK=custom\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"
    export BRIDGE="/ip4/151.115.14.33/tcp/2121/p2p/12D3KooWKEeRtzVMPUdxYsZo2edqps6mS67n6LT5mPdULSkPSxBQ"\nexport GENESIS_HASH=580B3DFF8A7C716968161D91116A1E171F486298D582874E93714E489C9E6E88\nexport NETWORK=custom\nexport CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"

    Then, start your node with:

    bash
    celestia <node-type> start [flags...]
    celestia <node-type> start [flags...]
    ',8),e=[l];function t(c,r,E,y,i,d){return a(),o("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.a43d9768.lean.js b/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.3d44971b.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.a43d9768.lean.js rename to pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.3d44971b.lean.js index 261e9fadc..702fe99f1 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.a43d9768.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-node-custom-networks.md.3d44971b.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const F=JSON.parse('{"title":"Custom networks and values","description":"Learn about custom networks and values on celestia-node.","frontmatter":{"description":"Learn about custom networks and values on celestia-node.","head":[["meta",{"property":"og:title","content":"Custom networks and values | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about custom networks and values on celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-custom-networks.md","filePath":"how-to-guides/celestia-node-custom-networks.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/celestia-node-custom-networks.md"},l=n("",8),e=[l];function t(c,r,E,y,i,d){return a(),o("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default}; +import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.2959b752.js";const F=JSON.parse('{"title":"Custom networks and values","description":"Learn about custom networks and values on celestia-node.","frontmatter":{"description":"Learn about custom networks and values on celestia-node.","head":[["meta",{"property":"og:title","content":"Custom networks and values | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about custom networks and values on celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-custom-networks.md","filePath":"how-to-guides/celestia-node-custom-networks.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/celestia-node-custom-networks.md"},l=n("",8),e=[l];function t(c,r,E,y,i,d){return a(),o("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6be6e0bb.js b/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6a48093e.js similarity index 99% rename from pr-1815/assets/how-to-guides_celestia-node-metrics.md.6be6e0bb.js rename to pr-1815/assets/how-to-guides_celestia-node-metrics.md.6a48093e.js index dbf3044fa..54b633faa 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6be6e0bb.js +++ b/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6a48093e.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"celestia-node metrics","description":"A guide on how to run metrics for your celestia-node DA instance.","frontmatter":{"description":"A guide on how to run metrics for your celestia-node DA instance.","head":[["meta",{"property":"og:title","content":"celestia-node metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run metrics for your celestia-node DA instance."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-metrics.md","filePath":"how-to-guides/celestia-node-metrics.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/celestia-node-metrics.md"},e=o(`

    celestia-node metrics

    This tutorial is for running metrics for your celestia-node data availability instance. This tutorial will focus on running metrics for a light node.

    This tutorial assumes you have already setup your light node by following the tutorial in the celestia-node API tutorial.

    Running metrics flags

    You can enable the celestia-node metric flags with the following command:

    sh
    celestia <node-type> start --metrics.tls=<boolean> \\
    +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"celestia-node metrics","description":"A guide on how to run metrics for your celestia-node DA instance.","frontmatter":{"description":"A guide on how to run metrics for your celestia-node DA instance.","head":[["meta",{"property":"og:title","content":"celestia-node metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run metrics for your celestia-node DA instance."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-metrics.md","filePath":"how-to-guides/celestia-node-metrics.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/celestia-node-metrics.md"},e=o(`

    celestia-node metrics

    This tutorial is for running metrics for your celestia-node data availability instance. This tutorial will focus on running metrics for a light node.

    This tutorial assumes you have already setup your light node by following the tutorial in the celestia-node API tutorial.

    Running metrics flags

    You can enable the celestia-node metric flags with the following command:

    sh
    celestia <node-type> start --metrics.tls=<boolean> \\
         --metrics --metrics.endpoint <URI> \\
         --p2p.network <network> --core.ip <URI>
    celestia <node-type> start --metrics.tls=<boolean> \\
         --metrics --metrics.endpoint <URI> \\
    diff --git a/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6be6e0bb.lean.js b/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6a48093e.lean.js
    similarity index 92%
    rename from pr-1815/assets/how-to-guides_celestia-node-metrics.md.6be6e0bb.lean.js
    rename to pr-1815/assets/how-to-guides_celestia-node-metrics.md.6a48093e.lean.js
    index 03955aad5..2f63ad43b 100644
    --- a/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6be6e0bb.lean.js
    +++ b/pr-1815/assets/how-to-guides_celestia-node-metrics.md.6a48093e.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"celestia-node metrics","description":"A guide on how to run metrics for your celestia-node DA instance.","frontmatter":{"description":"A guide on how to run metrics for your celestia-node DA instance.","head":[["meta",{"property":"og:title","content":"celestia-node metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run metrics for your celestia-node DA instance."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-metrics.md","filePath":"how-to-guides/celestia-node-metrics.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/celestia-node-metrics.md"},e=o("",30),p=[e];function t(c,r,y,i,E,d){return a(),n("div",null,p)}const C=s(l,[["render",t]]);export{h as __pageData,C as default};
    +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"celestia-node metrics","description":"A guide on how to run metrics for your celestia-node DA instance.","frontmatter":{"description":"A guide on how to run metrics for your celestia-node DA instance.","head":[["meta",{"property":"og:title","content":"celestia-node metrics | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide on how to run metrics for your celestia-node DA instance."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-metrics.md","filePath":"how-to-guides/celestia-node-metrics.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/celestia-node-metrics.md"},e=o("",30),p=[e];function t(c,r,y,i,E,d){return a(),n("div",null,p)}const C=s(l,[["render",t]]);export{h as __pageData,C as default};
    diff --git a/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.f13dec0a.js b/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.63b1cd30.js
    similarity index 98%
    rename from pr-1815/assets/how-to-guides_celestia-node-store-structure.md.f13dec0a.js
    rename to pr-1815/assets/how-to-guides_celestia-node-store-structure.md.63b1cd30.js
    index 910b1cc47..1c9ef3493 100644
    --- a/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.f13dec0a.js
    +++ b/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.63b1cd30.js
    @@ -1 +1 @@
    -import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"celestia-node datastore","description":"This section contains information on the celestia-node datastore and its contents.","frontmatter":{"description":"This section contains information on the celestia-node datastore and its contents.","head":[["meta",{"property":"og:title","content":"celestia-node datastore | Celestia Docs"}],["meta",{"property":"og:description","content":"This section contains information on the celestia-node datastore and its contents."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-store-structure.md","filePath":"how-to-guides/celestia-node-store-structure.md","lastUpdated":1732776394000}'),i={name:"how-to-guides/celestia-node-store-structure.md"},a=s('

    celestia-node datastore

    The node's datastore refers to the storage structure used to manage the data that supports the node's operation. It consists of directories and files that contain the node's state, configuration, and other information relevant to the node.

    The following are the directories and files found in the datastore:

    • /blocks: This directory stores blocks. Each file contained in this directory represents a block on Celestia and contains its associated data. This directory is present in the datastore for bridge and full nodes but not light nodes, as light nodes do not store blocks.

    • /data: This directory contains block headers and various files belonging to the node's log-structured merge (LSM) storage system. The LSM files (such as DISCARD, KEYREGISTRY, and MANIFEST) manage the efficient storage and retrieval of data.

    • /index: This directory stores the index files that handle mapping specific keys such as block heights, to the corresponding data. Similar to /blocks, the light node's datastore does not include this directory, as they do not perform indexing.

    • /inverted_index: This directory stores the inverted index files used for mapping queries to the corresponding data location, along with associated LSM storage system files. The light node's datastore does not contain this directory.

    • /keys: This directory stores the cryptographic key pairs that are used to operate the node.

    • /transients: This directory contains temporary data such as cache files that are used while the node is operating, but are not a part of the permanent blockchain state.

    • config.toml: Located in the node's root directory, this is the primary configuration file that defines core settings such as network parameters, P2P configuration, and API endpoints. This file is generated during node initialization.

    ',4),n=[a];function r(d,c,l,h,p,u){return t(),o("div",null,n)}const m=e(i,[["render",r]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"celestia-node datastore","description":"This section contains information on the celestia-node datastore and its contents.","frontmatter":{"description":"This section contains information on the celestia-node datastore and its contents.","head":[["meta",{"property":"og:title","content":"celestia-node datastore | Celestia Docs"}],["meta",{"property":"og:description","content":"This section contains information on the celestia-node datastore and its contents."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-store-structure.md","filePath":"how-to-guides/celestia-node-store-structure.md","lastUpdated":1732777479000}'),i={name:"how-to-guides/celestia-node-store-structure.md"},a=s('

    celestia-node datastore

    The node's datastore refers to the storage structure used to manage the data that supports the node's operation. It consists of directories and files that contain the node's state, configuration, and other information relevant to the node.

    The following are the directories and files found in the datastore:

    • /blocks: This directory stores blocks. Each file contained in this directory represents a block on Celestia and contains its associated data. This directory is present in the datastore for bridge and full nodes but not light nodes, as light nodes do not store blocks.

    • /data: This directory contains block headers and various files belonging to the node's log-structured merge (LSM) storage system. The LSM files (such as DISCARD, KEYREGISTRY, and MANIFEST) manage the efficient storage and retrieval of data.

    • /index: This directory stores the index files that handle mapping specific keys such as block heights, to the corresponding data. Similar to /blocks, the light node's datastore does not include this directory, as they do not perform indexing.

    • /inverted_index: This directory stores the inverted index files used for mapping queries to the corresponding data location, along with associated LSM storage system files. The light node's datastore does not contain this directory.

    • /keys: This directory stores the cryptographic key pairs that are used to operate the node.

    • /transients: This directory contains temporary data such as cache files that are used while the node is operating, but are not a part of the permanent blockchain state.

    • config.toml: Located in the node's root directory, this is the primary configuration file that defines core settings such as network parameters, P2P configuration, and API endpoints. This file is generated during node initialization.

    ',4),n=[a];function r(d,c,l,h,p,u){return t(),o("div",null,n)}const m=e(i,[["render",r]]);export{g as __pageData,m as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.f13dec0a.lean.js b/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.63b1cd30.lean.js similarity index 93% rename from pr-1815/assets/how-to-guides_celestia-node-store-structure.md.f13dec0a.lean.js rename to pr-1815/assets/how-to-guides_celestia-node-store-structure.md.63b1cd30.lean.js index dc4980a8a..dbf751bac 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.f13dec0a.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-node-store-structure.md.63b1cd30.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"celestia-node datastore","description":"This section contains information on the celestia-node datastore and its contents.","frontmatter":{"description":"This section contains information on the celestia-node datastore and its contents.","head":[["meta",{"property":"og:title","content":"celestia-node datastore | Celestia Docs"}],["meta",{"property":"og:description","content":"This section contains information on the celestia-node datastore and its contents."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-store-structure.md","filePath":"how-to-guides/celestia-node-store-structure.md","lastUpdated":1732776394000}'),i={name:"how-to-guides/celestia-node-store-structure.md"},a=s("",4),n=[a];function r(d,c,l,h,p,u){return t(),o("div",null,n)}const m=e(i,[["render",r]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"celestia-node datastore","description":"This section contains information on the celestia-node datastore and its contents.","frontmatter":{"description":"This section contains information on the celestia-node datastore and its contents.","head":[["meta",{"property":"og:title","content":"celestia-node datastore | Celestia Docs"}],["meta",{"property":"og:description","content":"This section contains information on the celestia-node datastore and its contents."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-store-structure.md","filePath":"how-to-guides/celestia-node-store-structure.md","lastUpdated":1732777479000}'),i={name:"how-to-guides/celestia-node-store-structure.md"},a=s("",4),n=[a];function r(d,c,l,h,p,u){return t(),o("div",null,n)}const m=e(i,[["render",r]]);export{g as __pageData,m as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.28daa8cd.js b/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.js similarity index 99% rename from pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.28daa8cd.js rename to pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.js index f4f91e7e8..df12c6406 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.28daa8cd.js +++ b/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.js @@ -58,4 +58,4 @@ import{c as n}from"./chunks/constants.b02263eb.js";import{o as p,c as t,k as s,a ...
    [Service]
     ...
     LimitNOFILE=1400000
    -...

    NOTE

    Be cautious when increasing file descriptor limits. Setting this value too high might affect system performance. Ensure the value is appropriate for your system's capabilities.

    1. Reload daemon and restart bridge service:
    bash
    sudo systemctl daemon-reload
    sudo systemctl daemon-reload
    bash
    sudo systemctl restart celestia-bridge
    sudo systemctl restart celestia-bridge
    `,70),A=JSON.parse('{"title":"Troubleshooting","description":"A guide to troubleshooting common issues with Celestia Node.","frontmatter":{"description":"A guide to troubleshooting common issues with Celestia Node.","next":{"text":"Metrics, visualization, and alerts","link":"how-to-guides/celestia-app-metrics"},"head":[["meta",{"property":"og:title","content":"Troubleshooting | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to troubleshooting common issues with Celestia Node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-troubleshooting.md","filePath":"how-to-guides/celestia-node-troubleshooting.md","lastUpdated":1732776394000}'),b={name:"how-to-guides/celestia-node-troubleshooting.md"},w=Object.assign(b,{setup(B){return(m,k)=>(p(),t("div",null,[r,s("p",null,[a("When interacting with celestia-node, it is important to take into account the different chain IDs for different networks. For Mainnet Beta, there is no need to declare a chain ID, as the default is "+o(l(n).mainnetChainId)+", ",1),c,a(" no "),i,a(" flag is required for Mainnet Beta.")]),s("table",null,[y,s("tbody",null,[s("tr",null,[E,s("td",null,o(l(n).mainnetChainId),1),d]),s("tr",null,[h,s("td",null,o(l(n).mochaChainId),1),F]),s("tr",null,[u,s("td",null,o(l(n).arabicaChainId),1),g])])]),C]))}});export{A as __pageData,w as default}; +...

    NOTE

    Be cautious when increasing file descriptor limits. Setting this value too high might affect system performance. Ensure the value is appropriate for your system's capabilities.

    1. Reload daemon and restart bridge service:
    bash
    sudo systemctl daemon-reload
    sudo systemctl daemon-reload
    bash
    sudo systemctl restart celestia-bridge
    sudo systemctl restart celestia-bridge
    `,70),A=JSON.parse('{"title":"Troubleshooting","description":"A guide to troubleshooting common issues with Celestia Node.","frontmatter":{"description":"A guide to troubleshooting common issues with Celestia Node.","next":{"text":"Metrics, visualization, and alerts","link":"how-to-guides/celestia-app-metrics"},"head":[["meta",{"property":"og:title","content":"Troubleshooting | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to troubleshooting common issues with Celestia Node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-troubleshooting.md","filePath":"how-to-guides/celestia-node-troubleshooting.md","lastUpdated":1732777479000}'),b={name:"how-to-guides/celestia-node-troubleshooting.md"},w=Object.assign(b,{setup(B){return(m,k)=>(p(),t("div",null,[r,s("p",null,[a("When interacting with celestia-node, it is important to take into account the different chain IDs for different networks. For Mainnet Beta, there is no need to declare a chain ID, as the default is "+o(l(n).mainnetChainId)+", ",1),c,a(" no "),i,a(" flag is required for Mainnet Beta.")]),s("table",null,[y,s("tbody",null,[s("tr",null,[E,s("td",null,o(l(n).mainnetChainId),1),d]),s("tr",null,[h,s("td",null,o(l(n).mochaChainId),1),F]),s("tr",null,[u,s("td",null,o(l(n).arabicaChainId),1),g])])]),C]))}});export{A as __pageData,w as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.28daa8cd.lean.js b/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.lean.js similarity index 96% rename from pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.28daa8cd.lean.js rename to pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.lean.js index eaad0ed59..58e718f6c 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.28daa8cd.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-node-troubleshooting.md.3ef61dbb.lean.js @@ -1 +1 @@ -import{c as n}from"./chunks/constants.b02263eb.js";import{o as p,c as t,k as s,a,t as o,l,Q as e}from"./chunks/framework.2959b752.js";const r=e("",7),c=s("em",null,"i.e.",-1),i=s("code",null,"--p2p.network string",-1),y=s("thead",null,[s("tr",null,[s("th",null,"Network"),s("th",null,"Chain ID"),s("th",null,[s("code",null,"--p2p.network string")])])],-1),E=s("td",null,"Mainnet Beta",-1),d=s("td",null,[a("not required ("),s("code",null,"--p2p.network celestia"),a(")")],-1),h=s("td",null,"Mocha",-1),F=s("td",null,[s("code",null,"--p2p.network mocha")],-1),u=s("td",null,"Arabica",-1),g=s("td",null,[s("code",null,"--p2p.network arabica")],-1),C=e("",70),A=JSON.parse('{"title":"Troubleshooting","description":"A guide to troubleshooting common issues with Celestia Node.","frontmatter":{"description":"A guide to troubleshooting common issues with Celestia Node.","next":{"text":"Metrics, visualization, and alerts","link":"how-to-guides/celestia-app-metrics"},"head":[["meta",{"property":"og:title","content":"Troubleshooting | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to troubleshooting common issues with Celestia Node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-troubleshooting.md","filePath":"how-to-guides/celestia-node-troubleshooting.md","lastUpdated":1732776394000}'),b={name:"how-to-guides/celestia-node-troubleshooting.md"},w=Object.assign(b,{setup(B){return(m,k)=>(p(),t("div",null,[r,s("p",null,[a("When interacting with celestia-node, it is important to take into account the different chain IDs for different networks. For Mainnet Beta, there is no need to declare a chain ID, as the default is "+o(l(n).mainnetChainId)+", ",1),c,a(" no "),i,a(" flag is required for Mainnet Beta.")]),s("table",null,[y,s("tbody",null,[s("tr",null,[E,s("td",null,o(l(n).mainnetChainId),1),d]),s("tr",null,[h,s("td",null,o(l(n).mochaChainId),1),F]),s("tr",null,[u,s("td",null,o(l(n).arabicaChainId),1),g])])]),C]))}});export{A as __pageData,w as default}; +import{c as n}from"./chunks/constants.b02263eb.js";import{o as p,c as t,k as s,a,t as o,l,Q as e}from"./chunks/framework.2959b752.js";const r=e("",7),c=s("em",null,"i.e.",-1),i=s("code",null,"--p2p.network string",-1),y=s("thead",null,[s("tr",null,[s("th",null,"Network"),s("th",null,"Chain ID"),s("th",null,[s("code",null,"--p2p.network string")])])],-1),E=s("td",null,"Mainnet Beta",-1),d=s("td",null,[a("not required ("),s("code",null,"--p2p.network celestia"),a(")")],-1),h=s("td",null,"Mocha",-1),F=s("td",null,[s("code",null,"--p2p.network mocha")],-1),u=s("td",null,"Arabica",-1),g=s("td",null,[s("code",null,"--p2p.network arabica")],-1),C=e("",70),A=JSON.parse('{"title":"Troubleshooting","description":"A guide to troubleshooting common issues with Celestia Node.","frontmatter":{"description":"A guide to troubleshooting common issues with Celestia Node.","next":{"text":"Metrics, visualization, and alerts","link":"how-to-guides/celestia-app-metrics"},"head":[["meta",{"property":"og:title","content":"Troubleshooting | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to troubleshooting common issues with Celestia Node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-troubleshooting.md","filePath":"how-to-guides/celestia-node-troubleshooting.md","lastUpdated":1732777479000}'),b={name:"how-to-guides/celestia-node-troubleshooting.md"},w=Object.assign(b,{setup(B){return(m,k)=>(p(),t("div",null,[r,s("p",null,[a("When interacting with celestia-node, it is important to take into account the different chain IDs for different networks. For Mainnet Beta, there is no need to declare a chain ID, as the default is "+o(l(n).mainnetChainId)+", ",1),c,a(" no "),i,a(" flag is required for Mainnet Beta.")]),s("table",null,[y,s("tbody",null,[s("tr",null,[E,s("td",null,o(l(n).mainnetChainId),1),d]),s("tr",null,[h,s("td",null,o(l(n).mochaChainId),1),F]),s("tr",null,[u,s("td",null,o(l(n).arabicaChainId),1),g])])]),C]))}});export{A as __pageData,w as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.dcfb937e.js b/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.js similarity index 99% rename from pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.dcfb937e.js rename to pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.js index 2fe2b58c8..76b6eeed6 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.dcfb937e.js +++ b/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.js @@ -1,3 +1,3 @@ -import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Syncing a light node from a trusted hash","description":"How to sync a light node from a trusted hash.","frontmatter":{"description":"How to sync a light node from a trusted hash.","head":[["meta",{"property":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"}],["meta",{"property":"og:description","content":"How to sync a light node from a trusted hash."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-trusted-hash.md","filePath":"how-to-guides/celestia-node-trusted-hash.md","lastUpdated":1732776394000}'),t={name:"how-to-guides/celestia-node-trusted-hash.md"},n=e(`

    Syncing a light node from a trusted hash

    This guide goes over how to sync a DA light node from a trusted hash. The example is with Mainnet Beta. You will need to adjust the commands accordingly for Mocha, Arabica, or a custom network.

    WARNING

    Syncing to a trusted hash means that you will not sample the entire chain. This adds a trust assumption that you trust the history of the chain up to that point and that you trust the entity where you get the hash from. In this example, the trusted entity is a consensus endpoint or Celenium.

    1. Get trusted height & hash from a consensus endpoint or Celenium.

    2. Initialize the node store

      sh
      celestia light init --p2p.network <network>
      celestia light init --p2p.network <network>
    3. Set the trusted height & hash

      1. Open your config.toml at .celestia-light/config.toml (or .celestia-light-<other-network>/config.toml)
      2. Set DASer.SampleFrom to the trusted height (e.g. SampleFrom = 123456)
    4. Run the node with the hash and flag:

    sh
    celestia light start --headers.trusted-hash <hash_of_block_n> \\
    +import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Syncing a light node from a trusted hash","description":"How to sync a light node from a trusted hash.","frontmatter":{"description":"How to sync a light node from a trusted hash.","head":[["meta",{"property":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"}],["meta",{"property":"og:description","content":"How to sync a light node from a trusted hash."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-trusted-hash.md","filePath":"how-to-guides/celestia-node-trusted-hash.md","lastUpdated":1732777479000}'),t={name:"how-to-guides/celestia-node-trusted-hash.md"},n=e(`

    Syncing a light node from a trusted hash

    This guide goes over how to sync a DA light node from a trusted hash. The example is with Mainnet Beta. You will need to adjust the commands accordingly for Mocha, Arabica, or a custom network.

    WARNING

    Syncing to a trusted hash means that you will not sample the entire chain. This adds a trust assumption that you trust the history of the chain up to that point and that you trust the entity where you get the hash from. In this example, the trusted entity is a consensus endpoint or Celenium.

    1. Get trusted height & hash from a consensus endpoint or Celenium.

    2. Initialize the node store

      sh
      celestia light init --p2p.network <network>
      celestia light init --p2p.network <network>
    3. Set the trusted height & hash

      1. Open your config.toml at .celestia-light/config.toml (or .celestia-light-<other-network>/config.toml)
      2. Set DASer.SampleFrom to the trusted height (e.g. SampleFrom = 123456)
    4. Run the node with the hash and flag:

    sh
    celestia light start --headers.trusted-hash <hash_of_block_n> \\
         --p2p.network <network> --core.ip <consensus-node-rpc>
    celestia light start --headers.trusted-hash <hash_of_block_n> \\
         --p2p.network <network> --core.ip <consensus-node-rpc>

    For service operators

    If you're using multiple light nodes for similar services like tracking the same rollup, it is recommended to use the same hash and height for them all services using the same starting height.

    `,7),l=[n];function p(r,c,i,h,d,y){return a(),o("div",null,l)}const u=s(t,[["render",p]]);export{g as __pageData,u as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.dcfb937e.lean.js b/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.dcfb937e.lean.js rename to pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.lean.js index 91450371d..8f424c02b 100644 --- a/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.dcfb937e.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-node-trusted-hash.md.4e90c5a9.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Syncing a light node from a trusted hash","description":"How to sync a light node from a trusted hash.","frontmatter":{"description":"How to sync a light node from a trusted hash.","head":[["meta",{"property":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"}],["meta",{"property":"og:description","content":"How to sync a light node from a trusted hash."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-trusted-hash.md","filePath":"how-to-guides/celestia-node-trusted-hash.md","lastUpdated":1732776394000}'),t={name:"how-to-guides/celestia-node-trusted-hash.md"},n=e("",7),l=[n];function p(r,c,i,h,d,y){return a(),o("div",null,l)}const u=s(t,[["render",p]]);export{g as __pageData,u as default}; +import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Syncing a light node from a trusted hash","description":"How to sync a light node from a trusted hash.","frontmatter":{"description":"How to sync a light node from a trusted hash.","head":[["meta",{"property":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"}],["meta",{"property":"og:description","content":"How to sync a light node from a trusted hash."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node-trusted-hash.md","filePath":"how-to-guides/celestia-node-trusted-hash.md","lastUpdated":1732777479000}'),t={name:"how-to-guides/celestia-node-trusted-hash.md"},n=e("",7),l=[n];function p(r,c,i,h,d,y){return a(),o("div",null,l)}const u=s(t,[["render",p]]);export{g as __pageData,u as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node.md.a33fa5a8.js b/pr-1815/assets/how-to-guides_celestia-node.md.e06533d5.js similarity index 86% rename from pr-1815/assets/how-to-guides_celestia-node.md.a33fa5a8.js rename to pr-1815/assets/how-to-guides_celestia-node.md.e06533d5.js index 2a47da2e6..9d82b7e17 100644 --- a/pr-1815/assets/how-to-guides_celestia-node.md.a33fa5a8.js +++ b/pr-1815/assets/how-to-guides_celestia-node.md.e06533d5.js @@ -4,12 +4,12 @@ import{a as n}from"./chunks/arabica_versions.8cd8d43b.js";import{m as i}from"./c cd celestia-node/
    cd $HOME
     rm -rf celestia-node
     git clone https://github.com/celestiaorg/celestia-node.git
    -cd celestia-node/
    `,1),h=s("p",null,"Check out to the desired version, based on the network you will use:",-1),_={class:"vp-code-group vp-adaptive-theme"},y=e('
    ',1),u={class:"blocks"},g={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},m={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),T=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},A={class:"line"},I=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),S=s("span",{style:{color:"#032F62"}},"checkout",-1),V=s("span",{style:{color:"#24292E"}}," ",-1),w={style:{color:"#032F62"}},D={class:"language-bash vp-adaptive-theme"},q=s("button",{title:"Copy Code",class:"copy"},null,-1),x=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},R={class:"line"},O=s("span",{style:{color:"#B392F0"}},"git",-1),G=s("span",{style:{color:"#E1E4E8"}}," ",-1),L=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),M=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},j={class:"line"},K=s("span",{style:{color:"#6F42C1"}},"git",-1),Y=s("span",{style:{color:"#24292E"}}," ",-1),J=s("span",{style:{color:"#032F62"}},"checkout",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),Z={style:{color:"#032F62"}},Q={class:"language-bash vp-adaptive-theme"},z=s("button",{title:"Copy Code",class:"copy"},null,-1),W=s("span",{class:"lang"},"bash",-1),X={class:"shiki github-dark vp-code-dark"},ss={class:"line"},es=s("span",{style:{color:"#B392F0"}},"git",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ls={style:{color:"#9ECBFF"}},ns={class:"shiki github-light vp-code-light"},is={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"git",-1),ps=s("span",{style:{color:"#24292E"}}," ",-1),rs=s("span",{style:{color:"#032F62"}},"checkout",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},_s=e('
  • Build the celestia binary:

    a. Standard build

    bash
    make build
    make build

    b. Experimental build

    OPTIONAL

    If you're a node operator comfortable with experimental features and seeking optimal performance with minimal RAM usage, this option is recommended for you.

    bash
    make build-jemalloc
    make build-jemalloc

    This build option enables CGO, and downloads and installs jemalloc. Learn more about the build command.

  • Install the binary:

    bash
    make install
    make install
  • Build the cel-key utility:

    bash
    make cel-key
    make cel-key
  • Verify that the binary is working and check the version:

    bash
    celestia version
    celestia version
  • ',4),ys=e('

    The output will show the semantic version of celestia-node, commit hash, build date, system version, and Golang version.

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia data availability node. Releases after celestia-node v0.13.3 have these binaries available.

    The installation script will download a binary file named celestia. Depending on your chosen installation option, the celestia binary will be available at one of these locations:

    • $GOPATH/bin/celestia (if Go is installed)
    • /usr/local/bin/celestia
    • $HOME/celestia-node-temp/celestia

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    Installation Options

    You can install the latest version or specify a particular version:

    ',9),us={class:"language-bash vp-adaptive-theme"},gs=s("button",{title:"Copy Code",class:"copy"},null,-1),bs=s("span",{class:"lang"},"bash",-1),Es={class:"shiki github-dark vp-code-dark"},Fs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),ms=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"',1),vs=s("span",{class:"line"},null,-1),Cs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),ks={class:"line"},Ts=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)" -- -v ',14),fs={style:{color:"#9ECBFF"}},Bs={class:"shiki github-light vp-code-light"},As=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),Is=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"',1),Ps=s("span",{class:"line"},null,-1),Ss=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),Vs={class:"line"},ws=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)" -- -v ',14),Ds={style:{color:"#032F62"}},qs=e('

    The script will:

    1. Detect your system's operating system and architecture
    2. Download the appropriate binary
    3. Verify the checksum for security
    4. Provide installation location options based on your environment:
      • If Go is installed:
        • Go bin directory ($GOPATH/bin)
        • System bin directory (/usr/local/bin)
        • Keep in current directory
      • If Go is not installed:
        • System bin directory (/usr/local/bin)
        • Keep in current directory

    Follow the instructions in the terminal output to choose your installation preferences. After installation, you can verify the setup by checking the version:

    bash
    celestia version && celestia --help
    celestia version && celestia --help

    View the script to learn more about what it is doing.

    Note: The script maintains a log file at $HOME/celestia-node-temp/logfile.log for troubleshooting purposes.

    Next steps

    First, we recommend reading the overview of our node types, if you haven't yet.

    Now that you've installed Celestia Node, it's time to pick your node type and run your node!

    If you're planning to run a light node, we recommend the node RPC CLI tutorial.

    Upgrading your binary

    To upgrade your binary, you can install the latest version from the instructions above and restart your node. If you run into any issues, Refer to the troubleshooting section.

    ',12),Hs=JSON.parse('{"title":"Install celestia-node","description":"Learn to build and install celestia-node.","frontmatter":{"description":"Learn to build and install celestia-node.","head":[["meta",{"property":"og:title","content":"Install celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to build and install celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node.md","filePath":"how-to-guides/celestia-node.md","lastUpdated":1732776394000}'),xs={name:"how-to-guides/celestia-node.md"},js=Object.assign(xs,{setup(Ns){return(Rs,Os)=>(c(),p("div",null,[r,s("ol",null,[d,s("li",null,[h,s("div",_,[y,s("div",u,[s("div",g,[b,E,s("pre",F,[s("code",null,[s("span",m,[v,C,k,T,s("span",f,"tags/"+a(o(l)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",A,[I,P,S,V,s("span",w,"tags/"+a(o(l)["node-latest-tag"]),1)])])])]),s("div",D,[q,x,s("pre",N,[s("code",null,[s("span",R,[O,G,L,M,s("span",$,"tags/"+a(o(i)["node-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",j,[K,Y,J,U,s("span",Z,"tags/"+a(o(i)["node-latest-tag"]),1)])])])]),s("div",Q,[z,W,s("pre",X,[s("code",null,[s("span",ss,[es,as,os,ts,s("span",ls,"tags/"+a(o(n)["node-latest-tag"]),1)])])]),s("pre",ns,[s("code",null,[s("span",is,[cs,ps,rs,ds,s("span",hs,"tags/"+a(o(n)["node-latest-tag"]),1)])])])])])])]),_s]),ys,s("div",us,[gs,bs,s("pre",Es,[s("code",null,[Fs,t(` +cd celestia-node/
    `,1),h=s("p",null,"Check out to the desired version, based on the network you will use:",-1),_={class:"vp-code-group vp-adaptive-theme"},y=e('
    ',1),u={class:"blocks"},g={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},m={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),T=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},I={class:"line"},A=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),S=s("span",{style:{color:"#032F62"}},"checkout",-1),w=s("span",{style:{color:"#24292E"}}," ",-1),V={style:{color:"#032F62"}},q={class:"language-bash vp-adaptive-theme"},x=s("button",{title:"Copy Code",class:"copy"},null,-1),D=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},O={class:"line"},R=s("span",{style:{color:"#B392F0"}},"git",-1),L=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),$=s("span",{style:{color:"#E1E4E8"}}," ",-1),G={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},j={class:"line"},U=s("span",{style:{color:"#6F42C1"}},"git",-1),W=s("span",{style:{color:"#24292E"}}," ",-1),X=s("span",{style:{color:"#032F62"}},"checkout",-1),z=s("span",{style:{color:"#24292E"}}," ",-1),K={style:{color:"#032F62"}},Z={class:"language-bash vp-adaptive-theme"},J=s("button",{title:"Copy Code",class:"copy"},null,-1),Q=s("span",{class:"lang"},"bash",-1),Y={class:"shiki github-dark vp-code-dark"},ss={class:"line"},es=s("span",{style:{color:"#B392F0"}},"git",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ls={style:{color:"#9ECBFF"}},ns={class:"shiki github-light vp-code-light"},is={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"git",-1),ps=s("span",{style:{color:"#24292E"}}," ",-1),rs=s("span",{style:{color:"#032F62"}},"checkout",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},_s=e('
  • Build the celestia binary:

    a. Standard build

    bash
    make build
    make build

    b. Experimental build

    OPTIONAL

    If you're a node operator comfortable with experimental features and seeking optimal performance with minimal RAM usage, this option is recommended for you.

    bash
    make build-jemalloc
    make build-jemalloc

    This build option enables CGO, and downloads and installs jemalloc. Learn more about the build command.

  • Install the binary:

    bash
    make install
    make install
  • Build the cel-key utility:

    bash
    make cel-key
    make cel-key
  • Verify that the binary is working and check the version:

    bash
    celestia version
    celestia version
  • ',4),ys=e('

    The output will show the semantic version of celestia-node, commit hash, build date, system version, and Golang version.

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia data availability node. Releases after celestia-node v0.13.3 have these binaries available.

    The installation script will download a binary file named celestia. Depending on your chosen installation option, the celestia binary will be available at one of these locations:

    • $GOPATH/bin/celestia (if Go is installed)
    • /usr/local/bin/celestia
    • $HOME/celestia-node-temp/celestia

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    Installation Options

    You can install the latest version or specify a particular version:

    ',9),us={class:"language-bash vp-adaptive-theme"},gs=s("button",{title:"Copy Code",class:"copy"},null,-1),bs=s("span",{class:"lang"},"bash",-1),Es={class:"shiki github-dark vp-code-dark"},Fs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),ms=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"',1),vs=s("span",{class:"line"},null,-1),Cs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),ks={class:"line"},Ts=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)" -- -v ',14),fs={style:{color:"#9ECBFF"}},Bs={class:"shiki github-light vp-code-light"},Is=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),As=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"',1),Ps=s("span",{class:"line"},null,-1),Ss=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),ws={class:"line"},Vs=e('bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)" -- -v ',14),qs={style:{color:"#032F62"}},xs=e('

    The script will:

    1. Detect your system's operating system and architecture
    2. Download the appropriate binary
    3. Verify the checksum for security
    4. Provide installation location options based on your environment:
      • If Go is installed:
        • Go bin directory ($GOPATH/bin)
        • System bin directory (/usr/local/bin)
        • Keep in current directory
      • If Go is not installed:
        • System bin directory (/usr/local/bin)
        • Keep in current directory

    Follow the instructions in the terminal output to choose your installation preferences. After installation, you can verify the setup by checking the version:

    bash
    celestia version && celestia --help
    celestia version && celestia --help

    View the script to learn more about what it is doing.

    Note: The script maintains a log file at $HOME/celestia-node-temp/logfile.log for troubleshooting purposes.

    Next steps

    First, we recommend reading the overview of our node types, if you haven't yet.

    Now that you've installed Celestia Node, it's time to pick your node type and run your node!

    If you're planning to run a light node, we recommend the node RPC CLI tutorial.

    Upgrading your binary

    To upgrade your binary, you can install the latest version from the instructions above and restart your node. If you run into any issues, Refer to the troubleshooting section.

    ',12),Hs=JSON.parse('{"title":"Install celestia-node","description":"Learn to build and install celestia-node.","frontmatter":{"description":"Learn to build and install celestia-node.","head":[["meta",{"property":"og:title","content":"Install celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to build and install celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node.md","filePath":"how-to-guides/celestia-node.md","lastUpdated":1732777479000}'),Ds={name:"how-to-guides/celestia-node.md"},js=Object.assign(Ds,{setup(Ns){return(Os,Rs)=>(c(),p("div",null,[r,s("ol",null,[d,s("li",null,[h,s("div",_,[y,s("div",u,[s("div",g,[b,E,s("pre",F,[s("code",null,[s("span",m,[v,C,k,T,s("span",f,"tags/"+a(o(l)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",I,[A,P,S,w,s("span",V,"tags/"+a(o(l)["node-latest-tag"]),1)])])])]),s("div",q,[x,D,s("pre",N,[s("code",null,[s("span",O,[R,L,M,$,s("span",G,"tags/"+a(o(i)["node-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",j,[U,W,X,z,s("span",K,"tags/"+a(o(i)["node-latest-tag"]),1)])])])]),s("div",Z,[J,Q,s("pre",Y,[s("code",null,[s("span",ss,[es,as,os,ts,s("span",ls,"tags/"+a(o(n)["node-latest-tag"]),1)])])]),s("pre",ns,[s("code",null,[s("span",is,[cs,ps,rs,ds,s("span",hs,"tags/"+a(o(n)["node-latest-tag"]),1)])])])])])])]),_s]),ys,s("div",us,[gs,bs,s("pre",Es,[s("code",null,[Fs,t(` `),ms,t(` `),vs,t(` `),Cs,t(` -`),s("span",ks,[Ts,s("span",fs,a(o(l)["node-latest-tag"]),1)])])]),s("pre",Bs,[s("code",null,[As,t(` -`),Is,t(` +`),s("span",ks,[Ts,s("span",fs,a(o(l)["node-latest-tag"]),1)])])]),s("pre",Bs,[s("code",null,[Is,t(` +`),As,t(` `),Ps,t(` `),Ss,t(` -`),s("span",Vs,[ws,s("span",Ds,a(o(l)["node-latest-tag"]),1)])])])]),qs]))}});export{Hs as __pageData,js as default}; +`),s("span",ws,[Vs,s("span",qs,a(o(l)["node-latest-tag"]),1)])])])]),xs]))}});export{Hs as __pageData,js as default}; diff --git a/pr-1815/assets/how-to-guides_celestia-node.md.a33fa5a8.lean.js b/pr-1815/assets/how-to-guides_celestia-node.md.e06533d5.lean.js similarity index 60% rename from pr-1815/assets/how-to-guides_celestia-node.md.a33fa5a8.lean.js rename to pr-1815/assets/how-to-guides_celestia-node.md.e06533d5.lean.js index f4e741271..b3b040ac2 100644 --- a/pr-1815/assets/how-to-guides_celestia-node.md.a33fa5a8.lean.js +++ b/pr-1815/assets/how-to-guides_celestia-node.md.e06533d5.lean.js @@ -1,9 +1,9 @@ -import{a as n}from"./chunks/arabica_versions.8cd8d43b.js";import{m as i}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as l}from"./chunks/mainnet_versions.f2c187e6.js";import{o as c,c as p,k as s,t as a,l as o,a as t,Q as e}from"./chunks/framework.2959b752.js";const r=e("",4),d=e("",1),h=s("p",null,"Check out to the desired version, based on the network you will use:",-1),_={class:"vp-code-group vp-adaptive-theme"},y=e("",1),u={class:"blocks"},g={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},m={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),T=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},A={class:"line"},I=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),S=s("span",{style:{color:"#032F62"}},"checkout",-1),V=s("span",{style:{color:"#24292E"}}," ",-1),w={style:{color:"#032F62"}},D={class:"language-bash vp-adaptive-theme"},q=s("button",{title:"Copy Code",class:"copy"},null,-1),x=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},R={class:"line"},O=s("span",{style:{color:"#B392F0"}},"git",-1),G=s("span",{style:{color:"#E1E4E8"}}," ",-1),L=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),M=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},j={class:"line"},K=s("span",{style:{color:"#6F42C1"}},"git",-1),Y=s("span",{style:{color:"#24292E"}}," ",-1),J=s("span",{style:{color:"#032F62"}},"checkout",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),Z={style:{color:"#032F62"}},Q={class:"language-bash vp-adaptive-theme"},z=s("button",{title:"Copy Code",class:"copy"},null,-1),W=s("span",{class:"lang"},"bash",-1),X={class:"shiki github-dark vp-code-dark"},ss={class:"line"},es=s("span",{style:{color:"#B392F0"}},"git",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ls={style:{color:"#9ECBFF"}},ns={class:"shiki github-light vp-code-light"},is={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"git",-1),ps=s("span",{style:{color:"#24292E"}}," ",-1),rs=s("span",{style:{color:"#032F62"}},"checkout",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},_s=e("",4),ys=e("",9),us={class:"language-bash vp-adaptive-theme"},gs=s("button",{title:"Copy Code",class:"copy"},null,-1),bs=s("span",{class:"lang"},"bash",-1),Es={class:"shiki github-dark vp-code-dark"},Fs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),ms=e("",1),vs=s("span",{class:"line"},null,-1),Cs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),ks={class:"line"},Ts=e("",14),fs={style:{color:"#9ECBFF"}},Bs={class:"shiki github-light vp-code-light"},As=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),Is=e("",1),Ps=s("span",{class:"line"},null,-1),Ss=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),Vs={class:"line"},ws=e("",14),Ds={style:{color:"#032F62"}},qs=e("",12),Hs=JSON.parse('{"title":"Install celestia-node","description":"Learn to build and install celestia-node.","frontmatter":{"description":"Learn to build and install celestia-node.","head":[["meta",{"property":"og:title","content":"Install celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to build and install celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node.md","filePath":"how-to-guides/celestia-node.md","lastUpdated":1732776394000}'),xs={name:"how-to-guides/celestia-node.md"},js=Object.assign(xs,{setup(Ns){return(Rs,Os)=>(c(),p("div",null,[r,s("ol",null,[d,s("li",null,[h,s("div",_,[y,s("div",u,[s("div",g,[b,E,s("pre",F,[s("code",null,[s("span",m,[v,C,k,T,s("span",f,"tags/"+a(o(l)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",A,[I,P,S,V,s("span",w,"tags/"+a(o(l)["node-latest-tag"]),1)])])])]),s("div",D,[q,x,s("pre",N,[s("code",null,[s("span",R,[O,G,L,M,s("span",$,"tags/"+a(o(i)["node-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",j,[K,Y,J,U,s("span",Z,"tags/"+a(o(i)["node-latest-tag"]),1)])])])]),s("div",Q,[z,W,s("pre",X,[s("code",null,[s("span",ss,[es,as,os,ts,s("span",ls,"tags/"+a(o(n)["node-latest-tag"]),1)])])]),s("pre",ns,[s("code",null,[s("span",is,[cs,ps,rs,ds,s("span",hs,"tags/"+a(o(n)["node-latest-tag"]),1)])])])])])])]),_s]),ys,s("div",us,[gs,bs,s("pre",Es,[s("code",null,[Fs,t(` +import{a as n}from"./chunks/arabica_versions.8cd8d43b.js";import{m as i}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as l}from"./chunks/mainnet_versions.f2c187e6.js";import{o as c,c as p,k as s,t as a,l as o,a as t,Q as e}from"./chunks/framework.2959b752.js";const r=e("",4),d=e("",1),h=s("p",null,"Check out to the desired version, based on the network you will use:",-1),_={class:"vp-code-group vp-adaptive-theme"},y=e("",1),u={class:"blocks"},g={class:"language-bash vp-adaptive-theme active"},b=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},m={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),T=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},I={class:"line"},A=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),S=s("span",{style:{color:"#032F62"}},"checkout",-1),w=s("span",{style:{color:"#24292E"}}," ",-1),V={style:{color:"#032F62"}},q={class:"language-bash vp-adaptive-theme"},x=s("button",{title:"Copy Code",class:"copy"},null,-1),D=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},O={class:"line"},R=s("span",{style:{color:"#B392F0"}},"git",-1),L=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),$=s("span",{style:{color:"#E1E4E8"}}," ",-1),G={style:{color:"#9ECBFF"}},H={class:"shiki github-light vp-code-light"},j={class:"line"},U=s("span",{style:{color:"#6F42C1"}},"git",-1),W=s("span",{style:{color:"#24292E"}}," ",-1),X=s("span",{style:{color:"#032F62"}},"checkout",-1),z=s("span",{style:{color:"#24292E"}}," ",-1),K={style:{color:"#032F62"}},Z={class:"language-bash vp-adaptive-theme"},J=s("button",{title:"Copy Code",class:"copy"},null,-1),Q=s("span",{class:"lang"},"bash",-1),Y={class:"shiki github-dark vp-code-dark"},ss={class:"line"},es=s("span",{style:{color:"#B392F0"}},"git",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),os=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ls={style:{color:"#9ECBFF"}},ns={class:"shiki github-light vp-code-light"},is={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"git",-1),ps=s("span",{style:{color:"#24292E"}}," ",-1),rs=s("span",{style:{color:"#032F62"}},"checkout",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},_s=e("",4),ys=e("",9),us={class:"language-bash vp-adaptive-theme"},gs=s("button",{title:"Copy Code",class:"copy"},null,-1),bs=s("span",{class:"lang"},"bash",-1),Es={class:"shiki github-dark vp-code-dark"},Fs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),ms=e("",1),vs=s("span",{class:"line"},null,-1),Cs=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),ks={class:"line"},Ts=e("",14),fs={style:{color:"#9ECBFF"}},Bs={class:"shiki github-light vp-code-light"},Is=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install latest version")],-1),As=e("",1),Ps=s("span",{class:"line"},null,-1),Ss=s("span",{class:"line"},[s("span",{style:{color:"#6A737D"}},"# Install specific version, Mainnet Beta in this example")],-1),ws={class:"line"},Vs=e("",14),qs={style:{color:"#032F62"}},xs=e("",12),Hs=JSON.parse('{"title":"Install celestia-node","description":"Learn to build and install celestia-node.","frontmatter":{"description":"Learn to build and install celestia-node.","head":[["meta",{"property":"og:title","content":"Install celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to build and install celestia-node."}]]},"headers":[],"relativePath":"how-to-guides/celestia-node.md","filePath":"how-to-guides/celestia-node.md","lastUpdated":1732777479000}'),Ds={name:"how-to-guides/celestia-node.md"},js=Object.assign(Ds,{setup(Ns){return(Os,Rs)=>(c(),p("div",null,[r,s("ol",null,[d,s("li",null,[h,s("div",_,[y,s("div",u,[s("div",g,[b,E,s("pre",F,[s("code",null,[s("span",m,[v,C,k,T,s("span",f,"tags/"+a(o(l)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",I,[A,P,S,w,s("span",V,"tags/"+a(o(l)["node-latest-tag"]),1)])])])]),s("div",q,[x,D,s("pre",N,[s("code",null,[s("span",O,[R,L,M,$,s("span",G,"tags/"+a(o(i)["node-latest-tag"]),1)])])]),s("pre",H,[s("code",null,[s("span",j,[U,W,X,z,s("span",K,"tags/"+a(o(i)["node-latest-tag"]),1)])])])]),s("div",Z,[J,Q,s("pre",Y,[s("code",null,[s("span",ss,[es,as,os,ts,s("span",ls,"tags/"+a(o(n)["node-latest-tag"]),1)])])]),s("pre",ns,[s("code",null,[s("span",is,[cs,ps,rs,ds,s("span",hs,"tags/"+a(o(n)["node-latest-tag"]),1)])])])])])])]),_s]),ys,s("div",us,[gs,bs,s("pre",Es,[s("code",null,[Fs,t(` `),ms,t(` `),vs,t(` `),Cs,t(` -`),s("span",ks,[Ts,s("span",fs,a(o(l)["node-latest-tag"]),1)])])]),s("pre",Bs,[s("code",null,[As,t(` -`),Is,t(` +`),s("span",ks,[Ts,s("span",fs,a(o(l)["node-latest-tag"]),1)])])]),s("pre",Bs,[s("code",null,[Is,t(` +`),As,t(` `),Ps,t(` `),Ss,t(` -`),s("span",Vs,[ws,s("span",Ds,a(o(l)["node-latest-tag"]),1)])])])]),qs]))}});export{Hs as __pageData,js as default}; +`),s("span",ws,[Vs,s("span",qs,a(o(l)["node-latest-tag"]),1)])])])]),xs]))}});export{Hs as __pageData,js as default}; diff --git a/pr-1815/assets/how-to-guides_config-toml.md.e0e7af97.js b/pr-1815/assets/how-to-guides_config-toml.md.c55b64b5.js similarity index 98% rename from pr-1815/assets/how-to-guides_config-toml.md.e0e7af97.js rename to pr-1815/assets/how-to-guides_config-toml.md.c55b64b5.js index 3f55e5f23..a591fc4e3 100644 --- a/pr-1815/assets/how-to-guides_config-toml.md.e0e7af97.js +++ b/pr-1815/assets/how-to-guides_config-toml.md.c55b64b5.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"config.toml guide","description":"A guide to the contents of the Config.toml file.","frontmatter":{"description":"A guide to the contents of the Config.toml file.","head":[["meta",{"property":"og:title","content":"config.toml guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to the contents of the Config.toml file."}]]},"headers":[],"relativePath":"how-to-guides/config-toml.md","filePath":"how-to-guides/config-toml.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/config-toml.md"},i=a('

    config.toml guide

    Pre-requisites

    Please, make sure that you have installed and initialized celestia-node

    Viewing the help menu

    In order to view all flags and their descriptions, use:

    bash
    celestia light start --help
    celestia light start --help

    Understanding config.toml

    After initialization, for any type of node, you will find a config.toml in the following path (default location):

    • $HOME/.celestia-bridge/config.toml for bridge node
    • $HOME/.celestia-light/config.toml for light node
    • $HOME/.celestia-full/config.toml for a full DA node

    Let's break down some of the most used sections.

    Core

    This section is needed for the Celestia bridge node. By default, Remote = false. Still for devnet, we are going to use the remote core option and this can also be set by the command line flag --core.remote.

    P2P

    Bootstrap

    Bootstrappers help new nodes to find peers faster in the network. By default, the Bootstrapper = false and the BootstrapPeers is empty. If you want your node to be a bootstrapper, then activate Bootstrapper = true. BootstrapPeers are already provided by default during initialisation. If you want to add your own manually, you need to provide the multiaddresses of the peers.

    Mutual peers

    The purpose of this config is to set up a bidirectional communication. This is usually the case for Celestia bridge nodes. In addition, you need to change the field PeerExchange from false to true.

    Services

    TrustedHash and TrustedPeer

    TrustedHash is needed to properly initialize a Celestia bridge node with an already-running Remote celestia-core node. Celestia light node will take a genesis hash as the trusted one, if no hash is manually provided during initialization phase.

    TrustedPeers is the array of bridge nodes' peers that Celestia light node trusts. By default, bootstrap peers becomes trusted peers for Celestia light nodes if a user is not setting the trusted peer params in config file.

    Any Celestia bridge node can be a trusted peer for the light one. However, the light node by design can not be a trusted peer for another light node.

    ',22),n=[i];function r(l,d,c,h,p,u){return t(),o("div",null,n)}const m=e(s,[["render",r]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"config.toml guide","description":"A guide to the contents of the Config.toml file.","frontmatter":{"description":"A guide to the contents of the Config.toml file.","head":[["meta",{"property":"og:title","content":"config.toml guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to the contents of the Config.toml file."}]]},"headers":[],"relativePath":"how-to-guides/config-toml.md","filePath":"how-to-guides/config-toml.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/config-toml.md"},i=a('

    config.toml guide

    Pre-requisites

    Please, make sure that you have installed and initialized celestia-node

    Viewing the help menu

    In order to view all flags and their descriptions, use:

    bash
    celestia light start --help
    celestia light start --help

    Understanding config.toml

    After initialization, for any type of node, you will find a config.toml in the following path (default location):

    • $HOME/.celestia-bridge/config.toml for bridge node
    • $HOME/.celestia-light/config.toml for light node
    • $HOME/.celestia-full/config.toml for a full DA node

    Let's break down some of the most used sections.

    Core

    This section is needed for the Celestia bridge node. By default, Remote = false. Still for devnet, we are going to use the remote core option and this can also be set by the command line flag --core.remote.

    P2P

    Bootstrap

    Bootstrappers help new nodes to find peers faster in the network. By default, the Bootstrapper = false and the BootstrapPeers is empty. If you want your node to be a bootstrapper, then activate Bootstrapper = true. BootstrapPeers are already provided by default during initialisation. If you want to add your own manually, you need to provide the multiaddresses of the peers.

    Mutual peers

    The purpose of this config is to set up a bidirectional communication. This is usually the case for Celestia bridge nodes. In addition, you need to change the field PeerExchange from false to true.

    Services

    TrustedHash and TrustedPeer

    TrustedHash is needed to properly initialize a Celestia bridge node with an already-running Remote celestia-core node. Celestia light node will take a genesis hash as the trusted one, if no hash is manually provided during initialization phase.

    TrustedPeers is the array of bridge nodes' peers that Celestia light node trusts. By default, bootstrap peers becomes trusted peers for Celestia light nodes if a user is not setting the trusted peer params in config file.

    Any Celestia bridge node can be a trusted peer for the light one. However, the light node by design can not be a trusted peer for another light node.

    ',22),n=[i];function r(l,d,c,h,p,u){return t(),o("div",null,n)}const m=e(s,[["render",r]]);export{g as __pageData,m as default}; diff --git a/pr-1815/assets/how-to-guides_config-toml.md.e0e7af97.lean.js b/pr-1815/assets/how-to-guides_config-toml.md.c55b64b5.lean.js similarity index 91% rename from pr-1815/assets/how-to-guides_config-toml.md.e0e7af97.lean.js rename to pr-1815/assets/how-to-guides_config-toml.md.c55b64b5.lean.js index d86969bc2..ad919c713 100644 --- a/pr-1815/assets/how-to-guides_config-toml.md.e0e7af97.lean.js +++ b/pr-1815/assets/how-to-guides_config-toml.md.c55b64b5.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"config.toml guide","description":"A guide to the contents of the Config.toml file.","frontmatter":{"description":"A guide to the contents of the Config.toml file.","head":[["meta",{"property":"og:title","content":"config.toml guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to the contents of the Config.toml file."}]]},"headers":[],"relativePath":"how-to-guides/config-toml.md","filePath":"how-to-guides/config-toml.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/config-toml.md"},i=a("",22),n=[i];function r(l,d,c,h,p,u){return t(),o("div",null,n)}const m=e(s,[["render",r]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"config.toml guide","description":"A guide to the contents of the Config.toml file.","frontmatter":{"description":"A guide to the contents of the Config.toml file.","head":[["meta",{"property":"og:title","content":"config.toml guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide to the contents of the Config.toml file."}]]},"headers":[],"relativePath":"how-to-guides/config-toml.md","filePath":"how-to-guides/config-toml.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/config-toml.md"},i=a("",22),n=[i];function r(l,d,c,h,p,u){return t(),o("div",null,n)}const m=e(s,[["render",r]]);export{g as __pageData,m as default}; diff --git a/pr-1815/assets/how-to-guides_consensus-node.md.26d064fd.js b/pr-1815/assets/how-to-guides_consensus-node.md.a59f3838.js similarity index 92% rename from pr-1815/assets/how-to-guides_consensus-node.md.26d064fd.js rename to pr-1815/assets/how-to-guides_consensus-node.md.a59f3838.js index cd432b355..25fc7389b 100644 --- a/pr-1815/assets/how-to-guides_consensus-node.md.26d064fd.js +++ b/pr-1815/assets/how-to-guides_consensus-node.md.a59f3838.js @@ -1,10 +1,10 @@ -import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/consensus-node.jpg",r=o('

    Consensus node

    This guide covers how to set up a consensus node on Celestia. Consensus nodes allow you to sync the entire blockchain history in the Celestia consensus layer.

    consensus node

    Minimum hardware requirements

    The following minimum hardware requirements are recommended for running a consensus node:

    • Memory: 16 GB RAM
    • CPU: Quad-Core
    • Disk: 2 TB SSD Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Set up a consensus node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up the dependencies

    Follow the instructions on installing dependencies.

    Install celestia-app

    Follow the tutorial on installing celestia-app.

    Set up the P2P networks

    To initialize the network, pick a "node-name" that describes your node. Keep in mind that this might change if a new testnet is deployed.

    ',14),i={class:"vp-code-group vp-adaptive-theme"},d=o('
    ',1),_={class:"blocks"},h={class:"language-bash vp-adaptive-theme active"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},F={class:"line"},g=o('celestia-appd init "node-name" --chain-id ',8),C={style:{color:"#9ECBFF"}},b={class:"shiki github-light vp-code-light"},T={class:"line"},m=o('celestia-appd init "node-name" --chain-id ',8),S={style:{color:"#032F62"}},v={class:"language-bash vp-adaptive-theme"},k=s("button",{title:"Copy Code",class:"copy"},null,-1),B=s("span",{class:"lang"},"bash",-1),A={class:"shiki github-dark vp-code-dark"},f={class:"line"},q=o('celestia-appd init "node-name" --chain-id ',8),P={style:{color:"#9ECBFF"}},I={class:"shiki github-light vp-code-light"},x={class:"line"},V=o('celestia-appd init "node-name" --chain-id ',8),R={style:{color:"#032F62"}},D={class:"language-bash vp-adaptive-theme"},w=s("button",{title:"Copy Code",class:"copy"},null,-1),N=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},M={class:"line"},O=o('celestia-appd init "node-name" --chain-id ',8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},Q={class:"line"},j=o('celestia-appd init "node-name" --chain-id ',8),U={style:{color:"#032F62"}},z=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),G={class:"vp-code-group vp-adaptive-theme"},J=o('
    ',1),K={class:"blocks"},Y={class:"language-bash vp-adaptive-theme active"},X=s("button",{title:"Copy Code",class:"copy"},null,-1),Z=s("span",{class:"lang"},"bash",-1),W={class:"shiki github-dark vp-code-dark"},ss={class:"line"},os=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),es=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),ns=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ps={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),is=s("span",{style:{color:"#032F62"}},"download-genesis",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),_s={style:{color:"#032F62"}},hs={class:"language-bash vp-adaptive-theme"},ys=s("button",{title:"Copy Code",class:"copy"},null,-1),Es=s("span",{class:"lang"},"bash",-1),us={class:"shiki github-dark vp-code-dark"},Fs={class:"line"},gs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),Cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),bs=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),Ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ms={style:{color:"#9ECBFF"}},Ss={class:"shiki github-light vp-code-light"},vs={class:"line"},ks=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Bs=s("span",{style:{color:"#24292E"}}," ",-1),As=s("span",{style:{color:"#032F62"}},"download-genesis",-1),fs=s("span",{style:{color:"#24292E"}}," ",-1),qs={style:{color:"#032F62"}},Ps={class:"language-bash vp-adaptive-theme"},Is=s("button",{title:"Copy Code",class:"copy"},null,-1),xs=s("span",{class:"lang"},"bash",-1),Vs={class:"shiki github-dark vp-code-dark"},Rs={class:"line"},Ds=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),ws=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ns=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),$s=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ms={style:{color:"#9ECBFF"}},Os={class:"shiki github-light vp-code-light"},Hs={class:"line"},Ls=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Qs=s("span",{style:{color:"#24292E"}}," ",-1),js=s("span",{style:{color:"#032F62"}},"download-genesis",-1),Us=s("span",{style:{color:"#24292E"}}," ",-1),zs={style:{color:"#032F62"}},Gs=s("p",null,[a("Set seeds in the "),s("code",null,"$HOME/.celestia-app/config/config.toml"),a(" file:")],-1),Js={class:"vp-code-group vp-adaptive-theme"},Ks=o('
    ',1),Ys={class:"blocks"},Xs={class:"language-bash vp-adaptive-theme active"},Zs=s("button",{title:"Copy Code",class:"copy"},null,-1),Ws=s("span",{class:"lang"},"bash",-1),so={class:"shiki github-dark vp-code-dark"},oo={class:"line"},ao=o('SEEDS=$(curl -sL',6),eo={style:{color:"#9ECBFF"}},no=s("span",{style:{color:"#F97583"}},"|",-1),to=s("span",{style:{color:"#9ECBFF"}}," ",-1),lo=s("span",{style:{color:"#B392F0"}},"tr",-1),po=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),co=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),ro=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),io={class:"shiki github-light vp-code-light"},_o={class:"line"},ho=o('SEEDS=$(curl -sL',6),yo={style:{color:"#032F62"}},Eo=s("span",{style:{color:"#D73A49"}},"|",-1),uo=s("span",{style:{color:"#032F62"}}," ",-1),Fo=s("span",{style:{color:"#6F42C1"}},"tr",-1),go=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Co=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),bo=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),To={class:"language-bash vp-adaptive-theme"},mo=s("button",{title:"Copy Code",class:"copy"},null,-1),So=s("span",{class:"lang"},"bash",-1),vo={class:"shiki github-dark vp-code-dark"},ko={class:"line"},Bo=o('SEEDS=$(curl -sL',6),Ao={style:{color:"#9ECBFF"}},fo=s("span",{style:{color:"#F97583"}},"|",-1),qo=s("span",{style:{color:"#9ECBFF"}}," ",-1),Po=s("span",{style:{color:"#B392F0"}},"tr",-1),Io=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),xo=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),Vo=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),Ro={class:"shiki github-light vp-code-light"},Do={class:"line"},wo=o('SEEDS=$(curl -sL',6),No={style:{color:"#032F62"}},$o=s("span",{style:{color:"#D73A49"}},"|",-1),Mo=s("span",{style:{color:"#032F62"}}," ",-1),Oo=s("span",{style:{color:"#6F42C1"}},"tr",-1),Ho=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Lo=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),Qo=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),jo=o(`
    bash
    # For Arabica, you can set seeds manually in the
    +import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/consensus-node.jpg",r=o('

    Consensus node

    This guide covers how to set up a consensus node on Celestia. Consensus nodes allow you to sync the entire blockchain history in the Celestia consensus layer.

    consensus node

    Minimum hardware requirements

    The following minimum hardware requirements are recommended for running a consensus node:

    • Memory: 16 GB RAM
    • CPU: Quad-Core
    • Disk: 2 TB SSD Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Set up a consensus node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up the dependencies

    Follow the instructions on installing dependencies.

    Install celestia-app

    Follow the tutorial on installing celestia-app.

    Set up the P2P networks

    To initialize the network, pick a "node-name" that describes your node. Keep in mind that this might change if a new testnet is deployed.

    ',14),i={class:"vp-code-group vp-adaptive-theme"},d=o('
    ',1),_={class:"blocks"},h={class:"language-bash vp-adaptive-theme active"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},F={class:"line"},g=o('celestia-appd init "node-name" --chain-id ',8),C={style:{color:"#9ECBFF"}},b={class:"shiki github-light vp-code-light"},T={class:"line"},m=o('celestia-appd init "node-name" --chain-id ',8),S={style:{color:"#032F62"}},v={class:"language-bash vp-adaptive-theme"},k=s("button",{title:"Copy Code",class:"copy"},null,-1),A=s("span",{class:"lang"},"bash",-1),B={class:"shiki github-dark vp-code-dark"},f={class:"line"},q=o('celestia-appd init "node-name" --chain-id ',8),P={style:{color:"#9ECBFF"}},I={class:"shiki github-light vp-code-light"},x={class:"line"},V=o('celestia-appd init "node-name" --chain-id ',8),R={style:{color:"#032F62"}},D={class:"language-bash vp-adaptive-theme"},w=s("button",{title:"Copy Code",class:"copy"},null,-1),N=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},M={class:"line"},O=o('celestia-appd init "node-name" --chain-id ',8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},Q={class:"line"},z=o('celestia-appd init "node-name" --chain-id ',8),X={style:{color:"#032F62"}},j=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),W={class:"vp-code-group vp-adaptive-theme"},U=o('
    ',1),Y={class:"blocks"},Z={class:"language-bash vp-adaptive-theme active"},K=s("button",{title:"Copy Code",class:"copy"},null,-1),G=s("span",{class:"lang"},"bash",-1),J={class:"shiki github-dark vp-code-dark"},ss={class:"line"},os=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),es=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),ns=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ps={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),is=s("span",{style:{color:"#032F62"}},"download-genesis",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),_s={style:{color:"#032F62"}},hs={class:"language-bash vp-adaptive-theme"},ys=s("button",{title:"Copy Code",class:"copy"},null,-1),Es=s("span",{class:"lang"},"bash",-1),us={class:"shiki github-dark vp-code-dark"},Fs={class:"line"},gs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),Cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),bs=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),Ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ms={style:{color:"#9ECBFF"}},Ss={class:"shiki github-light vp-code-light"},vs={class:"line"},ks=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),As=s("span",{style:{color:"#24292E"}}," ",-1),Bs=s("span",{style:{color:"#032F62"}},"download-genesis",-1),fs=s("span",{style:{color:"#24292E"}}," ",-1),qs={style:{color:"#032F62"}},Ps={class:"language-bash vp-adaptive-theme"},Is=s("button",{title:"Copy Code",class:"copy"},null,-1),xs=s("span",{class:"lang"},"bash",-1),Vs={class:"shiki github-dark vp-code-dark"},Rs={class:"line"},Ds=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),ws=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ns=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),$s=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ms={style:{color:"#9ECBFF"}},Os={class:"shiki github-light vp-code-light"},Hs={class:"line"},Ls=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Qs=s("span",{style:{color:"#24292E"}}," ",-1),zs=s("span",{style:{color:"#032F62"}},"download-genesis",-1),Xs=s("span",{style:{color:"#24292E"}}," ",-1),js={style:{color:"#032F62"}},Ws=s("p",null,[a("Set seeds in the "),s("code",null,"$HOME/.celestia-app/config/config.toml"),a(" file:")],-1),Us={class:"vp-code-group vp-adaptive-theme"},Ys=o('
    ',1),Zs={class:"blocks"},Ks={class:"language-bash vp-adaptive-theme active"},Gs=s("button",{title:"Copy Code",class:"copy"},null,-1),Js=s("span",{class:"lang"},"bash",-1),so={class:"shiki github-dark vp-code-dark"},oo={class:"line"},ao=o('SEEDS=$(curl -sL',6),eo={style:{color:"#9ECBFF"}},no=s("span",{style:{color:"#F97583"}},"|",-1),to=s("span",{style:{color:"#9ECBFF"}}," ",-1),lo=s("span",{style:{color:"#B392F0"}},"tr",-1),po=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),co=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),ro=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),io={class:"shiki github-light vp-code-light"},_o={class:"line"},ho=o('SEEDS=$(curl -sL',6),yo={style:{color:"#032F62"}},Eo=s("span",{style:{color:"#D73A49"}},"|",-1),uo=s("span",{style:{color:"#032F62"}}," ",-1),Fo=s("span",{style:{color:"#6F42C1"}},"tr",-1),go=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Co=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),bo=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),To={class:"language-bash vp-adaptive-theme"},mo=s("button",{title:"Copy Code",class:"copy"},null,-1),So=s("span",{class:"lang"},"bash",-1),vo={class:"shiki github-dark vp-code-dark"},ko={class:"line"},Ao=o('SEEDS=$(curl -sL',6),Bo={style:{color:"#9ECBFF"}},fo=s("span",{style:{color:"#F97583"}},"|",-1),qo=s("span",{style:{color:"#9ECBFF"}}," ",-1),Po=s("span",{style:{color:"#B392F0"}},"tr",-1),Io=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),xo=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),Vo=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),Ro={class:"shiki github-light vp-code-light"},Do={class:"line"},wo=o('SEEDS=$(curl -sL',6),No={style:{color:"#032F62"}},$o=s("span",{style:{color:"#D73A49"}},"|",-1),Mo=s("span",{style:{color:"#032F62"}}," ",-1),Oo=s("span",{style:{color:"#6F42C1"}},"tr",-1),Ho=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Lo=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),Qo=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),zo=o(`
    bash
    # For Arabica, you can set seeds manually in the
     # \`$HOME/.celestia-app/config/config.toml\` file:
     # Comma separated list of seed nodes to connect to
     seeds = ""
    # For Arabica, you can set seeds manually in the
     # \`$HOME/.celestia-app/config/config.toml\` file:
     # Comma separated list of seed nodes to connect to
    -seeds = ""
    `,1),Uo=o('Optional: Set persistent peers

    Optionally, you can set persistent peers in your config.toml file. If you set persistent peers, your node will always try to connect to these peers. This is useful when running a local devnet, for example, when you would always want to connect to the same local nodes in your devnet. In production, setting persistent peers is advised only if you are running a sentry node.

    You can get the persistent peers from the @cosmos/chain-registry repository (for Mainnet Beta) or @celestiaorg/networks repository repo (for Mocha and Arabica) with the following commands:

    ',3),zo={class:"vp-code-group vp-adaptive-theme"},Go=o('
    ',1),Jo={class:"blocks"},Ko={class:"language-bash vp-adaptive-theme active"},Yo=s("button",{title:"Copy Code",class:"copy"},null,-1),Xo=s("span",{class:"lang"},"bash",-1),Zo={class:"shiki github-dark vp-code-dark"},Wo={class:"line"},sa=o('PERSISTENT_PEERS=$(curl -s',6),oa={style:{color:"#9ECBFF"}},aa=o('| jq -r '.peers.persistent_peers[].address' | tr '\\n' ',' | sed 's/,$/\\n/')',14),ea=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),na=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),ta={class:"shiki github-light vp-code-light"},la={class:"line"},pa=o('PERSISTENT_PEERS=$(curl -s',6),ca={style:{color:"#032F62"}},ra=o('| jq -r '.peers.persistent_peers[].address' | tr '\\n' ',' | sed 's/,$/\\n/')',14),ia=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),da=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),_a={class:"language-bash vp-adaptive-theme"},ha=s("button",{title:"Copy Code",class:"copy"},null,-1),ya=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o('PERSISTENT_PEERS=$(curl -sL',6),ga={style:{color:"#9ECBFF"}},Ca=s("span",{style:{color:"#F97583"}},"|",-1),ba=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ta=s("span",{style:{color:"#B392F0"}},"tr",-1),ma=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),Sa=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),va=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),ka={class:"shiki github-light vp-code-light"},Ba={class:"line"},Aa=o('PERSISTENT_PEERS=$(curl -sL',6),fa={style:{color:"#032F62"}},qa=s("span",{style:{color:"#D73A49"}},"|",-1),Pa=s("span",{style:{color:"#032F62"}}," ",-1),Ia=s("span",{style:{color:"#6F42C1"}},"tr",-1),xa=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Va=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),Ra=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),Da={class:"language-bash vp-adaptive-theme"},wa=s("button",{title:"Copy Code",class:"copy"},null,-1),Na=s("span",{class:"lang"},"bash",-1),$a={class:"shiki github-dark vp-code-dark"},Ma={class:"line"},Oa=o('PERSISTENT_PEERS=$(curl -sL',6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Qa=s("span",{style:{color:"#9ECBFF"}}," ",-1),ja=s("span",{style:{color:"#B392F0"}},"tr",-1),Ua=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),za=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),Ga=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),Ja={class:"shiki github-light vp-code-light"},Ka={class:"line"},Ya=o('PERSISTENT_PEERS=$(curl -sL',6),Xa={style:{color:"#032F62"}},Za=s("span",{style:{color:"#D73A49"}},"|",-1),Wa=s("span",{style:{color:"#032F62"}}," ",-1),se=s("span",{style:{color:"#6F42C1"}},"tr",-1),oe=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),ae=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),ee=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),ne=o(`

    Storage and pruning configurations

    Optional: Connect a consensus node to a bridge node

    If your consensus node is being connected to a celestia-node bridge node, you will need to enable transaction indexing and retain all block data. This can be achieved with the following settings in your config.toml.

    Enable transaction indexing

    toml
    indexer = "kv"
    indexer = "kv"

    Retain all block data

    And in your app.toml, min-retain-blocks should remain as the default setting of 0:

    toml
    min-retain-blocks = 0 # retain all block data, this is default setting
    min-retain-blocks = 0 # retain all block data, this is default setting

    Query transactions by hash

    To query transactions using their hash, transaction indexing must be turned on. Set the indexer to "kv" in your config.toml:

    toml
    indexer = "kv"
    indexer = "kv"

    Optional: Access historical state

    If you want to query the historical state — for example, you might want to know the balance of a Celestia wallet at a given height in the past — you should run an archive node with pruning = "nothing" in your app.toml. Note that this configuration is resource-intensive and will require significant storage:

    toml
    pruning = "nothing"
    pruning = "nothing"

    Save on storage requirements

    If you want to save on storage requirements, consider using pruning = "everything" in your app.toml to prune everything. If you select "everything" or "default", but still want to keep the block data, you can do so by not changing the default value of min-retain-blocks = 0 in your app.toml. A value of 0 for min-retain-blocks will keep all block data. This will prune snapshots of the state, but it will keep block data:

    toml
    pruning = "everything"
    +seeds = ""
    `,1),Xo=o('Optional: Set persistent peers

    Optionally, you can set persistent peers in your config.toml file. If you set persistent peers, your node will always try to connect to these peers. This is useful when running a local devnet, for example, when you would always want to connect to the same local nodes in your devnet. In production, setting persistent peers is advised only if you are running a sentry node.

    You can get the persistent peers from the @cosmos/chain-registry repository (for Mainnet Beta) or @celestiaorg/networks repository repo (for Mocha and Arabica) with the following commands:

    ',3),jo={class:"vp-code-group vp-adaptive-theme"},Wo=o('
    ',1),Uo={class:"blocks"},Yo={class:"language-bash vp-adaptive-theme active"},Zo=s("button",{title:"Copy Code",class:"copy"},null,-1),Ko=s("span",{class:"lang"},"bash",-1),Go={class:"shiki github-dark vp-code-dark"},Jo={class:"line"},sa=o('PERSISTENT_PEERS=$(curl -s',6),oa={style:{color:"#9ECBFF"}},aa=o('| jq -r '.peers.persistent_peers[].address' | tr '\\n' ',' | sed 's/,$/\\n/')',14),ea=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),na=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),ta={class:"shiki github-light vp-code-light"},la={class:"line"},pa=o('PERSISTENT_PEERS=$(curl -s',6),ca={style:{color:"#032F62"}},ra=o('| jq -r '.peers.persistent_peers[].address' | tr '\\n' ',' | sed 's/,$/\\n/')',14),ia=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),da=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),_a={class:"language-bash vp-adaptive-theme"},ha=s("button",{title:"Copy Code",class:"copy"},null,-1),ya=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o('PERSISTENT_PEERS=$(curl -sL',6),ga={style:{color:"#9ECBFF"}},Ca=s("span",{style:{color:"#F97583"}},"|",-1),ba=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ta=s("span",{style:{color:"#B392F0"}},"tr",-1),ma=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),Sa=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),va=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),ka={class:"shiki github-light vp-code-light"},Aa={class:"line"},Ba=o('PERSISTENT_PEERS=$(curl -sL',6),fa={style:{color:"#032F62"}},qa=s("span",{style:{color:"#D73A49"}},"|",-1),Pa=s("span",{style:{color:"#032F62"}}," ",-1),Ia=s("span",{style:{color:"#6F42C1"}},"tr",-1),xa=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Va=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),Ra=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),Da={class:"language-bash vp-adaptive-theme"},wa=s("button",{title:"Copy Code",class:"copy"},null,-1),Na=s("span",{class:"lang"},"bash",-1),$a={class:"shiki github-dark vp-code-dark"},Ma={class:"line"},Oa=o('PERSISTENT_PEERS=$(curl -sL',6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Qa=s("span",{style:{color:"#9ECBFF"}}," ",-1),za=s("span",{style:{color:"#B392F0"}},"tr",-1),Xa=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),ja=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),Wa=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),Ua={class:"shiki github-light vp-code-light"},Ya={class:"line"},Za=o('PERSISTENT_PEERS=$(curl -sL',6),Ka={style:{color:"#032F62"}},Ga=s("span",{style:{color:"#D73A49"}},"|",-1),Ja=s("span",{style:{color:"#032F62"}}," ",-1),se=s("span",{style:{color:"#6F42C1"}},"tr",-1),oe=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),ae=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),ee=o('sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \\"$PERSISTENT_PEERS\\"/" $HOME/.celestia-app/config/config.toml',1),ne=o(`

    Storage and pruning configurations

    Optional: Connect a consensus node to a bridge node

    If your consensus node is being connected to a celestia-node bridge node, you will need to enable transaction indexing and retain all block data. This can be achieved with the following settings in your config.toml.

    Enable transaction indexing

    toml
    indexer = "kv"
    indexer = "kv"

    Retain all block data

    And in your app.toml, min-retain-blocks should remain as the default setting of 0:

    toml
    min-retain-blocks = 0 # retain all block data, this is default setting
    min-retain-blocks = 0 # retain all block data, this is default setting

    Query transactions by hash

    To query transactions using their hash, transaction indexing must be turned on. Set the indexer to "kv" in your config.toml:

    toml
    indexer = "kv"
    indexer = "kv"

    Optional: Access historical state

    If you want to query the historical state — for example, you might want to know the balance of a Celestia wallet at a given height in the past — you should run an archive node with pruning = "nothing" in your app.toml. Note that this configuration is resource-intensive and will require significant storage:

    toml
    pruning = "nothing"
    pruning = "nothing"

    Save on storage requirements

    If you want to save on storage requirements, consider using pruning = "everything" in your app.toml to prune everything. If you select "everything" or "default", but still want to keep the block data, you can do so by not changing the default value of min-retain-blocks = 0 in your app.toml. A value of 0 for min-retain-blocks will keep all block data. This will prune snapshots of the state, but it will keep block data:

    toml
    pruning = "everything"
     min-retain-blocks = 0 # this is the default setting
    pruning = "everything"
     min-retain-blocks = 0 # this is the default setting

    Sync types

    Sync modeTimeNotes
    Block sync~3 weeksDownloads and executes all blocks from genesis to the tip
    State sync~1 hourDownloads a snapshot of the state then downloads and executes all blocks after that snapshot to the tip.
    Quick sync~5 hoursDownloads the data directory from a node. Time depends on your download speed because the data being downloaded can exceed 1 TB for mainnet.

    Option 1: Block sync

    By default, a consensus node will sync using block sync; which will request, validate and execute every block up to the head of the blockchain. This is the most secure mechanism yet the slowest (taking up to weeks depending on the height of the blockchain).

    There are two alternatives for quicker syncing.

    Option 2: State sync

    State sync uses light client verification to verify state snapshots from peers and then apply them. State sync relies on weak subjectivity; a trusted header (specifically the hash and height) must be provided. This can be found by querying a trusted RPC endpoint (/block). RPC endpoints are also required for retrieving light blocks. These can be found in the docs here under the respective networks or from the chain-registry.

    In $HOME/.celestia-app/config/config.toml, set

    toml
    rpc_servers = ""
     trust_height = 0
    @@ -18,25 +18,25 @@ import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t
     ###         State Sync Configuration Options        ###
     #######################################################
     [statesync]
    -enable = true

    To their respective fields. At least two different rpc endpoints should be provided. The more, the greater the chance of detecting any fraudulent behavior.

    Once setup, you should be ready to start the node as normal. In the logs, you should see: Discovering snapshots. This may take a few minutes before snapshots are found depending on the network topology.

    TIP

    If you are looking to quickly sync a consensus node, and do not need historical blocks, you can use the following scripts and state sync. Remember to checkout to the correct version and run make install before running the scripts:

    The public networks will use state sync so they'll get to the tip very quickly, but won't work for your use case if you need historical blocks.

    Option 3: Quick sync

    Quick sync effectively downloads the entire data directory from a third-party provider meaning the node has all the application and blockchain state as the node it was copied from.

    Run the following command to quick-sync from a snapshot:

    `,34),te={class:"vp-code-group vp-adaptive-theme"},le=o('
    ',1),pe={class:"blocks"},ce={class:"language-bash vp-adaptive-theme active"},re=s("button",{title:"Copy Code",class:"copy"},null,-1),ie=s("span",{class:"lang"},"bash",-1),de={class:"shiki github-dark vp-code-dark"},_e=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),he=o('rm -rf ~/.celestia-app/data',1),ye=o('mkdir -p ~/.celestia-app/data',1),Ee=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),ue={class:"line"},Fe=s("span",{style:{color:"#9ECBFF"}}," ",-1),ge=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ce=s("span",{style:{color:"#9ECBFF"}}," ",-1),be=s("span",{style:{color:"#79B8FF"}},"-o",-1),Te={style:{color:"#9ECBFF"}},me=o('| tr -d ">")',6),Se=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),ve=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),ke={class:"shiki github-light vp-code-light"},Be=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),Ae=o('rm -rf ~/.celestia-app/data',1),fe=o('mkdir -p ~/.celestia-app/data',1),qe=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),Pe={class:"line"},Ie=s("span",{style:{color:"#032F62"}}," ",-1),xe=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ve=s("span",{style:{color:"#032F62"}}," ",-1),Re=s("span",{style:{color:"#005CC5"}},"-o",-1),De={style:{color:"#032F62"}},we=o('| tr -d ">")',6),Ne=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),$e=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Me={class:"language-bash vp-adaptive-theme"},Oe=s("button",{title:"Copy Code",class:"copy"},null,-1),He=s("span",{class:"lang"},"bash",-1),Le={class:"shiki github-dark vp-code-dark"},Qe=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),je=o('rm -rf ~/.celestia-app/data',1),Ue=o('mkdir -p ~/.celestia-app/data',1),ze=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),Ge={class:"line"},Je=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ke=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ye=s("span",{style:{color:"#9ECBFF"}}," ",-1),Xe=s("span",{style:{color:"#79B8FF"}},"-o",-1),Ze={style:{color:"#9ECBFF"}},We=o('| tr -d ">")',6),sn=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),on=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),an={class:"shiki github-light vp-code-light"},en=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),nn=o('rm -rf ~/.celestia-app/data',1),tn=o('mkdir -p ~/.celestia-app/data',1),ln=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),pn={class:"line"},cn=s("span",{style:{color:"#032F62"}}," ",-1),rn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),dn=s("span",{style:{color:"#032F62"}}," ",-1),_n=s("span",{style:{color:"#005CC5"}},"-o",-1),hn={style:{color:"#032F62"}},yn=o('| tr -d ">")',6),En=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),un=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Fn={class:"language-bash vp-adaptive-theme"},gn=s("button",{title:"Copy Code",class:"copy"},null,-1),Cn=s("span",{class:"lang"},"bash",-1),bn={class:"shiki github-dark vp-code-dark"},Tn=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),mn=o('rm -rf ~/.celestia-app/data',1),Sn=o('mkdir -p ~/.celestia-app/data',1),vn=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),kn={class:"line"},Bn=s("span",{style:{color:"#9ECBFF"}}," ",-1),An=s("span",{style:{color:"#B392F0"}},"egrep",-1),fn=s("span",{style:{color:"#9ECBFF"}}," ",-1),qn=s("span",{style:{color:"#79B8FF"}},"-o",-1),Pn={style:{color:"#9ECBFF"}},In=o('| tr -d ">")',6),xn=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),Vn=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Rn={class:"shiki github-light vp-code-light"},Dn=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),wn=o('rm -rf ~/.celestia-app/data',1),Nn=o('mkdir -p ~/.celestia-app/data',1),$n=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),Mn={class:"line"},On=s("span",{style:{color:"#032F62"}}," ",-1),Hn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ln=s("span",{style:{color:"#032F62"}}," ",-1),Qn=s("span",{style:{color:"#005CC5"}},"-o",-1),jn={style:{color:"#032F62"}},Un=o('| tr -d ">")',6),zn=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),Gn=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Jn=o('

    Start the consensus node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    Optional: If you would like celestia-app to run as a background process, you can follow the SystemD tutorial.

    Extra resources for consensus nodes

    Optional: Reset network

    This will delete all data folders so we can start fresh:

    sh
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app

    Optional: Configure an RPC endpoint

    You can configure your consensus node to be a public RPC endpoint. This allows it to accept connections from data availability nodes and serve requests for the data availability API.

    Expose RPC

    By default, the RPC service listens on localhost which means it can't be accessed from other machines. To make the RPC service available publicly, you need to bind it to a public IP or 0.0.0.0 (which means listening on all available network interfaces).

    You can do this by editing the config.toml file:

    sh
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml

    This command replaces the localhost IP address with 0.0.0.0, making the RPC service listen on all available network interfaces.

    Note on external-address

    The external-address field in the configuration is used when your node is behind a NAT and you need to advertise a different address for peers to dial. Populating this field is not necessary for making the RPC endpoint public.

    sh
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)\nsed -i.bak -e "s/^external-address = ""/external-address = "$EXTERNAL-ADDRESS:26656"/" \\\n    $HOME/.celestia-app/config/config.toml
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)\nsed -i.bak -e "s/^external-address = ""/external-address = "$EXTERNAL-ADDRESS:26656"/" \\\n    $HOME/.celestia-app/config/config.toml

    Restart the node

    After making these changes, restart celestia-appd to load the new configurations.

    Optional: Transaction indexer configuration options

    This section guides you on how to configure your config.toml file in celestia-app to select which transactions to index. Depending on the application's configuration, a node operator may decide which transactions to index.

    The available options are:

    1. null: This option disables indexing. If you don't need to query transactions, you can choose this option to save space.
    2. kv (default): This is the simplest indexer, backed by key-value storage (defaults to levelDB; see DBBackend). When kv is chosen, tx.height and tx.hash will always be indexed. This option is suitable for basic queries on transactions.
    3. psql: This indexer is backed by PostgreSQL. When psql is chosen, tx.height and tx.hash will always be indexed. This option is suitable for complex queries on transactions.

    An example to set the value to kv in config.toml is:

    toml
    indexer = "kv"
    indexer = "kv"

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    Optional: Discard ABCI responses configuration

    This section will guide you on how to configure your config.toml file in celestia-app to manage the storage of ABCI responses. ABCI responses are the results of executing transactions and are used for /block_results RPC queries and to reindex events in the command-line tool.

    The discard_abci_responses option allows you to control whether these responses are persisted in the state store:

    • false (default): ABCI responses are stored in the state store. This ensures that ABCI responses are available for /block_results RPC queries and for reindexing events. However, it can consume a significant amount of disk space.
    • true: ABCI responses are not stored in the state store. This can save a considerable amount of disk space, but /block_results RPC queries and event reindexing will not be available.

    An example to set the value to false in config.toml is:

    toml
    discard_abci_responses = false
    discard_abci_responses = false

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to:

    1. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    2. Remove the data/application.db inside your CELESTIA_HOME directory.
    3. Download the latest binary for your network.
    4. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    ',42),ot=JSON.parse('{"title":"Consensus node","description":"Learn how to set up a Celestia consensus node.","frontmatter":{"description":"Learn how to set up a Celestia consensus node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Consensus node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia consensus node."}]]},"headers":[],"relativePath":"how-to-guides/consensus-node.md","filePath":"how-to-guides/consensus-node.md","lastUpdated":1732776394000}'),Kn={name:"how-to-guides/consensus-node.md"},at=Object.assign(Kn,{setup(Yn){return(Xn,Zn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",h,[y,E,s("pre",u,[s("code",null,[s("span",F,[g,s("span",C,n(t(e).mainnetChainId),1)])])]),s("pre",b,[s("code",null,[s("span",T,[m,s("span",S,n(t(e).mainnetChainId),1)])])])]),s("div",v,[k,B,s("pre",A,[s("code",null,[s("span",f,[q,s("span",P,n(t(e).mochaChainId),1)])])]),s("pre",I,[s("code",null,[s("span",x,[V,s("span",R,n(t(e).mochaChainId),1)])])])]),s("div",D,[w,N,s("pre",$,[s("code",null,[s("span",M,[O,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",Q,[j,s("span",U,n(t(e).arabicaChainId),1)])])])])])]),z,s("div",G,[J,s("div",K,[s("div",Y,[X,Z,s("pre",W,[s("code",null,[s("span",ss,[os,as,es,ns,s("span",ts,n(t(e).mainnetChainId),1)])])]),s("pre",ls,[s("code",null,[s("span",ps,[cs,rs,is,ds,s("span",_s,n(t(e).mainnetChainId),1)])])])]),s("div",hs,[ys,Es,s("pre",us,[s("code",null,[s("span",Fs,[gs,Cs,bs,Ts,s("span",ms,n(t(e).mochaChainId),1)])])]),s("pre",Ss,[s("code",null,[s("span",vs,[ks,Bs,As,fs,s("span",qs,n(t(e).mochaChainId),1)])])])]),s("div",Ps,[Is,xs,s("pre",Vs,[s("code",null,[s("span",Rs,[Ds,ws,Ns,$s,s("span",Ms,n(t(e).arabicaChainId),1)])])]),s("pre",Os,[s("code",null,[s("span",Hs,[Ls,Qs,js,Us,s("span",zs,n(t(e).arabicaChainId),1)])])])])])]),Gs,s("div",Js,[Ks,s("div",Ys,[s("div",Xs,[Zs,Ws,s("pre",so,[s("code",null,[s("span",oo,[ao,s("span",eo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),no,to,lo,po]),a(` +enable = true

    To their respective fields. At least two different rpc endpoints should be provided. The more, the greater the chance of detecting any fraudulent behavior.

    Once setup, you should be ready to start the node as normal. In the logs, you should see: Discovering snapshots. This may take a few minutes before snapshots are found depending on the network topology.

    TIP

    If you are looking to quickly sync a consensus node, and do not need historical blocks, you can use the following scripts and state sync. Remember to checkout to the correct version and run make install before running the scripts:

    The public networks will use state sync so they'll get to the tip very quickly, but won't work for your use case if you need historical blocks.

    Option 3: Quick sync

    Quick sync effectively downloads the entire data directory from a third-party provider meaning the node has all the application and blockchain state as the node it was copied from.

    Run the following command to quick-sync from a snapshot:

    `,34),te={class:"vp-code-group vp-adaptive-theme"},le=o('
    ',1),pe={class:"blocks"},ce={class:"language-bash vp-adaptive-theme active"},re=s("button",{title:"Copy Code",class:"copy"},null,-1),ie=s("span",{class:"lang"},"bash",-1),de={class:"shiki github-dark vp-code-dark"},_e=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),he=o('rm -rf ~/.celestia-app/data',1),ye=o('mkdir -p ~/.celestia-app/data',1),Ee=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),ue={class:"line"},Fe=s("span",{style:{color:"#9ECBFF"}}," ",-1),ge=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ce=s("span",{style:{color:"#9ECBFF"}}," ",-1),be=s("span",{style:{color:"#79B8FF"}},"-o",-1),Te={style:{color:"#9ECBFF"}},me=o('| tr -d ">")',6),Se=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),ve=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),ke={class:"shiki github-light vp-code-light"},Ae=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),Be=o('rm -rf ~/.celestia-app/data',1),fe=o('mkdir -p ~/.celestia-app/data',1),qe=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),Pe={class:"line"},Ie=s("span",{style:{color:"#032F62"}}," ",-1),xe=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ve=s("span",{style:{color:"#032F62"}}," ",-1),Re=s("span",{style:{color:"#005CC5"}},"-o",-1),De={style:{color:"#032F62"}},we=o('| tr -d ">")',6),Ne=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),$e=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Me={class:"language-bash vp-adaptive-theme"},Oe=s("button",{title:"Copy Code",class:"copy"},null,-1),He=s("span",{class:"lang"},"bash",-1),Le={class:"shiki github-dark vp-code-dark"},Qe=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),ze=o('rm -rf ~/.celestia-app/data',1),Xe=o('mkdir -p ~/.celestia-app/data',1),je=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),We={class:"line"},Ue=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ye=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ze=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ke=s("span",{style:{color:"#79B8FF"}},"-o",-1),Ge={style:{color:"#9ECBFF"}},Je=o('| tr -d ">")',6),sn=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),on=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),an={class:"shiki github-light vp-code-light"},en=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),nn=o('rm -rf ~/.celestia-app/data',1),tn=o('mkdir -p ~/.celestia-app/data',1),ln=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),pn={class:"line"},cn=s("span",{style:{color:"#032F62"}}," ",-1),rn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),dn=s("span",{style:{color:"#032F62"}}," ",-1),_n=s("span",{style:{color:"#005CC5"}},"-o",-1),hn={style:{color:"#032F62"}},yn=o('| tr -d ">")',6),En=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),un=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Fn={class:"language-bash vp-adaptive-theme"},gn=s("button",{title:"Copy Code",class:"copy"},null,-1),Cn=s("span",{class:"lang"},"bash",-1),bn={class:"shiki github-dark vp-code-dark"},Tn=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),mn=o('rm -rf ~/.celestia-app/data',1),Sn=o('mkdir -p ~/.celestia-app/data',1),vn=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),kn={class:"line"},An=s("span",{style:{color:"#9ECBFF"}}," ",-1),Bn=s("span",{style:{color:"#B392F0"}},"egrep",-1),fn=s("span",{style:{color:"#9ECBFF"}}," ",-1),qn=s("span",{style:{color:"#79B8FF"}},"-o",-1),Pn={style:{color:"#9ECBFF"}},In=o('| tr -d ">")',6),xn=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),Vn=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Rn={class:"shiki github-light vp-code-light"},Dn=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),wn=o('rm -rf ~/.celestia-app/data',1),Nn=o('mkdir -p ~/.celestia-app/data',1),$n=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),Mn={class:"line"},On=s("span",{style:{color:"#032F62"}}," ",-1),Hn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ln=s("span",{style:{color:"#032F62"}}," ",-1),Qn=s("span",{style:{color:"#005CC5"}},"-o",-1),zn={style:{color:"#032F62"}},Xn=o('| tr -d ">")',6),jn=o('aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"',1),Wn=o('tar xf celestia-snap.tar -C ~/.celestia-app/data/',1),Un=o('

    Start the consensus node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    Optional: If you would like celestia-app to run as a background process, you can follow the SystemD tutorial.

    Extra resources for consensus nodes

    Optional: Reset network

    This will delete all data folders so we can start fresh:

    sh
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app

    Optional: Configure an RPC endpoint

    You can configure your consensus node to be a public RPC endpoint. This allows it to accept connections from data availability nodes and serve requests for the data availability API.

    Expose RPC

    By default, the RPC service listens on localhost which means it can't be accessed from other machines. To make the RPC service available publicly, you need to bind it to a public IP or 0.0.0.0 (which means listening on all available network interfaces).

    You can do this by editing the config.toml file:

    sh
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml

    This command replaces the localhost IP address with 0.0.0.0, making the RPC service listen on all available network interfaces.

    Note on external-address

    The external-address field in the configuration is used when your node is behind a NAT and you need to advertise a different address for peers to dial. Populating this field is not necessary for making the RPC endpoint public.

    sh
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)\nsed -i.bak -e "s/^external-address = ""/external-address = "$EXTERNAL-ADDRESS:26656"/" \\\n    $HOME/.celestia-app/config/config.toml
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)\nsed -i.bak -e "s/^external-address = ""/external-address = "$EXTERNAL-ADDRESS:26656"/" \\\n    $HOME/.celestia-app/config/config.toml

    Restart the node

    After making these changes, restart celestia-appd to load the new configurations.

    Optional: Transaction indexer configuration options

    This section guides you on how to configure your config.toml file in celestia-app to select which transactions to index. Depending on the application's configuration, a node operator may decide which transactions to index.

    The available options are:

    1. null: This option disables indexing. If you don't need to query transactions, you can choose this option to save space.
    2. kv (default): This is the simplest indexer, backed by key-value storage (defaults to levelDB; see DBBackend). When kv is chosen, tx.height and tx.hash will always be indexed. This option is suitable for basic queries on transactions.
    3. psql: This indexer is backed by PostgreSQL. When psql is chosen, tx.height and tx.hash will always be indexed. This option is suitable for complex queries on transactions.

    An example to set the value to kv in config.toml is:

    toml
    indexer = "kv"
    indexer = "kv"

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    Optional: Discard ABCI responses configuration

    This section will guide you on how to configure your config.toml file in celestia-app to manage the storage of ABCI responses. ABCI responses are the results of executing transactions and are used for /block_results RPC queries and to reindex events in the command-line tool.

    The discard_abci_responses option allows you to control whether these responses are persisted in the state store:

    • false (default): ABCI responses are stored in the state store. This ensures that ABCI responses are available for /block_results RPC queries and for reindexing events. However, it can consume a significant amount of disk space.
    • true: ABCI responses are not stored in the state store. This can save a considerable amount of disk space, but /block_results RPC queries and event reindexing will not be available.

    An example to set the value to false in config.toml is:

    toml
    discard_abci_responses = false
    discard_abci_responses = false

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to:

    1. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    2. Remove the data/application.db inside your CELESTIA_HOME directory.
    3. Download the latest binary for your network.
    4. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    ',42),ot=JSON.parse('{"title":"Consensus node","description":"Learn how to set up a Celestia consensus node.","frontmatter":{"description":"Learn how to set up a Celestia consensus node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Consensus node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia consensus node."}]]},"headers":[],"relativePath":"how-to-guides/consensus-node.md","filePath":"how-to-guides/consensus-node.md","lastUpdated":1732777479000}'),Yn={name:"how-to-guides/consensus-node.md"},at=Object.assign(Yn,{setup(Zn){return(Kn,Gn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",h,[y,E,s("pre",u,[s("code",null,[s("span",F,[g,s("span",C,n(t(e).mainnetChainId),1)])])]),s("pre",b,[s("code",null,[s("span",T,[m,s("span",S,n(t(e).mainnetChainId),1)])])])]),s("div",v,[k,A,s("pre",B,[s("code",null,[s("span",f,[q,s("span",P,n(t(e).mochaChainId),1)])])]),s("pre",I,[s("code",null,[s("span",x,[V,s("span",R,n(t(e).mochaChainId),1)])])])]),s("div",D,[w,N,s("pre",$,[s("code",null,[s("span",M,[O,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",Q,[z,s("span",X,n(t(e).arabicaChainId),1)])])])])])]),j,s("div",W,[U,s("div",Y,[s("div",Z,[K,G,s("pre",J,[s("code",null,[s("span",ss,[os,as,es,ns,s("span",ts,n(t(e).mainnetChainId),1)])])]),s("pre",ls,[s("code",null,[s("span",ps,[cs,rs,is,ds,s("span",_s,n(t(e).mainnetChainId),1)])])])]),s("div",hs,[ys,Es,s("pre",us,[s("code",null,[s("span",Fs,[gs,Cs,bs,Ts,s("span",ms,n(t(e).mochaChainId),1)])])]),s("pre",Ss,[s("code",null,[s("span",vs,[ks,As,Bs,fs,s("span",qs,n(t(e).mochaChainId),1)])])])]),s("div",Ps,[Is,xs,s("pre",Vs,[s("code",null,[s("span",Rs,[Ds,ws,Ns,$s,s("span",Ms,n(t(e).arabicaChainId),1)])])]),s("pre",Os,[s("code",null,[s("span",Hs,[Ls,Qs,zs,Xs,s("span",js,n(t(e).arabicaChainId),1)])])])])])]),Ws,s("div",Us,[Ys,s("div",Zs,[s("div",Ks,[Gs,Js,s("pre",so,[s("code",null,[s("span",oo,[ao,s("span",eo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),no,to,lo,po]),a(` `),co,a(` `),ro])]),s("pre",io,[s("code",null,[s("span",_o,[ho,s("span",yo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),Eo,uo,Fo,go]),a(` `),Co,a(` -`),bo])])]),s("div",To,[mo,So,s("pre",vo,[s("code",null,[s("span",ko,[Bo,s("span",Ao," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/seeds.txt ",1),fo,qo,Po,Io]),a(` +`),bo])])]),s("div",To,[mo,So,s("pre",vo,[s("code",null,[s("span",ko,[Ao,s("span",Bo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/seeds.txt ",1),fo,qo,Po,Io]),a(` `),xo,a(` `),Vo])]),s("pre",Ro,[s("code",null,[s("span",Do,[wo,s("span",No," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/seeds.txt ",1),$o,Mo,Oo,Ho]),a(` `),Lo,a(` -`),Qo])])]),jo])]),s("details",null,[Uo,s("div",zo,[Go,s("div",Jo,[s("div",Ko,[Yo,Xo,s("pre",Zo,[s("code",null,[s("span",Wo,[sa,s("span",oa," https://raw.githubusercontent.com/cosmos/chain-registry/master/"+n(t(e).mainnetChainId)+"/chain.json ",1),aa]),a(` +`),Qo])])]),zo])]),s("details",null,[Xo,s("div",jo,[Wo,s("div",Uo,[s("div",Yo,[Zo,Ko,s("pre",Go,[s("code",null,[s("span",Jo,[sa,s("span",oa," https://raw.githubusercontent.com/cosmos/chain-registry/master/"+n(t(e).mainnetChainId)+"/chain.json ",1),aa]),a(` `),ea,a(` `),na])]),s("pre",ta,[s("code",null,[s("span",la,[pa,s("span",ca," https://raw.githubusercontent.com/cosmos/chain-registry/master/"+n(t(e).mainnetChainId)+"/chain.json ",1),ra]),a(` `),ia,a(` `),da])])]),s("div",_a,[ha,ya,s("pre",Ea,[s("code",null,[s("span",ua,[Fa,s("span",ga," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),Ca,ba,Ta,ma]),a(` `),Sa,a(` -`),va])]),s("pre",ka,[s("code",null,[s("span",Ba,[Aa,s("span",fa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),qa,Pa,Ia,xa]),a(` +`),va])]),s("pre",ka,[s("code",null,[s("span",Aa,[Ba,s("span",fa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),qa,Pa,Ia,xa]),a(` `),Va,a(` -`),Ra])])]),s("div",Da,[wa,Na,s("pre",$a,[s("code",null,[s("span",Ma,[Oa,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Qa,ja,Ua]),a(` -`),za,a(` -`),Ga])]),s("pre",Ja,[s("code",null,[s("span",Ka,[Ya,s("span",Xa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),Za,Wa,se,oe]),a(` +`),Ra])])]),s("div",Da,[wa,Na,s("pre",$a,[s("code",null,[s("span",Ma,[Oa,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Qa,za,Xa]),a(` +`),ja,a(` +`),Wa])]),s("pre",Ua,[s("code",null,[s("span",Ya,[Za,s("span",Ka," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),Ga,Ja,se,oe]),a(` `),ae,a(` `),ee])])])])])]),ne,s("div",te,[le,s("div",pe,[s("div",ce,[re,ie,s("pre",de,[s("code",null,[_e,a(` `),he,a(` @@ -44,17 +44,17 @@ import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t `),Ee,a(` `),s("span",ue,[Fe,ge,Ce,be,s("span",Te,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),me]),a(` `),Se,a(` -`),ve])]),s("pre",ke,[s("code",null,[Be,a(` -`),Ae,a(` +`),ve])]),s("pre",ke,[s("code",null,[Ae,a(` +`),Be,a(` `),fe,a(` `),qe,a(` `),s("span",Pe,[Ie,xe,Ve,Re,s("span",De,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),we]),a(` `),Ne,a(` `),$e])])]),s("div",Me,[Oe,He,s("pre",Le,[s("code",null,[Qe,a(` -`),je,a(` -`),Ue,a(` `),ze,a(` -`),s("span",Ge,[Je,Ke,Ye,Xe,s("span",Ze,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),We]),a(` +`),Xe,a(` +`),je,a(` +`),s("span",We,[Ue,Ye,Ze,Ke,s("span",Ge,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),Je]),a(` `),sn,a(` `),on])]),s("pre",an,[s("code",null,[en,a(` `),nn,a(` @@ -66,12 +66,12 @@ import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t `),mn,a(` `),Sn,a(` `),vn,a(` -`),s("span",kn,[Bn,An,fn,qn,s("span",Pn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),In]),a(` +`),s("span",kn,[An,Bn,fn,qn,s("span",Pn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),In]),a(` `),xn,a(` `),Vn])]),s("pre",Rn,[s("code",null,[Dn,a(` `),wn,a(` `),Nn,a(` `),$n,a(` -`),s("span",Mn,[On,Hn,Ln,Qn,s("span",jn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),Un]),a(` -`),zn,a(` -`),Gn])])])])]),Jn]))}});export{ot as __pageData,at as default}; +`),s("span",Mn,[On,Hn,Ln,Qn,s("span",zn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),Xn]),a(` +`),jn,a(` +`),Wn])])])])]),Un]))}});export{ot as __pageData,at as default}; diff --git a/pr-1815/assets/how-to-guides_consensus-node.md.26d064fd.lean.js b/pr-1815/assets/how-to-guides_consensus-node.md.a59f3838.lean.js similarity index 76% rename from pr-1815/assets/how-to-guides_consensus-node.md.26d064fd.lean.js rename to pr-1815/assets/how-to-guides_consensus-node.md.a59f3838.lean.js index 5b3ca28a3..8e7dc3597 100644 --- a/pr-1815/assets/how-to-guides_consensus-node.md.26d064fd.lean.js +++ b/pr-1815/assets/how-to-guides_consensus-node.md.a59f3838.lean.js @@ -1,22 +1,22 @@ -import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/consensus-node.jpg",r=o("",14),i={class:"vp-code-group vp-adaptive-theme"},d=o("",1),_={class:"blocks"},h={class:"language-bash vp-adaptive-theme active"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},F={class:"line"},g=o("",8),C={style:{color:"#9ECBFF"}},b={class:"shiki github-light vp-code-light"},T={class:"line"},m=o("",8),S={style:{color:"#032F62"}},v={class:"language-bash vp-adaptive-theme"},k=s("button",{title:"Copy Code",class:"copy"},null,-1),B=s("span",{class:"lang"},"bash",-1),A={class:"shiki github-dark vp-code-dark"},f={class:"line"},q=o("",8),P={style:{color:"#9ECBFF"}},I={class:"shiki github-light vp-code-light"},x={class:"line"},V=o("",8),R={style:{color:"#032F62"}},D={class:"language-bash vp-adaptive-theme"},w=s("button",{title:"Copy Code",class:"copy"},null,-1),N=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},M={class:"line"},O=o("",8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},Q={class:"line"},j=o("",8),U={style:{color:"#032F62"}},z=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),G={class:"vp-code-group vp-adaptive-theme"},J=o("",1),K={class:"blocks"},Y={class:"language-bash vp-adaptive-theme active"},X=s("button",{title:"Copy Code",class:"copy"},null,-1),Z=s("span",{class:"lang"},"bash",-1),W={class:"shiki github-dark vp-code-dark"},ss={class:"line"},os=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),es=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),ns=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ps={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),is=s("span",{style:{color:"#032F62"}},"download-genesis",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),_s={style:{color:"#032F62"}},hs={class:"language-bash vp-adaptive-theme"},ys=s("button",{title:"Copy Code",class:"copy"},null,-1),Es=s("span",{class:"lang"},"bash",-1),us={class:"shiki github-dark vp-code-dark"},Fs={class:"line"},gs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),Cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),bs=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),Ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ms={style:{color:"#9ECBFF"}},Ss={class:"shiki github-light vp-code-light"},vs={class:"line"},ks=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Bs=s("span",{style:{color:"#24292E"}}," ",-1),As=s("span",{style:{color:"#032F62"}},"download-genesis",-1),fs=s("span",{style:{color:"#24292E"}}," ",-1),qs={style:{color:"#032F62"}},Ps={class:"language-bash vp-adaptive-theme"},Is=s("button",{title:"Copy Code",class:"copy"},null,-1),xs=s("span",{class:"lang"},"bash",-1),Vs={class:"shiki github-dark vp-code-dark"},Rs={class:"line"},Ds=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),ws=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ns=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),$s=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ms={style:{color:"#9ECBFF"}},Os={class:"shiki github-light vp-code-light"},Hs={class:"line"},Ls=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Qs=s("span",{style:{color:"#24292E"}}," ",-1),js=s("span",{style:{color:"#032F62"}},"download-genesis",-1),Us=s("span",{style:{color:"#24292E"}}," ",-1),zs={style:{color:"#032F62"}},Gs=s("p",null,[a("Set seeds in the "),s("code",null,"$HOME/.celestia-app/config/config.toml"),a(" file:")],-1),Js={class:"vp-code-group vp-adaptive-theme"},Ks=o("",1),Ys={class:"blocks"},Xs={class:"language-bash vp-adaptive-theme active"},Zs=s("button",{title:"Copy Code",class:"copy"},null,-1),Ws=s("span",{class:"lang"},"bash",-1),so={class:"shiki github-dark vp-code-dark"},oo={class:"line"},ao=o("",6),eo={style:{color:"#9ECBFF"}},no=s("span",{style:{color:"#F97583"}},"|",-1),to=s("span",{style:{color:"#9ECBFF"}}," ",-1),lo=s("span",{style:{color:"#B392F0"}},"tr",-1),po=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),co=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),ro=o("",1),io={class:"shiki github-light vp-code-light"},_o={class:"line"},ho=o("",6),yo={style:{color:"#032F62"}},Eo=s("span",{style:{color:"#D73A49"}},"|",-1),uo=s("span",{style:{color:"#032F62"}}," ",-1),Fo=s("span",{style:{color:"#6F42C1"}},"tr",-1),go=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Co=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),bo=o("",1),To={class:"language-bash vp-adaptive-theme"},mo=s("button",{title:"Copy Code",class:"copy"},null,-1),So=s("span",{class:"lang"},"bash",-1),vo={class:"shiki github-dark vp-code-dark"},ko={class:"line"},Bo=o("",6),Ao={style:{color:"#9ECBFF"}},fo=s("span",{style:{color:"#F97583"}},"|",-1),qo=s("span",{style:{color:"#9ECBFF"}}," ",-1),Po=s("span",{style:{color:"#B392F0"}},"tr",-1),Io=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),xo=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),Vo=o("",1),Ro={class:"shiki github-light vp-code-light"},Do={class:"line"},wo=o("",6),No={style:{color:"#032F62"}},$o=s("span",{style:{color:"#D73A49"}},"|",-1),Mo=s("span",{style:{color:"#032F62"}}," ",-1),Oo=s("span",{style:{color:"#6F42C1"}},"tr",-1),Ho=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Lo=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),Qo=o("",1),jo=o("",1),Uo=o("",3),zo={class:"vp-code-group vp-adaptive-theme"},Go=o("",1),Jo={class:"blocks"},Ko={class:"language-bash vp-adaptive-theme active"},Yo=s("button",{title:"Copy Code",class:"copy"},null,-1),Xo=s("span",{class:"lang"},"bash",-1),Zo={class:"shiki github-dark vp-code-dark"},Wo={class:"line"},sa=o("",6),oa={style:{color:"#9ECBFF"}},aa=o("",14),ea=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),na=o("",1),ta={class:"shiki github-light vp-code-light"},la={class:"line"},pa=o("",6),ca={style:{color:"#032F62"}},ra=o("",14),ia=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),da=o("",1),_a={class:"language-bash vp-adaptive-theme"},ha=s("button",{title:"Copy Code",class:"copy"},null,-1),ya=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o("",6),ga={style:{color:"#9ECBFF"}},Ca=s("span",{style:{color:"#F97583"}},"|",-1),ba=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ta=s("span",{style:{color:"#B392F0"}},"tr",-1),ma=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),Sa=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),va=o("",1),ka={class:"shiki github-light vp-code-light"},Ba={class:"line"},Aa=o("",6),fa={style:{color:"#032F62"}},qa=s("span",{style:{color:"#D73A49"}},"|",-1),Pa=s("span",{style:{color:"#032F62"}}," ",-1),Ia=s("span",{style:{color:"#6F42C1"}},"tr",-1),xa=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Va=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),Ra=o("",1),Da={class:"language-bash vp-adaptive-theme"},wa=s("button",{title:"Copy Code",class:"copy"},null,-1),Na=s("span",{class:"lang"},"bash",-1),$a={class:"shiki github-dark vp-code-dark"},Ma={class:"line"},Oa=o("",6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Qa=s("span",{style:{color:"#9ECBFF"}}," ",-1),ja=s("span",{style:{color:"#B392F0"}},"tr",-1),Ua=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),za=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),Ga=o("",1),Ja={class:"shiki github-light vp-code-light"},Ka={class:"line"},Ya=o("",6),Xa={style:{color:"#032F62"}},Za=s("span",{style:{color:"#D73A49"}},"|",-1),Wa=s("span",{style:{color:"#032F62"}}," ",-1),se=s("span",{style:{color:"#6F42C1"}},"tr",-1),oe=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),ae=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),ee=o("",1),ne=o("",34),te={class:"vp-code-group vp-adaptive-theme"},le=o("",1),pe={class:"blocks"},ce={class:"language-bash vp-adaptive-theme active"},re=s("button",{title:"Copy Code",class:"copy"},null,-1),ie=s("span",{class:"lang"},"bash",-1),de={class:"shiki github-dark vp-code-dark"},_e=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),he=o("",1),ye=o("",1),Ee=o("",1),ue={class:"line"},Fe=s("span",{style:{color:"#9ECBFF"}}," ",-1),ge=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ce=s("span",{style:{color:"#9ECBFF"}}," ",-1),be=s("span",{style:{color:"#79B8FF"}},"-o",-1),Te={style:{color:"#9ECBFF"}},me=o("",6),Se=o("",1),ve=o("",1),ke={class:"shiki github-light vp-code-light"},Be=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),Ae=o("",1),fe=o("",1),qe=o("",1),Pe={class:"line"},Ie=s("span",{style:{color:"#032F62"}}," ",-1),xe=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ve=s("span",{style:{color:"#032F62"}}," ",-1),Re=s("span",{style:{color:"#005CC5"}},"-o",-1),De={style:{color:"#032F62"}},we=o("",6),Ne=o("",1),$e=o("",1),Me={class:"language-bash vp-adaptive-theme"},Oe=s("button",{title:"Copy Code",class:"copy"},null,-1),He=s("span",{class:"lang"},"bash",-1),Le={class:"shiki github-dark vp-code-dark"},Qe=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),je=o("",1),Ue=o("",1),ze=o("",1),Ge={class:"line"},Je=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ke=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ye=s("span",{style:{color:"#9ECBFF"}}," ",-1),Xe=s("span",{style:{color:"#79B8FF"}},"-o",-1),Ze={style:{color:"#9ECBFF"}},We=o("",6),sn=o("",1),on=o("",1),an={class:"shiki github-light vp-code-light"},en=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),nn=o("",1),tn=o("",1),ln=o("",1),pn={class:"line"},cn=s("span",{style:{color:"#032F62"}}," ",-1),rn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),dn=s("span",{style:{color:"#032F62"}}," ",-1),_n=s("span",{style:{color:"#005CC5"}},"-o",-1),hn={style:{color:"#032F62"}},yn=o("",6),En=o("",1),un=o("",1),Fn={class:"language-bash vp-adaptive-theme"},gn=s("button",{title:"Copy Code",class:"copy"},null,-1),Cn=s("span",{class:"lang"},"bash",-1),bn={class:"shiki github-dark vp-code-dark"},Tn=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),mn=o("",1),Sn=o("",1),vn=o("",1),kn={class:"line"},Bn=s("span",{style:{color:"#9ECBFF"}}," ",-1),An=s("span",{style:{color:"#B392F0"}},"egrep",-1),fn=s("span",{style:{color:"#9ECBFF"}}," ",-1),qn=s("span",{style:{color:"#79B8FF"}},"-o",-1),Pn={style:{color:"#9ECBFF"}},In=o("",6),xn=o("",1),Vn=o("",1),Rn={class:"shiki github-light vp-code-light"},Dn=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),wn=o("",1),Nn=o("",1),$n=o("",1),Mn={class:"line"},On=s("span",{style:{color:"#032F62"}}," ",-1),Hn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ln=s("span",{style:{color:"#032F62"}}," ",-1),Qn=s("span",{style:{color:"#005CC5"}},"-o",-1),jn={style:{color:"#032F62"}},Un=o("",6),zn=o("",1),Gn=o("",1),Jn=o("",42),ot=JSON.parse('{"title":"Consensus node","description":"Learn how to set up a Celestia consensus node.","frontmatter":{"description":"Learn how to set up a Celestia consensus node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Consensus node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia consensus node."}]]},"headers":[],"relativePath":"how-to-guides/consensus-node.md","filePath":"how-to-guides/consensus-node.md","lastUpdated":1732776394000}'),Kn={name:"how-to-guides/consensus-node.md"},at=Object.assign(Kn,{setup(Yn){return(Xn,Zn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",h,[y,E,s("pre",u,[s("code",null,[s("span",F,[g,s("span",C,n(t(e).mainnetChainId),1)])])]),s("pre",b,[s("code",null,[s("span",T,[m,s("span",S,n(t(e).mainnetChainId),1)])])])]),s("div",v,[k,B,s("pre",A,[s("code",null,[s("span",f,[q,s("span",P,n(t(e).mochaChainId),1)])])]),s("pre",I,[s("code",null,[s("span",x,[V,s("span",R,n(t(e).mochaChainId),1)])])])]),s("div",D,[w,N,s("pre",$,[s("code",null,[s("span",M,[O,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",Q,[j,s("span",U,n(t(e).arabicaChainId),1)])])])])])]),z,s("div",G,[J,s("div",K,[s("div",Y,[X,Z,s("pre",W,[s("code",null,[s("span",ss,[os,as,es,ns,s("span",ts,n(t(e).mainnetChainId),1)])])]),s("pre",ls,[s("code",null,[s("span",ps,[cs,rs,is,ds,s("span",_s,n(t(e).mainnetChainId),1)])])])]),s("div",hs,[ys,Es,s("pre",us,[s("code",null,[s("span",Fs,[gs,Cs,bs,Ts,s("span",ms,n(t(e).mochaChainId),1)])])]),s("pre",Ss,[s("code",null,[s("span",vs,[ks,Bs,As,fs,s("span",qs,n(t(e).mochaChainId),1)])])])]),s("div",Ps,[Is,xs,s("pre",Vs,[s("code",null,[s("span",Rs,[Ds,ws,Ns,$s,s("span",Ms,n(t(e).arabicaChainId),1)])])]),s("pre",Os,[s("code",null,[s("span",Hs,[Ls,Qs,js,Us,s("span",zs,n(t(e).arabicaChainId),1)])])])])])]),Gs,s("div",Js,[Ks,s("div",Ys,[s("div",Xs,[Zs,Ws,s("pre",so,[s("code",null,[s("span",oo,[ao,s("span",eo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),no,to,lo,po]),a(` +import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/consensus-node.jpg",r=o("",14),i={class:"vp-code-group vp-adaptive-theme"},d=o("",1),_={class:"blocks"},h={class:"language-bash vp-adaptive-theme active"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},F={class:"line"},g=o("",8),C={style:{color:"#9ECBFF"}},b={class:"shiki github-light vp-code-light"},T={class:"line"},m=o("",8),S={style:{color:"#032F62"}},v={class:"language-bash vp-adaptive-theme"},k=s("button",{title:"Copy Code",class:"copy"},null,-1),A=s("span",{class:"lang"},"bash",-1),B={class:"shiki github-dark vp-code-dark"},f={class:"line"},q=o("",8),P={style:{color:"#9ECBFF"}},I={class:"shiki github-light vp-code-light"},x={class:"line"},V=o("",8),R={style:{color:"#032F62"}},D={class:"language-bash vp-adaptive-theme"},w=s("button",{title:"Copy Code",class:"copy"},null,-1),N=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},M={class:"line"},O=o("",8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},Q={class:"line"},z=o("",8),X={style:{color:"#032F62"}},j=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),W={class:"vp-code-group vp-adaptive-theme"},U=o("",1),Y={class:"blocks"},Z={class:"language-bash vp-adaptive-theme active"},K=s("button",{title:"Copy Code",class:"copy"},null,-1),G=s("span",{class:"lang"},"bash",-1),J={class:"shiki github-dark vp-code-dark"},ss={class:"line"},os=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),as=s("span",{style:{color:"#E1E4E8"}}," ",-1),es=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),ns=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ps={class:"line"},cs=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),is=s("span",{style:{color:"#032F62"}},"download-genesis",-1),ds=s("span",{style:{color:"#24292E"}}," ",-1),_s={style:{color:"#032F62"}},hs={class:"language-bash vp-adaptive-theme"},ys=s("button",{title:"Copy Code",class:"copy"},null,-1),Es=s("span",{class:"lang"},"bash",-1),us={class:"shiki github-dark vp-code-dark"},Fs={class:"line"},gs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),Cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),bs=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),Ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ms={style:{color:"#9ECBFF"}},Ss={class:"shiki github-light vp-code-light"},vs={class:"line"},ks=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),As=s("span",{style:{color:"#24292E"}}," ",-1),Bs=s("span",{style:{color:"#032F62"}},"download-genesis",-1),fs=s("span",{style:{color:"#24292E"}}," ",-1),qs={style:{color:"#032F62"}},Ps={class:"language-bash vp-adaptive-theme"},Is=s("button",{title:"Copy Code",class:"copy"},null,-1),xs=s("span",{class:"lang"},"bash",-1),Vs={class:"shiki github-dark vp-code-dark"},Rs={class:"line"},Ds=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),ws=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ns=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),$s=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ms={style:{color:"#9ECBFF"}},Os={class:"shiki github-light vp-code-light"},Hs={class:"line"},Ls=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Qs=s("span",{style:{color:"#24292E"}}," ",-1),zs=s("span",{style:{color:"#032F62"}},"download-genesis",-1),Xs=s("span",{style:{color:"#24292E"}}," ",-1),js={style:{color:"#032F62"}},Ws=s("p",null,[a("Set seeds in the "),s("code",null,"$HOME/.celestia-app/config/config.toml"),a(" file:")],-1),Us={class:"vp-code-group vp-adaptive-theme"},Ys=o("",1),Zs={class:"blocks"},Ks={class:"language-bash vp-adaptive-theme active"},Gs=s("button",{title:"Copy Code",class:"copy"},null,-1),Js=s("span",{class:"lang"},"bash",-1),so={class:"shiki github-dark vp-code-dark"},oo={class:"line"},ao=o("",6),eo={style:{color:"#9ECBFF"}},no=s("span",{style:{color:"#F97583"}},"|",-1),to=s("span",{style:{color:"#9ECBFF"}}," ",-1),lo=s("span",{style:{color:"#B392F0"}},"tr",-1),po=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),co=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),ro=o("",1),io={class:"shiki github-light vp-code-light"},_o={class:"line"},ho=o("",6),yo={style:{color:"#032F62"}},Eo=s("span",{style:{color:"#D73A49"}},"|",-1),uo=s("span",{style:{color:"#032F62"}}," ",-1),Fo=s("span",{style:{color:"#6F42C1"}},"tr",-1),go=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Co=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),bo=o("",1),To={class:"language-bash vp-adaptive-theme"},mo=s("button",{title:"Copy Code",class:"copy"},null,-1),So=s("span",{class:"lang"},"bash",-1),vo={class:"shiki github-dark vp-code-dark"},ko={class:"line"},Ao=o("",6),Bo={style:{color:"#9ECBFF"}},fo=s("span",{style:{color:"#F97583"}},"|",-1),qo=s("span",{style:{color:"#9ECBFF"}}," ",-1),Po=s("span",{style:{color:"#B392F0"}},"tr",-1),Io=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),xo=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $SEEDS")],-1),Vo=o("",1),Ro={class:"shiki github-light vp-code-light"},Do={class:"line"},wo=o("",6),No={style:{color:"#032F62"}},$o=s("span",{style:{color:"#D73A49"}},"|",-1),Mo=s("span",{style:{color:"#032F62"}}," ",-1),Oo=s("span",{style:{color:"#6F42C1"}},"tr",-1),Ho=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Lo=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),Qo=o("",1),zo=o("",1),Xo=o("",3),jo={class:"vp-code-group vp-adaptive-theme"},Wo=o("",1),Uo={class:"blocks"},Yo={class:"language-bash vp-adaptive-theme active"},Zo=s("button",{title:"Copy Code",class:"copy"},null,-1),Ko=s("span",{class:"lang"},"bash",-1),Go={class:"shiki github-dark vp-code-dark"},Jo={class:"line"},sa=o("",6),oa={style:{color:"#9ECBFF"}},aa=o("",14),ea=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),na=o("",1),ta={class:"shiki github-light vp-code-light"},la={class:"line"},pa=o("",6),ca={style:{color:"#032F62"}},ra=o("",14),ia=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),da=o("",1),_a={class:"language-bash vp-adaptive-theme"},ha=s("button",{title:"Copy Code",class:"copy"},null,-1),ya=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o("",6),ga={style:{color:"#9ECBFF"}},Ca=s("span",{style:{color:"#F97583"}},"|",-1),ba=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ta=s("span",{style:{color:"#B392F0"}},"tr",-1),ma=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),Sa=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),va=o("",1),ka={class:"shiki github-light vp-code-light"},Aa={class:"line"},Ba=o("",6),fa={style:{color:"#032F62"}},qa=s("span",{style:{color:"#D73A49"}},"|",-1),Pa=s("span",{style:{color:"#032F62"}}," ",-1),Ia=s("span",{style:{color:"#6F42C1"}},"tr",-1),xa=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),Va=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),Ra=o("",1),Da={class:"language-bash vp-adaptive-theme"},wa=s("button",{title:"Copy Code",class:"copy"},null,-1),Na=s("span",{class:"lang"},"bash",-1),$a={class:"shiki github-dark vp-code-dark"},Ma={class:"line"},Oa=o("",6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Qa=s("span",{style:{color:"#9ECBFF"}}," ",-1),za=s("span",{style:{color:"#B392F0"}},"tr",-1),Xa=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),ja=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),Wa=o("",1),Ua={class:"shiki github-light vp-code-light"},Ya={class:"line"},Za=o("",6),Ka={style:{color:"#032F62"}},Ga=s("span",{style:{color:"#D73A49"}},"|",-1),Ja=s("span",{style:{color:"#032F62"}}," ",-1),se=s("span",{style:{color:"#6F42C1"}},"tr",-1),oe=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),ae=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $PERSISTENT_PEERS")],-1),ee=o("",1),ne=o("",34),te={class:"vp-code-group vp-adaptive-theme"},le=o("",1),pe={class:"blocks"},ce={class:"language-bash vp-adaptive-theme active"},re=s("button",{title:"Copy Code",class:"copy"},null,-1),ie=s("span",{class:"lang"},"bash",-1),de={class:"shiki github-dark vp-code-dark"},_e=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),he=o("",1),ye=o("",1),Ee=o("",1),ue={class:"line"},Fe=s("span",{style:{color:"#9ECBFF"}}," ",-1),ge=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ce=s("span",{style:{color:"#9ECBFF"}}," ",-1),be=s("span",{style:{color:"#79B8FF"}},"-o",-1),Te={style:{color:"#9ECBFF"}},me=o("",6),Se=o("",1),ve=o("",1),ke={class:"shiki github-light vp-code-light"},Ae=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),Be=o("",1),fe=o("",1),qe=o("",1),Pe={class:"line"},Ie=s("span",{style:{color:"#032F62"}}," ",-1),xe=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ve=s("span",{style:{color:"#032F62"}}," ",-1),Re=s("span",{style:{color:"#005CC5"}},"-o",-1),De={style:{color:"#032F62"}},we=o("",6),Ne=o("",1),$e=o("",1),Me={class:"language-bash vp-adaptive-theme"},Oe=s("button",{title:"Copy Code",class:"copy"},null,-1),He=s("span",{class:"lang"},"bash",-1),Le={class:"shiki github-dark vp-code-dark"},Qe=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),ze=o("",1),Xe=o("",1),je=o("",1),We={class:"line"},Ue=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ye=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ze=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ke=s("span",{style:{color:"#79B8FF"}},"-o",-1),Ge={style:{color:"#9ECBFF"}},Je=o("",6),sn=o("",1),on=o("",1),an={class:"shiki github-light vp-code-light"},en=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),nn=o("",1),tn=o("",1),ln=o("",1),pn={class:"line"},cn=s("span",{style:{color:"#032F62"}}," ",-1),rn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),dn=s("span",{style:{color:"#032F62"}}," ",-1),_n=s("span",{style:{color:"#005CC5"}},"-o",-1),hn={style:{color:"#032F62"}},yn=o("",6),En=o("",1),un=o("",1),Fn={class:"language-bash vp-adaptive-theme"},gn=s("button",{title:"Copy Code",class:"copy"},null,-1),Cn=s("span",{class:"lang"},"bash",-1),bn={class:"shiki github-dark vp-code-dark"},Tn=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),mn=o("",1),Sn=o("",1),vn=o("",1),kn={class:"line"},An=s("span",{style:{color:"#9ECBFF"}}," ",-1),Bn=s("span",{style:{color:"#B392F0"}},"egrep",-1),fn=s("span",{style:{color:"#9ECBFF"}}," ",-1),qn=s("span",{style:{color:"#79B8FF"}},"-o",-1),Pn={style:{color:"#9ECBFF"}},In=o("",6),xn=o("",1),Vn=o("",1),Rn={class:"shiki github-light vp-code-light"},Dn=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"cd"),s("span",{style:{color:"#24292E"}}," $HOME")],-1),wn=o("",1),Nn=o("",1),$n=o("",1),Mn={class:"line"},On=s("span",{style:{color:"#032F62"}}," ",-1),Hn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ln=s("span",{style:{color:"#032F62"}}," ",-1),Qn=s("span",{style:{color:"#005CC5"}},"-o",-1),zn={style:{color:"#032F62"}},Xn=o("",6),jn=o("",1),Wn=o("",1),Un=o("",42),ot=JSON.parse('{"title":"Consensus node","description":"Learn how to set up a Celestia consensus node.","frontmatter":{"description":"Learn how to set up a Celestia consensus node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Consensus node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia consensus node."}]]},"headers":[],"relativePath":"how-to-guides/consensus-node.md","filePath":"how-to-guides/consensus-node.md","lastUpdated":1732777479000}'),Yn={name:"how-to-guides/consensus-node.md"},at=Object.assign(Yn,{setup(Zn){return(Kn,Gn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",h,[y,E,s("pre",u,[s("code",null,[s("span",F,[g,s("span",C,n(t(e).mainnetChainId),1)])])]),s("pre",b,[s("code",null,[s("span",T,[m,s("span",S,n(t(e).mainnetChainId),1)])])])]),s("div",v,[k,A,s("pre",B,[s("code",null,[s("span",f,[q,s("span",P,n(t(e).mochaChainId),1)])])]),s("pre",I,[s("code",null,[s("span",x,[V,s("span",R,n(t(e).mochaChainId),1)])])])]),s("div",D,[w,N,s("pre",$,[s("code",null,[s("span",M,[O,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",Q,[z,s("span",X,n(t(e).arabicaChainId),1)])])])])])]),j,s("div",W,[U,s("div",Y,[s("div",Z,[K,G,s("pre",J,[s("code",null,[s("span",ss,[os,as,es,ns,s("span",ts,n(t(e).mainnetChainId),1)])])]),s("pre",ls,[s("code",null,[s("span",ps,[cs,rs,is,ds,s("span",_s,n(t(e).mainnetChainId),1)])])])]),s("div",hs,[ys,Es,s("pre",us,[s("code",null,[s("span",Fs,[gs,Cs,bs,Ts,s("span",ms,n(t(e).mochaChainId),1)])])]),s("pre",Ss,[s("code",null,[s("span",vs,[ks,As,Bs,fs,s("span",qs,n(t(e).mochaChainId),1)])])])]),s("div",Ps,[Is,xs,s("pre",Vs,[s("code",null,[s("span",Rs,[Ds,ws,Ns,$s,s("span",Ms,n(t(e).arabicaChainId),1)])])]),s("pre",Os,[s("code",null,[s("span",Hs,[Ls,Qs,zs,Xs,s("span",js,n(t(e).arabicaChainId),1)])])])])])]),Ws,s("div",Us,[Ys,s("div",Zs,[s("div",Ks,[Gs,Js,s("pre",so,[s("code",null,[s("span",oo,[ao,s("span",eo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),no,to,lo,po]),a(` `),co,a(` `),ro])]),s("pre",io,[s("code",null,[s("span",_o,[ho,s("span",yo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),Eo,uo,Fo,go]),a(` `),Co,a(` -`),bo])])]),s("div",To,[mo,So,s("pre",vo,[s("code",null,[s("span",ko,[Bo,s("span",Ao," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/seeds.txt ",1),fo,qo,Po,Io]),a(` +`),bo])])]),s("div",To,[mo,So,s("pre",vo,[s("code",null,[s("span",ko,[Ao,s("span",Bo," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/seeds.txt ",1),fo,qo,Po,Io]),a(` `),xo,a(` `),Vo])]),s("pre",Ro,[s("code",null,[s("span",Do,[wo,s("span",No," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/seeds.txt ",1),$o,Mo,Oo,Ho]),a(` `),Lo,a(` -`),Qo])])]),jo])]),s("details",null,[Uo,s("div",zo,[Go,s("div",Jo,[s("div",Ko,[Yo,Xo,s("pre",Zo,[s("code",null,[s("span",Wo,[sa,s("span",oa," https://raw.githubusercontent.com/cosmos/chain-registry/master/"+n(t(e).mainnetChainId)+"/chain.json ",1),aa]),a(` +`),Qo])])]),zo])]),s("details",null,[Xo,s("div",jo,[Wo,s("div",Uo,[s("div",Yo,[Zo,Ko,s("pre",Go,[s("code",null,[s("span",Jo,[sa,s("span",oa," https://raw.githubusercontent.com/cosmos/chain-registry/master/"+n(t(e).mainnetChainId)+"/chain.json ",1),aa]),a(` `),ea,a(` `),na])]),s("pre",ta,[s("code",null,[s("span",la,[pa,s("span",ca," https://raw.githubusercontent.com/cosmos/chain-registry/master/"+n(t(e).mainnetChainId)+"/chain.json ",1),ra]),a(` `),ia,a(` `),da])])]),s("div",_a,[ha,ya,s("pre",Ea,[s("code",null,[s("span",ua,[Fa,s("span",ga," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),Ca,ba,Ta,ma]),a(` `),Sa,a(` -`),va])]),s("pre",ka,[s("code",null,[s("span",Ba,[Aa,s("span",fa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),qa,Pa,Ia,xa]),a(` +`),va])]),s("pre",ka,[s("code",null,[s("span",Aa,[Ba,s("span",fa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),qa,Pa,Ia,xa]),a(` `),Va,a(` -`),Ra])])]),s("div",Da,[wa,Na,s("pre",$a,[s("code",null,[s("span",Ma,[Oa,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Qa,ja,Ua]),a(` -`),za,a(` -`),Ga])]),s("pre",Ja,[s("code",null,[s("span",Ka,[Ya,s("span",Xa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),Za,Wa,se,oe]),a(` +`),Ra])])]),s("div",Da,[wa,Na,s("pre",$a,[s("code",null,[s("span",Ma,[Oa,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Qa,za,Xa]),a(` +`),ja,a(` +`),Wa])]),s("pre",Ua,[s("code",null,[s("span",Ya,[Za,s("span",Ka," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),Ga,Ja,se,oe]),a(` `),ae,a(` `),ee])])])])])]),ne,s("div",te,[le,s("div",pe,[s("div",ce,[re,ie,s("pre",de,[s("code",null,[_e,a(` `),he,a(` @@ -24,17 +24,17 @@ import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t `),Ee,a(` `),s("span",ue,[Fe,ge,Ce,be,s("span",Te,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),me]),a(` `),Se,a(` -`),ve])]),s("pre",ke,[s("code",null,[Be,a(` -`),Ae,a(` +`),ve])]),s("pre",ke,[s("code",null,[Ae,a(` +`),Be,a(` `),fe,a(` `),qe,a(` `),s("span",Pe,[Ie,xe,Ve,Re,s("span",De,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),we]),a(` `),Ne,a(` `),$e])])]),s("div",Me,[Oe,He,s("pre",Le,[s("code",null,[Qe,a(` -`),je,a(` -`),Ue,a(` `),ze,a(` -`),s("span",Ge,[Je,Ke,Ye,Xe,s("span",Ze,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),We]),a(` +`),Xe,a(` +`),je,a(` +`),s("span",We,[Ue,Ye,Ze,Ke,s("span",Ge,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),Je]),a(` `),sn,a(` `),on])]),s("pre",an,[s("code",null,[en,a(` `),nn,a(` @@ -46,12 +46,12 @@ import{c as e}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,t `),mn,a(` `),Sn,a(` `),vn,a(` -`),s("span",kn,[Bn,An,fn,qn,s("span",Pn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),In]),a(` +`),s("span",kn,[An,Bn,fn,qn,s("span",Pn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),In]),a(` `),xn,a(` `),Vn])]),s("pre",Rn,[s("code",null,[Dn,a(` `),wn,a(` `),Nn,a(` `),$n,a(` -`),s("span",Mn,[On,Hn,Ln,Qn,s("span",jn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),Un]),a(` -`),zn,a(` -`),Gn])])])])]),Jn]))}});export{ot as __pageData,at as default}; +`),s("span",Mn,[On,Hn,Ln,Qn,s("span",zn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),Xn]),a(` +`),jn,a(` +`),Wn])])])])]),Un]))}});export{ot as __pageData,at as default}; diff --git a/pr-1815/assets/how-to-guides_decide-node.md.985bb243.js b/pr-1815/assets/how-to-guides_decide-node.md.29d9cc16.js similarity index 97% rename from pr-1815/assets/how-to-guides_decide-node.md.985bb243.js rename to pr-1815/assets/how-to-guides_decide-node.md.29d9cc16.js index acc705347..b8deb82d8 100644 --- a/pr-1815/assets/how-to-guides_decide-node.md.985bb243.js +++ b/pr-1815/assets/how-to-guides_decide-node.md.29d9cc16.js @@ -1 +1 @@ -import{_ as e,o,c as n,Q as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Deciding which node to run","description":"Guide on helping you decide which type of node to run.","frontmatter":{"description":"Guide on helping you decide which type of node to run.","head":[["meta",{"property":"og:title","content":"Deciding which node to run | Celestia Docs"}],["meta",{"property":"og:description","content":"Guide on helping you decide which type of node to run."}]]},"headers":[],"relativePath":"how-to-guides/decide-node.md","filePath":"how-to-guides/decide-node.md","lastUpdated":1732776394000}'),a={name:"how-to-guides/decide-node.md"},i=t('

    Deciding which node to run

    Now that you have installed the basic dependencies, you can start exploring which nodes to run!

    Light node

    It is highly recommended to get started with running a data availability light node.

    You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

    Other DA nodes

    Depending on your use case, you also may want to run a bridge node or a full DA node.

    Consensus node

    If you are looking to run a consensus node, please follow the tutorial for running a consensus node.

    Note that running a validator means you must also run a bridge node, which is covered in this section.

    ',10),d=[i];function r(h,s,c,l,u,p){return o(),n("div",null,d)}const _=e(a,[["render",r]]);export{f as __pageData,_ as default}; +import{_ as e,o,c as n,Q as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Deciding which node to run","description":"Guide on helping you decide which type of node to run.","frontmatter":{"description":"Guide on helping you decide which type of node to run.","head":[["meta",{"property":"og:title","content":"Deciding which node to run | Celestia Docs"}],["meta",{"property":"og:description","content":"Guide on helping you decide which type of node to run."}]]},"headers":[],"relativePath":"how-to-guides/decide-node.md","filePath":"how-to-guides/decide-node.md","lastUpdated":1732777479000}'),a={name:"how-to-guides/decide-node.md"},i=t('

    Deciding which node to run

    Now that you have installed the basic dependencies, you can start exploring which nodes to run!

    Light node

    It is highly recommended to get started with running a data availability light node.

    You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

    Other DA nodes

    Depending on your use case, you also may want to run a bridge node or a full DA node.

    Consensus node

    If you are looking to run a consensus node, please follow the tutorial for running a consensus node.

    Note that running a validator means you must also run a bridge node, which is covered in this section.

    ',10),d=[i];function r(h,s,c,l,u,p){return o(),n("div",null,d)}const _=e(a,[["render",r]]);export{f as __pageData,_ as default}; diff --git a/pr-1815/assets/how-to-guides_decide-node.md.985bb243.lean.js b/pr-1815/assets/how-to-guides_decide-node.md.29d9cc16.lean.js similarity index 91% rename from pr-1815/assets/how-to-guides_decide-node.md.985bb243.lean.js rename to pr-1815/assets/how-to-guides_decide-node.md.29d9cc16.lean.js index 1ecab9b32..cde81a9f0 100644 --- a/pr-1815/assets/how-to-guides_decide-node.md.985bb243.lean.js +++ b/pr-1815/assets/how-to-guides_decide-node.md.29d9cc16.lean.js @@ -1 +1 @@ -import{_ as e,o,c as n,Q as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Deciding which node to run","description":"Guide on helping you decide which type of node to run.","frontmatter":{"description":"Guide on helping you decide which type of node to run.","head":[["meta",{"property":"og:title","content":"Deciding which node to run | Celestia Docs"}],["meta",{"property":"og:description","content":"Guide on helping you decide which type of node to run."}]]},"headers":[],"relativePath":"how-to-guides/decide-node.md","filePath":"how-to-guides/decide-node.md","lastUpdated":1732776394000}'),a={name:"how-to-guides/decide-node.md"},i=t("",10),d=[i];function r(h,s,c,l,u,p){return o(),n("div",null,d)}const _=e(a,[["render",r]]);export{f as __pageData,_ as default}; +import{_ as e,o,c as n,Q as t}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Deciding which node to run","description":"Guide on helping you decide which type of node to run.","frontmatter":{"description":"Guide on helping you decide which type of node to run.","head":[["meta",{"property":"og:title","content":"Deciding which node to run | Celestia Docs"}],["meta",{"property":"og:description","content":"Guide on helping you decide which type of node to run."}]]},"headers":[],"relativePath":"how-to-guides/decide-node.md","filePath":"how-to-guides/decide-node.md","lastUpdated":1732777479000}'),a={name:"how-to-guides/decide-node.md"},i=t("",10),d=[i];function r(h,s,c,l,u,p){return o(),n("div",null,d)}const _=e(a,[["render",r]]);export{f as __pageData,_ as default}; diff --git a/pr-1815/assets/how-to-guides_docker-images.md.72749f80.js b/pr-1815/assets/how-to-guides_docker-images.md.23a48650.js similarity index 86% rename from pr-1815/assets/how-to-guides_docker-images.md.72749f80.js rename to pr-1815/assets/how-to-guides_docker-images.md.23a48650.js index 4f2c81534..990215e00 100644 --- a/pr-1815/assets/how-to-guides_docker-images.md.72749f80.js +++ b/pr-1815/assets/how-to-guides_docker-images.md.23a48650.js @@ -1,59 +1,59 @@ -import{a as l}from"./chunks/arabica_versions.8cd8d43b.js";import{m as t}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as p}from"./chunks/mainnet_versions.f2c187e6.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.2959b752.js";const _=o('

    🐳 Docker setup

    This page has instructions to run celestia-node using Docker. If you are looking for instructions to run celestia-node using a binary, please refer to the celestia-node page.

    Using Docker is the easiest way to run celestia-node for most users. Docker is a containerization platform that allows you to run celestia-node in an isolated environment.

    This means that you can run celestia-node on your machine without having to worry about installing and configuring all of the dependencies required to run the node.

    If you would like to learn more about key management in Docker, visit the Docker and cel-key section.

    The easiest way to install Docker is to use the Docker Desktop installer or Ubuntu. You can follow the instructions for your operating system.

    Prerequisites

    Quick start

    ',9),i=o('
  • Set the network you would like to run your node on:

    bash
    export NETWORK=celestia
    export NETWORK=celestia
    bash
    export NETWORK=mocha
    export NETWORK=mocha
    bash
    export NETWORK=arabica
    export NETWORK=arabica
  • Set the node type

    bash
    export NODE_TYPE=light
    export NODE_TYPE=light
    bash
    export NODE_TYPE=bridge
    export NODE_TYPE=bridge
    bash
    export NODE_TYPE=full
    export NODE_TYPE=full
  • Set an RPC endpoint for either Mainnet Beta, Mocha, or Arabica using the bare URL (without http or https):

    bash
    export RPC_URL=this-is-an-rpc-url.com
    export RPC_URL=this-is-an-rpc-url.com
  • ',3),E=s("p",null,"Run the image from the command line:",-1),y={class:"vp-code-group vp-adaptive-theme"},d=o('
    ',1),h={class:"blocks"},T={class:"language-bash vp-adaptive-theme active"},F=s("button",{title:"Copy Code",class:"copy"},null,-1),C=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),b={class:"line"},v=s("span",{style:{color:"#E1E4E8"}}," ",-1),P={style:{color:"#9ECBFF"}},k=s("span",{style:{color:"#E1E4E8"}}," ",-1),m=s("span",{style:{color:"#79B8FF"}},"\\",-1),A=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),S={class:"shiki github-light vp-code-light"},N=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),B={class:"line"},D=s("span",{style:{color:"#24292E"}}," ",-1),R={style:{color:"#032F62"}},O=s("span",{style:{color:"#24292E"}}," ",-1),V=s("span",{style:{color:"#005CC5"}},"\\",-1),I=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),f={class:"language-bash vp-adaptive-theme"},$=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),W={class:"shiki github-dark vp-code-dark"},K=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Y={class:"line"},M=s("span",{style:{color:"#E1E4E8"}}," ",-1),x={style:{color:"#9ECBFF"}},H=s("span",{style:{color:"#E1E4E8"}}," ",-1),q=s("span",{style:{color:"#79B8FF"}},"\\",-1),L=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),U={class:"shiki github-light vp-code-light"},j=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Q={class:"line"},z=s("span",{style:{color:"#24292E"}}," ",-1),X={style:{color:"#032F62"}},G=s("span",{style:{color:"#24292E"}}," ",-1),J=s("span",{style:{color:"#005CC5"}},"\\",-1),Z=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),ss={class:"language-bash vp-adaptive-theme"},os=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"bash",-1),ns={class:"shiki github-dark vp-code-dark"},es=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ls={class:"line"},ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ps={style:{color:"#9ECBFF"}},cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),rs=s("span",{style:{color:"#79B8FF"}},"\\",-1),_s=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),is={class:"shiki github-light vp-code-light"},Es=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ys={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},Ts=s("span",{style:{color:"#24292E"}}," ",-1),Fs=s("span",{style:{color:"#005CC5"}},"\\",-1),Cs=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),us=o(`

    Congratulations! You now have a celestia-node running!

    If you would like to run the node with custom flags, you can refer to the celestia-node tutorial page. Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Light node setup with persistent storage

    If you delete a container that you started above, all data will be lost. To avoid this, you can mount a volume to the container. This will allow you to persist data even after the container is deleted.

    First, you will need to create a directory on your host machine. This directory will be used to store the data for the container. Create a directory on your host machine and give it a name. For example, you can name it my-node-store:

    bash
    cd $HOME
    +import{a as l}from"./chunks/arabica_versions.8cd8d43b.js";import{m as t}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as p}from"./chunks/mainnet_versions.f2c187e6.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.2959b752.js";const _=o('

    🐳 Docker setup

    This page has instructions to run celestia-node using Docker. If you are looking for instructions to run celestia-node using a binary, please refer to the celestia-node page.

    Using Docker is the easiest way to run celestia-node for most users. Docker is a containerization platform that allows you to run celestia-node in an isolated environment.

    This means that you can run celestia-node on your machine without having to worry about installing and configuring all of the dependencies required to run the node.

    If you would like to learn more about key management in Docker, visit the Docker and cel-key section.

    The easiest way to install Docker is to use the Docker Desktop installer or Ubuntu. You can follow the instructions for your operating system.

    Prerequisites

    Quick start

    ',9),i=o('
  • Set the network you would like to run your node on:

    bash
    export NETWORK=celestia
    export NETWORK=celestia
    bash
    export NETWORK=mocha
    export NETWORK=mocha
    bash
    export NETWORK=arabica
    export NETWORK=arabica
  • Set the node type

    bash
    export NODE_TYPE=light
    export NODE_TYPE=light
    bash
    export NODE_TYPE=bridge
    export NODE_TYPE=bridge
    bash
    export NODE_TYPE=full
    export NODE_TYPE=full
  • Set an RPC endpoint for either Mainnet Beta, Mocha, or Arabica using the bare URL (without http or https):

    bash
    export RPC_URL=this-is-an-rpc-url.com
    export RPC_URL=this-is-an-rpc-url.com
  • ',3),E=s("p",null,"Run the image from the command line:",-1),y={class:"vp-code-group vp-adaptive-theme"},d=o('
    ',1),h={class:"blocks"},T={class:"language-bash vp-adaptive-theme active"},F=s("button",{title:"Copy Code",class:"copy"},null,-1),C=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),b={class:"line"},v=s("span",{style:{color:"#E1E4E8"}}," ",-1),k={style:{color:"#9ECBFF"}},P=s("span",{style:{color:"#E1E4E8"}}," ",-1),m=s("span",{style:{color:"#79B8FF"}},"\\",-1),A=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),S={class:"shiki github-light vp-code-light"},N=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),B={class:"line"},R=s("span",{style:{color:"#24292E"}}," ",-1),D={style:{color:"#032F62"}},O=s("span",{style:{color:"#24292E"}}," ",-1),I=s("span",{style:{color:"#005CC5"}},"\\",-1),V=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),f={class:"language-bash vp-adaptive-theme"},$=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),W={class:"shiki github-dark vp-code-dark"},K=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Y={class:"line"},M=s("span",{style:{color:"#E1E4E8"}}," ",-1),x={style:{color:"#9ECBFF"}},L=s("span",{style:{color:"#E1E4E8"}}," ",-1),q=s("span",{style:{color:"#79B8FF"}},"\\",-1),H=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),U={class:"shiki github-light vp-code-light"},z=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),J={class:"line"},Q=s("span",{style:{color:"#24292E"}}," ",-1),Z={style:{color:"#032F62"}},j=s("span",{style:{color:"#24292E"}}," ",-1),G=s("span",{style:{color:"#005CC5"}},"\\",-1),X=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),ss={class:"language-bash vp-adaptive-theme"},os=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"bash",-1),ns={class:"shiki github-dark vp-code-dark"},es=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ls={class:"line"},ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ps={style:{color:"#9ECBFF"}},cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),rs=s("span",{style:{color:"#79B8FF"}},"\\",-1),_s=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),is={class:"shiki github-light vp-code-light"},Es=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ys={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},Ts=s("span",{style:{color:"#24292E"}}," ",-1),Fs=s("span",{style:{color:"#005CC5"}},"\\",-1),Cs=o(' celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK',1),us=o(`

    Congratulations! You now have a celestia-node running!

    If you would like to run the node with custom flags, you can refer to the celestia-node tutorial page. Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Light node setup with persistent storage

    If you delete a container that you started above, all data will be lost. To avoid this, you can mount a volume to the container. This will allow you to persist data even after the container is deleted.

    First, you will need to create a directory on your host machine. This directory will be used to store the data for the container. Create a directory on your host machine and give it a name. For example, you can name it my-node-store:

    bash
    cd $HOME
     mkdir my-node-store
    cd $HOME
    -mkdir my-node-store

    Now, you can mount this directory to the container. Before mounting a volume, you may need to set permissions for the user on the host machine by running:

    bash
    sudo chown 10001:10001 $HOME/my-node-store
    sudo chown 10001:10001 $HOME/my-node-store
    bash
    # you're good to go 😎
    # you're good to go 😎

    Initialize the node store and key

    In order to mount a volume to the container, you need to specify the path to the volume. When you run your container, you can specify the path to the volume using the --volume (or -v for short) flag. In this command, we'll create our key and initialize the node store, using the variables we set in the quick start section:

    bash
    # --volume == -v [local path]:[container path]
    +mkdir my-node-store

    Now, you can mount this directory to the container. Before mounting a volume, you may need to set permissions for the user on the host machine by running:

    bash
    sudo chown 10001:10001 $HOME/my-node-store
    sudo chown 10001:10001 $HOME/my-node-store
    bash
    # you're good to go 😎
    # you're good to go 😎

    Initialize the node store and key

    In order to mount a volume to the container, you need to specify the path to the volume. When you run your container, you can specify the path to the volume using the --volume (or -v for short) flag. In this command, we'll create our key and initialize the node store, using the variables we set in the quick start section:

    bash
    # --volume == -v [local path]:[container path]
     docker run [args...] -v $HOME/my-node-store:/home/celestia \\
         celestia $NODE_TYPE init [args...]
    # --volume == -v [local path]:[container path]
     docker run [args...] -v $HOME/my-node-store:/home/celestia \\
    -    celestia $NODE_TYPE init [args...]

    An example init command will look similar to below:

    `,12),gs={class:"vp-code-group vp-adaptive-theme"},bs=o('
    ',1),vs={class:"blocks"},Ps={class:"language-bash vp-adaptive-theme active"},ks=s("button",{title:"Copy Code",class:"copy"},null,-1),ms=s("span",{class:"lang"},"bash",-1),As={class:"shiki github-dark vp-code-dark"},Ss=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ns=o(' -v $HOME/my-node-store:/home/celestia \\',1),Bs={class:"line"},Ds=s("span",{style:{color:"#E1E4E8"}}," ",-1),Rs={style:{color:"#9ECBFF"}},Os=s("span",{style:{color:"#E1E4E8"}}," ",-1),Vs=s("span",{style:{color:"#79B8FF"}},"\\",-1),Is=o(' celestia light init --p2p.network $NETWORK',1),fs={class:"shiki github-light vp-code-light"},$s=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ws=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ws={class:"line"},Ks=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},Ms=s("span",{style:{color:"#24292E"}}," ",-1),xs=s("span",{style:{color:"#005CC5"}},"\\",-1),Hs=o(' celestia light init --p2p.network $NETWORK',1),qs={class:"language-bash vp-adaptive-theme"},Ls=s("button",{title:"Copy Code",class:"copy"},null,-1),Us=s("span",{class:"lang"},"bash",-1),js={class:"shiki github-dark vp-code-dark"},Qs=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),zs=o(' -v $HOME/my-node-store:/home/celestia \\',1),Xs={class:"line"},Gs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Js={style:{color:"#9ECBFF"}},Zs=s("span",{style:{color:"#E1E4E8"}}," ",-1),so=s("span",{style:{color:"#79B8FF"}},"\\",-1),oo=o(' celestia light init --p2p.network $NETWORK',1),ao={class:"shiki github-light vp-code-light"},no=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),eo=o(' -v $HOME/my-node-store:/home/celestia \\',1),lo={class:"line"},to=s("span",{style:{color:"#24292E"}}," ",-1),po={style:{color:"#032F62"}},co=s("span",{style:{color:"#24292E"}}," ",-1),ro=s("span",{style:{color:"#005CC5"}},"\\",-1),_o=o(' celestia light init --p2p.network $NETWORK',1),io={class:"language-bash vp-adaptive-theme"},Eo=s("button",{title:"Copy Code",class:"copy"},null,-1),yo=s("span",{class:"lang"},"bash",-1),ho={class:"shiki github-dark vp-code-dark"},To=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Fo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Co={class:"line"},uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),go={style:{color:"#9ECBFF"}},bo=s("span",{style:{color:"#E1E4E8"}}," ",-1),vo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Po=o(' celestia light init --p2p.network $NETWORK',1),ko={class:"shiki github-light vp-code-light"},mo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ao=o(' -v $HOME/my-node-store:/home/celestia \\',1),So={class:"line"},No=s("span",{style:{color:"#24292E"}}," ",-1),Bo={style:{color:"#032F62"}},Do=s("span",{style:{color:"#24292E"}}," ",-1),Ro=s("span",{style:{color:"#005CC5"}},"\\",-1),Oo=o(' celestia light init --p2p.network $NETWORK',1),Vo=o(`

    Start the node

    Run the following command to start the node:

    bash
    # --volume == -v [local path]:[container path]
    +    celestia $NODE_TYPE init [args...]

    An example init command will look similar to below:

    `,12),gs={class:"vp-code-group vp-adaptive-theme"},bs=o('
    ',1),vs={class:"blocks"},ks={class:"language-bash vp-adaptive-theme active"},Ps=s("button",{title:"Copy Code",class:"copy"},null,-1),ms=s("span",{class:"lang"},"bash",-1),As={class:"shiki github-dark vp-code-dark"},Ss=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ns=o(' -v $HOME/my-node-store:/home/celestia \\',1),Bs={class:"line"},Rs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ds={style:{color:"#9ECBFF"}},Os=s("span",{style:{color:"#E1E4E8"}}," ",-1),Is=s("span",{style:{color:"#79B8FF"}},"\\",-1),Vs=o(' celestia light init --p2p.network $NETWORK',1),fs={class:"shiki github-light vp-code-light"},$s=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ws=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ws={class:"line"},Ks=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},Ms=s("span",{style:{color:"#24292E"}}," ",-1),xs=s("span",{style:{color:"#005CC5"}},"\\",-1),Ls=o(' celestia light init --p2p.network $NETWORK',1),qs={class:"language-bash vp-adaptive-theme"},Hs=s("button",{title:"Copy Code",class:"copy"},null,-1),Us=s("span",{class:"lang"},"bash",-1),zs={class:"shiki github-dark vp-code-dark"},Js=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Qs=o(' -v $HOME/my-node-store:/home/celestia \\',1),Zs={class:"line"},js=s("span",{style:{color:"#E1E4E8"}}," ",-1),Gs={style:{color:"#9ECBFF"}},Xs=s("span",{style:{color:"#E1E4E8"}}," ",-1),so=s("span",{style:{color:"#79B8FF"}},"\\",-1),oo=o(' celestia light init --p2p.network $NETWORK',1),ao={class:"shiki github-light vp-code-light"},no=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),eo=o(' -v $HOME/my-node-store:/home/celestia \\',1),lo={class:"line"},to=s("span",{style:{color:"#24292E"}}," ",-1),po={style:{color:"#032F62"}},co=s("span",{style:{color:"#24292E"}}," ",-1),ro=s("span",{style:{color:"#005CC5"}},"\\",-1),_o=o(' celestia light init --p2p.network $NETWORK',1),io={class:"language-bash vp-adaptive-theme"},Eo=s("button",{title:"Copy Code",class:"copy"},null,-1),yo=s("span",{class:"lang"},"bash",-1),ho={class:"shiki github-dark vp-code-dark"},To=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Fo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Co={class:"line"},uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),go={style:{color:"#9ECBFF"}},bo=s("span",{style:{color:"#E1E4E8"}}," ",-1),vo=s("span",{style:{color:"#79B8FF"}},"\\",-1),ko=o(' celestia light init --p2p.network $NETWORK',1),Po={class:"shiki github-light vp-code-light"},mo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ao=o(' -v $HOME/my-node-store:/home/celestia \\',1),So={class:"line"},No=s("span",{style:{color:"#24292E"}}," ",-1),Bo={style:{color:"#032F62"}},Ro=s("span",{style:{color:"#24292E"}}," ",-1),Do=s("span",{style:{color:"#005CC5"}},"\\",-1),Oo=o(' celestia light init --p2p.network $NETWORK',1),Io=o(`

    Start the node

    Run the following command to start the node:

    bash
    # --volume == -v [local path]:[container path]
     docker run [...args] -v $HOME/my-node-store:/home/celestia \\
         celestia <node-type> start [...args]
    # --volume == -v [local path]:[container path]
     docker run [...args] -v $HOME/my-node-store:/home/celestia \\
    -    celestia <node-type> start [...args]

    A full start command will look similar to below.

    `,4),Io={class:"vp-code-group vp-adaptive-theme"},fo=o('
    ',1),$o={class:"blocks"},wo={class:"language-bash vp-adaptive-theme active"},Wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Ko=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},Mo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),xo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ho={class:"line"},qo=s("span",{style:{color:"#E1E4E8"}}," ",-1),Lo={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),jo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Qo=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),zo={class:"shiki github-light vp-code-light"},Xo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Go=o(' -v $HOME/my-node-store:/home/celestia \\',1),Jo={class:"line"},Zo=s("span",{style:{color:"#24292E"}}," ",-1),sa={style:{color:"#032F62"}},oa=s("span",{style:{color:"#24292E"}}," ",-1),aa=s("span",{style:{color:"#005CC5"}},"\\",-1),na=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),ea={class:"language-bash vp-adaptive-theme"},la=s("button",{title:"Copy Code",class:"copy"},null,-1),ta=s("span",{class:"lang"},"bash",-1),pa={class:"shiki github-dark vp-code-dark"},ca=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ra=o(' -v $HOME/my-node-store:/home/celestia \\',1),_a={class:"line"},ia=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ea={style:{color:"#9ECBFF"}},ya=s("span",{style:{color:"#E1E4E8"}}," ",-1),da=s("span",{style:{color:"#79B8FF"}},"\\",-1),ha=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),Ta={class:"shiki github-light vp-code-light"},Fa=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ca=o(' -v $HOME/my-node-store:/home/celestia \\',1),ua={class:"line"},ga=s("span",{style:{color:"#24292E"}}," ",-1),ba={style:{color:"#032F62"}},va=s("span",{style:{color:"#24292E"}}," ",-1),Pa=s("span",{style:{color:"#005CC5"}},"\\",-1),ka=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),ma={class:"language-bash vp-adaptive-theme"},Aa=s("button",{title:"Copy Code",class:"copy"},null,-1),Sa=s("span",{class:"lang"},"bash",-1),Na={class:"shiki github-dark vp-code-dark"},Ba=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Da=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ra={class:"line"},Oa=s("span",{style:{color:"#E1E4E8"}}," ",-1),Va={style:{color:"#9ECBFF"}},Ia=s("span",{style:{color:"#E1E4E8"}}," ",-1),fa=s("span",{style:{color:"#79B8FF"}},"\\",-1),$a=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),wa={class:"shiki github-light vp-code-light"},Wa=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ka=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ya={class:"line"},Ma=s("span",{style:{color:"#24292E"}}," ",-1),xa={style:{color:"#032F62"}},Ha=s("span",{style:{color:"#24292E"}}," ",-1),qa=s("span",{style:{color:"#005CC5"}},"\\",-1),La=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),Ua=s("p",null,"Congratulations! You now have a node running with persistent storage.",-1),ja=s("h2",{id:"video-walkthrough",tabindex:"-1"},[a("Video walkthrough "),s("a",{class:"header-anchor",href:"#video-walkthrough","aria-label":'Permalink to "Video walkthrough"'},"​")],-1),Qa=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/WFubhQc8tGk",allowfullscreen:""})],-1),za=s("h3",{id:"_2-5-minute-version",tabindex:"-1"},[a("2.5 minute version "),s("a",{class:"header-anchor",href:"#_2-5-minute-version","aria-label":'Permalink to "2.5 minute version"'},"​")],-1),Xa=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/ROZv871Q7RM",allowfullscreen:""})],-1),Ga=s("h2",{id:"troubleshooting",tabindex:"-1"},[a("Troubleshooting "),s("a",{class:"header-anchor",href:"#troubleshooting","aria-label":'Permalink to "Troubleshooting"'},"​")],-1),Ja=s("p",null,[a("For security purposes Celestia expects to interact with your node's keys in a read-only manner. This is enforced using linux style permissions on the filesystem. Windows NTFS does not support these types of permissions. As a result the recommended path for Windows users to mount a persisted volume is to do so within WSL. You can find "),s("a",{href:"https://learn.microsoft.com/en-us/windows/wsl/install",target:"_blank",rel:"noreferrer"},"instructions for installing WSL"),a(".")],-1),pn=JSON.parse('{"title":"🐳 Docker setup","description":"Running Celestia Node using Docker.","frontmatter":{"sidebar_label":"Docker images","description":"Running Celestia Node using Docker.","head":[["meta",{"property":"og:title","content":"🐳 Docker setup | Celestia Docs"}],["meta",{"property":"og:description","content":"Running Celestia Node using Docker."}]]},"headers":[],"relativePath":"how-to-guides/docker-images.md","filePath":"how-to-guides/docker-images.md","lastUpdated":1732776394000}'),Za={name:"how-to-guides/docker-images.md"},cn=Object.assign(Za,{setup(sn){return(on,an)=>(c(),r("div",null,[_,s("ol",null,[i,s("li",null,[E,s("div",y,[d,s("div",h,[s("div",T,[F,C,s("pre",u,[s("code",null,[g,a(` -`),s("span",b,[v,s("span",P,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),k,m]),a(` + celestia <node-type> start [...args]

    A full start command will look similar to below.

    `,4),Vo={class:"vp-code-group vp-adaptive-theme"},fo=o('
    ',1),$o={class:"blocks"},wo={class:"language-bash vp-adaptive-theme active"},Wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Ko=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},Mo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),xo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Lo={class:"line"},qo=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ho={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),zo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Jo=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),Qo={class:"shiki github-light vp-code-light"},Zo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),jo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Go={class:"line"},Xo=s("span",{style:{color:"#24292E"}}," ",-1),sa={style:{color:"#032F62"}},oa=s("span",{style:{color:"#24292E"}}," ",-1),aa=s("span",{style:{color:"#005CC5"}},"\\",-1),na=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),ea={class:"language-bash vp-adaptive-theme"},la=s("button",{title:"Copy Code",class:"copy"},null,-1),ta=s("span",{class:"lang"},"bash",-1),pa={class:"shiki github-dark vp-code-dark"},ca=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),ra=o(' -v $HOME/my-node-store:/home/celestia \\',1),_a={class:"line"},ia=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ea={style:{color:"#9ECBFF"}},ya=s("span",{style:{color:"#E1E4E8"}}," ",-1),da=s("span",{style:{color:"#79B8FF"}},"\\",-1),ha=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),Ta={class:"shiki github-light vp-code-light"},Fa=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ca=o(' -v $HOME/my-node-store:/home/celestia \\',1),ua={class:"line"},ga=s("span",{style:{color:"#24292E"}}," ",-1),ba={style:{color:"#032F62"}},va=s("span",{style:{color:"#24292E"}}," ",-1),ka=s("span",{style:{color:"#005CC5"}},"\\",-1),Pa=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),ma={class:"language-bash vp-adaptive-theme"},Aa=s("button",{title:"Copy Code",class:"copy"},null,-1),Sa=s("span",{class:"lang"},"bash",-1),Na={class:"shiki github-dark vp-code-dark"},Ba=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ra=o(' -v $HOME/my-node-store:/home/celestia \\',1),Da={class:"line"},Oa=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ia={style:{color:"#9ECBFF"}},Va=s("span",{style:{color:"#E1E4E8"}}," ",-1),fa=s("span",{style:{color:"#79B8FF"}},"\\",-1),$a=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),wa={class:"shiki github-light vp-code-light"},Wa=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Ka=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ya={class:"line"},Ma=s("span",{style:{color:"#24292E"}}," ",-1),xa={style:{color:"#032F62"}},La=s("span",{style:{color:"#24292E"}}," ",-1),qa=s("span",{style:{color:"#005CC5"}},"\\",-1),Ha=o(' celestia light start --core.ip $RPC_URL --p2p.network $NETWORK',1),Ua=s("p",null,"Congratulations! You now have a node running with persistent storage.",-1),za=s("h2",{id:"video-walkthrough",tabindex:"-1"},[a("Video walkthrough "),s("a",{class:"header-anchor",href:"#video-walkthrough","aria-label":'Permalink to "Video walkthrough"'},"​")],-1),Ja=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/WFubhQc8tGk",allowfullscreen:""})],-1),Qa=s("h3",{id:"_2-5-minute-version",tabindex:"-1"},[a("2.5 minute version "),s("a",{class:"header-anchor",href:"#_2-5-minute-version","aria-label":'Permalink to "2.5 minute version"'},"​")],-1),Za=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/ROZv871Q7RM",allowfullscreen:""})],-1),ja=s("h2",{id:"troubleshooting",tabindex:"-1"},[a("Troubleshooting "),s("a",{class:"header-anchor",href:"#troubleshooting","aria-label":'Permalink to "Troubleshooting"'},"​")],-1),Ga=s("p",null,[a("For security purposes Celestia expects to interact with your node's keys in a read-only manner. This is enforced using linux style permissions on the filesystem. Windows NTFS does not support these types of permissions. As a result the recommended path for Windows users to mount a persisted volume is to do so within WSL. You can find "),s("a",{href:"https://learn.microsoft.com/en-us/windows/wsl/install",target:"_blank",rel:"noreferrer"},"instructions for installing WSL"),a(".")],-1),pn=JSON.parse('{"title":"🐳 Docker setup","description":"Running Celestia Node using Docker.","frontmatter":{"sidebar_label":"Docker images","description":"Running Celestia Node using Docker.","head":[["meta",{"property":"og:title","content":"🐳 Docker setup | Celestia Docs"}],["meta",{"property":"og:description","content":"Running Celestia Node using Docker."}]]},"headers":[],"relativePath":"how-to-guides/docker-images.md","filePath":"how-to-guides/docker-images.md","lastUpdated":1732777479000}'),Xa={name:"how-to-guides/docker-images.md"},cn=Object.assign(Xa,{setup(sn){return(on,an)=>(c(),r("div",null,[_,s("ol",null,[i,s("li",null,[E,s("div",y,[d,s("div",h,[s("div",T,[F,C,s("pre",u,[s("code",null,[g,a(` +`),s("span",b,[v,s("span",k,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),P,m]),a(` `),A])]),s("pre",S,[s("code",null,[N,a(` -`),s("span",B,[D,s("span",R,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),O,V]),a(` -`),I])])]),s("div",f,[$,w,s("pre",W,[s("code",null,[K,a(` -`),s("span",Y,[M,s("span",x,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),H,q]),a(` -`),L])]),s("pre",U,[s("code",null,[j,a(` -`),s("span",Q,[z,s("span",X,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),G,J]),a(` -`),Z])])]),s("div",ss,[os,as,s("pre",ns,[s("code",null,[es,a(` +`),s("span",B,[R,s("span",D,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),O,I]),a(` +`),V])])]),s("div",f,[$,w,s("pre",W,[s("code",null,[K,a(` +`),s("span",Y,[M,s("span",x,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),L,q]),a(` +`),H])]),s("pre",U,[s("code",null,[z,a(` +`),s("span",J,[Q,s("span",Z,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),j,G]),a(` +`),X])])]),s("div",ss,[os,as,s("pre",ns,[s("code",null,[es,a(` `),s("span",ls,[ts,s("span",ps,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),cs,rs]),a(` `),_s])]),s("pre",is,[s("code",null,[Es,a(` `),s("span",ys,[ds,s("span",hs,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ts,Fs]),a(` -`),Cs])])])])])])]),us,s("div",gs,[bs,s("div",vs,[s("div",Ps,[ks,ms,s("pre",As,[s("code",null,[Ss,a(` +`),Cs])])])])])])]),us,s("div",gs,[bs,s("div",vs,[s("div",ks,[Ps,ms,s("pre",As,[s("code",null,[Ss,a(` `),Ns,a(` -`),s("span",Bs,[Ds,s("span",Rs,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Os,Vs]),a(` -`),Is])]),s("pre",fs,[s("code",null,[$s,a(` +`),s("span",Bs,[Rs,s("span",Ds,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Os,Is]),a(` +`),Vs])]),s("pre",fs,[s("code",null,[$s,a(` `),ws,a(` `),s("span",Ws,[Ks,s("span",Ys,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Ms,xs]),a(` -`),Hs])])]),s("div",qs,[Ls,Us,s("pre",js,[s("code",null,[Qs,a(` -`),zs,a(` -`),s("span",Xs,[Gs,s("span",Js,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Zs,so]),a(` +`),Ls])])]),s("div",qs,[Hs,Us,s("pre",zs,[s("code",null,[Js,a(` +`),Qs,a(` +`),s("span",Zs,[js,s("span",Gs,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Xs,so]),a(` `),oo])]),s("pre",ao,[s("code",null,[no,a(` `),eo,a(` `),s("span",lo,[to,s("span",po,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),co,ro]),a(` `),_o])])]),s("div",io,[Eo,yo,s("pre",ho,[s("code",null,[To,a(` `),Fo,a(` `),s("span",Co,[uo,s("span",go,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),bo,vo]),a(` -`),Po])]),s("pre",ko,[s("code",null,[mo,a(` +`),ko])]),s("pre",Po,[s("code",null,[mo,a(` `),Ao,a(` -`),s("span",So,[No,s("span",Bo,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Do,Ro]),a(` -`),Oo])])])])]),Vo,s("div",Io,[fo,s("div",$o,[s("div",wo,[Wo,Ko,s("pre",Yo,[s("code",null,[Mo,a(` +`),s("span",So,[No,s("span",Bo,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ro,Do]),a(` +`),Oo])])])])]),Io,s("div",Vo,[fo,s("div",$o,[s("div",wo,[Wo,Ko,s("pre",Yo,[s("code",null,[Mo,a(` `),xo,a(` -`),s("span",Ho,[qo,s("span",Lo,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,jo]),a(` -`),Qo])]),s("pre",zo,[s("code",null,[Xo,a(` -`),Go,a(` -`),s("span",Jo,[Zo,s("span",sa,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),oa,aa]),a(` +`),s("span",Lo,[qo,s("span",Ho,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,zo]),a(` +`),Jo])]),s("pre",Qo,[s("code",null,[Zo,a(` +`),jo,a(` +`),s("span",Go,[Xo,s("span",sa,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),oa,aa]),a(` `),na])])]),s("div",ea,[la,ta,s("pre",pa,[s("code",null,[ca,a(` `),ra,a(` `),s("span",_a,[ia,s("span",Ea,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),ya,da]),a(` `),ha])]),s("pre",Ta,[s("code",null,[Fa,a(` `),Ca,a(` -`),s("span",ua,[ga,s("span",ba,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),va,Pa]),a(` -`),ka])])]),s("div",ma,[Aa,Sa,s("pre",Na,[s("code",null,[Ba,a(` -`),Da,a(` -`),s("span",Ra,[Oa,s("span",Va,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ia,fa]),a(` +`),s("span",ua,[ga,s("span",ba,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),va,ka]),a(` +`),Pa])])]),s("div",ma,[Aa,Sa,s("pre",Na,[s("code",null,[Ba,a(` +`),Ra,a(` +`),s("span",Da,[Oa,s("span",Ia,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Va,fa]),a(` `),$a])]),s("pre",wa,[s("code",null,[Wa,a(` `),Ka,a(` -`),s("span",Ya,[Ma,s("span",xa,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ha,qa]),a(` -`),La])])])])]),Ua,ja,Qa,za,Xa,Ga,Ja]))}});export{pn as __pageData,cn as default}; +`),s("span",Ya,[Ma,s("span",xa,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),La,qa]),a(` +`),Ha])])])])]),Ua,za,Ja,Qa,Za,ja,Ga]))}});export{pn as __pageData,cn as default}; diff --git a/pr-1815/assets/how-to-guides_docker-images.md.72749f80.lean.js b/pr-1815/assets/how-to-guides_docker-images.md.23a48650.lean.js similarity index 61% rename from pr-1815/assets/how-to-guides_docker-images.md.72749f80.lean.js rename to pr-1815/assets/how-to-guides_docker-images.md.23a48650.lean.js index f0ab9c727..2feacebcb 100644 --- a/pr-1815/assets/how-to-guides_docker-images.md.72749f80.lean.js +++ b/pr-1815/assets/how-to-guides_docker-images.md.23a48650.lean.js @@ -1,49 +1,49 @@ -import{a as l}from"./chunks/arabica_versions.8cd8d43b.js";import{m as t}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as p}from"./chunks/mainnet_versions.f2c187e6.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.2959b752.js";const _=o("",9),i=o("",3),E=s("p",null,"Run the image from the command line:",-1),y={class:"vp-code-group vp-adaptive-theme"},d=o("",1),h={class:"blocks"},T={class:"language-bash vp-adaptive-theme active"},F=s("button",{title:"Copy Code",class:"copy"},null,-1),C=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g=o("",1),b={class:"line"},v=s("span",{style:{color:"#E1E4E8"}}," ",-1),P={style:{color:"#9ECBFF"}},k=s("span",{style:{color:"#E1E4E8"}}," ",-1),m=s("span",{style:{color:"#79B8FF"}},"\\",-1),A=o("",1),S={class:"shiki github-light vp-code-light"},N=o("",1),B={class:"line"},D=s("span",{style:{color:"#24292E"}}," ",-1),R={style:{color:"#032F62"}},O=s("span",{style:{color:"#24292E"}}," ",-1),V=s("span",{style:{color:"#005CC5"}},"\\",-1),I=o("",1),f={class:"language-bash vp-adaptive-theme"},$=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),W={class:"shiki github-dark vp-code-dark"},K=o("",1),Y={class:"line"},M=s("span",{style:{color:"#E1E4E8"}}," ",-1),x={style:{color:"#9ECBFF"}},H=s("span",{style:{color:"#E1E4E8"}}," ",-1),q=s("span",{style:{color:"#79B8FF"}},"\\",-1),L=o("",1),U={class:"shiki github-light vp-code-light"},j=o("",1),Q={class:"line"},z=s("span",{style:{color:"#24292E"}}," ",-1),X={style:{color:"#032F62"}},G=s("span",{style:{color:"#24292E"}}," ",-1),J=s("span",{style:{color:"#005CC5"}},"\\",-1),Z=o("",1),ss={class:"language-bash vp-adaptive-theme"},os=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"bash",-1),ns={class:"shiki github-dark vp-code-dark"},es=o("",1),ls={class:"line"},ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ps={style:{color:"#9ECBFF"}},cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),rs=s("span",{style:{color:"#79B8FF"}},"\\",-1),_s=o("",1),is={class:"shiki github-light vp-code-light"},Es=o("",1),ys={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},Ts=s("span",{style:{color:"#24292E"}}," ",-1),Fs=s("span",{style:{color:"#005CC5"}},"\\",-1),Cs=o("",1),us=o("",12),gs={class:"vp-code-group vp-adaptive-theme"},bs=o("",1),vs={class:"blocks"},Ps={class:"language-bash vp-adaptive-theme active"},ks=s("button",{title:"Copy Code",class:"copy"},null,-1),ms=s("span",{class:"lang"},"bash",-1),As={class:"shiki github-dark vp-code-dark"},Ss=o("",1),Ns=o("",1),Bs={class:"line"},Ds=s("span",{style:{color:"#E1E4E8"}}," ",-1),Rs={style:{color:"#9ECBFF"}},Os=s("span",{style:{color:"#E1E4E8"}}," ",-1),Vs=s("span",{style:{color:"#79B8FF"}},"\\",-1),Is=o("",1),fs={class:"shiki github-light vp-code-light"},$s=o("",1),ws=o("",1),Ws={class:"line"},Ks=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},Ms=s("span",{style:{color:"#24292E"}}," ",-1),xs=s("span",{style:{color:"#005CC5"}},"\\",-1),Hs=o("",1),qs={class:"language-bash vp-adaptive-theme"},Ls=s("button",{title:"Copy Code",class:"copy"},null,-1),Us=s("span",{class:"lang"},"bash",-1),js={class:"shiki github-dark vp-code-dark"},Qs=o("",1),zs=o("",1),Xs={class:"line"},Gs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Js={style:{color:"#9ECBFF"}},Zs=s("span",{style:{color:"#E1E4E8"}}," ",-1),so=s("span",{style:{color:"#79B8FF"}},"\\",-1),oo=o("",1),ao={class:"shiki github-light vp-code-light"},no=o("",1),eo=o("",1),lo={class:"line"},to=s("span",{style:{color:"#24292E"}}," ",-1),po={style:{color:"#032F62"}},co=s("span",{style:{color:"#24292E"}}," ",-1),ro=s("span",{style:{color:"#005CC5"}},"\\",-1),_o=o("",1),io={class:"language-bash vp-adaptive-theme"},Eo=s("button",{title:"Copy Code",class:"copy"},null,-1),yo=s("span",{class:"lang"},"bash",-1),ho={class:"shiki github-dark vp-code-dark"},To=o("",1),Fo=o("",1),Co={class:"line"},uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),go={style:{color:"#9ECBFF"}},bo=s("span",{style:{color:"#E1E4E8"}}," ",-1),vo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Po=o("",1),ko={class:"shiki github-light vp-code-light"},mo=o("",1),Ao=o("",1),So={class:"line"},No=s("span",{style:{color:"#24292E"}}," ",-1),Bo={style:{color:"#032F62"}},Do=s("span",{style:{color:"#24292E"}}," ",-1),Ro=s("span",{style:{color:"#005CC5"}},"\\",-1),Oo=o("",1),Vo=o("",4),Io={class:"vp-code-group vp-adaptive-theme"},fo=o("",1),$o={class:"blocks"},wo={class:"language-bash vp-adaptive-theme active"},Wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Ko=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},Mo=o("",1),xo=o("",1),Ho={class:"line"},qo=s("span",{style:{color:"#E1E4E8"}}," ",-1),Lo={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),jo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Qo=o("",1),zo={class:"shiki github-light vp-code-light"},Xo=o("",1),Go=o("",1),Jo={class:"line"},Zo=s("span",{style:{color:"#24292E"}}," ",-1),sa={style:{color:"#032F62"}},oa=s("span",{style:{color:"#24292E"}}," ",-1),aa=s("span",{style:{color:"#005CC5"}},"\\",-1),na=o("",1),ea={class:"language-bash vp-adaptive-theme"},la=s("button",{title:"Copy Code",class:"copy"},null,-1),ta=s("span",{class:"lang"},"bash",-1),pa={class:"shiki github-dark vp-code-dark"},ca=o("",1),ra=o("",1),_a={class:"line"},ia=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ea={style:{color:"#9ECBFF"}},ya=s("span",{style:{color:"#E1E4E8"}}," ",-1),da=s("span",{style:{color:"#79B8FF"}},"\\",-1),ha=o("",1),Ta={class:"shiki github-light vp-code-light"},Fa=o("",1),Ca=o("",1),ua={class:"line"},ga=s("span",{style:{color:"#24292E"}}," ",-1),ba={style:{color:"#032F62"}},va=s("span",{style:{color:"#24292E"}}," ",-1),Pa=s("span",{style:{color:"#005CC5"}},"\\",-1),ka=o("",1),ma={class:"language-bash vp-adaptive-theme"},Aa=s("button",{title:"Copy Code",class:"copy"},null,-1),Sa=s("span",{class:"lang"},"bash",-1),Na={class:"shiki github-dark vp-code-dark"},Ba=o("",1),Da=o("",1),Ra={class:"line"},Oa=s("span",{style:{color:"#E1E4E8"}}," ",-1),Va={style:{color:"#9ECBFF"}},Ia=s("span",{style:{color:"#E1E4E8"}}," ",-1),fa=s("span",{style:{color:"#79B8FF"}},"\\",-1),$a=o("",1),wa={class:"shiki github-light vp-code-light"},Wa=o("",1),Ka=o("",1),Ya={class:"line"},Ma=s("span",{style:{color:"#24292E"}}," ",-1),xa={style:{color:"#032F62"}},Ha=s("span",{style:{color:"#24292E"}}," ",-1),qa=s("span",{style:{color:"#005CC5"}},"\\",-1),La=o("",1),Ua=s("p",null,"Congratulations! You now have a node running with persistent storage.",-1),ja=s("h2",{id:"video-walkthrough",tabindex:"-1"},[a("Video walkthrough "),s("a",{class:"header-anchor",href:"#video-walkthrough","aria-label":'Permalink to "Video walkthrough"'},"​")],-1),Qa=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/WFubhQc8tGk",allowfullscreen:""})],-1),za=s("h3",{id:"_2-5-minute-version",tabindex:"-1"},[a("2.5 minute version "),s("a",{class:"header-anchor",href:"#_2-5-minute-version","aria-label":'Permalink to "2.5 minute version"'},"​")],-1),Xa=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/ROZv871Q7RM",allowfullscreen:""})],-1),Ga=s("h2",{id:"troubleshooting",tabindex:"-1"},[a("Troubleshooting "),s("a",{class:"header-anchor",href:"#troubleshooting","aria-label":'Permalink to "Troubleshooting"'},"​")],-1),Ja=s("p",null,[a("For security purposes Celestia expects to interact with your node's keys in a read-only manner. This is enforced using linux style permissions on the filesystem. Windows NTFS does not support these types of permissions. As a result the recommended path for Windows users to mount a persisted volume is to do so within WSL. You can find "),s("a",{href:"https://learn.microsoft.com/en-us/windows/wsl/install",target:"_blank",rel:"noreferrer"},"instructions for installing WSL"),a(".")],-1),pn=JSON.parse('{"title":"🐳 Docker setup","description":"Running Celestia Node using Docker.","frontmatter":{"sidebar_label":"Docker images","description":"Running Celestia Node using Docker.","head":[["meta",{"property":"og:title","content":"🐳 Docker setup | Celestia Docs"}],["meta",{"property":"og:description","content":"Running Celestia Node using Docker."}]]},"headers":[],"relativePath":"how-to-guides/docker-images.md","filePath":"how-to-guides/docker-images.md","lastUpdated":1732776394000}'),Za={name:"how-to-guides/docker-images.md"},cn=Object.assign(Za,{setup(sn){return(on,an)=>(c(),r("div",null,[_,s("ol",null,[i,s("li",null,[E,s("div",y,[d,s("div",h,[s("div",T,[F,C,s("pre",u,[s("code",null,[g,a(` -`),s("span",b,[v,s("span",P,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),k,m]),a(` +import{a as l}from"./chunks/arabica_versions.8cd8d43b.js";import{m as t}from"./chunks/mocha_versions.1f7c0f1d.js";import{m as p}from"./chunks/mainnet_versions.f2c187e6.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.2959b752.js";const _=o("",9),i=o("",3),E=s("p",null,"Run the image from the command line:",-1),y={class:"vp-code-group vp-adaptive-theme"},d=o("",1),h={class:"blocks"},T={class:"language-bash vp-adaptive-theme active"},F=s("button",{title:"Copy Code",class:"copy"},null,-1),C=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g=o("",1),b={class:"line"},v=s("span",{style:{color:"#E1E4E8"}}," ",-1),k={style:{color:"#9ECBFF"}},P=s("span",{style:{color:"#E1E4E8"}}," ",-1),m=s("span",{style:{color:"#79B8FF"}},"\\",-1),A=o("",1),S={class:"shiki github-light vp-code-light"},N=o("",1),B={class:"line"},R=s("span",{style:{color:"#24292E"}}," ",-1),D={style:{color:"#032F62"}},O=s("span",{style:{color:"#24292E"}}," ",-1),I=s("span",{style:{color:"#005CC5"}},"\\",-1),V=o("",1),f={class:"language-bash vp-adaptive-theme"},$=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),W={class:"shiki github-dark vp-code-dark"},K=o("",1),Y={class:"line"},M=s("span",{style:{color:"#E1E4E8"}}," ",-1),x={style:{color:"#9ECBFF"}},L=s("span",{style:{color:"#E1E4E8"}}," ",-1),q=s("span",{style:{color:"#79B8FF"}},"\\",-1),H=o("",1),U={class:"shiki github-light vp-code-light"},z=o("",1),J={class:"line"},Q=s("span",{style:{color:"#24292E"}}," ",-1),Z={style:{color:"#032F62"}},j=s("span",{style:{color:"#24292E"}}," ",-1),G=s("span",{style:{color:"#005CC5"}},"\\",-1),X=o("",1),ss={class:"language-bash vp-adaptive-theme"},os=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"bash",-1),ns={class:"shiki github-dark vp-code-dark"},es=o("",1),ls={class:"line"},ts=s("span",{style:{color:"#E1E4E8"}}," ",-1),ps={style:{color:"#9ECBFF"}},cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),rs=s("span",{style:{color:"#79B8FF"}},"\\",-1),_s=o("",1),is={class:"shiki github-light vp-code-light"},Es=o("",1),ys={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#032F62"}},Ts=s("span",{style:{color:"#24292E"}}," ",-1),Fs=s("span",{style:{color:"#005CC5"}},"\\",-1),Cs=o("",1),us=o("",12),gs={class:"vp-code-group vp-adaptive-theme"},bs=o("",1),vs={class:"blocks"},ks={class:"language-bash vp-adaptive-theme active"},Ps=s("button",{title:"Copy Code",class:"copy"},null,-1),ms=s("span",{class:"lang"},"bash",-1),As={class:"shiki github-dark vp-code-dark"},Ss=o("",1),Ns=o("",1),Bs={class:"line"},Rs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ds={style:{color:"#9ECBFF"}},Os=s("span",{style:{color:"#E1E4E8"}}," ",-1),Is=s("span",{style:{color:"#79B8FF"}},"\\",-1),Vs=o("",1),fs={class:"shiki github-light vp-code-light"},$s=o("",1),ws=o("",1),Ws={class:"line"},Ks=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},Ms=s("span",{style:{color:"#24292E"}}," ",-1),xs=s("span",{style:{color:"#005CC5"}},"\\",-1),Ls=o("",1),qs={class:"language-bash vp-adaptive-theme"},Hs=s("button",{title:"Copy Code",class:"copy"},null,-1),Us=s("span",{class:"lang"},"bash",-1),zs={class:"shiki github-dark vp-code-dark"},Js=o("",1),Qs=o("",1),Zs={class:"line"},js=s("span",{style:{color:"#E1E4E8"}}," ",-1),Gs={style:{color:"#9ECBFF"}},Xs=s("span",{style:{color:"#E1E4E8"}}," ",-1),so=s("span",{style:{color:"#79B8FF"}},"\\",-1),oo=o("",1),ao={class:"shiki github-light vp-code-light"},no=o("",1),eo=o("",1),lo={class:"line"},to=s("span",{style:{color:"#24292E"}}," ",-1),po={style:{color:"#032F62"}},co=s("span",{style:{color:"#24292E"}}," ",-1),ro=s("span",{style:{color:"#005CC5"}},"\\",-1),_o=o("",1),io={class:"language-bash vp-adaptive-theme"},Eo=s("button",{title:"Copy Code",class:"copy"},null,-1),yo=s("span",{class:"lang"},"bash",-1),ho={class:"shiki github-dark vp-code-dark"},To=o("",1),Fo=o("",1),Co={class:"line"},uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),go={style:{color:"#9ECBFF"}},bo=s("span",{style:{color:"#E1E4E8"}}," ",-1),vo=s("span",{style:{color:"#79B8FF"}},"\\",-1),ko=o("",1),Po={class:"shiki github-light vp-code-light"},mo=o("",1),Ao=o("",1),So={class:"line"},No=s("span",{style:{color:"#24292E"}}," ",-1),Bo={style:{color:"#032F62"}},Ro=s("span",{style:{color:"#24292E"}}," ",-1),Do=s("span",{style:{color:"#005CC5"}},"\\",-1),Oo=o("",1),Io=o("",4),Vo={class:"vp-code-group vp-adaptive-theme"},fo=o("",1),$o={class:"blocks"},wo={class:"language-bash vp-adaptive-theme active"},Wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Ko=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},Mo=o("",1),xo=o("",1),Lo={class:"line"},qo=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ho={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),zo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Jo=o("",1),Qo={class:"shiki github-light vp-code-light"},Zo=o("",1),jo=o("",1),Go={class:"line"},Xo=s("span",{style:{color:"#24292E"}}," ",-1),sa={style:{color:"#032F62"}},oa=s("span",{style:{color:"#24292E"}}," ",-1),aa=s("span",{style:{color:"#005CC5"}},"\\",-1),na=o("",1),ea={class:"language-bash vp-adaptive-theme"},la=s("button",{title:"Copy Code",class:"copy"},null,-1),ta=s("span",{class:"lang"},"bash",-1),pa={class:"shiki github-dark vp-code-dark"},ca=o("",1),ra=o("",1),_a={class:"line"},ia=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ea={style:{color:"#9ECBFF"}},ya=s("span",{style:{color:"#E1E4E8"}}," ",-1),da=s("span",{style:{color:"#79B8FF"}},"\\",-1),ha=o("",1),Ta={class:"shiki github-light vp-code-light"},Fa=o("",1),Ca=o("",1),ua={class:"line"},ga=s("span",{style:{color:"#24292E"}}," ",-1),ba={style:{color:"#032F62"}},va=s("span",{style:{color:"#24292E"}}," ",-1),ka=s("span",{style:{color:"#005CC5"}},"\\",-1),Pa=o("",1),ma={class:"language-bash vp-adaptive-theme"},Aa=s("button",{title:"Copy Code",class:"copy"},null,-1),Sa=s("span",{class:"lang"},"bash",-1),Na={class:"shiki github-dark vp-code-dark"},Ba=o("",1),Ra=o("",1),Da={class:"line"},Oa=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ia={style:{color:"#9ECBFF"}},Va=s("span",{style:{color:"#E1E4E8"}}," ",-1),fa=s("span",{style:{color:"#79B8FF"}},"\\",-1),$a=o("",1),wa={class:"shiki github-light vp-code-light"},Wa=o("",1),Ka=o("",1),Ya={class:"line"},Ma=s("span",{style:{color:"#24292E"}}," ",-1),xa={style:{color:"#032F62"}},La=s("span",{style:{color:"#24292E"}}," ",-1),qa=s("span",{style:{color:"#005CC5"}},"\\",-1),Ha=o("",1),Ua=s("p",null,"Congratulations! You now have a node running with persistent storage.",-1),za=s("h2",{id:"video-walkthrough",tabindex:"-1"},[a("Video walkthrough "),s("a",{class:"header-anchor",href:"#video-walkthrough","aria-label":'Permalink to "Video walkthrough"'},"​")],-1),Ja=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/WFubhQc8tGk",allowfullscreen:""})],-1),Qa=s("h3",{id:"_2-5-minute-version",tabindex:"-1"},[a("2.5 minute version "),s("a",{class:"header-anchor",href:"#_2-5-minute-version","aria-label":'Permalink to "2.5 minute version"'},"​")],-1),Za=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/ROZv871Q7RM",allowfullscreen:""})],-1),ja=s("h2",{id:"troubleshooting",tabindex:"-1"},[a("Troubleshooting "),s("a",{class:"header-anchor",href:"#troubleshooting","aria-label":'Permalink to "Troubleshooting"'},"​")],-1),Ga=s("p",null,[a("For security purposes Celestia expects to interact with your node's keys in a read-only manner. This is enforced using linux style permissions on the filesystem. Windows NTFS does not support these types of permissions. As a result the recommended path for Windows users to mount a persisted volume is to do so within WSL. You can find "),s("a",{href:"https://learn.microsoft.com/en-us/windows/wsl/install",target:"_blank",rel:"noreferrer"},"instructions for installing WSL"),a(".")],-1),pn=JSON.parse('{"title":"🐳 Docker setup","description":"Running Celestia Node using Docker.","frontmatter":{"sidebar_label":"Docker images","description":"Running Celestia Node using Docker.","head":[["meta",{"property":"og:title","content":"🐳 Docker setup | Celestia Docs"}],["meta",{"property":"og:description","content":"Running Celestia Node using Docker."}]]},"headers":[],"relativePath":"how-to-guides/docker-images.md","filePath":"how-to-guides/docker-images.md","lastUpdated":1732777479000}'),Xa={name:"how-to-guides/docker-images.md"},cn=Object.assign(Xa,{setup(sn){return(on,an)=>(c(),r("div",null,[_,s("ol",null,[i,s("li",null,[E,s("div",y,[d,s("div",h,[s("div",T,[F,C,s("pre",u,[s("code",null,[g,a(` +`),s("span",b,[v,s("span",k,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),P,m]),a(` `),A])]),s("pre",S,[s("code",null,[N,a(` -`),s("span",B,[D,s("span",R,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),O,V]),a(` -`),I])])]),s("div",f,[$,w,s("pre",W,[s("code",null,[K,a(` -`),s("span",Y,[M,s("span",x,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),H,q]),a(` -`),L])]),s("pre",U,[s("code",null,[j,a(` -`),s("span",Q,[z,s("span",X,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),G,J]),a(` -`),Z])])]),s("div",ss,[os,as,s("pre",ns,[s("code",null,[es,a(` +`),s("span",B,[R,s("span",D,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),O,I]),a(` +`),V])])]),s("div",f,[$,w,s("pre",W,[s("code",null,[K,a(` +`),s("span",Y,[M,s("span",x,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),L,q]),a(` +`),H])]),s("pre",U,[s("code",null,[z,a(` +`),s("span",J,[Q,s("span",Z,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),j,G]),a(` +`),X])])]),s("div",ss,[os,as,s("pre",ns,[s("code",null,[es,a(` `),s("span",ls,[ts,s("span",ps,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),cs,rs]),a(` `),_s])]),s("pre",is,[s("code",null,[Es,a(` `),s("span",ys,[ds,s("span",hs,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ts,Fs]),a(` -`),Cs])])])])])])]),us,s("div",gs,[bs,s("div",vs,[s("div",Ps,[ks,ms,s("pre",As,[s("code",null,[Ss,a(` +`),Cs])])])])])])]),us,s("div",gs,[bs,s("div",vs,[s("div",ks,[Ps,ms,s("pre",As,[s("code",null,[Ss,a(` `),Ns,a(` -`),s("span",Bs,[Ds,s("span",Rs,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Os,Vs]),a(` -`),Is])]),s("pre",fs,[s("code",null,[$s,a(` +`),s("span",Bs,[Rs,s("span",Ds,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Os,Is]),a(` +`),Vs])]),s("pre",fs,[s("code",null,[$s,a(` `),ws,a(` `),s("span",Ws,[Ks,s("span",Ys,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Ms,xs]),a(` -`),Hs])])]),s("div",qs,[Ls,Us,s("pre",js,[s("code",null,[Qs,a(` -`),zs,a(` -`),s("span",Xs,[Gs,s("span",Js,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Zs,so]),a(` +`),Ls])])]),s("div",qs,[Hs,Us,s("pre",zs,[s("code",null,[Js,a(` +`),Qs,a(` +`),s("span",Zs,[js,s("span",Gs,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Xs,so]),a(` `),oo])]),s("pre",ao,[s("code",null,[no,a(` `),eo,a(` `),s("span",lo,[to,s("span",po,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),co,ro]),a(` `),_o])])]),s("div",io,[Eo,yo,s("pre",ho,[s("code",null,[To,a(` `),Fo,a(` `),s("span",Co,[uo,s("span",go,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),bo,vo]),a(` -`),Po])]),s("pre",ko,[s("code",null,[mo,a(` +`),ko])]),s("pre",Po,[s("code",null,[mo,a(` `),Ao,a(` -`),s("span",So,[No,s("span",Bo,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Do,Ro]),a(` -`),Oo])])])])]),Vo,s("div",Io,[fo,s("div",$o,[s("div",wo,[Wo,Ko,s("pre",Yo,[s("code",null,[Mo,a(` +`),s("span",So,[No,s("span",Bo,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ro,Do]),a(` +`),Oo])])])])]),Io,s("div",Vo,[fo,s("div",$o,[s("div",wo,[Wo,Ko,s("pre",Yo,[s("code",null,[Mo,a(` `),xo,a(` -`),s("span",Ho,[qo,s("span",Lo,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,jo]),a(` -`),Qo])]),s("pre",zo,[s("code",null,[Xo,a(` -`),Go,a(` -`),s("span",Jo,[Zo,s("span",sa,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),oa,aa]),a(` +`),s("span",Lo,[qo,s("span",Ho,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,zo]),a(` +`),Jo])]),s("pre",Qo,[s("code",null,[Zo,a(` +`),jo,a(` +`),s("span",Go,[Xo,s("span",sa,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),oa,aa]),a(` `),na])])]),s("div",ea,[la,ta,s("pre",pa,[s("code",null,[ca,a(` `),ra,a(` `),s("span",_a,[ia,s("span",Ea,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),ya,da]),a(` `),ha])]),s("pre",Ta,[s("code",null,[Fa,a(` `),Ca,a(` -`),s("span",ua,[ga,s("span",ba,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),va,Pa]),a(` -`),ka])])]),s("div",ma,[Aa,Sa,s("pre",Na,[s("code",null,[Ba,a(` -`),Da,a(` -`),s("span",Ra,[Oa,s("span",Va,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ia,fa]),a(` +`),s("span",ua,[ga,s("span",ba,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),va,ka]),a(` +`),Pa])])]),s("div",ma,[Aa,Sa,s("pre",Na,[s("code",null,[Ba,a(` +`),Ra,a(` +`),s("span",Da,[Oa,s("span",Ia,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Va,fa]),a(` `),$a])]),s("pre",wa,[s("code",null,[Wa,a(` `),Ka,a(` -`),s("span",Ya,[Ma,s("span",xa,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Ha,qa]),a(` -`),La])])])])]),Ua,ja,Qa,za,Xa,Ga,Ja]))}});export{pn as __pageData,cn as default}; +`),s("span",Ya,[Ma,s("span",xa,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),La,qa]),a(` +`),Ha])])])])]),Ua,za,Ja,Qa,Za,ja,Ga]))}});export{pn as __pageData,cn as default}; diff --git a/pr-1815/assets/how-to-guides_environment.md.33880087.js b/pr-1815/assets/how-to-guides_environment.md.0bd51cab.js similarity index 91% rename from pr-1815/assets/how-to-guides_environment.md.33880087.js rename to pr-1815/assets/how-to-guides_environment.md.0bd51cab.js index 7e618ebb8..a5a7b67db 100644 --- a/pr-1815/assets/how-to-guides_environment.md.33880087.js +++ b/pr-1815/assets/how-to-guides_environment.md.0bd51cab.js @@ -1,4 +1,4 @@ -import{c as a}from"./chunks/constants.b02263eb.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.2959b752.js";const t=l(`

    Development environment

    This page will go over setting up your development environment to run Celestia software. This environment can be used for development, building binaries, and running nodes.

    Install dependencies

    1. If you are on Ubuntu, first update and upgrade your OS:

      bash
      sudo apt update && sudo apt upgrade -y
      sudo apt update && sudo apt upgrade -y
      bash
      sudo yum update
      sudo yum update
    2. Install essential packages that are necessary to execute many tasks like downloading files, compiling, and monitoring the node:

      bash
      sudo apt install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \\
      +import{c as a}from"./chunks/constants.b02263eb.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.2959b752.js";const t=l(`

      Development environment

      This page will go over setting up your development environment to run Celestia software. This environment can be used for development, building binaries, and running nodes.

      Install dependencies

      1. If you are on Ubuntu, first update and upgrade your OS:

        bash
        sudo apt update && sudo apt upgrade -y
        sudo apt update && sudo apt upgrade -y
        bash
        sudo yum update
        sudo yum update
      2. Install essential packages that are necessary to execute many tasks like downloading files, compiling, and monitoring the node:

        bash
        sudo apt install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \\
         git make ncdu -y
        sudo apt install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \\
         git make ncdu -y
        bash
        sudo yum install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \\
         git make ncdu -y
        sudo yum install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \\
        @@ -12,7 +12,7 @@ import{c as a}from"./chunks/constants.b02263eb.js";import{o as p,c as e,k as s,t
         /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
         
         # then install wget & jq
        -brew install wget && brew install jq

      Install Golang

      celestia-node is written in Golang so we must install Golang to build and run our node.

      `,6),c=s("p",null,"Set the version for your desired network:",-1),r={class:"vp-code-group vp-adaptive-theme"},y=l('
      ',1),i={class:"blocks"},E={class:"language-bash vp-adaptive-theme active"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),F=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g={class:"line"},h=s("span",{style:{color:"#E1E4E8"}},"ver",-1),C=s("span",{style:{color:"#F97583"}},"=",-1),b={style:{color:"#9ECBFF"}},v={class:"shiki github-light vp-code-light"},m={class:"line"},B=s("span",{style:{color:"#24292E"}},"ver",-1),_=s("span",{style:{color:"#D73A49"}},"=",-1),k={style:{color:"#032F62"}},q={class:"language-bash vp-adaptive-theme"},f=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},A={class:"line"},T=s("span",{style:{color:"#E1E4E8"}},"ver",-1),z=s("span",{style:{color:"#F97583"}},"=",-1),H={style:{color:"#9ECBFF"}},M={class:"shiki github-light vp-code-light"},P={class:"line"},x=s("span",{style:{color:"#24292E"}},"ver",-1),D=s("span",{style:{color:"#D73A49"}},"=",-1),O={style:{color:"#032F62"}},N={class:"language-bash vp-adaptive-theme"},j=s("button",{title:"Copy Code",class:"copy"},null,-1),S=s("span",{class:"lang"},"bash",-1),L={class:"shiki github-dark vp-code-dark"},I={class:"line"},U=s("span",{style:{color:"#E1E4E8"}},"ver",-1),V=s("span",{style:{color:"#F97583"}},"=",-1),Q={style:{color:"#9ECBFF"}},G={class:"shiki github-light vp-code-light"},J={class:"line"},R=s("span",{style:{color:"#24292E"}},"ver",-1),Y=s("span",{style:{color:"#D73A49"}},"=",-1),W={style:{color:"#032F62"}},X=l(`
    3. Download and install Golang:

      bash
      cd $HOME
      +brew install wget && brew install jq

    Install Golang

    celestia-node is written in Golang so we must install Golang to build and run our node.

    `,6),c=s("p",null,"Set the version for your desired network:",-1),r={class:"vp-code-group vp-adaptive-theme"},y=l('
    ',1),i={class:"blocks"},E={class:"language-bash vp-adaptive-theme active"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),F=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g={class:"line"},h=s("span",{style:{color:"#E1E4E8"}},"ver",-1),C=s("span",{style:{color:"#F97583"}},"=",-1),b={style:{color:"#9ECBFF"}},v={class:"shiki github-light vp-code-light"},m={class:"line"},B=s("span",{style:{color:"#24292E"}},"ver",-1),_=s("span",{style:{color:"#D73A49"}},"=",-1),k={style:{color:"#032F62"}},q={class:"language-bash vp-adaptive-theme"},f=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},A={class:"line"},M=s("span",{style:{color:"#E1E4E8"}},"ver",-1),x=s("span",{style:{color:"#F97583"}},"=",-1),H={style:{color:"#9ECBFF"}},z={class:"shiki github-light vp-code-light"},T={class:"line"},P=s("span",{style:{color:"#24292E"}},"ver",-1),O=s("span",{style:{color:"#D73A49"}},"=",-1),D={style:{color:"#032F62"}},S={class:"language-bash vp-adaptive-theme"},G=s("button",{title:"Copy Code",class:"copy"},null,-1),I=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},j={class:"line"},U=s("span",{style:{color:"#E1E4E8"}},"ver",-1),V=s("span",{style:{color:"#F97583"}},"=",-1),L={style:{color:"#9ECBFF"}},R={class:"shiki github-light vp-code-light"},Q={class:"line"},K=s("span",{style:{color:"#24292E"}},"ver",-1),X=s("span",{style:{color:"#D73A49"}},"=",-1),Z={style:{color:"#032F62"}},W=l(`
  • Download and install Golang:

    bash
    cd $HOME
     wget "https://golang.org/dl/go$ver.linux-amd64.tar.gz"
     sudo rm -rf /usr/local/go
     sudo tar -C /usr/local -xzf "go$ver.linux-amd64.tar.gz"
    @@ -44,8 +44,8 @@ import{c as a}from"./chunks/constants.b02263eb.js";import{o as p,c as e,k as s,t
     wget "https://golang.org/dl/go$ver.darwin-amd64.tar.gz"
     sudo rm -rf /usr/local/go
     sudo tar -C /usr/local -xzf "go$ver.darwin-amd64.tar.gz"
    -rm "go$ver.darwin-amd64.tar.gz"
  • Add your /usr/local/go/bin directory to your $PATH if you have not already:

    bash
    echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
    +rm "go$ver.darwin-amd64.tar.gz"
  • Add your /usr/local/go/bin directory to your $PATH if you have not already:

    bash
    echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
     source $HOME/.bash_profile
    echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
     source $HOME/.bash_profile
    bash
    echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.zshrc
     source $HOME/.zshrc
    echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.zshrc
    -source $HOME/.zshrc

    TIP

    Use echo $SHELL to figure out what type of shell you are using!

  • To verify that the correct version of Go was installed correctly run:

    bash
    go version
    go version
  • `,3),K=s("p",null,"The output will show the version installed.",-1),ps=JSON.parse('{"title":"Development environment","description":"Learn to set up your development environment to run Celestia software.","frontmatter":{"description":"Learn to set up your development environment to run Celestia software.","head":[["meta",{"property":"og:title","content":"Development environment | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to set up your development environment to run Celestia software."}]]},"headers":[],"relativePath":"how-to-guides/environment.md","filePath":"how-to-guides/environment.md","lastUpdated":1732776394000}'),Z={name:"how-to-guides/environment.md"},es=Object.assign(Z,{setup(ss){return(as,ns)=>(p(),e("div",null,[t,s("ol",null,[s("li",null,[c,s("div",r,[y,s("div",i,[s("div",E,[d,F,s("pre",u,[s("code",null,[s("span",g,[h,C,s("span",b,'"'+n(o(a).golangNodeMainnet)+'"',1)])])]),s("pre",v,[s("code",null,[s("span",m,[B,_,s("span",k,'"'+n(o(a).golangNodeMainnet)+'"',1)])])])]),s("div",q,[f,w,s("pre",$,[s("code",null,[s("span",A,[T,z,s("span",H,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",M,[s("code",null,[s("span",P,[x,D,s("span",O,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",N,[j,S,s("pre",L,[s("code",null,[s("span",I,[U,V,s("span",Q,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",G,[s("code",null,[s("span",J,[R,Y,s("span",W,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),X]),K]))}});export{ps as __pageData,es as default}; +source $HOME/.zshrc

    TIP

    Use echo $SHELL to figure out what type of shell you are using!

  • To verify that the correct version of Go was installed correctly run:

    bash
    go version
    go version
  • `,3),Y=s("p",null,"The output will show the version installed.",-1),ps=JSON.parse('{"title":"Development environment","description":"Learn to set up your development environment to run Celestia software.","frontmatter":{"description":"Learn to set up your development environment to run Celestia software.","head":[["meta",{"property":"og:title","content":"Development environment | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to set up your development environment to run Celestia software."}]]},"headers":[],"relativePath":"how-to-guides/environment.md","filePath":"how-to-guides/environment.md","lastUpdated":1732777479000}'),J={name:"how-to-guides/environment.md"},es=Object.assign(J,{setup(ss){return(as,ns)=>(p(),e("div",null,[t,s("ol",null,[s("li",null,[c,s("div",r,[y,s("div",i,[s("div",E,[d,F,s("pre",u,[s("code",null,[s("span",g,[h,C,s("span",b,'"'+n(o(a).golangNodeMainnet)+'"',1)])])]),s("pre",v,[s("code",null,[s("span",m,[B,_,s("span",k,'"'+n(o(a).golangNodeMainnet)+'"',1)])])])]),s("div",q,[f,w,s("pre",$,[s("code",null,[s("span",A,[M,x,s("span",H,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",z,[s("code",null,[s("span",T,[P,O,s("span",D,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",S,[G,I,s("pre",N,[s("code",null,[s("span",j,[U,V,s("span",L,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",R,[s("code",null,[s("span",Q,[K,X,s("span",Z,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),W]),Y]))}});export{ps as __pageData,es as default}; diff --git a/pr-1815/assets/how-to-guides_environment.md.33880087.lean.js b/pr-1815/assets/how-to-guides_environment.md.0bd51cab.lean.js similarity index 57% rename from pr-1815/assets/how-to-guides_environment.md.33880087.lean.js rename to pr-1815/assets/how-to-guides_environment.md.0bd51cab.lean.js index 8b9039e2b..62f2b505b 100644 --- a/pr-1815/assets/how-to-guides_environment.md.33880087.lean.js +++ b/pr-1815/assets/how-to-guides_environment.md.0bd51cab.lean.js @@ -1 +1 @@ -import{c as a}from"./chunks/constants.b02263eb.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.2959b752.js";const t=l("",6),c=s("p",null,"Set the version for your desired network:",-1),r={class:"vp-code-group vp-adaptive-theme"},y=l("",1),i={class:"blocks"},E={class:"language-bash vp-adaptive-theme active"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),F=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g={class:"line"},h=s("span",{style:{color:"#E1E4E8"}},"ver",-1),C=s("span",{style:{color:"#F97583"}},"=",-1),b={style:{color:"#9ECBFF"}},v={class:"shiki github-light vp-code-light"},m={class:"line"},B=s("span",{style:{color:"#24292E"}},"ver",-1),_=s("span",{style:{color:"#D73A49"}},"=",-1),k={style:{color:"#032F62"}},q={class:"language-bash vp-adaptive-theme"},f=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},A={class:"line"},T=s("span",{style:{color:"#E1E4E8"}},"ver",-1),z=s("span",{style:{color:"#F97583"}},"=",-1),H={style:{color:"#9ECBFF"}},M={class:"shiki github-light vp-code-light"},P={class:"line"},x=s("span",{style:{color:"#24292E"}},"ver",-1),D=s("span",{style:{color:"#D73A49"}},"=",-1),O={style:{color:"#032F62"}},N={class:"language-bash vp-adaptive-theme"},j=s("button",{title:"Copy Code",class:"copy"},null,-1),S=s("span",{class:"lang"},"bash",-1),L={class:"shiki github-dark vp-code-dark"},I={class:"line"},U=s("span",{style:{color:"#E1E4E8"}},"ver",-1),V=s("span",{style:{color:"#F97583"}},"=",-1),Q={style:{color:"#9ECBFF"}},G={class:"shiki github-light vp-code-light"},J={class:"line"},R=s("span",{style:{color:"#24292E"}},"ver",-1),Y=s("span",{style:{color:"#D73A49"}},"=",-1),W={style:{color:"#032F62"}},X=l("",3),K=s("p",null,"The output will show the version installed.",-1),ps=JSON.parse('{"title":"Development environment","description":"Learn to set up your development environment to run Celestia software.","frontmatter":{"description":"Learn to set up your development environment to run Celestia software.","head":[["meta",{"property":"og:title","content":"Development environment | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to set up your development environment to run Celestia software."}]]},"headers":[],"relativePath":"how-to-guides/environment.md","filePath":"how-to-guides/environment.md","lastUpdated":1732776394000}'),Z={name:"how-to-guides/environment.md"},es=Object.assign(Z,{setup(ss){return(as,ns)=>(p(),e("div",null,[t,s("ol",null,[s("li",null,[c,s("div",r,[y,s("div",i,[s("div",E,[d,F,s("pre",u,[s("code",null,[s("span",g,[h,C,s("span",b,'"'+n(o(a).golangNodeMainnet)+'"',1)])])]),s("pre",v,[s("code",null,[s("span",m,[B,_,s("span",k,'"'+n(o(a).golangNodeMainnet)+'"',1)])])])]),s("div",q,[f,w,s("pre",$,[s("code",null,[s("span",A,[T,z,s("span",H,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",M,[s("code",null,[s("span",P,[x,D,s("span",O,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",N,[j,S,s("pre",L,[s("code",null,[s("span",I,[U,V,s("span",Q,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",G,[s("code",null,[s("span",J,[R,Y,s("span",W,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),X]),K]))}});export{ps as __pageData,es as default}; +import{c as a}from"./chunks/constants.b02263eb.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.2959b752.js";const t=l("",6),c=s("p",null,"Set the version for your desired network:",-1),r={class:"vp-code-group vp-adaptive-theme"},y=l("",1),i={class:"blocks"},E={class:"language-bash vp-adaptive-theme active"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),F=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},g={class:"line"},h=s("span",{style:{color:"#E1E4E8"}},"ver",-1),C=s("span",{style:{color:"#F97583"}},"=",-1),b={style:{color:"#9ECBFF"}},v={class:"shiki github-light vp-code-light"},m={class:"line"},B=s("span",{style:{color:"#24292E"}},"ver",-1),_=s("span",{style:{color:"#D73A49"}},"=",-1),k={style:{color:"#032F62"}},q={class:"language-bash vp-adaptive-theme"},f=s("button",{title:"Copy Code",class:"copy"},null,-1),w=s("span",{class:"lang"},"bash",-1),$={class:"shiki github-dark vp-code-dark"},A={class:"line"},M=s("span",{style:{color:"#E1E4E8"}},"ver",-1),x=s("span",{style:{color:"#F97583"}},"=",-1),H={style:{color:"#9ECBFF"}},z={class:"shiki github-light vp-code-light"},T={class:"line"},P=s("span",{style:{color:"#24292E"}},"ver",-1),O=s("span",{style:{color:"#D73A49"}},"=",-1),D={style:{color:"#032F62"}},S={class:"language-bash vp-adaptive-theme"},G=s("button",{title:"Copy Code",class:"copy"},null,-1),I=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},j={class:"line"},U=s("span",{style:{color:"#E1E4E8"}},"ver",-1),V=s("span",{style:{color:"#F97583"}},"=",-1),L={style:{color:"#9ECBFF"}},R={class:"shiki github-light vp-code-light"},Q={class:"line"},K=s("span",{style:{color:"#24292E"}},"ver",-1),X=s("span",{style:{color:"#D73A49"}},"=",-1),Z={style:{color:"#032F62"}},W=l("",3),Y=s("p",null,"The output will show the version installed.",-1),ps=JSON.parse('{"title":"Development environment","description":"Learn to set up your development environment to run Celestia software.","frontmatter":{"description":"Learn to set up your development environment to run Celestia software.","head":[["meta",{"property":"og:title","content":"Development environment | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn to set up your development environment to run Celestia software."}]]},"headers":[],"relativePath":"how-to-guides/environment.md","filePath":"how-to-guides/environment.md","lastUpdated":1732777479000}'),J={name:"how-to-guides/environment.md"},es=Object.assign(J,{setup(ss){return(as,ns)=>(p(),e("div",null,[t,s("ol",null,[s("li",null,[c,s("div",r,[y,s("div",i,[s("div",E,[d,F,s("pre",u,[s("code",null,[s("span",g,[h,C,s("span",b,'"'+n(o(a).golangNodeMainnet)+'"',1)])])]),s("pre",v,[s("code",null,[s("span",m,[B,_,s("span",k,'"'+n(o(a).golangNodeMainnet)+'"',1)])])])]),s("div",q,[f,w,s("pre",$,[s("code",null,[s("span",A,[M,x,s("span",H,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",z,[s("code",null,[s("span",T,[P,O,s("span",D,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",S,[G,I,s("pre",N,[s("code",null,[s("span",j,[U,V,s("span",L,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",R,[s("code",null,[s("span",Q,[K,X,s("span",Z,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),W]),Y]))}});export{ps as __pageData,es as default}; diff --git a/pr-1815/assets/how-to-guides_ethereum-fallback.md.353433f7.js b/pr-1815/assets/how-to-guides_ethereum-fallback.md.7b275d7a.js similarity index 97% rename from pr-1815/assets/how-to-guides_ethereum-fallback.md.353433f7.js rename to pr-1815/assets/how-to-guides_ethereum-fallback.md.7b275d7a.js index e7cb6bfc0..175c4bbe2 100644 --- a/pr-1815/assets/how-to-guides_ethereum-fallback.md.353433f7.js +++ b/pr-1815/assets/how-to-guides_ethereum-fallback.md.7b275d7a.js @@ -1 +1 @@ -import{_ as a,o,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/Celestia_ethereum-fallback.jpg",v=JSON.parse('{"title":"Ethereum fallback","description":"The DA fallback mechanism to Ethereum for rollups.","frontmatter":{"description":"The DA fallback mechanism to Ethereum for rollups.","next":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/how-to-guides/optimism"},"head":[["meta",{"property":"og:title","content":"Ethereum fallback | Celestia Docs"}],["meta",{"property":"og:description","content":"The DA fallback mechanism to Ethereum for rollups."}]]},"headers":[],"relativePath":"how-to-guides/ethereum-fallback.md","filePath":"how-to-guides/ethereum-fallback.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/ethereum-fallback.md"},n=e("h1",{id:"ethereum-fallback",tabindex:"-1"},[t("Ethereum fallback "),e("a",{class:"header-anchor",href:"#ethereum-fallback","aria-label":'Permalink to "Ethereum fallback"'},"​")],-1),i=e("p",null,"Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fallback” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta. This feature is currently supported by Celestia integrations with:",-1),c=e("ul",null,[e("li",null,[e("a",{href:"./arbitrum-integration#ethereum-fallback-mechanism-in-nitro"},"Arbitrum Nitro")])],-1),h=e("p",null,"In the case of Celestia downtime or temporary unavailability, L2s can fallback to posting transactions as calldata on Ethereum or another DA layer for data availability instead of posting to Celestia. This mechanism ensures users can continue to transact securely and seamlessly, preventing disruptions and helping to ensure user funds do not get stuck in the L2's bridge on Ethereum.",-1),u=e("p",null,[t("Ethereum fallback is triggered whenever the sequencer has an error sending the "),e("code",null,"PayForBlobs"),t(" transaction on Celestia. Fallback can be triggered due to a congested mempool or nonce error and can be simulated with an error such as low balance or incorrect sequence. Fallback can also be triggered in the event Blobstream stops relaying attestations.")],-1),m=e("p",null,[e("img",{src:l,alt:"Ethereum fallback"})],-1),d=[n,i,c,h,u,m];function p(b,f,g,k,_,E){return o(),r("div",null,d)}const w=a(s,[["render",p]]);export{v as __pageData,w as default}; +import{_ as a,o,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/Celestia_ethereum-fallback.jpg",v=JSON.parse('{"title":"Ethereum fallback","description":"The DA fallback mechanism to Ethereum for rollups.","frontmatter":{"description":"The DA fallback mechanism to Ethereum for rollups.","next":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/how-to-guides/optimism"},"head":[["meta",{"property":"og:title","content":"Ethereum fallback | Celestia Docs"}],["meta",{"property":"og:description","content":"The DA fallback mechanism to Ethereum for rollups."}]]},"headers":[],"relativePath":"how-to-guides/ethereum-fallback.md","filePath":"how-to-guides/ethereum-fallback.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/ethereum-fallback.md"},n=e("h1",{id:"ethereum-fallback",tabindex:"-1"},[t("Ethereum fallback "),e("a",{class:"header-anchor",href:"#ethereum-fallback","aria-label":'Permalink to "Ethereum fallback"'},"​")],-1),i=e("p",null,"Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fallback” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta. This feature is currently supported by Celestia integrations with:",-1),c=e("ul",null,[e("li",null,[e("a",{href:"./arbitrum-integration#ethereum-fallback-mechanism-in-nitro"},"Arbitrum Nitro")])],-1),h=e("p",null,"In the case of Celestia downtime or temporary unavailability, L2s can fallback to posting transactions as calldata on Ethereum or another DA layer for data availability instead of posting to Celestia. This mechanism ensures users can continue to transact securely and seamlessly, preventing disruptions and helping to ensure user funds do not get stuck in the L2's bridge on Ethereum.",-1),u=e("p",null,[t("Ethereum fallback is triggered whenever the sequencer has an error sending the "),e("code",null,"PayForBlobs"),t(" transaction on Celestia. Fallback can be triggered due to a congested mempool or nonce error and can be simulated with an error such as low balance or incorrect sequence. Fallback can also be triggered in the event Blobstream stops relaying attestations.")],-1),m=e("p",null,[e("img",{src:l,alt:"Ethereum fallback"})],-1),d=[n,i,c,h,u,m];function p(b,f,g,k,_,E){return o(),r("div",null,d)}const w=a(s,[["render",p]]);export{v as __pageData,w as default}; diff --git a/pr-1815/assets/how-to-guides_ethereum-fallback.md.353433f7.lean.js b/pr-1815/assets/how-to-guides_ethereum-fallback.md.7b275d7a.lean.js similarity index 97% rename from pr-1815/assets/how-to-guides_ethereum-fallback.md.353433f7.lean.js rename to pr-1815/assets/how-to-guides_ethereum-fallback.md.7b275d7a.lean.js index e7cb6bfc0..175c4bbe2 100644 --- a/pr-1815/assets/how-to-guides_ethereum-fallback.md.353433f7.lean.js +++ b/pr-1815/assets/how-to-guides_ethereum-fallback.md.7b275d7a.lean.js @@ -1 +1 @@ -import{_ as a,o,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/Celestia_ethereum-fallback.jpg",v=JSON.parse('{"title":"Ethereum fallback","description":"The DA fallback mechanism to Ethereum for rollups.","frontmatter":{"description":"The DA fallback mechanism to Ethereum for rollups.","next":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/how-to-guides/optimism"},"head":[["meta",{"property":"og:title","content":"Ethereum fallback | Celestia Docs"}],["meta",{"property":"og:description","content":"The DA fallback mechanism to Ethereum for rollups."}]]},"headers":[],"relativePath":"how-to-guides/ethereum-fallback.md","filePath":"how-to-guides/ethereum-fallback.md","lastUpdated":1732776394000}'),s={name:"how-to-guides/ethereum-fallback.md"},n=e("h1",{id:"ethereum-fallback",tabindex:"-1"},[t("Ethereum fallback "),e("a",{class:"header-anchor",href:"#ethereum-fallback","aria-label":'Permalink to "Ethereum fallback"'},"​")],-1),i=e("p",null,"Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fallback” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta. This feature is currently supported by Celestia integrations with:",-1),c=e("ul",null,[e("li",null,[e("a",{href:"./arbitrum-integration#ethereum-fallback-mechanism-in-nitro"},"Arbitrum Nitro")])],-1),h=e("p",null,"In the case of Celestia downtime or temporary unavailability, L2s can fallback to posting transactions as calldata on Ethereum or another DA layer for data availability instead of posting to Celestia. This mechanism ensures users can continue to transact securely and seamlessly, preventing disruptions and helping to ensure user funds do not get stuck in the L2's bridge on Ethereum.",-1),u=e("p",null,[t("Ethereum fallback is triggered whenever the sequencer has an error sending the "),e("code",null,"PayForBlobs"),t(" transaction on Celestia. Fallback can be triggered due to a congested mempool or nonce error and can be simulated with an error such as low balance or incorrect sequence. Fallback can also be triggered in the event Blobstream stops relaying attestations.")],-1),m=e("p",null,[e("img",{src:l,alt:"Ethereum fallback"})],-1),d=[n,i,c,h,u,m];function p(b,f,g,k,_,E){return o(),r("div",null,d)}const w=a(s,[["render",p]]);export{v as __pageData,w as default}; +import{_ as a,o,c as r,k as e,a as t}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/Celestia_ethereum-fallback.jpg",v=JSON.parse('{"title":"Ethereum fallback","description":"The DA fallback mechanism to Ethereum for rollups.","frontmatter":{"description":"The DA fallback mechanism to Ethereum for rollups.","next":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/how-to-guides/optimism"},"head":[["meta",{"property":"og:title","content":"Ethereum fallback | Celestia Docs"}],["meta",{"property":"og:description","content":"The DA fallback mechanism to Ethereum for rollups."}]]},"headers":[],"relativePath":"how-to-guides/ethereum-fallback.md","filePath":"how-to-guides/ethereum-fallback.md","lastUpdated":1732777479000}'),s={name:"how-to-guides/ethereum-fallback.md"},n=e("h1",{id:"ethereum-fallback",tabindex:"-1"},[t("Ethereum fallback "),e("a",{class:"header-anchor",href:"#ethereum-fallback","aria-label":'Permalink to "Ethereum fallback"'},"​")],-1),i=e("p",null,"Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fallback” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta. This feature is currently supported by Celestia integrations with:",-1),c=e("ul",null,[e("li",null,[e("a",{href:"./arbitrum-integration#ethereum-fallback-mechanism-in-nitro"},"Arbitrum Nitro")])],-1),h=e("p",null,"In the case of Celestia downtime or temporary unavailability, L2s can fallback to posting transactions as calldata on Ethereum or another DA layer for data availability instead of posting to Celestia. This mechanism ensures users can continue to transact securely and seamlessly, preventing disruptions and helping to ensure user funds do not get stuck in the L2's bridge on Ethereum.",-1),u=e("p",null,[t("Ethereum fallback is triggered whenever the sequencer has an error sending the "),e("code",null,"PayForBlobs"),t(" transaction on Celestia. Fallback can be triggered due to a congested mempool or nonce error and can be simulated with an error such as low balance or incorrect sequence. Fallback can also be triggered in the event Blobstream stops relaying attestations.")],-1),m=e("p",null,[e("img",{src:l,alt:"Ethereum fallback"})],-1),d=[n,i,c,h,u,m];function p(b,f,g,k,_,E){return o(),r("div",null,d)}const w=a(s,[["render",p]]);export{v as __pageData,w as default}; diff --git a/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.b58bc74e.js b/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.716309b7.js similarity index 99% rename from pr-1815/assets/how-to-guides_feegrant-for-blobs.md.b58bc74e.js rename to pr-1815/assets/how-to-guides_feegrant-for-blobs.md.716309b7.js index a4c2f582e..5dc1c8821 100644 --- a/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.b58bc74e.js +++ b/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.716309b7.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/feegrant-for-blobs.md","filePath":"how-to-guides/feegrant-for-blobs.md","lastUpdated":1732776394000}'),e={name:"how-to-guides/feegrant-for-blobs.md"},l=o(`

    FeeGrant module for blobs submission

    Overview

    This guide provides developers with the knowledge to use the FeeGrant module on the Celestia's Mocha testnet chain for granting a data availability node's account to submit blobs without constantly funding it, enabling a third-party account to cover the transaction fees.

    Pre-requisites

    • celestia-node binary (celestia) installed
    • Access to a Mocha node (e.g., https://rpc-mocha.pops.one:443)
    • Running DA Light node on Mocha testnet
    • One account with sufficient funds, the "granter"
    • One account with no funds, the "grantee"

    Introduction

    Each DA node contains a Celestia account that is used to pay for blobs submissions. To unify the fee payment process, the FeeGrant module allows a third-party account (granter) to pay for the fees incurred by a DA node's (grantee) account. You will need one account that will contain the funds, the granter, and another account that will be in the DA node you run to post blobs, the grantee. You will see the DA node's account once you initialize the node. Learn more about managing accounts with cel-key in create a wallet with celestia-node.

    Granting fee allowances using celestia-node

    To get started granting the fee allowance, you will need two separate keys to run the light node with. One to begin the FeeGrant as the granter and another to use the FeeGrant as the grantee.

    Set some variables for your accounts for the remainder of the guide:

    bash
    export GRANTER_ADDRESS=<your-granter-account-address>
    +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/feegrant-for-blobs.md","filePath":"how-to-guides/feegrant-for-blobs.md","lastUpdated":1732777479000}'),e={name:"how-to-guides/feegrant-for-blobs.md"},l=o(`

    FeeGrant module for blobs submission

    Overview

    This guide provides developers with the knowledge to use the FeeGrant module on the Celestia's Mocha testnet chain for granting a data availability node's account to submit blobs without constantly funding it, enabling a third-party account to cover the transaction fees.

    Pre-requisites

    • celestia-node binary (celestia) installed
    • Access to a Mocha node (e.g., https://rpc-mocha.pops.one:443)
    • Running DA Light node on Mocha testnet
    • One account with sufficient funds, the "granter"
    • One account with no funds, the "grantee"

    Introduction

    Each DA node contains a Celestia account that is used to pay for blobs submissions. To unify the fee payment process, the FeeGrant module allows a third-party account (granter) to pay for the fees incurred by a DA node's (grantee) account. You will need one account that will contain the funds, the granter, and another account that will be in the DA node you run to post blobs, the grantee. You will see the DA node's account once you initialize the node. Learn more about managing accounts with cel-key in create a wallet with celestia-node.

    Granting fee allowances using celestia-node

    To get started granting the fee allowance, you will need two separate keys to run the light node with. One to begin the FeeGrant as the granter and another to use the FeeGrant as the grantee.

    Set some variables for your accounts for the remainder of the guide:

    bash
    export GRANTER_ADDRESS=<your-granter-account-address>
     export GRANTEE_ADDRESS=<your-grantee-account-address>
     export RPC_URL=rpc-mocha.pops.one
    export GRANTER_ADDRESS=<your-granter-account-address>
     export GRANTEE_ADDRESS=<your-grantee-account-address>
    diff --git a/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.b58bc74e.lean.js b/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.716309b7.lean.js
    similarity index 90%
    rename from pr-1815/assets/how-to-guides_feegrant-for-blobs.md.b58bc74e.lean.js
    rename to pr-1815/assets/how-to-guides_feegrant-for-blobs.md.716309b7.lean.js
    index 294ef6e53..57e169355 100644
    --- a/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.b58bc74e.lean.js
    +++ b/pr-1815/assets/how-to-guides_feegrant-for-blobs.md.716309b7.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/feegrant-for-blobs.md","filePath":"how-to-guides/feegrant-for-blobs.md","lastUpdated":1732776394000}'),e={name:"how-to-guides/feegrant-for-blobs.md"},l=o("",54),p=[l];function t(c,r,i,E,y,d){return a(),n("div",null,p)}const g=s(e,[["render",t]]);export{h as __pageData,g as default};
    +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/feegrant-for-blobs.md","filePath":"how-to-guides/feegrant-for-blobs.md","lastUpdated":1732777479000}'),e={name:"how-to-guides/feegrant-for-blobs.md"},l=o("",54),p=[l];function t(c,r,i,E,y,d){return a(),n("div",null,p)}const g=s(e,[["render",t]]);export{h as __pageData,g as default};
    diff --git a/pr-1815/assets/how-to-guides_full-storage-node.md.35341887.js b/pr-1815/assets/how-to-guides_full-storage-node.md.12f43165.js
    similarity index 96%
    rename from pr-1815/assets/how-to-guides_full-storage-node.md.35341887.js
    rename to pr-1815/assets/how-to-guides_full-storage-node.md.12f43165.js
    index 915163c69..efdac4ebf 100644
    --- a/pr-1815/assets/how-to-guides_full-storage-node.md.35341887.js
    +++ b/pr-1815/assets/how-to-guides_full-storage-node.md.12f43165.js
    @@ -1,4 +1,4 @@
    -import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/nodes/full-storage-node.png",g=JSON.parse('{"title":"Setting up a Celestia full storage Node","description":"Set up a Celestia full storage node.","frontmatter":{"description":"Set up a Celestia full storage node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"}],["meta",{"property":"og:description","content":"Set up a Celestia full storage node."}]]},"headers":[],"relativePath":"how-to-guides/full-storage-node.md","filePath":"how-to-guides/full-storage-node.md","lastUpdated":1732776394000}'),n={name:"how-to-guides/full-storage-node.md"},t=o('

    Setting up a Celestia full storage Node

    This tutorial will guide you through setting up a Celestia full storage node, which is a celestia-node that doesn't connect to celestia-app (hence not a consensus node), but stores all the data.

    Overview of full storage nodes

    Full storage nodes are Celestia nodes that store all the data. Full storage nodes send block shares, headers, and fraud proofs to light nodes. The light nodes gossip headers, fraud proofs, and sometimes block shares, between one another.

    Full storage node

    Hardware requirements

    The following hardware minimum requirements are recommended for running the full storage node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your full storage node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    You can follow the tutorial for setting up your dependencies

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Run the full storage node

    Initialize the full storage node

    Run the following command:

    sh
    celestia full init
    celestia full init
    sh
    celestia full init --p2p.network mocha
    celestia full init --p2p.network mocha
    sh
    celestia full init --p2p.network arabica
    celestia full init --p2p.network arabica

    Start the full storage node

    Start the full storage node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get/submit state-related information, such as the ability to submit PayForBlob transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia full start --core.ip <URI>
    celestia full start --core.ip <URI>

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    You can create your key for your node by following the cel-key instructions

    Once you start the full storage node, a wallet key will be generated for you. You will need to fund that address with testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a full-storage node for your sovereign rollup, it is highly recommended to request Arabica devnet tokens as Arabica has the latest changes that can be used to test for developing your sovereign rollup. You can still use Mocha testnet as well, it is just mostly used for validator operations.

    Optional: run the full storage node with a custom key

    In order to run a full storage node using a custom key:

    1. The custom key must exist inside the celestia full storage node directory at the correct path (default: ~/.celestia-full/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia full start --core.ip <URI> \\
    +import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/nodes/full-storage-node.png",g=JSON.parse('{"title":"Setting up a Celestia full storage Node","description":"Set up a Celestia full storage node.","frontmatter":{"description":"Set up a Celestia full storage node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"}],["meta",{"property":"og:description","content":"Set up a Celestia full storage node."}]]},"headers":[],"relativePath":"how-to-guides/full-storage-node.md","filePath":"how-to-guides/full-storage-node.md","lastUpdated":1732777479000}'),n={name:"how-to-guides/full-storage-node.md"},t=o('

    Setting up a Celestia full storage Node

    This tutorial will guide you through setting up a Celestia full storage node, which is a celestia-node that doesn't connect to celestia-app (hence not a consensus node), but stores all the data.

    Overview of full storage nodes

    Full storage nodes are Celestia nodes that store all the data. Full storage nodes send block shares, headers, and fraud proofs to light nodes. The light nodes gossip headers, fraud proofs, and sometimes block shares, between one another.

    Full storage node

    Hardware requirements

    The following hardware minimum requirements are recommended for running the full storage node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your full storage node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    You can follow the tutorial for setting up your dependencies

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Run the full storage node

    Initialize the full storage node

    Run the following command:

    sh
    celestia full init
    celestia full init
    sh
    celestia full init --p2p.network mocha
    celestia full init --p2p.network mocha
    sh
    celestia full init --p2p.network arabica
    celestia full init --p2p.network arabica

    Start the full storage node

    Start the full storage node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get/submit state-related information, such as the ability to submit PayForBlob transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia full start --core.ip <URI>
    celestia full start --core.ip <URI>

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    You can create your key for your node by following the cel-key instructions

    Once you start the full storage node, a wallet key will be generated for you. You will need to fund that address with testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a full-storage node for your sovereign rollup, it is highly recommended to request Arabica devnet tokens as Arabica has the latest changes that can be used to test for developing your sovereign rollup. You can still use Mocha testnet as well, it is just mostly used for validator operations.

    Optional: run the full storage node with a custom key

    In order to run a full storage node using a custom key:

    1. The custom key must exist inside the celestia full storage node directory at the correct path (default: ~/.celestia-full/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia full start --core.ip <URI> \\
       --keyring.keyname <name-of-custom-key> \\
    celestia full start --core.ip <URI> \\
       --keyring.keyname <name-of-custom-key> \\
    sh
    celestia full start --core.ip <URI> \\
       --keyring.keyname <name-of-custom-key> \\
    diff --git a/pr-1815/assets/how-to-guides_full-storage-node.md.35341887.lean.js b/pr-1815/assets/how-to-guides_full-storage-node.md.12f43165.lean.js
    similarity index 92%
    rename from pr-1815/assets/how-to-guides_full-storage-node.md.35341887.lean.js
    rename to pr-1815/assets/how-to-guides_full-storage-node.md.12f43165.lean.js
    index 6b1dc11e9..bd1a23912 100644
    --- a/pr-1815/assets/how-to-guides_full-storage-node.md.35341887.lean.js
    +++ b/pr-1815/assets/how-to-guides_full-storage-node.md.12f43165.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/nodes/full-storage-node.png",g=JSON.parse('{"title":"Setting up a Celestia full storage Node","description":"Set up a Celestia full storage node.","frontmatter":{"description":"Set up a Celestia full storage node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"}],["meta",{"property":"og:description","content":"Set up a Celestia full storage node."}]]},"headers":[],"relativePath":"how-to-guides/full-storage-node.md","filePath":"how-to-guides/full-storage-node.md","lastUpdated":1732776394000}'),n={name:"how-to-guides/full-storage-node.md"},t=o("",44),p=[t];function r(c,i,d,y,u,h){return a(),e("div",null,p)}const f=s(n,[["render",r]]);export{g as __pageData,f as default};
    +import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/nodes/full-storage-node.png",g=JSON.parse('{"title":"Setting up a Celestia full storage Node","description":"Set up a Celestia full storage node.","frontmatter":{"description":"Set up a Celestia full storage node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"}],["meta",{"property":"og:description","content":"Set up a Celestia full storage node."}]]},"headers":[],"relativePath":"how-to-guides/full-storage-node.md","filePath":"how-to-guides/full-storage-node.md","lastUpdated":1732777479000}'),n={name:"how-to-guides/full-storage-node.md"},t=o("",44),p=[t];function r(c,i,d,y,u,h){return a(),e("div",null,p)}const f=s(n,[["render",r]]);export{g as __pageData,f as default};
    diff --git a/pr-1815/assets/how-to-guides_ibc-relayer.md.f1a48ea7.js b/pr-1815/assets/how-to-guides_ibc-relayer.md.54b5d7e7.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_ibc-relayer.md.f1a48ea7.js
    rename to pr-1815/assets/how-to-guides_ibc-relayer.md.54b5d7e7.js
    index 7d60d3eb4..aed3f10ce 100644
    --- a/pr-1815/assets/how-to-guides_ibc-relayer.md.f1a48ea7.js
    +++ b/pr-1815/assets/how-to-guides_ibc-relayer.md.54b5d7e7.js
    @@ -1,4 +1,4 @@
    -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"IBC relaying guide","description":"Learn how to establish IBC connections and relay packets.","frontmatter":{"description":"Learn how to establish IBC connections and relay packets.","next":{"text":"Metrics","link":"/how-to-guides/celestia-node-metrics"},"head":[["meta",{"property":"og:title","content":"IBC relaying guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to establish IBC connections and relay packets."}]]},"headers":[],"relativePath":"how-to-guides/ibc-relayer.md","filePath":"how-to-guides/ibc-relayer.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/ibc-relayer.md"},o=l(`

    IBC relaying guide

    Celestia uses IBC (Inter-Blockchain Communication protocol) to enable cross-chain transfer of tokens. To support this capability it relies on relayers, processes that can be run by anyone which constantly scan for outbound packets on one chain and submits these packets alongside corresponding proofs on the destination chain. This section describes how one can setup a relayer and create new connections between chains. There are two standard implementations:

    The following guide explains how to establish IBC connections and relay packets between Mocha testnet and Cosmos hub testnet networks by using the Hermes relayer.

    Check the latest celestia-app release's go.mod for the version of ibc-go that is currently used.

    Hermes

    Hermes is an open-source Rust implementation of an IBC relayer released as part of the ibc-relayer-cli crate. It includes a CLI for relaying packets between Cosmos SDK chains, as well as Prometheus metrics and a REST API.

    Please follow the steps at Hermes Quick Start to install Hermes. Before proceeding, verify that Hermes is installed correctly by running hermes version.

    TIP

    Hermes currently doesn't support configuring the Tendermint CompatMode in chain config (see hermes#3623). Until that issue is resolved, please use Hermes v1.7.0+ because it falls back to Tendermint CompatMode v0.34 (see hermes#3663) which is compatible with Celestia.

    Configuration

    After you have successfully installed Hermes and created the necessary folders, you now have to edit config.toml and add the appropriate configurations for the chains you want to relay between.

    For this tutorial, we will be using the following chains:

    • Celestia's mocha-4 testnet
    • Cosmos Hub's theta-testnet-001 testnet

    Edit the Hermes configuration.

    bash
    vim $HOME/.hermes/config.toml
    vim $HOME/.hermes/config.toml
    toml
    [global]
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"IBC relaying guide","description":"Learn how to establish IBC connections and relay packets.","frontmatter":{"description":"Learn how to establish IBC connections and relay packets.","next":{"text":"Metrics","link":"/how-to-guides/celestia-node-metrics"},"head":[["meta",{"property":"og:title","content":"IBC relaying guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to establish IBC connections and relay packets."}]]},"headers":[],"relativePath":"how-to-guides/ibc-relayer.md","filePath":"how-to-guides/ibc-relayer.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/ibc-relayer.md"},o=l(`

    IBC relaying guide

    Celestia uses IBC (Inter-Blockchain Communication protocol) to enable cross-chain transfer of tokens. To support this capability it relies on relayers, processes that can be run by anyone which constantly scan for outbound packets on one chain and submits these packets alongside corresponding proofs on the destination chain. This section describes how one can setup a relayer and create new connections between chains. There are two standard implementations:

    The following guide explains how to establish IBC connections and relay packets between Mocha testnet and Cosmos hub testnet networks by using the Hermes relayer.

    Check the latest celestia-app release's go.mod for the version of ibc-go that is currently used.

    Hermes

    Hermes is an open-source Rust implementation of an IBC relayer released as part of the ibc-relayer-cli crate. It includes a CLI for relaying packets between Cosmos SDK chains, as well as Prometheus metrics and a REST API.

    Please follow the steps at Hermes Quick Start to install Hermes. Before proceeding, verify that Hermes is installed correctly by running hermes version.

    TIP

    Hermes currently doesn't support configuring the Tendermint CompatMode in chain config (see hermes#3623). Until that issue is resolved, please use Hermes v1.7.0+ because it falls back to Tendermint CompatMode v0.34 (see hermes#3663) which is compatible with Celestia.

    Configuration

    After you have successfully installed Hermes and created the necessary folders, you now have to edit config.toml and add the appropriate configurations for the chains you want to relay between.

    For this tutorial, we will be using the following chains:

    • Celestia's mocha-4 testnet
    • Cosmos Hub's theta-testnet-001 testnet

    Edit the Hermes configuration.

    bash
    vim $HOME/.hermes/config.toml
    vim $HOME/.hermes/config.toml
    toml
    [global]
     log_level = "info"
     
     [mode.clients]
    diff --git a/pr-1815/assets/how-to-guides_ibc-relayer.md.f1a48ea7.lean.js b/pr-1815/assets/how-to-guides_ibc-relayer.md.54b5d7e7.lean.js
    similarity index 92%
    rename from pr-1815/assets/how-to-guides_ibc-relayer.md.f1a48ea7.lean.js
    rename to pr-1815/assets/how-to-guides_ibc-relayer.md.54b5d7e7.lean.js
    index 4d114a246..0a6af5486 100644
    --- a/pr-1815/assets/how-to-guides_ibc-relayer.md.f1a48ea7.lean.js
    +++ b/pr-1815/assets/how-to-guides_ibc-relayer.md.54b5d7e7.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"IBC relaying guide","description":"Learn how to establish IBC connections and relay packets.","frontmatter":{"description":"Learn how to establish IBC connections and relay packets.","next":{"text":"Metrics","link":"/how-to-guides/celestia-node-metrics"},"head":[["meta",{"property":"og:title","content":"IBC relaying guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to establish IBC connections and relay packets."}]]},"headers":[],"relativePath":"how-to-guides/ibc-relayer.md","filePath":"how-to-guides/ibc-relayer.md","lastUpdated":1732776394000}'),p={name:"how-to-guides/ibc-relayer.md"},o=l("",61),e=[o];function t(c,r,E,y,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{h as __pageData,u as default};
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"IBC relaying guide","description":"Learn how to establish IBC connections and relay packets.","frontmatter":{"description":"Learn how to establish IBC connections and relay packets.","next":{"text":"Metrics","link":"/how-to-guides/celestia-node-metrics"},"head":[["meta",{"property":"og:title","content":"IBC relaying guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to establish IBC connections and relay packets."}]]},"headers":[],"relativePath":"how-to-guides/ibc-relayer.md","filePath":"how-to-guides/ibc-relayer.md","lastUpdated":1732777479000}'),p={name:"how-to-guides/ibc-relayer.md"},o=l("",61),e=[o];function t(c,r,E,y,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{h as __pageData,u as default};
    diff --git a/pr-1815/assets/how-to-guides_instantiate-testnet.md.e040791e.js b/pr-1815/assets/how-to-guides_instantiate-testnet.md.6d6bb2c0.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_instantiate-testnet.md.e040791e.js
    rename to pr-1815/assets/how-to-guides_instantiate-testnet.md.6d6bb2c0.js
    index 7c30c0be2..a65ceb0c3 100644
    --- a/pr-1815/assets/how-to-guides_instantiate-testnet.md.e040791e.js
    +++ b/pr-1815/assets/how-to-guides_instantiate-testnet.md.6d6bb2c0.js
    @@ -1,4 +1,4 @@
    -import{_ as e,o as s,c as a,Q as n}from"./chunks/framework.2959b752.js";const E=JSON.parse('{"title":"Celestia App network instantiation guide","description":"A guide that helps you instantiate a new testnetwork with Celestia App.","frontmatter":{"description":"A guide that helps you instantiate a new testnetwork with Celestia App.","head":[["meta",{"property":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps you instantiate a new testnetwork with Celestia App."}]]},"headers":[],"relativePath":"how-to-guides/instantiate-testnet.md","filePath":"how-to-guides/instantiate-testnet.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/instantiate-testnet.md"},t=n(`

    Celestia App network instantiation guide

    This guide is for helping instantiate a new testnetwork and following the correct steps to do so with Celestia App. You should only follow this guide if you want to experiment with your own Celestia test network (testnet) or if you want to test out new features to build as a core developer.

    Hardware requirements

    You will need to follow hardware requirements.

    Setup dependencies

    You will need to setup dependencies by following the guide.

    celestia-app installation

    You will need to install celestia-app by following the guide.

    Spin up a Celestia testnet

    If you want to spin up a quick testnet with your friends, you can follow these steps. Unless otherwise noted, every step must be done by everyone who wants to participate in this testnet.

    Optional: Reset working directory

    If you have already initialized a working directory for celestia-appd in the past, you must clean up before reinitializing a new directory. You can do so by running the following command:

    sh
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app

    Initialize a working directory

    Run the following command:

    sh
    VALIDATOR_NAME=validator1
    +import{_ as e,o as s,c as a,Q as n}from"./chunks/framework.2959b752.js";const E=JSON.parse('{"title":"Celestia App network instantiation guide","description":"A guide that helps you instantiate a new testnetwork with Celestia App.","frontmatter":{"description":"A guide that helps you instantiate a new testnetwork with Celestia App.","head":[["meta",{"property":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps you instantiate a new testnetwork with Celestia App."}]]},"headers":[],"relativePath":"how-to-guides/instantiate-testnet.md","filePath":"how-to-guides/instantiate-testnet.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/instantiate-testnet.md"},t=n(`

    Celestia App network instantiation guide

    This guide is for helping instantiate a new testnetwork and following the correct steps to do so with Celestia App. You should only follow this guide if you want to experiment with your own Celestia test network (testnet) or if you want to test out new features to build as a core developer.

    Hardware requirements

    You will need to follow hardware requirements.

    Setup dependencies

    You will need to setup dependencies by following the guide.

    celestia-app installation

    You will need to install celestia-app by following the guide.

    Spin up a Celestia testnet

    If you want to spin up a quick testnet with your friends, you can follow these steps. Unless otherwise noted, every step must be done by everyone who wants to participate in this testnet.

    Optional: Reset working directory

    If you have already initialized a working directory for celestia-appd in the past, you must clean up before reinitializing a new directory. You can do so by running the following command:

    sh
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app

    Initialize a working directory

    Run the following command:

    sh
    VALIDATOR_NAME=validator1
     CHAIN_ID=testnet
     celestia-appd init $VALIDATOR_NAME --chain-id $CHAIN_ID
    VALIDATOR_NAME=validator1
     CHAIN_ID=testnet
    diff --git a/pr-1815/assets/how-to-guides_instantiate-testnet.md.e040791e.lean.js b/pr-1815/assets/how-to-guides_instantiate-testnet.md.6d6bb2c0.lean.js
    similarity index 92%
    rename from pr-1815/assets/how-to-guides_instantiate-testnet.md.e040791e.lean.js
    rename to pr-1815/assets/how-to-guides_instantiate-testnet.md.6d6bb2c0.lean.js
    index f0ac9c72b..64d264084 100644
    --- a/pr-1815/assets/how-to-guides_instantiate-testnet.md.e040791e.lean.js
    +++ b/pr-1815/assets/how-to-guides_instantiate-testnet.md.6d6bb2c0.lean.js
    @@ -1 +1 @@
    -import{_ as e,o as s,c as a,Q as n}from"./chunks/framework.2959b752.js";const E=JSON.parse('{"title":"Celestia App network instantiation guide","description":"A guide that helps you instantiate a new testnetwork with Celestia App.","frontmatter":{"description":"A guide that helps you instantiate a new testnetwork with Celestia App.","head":[["meta",{"property":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps you instantiate a new testnetwork with Celestia App."}]]},"headers":[],"relativePath":"how-to-guides/instantiate-testnet.md","filePath":"how-to-guides/instantiate-testnet.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/instantiate-testnet.md"},t=n("",60),l=[t];function p(i,r,c,d,h,y){return s(),a("div",null,l)}const g=e(o,[["render",p]]);export{E as __pageData,g as default};
    +import{_ as e,o as s,c as a,Q as n}from"./chunks/framework.2959b752.js";const E=JSON.parse('{"title":"Celestia App network instantiation guide","description":"A guide that helps you instantiate a new testnetwork with Celestia App.","frontmatter":{"description":"A guide that helps you instantiate a new testnetwork with Celestia App.","head":[["meta",{"property":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"}],["meta",{"property":"og:description","content":"A guide that helps you instantiate a new testnetwork with Celestia App."}]]},"headers":[],"relativePath":"how-to-guides/instantiate-testnet.md","filePath":"how-to-guides/instantiate-testnet.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/instantiate-testnet.md"},t=n("",60),l=[t];function p(i,r,c,d,h,y){return s(),a("div",null,l)}const g=e(o,[["render",p]]);export{E as __pageData,g as default};
    diff --git a/pr-1815/assets/how-to-guides_intro-to-op-stack.md.fc0653f2.js b/pr-1815/assets/how-to-guides_intro-to-op-stack.md.41b9814c.js
    similarity index 98%
    rename from pr-1815/assets/how-to-guides_intro-to-op-stack.md.fc0653f2.js
    rename to pr-1815/assets/how-to-guides_intro-to-op-stack.md.41b9814c.js
    index 1ea20c635..9b5f2b8cd 100644
    --- a/pr-1815/assets/how-to-guides_intro-to-op-stack.md.fc0653f2.js
    +++ b/pr-1815/assets/how-to-guides_intro-to-op-stack.md.41b9814c.js
    @@ -1 +1 @@
    -import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Introduction to OP Stack integration","description":"Learn about the integration of OP Stack with Celestia.","frontmatter":{"description":"Learn about the integration of OP Stack with Celestia.","prev":{"text":"Bridging in and out of your Orbit rollup","link":"/how-to-guides/arbitrum-bridge"},"head":[["meta",{"property":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about the integration of OP Stack with Celestia."}]]},"headers":[],"relativePath":"how-to-guides/intro-to-op-stack.md","filePath":"how-to-guides/intro-to-op-stack.md","lastUpdated":1732776394000}'),i={name:"how-to-guides/intro-to-op-stack.md"},r=o('

    Introduction to OP Stack integration

    Optimism is a low-cost and lightning-fast Ethereum L2 blockchain, built with the OP Stack.

    Celestia is a modular consensus and data availability (DA) network, built to enable anyone to easily deploy their own blockchain with minimal overhead.

    Together, they allow developers to create rollups that post data to Celestia and settle on Ethereum.

    About the integration

    Optimism uses Ethereum as a DA layer. Currently, settlement and DA for Optimism are on Ethereum, both onchain. op-batcher batches up rollup blocks and posts to Ethereum.

    The integration of OP Stack with Celestia underneath for DA allows rollup operators to reduce overhead that is associated with posting data as calldata on Ethereum. Instead, op-batcher batches up rollup blocks and posts them to Celestia's DA network.

    Data is managed in two ways. First, data is written to the data availability (DA) layer i.e. in this case Celestia, then the data commitment is written to the op-batcher. When reading op-node simply reads the data back from the DA layer by reading the data commitment from the op-batcher first, then reading the data from the DA layer using the data commitment. While previously op-node was reading from calldata on Ethereum, it now reads data from Celestia.

    There are a few tools involved in the data handling process. op-batcher batches up rollup blocks and posts them to Ethereum. op-geth handles execution, while op-proposer is responsible for state commitment submission.

    By using Celestia as a DA layer, existing L2s can switch from posting their data as calldata on Ethereum, to posting to Celestia. The commitment to the block is posted on Celestia, which is purpose-built for data availability. This is a more scalable than the traditional method of posting this data as calldata on monolithic chains.

    GitHub repository

    Find the repository for this integration at https://github.com/celestiaorg/optimism.

    WARNING

    This is a beta integration and we are working on resolving open issues.

    Next steps

    Now that you understand the integration, you can start learning about the Bubs testnet, built with OP Stack and Celestia! This testnet is a great way to explore the possibilities of this integration and test your applications in a live environment.

    ',15),n=[r];function s(h,c,l,d,p,u){return e(),a("div",null,n)}const g=t(i,[["render",s]]);export{b as __pageData,g as default}; +import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Introduction to OP Stack integration","description":"Learn about the integration of OP Stack with Celestia.","frontmatter":{"description":"Learn about the integration of OP Stack with Celestia.","prev":{"text":"Bridging in and out of your Orbit rollup","link":"/how-to-guides/arbitrum-bridge"},"head":[["meta",{"property":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about the integration of OP Stack with Celestia."}]]},"headers":[],"relativePath":"how-to-guides/intro-to-op-stack.md","filePath":"how-to-guides/intro-to-op-stack.md","lastUpdated":1732777479000}'),i={name:"how-to-guides/intro-to-op-stack.md"},r=o('

    Introduction to OP Stack integration

    Optimism is a low-cost and lightning-fast Ethereum L2 blockchain, built with the OP Stack.

    Celestia is a modular consensus and data availability (DA) network, built to enable anyone to easily deploy their own blockchain with minimal overhead.

    Together, they allow developers to create rollups that post data to Celestia and settle on Ethereum.

    About the integration

    Optimism uses Ethereum as a DA layer. Currently, settlement and DA for Optimism are on Ethereum, both onchain. op-batcher batches up rollup blocks and posts to Ethereum.

    The integration of OP Stack with Celestia underneath for DA allows rollup operators to reduce overhead that is associated with posting data as calldata on Ethereum. Instead, op-batcher batches up rollup blocks and posts them to Celestia's DA network.

    Data is managed in two ways. First, data is written to the data availability (DA) layer i.e. in this case Celestia, then the data commitment is written to the op-batcher. When reading op-node simply reads the data back from the DA layer by reading the data commitment from the op-batcher first, then reading the data from the DA layer using the data commitment. While previously op-node was reading from calldata on Ethereum, it now reads data from Celestia.

    There are a few tools involved in the data handling process. op-batcher batches up rollup blocks and posts them to Ethereum. op-geth handles execution, while op-proposer is responsible for state commitment submission.

    By using Celestia as a DA layer, existing L2s can switch from posting their data as calldata on Ethereum, to posting to Celestia. The commitment to the block is posted on Celestia, which is purpose-built for data availability. This is a more scalable than the traditional method of posting this data as calldata on monolithic chains.

    GitHub repository

    Find the repository for this integration at https://github.com/celestiaorg/optimism.

    WARNING

    This is a beta integration and we are working on resolving open issues.

    Next steps

    Now that you understand the integration, you can start learning about the Bubs testnet, built with OP Stack and Celestia! This testnet is a great way to explore the possibilities of this integration and test your applications in a live environment.

    ',15),n=[r];function s(h,c,l,d,p,u){return e(),a("div",null,n)}const g=t(i,[["render",s]]);export{b as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_intro-to-op-stack.md.fc0653f2.lean.js b/pr-1815/assets/how-to-guides_intro-to-op-stack.md.41b9814c.lean.js similarity index 93% rename from pr-1815/assets/how-to-guides_intro-to-op-stack.md.fc0653f2.lean.js rename to pr-1815/assets/how-to-guides_intro-to-op-stack.md.41b9814c.lean.js index bca8de604..e8ebc74d7 100644 --- a/pr-1815/assets/how-to-guides_intro-to-op-stack.md.fc0653f2.lean.js +++ b/pr-1815/assets/how-to-guides_intro-to-op-stack.md.41b9814c.lean.js @@ -1 +1 @@ -import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Introduction to OP Stack integration","description":"Learn about the integration of OP Stack with Celestia.","frontmatter":{"description":"Learn about the integration of OP Stack with Celestia.","prev":{"text":"Bridging in and out of your Orbit rollup","link":"/how-to-guides/arbitrum-bridge"},"head":[["meta",{"property":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about the integration of OP Stack with Celestia."}]]},"headers":[],"relativePath":"how-to-guides/intro-to-op-stack.md","filePath":"how-to-guides/intro-to-op-stack.md","lastUpdated":1732776394000}'),i={name:"how-to-guides/intro-to-op-stack.md"},r=o("",15),n=[r];function s(h,c,l,d,p,u){return e(),a("div",null,n)}const g=t(i,[["render",s]]);export{b as __pageData,g as default}; +import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Introduction to OP Stack integration","description":"Learn about the integration of OP Stack with Celestia.","frontmatter":{"description":"Learn about the integration of OP Stack with Celestia.","prev":{"text":"Bridging in and out of your Orbit rollup","link":"/how-to-guides/arbitrum-bridge"},"head":[["meta",{"property":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about the integration of OP Stack with Celestia."}]]},"headers":[],"relativePath":"how-to-guides/intro-to-op-stack.md","filePath":"how-to-guides/intro-to-op-stack.md","lastUpdated":1732777479000}'),i={name:"how-to-guides/intro-to-op-stack.md"},r=o("",15),n=[r];function s(h,c,l,d,p,u){return e(),a("div",null,n)}const g=t(i,[["render",s]]);export{b as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_light-node.md.faf1d5ee.js b/pr-1815/assets/how-to-guides_light-node.md.edb7fb97.js similarity index 95% rename from pr-1815/assets/how-to-guides_light-node.md.faf1d5ee.js rename to pr-1815/assets/how-to-guides_light-node.md.edb7fb97.js index 6a9d42b7a..da7706a8f 100644 --- a/pr-1815/assets/how-to-guides_light-node.md.faf1d5ee.js +++ b/pr-1815/assets/how-to-guides_light-node.md.edb7fb97.js @@ -1,6 +1,6 @@ -import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/nodes/LightNodes.png",F=JSON.parse('{"title":"Setting up a Celestia light node","description":"This tutorial covers setting up a Celestia light node.","frontmatter":{"sidebar_label":"Light node","description":"This tutorial covers setting up a Celestia light node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia light node | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers setting up a Celestia light node."}]]},"headers":[],"relativePath":"how-to-guides/light-node.md","filePath":"how-to-guides/light-node.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/light-node.md"},t=n('

    Setting up a Celestia light node

    This tutorial will guide you through setting up a Celestia light node, which will allow you to perform data availability sampling (DAS) on Celestia's data availability (DA) network.

    Overview of light nodes

    Light nodes ensure data availability. This is the most common way to interact with Celestia networks.

    light-node

    Light nodes have the following behavior:

    1. They listen for ExtendedHeaders, i.e. wrapped “raw” headers, that notify Celestia nodes of new block headers and relevant DA metadata.
    2. They perform DAS on the received headers

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 100 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Quickstart: Run a light node in your browser

    The easiest way to run a Celestia light node is with Lumina.rs in your browser.

    Lumina.rs in browser

    You can also run Lumina on the first decentralized block explorer, Celenium.

    Celenium running a light node with Lumina.rs

    Setting up your light node

    This tutorial was performed on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up dependencies on the setting up environment page.

    Install celestia-node

    Install the celestia binary by building and installing celestia-node.

    Initialize the light node

    Run the following command:

    sh
    celestia light init
    celestia light init
    sh
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    sh
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    The output in your terminal will show the location of your node store and config. It will also show confirmation that the node store has been initialized.

    Start the light node

    Start the light node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get and submit state-related information, such as the ability to submit PayForBlobs transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    sh
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    sh
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica

    Tip: you can replace the core.ip with a consensus node RPC endpoint from Mainnet Beta, Mocha testnet, or Arabica devnet.

    Keys and wallets

    You can create your key for your node by running the following command with the cel-key utility in the celestia-node directory:

    sh
    ./cel-key add <key-name> --keyring-backend test \\
    +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/nodes/LightNodes.png",u=JSON.parse('{"title":"Setting up a Celestia light node","description":"This tutorial covers setting up a Celestia light node.","frontmatter":{"sidebar_label":"Light node","description":"This tutorial covers setting up a Celestia light node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia light node | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers setting up a Celestia light node."}]]},"headers":[],"relativePath":"how-to-guides/light-node.md","filePath":"how-to-guides/light-node.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/light-node.md"},t=n('

    Setting up a Celestia light node

    This tutorial will guide you through setting up a Celestia light node, which will allow you to perform data availability sampling (DAS) on Celestia's data availability (DA) network.

    Overview of light nodes

    Light nodes ensure data availability. This is the most common way to interact with Celestia networks.

    light-node

    Light nodes have the following behavior:

    1. They listen for ExtendedHeaders, i.e. wrapped “raw” headers, that notify Celestia nodes of new block headers and relevant DA metadata.
    2. They perform DAS on the received headers

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 100 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Quickstart: Run a light node in your browser

    The easiest way to run a Celestia light node is with Lumina.rs in your browser.

    Lumina.rs in browser

    You can also run Lumina on the first decentralized block explorer, Celenium.

    Celenium running a light node with Lumina.rs

    Setting up your light node

    This tutorial was performed on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up dependencies on the setting up environment page.

    Install celestia-node

    Install the celestia binary by building and installing celestia-node.

    Initialize the light node

    Run the following command:

    sh
    celestia light init
    celestia light init
    sh
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    sh
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    The output in your terminal will show the location of your node store and config. It will also show confirmation that the node store has been initialized.

    Start the light node

    Start the light node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get and submit state-related information, such as the ability to submit PayForBlobs transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    sh
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    sh
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica

    Tip: you can replace the core.ip with a consensus node RPC endpoint from Mainnet Beta, Mocha testnet, or Arabica devnet.

    Keys and wallets

    You can create your key for your node by running the following command with the cel-key utility in the celestia-node directory:

    sh
    ./cel-key add <key-name> --keyring-backend test \\
         --node.type light --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test \\
    -    --node.type light --p2p.network <network>

    You can start your light node with the key created above by running the following command:

    sh
    celestia light start --keyring.keyname my_celes_key \\
    +    --node.type light --p2p.network <network>

    You can start your light node with the key created above by running the following command:

    sh
    celestia light start --keyring.keyname my_celes_key \\
         --core.ip consensus.lunaroasis.net
    celestia light start --keyring.keyname my_celes_key \\
         --core.ip consensus.lunaroasis.net
    sh
    celestia light start --keyring.keyname my_celes_key \\
         --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --keyring.keyname my_celes_key \\
    @@ -10,7 +10,7 @@ import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const o=
         --core.ip validator-1.celestia-arabica-11.com \\
         --p2p.network arabica

    Once you start the light node, a wallet key will be generated for you. You will need to fund that address with testnet tokens to pay for PayForBlob transactions.

    You can find the address using the RPC CLI or by running the following command in the celestia-node directory:

    sh
    ./cel-key list --node.type light --keyring-backend test \\
         --p2p.network <network>
    ./cel-key list --node.type light --keyring-backend test \\
    -    --p2p.network <network>

    Testnet tokens

    You have two networks to get testnet tokens from:

    You can request funds to your wallet address using the following command in Discord:

    console
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is the celestia1****** address generated when you created the wallet.

    Optional: run the light node with a custom key

    In order to run a light node using a custom key:

    1. The custom key must exist inside the celestia light node directory at the correct path (default: ~/.celestia-light/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia light start --core.ip <URI> \\
    +    --p2p.network <network>

    Testnet tokens

    You have two networks to get testnet tokens from:

    You can request funds to your wallet address using the following command in Discord:

    console
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is the celestia1****** address generated when you created the wallet.

    Optional: run the light node with a custom key

    In order to run a light node using a custom key:

    1. The custom key must exist inside the celestia light node directory at the correct path (default: ~/.celestia-light/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia light start --core.ip <URI> \\
         --keyring.keyname <name-of-custom-key> \\
    celestia light start --core.ip <URI> \\
         --keyring.keyname <name-of-custom-key> \\
    sh
    celestia light start --core.ip <URI> \\
         --keyring.keyname <name-of-custom-key> \\
    @@ -20,4 +20,4 @@ import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const o=
         --keyring.keyname <name-of-custom-key> \\
         --p2p.network mocha
    celestia light start --core.ip <URI> \\
         --keyring.keyname <name-of-custom-key> \\
    -    --p2p.network mocha

    Optional: Migrate node id to another server

    To migrate a light node ID:

    1. You need to back up two files located in the celestia-light node directory at the correct path (default: ~/.celestia-light/keys).
    2. Upload the files to the new server and start the node.

    Optional: start light node with SystemD

    Follow the tutorial on setting up the light node as a background process with SystemD.

    Data availability sampling

    With your light node running, you can check out this tutorial on submitting PayForBlob transactions.

    `,55),p=[t];function r(c,i,y,d,E,h){return a(),e("div",null,p)}const u=s(l,[["render",r]]);export{F as __pageData,u as default}; + --p2p.network mocha

    Optional: Migrate node id to another server

    To migrate a light node ID:

    1. You need to back up two files located in the celestia-light node directory at the correct path (default: ~/.celestia-light/keys).
    2. Upload the files to the new server and start the node.

    Optional: start light node with SystemD

    Follow the tutorial on setting up the light node as a background process with SystemD.

    Data availability sampling

    With your light node running, you can check out this tutorial on submitting PayForBlob transactions.

    `,55),p=[t];function r(c,i,y,d,E,h){return a(),e("div",null,p)}const F=s(l,[["render",r]]);export{u as __pageData,F as default}; diff --git a/pr-1815/assets/how-to-guides_light-node.md.faf1d5ee.lean.js b/pr-1815/assets/how-to-guides_light-node.md.edb7fb97.lean.js similarity index 65% rename from pr-1815/assets/how-to-guides_light-node.md.faf1d5ee.lean.js rename to pr-1815/assets/how-to-guides_light-node.md.edb7fb97.lean.js index d0df6cf85..0ca6be249 100644 --- a/pr-1815/assets/how-to-guides_light-node.md.faf1d5ee.lean.js +++ b/pr-1815/assets/how-to-guides_light-node.md.edb7fb97.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/nodes/LightNodes.png",F=JSON.parse('{"title":"Setting up a Celestia light node","description":"This tutorial covers setting up a Celestia light node.","frontmatter":{"sidebar_label":"Light node","description":"This tutorial covers setting up a Celestia light node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia light node | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers setting up a Celestia light node."}]]},"headers":[],"relativePath":"how-to-guides/light-node.md","filePath":"how-to-guides/light-node.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/light-node.md"},t=n("",55),p=[t];function r(c,i,y,d,E,h){return a(),e("div",null,p)}const u=s(l,[["render",r]]);export{F as __pageData,u as default}; +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/nodes/LightNodes.png",u=JSON.parse('{"title":"Setting up a Celestia light node","description":"This tutorial covers setting up a Celestia light node.","frontmatter":{"sidebar_label":"Light node","description":"This tutorial covers setting up a Celestia light node.","head":[["meta",{"property":"og:title","content":"Setting up a Celestia light node | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers setting up a Celestia light node."}]]},"headers":[],"relativePath":"how-to-guides/light-node.md","filePath":"how-to-guides/light-node.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/light-node.md"},t=n("",55),p=[t];function r(c,i,y,d,E,h){return a(),e("div",null,p)}const F=s(l,[["render",r]]);export{u as __pageData,F as default}; diff --git a/pr-1815/assets/how-to-guides_local-testnet.md.b7413a1e.js b/pr-1815/assets/how-to-guides_local-testnet.md.d47ac3d0.js similarity index 91% rename from pr-1815/assets/how-to-guides_local-testnet.md.b7413a1e.js rename to pr-1815/assets/how-to-guides_local-testnet.md.d47ac3d0.js index 7644e156d..1105153b6 100644 --- a/pr-1815/assets/how-to-guides_local-testnet.md.b7413a1e.js +++ b/pr-1815/assets/how-to-guides_local-testnet.md.d47ac3d0.js @@ -1,6 +1,6 @@ -import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up a Celestia local testnet","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Setting up a Celestia local testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/local-testnet.md","filePath":"how-to-guides/local-testnet.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/local-testnet.md"},o=p(`

    Setting up a Celestia local testnet

    This guide walks through setting up a local Celestia testnet with a validator node, bridge node, and light node.

    Prerequisites

    • celestia-app installed (based on compatible versions)
    • celestia node binary installed
    • jq installed

    Starting the validator node

    First, navigate to the celestia-app scripts directory and run the single node script:

    bash
    cd celestia-app/scripts
    +import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up a Celestia local testnet","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Setting up a Celestia local testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/local-testnet.md","filePath":"how-to-guides/local-testnet.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/local-testnet.md"},o=p(`

    Setting up a Celestia local testnet

    This guide walks through setting up a local Celestia testnet with a validator node, bridge node, and light node.

    Prerequisites

    • celestia-app installed (based on compatible versions)
    • celestia node binary installed
    • jq installed
    • nc (netcat) installed

    Bash script

    This method will start up the testnet with a bash script. It still assumes you have the prerequisites installed.

    bash
    bash -c "$(curl -sL https://docs.celestia.org/start-local.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/start-local.sh)"

    To interact with the nodes, you can use the celestia and celestia-appd CLIs. Use the funding and testing section below as a guide.

    Manual setup

    Starting the validator node

    First, navigate to the celestia-app scripts directory and run the single node script:

    bash
    cd celestia-app/scripts
     bash single-node.sh
    cd celestia-app/scripts
    -bash single-node.sh

    Setting up the bridge node

    Once your validator node is running, get the genesis block hash:

    bash
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'

    This will return a hash like:

    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Set this as an environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the bridge node:

    bash
    celestia bridge init \\
    +bash single-node.sh

    Setting up the bridge node

    Once your validator node is running, get the genesis block hash:

    bash
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'

    This will return a hash like:

    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Set this as an environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the bridge node:

    bash
    celestia bridge init \\
         --node.store $HOME/.celestia-custom-bridge \\
         --core.ip localhost \\
         --core.grpc.port 9090 \\
    @@ -20,7 +20,7 @@ import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=
         --core.ip localhost \\
         --core.grpc.port 9090 \\
         --core.rpc.port 26657 \\
    -    --p2p.network test

    Setting up the light node

    In a new terminal, set the same environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the light node:

    bash
    celestia light init \\
    +    --p2p.network test

    Setting up the light node

    In a new terminal, set the same environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the light node:

    bash
    celestia light init \\
         --p2p.network test \\
         --core.ip localhost:26657 \\
         --node.store $HOME/.celestia-custom-light/
    celestia light init \\
    @@ -62,7 +62,7 @@ import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=
         --core.ip localhost:26657 \\
         --node.store $HOME/.celestia-custom-light/ \\
         --headers.trusted-peers /ip4/10.0.0.125/udp/2121/webrtc-direct/certhash/uEiBXDYwH1McBsLM2aEc3SdvAuhq2ZQ0RUgbjgTvXMQm7LA/p2p/12D3KooWAVsZ36CdczaEXNNnDpsPcVyAnbeBe5EPG7AjttRGfux7 \\
    -    --rpc.port 42069

    Funding and testing

    Get the bridge node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-bridge
    celestia state account-address --node.store $HOME/.celestia-custom-bridge

    Get the light node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069

    Send funds to the light node:

    bash
    celestia-appd tx bank send validator celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3 10000000utia \\
    +    --rpc.port 42069

    Funding and testing

    Get the bridge node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-bridge
    celestia state account-address --node.store $HOME/.celestia-custom-bridge

    Get the light node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069

    Send funds to the light node:

    bash
    celestia-appd tx bank send validator celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3 10000000utia \\
         --chain-id test \\
         --keyring-backend test \\
         --fees 500utia
    celestia-appd tx bank send validator celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3 10000000utia \\
    @@ -72,4 +72,4 @@ import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=
         --node.store $HOME/.celestia-custom-light \\
         --url http://localhost:42069
    celestia blob submit 0x4772756763686174 '"Simplicity is the ultimate sophistication." -Leonardo da Vinci' \\
         --node.store $HOME/.celestia-custom-light \\
    -    --url http://localhost:42069
    `,38),e=[o];function t(c,r,E,i,y,d){return a(),n("div",null,e)}const u=s(l,[["render",t]]);export{h as __pageData,u as default}; + --url http://localhost:42069
    `,43),e=[o];function t(c,r,E,i,y,d){return a(),n("div",null,e)}const u=s(l,[["render",t]]);export{h as __pageData,u as default}; diff --git a/pr-1815/assets/how-to-guides_local-testnet.md.b7413a1e.lean.js b/pr-1815/assets/how-to-guides_local-testnet.md.d47ac3d0.lean.js similarity index 81% rename from pr-1815/assets/how-to-guides_local-testnet.md.b7413a1e.lean.js rename to pr-1815/assets/how-to-guides_local-testnet.md.d47ac3d0.lean.js index a60f2eec8..f3eed3a81 100644 --- a/pr-1815/assets/how-to-guides_local-testnet.md.b7413a1e.lean.js +++ b/pr-1815/assets/how-to-guides_local-testnet.md.d47ac3d0.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up a Celestia local testnet","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Setting up a Celestia local testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/local-testnet.md","filePath":"how-to-guides/local-testnet.md","lastUpdated":1732776394000}'),l={name:"how-to-guides/local-testnet.md"},o=p("",38),e=[o];function t(c,r,E,i,y,d){return a(),n("div",null,e)}const u=s(l,[["render",t]]);export{h as __pageData,u as default}; +import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up a Celestia local testnet","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Setting up a Celestia local testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/local-testnet.md","filePath":"how-to-guides/local-testnet.md","lastUpdated":1732777479000}'),l={name:"how-to-guides/local-testnet.md"},o=p("",43),e=[o];function t(c,r,E,i,y,d){return a(),n("div",null,e)}const u=s(l,[["render",t]]);export{h as __pageData,u as default}; diff --git a/pr-1815/assets/how-to-guides_mainnet.md.1539ba72.js b/pr-1815/assets/how-to-guides_mainnet.md.8c474549.js similarity index 99% rename from pr-1815/assets/how-to-guides_mainnet.md.1539ba72.js rename to pr-1815/assets/how-to-guides_mainnet.md.8c474549.js index c399a55f3..c2405616e 100644 --- a/pr-1815/assets/how-to-guides_mainnet.md.1539ba72.js +++ b/pr-1815/assets/how-to-guides_mainnet.md.8c474549.js @@ -1 +1 @@ -import{M as p}from"./chunks/MainnetVersionTags.45ab5901.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as m,o as s,c as r,k as e,t as o,C as i,H as a,w as c,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mainnet_versions.f2c187e6.js";const f="/docs-preview/pr-1815/img/Mainnet-Beta.png",y="/docs-preview/pr-1815/grove/grove-sandbox.png",b={name:"MainnetBetaDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),H=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"6BE39EFD10BA412A9DB5288488303F5DD32CF386707A5BEF33617F4C43301872")])],-1),V=e("td",null,"Genesis file",-1),w=["href"],L=e("td",null,"Peers file",-1),v=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function M(d,T,Q,l,t,R){return s(),r("table",null,[g,e("tr",null,[H,e("td",null,[e("code",null,o(t.constants.mainnetChainId),1)])]),k,e("tr",null,[V,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/genesis.json ",9,w)])]),e("tr",null,[L,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/peers.txt ",9,v)])]),_])}const x=m(b,[["render",M]]),C=n('

    Mainnet Beta

    Mainnet Beta

    Welcome to the guide for Celestia’s Mainnet Beta, the production network that marks the pinnacle of Celestia’s evolution since its inception in 2019. This network is where all components of the Celestia ecosystem come to life in a real-world environment.

    Mainnet Beta is the culmination of rigorous community testing, upgrades, and feedback. It serves as the platform for deploying Mainnet Beta rollups and applications.

    Network stability and upgrades

    Mainnet Beta is a stable network, but will still receive updates and improvements. Any changes or upgrades will be coordinated with node operators and the broader Celestia community to ensure seamless integration and minimal service interruptions.

    As we step into unexplored territories with groundbreaking technologies like data availability sampling, it's crucial to remember that Mainnet Beta remains experimental at this stage. While the network is live and functional, users may encounter occasional instability or reduced performance.

    Network details

    ',8),Z=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n('

    Network parameters

    Full network parameters, such as max bytes, can be found in the celestia-app specifications.

    CIP-13 has been drafted to create a living document for these parameters as a part of the CIP process.

    Maximum bytes

    There is a hard limit on the total blob size in a transaction, which is determined by the effective maximum square size. Given that the current governance maximum square size is 64, the total blob size in a transaction must be slightly less than ~2 MiB, or 1,973,786 bytes to be exact.

    The following provides an approximation of the maximum block size:

    • The maximum square size is 64x64, which gives us 4096 shares.
    • One share is reserved for the PFB transaction, leaving us with 4095 shares.
    • The first sparse share has 478 bytes available, and the remaining sparse shares have 482 bytes each.

    This can be calculated as follows:

    ',8),E={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"68.588ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 30315.8 1000","aria-hidden":"true"},q=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mtext"},[e("path",{"data-c":"54",d:"M36 443Q37 448 46 558T55 671V677H666V671Q667 666 676 556T685 443V437H645V443Q645 445 642 478T631 544T610 593Q593 614 555 625Q534 630 478 630H451H443Q417 630 414 618Q413 616 413 339V63Q420 53 439 50T528 46H558V0H545L361 3Q186 1 177 0H164V46H194Q264 46 283 49T309 63V339V550Q309 620 304 625T271 630H244H224Q154 630 119 601Q101 585 93 554T81 486T76 443V437H36V443Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"6F",d:"M28 214Q28 309 93 378T250 448Q340 448 405 380T471 215Q471 120 407 55T250 -10Q153 -10 91 57T28 214ZM250 30Q372 30 372 193V225V250Q372 272 371 288T364 326T348 362T317 390T268 410Q263 411 252 411Q222 411 195 399Q152 377 139 338T126 246V226Q126 130 145 91Q177 30 250 30Z",transform:"translate(722,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1222,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"61",d:"M137 305T115 305T78 320T63 359Q63 394 97 421T218 448Q291 448 336 416T396 340Q401 326 401 309T402 194V124Q402 76 407 58T428 40Q443 40 448 56T453 109V145H493V106Q492 66 490 59Q481 29 455 12T400 -6T353 12T329 54V58L327 55Q325 52 322 49T314 40T302 29T287 17T269 6T247 -2T221 -8T190 -11Q130 -11 82 20T34 107Q34 128 41 147T68 188T116 225T194 253T304 268H318V290Q318 324 312 340Q290 411 215 411Q197 411 181 410T156 406T148 403Q170 388 170 359Q170 334 154 320ZM126 106Q126 75 150 51T209 26Q247 26 276 49T315 109Q317 116 318 175Q318 233 317 233Q309 233 296 232T251 223T193 203T147 166T126 106Z",transform:"translate(1611,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"6C",d:"M42 46H56Q95 46 103 60V68Q103 77 103 91T103 124T104 167T104 217T104 272T104 329Q104 366 104 407T104 482T104 542T103 586T103 603Q100 622 89 628T44 637H26V660Q26 683 28 683L38 684Q48 685 67 686T104 688Q121 689 141 690T171 693T182 694H185V379Q185 62 186 60Q190 52 198 49Q219 46 247 46H263V0H255L232 1Q209 2 183 2T145 3T107 3T57 1L34 0H26V46H42Z",transform:"translate(2111,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"20",d:"",transform:"translate(2389,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"42",d:"M131 622Q124 629 120 631T104 634T61 637H28V683H229H267H346Q423 683 459 678T531 651Q574 627 599 590T624 512Q624 461 583 419T476 360L466 357Q539 348 595 302T651 187Q651 119 600 67T469 3Q456 1 242 0H28V46H61Q103 47 112 49T131 61V622ZM511 513Q511 560 485 594T416 636Q415 636 403 636T371 636T333 637Q266 637 251 636T232 628Q229 624 229 499V374H312L396 375L406 377Q410 378 417 380T442 393T474 417T499 456T511 513ZM537 188Q537 239 509 282T430 336L329 337H229V200V116Q229 57 234 52Q240 47 334 47H383Q425 47 443 53Q486 67 511 104T537 188Z",transform:"translate(2639,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(3347,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(3875,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(4264,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(4708,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(5379.8,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(6435.6,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(6824.6,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(7546.8,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(8547,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(10047,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(10214,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(12525,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(13136.2,0)"},[e("path",{"data-c":"2B",d:"M56 237T56 250T70 270H369V420L370 570Q380 583 389 583Q402 583 409 568V270H707Q722 262 722 250T707 230H409V-68Q401 -82 391 -82H389H387Q375 -82 369 -68V230H70Q56 237 56 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(14136.4,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(14525.4,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"30",d:"M96 585Q152 666 249 666Q297 666 345 640T423 548Q460 465 460 320Q460 165 417 83Q397 41 362 16T301 -15T250 -22Q224 -22 198 -16T137 16T82 83Q39 165 39 320Q39 494 96 585ZM321 597Q291 629 250 629Q208 629 178 597Q153 571 145 525T137 333Q137 175 145 125T181 46Q209 16 250 16Q290 16 318 46Q347 76 354 130T362 333Q362 478 354 524T321 597Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",transform:"translate(1500,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(16747.7,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(17747.9,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"32",d:"M109 429Q82 429 66 447T50 491Q50 562 103 614T235 666Q326 666 387 610T449 465Q449 422 429 383T381 315T301 241Q265 210 201 149L142 93L218 92Q375 92 385 97Q392 99 409 186V189H449V186Q448 183 436 95T421 3V0H50V19V31Q50 38 56 46T86 81Q115 113 136 137Q145 147 170 174T204 211T233 244T261 278T284 308T305 340T320 369T333 401T340 431T343 464Q343 527 309 573T212 619Q179 619 154 602T119 569T109 550Q109 549 114 549Q132 549 151 535T170 489Q170 464 154 447T109 429Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(19247.9,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(19414.9,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(21725.9,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(22392.7,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(23448.4,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(23948.4,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(24393.1,0)"},[e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"33",d:"M127 463Q100 463 85 480T69 524Q69 579 117 622T233 665Q268 665 277 664Q351 652 390 611T430 522Q430 470 396 421T302 350L299 348Q299 347 308 345T337 336T375 315Q457 262 457 175Q457 96 395 37T238 -22Q158 -22 100 21T42 130Q42 158 60 175T105 193Q133 193 151 175T169 130Q169 119 166 110T159 94T148 82T136 74T126 70T118 67L114 66Q165 21 238 21Q293 21 321 74Q338 107 338 175V195Q338 290 274 322Q259 328 213 329L171 330L168 332Q166 335 166 348Q166 366 174 366Q202 366 232 371Q266 376 294 413T322 525V533Q322 590 287 612Q265 626 240 626Q208 626 181 615T143 592T132 580H135Q138 579 143 578T153 573T165 566T175 555T183 540T186 520Q186 498 172 481T127 463Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(25893.1,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(26337.8,0)"},[e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"36",d:"M42 313Q42 476 123 571T303 666Q372 666 402 630T432 550Q432 525 418 510T379 495Q356 495 341 509T326 548Q326 592 373 601Q351 623 311 626Q240 626 194 566Q147 500 147 364L148 360Q153 366 156 373Q197 433 263 433H267Q313 433 348 414Q372 400 396 374T435 317Q456 268 456 210V192Q456 169 451 149Q440 90 387 34T253 -22Q225 -22 199 -14T143 16T92 75T56 172T42 313ZM257 397Q227 397 205 380T171 335T154 278T148 216Q148 133 160 97T198 39Q222 21 251 21Q302 21 329 59Q342 77 347 104T352 209Q352 289 347 316T329 361Q302 397 257 397Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(27837.8,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(28004.8,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})])])],-1),D=[q],A=e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mtext",null,"Total Bytes"),e("mo",null,"="),e("mo",{stretchy:"false"},"("),e("mn",null,"1"),e("mo",null,"×"),e("mn",null,"478"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"+"),e("mo",{stretchy:"false"},"("),e("mn",null,"4094"),e("mo",null,"×"),e("mn",null,"482"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"="),e("mn",null,"1"),e("mo",null,","),e("mn",null,"973"),e("mo",null,","),e("mn",null,"786"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes")],-1),B=n('

    Please note that there isn't a precise upper bound on the maximum total blob size. It depends on several factors:

    • The maximum square size, which is determined by a governance parameter and a versioned constant.
    • The maximum bytes in a block, which is determined by a governance parameter and a hard-coded constant in CometBFT.
    • The number of shares occupied by the PFB transaction share.

    These factors can cause the maximum total blob size that can be included in one block to vary.

    See the code in celestia-app and celestia-node.

    Integrations

    This guide contains the relevant sections for how to connect to Mainnet Beta, depending on the type of node you are running. Your best approach to participating is to first determine which node you would like to run. Each node’s guide will link to the relevant network in order to show you how to connect to them. Learn about the different endpoint types in the Cosmos SDK documentation.

    Here is a list of options of the types of nodes you can run in order to participate in Mainnet Beta:

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Consensus nodes

    Community consensus RPC endpoints

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs.

    • public-celestia-rpc.numia.xyz
    • rpc.celestia.pops.one
    • rpc.lunaroasis.net
    • rpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com
    • celestia.rpc.stakin-nodes.com
    • celestia.cumulo.org.es
    • rpc.archive.celestia.cumulo.com.es
    • rpc-celestia-01.stakeflow.io
    • rpc-celestia.alphab.ai
    • rpc-celestia-full.avril14th.org
    • celestia-rpc.easy2stake.com
    • celestia.rpc.kjnodes.com
    • celestia-rpc.0xcryptovestor.com
    • rpc-celestia-mainnet.trusted-point.com
    • celestia-rpc.chainode.tech:33373
    • celestia-mainnet-rpc.itrocket.net:443

    Community API endpoints

    • public-celestia-lcd.numia.xyz
    • celestia-rest.mesa.newmetric.xyz
    • api.celestia.pops.one
    • api.lunaroasis.net
    • api.celestia.nodestake.top
    • celestia-rpc.brightlystake.com/api
    • celestia.rest.stakin-nodes.com
    • celestia.api.cumulo.org.es
    • api.archive.celestia.cumulo.com.es
    • api-celestia.mzonder.com
    • api-celestia-01.stakeflow.io
    • api-celestia.alphab.ai
    • api-celestia-full.avril14th.org
    • celestia-lcd.easy2stake.com
    • celestia.api.kjnodes.com
    • api-celestia-mainnet.trusted-point.com
    • celestia-api.chainode.tech
    • celestia-mainnet-api.itrocket.net:443

    Community gRPC endpoints

    • public-celestia-grpc.numia.xyz
    • celestia-grpc.mesa.newmetric.xyz
    • grpc.celestia.pops.one
    • grpc.lunaroasis.net:443
    • grpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com:9090
    • celestia.grpc.stakin-nodes.com:443
    • celestia.grpc.cumulo.org.es:443
    • grpc.archive.celestia.cumulo.com.es:443
    • grpc-celestia-01.stakeflow.io:15002
    • rpc-celestia.alphab.ai:9090
    • grpc-celestia-full.avril14th.org
    • celestia.grpc.kjnodes.com:443
    • grpc-celestia-mainnet.trusted-point.com:9095
    • celestia-grpc.chainode.tech:443
    • celestia-mainnet-grpc.itrocket.net:443

    Community WebSocket endpoints

    • wss://celestia-ws.chainode.tech:33373/websocket
    • wss://celestia-mainnet-ws.itrocket.net:443/websocket
    • wss://celestia.cumulo.org.es:443/websocket
    • wss://rpc.archive.celestia.cumulo.com.es:443/websocket

    Data availability nodes

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    TIP

    bash
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>

    Bridge nodes

    Not all RPC endpoints guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

    RPCs for DA nodes to initialise or start your celestia-node to Mainnet Beta with:

    • public-celestia-consensus.numia.xyz
      • gRPC: port 9090
      • RPC: port 26657
    • rpc.celestia.pops.one
      • gRPC: port 9090
      • RPC: port 26657
    • consensus.lunaroasis.net
      • gRPC: port 9090
      • RPC: port 26657
    • rpc-celestia.alphab.ai
      • gRPC: port 9090
      • RPC: port 26657
    • celestia-mainnet-consensus.itrocket.net
      • gRPC: port 9090
      • RPC: port 26657

    DA full and light nodes might have troubles connecting to the networks, so you can check out this Grafana dashboard to see health/uptime status of DA bootstrappers (now celestia network only).

    You can find the status of these endpoints.

    Archival DA RPC endpoints

    By default, light nodes prune recent data to save on storage space. Archival data availability (DA) nodes store the entire history of the chain without pruning any data so all data available data is retrievable. You can read more about light vs archival nodes.

    Grove archival endpoints

    You can provision your own Celestia Archival endpoint on Grove. Learn more about Celestia on Grove, or find the fully supported spec.

    There is a sandbox you can leverage for testing straight in your browser:

    grove-sandbox

    Explorers

    There are multiple explorers you can use for Mainnet Beta:

    Analytics

    The following websites provide analytics for Celestia:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mainnet Beta:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    ',50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Mainnet Beta | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/mainnet.md","filePath":"how-to-guides/mainnet.md","lastUpdated":1732776394000}'),F={name:"how-to-guides/mainnet.md"},G=Object.assign(F,{setup(d){return(T,Q)=>{const l=i("mjx-assistive-mml"),t=i("mjx-container");return s(),r("div",null,[C,a(x),Z,a(p),P,e("p",null,[a(t,{class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},{default:c(()=>[(s(),r("svg",E,D)),a(l,{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},{default:c(()=>[A]),_:1})]),_:1})]),B])}}});export{j as __pageData,G as default}; +import{M as p}from"./chunks/MainnetVersionTags.45ab5901.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as m,o as s,c as r,k as e,t as o,C as i,H as a,w as c,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mainnet_versions.f2c187e6.js";const f="/docs-preview/pr-1815/img/Mainnet-Beta.png",y="/docs-preview/pr-1815/grove/grove-sandbox.png",b={name:"MainnetBetaDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),H=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"6BE39EFD10BA412A9DB5288488303F5DD32CF386707A5BEF33617F4C43301872")])],-1),V=e("td",null,"Genesis file",-1),w=["href"],L=e("td",null,"Peers file",-1),v=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function M(d,T,Q,l,t,R){return s(),r("table",null,[g,e("tr",null,[H,e("td",null,[e("code",null,o(t.constants.mainnetChainId),1)])]),k,e("tr",null,[V,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/genesis.json ",9,w)])]),e("tr",null,[L,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/peers.txt ",9,v)])]),_])}const x=m(b,[["render",M]]),C=n('

    Mainnet Beta

    Mainnet Beta

    Welcome to the guide for Celestia’s Mainnet Beta, the production network that marks the pinnacle of Celestia’s evolution since its inception in 2019. This network is where all components of the Celestia ecosystem come to life in a real-world environment.

    Mainnet Beta is the culmination of rigorous community testing, upgrades, and feedback. It serves as the platform for deploying Mainnet Beta rollups and applications.

    Network stability and upgrades

    Mainnet Beta is a stable network, but will still receive updates and improvements. Any changes or upgrades will be coordinated with node operators and the broader Celestia community to ensure seamless integration and minimal service interruptions.

    As we step into unexplored territories with groundbreaking technologies like data availability sampling, it's crucial to remember that Mainnet Beta remains experimental at this stage. While the network is live and functional, users may encounter occasional instability or reduced performance.

    Network details

    ',8),Z=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n('

    Network parameters

    Full network parameters, such as max bytes, can be found in the celestia-app specifications.

    CIP-13 has been drafted to create a living document for these parameters as a part of the CIP process.

    Maximum bytes

    There is a hard limit on the total blob size in a transaction, which is determined by the effective maximum square size. Given that the current governance maximum square size is 64, the total blob size in a transaction must be slightly less than ~2 MiB, or 1,973,786 bytes to be exact.

    The following provides an approximation of the maximum block size:

    • The maximum square size is 64x64, which gives us 4096 shares.
    • One share is reserved for the PFB transaction, leaving us with 4095 shares.
    • The first sparse share has 478 bytes available, and the remaining sparse shares have 482 bytes each.

    This can be calculated as follows:

    ',8),E={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"68.588ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 30315.8 1000","aria-hidden":"true"},q=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mtext"},[e("path",{"data-c":"54",d:"M36 443Q37 448 46 558T55 671V677H666V671Q667 666 676 556T685 443V437H645V443Q645 445 642 478T631 544T610 593Q593 614 555 625Q534 630 478 630H451H443Q417 630 414 618Q413 616 413 339V63Q420 53 439 50T528 46H558V0H545L361 3Q186 1 177 0H164V46H194Q264 46 283 49T309 63V339V550Q309 620 304 625T271 630H244H224Q154 630 119 601Q101 585 93 554T81 486T76 443V437H36V443Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"6F",d:"M28 214Q28 309 93 378T250 448Q340 448 405 380T471 215Q471 120 407 55T250 -10Q153 -10 91 57T28 214ZM250 30Q372 30 372 193V225V250Q372 272 371 288T364 326T348 362T317 390T268 410Q263 411 252 411Q222 411 195 399Q152 377 139 338T126 246V226Q126 130 145 91Q177 30 250 30Z",transform:"translate(722,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1222,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"61",d:"M137 305T115 305T78 320T63 359Q63 394 97 421T218 448Q291 448 336 416T396 340Q401 326 401 309T402 194V124Q402 76 407 58T428 40Q443 40 448 56T453 109V145H493V106Q492 66 490 59Q481 29 455 12T400 -6T353 12T329 54V58L327 55Q325 52 322 49T314 40T302 29T287 17T269 6T247 -2T221 -8T190 -11Q130 -11 82 20T34 107Q34 128 41 147T68 188T116 225T194 253T304 268H318V290Q318 324 312 340Q290 411 215 411Q197 411 181 410T156 406T148 403Q170 388 170 359Q170 334 154 320ZM126 106Q126 75 150 51T209 26Q247 26 276 49T315 109Q317 116 318 175Q318 233 317 233Q309 233 296 232T251 223T193 203T147 166T126 106Z",transform:"translate(1611,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"6C",d:"M42 46H56Q95 46 103 60V68Q103 77 103 91T103 124T104 167T104 217T104 272T104 329Q104 366 104 407T104 482T104 542T103 586T103 603Q100 622 89 628T44 637H26V660Q26 683 28 683L38 684Q48 685 67 686T104 688Q121 689 141 690T171 693T182 694H185V379Q185 62 186 60Q190 52 198 49Q219 46 247 46H263V0H255L232 1Q209 2 183 2T145 3T107 3T57 1L34 0H26V46H42Z",transform:"translate(2111,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"20",d:"",transform:"translate(2389,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"42",d:"M131 622Q124 629 120 631T104 634T61 637H28V683H229H267H346Q423 683 459 678T531 651Q574 627 599 590T624 512Q624 461 583 419T476 360L466 357Q539 348 595 302T651 187Q651 119 600 67T469 3Q456 1 242 0H28V46H61Q103 47 112 49T131 61V622ZM511 513Q511 560 485 594T416 636Q415 636 403 636T371 636T333 637Q266 637 251 636T232 628Q229 624 229 499V374H312L396 375L406 377Q410 378 417 380T442 393T474 417T499 456T511 513ZM537 188Q537 239 509 282T430 336L329 337H229V200V116Q229 57 234 52Q240 47 334 47H383Q425 47 443 53Q486 67 511 104T537 188Z",transform:"translate(2639,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(3347,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(3875,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(4264,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(4708,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(5379.8,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(6435.6,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(6824.6,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(7546.8,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(8547,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(10047,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(10214,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(12525,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(13136.2,0)"},[e("path",{"data-c":"2B",d:"M56 237T56 250T70 270H369V420L370 570Q380 583 389 583Q402 583 409 568V270H707Q722 262 722 250T707 230H409V-68Q401 -82 391 -82H389H387Q375 -82 369 -68V230H70Q56 237 56 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(14136.4,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(14525.4,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"30",d:"M96 585Q152 666 249 666Q297 666 345 640T423 548Q460 465 460 320Q460 165 417 83Q397 41 362 16T301 -15T250 -22Q224 -22 198 -16T137 16T82 83Q39 165 39 320Q39 494 96 585ZM321 597Q291 629 250 629Q208 629 178 597Q153 571 145 525T137 333Q137 175 145 125T181 46Q209 16 250 16Q290 16 318 46Q347 76 354 130T362 333Q362 478 354 524T321 597Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",transform:"translate(1500,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(16747.7,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(17747.9,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"32",d:"M109 429Q82 429 66 447T50 491Q50 562 103 614T235 666Q326 666 387 610T449 465Q449 422 429 383T381 315T301 241Q265 210 201 149L142 93L218 92Q375 92 385 97Q392 99 409 186V189H449V186Q448 183 436 95T421 3V0H50V19V31Q50 38 56 46T86 81Q115 113 136 137Q145 147 170 174T204 211T233 244T261 278T284 308T305 340T320 369T333 401T340 431T343 464Q343 527 309 573T212 619Q179 619 154 602T119 569T109 550Q109 549 114 549Q132 549 151 535T170 489Q170 464 154 447T109 429Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(19247.9,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(19414.9,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(21725.9,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(22392.7,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(23448.4,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(23948.4,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(24393.1,0)"},[e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"33",d:"M127 463Q100 463 85 480T69 524Q69 579 117 622T233 665Q268 665 277 664Q351 652 390 611T430 522Q430 470 396 421T302 350L299 348Q299 347 308 345T337 336T375 315Q457 262 457 175Q457 96 395 37T238 -22Q158 -22 100 21T42 130Q42 158 60 175T105 193Q133 193 151 175T169 130Q169 119 166 110T159 94T148 82T136 74T126 70T118 67L114 66Q165 21 238 21Q293 21 321 74Q338 107 338 175V195Q338 290 274 322Q259 328 213 329L171 330L168 332Q166 335 166 348Q166 366 174 366Q202 366 232 371Q266 376 294 413T322 525V533Q322 590 287 612Q265 626 240 626Q208 626 181 615T143 592T132 580H135Q138 579 143 578T153 573T165 566T175 555T183 540T186 520Q186 498 172 481T127 463Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(25893.1,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(26337.8,0)"},[e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"36",d:"M42 313Q42 476 123 571T303 666Q372 666 402 630T432 550Q432 525 418 510T379 495Q356 495 341 509T326 548Q326 592 373 601Q351 623 311 626Q240 626 194 566Q147 500 147 364L148 360Q153 366 156 373Q197 433 263 433H267Q313 433 348 414Q372 400 396 374T435 317Q456 268 456 210V192Q456 169 451 149Q440 90 387 34T253 -22Q225 -22 199 -14T143 16T92 75T56 172T42 313ZM257 397Q227 397 205 380T171 335T154 278T148 216Q148 133 160 97T198 39Q222 21 251 21Q302 21 329 59Q342 77 347 104T352 209Q352 289 347 316T329 361Q302 397 257 397Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(27837.8,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(28004.8,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})])])],-1),D=[q],A=e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mtext",null,"Total Bytes"),e("mo",null,"="),e("mo",{stretchy:"false"},"("),e("mn",null,"1"),e("mo",null,"×"),e("mn",null,"478"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"+"),e("mo",{stretchy:"false"},"("),e("mn",null,"4094"),e("mo",null,"×"),e("mn",null,"482"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"="),e("mn",null,"1"),e("mo",null,","),e("mn",null,"973"),e("mo",null,","),e("mn",null,"786"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes")],-1),B=n('

    Please note that there isn't a precise upper bound on the maximum total blob size. It depends on several factors:

    • The maximum square size, which is determined by a governance parameter and a versioned constant.
    • The maximum bytes in a block, which is determined by a governance parameter and a hard-coded constant in CometBFT.
    • The number of shares occupied by the PFB transaction share.

    These factors can cause the maximum total blob size that can be included in one block to vary.

    See the code in celestia-app and celestia-node.

    Integrations

    This guide contains the relevant sections for how to connect to Mainnet Beta, depending on the type of node you are running. Your best approach to participating is to first determine which node you would like to run. Each node’s guide will link to the relevant network in order to show you how to connect to them. Learn about the different endpoint types in the Cosmos SDK documentation.

    Here is a list of options of the types of nodes you can run in order to participate in Mainnet Beta:

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Consensus nodes

    Community consensus RPC endpoints

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs.

    • public-celestia-rpc.numia.xyz
    • rpc.celestia.pops.one
    • rpc.lunaroasis.net
    • rpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com
    • celestia.rpc.stakin-nodes.com
    • celestia.cumulo.org.es
    • rpc.archive.celestia.cumulo.com.es
    • rpc-celestia-01.stakeflow.io
    • rpc-celestia.alphab.ai
    • rpc-celestia-full.avril14th.org
    • celestia-rpc.easy2stake.com
    • celestia.rpc.kjnodes.com
    • celestia-rpc.0xcryptovestor.com
    • rpc-celestia-mainnet.trusted-point.com
    • celestia-rpc.chainode.tech:33373
    • celestia-mainnet-rpc.itrocket.net:443

    Community API endpoints

    • public-celestia-lcd.numia.xyz
    • celestia-rest.mesa.newmetric.xyz
    • api.celestia.pops.one
    • api.lunaroasis.net
    • api.celestia.nodestake.top
    • celestia-rpc.brightlystake.com/api
    • celestia.rest.stakin-nodes.com
    • celestia.api.cumulo.org.es
    • api.archive.celestia.cumulo.com.es
    • api-celestia.mzonder.com
    • api-celestia-01.stakeflow.io
    • api-celestia.alphab.ai
    • api-celestia-full.avril14th.org
    • celestia-lcd.easy2stake.com
    • celestia.api.kjnodes.com
    • api-celestia-mainnet.trusted-point.com
    • celestia-api.chainode.tech
    • celestia-mainnet-api.itrocket.net:443

    Community gRPC endpoints

    • public-celestia-grpc.numia.xyz
    • celestia-grpc.mesa.newmetric.xyz
    • grpc.celestia.pops.one
    • grpc.lunaroasis.net:443
    • grpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com:9090
    • celestia.grpc.stakin-nodes.com:443
    • celestia.grpc.cumulo.org.es:443
    • grpc.archive.celestia.cumulo.com.es:443
    • grpc-celestia-01.stakeflow.io:15002
    • rpc-celestia.alphab.ai:9090
    • grpc-celestia-full.avril14th.org
    • celestia.grpc.kjnodes.com:443
    • grpc-celestia-mainnet.trusted-point.com:9095
    • celestia-grpc.chainode.tech:443
    • celestia-mainnet-grpc.itrocket.net:443

    Community WebSocket endpoints

    • wss://celestia-ws.chainode.tech:33373/websocket
    • wss://celestia-mainnet-ws.itrocket.net:443/websocket
    • wss://celestia.cumulo.org.es:443/websocket
    • wss://rpc.archive.celestia.cumulo.com.es:443/websocket

    Data availability nodes

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    TIP

    bash
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>

    Bridge nodes

    Not all RPC endpoints guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

    RPCs for DA nodes to initialise or start your celestia-node to Mainnet Beta with:

    • public-celestia-consensus.numia.xyz
      • gRPC: port 9090
      • RPC: port 26657
    • rpc.celestia.pops.one
      • gRPC: port 9090
      • RPC: port 26657
    • consensus.lunaroasis.net
      • gRPC: port 9090
      • RPC: port 26657
    • rpc-celestia.alphab.ai
      • gRPC: port 9090
      • RPC: port 26657
    • celestia-mainnet-consensus.itrocket.net
      • gRPC: port 9090
      • RPC: port 26657

    DA full and light nodes might have troubles connecting to the networks, so you can check out this Grafana dashboard to see health/uptime status of DA bootstrappers (now celestia network only).

    You can find the status of these endpoints.

    Archival DA RPC endpoints

    By default, light nodes prune recent data to save on storage space. Archival data availability (DA) nodes store the entire history of the chain without pruning any data so all data available data is retrievable. You can read more about light vs archival nodes.

    Grove archival endpoints

    You can provision your own Celestia Archival endpoint on Grove. Learn more about Celestia on Grove, or find the fully supported spec.

    There is a sandbox you can leverage for testing straight in your browser:

    grove-sandbox

    Explorers

    There are multiple explorers you can use for Mainnet Beta:

    Analytics

    The following websites provide analytics for Celestia:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mainnet Beta:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    ',50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Mainnet Beta | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/mainnet.md","filePath":"how-to-guides/mainnet.md","lastUpdated":1732777479000}'),F={name:"how-to-guides/mainnet.md"},G=Object.assign(F,{setup(d){return(T,Q)=>{const l=i("mjx-assistive-mml"),t=i("mjx-container");return s(),r("div",null,[C,a(x),Z,a(p),P,e("p",null,[a(t,{class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},{default:c(()=>[(s(),r("svg",E,D)),a(l,{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},{default:c(()=>[A]),_:1})]),_:1})]),B])}}});export{j as __pageData,G as default}; diff --git a/pr-1815/assets/how-to-guides_mainnet.md.1539ba72.lean.js b/pr-1815/assets/how-to-guides_mainnet.md.8c474549.lean.js similarity index 99% rename from pr-1815/assets/how-to-guides_mainnet.md.1539ba72.lean.js rename to pr-1815/assets/how-to-guides_mainnet.md.8c474549.lean.js index 9ac2c64d4..bb9fda88b 100644 --- a/pr-1815/assets/how-to-guides_mainnet.md.1539ba72.lean.js +++ b/pr-1815/assets/how-to-guides_mainnet.md.8c474549.lean.js @@ -1 +1 @@ -import{M as p}from"./chunks/MainnetVersionTags.45ab5901.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as m,o as s,c as r,k as e,t as o,C as i,H as a,w as c,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mainnet_versions.f2c187e6.js";const f="/docs-preview/pr-1815/img/Mainnet-Beta.png",y="/docs-preview/pr-1815/grove/grove-sandbox.png",b={name:"MainnetBetaDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),H=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"6BE39EFD10BA412A9DB5288488303F5DD32CF386707A5BEF33617F4C43301872")])],-1),V=e("td",null,"Genesis file",-1),w=["href"],L=e("td",null,"Peers file",-1),v=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function M(d,T,Q,l,t,R){return s(),r("table",null,[g,e("tr",null,[H,e("td",null,[e("code",null,o(t.constants.mainnetChainId),1)])]),k,e("tr",null,[V,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/genesis.json ",9,w)])]),e("tr",null,[L,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/peers.txt ",9,v)])]),_])}const x=m(b,[["render",M]]),C=n("",8),Z=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n("",8),E={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"68.588ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 30315.8 1000","aria-hidden":"true"},q=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mtext"},[e("path",{"data-c":"54",d:"M36 443Q37 448 46 558T55 671V677H666V671Q667 666 676 556T685 443V437H645V443Q645 445 642 478T631 544T610 593Q593 614 555 625Q534 630 478 630H451H443Q417 630 414 618Q413 616 413 339V63Q420 53 439 50T528 46H558V0H545L361 3Q186 1 177 0H164V46H194Q264 46 283 49T309 63V339V550Q309 620 304 625T271 630H244H224Q154 630 119 601Q101 585 93 554T81 486T76 443V437H36V443Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"6F",d:"M28 214Q28 309 93 378T250 448Q340 448 405 380T471 215Q471 120 407 55T250 -10Q153 -10 91 57T28 214ZM250 30Q372 30 372 193V225V250Q372 272 371 288T364 326T348 362T317 390T268 410Q263 411 252 411Q222 411 195 399Q152 377 139 338T126 246V226Q126 130 145 91Q177 30 250 30Z",transform:"translate(722,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1222,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"61",d:"M137 305T115 305T78 320T63 359Q63 394 97 421T218 448Q291 448 336 416T396 340Q401 326 401 309T402 194V124Q402 76 407 58T428 40Q443 40 448 56T453 109V145H493V106Q492 66 490 59Q481 29 455 12T400 -6T353 12T329 54V58L327 55Q325 52 322 49T314 40T302 29T287 17T269 6T247 -2T221 -8T190 -11Q130 -11 82 20T34 107Q34 128 41 147T68 188T116 225T194 253T304 268H318V290Q318 324 312 340Q290 411 215 411Q197 411 181 410T156 406T148 403Q170 388 170 359Q170 334 154 320ZM126 106Q126 75 150 51T209 26Q247 26 276 49T315 109Q317 116 318 175Q318 233 317 233Q309 233 296 232T251 223T193 203T147 166T126 106Z",transform:"translate(1611,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"6C",d:"M42 46H56Q95 46 103 60V68Q103 77 103 91T103 124T104 167T104 217T104 272T104 329Q104 366 104 407T104 482T104 542T103 586T103 603Q100 622 89 628T44 637H26V660Q26 683 28 683L38 684Q48 685 67 686T104 688Q121 689 141 690T171 693T182 694H185V379Q185 62 186 60Q190 52 198 49Q219 46 247 46H263V0H255L232 1Q209 2 183 2T145 3T107 3T57 1L34 0H26V46H42Z",transform:"translate(2111,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"20",d:"",transform:"translate(2389,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"42",d:"M131 622Q124 629 120 631T104 634T61 637H28V683H229H267H346Q423 683 459 678T531 651Q574 627 599 590T624 512Q624 461 583 419T476 360L466 357Q539 348 595 302T651 187Q651 119 600 67T469 3Q456 1 242 0H28V46H61Q103 47 112 49T131 61V622ZM511 513Q511 560 485 594T416 636Q415 636 403 636T371 636T333 637Q266 637 251 636T232 628Q229 624 229 499V374H312L396 375L406 377Q410 378 417 380T442 393T474 417T499 456T511 513ZM537 188Q537 239 509 282T430 336L329 337H229V200V116Q229 57 234 52Q240 47 334 47H383Q425 47 443 53Q486 67 511 104T537 188Z",transform:"translate(2639,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(3347,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(3875,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(4264,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(4708,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(5379.8,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(6435.6,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(6824.6,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(7546.8,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(8547,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(10047,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(10214,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(12525,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(13136.2,0)"},[e("path",{"data-c":"2B",d:"M56 237T56 250T70 270H369V420L370 570Q380 583 389 583Q402 583 409 568V270H707Q722 262 722 250T707 230H409V-68Q401 -82 391 -82H389H387Q375 -82 369 -68V230H70Q56 237 56 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(14136.4,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(14525.4,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"30",d:"M96 585Q152 666 249 666Q297 666 345 640T423 548Q460 465 460 320Q460 165 417 83Q397 41 362 16T301 -15T250 -22Q224 -22 198 -16T137 16T82 83Q39 165 39 320Q39 494 96 585ZM321 597Q291 629 250 629Q208 629 178 597Q153 571 145 525T137 333Q137 175 145 125T181 46Q209 16 250 16Q290 16 318 46Q347 76 354 130T362 333Q362 478 354 524T321 597Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",transform:"translate(1500,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(16747.7,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(17747.9,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"32",d:"M109 429Q82 429 66 447T50 491Q50 562 103 614T235 666Q326 666 387 610T449 465Q449 422 429 383T381 315T301 241Q265 210 201 149L142 93L218 92Q375 92 385 97Q392 99 409 186V189H449V186Q448 183 436 95T421 3V0H50V19V31Q50 38 56 46T86 81Q115 113 136 137Q145 147 170 174T204 211T233 244T261 278T284 308T305 340T320 369T333 401T340 431T343 464Q343 527 309 573T212 619Q179 619 154 602T119 569T109 550Q109 549 114 549Q132 549 151 535T170 489Q170 464 154 447T109 429Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(19247.9,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(19414.9,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(21725.9,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(22392.7,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(23448.4,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(23948.4,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(24393.1,0)"},[e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"33",d:"M127 463Q100 463 85 480T69 524Q69 579 117 622T233 665Q268 665 277 664Q351 652 390 611T430 522Q430 470 396 421T302 350L299 348Q299 347 308 345T337 336T375 315Q457 262 457 175Q457 96 395 37T238 -22Q158 -22 100 21T42 130Q42 158 60 175T105 193Q133 193 151 175T169 130Q169 119 166 110T159 94T148 82T136 74T126 70T118 67L114 66Q165 21 238 21Q293 21 321 74Q338 107 338 175V195Q338 290 274 322Q259 328 213 329L171 330L168 332Q166 335 166 348Q166 366 174 366Q202 366 232 371Q266 376 294 413T322 525V533Q322 590 287 612Q265 626 240 626Q208 626 181 615T143 592T132 580H135Q138 579 143 578T153 573T165 566T175 555T183 540T186 520Q186 498 172 481T127 463Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(25893.1,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(26337.8,0)"},[e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"36",d:"M42 313Q42 476 123 571T303 666Q372 666 402 630T432 550Q432 525 418 510T379 495Q356 495 341 509T326 548Q326 592 373 601Q351 623 311 626Q240 626 194 566Q147 500 147 364L148 360Q153 366 156 373Q197 433 263 433H267Q313 433 348 414Q372 400 396 374T435 317Q456 268 456 210V192Q456 169 451 149Q440 90 387 34T253 -22Q225 -22 199 -14T143 16T92 75T56 172T42 313ZM257 397Q227 397 205 380T171 335T154 278T148 216Q148 133 160 97T198 39Q222 21 251 21Q302 21 329 59Q342 77 347 104T352 209Q352 289 347 316T329 361Q302 397 257 397Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(27837.8,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(28004.8,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})])])],-1),D=[q],A=e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mtext",null,"Total Bytes"),e("mo",null,"="),e("mo",{stretchy:"false"},"("),e("mn",null,"1"),e("mo",null,"×"),e("mn",null,"478"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"+"),e("mo",{stretchy:"false"},"("),e("mn",null,"4094"),e("mo",null,"×"),e("mn",null,"482"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"="),e("mn",null,"1"),e("mo",null,","),e("mn",null,"973"),e("mo",null,","),e("mn",null,"786"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes")],-1),B=n("",50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Mainnet Beta | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/mainnet.md","filePath":"how-to-guides/mainnet.md","lastUpdated":1732776394000}'),F={name:"how-to-guides/mainnet.md"},G=Object.assign(F,{setup(d){return(T,Q)=>{const l=i("mjx-assistive-mml"),t=i("mjx-container");return s(),r("div",null,[C,a(x),Z,a(p),P,e("p",null,[a(t,{class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},{default:c(()=>[(s(),r("svg",E,D)),a(l,{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},{default:c(()=>[A]),_:1})]),_:1})]),B])}}});export{j as __pageData,G as default}; +import{M as p}from"./chunks/MainnetVersionTags.45ab5901.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as m,o as s,c as r,k as e,t as o,C as i,H as a,w as c,Q as n,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mainnet_versions.f2c187e6.js";const f="/docs-preview/pr-1815/img/Mainnet-Beta.png",y="/docs-preview/pr-1815/grove/grove-sandbox.png",b={name:"MainnetBetaDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),H=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"6BE39EFD10BA412A9DB5288488303F5DD32CF386707A5BEF33617F4C43301872")])],-1),V=e("td",null,"Genesis file",-1),w=["href"],L=e("td",null,"Peers file",-1),v=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function M(d,T,Q,l,t,R){return s(),r("table",null,[g,e("tr",null,[H,e("td",null,[e("code",null,o(t.constants.mainnetChainId),1)])]),k,e("tr",null,[V,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/genesis.json ",9,w)])]),e("tr",null,[L,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mainnetChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mainnetChainId)+"/peers.txt ",9,v)])]),_])}const x=m(b,[["render",M]]),C=n("",8),Z=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),P=n("",8),E={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"68.588ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 30315.8 1000","aria-hidden":"true"},q=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mtext"},[e("path",{"data-c":"54",d:"M36 443Q37 448 46 558T55 671V677H666V671Q667 666 676 556T685 443V437H645V443Q645 445 642 478T631 544T610 593Q593 614 555 625Q534 630 478 630H451H443Q417 630 414 618Q413 616 413 339V63Q420 53 439 50T528 46H558V0H545L361 3Q186 1 177 0H164V46H194Q264 46 283 49T309 63V339V550Q309 620 304 625T271 630H244H224Q154 630 119 601Q101 585 93 554T81 486T76 443V437H36V443Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"6F",d:"M28 214Q28 309 93 378T250 448Q340 448 405 380T471 215Q471 120 407 55T250 -10Q153 -10 91 57T28 214ZM250 30Q372 30 372 193V225V250Q372 272 371 288T364 326T348 362T317 390T268 410Q263 411 252 411Q222 411 195 399Q152 377 139 338T126 246V226Q126 130 145 91Q177 30 250 30Z",transform:"translate(722,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1222,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"61",d:"M137 305T115 305T78 320T63 359Q63 394 97 421T218 448Q291 448 336 416T396 340Q401 326 401 309T402 194V124Q402 76 407 58T428 40Q443 40 448 56T453 109V145H493V106Q492 66 490 59Q481 29 455 12T400 -6T353 12T329 54V58L327 55Q325 52 322 49T314 40T302 29T287 17T269 6T247 -2T221 -8T190 -11Q130 -11 82 20T34 107Q34 128 41 147T68 188T116 225T194 253T304 268H318V290Q318 324 312 340Q290 411 215 411Q197 411 181 410T156 406T148 403Q170 388 170 359Q170 334 154 320ZM126 106Q126 75 150 51T209 26Q247 26 276 49T315 109Q317 116 318 175Q318 233 317 233Q309 233 296 232T251 223T193 203T147 166T126 106Z",transform:"translate(1611,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"6C",d:"M42 46H56Q95 46 103 60V68Q103 77 103 91T103 124T104 167T104 217T104 272T104 329Q104 366 104 407T104 482T104 542T103 586T103 603Q100 622 89 628T44 637H26V660Q26 683 28 683L38 684Q48 685 67 686T104 688Q121 689 141 690T171 693T182 694H185V379Q185 62 186 60Q190 52 198 49Q219 46 247 46H263V0H255L232 1Q209 2 183 2T145 3T107 3T57 1L34 0H26V46H42Z",transform:"translate(2111,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"20",d:"",transform:"translate(2389,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"42",d:"M131 622Q124 629 120 631T104 634T61 637H28V683H229H267H346Q423 683 459 678T531 651Q574 627 599 590T624 512Q624 461 583 419T476 360L466 357Q539 348 595 302T651 187Q651 119 600 67T469 3Q456 1 242 0H28V46H61Q103 47 112 49T131 61V622ZM511 513Q511 560 485 594T416 636Q415 636 403 636T371 636T333 637Q266 637 251 636T232 628Q229 624 229 499V374H312L396 375L406 377Q410 378 417 380T442 393T474 417T499 456T511 513ZM537 188Q537 239 509 282T430 336L329 337H229V200V116Q229 57 234 52Q240 47 334 47H383Q425 47 443 53Q486 67 511 104T537 188Z",transform:"translate(2639,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(3347,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(3875,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(4264,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(4708,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(5379.8,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(6435.6,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(6824.6,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(7546.8,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(8547,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(10047,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(10214,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(12525,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(13136.2,0)"},[e("path",{"data-c":"2B",d:"M56 237T56 250T70 270H369V420L370 570Q380 583 389 583Q402 583 409 568V270H707Q722 262 722 250T707 230H409V-68Q401 -82 391 -82H389H387Q375 -82 369 -68V230H70Q56 237 56 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(14136.4,0)"},[e("path",{"data-c":"28",d:"M94 250Q94 319 104 381T127 488T164 576T202 643T244 695T277 729T302 750H315H319Q333 750 333 741Q333 738 316 720T275 667T226 581T184 443T167 250T184 58T225 -81T274 -167T316 -220T333 -241Q333 -250 318 -250H315H302L274 -226Q180 -141 137 -14T94 250Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(14525.4,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"30",d:"M96 585Q152 666 249 666Q297 666 345 640T423 548Q460 465 460 320Q460 165 417 83Q397 41 362 16T301 -15T250 -22Q224 -22 198 -16T137 16T82 83Q39 165 39 320Q39 494 96 585ZM321 597Q291 629 250 629Q208 629 178 597Q153 571 145 525T137 333Q137 175 145 125T181 46Q209 16 250 16Q290 16 318 46Q347 76 354 130T362 333Q362 478 354 524T321 597Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",transform:"translate(1500,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(16747.7,0)"},[e("path",{"data-c":"D7",d:"M630 29Q630 9 609 9Q604 9 587 25T493 118L389 222L284 117Q178 13 175 11Q171 9 168 9Q160 9 154 15T147 29Q147 36 161 51T255 146L359 250L255 354Q174 435 161 449T147 471Q147 480 153 485T168 490Q173 490 175 489Q178 487 284 383L389 278L493 382Q570 459 587 475T609 491Q630 491 630 471Q630 464 620 453T522 355L418 250L522 145Q606 61 618 48T630 29Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(17747.9,0)"},[e("path",{"data-c":"34",d:"M462 0Q444 3 333 3Q217 3 199 0H190V46H221Q241 46 248 46T265 48T279 53T286 61Q287 63 287 115V165H28V211L179 442Q332 674 334 675Q336 677 355 677H373L379 671V211H471V165H379V114Q379 73 379 66T385 54Q393 47 442 46H471V0H462ZM293 211V545L74 212L183 211H293Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"32",d:"M109 429Q82 429 66 447T50 491Q50 562 103 614T235 666Q326 666 387 610T449 465Q449 422 429 383T381 315T301 241Q265 210 201 149L142 93L218 92Q375 92 385 97Q392 99 409 186V189H449V186Q448 183 436 95T421 3V0H50V19V31Q50 38 56 46T86 81Q115 113 136 137Q145 147 170 174T204 211T233 244T261 278T284 308T305 340T320 369T333 401T340 431T343 464Q343 527 309 573T212 619Q179 619 154 602T119 569T109 550Q109 549 114 549Q132 549 151 535T170 489Q170 464 154 447T109 429Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(19247.9,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(19414.9,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(21725.9,0)"},[e("path",{"data-c":"29",d:"M60 749L64 750Q69 750 74 750H86L114 726Q208 641 251 514T294 250Q294 182 284 119T261 12T224 -76T186 -143T145 -194T113 -227T90 -246Q87 -249 86 -250H74Q66 -250 63 -250T58 -247T55 -238Q56 -237 66 -225Q221 -64 221 250T66 725Q56 737 55 738Q55 746 60 749Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(22392.7,0)"},[e("path",{"data-c":"3D",d:"M56 347Q56 360 70 367H707Q722 359 722 347Q722 336 708 328L390 327H72Q56 332 56 347ZM56 153Q56 168 72 173H708Q722 163 722 153Q722 140 707 133H70Q56 140 56 153Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(23448.4,0)"},[e("path",{"data-c":"31",d:"M213 578L200 573Q186 568 160 563T102 556H83V602H102Q149 604 189 617T245 641T273 663Q275 666 285 666Q294 666 302 660V361L303 61Q310 54 315 52T339 48T401 46H427V0H416Q395 3 257 3Q121 3 100 0H88V46H114Q136 46 152 46T177 47T193 50T201 52T207 57T213 61V578Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(23948.4,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(24393.1,0)"},[e("path",{"data-c":"39",d:"M352 287Q304 211 232 211Q154 211 104 270T44 396Q42 412 42 436V444Q42 537 111 606Q171 666 243 666Q245 666 249 666T257 665H261Q273 665 286 663T323 651T370 619T413 560Q456 472 456 334Q456 194 396 97Q361 41 312 10T208 -22Q147 -22 108 7T68 93T121 149Q143 149 158 135T173 96Q173 78 164 65T148 49T135 44L131 43Q131 41 138 37T164 27T206 22H212Q272 22 313 86Q352 142 352 280V287ZM244 248Q292 248 321 297T351 430Q351 508 343 542Q341 552 337 562T323 588T293 615T246 625Q208 625 181 598Q160 576 154 546T147 441Q147 358 152 329T172 282Q197 248 244 248Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"33",d:"M127 463Q100 463 85 480T69 524Q69 579 117 622T233 665Q268 665 277 664Q351 652 390 611T430 522Q430 470 396 421T302 350L299 348Q299 347 308 345T337 336T375 315Q457 262 457 175Q457 96 395 37T238 -22Q158 -22 100 21T42 130Q42 158 60 175T105 193Q133 193 151 175T169 130Q169 119 166 110T159 94T148 82T136 74T126 70T118 67L114 66Q165 21 238 21Q293 21 321 74Q338 107 338 175V195Q338 290 274 322Q259 328 213 329L171 330L168 332Q166 335 166 348Q166 366 174 366Q202 366 232 371Q266 376 294 413T322 525V533Q322 590 287 612Q265 626 240 626Q208 626 181 615T143 592T132 580H135Q138 579 143 578T153 573T165 566T175 555T183 540T186 520Q186 498 172 481T127 463Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mo",transform:"translate(25893.1,0)"},[e("path",{"data-c":"2C",d:"M78 35T78 60T94 103T137 121Q165 121 187 96T210 8Q210 -27 201 -60T180 -117T154 -158T130 -185T117 -194Q113 -194 104 -185T95 -172Q95 -168 106 -156T131 -126T157 -76T173 -3V9L172 8Q170 7 167 6T161 3T152 1T140 0Q113 0 96 17Z",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mn",transform:"translate(26337.8,0)"},[e("path",{"data-c":"37",d:"M55 458Q56 460 72 567L88 674Q88 676 108 676H128V672Q128 662 143 655T195 646T364 644H485V605L417 512Q408 500 387 472T360 435T339 403T319 367T305 330T292 284T284 230T278 162T275 80Q275 66 275 52T274 28V19Q270 2 255 -10T221 -22Q210 -22 200 -19T179 0T168 40Q168 198 265 368Q285 400 349 489L395 552H302Q128 552 119 546Q113 543 108 522T98 479L95 458V455H55V458Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"38",d:"M70 417T70 494T124 618T248 666Q319 666 374 624T429 515Q429 485 418 459T392 417T361 389T335 371T324 363L338 354Q352 344 366 334T382 323Q457 264 457 174Q457 95 399 37T249 -22Q159 -22 101 29T43 155Q43 263 172 335L154 348Q133 361 127 368Q70 417 70 494ZM286 386L292 390Q298 394 301 396T311 403T323 413T334 425T345 438T355 454T364 471T369 491T371 513Q371 556 342 586T275 624Q268 625 242 625Q201 625 165 599T128 534Q128 511 141 492T167 463T217 431Q224 426 228 424L286 386ZM250 21Q308 21 350 55T392 137Q392 154 387 169T375 194T353 216T330 234T301 253T274 270Q260 279 244 289T218 306L210 311Q204 311 181 294T133 239T107 157Q107 98 150 60T250 21Z",transform:"translate(500,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"36",d:"M42 313Q42 476 123 571T303 666Q372 666 402 630T432 550Q432 525 418 510T379 495Q356 495 341 509T326 548Q326 592 373 601Q351 623 311 626Q240 626 194 566Q147 500 147 364L148 360Q153 366 156 373Q197 433 263 433H267Q313 433 348 414Q372 400 396 374T435 317Q456 268 456 210V192Q456 169 451 149Q440 90 387 34T253 -22Q225 -22 199 -14T143 16T92 75T56 172T42 313ZM257 397Q227 397 205 380T171 335T154 278T148 216Q148 133 160 97T198 39Q222 21 251 21Q302 21 329 59Q342 77 347 104T352 209Q352 289 347 316T329 361Q302 397 257 397Z",transform:"translate(1000,0)",style:{"stroke-width":"3"}})]),e("g",{"data-mml-node":"mstyle",transform:"translate(27837.8,0)"},[e("g",{"data-mml-node":"mspace"})]),e("g",{"data-mml-node":"mtext",transform:"translate(28004.8,0)"},[e("path",{"data-c":"62",d:"M307 -11Q234 -11 168 55L158 37Q156 34 153 28T147 17T143 10L138 1L118 0H98V298Q98 599 97 603Q94 622 83 628T38 637H20V660Q20 683 22 683L32 684Q42 685 61 686T98 688Q115 689 135 690T165 693T176 694H179V543Q179 391 180 391L183 394Q186 397 192 401T207 411T228 421T254 431T286 439T323 442Q401 442 461 379T522 216Q522 115 458 52T307 -11ZM182 98Q182 97 187 90T196 79T206 67T218 55T233 44T250 35T271 29T295 26Q330 26 363 46T412 113Q424 148 424 212Q424 287 412 323Q385 405 300 405Q270 405 239 390T188 347L182 339V98Z",style:{"stroke-width":"3"}}),e("path",{"data-c":"79",d:"M69 -66Q91 -66 104 -80T118 -116Q118 -134 109 -145T91 -160Q84 -163 97 -166Q104 -168 111 -168Q131 -168 148 -159T175 -138T197 -106T213 -75T225 -43L242 0L170 183Q150 233 125 297Q101 358 96 368T80 381Q79 382 78 382Q66 385 34 385H19V431H26L46 430Q65 430 88 429T122 428Q129 428 142 428T171 429T200 430T224 430L233 431H241V385H232Q183 385 185 366L286 112Q286 113 332 227L376 341V350Q376 365 366 373T348 383T334 385H331V431H337H344Q351 431 361 431T382 430T405 429T422 429Q477 429 503 431H508V385H497Q441 380 422 345Q420 343 378 235T289 9T227 -131Q180 -204 113 -204Q69 -204 44 -177T19 -116Q19 -89 35 -78T69 -66Z",transform:"translate(556,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"74",d:"M27 422Q80 426 109 478T141 600V615H181V431H316V385H181V241Q182 116 182 100T189 68Q203 29 238 29Q282 29 292 100Q293 108 293 146V181H333V146V134Q333 57 291 17Q264 -10 221 -10Q187 -10 162 2T124 33T105 68T98 100Q97 107 97 248V385H18V422H27Z",transform:"translate(1084,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"65",d:"M28 218Q28 273 48 318T98 391T163 433T229 448Q282 448 320 430T378 380T406 316T415 245Q415 238 408 231H126V216Q126 68 226 36Q246 30 270 30Q312 30 342 62Q359 79 369 104L379 128Q382 131 395 131H398Q415 131 415 121Q415 117 412 108Q393 53 349 21T250 -11Q155 -11 92 58T28 218ZM333 275Q322 403 238 411H236Q228 411 220 410T195 402T166 381T143 340T127 274V267H333V275Z",transform:"translate(1473,0)",style:{"stroke-width":"3"}}),e("path",{"data-c":"73",d:"M295 316Q295 356 268 385T190 414Q154 414 128 401Q98 382 98 349Q97 344 98 336T114 312T157 287Q175 282 201 278T245 269T277 256Q294 248 310 236T342 195T359 133Q359 71 321 31T198 -10H190Q138 -10 94 26L86 19L77 10Q71 4 65 -1L54 -11H46H42Q39 -11 33 -5V74V132Q33 153 35 157T45 162H54Q66 162 70 158T75 146T82 119T101 77Q136 26 198 26Q295 26 295 104Q295 133 277 151Q257 175 194 187T111 210Q75 227 54 256T33 318Q33 357 50 384T93 424T143 442T187 447H198Q238 447 268 432L283 424L292 431Q302 440 314 448H322H326Q329 448 335 442V310L329 304H301Q295 310 295 316Z",transform:"translate(1917,0)",style:{"stroke-width":"3"}})])])],-1),D=[q],A=e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mtext",null,"Total Bytes"),e("mo",null,"="),e("mo",{stretchy:"false"},"("),e("mn",null,"1"),e("mo",null,"×"),e("mn",null,"478"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"+"),e("mo",{stretchy:"false"},"("),e("mn",null,"4094"),e("mo",null,"×"),e("mn",null,"482"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes"),e("mo",{stretchy:"false"},")"),e("mo",null,"="),e("mn",null,"1"),e("mo",null,","),e("mn",null,"973"),e("mo",null,","),e("mn",null,"786"),e("mstyle",{scriptlevel:"0"},[e("mspace",{width:"0.167em"})]),e("mtext",null,"bytes")],-1),B=n("",50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Mainnet Beta | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/mainnet.md","filePath":"how-to-guides/mainnet.md","lastUpdated":1732777479000}'),F={name:"how-to-guides/mainnet.md"},G=Object.assign(F,{setup(d){return(T,Q)=>{const l=i("mjx-assistive-mml"),t=i("mjx-container");return s(),r("div",null,[C,a(x),Z,a(p),P,e("p",null,[a(t,{class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},{default:c(()=>[(s(),r("svg",E,D)),a(l,{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},{default:c(()=>[A]),_:1})]),_:1})]),B])}}});export{j as __pageData,G as default}; diff --git a/pr-1815/assets/how-to-guides_mocha-testnet.md.94189cf4.js b/pr-1815/assets/how-to-guides_mocha-testnet.md.4fde7245.js similarity index 99% rename from pr-1815/assets/how-to-guides_mocha-testnet.md.94189cf4.js rename to pr-1815/assets/how-to-guides_mocha-testnet.md.4fde7245.js index 22b638da8..353953347 100644 --- a/pr-1815/assets/how-to-guides_mocha-testnet.md.94189cf4.js +++ b/pr-1815/assets/how-to-guides_mocha-testnet.md.4fde7245.js @@ -1 +1 @@ -import{M as d}from"./chunks/MochaVersionTags.c661f1a2.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as p,o as s,c as r,k as e,t as o,H as a,Q as i,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mocha_versions.1f7c0f1d.js";const m="/docs-preview/pr-1815/img/mocha.jpg",f={name:"MochaTestnetDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),b=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"B93BBE20A0FBFDF955811B6420F8433904664D45DB4BF51022BE4200C1A1680D")])],-1),y=e("td",null,"Genesis file",-1),w=["href"],_=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(n,l,c,S,t,E){return s(),r("table",null,[g,e("tr",null,[b,e("td",null,[e("code",null,o(t.constants.mochaChainId),1)])]),k,e("tr",null,[y,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/genesis.json ",9,w)])]),e("tr",null,[_,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/peers.txt ",9,v)])]),C])}const T=p(f,[["render",P]]),R=i('

    Mocha testnet

    mocha-testnet

    This guide contains the relevant sections for how to connect to Mocha, depending on the type of node you are running. Mocha testnet is designed to help validators test out their infrastructure and node software. Developers are encouraged to deploy their sovereign rollups on Mocha, but we also recommend Arabica devnet for that as it is designed for development purposes.

    Mocha is a milestone in Celestia, allowing everyone to test out core functionalities on the network. Read the announcement. Your best approach to participating is to first determine which node you would like to run. Each node's guide will link to the relevant networks, to show you how to connect to them.

    You have a list of options on the types of nodes you can run to participate in Mocha:

    Consensus:

    Data Availability:

    Select the type of node you would like to run and follow the instructions on each respective page. Whenever you are asked to select the type of network you want to connect to in those guides, select Mocha to refer to the correct instructions on this page on how to connect to Mocha.

    Network details

    ',11),x=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),A=i('

    RPC for DA bridge, full, and light nodes

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    Bridge nodes

    Mentioned below RPC endpoints do not guarantee you the download of full blocks from them. We advise that if you are running a bridge node, that you also run a local consensus node in order to download full blocks from it.

    • public-celestia-mocha4-consensus.numia.xyz
    • mocha-4-consensus.mesa.newmetric.xyz
    • full.consensus.mocha-4.celestia-mocha.com
    • consensus-full-mocha-4.celestia-mocha.com
    • rpc-mocha.pops.one
    • celestia-testnet-consensus.itrocket.net
      • RPC port: 26657
      • gRPC port: 9090
    • rpc-celestia-testnet.cryptech.com.ua
      • gRPC: grpc-celestia-testnet.cryptech.com.ua:443

    Community RPC endpoints

    The RPC endpoint is to allow users to interact with Celestia's nodes by querying the node's state and broadcasting transactions on the Celestia network. The default port is 26657.

    • public-celestia-mocha4-consensus.numia.xyz:26657
    • mocha-4-consensus.mesa.newmetric.xyz:26657
    • celestia-testnet.brightlystake.com
    • rpc-celestia-mocha.trusted-point.com
    • rpc-celestia-testnet-01.stakeflow.io
    • mocha.celestia.rpc.cumulo.me
    • rpc.archive.mocha.cumulo.com.es
    • rpc-mocha-full.avril14th.org
    • rpc-1.testnet.celestia.nodes.guru
    • rpc-2.testnet.celestia.nodes.guru
    • celestia-testnet-rpc.itrocket.net:443
    • rpc-celestia-testnet.cryptech.com.ua:443

    Community API endpoints

    The API endpoint is to allow users to interact with the REST API in Cosmos SDK which is implemented using gRPC-gateway, which exposes gRPC endpoints as REST endpoints. This allows for communication with the node using REST calls, which can be useful if the client does not support gRPC or HTTP2. The default port is 1317.

    Community gRPC endpoints

    The gRPC endpoint is to allow users to interact with a Celestia Node using gRPC, a modern open-source and high-performance RPC framework. The default port is 9090. In the Cosmos SDK, gRPC is used to define state queries and broadcast transactions.

    • public-celestia-mocha4-consensus.numia.xyz:9090
    • mocha-4-consensus.mesa.newmetric.xyz:9090
    • grpc-mocha.pops.one
    • grpc.celestia-mocha.com:443
    • full.consensus.mocha-4.celestia-mocha.com:9090
    • consensus-full-mocha-4.celestia-mocha.com:9090
    • celestia-testnet.brightlystake.com:9390
    • grpc-celestia-mocha.trusted-point.com:9099
    • grpc-celestia-testnet-01.stakeflow.io:16002
    • mocha.grpc.cumulo.me:443
    • grpc.archive.mocha.cumulo.com.es:443
    • grpc-mocha-full.avril14th.org
    • grpc-1.testnet.celestia.nodes.guru:10790
    • grpc-2.testnet.celestia.nodes.guru:10790
    • celestia-testnet-grpc.itrocket.net:443
    • grpc-celestia-testnet.cryptech.com.ua:443

    Community bridge and full node endpoints

    The endpoints below are for bridge and full nodes only. They can be used to find bootstrapper peers in the p2p network.

    Bridge node 1:

    • da-bridge-mocha-4.celestia-mocha.com
    • bridge-mocha-4.da.celestia-mocha.com

    Bridge node 2:

    • da-bridge-mocha-4-2.celestia-mocha.com
    • bridge-mocha-4-2.da.celestia-mocha.com

    Full node 1:

    • da-full-1-mocha-4.celestia-mocha.com
    • full-1-mocha-4.da.celestia-mocha.com

    Full node 2:

    • da-full-2-mocha-4.celestia-mocha.com
    • full-2-mocha-4.da.celestia-mocha.com

    Mocha testnet faucet

    WARNING

    USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

    You can request from Mocha testnet Faucet on the #mocha-faucet channel on Celestia's Discord server with the following command:

    text
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

    NOTE

    Faucet has a limit of 10 tokens per week per address/Discord ID.

    Analytics

    The following websites provide analytics for Mocha Testnet:

    Explorers

    There are several explorers you can use for Mocha:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mocha testnet:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    ',46),F=JSON.parse('{"title":"Mocha testnet","description":"Learn how to connect to the Mocha network.","frontmatter":{"description":"Learn how to connect to the Mocha network.","head":[["meta",{"property":"og:title","content":"Mocha testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to connect to the Mocha network."}]]},"headers":[],"relativePath":"how-to-guides/mocha-testnet.md","filePath":"how-to-guides/mocha-testnet.md","lastUpdated":1732776394000}'),D={name:"how-to-guides/mocha-testnet.md"},B=Object.assign(D,{setup(n){return(l,c)=>(s(),r("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; +import{M as d}from"./chunks/MochaVersionTags.c661f1a2.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as p,o as s,c as r,k as e,t as o,H as a,Q as i,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mocha_versions.1f7c0f1d.js";const m="/docs-preview/pr-1815/img/mocha.jpg",f={name:"MochaTestnetDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),b=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"B93BBE20A0FBFDF955811B6420F8433904664D45DB4BF51022BE4200C1A1680D")])],-1),y=e("td",null,"Genesis file",-1),w=["href"],_=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(n,l,c,S,t,E){return s(),r("table",null,[g,e("tr",null,[b,e("td",null,[e("code",null,o(t.constants.mochaChainId),1)])]),k,e("tr",null,[y,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/genesis.json ",9,w)])]),e("tr",null,[_,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/peers.txt ",9,v)])]),C])}const T=p(f,[["render",P]]),R=i('

    Mocha testnet

    mocha-testnet

    This guide contains the relevant sections for how to connect to Mocha, depending on the type of node you are running. Mocha testnet is designed to help validators test out their infrastructure and node software. Developers are encouraged to deploy their sovereign rollups on Mocha, but we also recommend Arabica devnet for that as it is designed for development purposes.

    Mocha is a milestone in Celestia, allowing everyone to test out core functionalities on the network. Read the announcement. Your best approach to participating is to first determine which node you would like to run. Each node's guide will link to the relevant networks, to show you how to connect to them.

    You have a list of options on the types of nodes you can run to participate in Mocha:

    Consensus:

    Data Availability:

    Select the type of node you would like to run and follow the instructions on each respective page. Whenever you are asked to select the type of network you want to connect to in those guides, select Mocha to refer to the correct instructions on this page on how to connect to Mocha.

    Network details

    ',11),x=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),A=i('

    RPC for DA bridge, full, and light nodes

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    Bridge nodes

    Mentioned below RPC endpoints do not guarantee you the download of full blocks from them. We advise that if you are running a bridge node, that you also run a local consensus node in order to download full blocks from it.

    • public-celestia-mocha4-consensus.numia.xyz
    • mocha-4-consensus.mesa.newmetric.xyz
    • full.consensus.mocha-4.celestia-mocha.com
    • consensus-full-mocha-4.celestia-mocha.com
    • rpc-mocha.pops.one
    • celestia-testnet-consensus.itrocket.net
      • RPC port: 26657
      • gRPC port: 9090
    • rpc-celestia-testnet.cryptech.com.ua
      • gRPC: grpc-celestia-testnet.cryptech.com.ua:443

    Community RPC endpoints

    The RPC endpoint is to allow users to interact with Celestia's nodes by querying the node's state and broadcasting transactions on the Celestia network. The default port is 26657.

    • public-celestia-mocha4-consensus.numia.xyz:26657
    • mocha-4-consensus.mesa.newmetric.xyz:26657
    • celestia-testnet.brightlystake.com
    • rpc-celestia-mocha.trusted-point.com
    • rpc-celestia-testnet-01.stakeflow.io
    • mocha.celestia.rpc.cumulo.me
    • rpc.archive.mocha.cumulo.com.es
    • rpc-mocha-full.avril14th.org
    • rpc-1.testnet.celestia.nodes.guru
    • rpc-2.testnet.celestia.nodes.guru
    • celestia-testnet-rpc.itrocket.net:443
    • rpc-celestia-testnet.cryptech.com.ua:443

    Community API endpoints

    The API endpoint is to allow users to interact with the REST API in Cosmos SDK which is implemented using gRPC-gateway, which exposes gRPC endpoints as REST endpoints. This allows for communication with the node using REST calls, which can be useful if the client does not support gRPC or HTTP2. The default port is 1317.

    Community gRPC endpoints

    The gRPC endpoint is to allow users to interact with a Celestia Node using gRPC, a modern open-source and high-performance RPC framework. The default port is 9090. In the Cosmos SDK, gRPC is used to define state queries and broadcast transactions.

    • public-celestia-mocha4-consensus.numia.xyz:9090
    • mocha-4-consensus.mesa.newmetric.xyz:9090
    • grpc-mocha.pops.one
    • grpc.celestia-mocha.com:443
    • full.consensus.mocha-4.celestia-mocha.com:9090
    • consensus-full-mocha-4.celestia-mocha.com:9090
    • celestia-testnet.brightlystake.com:9390
    • grpc-celestia-mocha.trusted-point.com:9099
    • grpc-celestia-testnet-01.stakeflow.io:16002
    • mocha.grpc.cumulo.me:443
    • grpc.archive.mocha.cumulo.com.es:443
    • grpc-mocha-full.avril14th.org
    • grpc-1.testnet.celestia.nodes.guru:10790
    • grpc-2.testnet.celestia.nodes.guru:10790
    • celestia-testnet-grpc.itrocket.net:443
    • grpc-celestia-testnet.cryptech.com.ua:443

    Community bridge and full node endpoints

    The endpoints below are for bridge and full nodes only. They can be used to find bootstrapper peers in the p2p network.

    Bridge node 1:

    • da-bridge-mocha-4.celestia-mocha.com
    • bridge-mocha-4.da.celestia-mocha.com

    Bridge node 2:

    • da-bridge-mocha-4-2.celestia-mocha.com
    • bridge-mocha-4-2.da.celestia-mocha.com

    Full node 1:

    • da-full-1-mocha-4.celestia-mocha.com
    • full-1-mocha-4.da.celestia-mocha.com

    Full node 2:

    • da-full-2-mocha-4.celestia-mocha.com
    • full-2-mocha-4.da.celestia-mocha.com

    Mocha testnet faucet

    WARNING

    USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

    You can request from Mocha testnet Faucet on the #mocha-faucet channel on Celestia's Discord server with the following command:

    text
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

    NOTE

    Faucet has a limit of 10 tokens per week per address/Discord ID.

    Analytics

    The following websites provide analytics for Mocha Testnet:

    Explorers

    There are several explorers you can use for Mocha:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mocha testnet:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    ',46),F=JSON.parse('{"title":"Mocha testnet","description":"Learn how to connect to the Mocha network.","frontmatter":{"description":"Learn how to connect to the Mocha network.","head":[["meta",{"property":"og:title","content":"Mocha testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to connect to the Mocha network."}]]},"headers":[],"relativePath":"how-to-guides/mocha-testnet.md","filePath":"how-to-guides/mocha-testnet.md","lastUpdated":1732777479000}'),D={name:"how-to-guides/mocha-testnet.md"},B=Object.assign(D,{setup(n){return(l,c)=>(s(),r("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; diff --git a/pr-1815/assets/how-to-guides_mocha-testnet.md.94189cf4.lean.js b/pr-1815/assets/how-to-guides_mocha-testnet.md.4fde7245.lean.js similarity index 97% rename from pr-1815/assets/how-to-guides_mocha-testnet.md.94189cf4.lean.js rename to pr-1815/assets/how-to-guides_mocha-testnet.md.4fde7245.lean.js index 3d6a2f154..a65b6279d 100644 --- a/pr-1815/assets/how-to-guides_mocha-testnet.md.94189cf4.lean.js +++ b/pr-1815/assets/how-to-guides_mocha-testnet.md.4fde7245.lean.js @@ -1 +1 @@ -import{M as d}from"./chunks/MochaVersionTags.c661f1a2.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as p,o as s,c as r,k as e,t as o,H as a,Q as i,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mocha_versions.1f7c0f1d.js";const m="/docs-preview/pr-1815/img/mocha.jpg",f={name:"MochaTestnetDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),b=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"B93BBE20A0FBFDF955811B6420F8433904664D45DB4BF51022BE4200C1A1680D")])],-1),y=e("td",null,"Genesis file",-1),w=["href"],_=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(n,l,c,S,t,E){return s(),r("table",null,[g,e("tr",null,[b,e("td",null,[e("code",null,o(t.constants.mochaChainId),1)])]),k,e("tr",null,[y,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/genesis.json ",9,w)])]),e("tr",null,[_,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/peers.txt ",9,v)])]),C])}const T=p(f,[["render",P]]),R=i("",11),x=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),A=i("",46),F=JSON.parse('{"title":"Mocha testnet","description":"Learn how to connect to the Mocha network.","frontmatter":{"description":"Learn how to connect to the Mocha network.","head":[["meta",{"property":"og:title","content":"Mocha testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to connect to the Mocha network."}]]},"headers":[],"relativePath":"how-to-guides/mocha-testnet.md","filePath":"how-to-guides/mocha-testnet.md","lastUpdated":1732776394000}'),D={name:"how-to-guides/mocha-testnet.md"},B=Object.assign(D,{setup(n){return(l,c)=>(s(),r("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; +import{M as d}from"./chunks/MochaVersionTags.c661f1a2.js";import{c as h}from"./chunks/constants.b02263eb.js";import{_ as p,o as s,c as r,k as e,t as o,H as a,Q as i,a as u}from"./chunks/framework.2959b752.js";import"./chunks/mocha_versions.1f7c0f1d.js";const m="/docs-preview/pr-1815/img/mocha.jpg",f={name:"MochaTestnetDetails",data(){return{constants:h}}},g=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),b=e("td",null,"Chain ID",-1),k=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"B93BBE20A0FBFDF955811B6420F8433904664D45DB4BF51022BE4200C1A1680D")])],-1),y=e("td",null,"Genesis file",-1),w=["href"],_=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(n,l,c,S,t,E){return s(),r("table",null,[g,e("tr",null,[b,e("td",null,[e("code",null,o(t.constants.mochaChainId),1)])]),k,e("tr",null,[y,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/genesis.json`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/genesis.json ",9,w)])]),e("tr",null,[_,e("td",null,[e("a",{href:`https://github.com/celestiaorg/networks/blob/master/${t.constants.mochaChainId}/peers.txt`,target:"_blank",rel:"noopener noreferrer"}," https://github.com/celestiaorg/networks/blob/master/"+o(t.constants.mochaChainId)+"/peers.txt ",9,v)])]),C])}const T=p(f,[["render",P]]),R=i("",11),x=e("h2",{id:"software-version-numbers",tabindex:"-1"},[u("Software version numbers "),e("a",{class:"header-anchor",href:"#software-version-numbers","aria-label":'Permalink to "Software version numbers"'},"​")],-1),A=i("",46),F=JSON.parse('{"title":"Mocha testnet","description":"Learn how to connect to the Mocha network.","frontmatter":{"description":"Learn how to connect to the Mocha network.","head":[["meta",{"property":"og:title","content":"Mocha testnet | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to connect to the Mocha network."}]]},"headers":[],"relativePath":"how-to-guides/mocha-testnet.md","filePath":"how-to-guides/mocha-testnet.md","lastUpdated":1732777479000}'),D={name:"how-to-guides/mocha-testnet.md"},B=Object.assign(D,{setup(n){return(l,c)=>(s(),r("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; diff --git a/pr-1815/assets/how-to-guides_multiaccounts.md.c40b388b.js b/pr-1815/assets/how-to-guides_multiaccounts.md.54e5cfc9.js similarity index 99% rename from pr-1815/assets/how-to-guides_multiaccounts.md.c40b388b.js rename to pr-1815/assets/how-to-guides_multiaccounts.md.54e5cfc9.js index 919c2aad8..d09be162a 100644 --- a/pr-1815/assets/how-to-guides_multiaccounts.md.c40b388b.js +++ b/pr-1815/assets/how-to-guides_multiaccounts.md.54e5cfc9.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"MultiAccounts feature for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"MultiAccounts feature for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/multiaccounts.md","filePath":"how-to-guides/multiaccounts.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/multiaccounts.md"},t=n(`

    MultiAccounts feature for blobs submission

    Overview

    By default, a celestia-node creates a key named my_celes_key during initialization. This document explains how to run a node with a different default key name and how to submit blobs using different signers.

    Running a node with a different default key name

    To start a Celestia node with a different default key name, use the following command:

    sh
    celestia light start --core.ip=consensus.celestia-arabica-11.com \\
    +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"MultiAccounts feature for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"MultiAccounts feature for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/multiaccounts.md","filePath":"how-to-guides/multiaccounts.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/multiaccounts.md"},t=n(`

    MultiAccounts feature for blobs submission

    Overview

    By default, a celestia-node creates a key named my_celes_key during initialization. This document explains how to run a node with a different default key name and how to submit blobs using different signers.

    Running a node with a different default key name

    To start a Celestia node with a different default key name, use the following command:

    sh
    celestia light start --core.ip=consensus.celestia-arabica-11.com \\
         --p2p.network=arabica --keyring.keyname testKey
    celestia light start --core.ip=consensus.celestia-arabica-11.com \\
         --p2p.network=arabica --keyring.keyname testKey

    In this example, testKey becomes the default node key, and the node's address will change accordingly.

    Submitting blobs with a different signer/key name

    Option 1: Submit passing key name

    You can submit a blob by specifying a different key name:

    sh
    celestia blob submit 0x42690c204d39600fddd3 'gm' --key.name testKey2
    celestia blob submit 0x42690c204d39600fddd3 'gm' --key.name testKey2

    This transaction will be signed by the address associated with testKey2.

    Option 2: Submit passing signer address

    Alternatively, you can submit a blob by specifying the signer's address:

    sh
    celestia blob submit 0x42690c204d39600fddd3 'gm' --signer $SIGNER_ADDRESS
    celestia blob submit 0x42690c204d39600fddd3 'gm' --signer $SIGNER_ADDRESS

    Both options achieve the same result but use different inputs. The testKey2 points to SIGNER_ADDRESS in the KeyStore.

    Key management

    All keys and addresses must be added to the KeyStore. To create a new key, use the cel-key library:

    Creating a new key

    sh
    ./cel-key add testKey --keyring-backend test \\
         --node.type light --p2p.network arabica
    ./cel-key add testKey --keyring-backend test \\
    diff --git a/pr-1815/assets/how-to-guides_multiaccounts.md.c40b388b.lean.js b/pr-1815/assets/how-to-guides_multiaccounts.md.54e5cfc9.lean.js
    similarity index 90%
    rename from pr-1815/assets/how-to-guides_multiaccounts.md.c40b388b.lean.js
    rename to pr-1815/assets/how-to-guides_multiaccounts.md.54e5cfc9.lean.js
    index be70a4cff..0bd3d3772 100644
    --- a/pr-1815/assets/how-to-guides_multiaccounts.md.c40b388b.lean.js
    +++ b/pr-1815/assets/how-to-guides_multiaccounts.md.54e5cfc9.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"MultiAccounts feature for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"MultiAccounts feature for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/multiaccounts.md","filePath":"how-to-guides/multiaccounts.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/multiaccounts.md"},t=n("",28),l=[t];function p(r,i,c,d,y,h){return a(),e("div",null,l)}const E=s(o,[["render",p]]);export{b as __pageData,E as default};
    +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"MultiAccounts feature for blobs submission","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"MultiAccounts feature for blobs submission | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/multiaccounts.md","filePath":"how-to-guides/multiaccounts.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/multiaccounts.md"},t=n("",28),l=[t];function p(r,i,c,d,y,h){return a(),e("div",null,l)}const E=s(o,[["render",p]]);export{b as __pageData,E as default};
    diff --git a/pr-1815/assets/how-to-guides_network-upgrade-process.md.0db1d530.js b/pr-1815/assets/how-to-guides_network-upgrade-process.md.1493429a.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_network-upgrade-process.md.0db1d530.js
    rename to pr-1815/assets/how-to-guides_network-upgrade-process.md.1493429a.js
    index bae82ebbf..999ff16f6 100644
    --- a/pr-1815/assets/how-to-guides_network-upgrade-process.md.0db1d530.js
    +++ b/pr-1815/assets/how-to-guides_network-upgrade-process.md.1493429a.js
    @@ -1 +1 @@
    -import{_ as e,o as r,c as a,Q as t}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Celestia network upgrade process","description":"Overview of the Celestia network upgrade process.","frontmatter":{"description":"Overview of the Celestia network upgrade process.","head":[["meta",{"property":"og:title","content":"Celestia network upgrade process | Celestia Docs"}],["meta",{"property":"og:description","content":"Overview of the Celestia network upgrade process."}]]},"headers":[],"relativePath":"how-to-guides/network-upgrade-process.md","filePath":"how-to-guides/network-upgrade-process.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/network-upgrade-process.md"},i=t('

    Celestia network upgrade process

    Blockchain networks often need to upgrade with new features which require coordination work among the community of developers, validators, and node operators prior to activating the upgrades. This process is called a network upgrade, which can be breaking or non-breaking. During planned network upgrades the community will coordinate to prepare for the upcoming upgrade. Breaking network upgrades are not backward-compatible with older versions of the network software, which is why it is important that validators upgrade their software to continue validating on the network. Non-breaking network upgrades are backward-compatible and require less coordination.

    Network upgrade coordination

    As of the Lemongrass upgrade in September 2024, Celestia has implemented CIP-10, which establishes two methods for coordinating network upgrades:

    1. Pre-programmed height: Used for the Lemongrass network upgrade (v2)
    2. In-protocol signaling: Used for all subsequent upgrades (v3+)

    Under the in-protocol signaling mechanism, validators submit messages to signal their readiness and preference for the next version. The upgrade activates automatically once a quorum of 5/6 of validators have signaled for the same version.

    Upgrade process

    The upgrade process can be broken down into a few steps:

    1. Celestia Improvement Proposals (CIPs) are created for consensus-breaking changes and features that impact user experience. These CIPs are included in a meta-CIP, which define the scope of the upgrade.
    2. Celestia core developer teams implement the features defined in the CIPs.
    3. A new binary is released with the new features to be tested on testnets.
    4. Validators upgrade their nodes to the new binary, on Arabica devnet, Mocha testnet, and finally on Celestia Mainnet Beta.
      • Upgrades using pre-programmed height (v2) activate at a predetermined block number.
      • Upgrades using in-protocol signaling (v3+) activate one week after 5/6 of the voting power has signaled for a particular version

    Upcoming upgrade

    Ginger network upgrade

    The Ginger network upgrade (v3) will be the first to use the new in-protocol signaling mechanism defined in CIP-10. This upgrade includes changes defined in CIP-25:

    Key features include:

    • CIP-21: Introduce blob type with verified signer
    • CIP-24: Versioned Gas Scheduler Variables
    • CIP-26: Versioned timeouts
    • CIP-27: Block limits for number of PFBs and non-PFBs
    • CIP-28: Transaction size limit

    Unlike the Lemongrass upgrade, there will not be a pre-programmed upgrade height. Instead, validators will signal their readiness for v3 through in-protocol signaling, and the upgrade will automatically activate one week after 5/6 of voting power have signaled for a particular version.

    Learn more in the v3.0.0 release notes.

    INFO

    Validators should ensure they are running a v3 binary before signaling support for the upgrade.

    WARNING

    You do not need to use a tool like cosmovisor to upgrade the binary. Please upgrade your binary before signaling support for the new version.

    Past Upgrades

    Lemongrass network upgrade

    The Lemongrass network upgrade (v2) was the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass network upgrade included all of the CIPs listed in CIP-17 and implemented CIP-10 for future upgrades.

    NetworkChain IDDate and timeUpgrade height
    Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
    Mochamocha-42024/08/28 @ 14:00 UTC2585031
    Mainnet Betacelestia2024/09/18 @ 14:00 UTC2371495
    ',22),s=[i];function n(l,d,p,c,h,g){return r(),a("div",null,s)}const f=e(o,[["render",n]]);export{m as __pageData,f as default}; +import{_ as e,o as r,c as a,Q as t}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Celestia network upgrade process","description":"Overview of the Celestia network upgrade process.","frontmatter":{"description":"Overview of the Celestia network upgrade process.","head":[["meta",{"property":"og:title","content":"Celestia network upgrade process | Celestia Docs"}],["meta",{"property":"og:description","content":"Overview of the Celestia network upgrade process."}]]},"headers":[],"relativePath":"how-to-guides/network-upgrade-process.md","filePath":"how-to-guides/network-upgrade-process.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/network-upgrade-process.md"},i=t('

    Celestia network upgrade process

    Blockchain networks often need to upgrade with new features which require coordination work among the community of developers, validators, and node operators prior to activating the upgrades. This process is called a network upgrade, which can be breaking or non-breaking. During planned network upgrades the community will coordinate to prepare for the upcoming upgrade. Breaking network upgrades are not backward-compatible with older versions of the network software, which is why it is important that validators upgrade their software to continue validating on the network. Non-breaking network upgrades are backward-compatible and require less coordination.

    Network upgrade coordination

    As of the Lemongrass upgrade in September 2024, Celestia has implemented CIP-10, which establishes two methods for coordinating network upgrades:

    1. Pre-programmed height: Used for the Lemongrass network upgrade (v2)
    2. In-protocol signaling: Used for all subsequent upgrades (v3+)

    Under the in-protocol signaling mechanism, validators submit messages to signal their readiness and preference for the next version. The upgrade activates automatically once a quorum of 5/6 of validators have signaled for the same version.

    Upgrade process

    The upgrade process can be broken down into a few steps:

    1. Celestia Improvement Proposals (CIPs) are created for consensus-breaking changes and features that impact user experience. These CIPs are included in a meta-CIP, which define the scope of the upgrade.
    2. Celestia core developer teams implement the features defined in the CIPs.
    3. A new binary is released with the new features to be tested on testnets.
    4. Validators upgrade their nodes to the new binary, on Arabica devnet, Mocha testnet, and finally on Celestia Mainnet Beta.
      • Upgrades using pre-programmed height (v2) activate at a predetermined block number.
      • Upgrades using in-protocol signaling (v3+) activate one week after 5/6 of the voting power has signaled for a particular version

    Upcoming upgrade

    Ginger network upgrade

    The Ginger network upgrade (v3) will be the first to use the new in-protocol signaling mechanism defined in CIP-10. This upgrade includes changes defined in CIP-25:

    Key features include:

    • CIP-21: Introduce blob type with verified signer
    • CIP-24: Versioned Gas Scheduler Variables
    • CIP-26: Versioned timeouts
    • CIP-27: Block limits for number of PFBs and non-PFBs
    • CIP-28: Transaction size limit

    Unlike the Lemongrass upgrade, there will not be a pre-programmed upgrade height. Instead, validators will signal their readiness for v3 through in-protocol signaling, and the upgrade will automatically activate one week after 5/6 of voting power have signaled for a particular version.

    Learn more in the v3.0.0 release notes.

    INFO

    Validators should ensure they are running a v3 binary before signaling support for the upgrade.

    WARNING

    You do not need to use a tool like cosmovisor to upgrade the binary. Please upgrade your binary before signaling support for the new version.

    Past Upgrades

    Lemongrass network upgrade

    The Lemongrass network upgrade (v2) was the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass network upgrade included all of the CIPs listed in CIP-17 and implemented CIP-10 for future upgrades.

    NetworkChain IDDate and timeUpgrade height
    Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
    Mochamocha-42024/08/28 @ 14:00 UTC2585031
    Mainnet Betacelestia2024/09/18 @ 14:00 UTC2371495
    ',22),s=[i];function n(l,d,p,c,h,g){return r(),a("div",null,s)}const f=e(o,[["render",n]]);export{m as __pageData,f as default}; diff --git a/pr-1815/assets/how-to-guides_network-upgrade-process.md.0db1d530.lean.js b/pr-1815/assets/how-to-guides_network-upgrade-process.md.1493429a.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_network-upgrade-process.md.0db1d530.lean.js rename to pr-1815/assets/how-to-guides_network-upgrade-process.md.1493429a.lean.js index f01ebad5b..94981fe8c 100644 --- a/pr-1815/assets/how-to-guides_network-upgrade-process.md.0db1d530.lean.js +++ b/pr-1815/assets/how-to-guides_network-upgrade-process.md.1493429a.lean.js @@ -1 +1 @@ -import{_ as e,o as r,c as a,Q as t}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Celestia network upgrade process","description":"Overview of the Celestia network upgrade process.","frontmatter":{"description":"Overview of the Celestia network upgrade process.","head":[["meta",{"property":"og:title","content":"Celestia network upgrade process | Celestia Docs"}],["meta",{"property":"og:description","content":"Overview of the Celestia network upgrade process."}]]},"headers":[],"relativePath":"how-to-guides/network-upgrade-process.md","filePath":"how-to-guides/network-upgrade-process.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/network-upgrade-process.md"},i=t("",22),s=[i];function n(l,d,p,c,h,g){return r(),a("div",null,s)}const f=e(o,[["render",n]]);export{m as __pageData,f as default}; +import{_ as e,o as r,c as a,Q as t}from"./chunks/framework.2959b752.js";const m=JSON.parse('{"title":"Celestia network upgrade process","description":"Overview of the Celestia network upgrade process.","frontmatter":{"description":"Overview of the Celestia network upgrade process.","head":[["meta",{"property":"og:title","content":"Celestia network upgrade process | Celestia Docs"}],["meta",{"property":"og:description","content":"Overview of the Celestia network upgrade process."}]]},"headers":[],"relativePath":"how-to-guides/network-upgrade-process.md","filePath":"how-to-guides/network-upgrade-process.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/network-upgrade-process.md"},i=t("",22),s=[i];function n(l,d,p,c,h,g){return r(),a("div",null,s)}const f=e(o,[["render",n]]);export{m as __pageData,f as default}; diff --git a/pr-1815/assets/how-to-guides_nodes-overview.md.e7d3307b.js b/pr-1815/assets/how-to-guides_nodes-overview.md.082b2343.js similarity index 98% rename from pr-1815/assets/how-to-guides_nodes-overview.md.e7d3307b.js rename to pr-1815/assets/how-to-guides_nodes-overview.md.082b2343.js index 8d5ed4671..dd474a59a 100644 --- a/pr-1815/assets/how-to-guides_nodes-overview.md.e7d3307b.js +++ b/pr-1815/assets/how-to-guides_nodes-overview.md.082b2343.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const v=JSON.parse('{"title":"Overview to running nodes on Celestia","description":"An overview on how to participate in the Celestia network.","frontmatter":{"description":"An overview on how to participate in the Celestia network.","head":[["meta",{"property":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview on how to participate in the Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/nodes-overview.md","filePath":"how-to-guides/nodes-overview.md","lastUpdated":1732776394000}'),n={name:"how-to-guides/nodes-overview.md"},d=a('

    Overview to running nodes on Celestia

    There are many ways you can participate in the Celestia networks.

    Celestia node operators can run several options on the network.

    Consensus:

    • Validator node: This type of node participates in consensus by producing and voting on blocks.
    • Consensus node: A celestia-app full node to sync blockchain history.

    Data Availability:

    • Bridge node: This node bridges blocks between the Data-Availability network and the Consensus network.
    • Full storage node: This node stores all the data but does not connect to Consensus.
    • Light node: Light clients conduct data availability sampling on the Data Availability network.

    You can learn more about how to set up each different node by going through each tutorial guide.

    Data availability nodes

    Node typeMemoryCPUDiskBandwidth
    Light node500 MB RAMSingle core100 GB SSD56 Kbps
    Bridge node16 GB RAM6 cores2 TB NVME1 Gbps
    Full storage node16 GB RAMQuad-core2 TB NVME1 Gbps

    Consensus nodes

    Node typeMemoryCPUDiskBandwidth
    Validator16 GB RAM8 cores2 TB SSD1 Gbps
    Consensus node16 GB RAMQuad-core2 TB SSD1 Gbps

    Please provide any feedback on the tutorials and guides. If you notice a bug or issue, feel free to make a pull request or write up a Github issue!

    ',14),i=[d];function s(r,l,h,c,u,p){return t(),o("div",null,i)}const g=e(n,[["render",s]]);export{v as __pageData,g as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const v=JSON.parse('{"title":"Overview to running nodes on Celestia","description":"An overview on how to participate in the Celestia network.","frontmatter":{"description":"An overview on how to participate in the Celestia network.","head":[["meta",{"property":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview on how to participate in the Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/nodes-overview.md","filePath":"how-to-guides/nodes-overview.md","lastUpdated":1732777479000}'),n={name:"how-to-guides/nodes-overview.md"},d=a('

    Overview to running nodes on Celestia

    There are many ways you can participate in the Celestia networks.

    Celestia node operators can run several options on the network.

    Consensus:

    • Validator node: This type of node participates in consensus by producing and voting on blocks.
    • Consensus node: A celestia-app full node to sync blockchain history.

    Data Availability:

    • Bridge node: This node bridges blocks between the Data-Availability network and the Consensus network.
    • Full storage node: This node stores all the data but does not connect to Consensus.
    • Light node: Light clients conduct data availability sampling on the Data Availability network.

    You can learn more about how to set up each different node by going through each tutorial guide.

    Data availability nodes

    Node typeMemoryCPUDiskBandwidth
    Light node500 MB RAMSingle core100 GB SSD56 Kbps
    Bridge node16 GB RAM6 cores2 TB NVME1 Gbps
    Full storage node16 GB RAMQuad-core2 TB NVME1 Gbps

    Consensus nodes

    Node typeMemoryCPUDiskBandwidth
    Validator16 GB RAM8 cores2 TB SSD1 Gbps
    Consensus node16 GB RAMQuad-core2 TB SSD1 Gbps

    Please provide any feedback on the tutorials and guides. If you notice a bug or issue, feel free to make a pull request or write up a Github issue!

    ',14),i=[d];function s(r,l,h,c,u,p){return t(),o("div",null,i)}const g=e(n,[["render",s]]);export{v as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_nodes-overview.md.e7d3307b.lean.js b/pr-1815/assets/how-to-guides_nodes-overview.md.082b2343.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_nodes-overview.md.e7d3307b.lean.js rename to pr-1815/assets/how-to-guides_nodes-overview.md.082b2343.lean.js index ca8d084a2..99f866aa6 100644 --- a/pr-1815/assets/how-to-guides_nodes-overview.md.e7d3307b.lean.js +++ b/pr-1815/assets/how-to-guides_nodes-overview.md.082b2343.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const v=JSON.parse('{"title":"Overview to running nodes on Celestia","description":"An overview on how to participate in the Celestia network.","frontmatter":{"description":"An overview on how to participate in the Celestia network.","head":[["meta",{"property":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview on how to participate in the Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/nodes-overview.md","filePath":"how-to-guides/nodes-overview.md","lastUpdated":1732776394000}'),n={name:"how-to-guides/nodes-overview.md"},d=a("",14),i=[d];function s(r,l,h,c,u,p){return t(),o("div",null,i)}const g=e(n,[["render",s]]);export{v as __pageData,g as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const v=JSON.parse('{"title":"Overview to running nodes on Celestia","description":"An overview on how to participate in the Celestia network.","frontmatter":{"description":"An overview on how to participate in the Celestia network.","head":[["meta",{"property":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview on how to participate in the Celestia network."}]]},"headers":[],"relativePath":"how-to-guides/nodes-overview.md","filePath":"how-to-guides/nodes-overview.md","lastUpdated":1732777479000}'),n={name:"how-to-guides/nodes-overview.md"},d=a("",14),i=[d];function s(r,l,h,c,u,p){return t(),o("div",null,i)}const g=e(n,[["render",s]]);export{v as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_optimism-devnet.md.ef6600cc.js b/pr-1815/assets/how-to-guides_optimism-devnet.md.ea2a7388.js similarity index 99% rename from pr-1815/assets/how-to-guides_optimism-devnet.md.ef6600cc.js rename to pr-1815/assets/how-to-guides_optimism-devnet.md.ea2a7388.js index 098741475..d010af644 100644 --- a/pr-1815/assets/how-to-guides_optimism-devnet.md.ef6600cc.js +++ b/pr-1815/assets/how-to-guides_optimism-devnet.md.ea2a7388.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Optimism devnet deep dive | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/optimism-devnet.md","filePath":"how-to-guides/optimism-devnet.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/optimism-devnet.md"},l=e(`

    Optimism devnet deep dive

    This page is for those interested in doing a deep dive on their pre-op-plasma-celestia @celestiaorg/optimism rollups.

    Find a transaction

    Now, we'll check for a recent transaction on the L1 with:

    bash
    cast block latest --rpc-url localhost:8545
    cast block latest --rpc-url localhost:8545

    Output of a block that contains a transaction will look like this:

    console
    baseFeePerGas        7
    +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Optimism devnet deep dive | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/optimism-devnet.md","filePath":"how-to-guides/optimism-devnet.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/optimism-devnet.md"},l=e(`

    Optimism devnet deep dive

    This page is for those interested in doing a deep dive on their pre-op-plasma-celestia @celestiaorg/optimism rollups.

    Find a transaction

    Now, we'll check for a recent transaction on the L1 with:

    bash
    cast block latest --rpc-url localhost:8545
    cast block latest --rpc-url localhost:8545

    Output of a block that contains a transaction will look like this:

    console
    baseFeePerGas        7
     difficulty           2
     extraData            0xd883010d04846765746888676f312e32312e33856c696e7578000000000000006b3afa42dce1f87f1f07a1ef569c4d43e41738ef93c865098bfa1458645f384e2e4498bcfe4ad9353ff1913a2e16162f496fafe5b0939a6c78fb5b503248d6da01
     gasLimit             30000000
    diff --git a/pr-1815/assets/how-to-guides_optimism-devnet.md.ef6600cc.lean.js b/pr-1815/assets/how-to-guides_optimism-devnet.md.ea2a7388.lean.js
    similarity index 90%
    rename from pr-1815/assets/how-to-guides_optimism-devnet.md.ef6600cc.lean.js
    rename to pr-1815/assets/how-to-guides_optimism-devnet.md.ea2a7388.lean.js
    index dab913a58..650f8e27f 100644
    --- a/pr-1815/assets/how-to-guides_optimism-devnet.md.ef6600cc.lean.js
    +++ b/pr-1815/assets/how-to-guides_optimism-devnet.md.ea2a7388.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Optimism devnet deep dive | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/optimism-devnet.md","filePath":"how-to-guides/optimism-devnet.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/optimism-devnet.md"},l=e("",26),p=[l];function c(t,r,d,i,y,b){return a(),n("div",null,p)}const h=s(o,[["render",c]]);export{f as __pageData,h as default};
    +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Optimism devnet deep dive | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/optimism-devnet.md","filePath":"how-to-guides/optimism-devnet.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/optimism-devnet.md"},l=e("",26),p=[l];function c(t,r,d,i,y,b){return a(),n("div",null,p)}const h=s(o,[["render",c]]);export{f as __pageData,h as default};
    diff --git a/pr-1815/assets/how-to-guides_optimism.md.50d1f609.js b/pr-1815/assets/how-to-guides_optimism.md.b6848def.js
    similarity index 95%
    rename from pr-1815/assets/how-to-guides_optimism.md.50d1f609.js
    rename to pr-1815/assets/how-to-guides_optimism.md.b6848def.js
    index 8eec468ad..fba0d453f 100644
    --- a/pr-1815/assets/how-to-guides_optimism.md.50d1f609.js
    +++ b/pr-1815/assets/how-to-guides_optimism.md.b6848def.js
    @@ -1,4 +1,4 @@
    -import{c as s}from"./chunks/constants.b02263eb.js";import{o as t,c as l,k as a,t as e,l as n,Q as o}from"./chunks/framework.2959b752.js";const p=o('

    Run an OP Stack rollup with Celestia underneath

    This guide will show you how to run your own OP Stack devnet and testnet that posts data to Celestia's Mocha testnet using roll-op and op-plasma-celestia.

    The roll-op tool is used to deploy and manage the OP Stack rollup environment, including the rollup, batcher, and other components. While the op-plasma-celestia integration allows the OP Stack to use Celestia as the data availability (DA) layer.

    This guide is in two parts:

    • First, you'll spin up a mock L1 environment and deploy a devnet that posts data to the Mocha testnet.
    • In the second part, you'll deploy a testnet that posts data to the Mocha testnet, but this time on a real L1 environment; the Ethereum Sepolia testnet. This will involve setting up a configuration file with the necessary details like Sepolia chain ID, RPC URL, and your deployment keys.

    After successful deployments, you'll be able to observe data blobs being successfully submitted to the Mocha testnet in the logs, as well as some activity on your rollup account on Celenium.

    If you don't have devops experience and would like to use a Rollups as a Service (RaaS) provider, see the RaaS category in the menu.

    This guide is also available on YouTube if you'd like to follow along with a video.

    Dependency setup

    Setting up your light node

    Sync and fund a Celestia light node. The light node must be fully synced and funded for you to be able to submit and retrieve PayForBlobs to Mocha Testnet. This allows your rollup to post and retrieve data without any errors.

    In order to mount existing data, you must have a node store that is in the default directory:

    ',13),c={class:"vp-code-group vp-adaptive-theme"},i=o('
    ',1),r={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=a("button",{title:"Copy Code",class:"copy"},null,-1),h=a("span",{class:"lang"},"bash",-1),y={class:"shiki github-dark vp-code-dark"},_={class:"line"},E={style:{color:"#E1E4E8"}},g={class:"shiki github-light vp-code-light"},m={class:"line"},b={style:{color:"#24292E"}},v=o('
    bash
    $HOME/.celestia-light
    $HOME/.celestia-light
    ',1),k={class:"language-bash vp-adaptive-theme"},C=a("button",{title:"Copy Code",class:"copy"},null,-1),f=a("span",{class:"lang"},"bash",-1),q={class:"shiki github-dark vp-code-dark"},F={class:"line"},w={style:{color:"#E1E4E8"}},S={class:"shiki github-light vp-code-light"},T={class:"line"},A={style:{color:"#24292E"}},D=o(`

    By default, the node will run with the account named my_celes_key on Mocha. This is the account that needs to be funded.

    TIP

    Unless you changed your configuration, you won't have to change anything. 😎

    Deploying a devnet to Mocha

    See the Alt-DA x Celestia README for instructions on how to deploy a Devnet.

    TIP for macOS users

    If you are on macOS, you will need to run a venv before starting roll-op.

    sh
    cd $HOME/roll-op
    +import{c as s}from"./chunks/constants.b02263eb.js";import{o as t,c as l,k as a,t as e,l as n,Q as o}from"./chunks/framework.2959b752.js";const p=o('

    Run an OP Stack rollup with Celestia underneath

    This guide will show you how to run your own OP Stack devnet and testnet that posts data to Celestia's Mocha testnet using roll-op and op-plasma-celestia.

    The roll-op tool is used to deploy and manage the OP Stack rollup environment, including the rollup, batcher, and other components. While the op-plasma-celestia integration allows the OP Stack to use Celestia as the data availability (DA) layer.

    This guide is in two parts:

    • First, you'll spin up a mock L1 environment and deploy a devnet that posts data to the Mocha testnet.
    • In the second part, you'll deploy a testnet that posts data to the Mocha testnet, but this time on a real L1 environment; the Ethereum Sepolia testnet. This will involve setting up a configuration file with the necessary details like Sepolia chain ID, RPC URL, and your deployment keys.

    After successful deployments, you'll be able to observe data blobs being successfully submitted to the Mocha testnet in the logs, as well as some activity on your rollup account on Celenium.

    If you don't have devops experience and would like to use a Rollups as a Service (RaaS) provider, see the RaaS category in the menu.

    This guide is also available on YouTube if you'd like to follow along with a video.

    Dependency setup

    Setting up your light node

    Sync and fund a Celestia light node. The light node must be fully synced and funded for you to be able to submit and retrieve PayForBlobs to Mocha Testnet. This allows your rollup to post and retrieve data without any errors.

    In order to mount existing data, you must have a node store that is in the default directory:

    ',13),c={class:"vp-code-group vp-adaptive-theme"},i=o('
    ',1),r={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=a("button",{title:"Copy Code",class:"copy"},null,-1),h=a("span",{class:"lang"},"bash",-1),y={class:"shiki github-dark vp-code-dark"},_={class:"line"},E={style:{color:"#E1E4E8"}},g={class:"shiki github-light vp-code-light"},m={class:"line"},b={style:{color:"#24292E"}},v=o('
    bash
    $HOME/.celestia-light
    $HOME/.celestia-light
    ',1),k={class:"language-bash vp-adaptive-theme"},C=a("button",{title:"Copy Code",class:"copy"},null,-1),f=a("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},q={class:"line"},w={style:{color:"#E1E4E8"}},S={class:"shiki github-light vp-code-light"},T={class:"line"},A={style:{color:"#24292E"}},D=o(`

    By default, the node will run with the account named my_celes_key on Mocha. This is the account that needs to be funded.

    TIP

    Unless you changed your configuration, you won't have to change anything. 😎

    Deploying a devnet to Mocha

    See the Alt-DA x Celestia README for instructions on how to deploy a Devnet.

    TIP for macOS users

    If you are on macOS, you will need to run a venv before starting roll-op.

    sh
    cd $HOME/roll-op
     python3 -m venv ./venv
     source ./venv/bin/activate
    cd $HOME/roll-op
     python3 -m venv ./venv
    @@ -42,4 +42,4 @@ import{c as s}from"./chunks/constants.b02263eb.js";import{o as t,c as l,k as a,t
     admin_account = "0xaddress"
     admin_key = "privatekey"
     p2p_sequencer_account = "0xaddress"
    -p2p_sequencer_key = "privatekey"

    Your 0xaddress key must also be funded with testnet ETH. We recommend at least 10 SepoliaETH to get your chain started, but you will need more to keep it running longer.

    Congratulations

    Congrats! You now have an OP Stack rollup running with Celestia underneath.

    You can learn more about Alt-DA in Optimism docs.

    `,16),R=JSON.parse('{"title":"Run an OP Stack rollup with Celestia underneath","description":"Start your own rollup with op-plasma-celestia and roll-op.","frontmatter":{"description":"Start your own rollup with op-plasma-celestia and roll-op.","head":[["meta",{"property":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"}],["meta",{"property":"og:description","content":"Start your own rollup with op-plasma-celestia and roll-op."}]]},"headers":[],"relativePath":"how-to-guides/optimism.md","filePath":"how-to-guides/optimism.md","lastUpdated":1732776394000}'),M={name:"how-to-guides/optimism.md"},V=Object.assign(M,{setup(P){return(B,x)=>(t(),l("div",null,[p,a("div",c,[i,a("div",r,[a("div",d,[u,h,a("pre",y,[a("code",null,[a("span",_,[a("span",E,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])]),a("pre",g,[a("code",null,[a("span",m,[a("span",b,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])])]),v,a("div",k,[C,f,a("pre",q,[a("code",null,[a("span",F,[a("span",w,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])]),a("pre",S,[a("code",null,[a("span",T,[a("span",A,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])])])])]),D]))}});export{R as __pageData,V as default}; +p2p_sequencer_key = "privatekey"

    Your 0xaddress key must also be funded with testnet ETH. We recommend at least 10 SepoliaETH to get your chain started, but you will need more to keep it running longer.

    Congratulations

    Congrats! You now have an OP Stack rollup running with Celestia underneath.

    You can learn more about Alt-DA in Optimism docs.

    `,16),R=JSON.parse('{"title":"Run an OP Stack rollup with Celestia underneath","description":"Start your own rollup with op-plasma-celestia and roll-op.","frontmatter":{"description":"Start your own rollup with op-plasma-celestia and roll-op.","head":[["meta",{"property":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"}],["meta",{"property":"og:description","content":"Start your own rollup with op-plasma-celestia and roll-op."}]]},"headers":[],"relativePath":"how-to-guides/optimism.md","filePath":"how-to-guides/optimism.md","lastUpdated":1732777479000}'),P={name:"how-to-guides/optimism.md"},V=Object.assign(P,{setup(M){return(B,x)=>(t(),l("div",null,[p,a("div",c,[i,a("div",r,[a("div",d,[u,h,a("pre",y,[a("code",null,[a("span",_,[a("span",E,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])]),a("pre",g,[a("code",null,[a("span",m,[a("span",b,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])])]),v,a("div",k,[C,f,a("pre",F,[a("code",null,[a("span",q,[a("span",w,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])]),a("pre",S,[a("code",null,[a("span",T,[a("span",A,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])])])])]),D]))}});export{R as __pageData,V as default}; diff --git a/pr-1815/assets/how-to-guides_optimism.md.50d1f609.lean.js b/pr-1815/assets/how-to-guides_optimism.md.b6848def.lean.js similarity index 78% rename from pr-1815/assets/how-to-guides_optimism.md.50d1f609.lean.js rename to pr-1815/assets/how-to-guides_optimism.md.b6848def.lean.js index e13090006..af87155a8 100644 --- a/pr-1815/assets/how-to-guides_optimism.md.50d1f609.lean.js +++ b/pr-1815/assets/how-to-guides_optimism.md.b6848def.lean.js @@ -1 +1 @@ -import{c as s}from"./chunks/constants.b02263eb.js";import{o as t,c as l,k as a,t as e,l as n,Q as o}from"./chunks/framework.2959b752.js";const p=o("",13),c={class:"vp-code-group vp-adaptive-theme"},i=o("",1),r={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=a("button",{title:"Copy Code",class:"copy"},null,-1),h=a("span",{class:"lang"},"bash",-1),y={class:"shiki github-dark vp-code-dark"},_={class:"line"},E={style:{color:"#E1E4E8"}},g={class:"shiki github-light vp-code-light"},m={class:"line"},b={style:{color:"#24292E"}},v=o("",1),k={class:"language-bash vp-adaptive-theme"},C=a("button",{title:"Copy Code",class:"copy"},null,-1),f=a("span",{class:"lang"},"bash",-1),q={class:"shiki github-dark vp-code-dark"},F={class:"line"},w={style:{color:"#E1E4E8"}},S={class:"shiki github-light vp-code-light"},T={class:"line"},A={style:{color:"#24292E"}},D=o("",16),R=JSON.parse('{"title":"Run an OP Stack rollup with Celestia underneath","description":"Start your own rollup with op-plasma-celestia and roll-op.","frontmatter":{"description":"Start your own rollup with op-plasma-celestia and roll-op.","head":[["meta",{"property":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"}],["meta",{"property":"og:description","content":"Start your own rollup with op-plasma-celestia and roll-op."}]]},"headers":[],"relativePath":"how-to-guides/optimism.md","filePath":"how-to-guides/optimism.md","lastUpdated":1732776394000}'),M={name:"how-to-guides/optimism.md"},V=Object.assign(M,{setup(P){return(B,x)=>(t(),l("div",null,[p,a("div",c,[i,a("div",r,[a("div",d,[u,h,a("pre",y,[a("code",null,[a("span",_,[a("span",E,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])]),a("pre",g,[a("code",null,[a("span",m,[a("span",b,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])])]),v,a("div",k,[C,f,a("pre",q,[a("code",null,[a("span",F,[a("span",w,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])]),a("pre",S,[a("code",null,[a("span",T,[a("span",A,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])])])])]),D]))}});export{R as __pageData,V as default}; +import{c as s}from"./chunks/constants.b02263eb.js";import{o as t,c as l,k as a,t as e,l as n,Q as o}from"./chunks/framework.2959b752.js";const p=o("",13),c={class:"vp-code-group vp-adaptive-theme"},i=o("",1),r={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=a("button",{title:"Copy Code",class:"copy"},null,-1),h=a("span",{class:"lang"},"bash",-1),y={class:"shiki github-dark vp-code-dark"},_={class:"line"},E={style:{color:"#E1E4E8"}},g={class:"shiki github-light vp-code-light"},m={class:"line"},b={style:{color:"#24292E"}},v=o("",1),k={class:"language-bash vp-adaptive-theme"},C=a("button",{title:"Copy Code",class:"copy"},null,-1),f=a("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},q={class:"line"},w={style:{color:"#E1E4E8"}},S={class:"shiki github-light vp-code-light"},T={class:"line"},A={style:{color:"#24292E"}},D=o("",16),R=JSON.parse('{"title":"Run an OP Stack rollup with Celestia underneath","description":"Start your own rollup with op-plasma-celestia and roll-op.","frontmatter":{"description":"Start your own rollup with op-plasma-celestia and roll-op.","head":[["meta",{"property":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"}],["meta",{"property":"og:description","content":"Start your own rollup with op-plasma-celestia and roll-op."}]]},"headers":[],"relativePath":"how-to-guides/optimism.md","filePath":"how-to-guides/optimism.md","lastUpdated":1732777479000}'),P={name:"how-to-guides/optimism.md"},V=Object.assign(P,{setup(M){return(B,x)=>(t(),l("div",null,[p,a("div",c,[i,a("div",r,[a("div",d,[u,h,a("pre",y,[a("code",null,[a("span",_,[a("span",E,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])]),a("pre",g,[a("code",null,[a("span",m,[a("span",b,"$HOME/.celestia-light-"+e(n(s).mochaChainId),1)])])])]),v,a("div",k,[C,f,a("pre",F,[a("code",null,[a("span",q,[a("span",w,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])]),a("pre",S,[a("code",null,[a("span",T,[a("span",A,"$HOME/.celestia-light-"+e(n(s).arabicaChainId),1)])])])])])]),D]))}});export{R as __pageData,V as default}; diff --git a/pr-1815/assets/how-to-guides_participate.md.090651cf.js b/pr-1815/assets/how-to-guides_participate.md.7ccb450b.js similarity index 98% rename from pr-1815/assets/how-to-guides_participate.md.090651cf.js rename to pr-1815/assets/how-to-guides_participate.md.7ccb450b.js index 882cf5fed..12737ef0e 100644 --- a/pr-1815/assets/how-to-guides_participate.md.090651cf.js +++ b/pr-1815/assets/how-to-guides_participate.md.7ccb450b.js @@ -1 +1 @@ -import{A as t}from"./chunks/ArabicaVersionTags.bc287822.js";import{M as r}from"./chunks/MochaVersionTags.c661f1a2.js";import{M as o}from"./chunks/MainnetVersionTags.45ab5901.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";import"./chunks/constants.b02263eb.js";import"./chunks/mocha_versions.1f7c0f1d.js";import"./chunks/mainnet_versions.f2c187e6.js";const s=e('

    Participate in the Celestia networks

    Mainnet Beta

    Celestia’s Mainnet Beta is the production network for deploying Mainnet Beta rollups and applications. This marks the culmination of years of development and community testing. While the network is stable and continues to receive updates, it remains experimental and users may experience occasional instability or reduced performance.

    Compatible software versions for Mainnet Beta

    ',4),c=e('

    Testnets

    Celestia currently has two existing testnets that you can participate in:

    Arabica Devnet

    Arabica devnet is a devnet focused on developers who want to deploy sovereign rollups on the latest changes from Celestia's codebase. Arabica will be updated frequently and might be unstable at times given new updates. Validators won't be able to validate on Arabica as it is not designed for validators to participate.

    Compatible software versions for Arabica devnet

    ',5),l=e('

    Mocha testnet

    Mocha testnet is a testnet focused on enabling validators to test out their infrastructure by running nodes connected to the network. Developers can also deploy sovereign rollups on Mocha, it just will always be behind Arabica as Mocha upgrades are slower given they need to be done via breaking network upgrades in coordination with the validator community on Mocha.

    Compatible software versions for Mocha testnet

    ',3),h=e('

    Network upgrades

    There are a few ways to stay informed about network upgrades:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    ',4),A=JSON.parse('{"title":"Participate in the Celestia networks","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Participate in the Celestia networks | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/participate.md","filePath":"how-to-guides/participate.md","lastUpdated":1732776394000}'),d={name:"how-to-guides/participate.md"},P=Object.assign(d,{setup(p){return(m,u)=>(n(),i("div",null,[s,a(o),c,a(t),l,a(r),h]))}});export{A as __pageData,P as default}; +import{A as t}from"./chunks/ArabicaVersionTags.bc287822.js";import{M as r}from"./chunks/MochaVersionTags.c661f1a2.js";import{M as o}from"./chunks/MainnetVersionTags.45ab5901.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";import"./chunks/constants.b02263eb.js";import"./chunks/mocha_versions.1f7c0f1d.js";import"./chunks/mainnet_versions.f2c187e6.js";const s=e('

    Participate in the Celestia networks

    Mainnet Beta

    Celestia’s Mainnet Beta is the production network for deploying Mainnet Beta rollups and applications. This marks the culmination of years of development and community testing. While the network is stable and continues to receive updates, it remains experimental and users may experience occasional instability or reduced performance.

    Compatible software versions for Mainnet Beta

    ',4),c=e('

    Testnets

    Celestia currently has two existing testnets that you can participate in:

    Arabica Devnet

    Arabica devnet is a devnet focused on developers who want to deploy sovereign rollups on the latest changes from Celestia's codebase. Arabica will be updated frequently and might be unstable at times given new updates. Validators won't be able to validate on Arabica as it is not designed for validators to participate.

    Compatible software versions for Arabica devnet

    ',5),l=e('

    Mocha testnet

    Mocha testnet is a testnet focused on enabling validators to test out their infrastructure by running nodes connected to the network. Developers can also deploy sovereign rollups on Mocha, it just will always be behind Arabica as Mocha upgrades are slower given they need to be done via breaking network upgrades in coordination with the validator community on Mocha.

    Compatible software versions for Mocha testnet

    ',3),h=e('

    Network upgrades

    There are a few ways to stay informed about network upgrades:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    ',4),A=JSON.parse('{"title":"Participate in the Celestia networks","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Participate in the Celestia networks | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/participate.md","filePath":"how-to-guides/participate.md","lastUpdated":1732777479000}'),d={name:"how-to-guides/participate.md"},P=Object.assign(d,{setup(p){return(m,u)=>(n(),i("div",null,[s,a(o),c,a(t),l,a(r),h]))}});export{A as __pageData,P as default}; diff --git a/pr-1815/assets/how-to-guides_participate.md.090651cf.lean.js b/pr-1815/assets/how-to-guides_participate.md.7ccb450b.lean.js similarity index 93% rename from pr-1815/assets/how-to-guides_participate.md.090651cf.lean.js rename to pr-1815/assets/how-to-guides_participate.md.7ccb450b.lean.js index ddf592b29..14fc980fe 100644 --- a/pr-1815/assets/how-to-guides_participate.md.090651cf.lean.js +++ b/pr-1815/assets/how-to-guides_participate.md.7ccb450b.lean.js @@ -1 +1 @@ -import{A as t}from"./chunks/ArabicaVersionTags.bc287822.js";import{M as r}from"./chunks/MochaVersionTags.c661f1a2.js";import{M as o}from"./chunks/MainnetVersionTags.45ab5901.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";import"./chunks/constants.b02263eb.js";import"./chunks/mocha_versions.1f7c0f1d.js";import"./chunks/mainnet_versions.f2c187e6.js";const s=e("",4),c=e("",5),l=e("",3),h=e("",4),A=JSON.parse('{"title":"Participate in the Celestia networks","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Participate in the Celestia networks | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/participate.md","filePath":"how-to-guides/participate.md","lastUpdated":1732776394000}'),d={name:"how-to-guides/participate.md"},P=Object.assign(d,{setup(p){return(m,u)=>(n(),i("div",null,[s,a(o),c,a(t),l,a(r),h]))}});export{A as __pageData,P as default}; +import{A as t}from"./chunks/ArabicaVersionTags.bc287822.js";import{M as r}from"./chunks/MochaVersionTags.c661f1a2.js";import{M as o}from"./chunks/MainnetVersionTags.45ab5901.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.2959b752.js";import"./chunks/arabica_versions.8cd8d43b.js";import"./chunks/constants.b02263eb.js";import"./chunks/mocha_versions.1f7c0f1d.js";import"./chunks/mainnet_versions.f2c187e6.js";const s=e("",4),c=e("",5),l=e("",3),h=e("",4),A=JSON.parse('{"title":"Participate in the Celestia networks","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Participate in the Celestia networks | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/participate.md","filePath":"how-to-guides/participate.md","lastUpdated":1732777479000}'),d={name:"how-to-guides/participate.md"},P=Object.assign(d,{setup(p){return(m,u)=>(n(),i("div",null,[s,a(o),c,a(t),l,a(r),h]))}});export{A as __pageData,P as default}; diff --git a/pr-1815/assets/how-to-guides_quick-start.md.75f45a26.js b/pr-1815/assets/how-to-guides_quick-start.md.869e21a3.js similarity index 99% rename from pr-1815/assets/how-to-guides_quick-start.md.75f45a26.js rename to pr-1815/assets/how-to-guides_quick-start.md.869e21a3.js index 54b00f8f8..18824a1d1 100644 --- a/pr-1815/assets/how-to-guides_quick-start.md.75f45a26.js +++ b/pr-1815/assets/how-to-guides_quick-start.md.869e21a3.js @@ -48,7 +48,7 @@ import{c as l}from"./chunks/constants.b02263eb.js";import{m as t}from"./chunks/m "commitment": "0x715ab246772c923104c556dc28d5d4fcfca0398b0a252bcd19dd5705495756ac", "index": 29 } -}

    Let's break it down:

    • namespace: The namespace you used to categorize your data.
    • data: The data blob you posted to the network.
    • share_version: The version of the share. A share is a fixed-size data chunk that is associated with exactly one namespace.
    • commitment: The commitment of the data (see Blob Share Commitment Rules).
    • index: The index of the data share in the square.

    Congratulations! You've successfully learned how to run a light node to post and retrieve data from Celestia's Mocha testnet.

    Diving deeper into the stack

    This section covers some more in-depth topics that you may find useful when working with your Celestia light node.

    Get your auth token

    Your auth token may be useful when you want to interact with your Celestia light node from a client application. You can get your auth token by running:

    bash
    celestia light auth admin --p2p.network mocha
    celestia light auth admin --p2p.network mocha

    Use celestia light auth --help to learn more about the available options.

    Key management with cel-key

    In the first part of this guide, we generated a key when we initialized the light node.

    An advanced option for key management is using the cel-key utility, which is a separate tool from the celestia binary. cel-key is a key management tool that allows you to create, import, and manage keys for your Celestia DA node.

    If you're using the quickstart script above, you will have to build cel-key separately from source. You can find the instructions for building cel-key in the celestia-node documentation.

    Rust client tutorial

    If you're interested in writing a Rust program to interact with your Celestia light node, check out the Rust client tutorial.

    Golang client tutorial

    If you're interested in writing a Golang program to interact with your Celestia light node, check out the Golang client tutorial.

    Node store contents

    As described in the initialize the light node section above, the node store is created in the ~/.celestia-<node-type>-<network> directory.

    `,45),la=o('
    • config.toml: Node configuration settings
    • data/: Contains database files
      • .vlog files: Value log files storing actual data
      • .sst files: Static sorted tables containing indexed data
      • System files: DISCARD, KEYREGISTRY, and MANIFEST for database management
    • keys/: Stores node identity and account keys
      • Contains encoded node identifiers
      • keyring-test/: Test keyring directory
        • .address files: Account addresses
        • .info files: Key metadata and information

    Troubleshooting

    If you run into issues, check out the troubleshooting page for common problems and solutions.

    Next steps

    Check out the rollup stacks page to get started learning about ways to build whatever with Celestia underneath.

    Head to the next page to learn about different node types for the consensus and DA networks.

    ',6),da=JSON.parse('{"title":"Quick-start guide","description":"Learn how to get started and post your first blob to Celestia.","frontmatter":{"description":"Learn how to get started and post your first blob to Celestia.","head":[["meta",{"property":"og:title","content":"Quick-start guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to get started and post your first blob to Celestia."}]]},"headers":[],"relativePath":"how-to-guides/quick-start.md","filePath":"how-to-guides/quick-start.md","lastUpdated":1732776394000}'),ta={name:"how-to-guides/quick-start.md"},ha=Object.assign(ta,{setup(pa){return(ca,ra)=>(p(),c("div",null,[r,s("div",i,[y,E,s("pre",d,[s("code",null,[s("span",h,[_,s("span",F,n(e(t)["node-latest-tag"]),1)])])]),s("pre",u,[s("code",null,[s("span",C,[g,s("span",b,n(e(t)["node-latest-tag"]),1)])])])]),m,s("blockquote",null,[s("p",null,[a("The chain ID "),s("code",null,n(e(l).mochaChainId),1),a(" is also an accepted alias.")])]),B,s("div",T,[k,v,s("pre",f,[s("code",null,[s("span",q,[S,s("span",A,"'/Users/js/.celestia-light-"+n(e(l).mochaChainId)+"'",1)]),a(` +}

    Let's break it down:

    • namespace: The namespace you used to categorize your data.
    • data: The data blob you posted to the network.
    • share_version: The version of the share. A share is a fixed-size data chunk that is associated with exactly one namespace.
    • commitment: The commitment of the data (see Blob Share Commitment Rules).
    • index: The index of the data share in the square.

    Congratulations! You've successfully learned how to run a light node to post and retrieve data from Celestia's Mocha testnet.

    Diving deeper into the stack

    This section covers some more in-depth topics that you may find useful when working with your Celestia light node.

    Get your auth token

    Your auth token may be useful when you want to interact with your Celestia light node from a client application. You can get your auth token by running:

    bash
    celestia light auth admin --p2p.network mocha
    celestia light auth admin --p2p.network mocha

    Use celestia light auth --help to learn more about the available options.

    Key management with cel-key

    In the first part of this guide, we generated a key when we initialized the light node.

    An advanced option for key management is using the cel-key utility, which is a separate tool from the celestia binary. cel-key is a key management tool that allows you to create, import, and manage keys for your Celestia DA node.

    If you're using the quickstart script above, you will have to build cel-key separately from source. You can find the instructions for building cel-key in the celestia-node documentation.

    Rust client tutorial

    If you're interested in writing a Rust program to interact with your Celestia light node, check out the Rust client tutorial.

    Golang client tutorial

    If you're interested in writing a Golang program to interact with your Celestia light node, check out the Golang client tutorial.

    Node store contents

    As described in the initialize the light node section above, the node store is created in the ~/.celestia-<node-type>-<network> directory.

    `,45),la=o('
    • config.toml: Node configuration settings
    • data/: Contains database files
      • .vlog files: Value log files storing actual data
      • .sst files: Static sorted tables containing indexed data
      • System files: DISCARD, KEYREGISTRY, and MANIFEST for database management
    • keys/: Stores node identity and account keys
      • Contains encoded node identifiers
      • keyring-test/: Test keyring directory
        • .address files: Account addresses
        • .info files: Key metadata and information

    Troubleshooting

    If you run into issues, check out the troubleshooting page for common problems and solutions.

    Next steps

    Check out the rollup stacks page to get started learning about ways to build whatever with Celestia underneath.

    Head to the next page to learn about different node types for the consensus and DA networks.

    ',6),da=JSON.parse('{"title":"Quick-start guide","description":"Learn how to get started and post your first blob to Celestia.","frontmatter":{"description":"Learn how to get started and post your first blob to Celestia.","head":[["meta",{"property":"og:title","content":"Quick-start guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to get started and post your first blob to Celestia."}]]},"headers":[],"relativePath":"how-to-guides/quick-start.md","filePath":"how-to-guides/quick-start.md","lastUpdated":1732777479000}'),ta={name:"how-to-guides/quick-start.md"},ha=Object.assign(ta,{setup(pa){return(ca,ra)=>(p(),c("div",null,[r,s("div",i,[y,E,s("pre",d,[s("code",null,[s("span",h,[_,s("span",F,n(e(t)["node-latest-tag"]),1)])])]),s("pre",u,[s("code",null,[s("span",C,[g,s("span",b,n(e(t)["node-latest-tag"]),1)])])])]),m,s("blockquote",null,[s("p",null,[a("The chain ID "),s("code",null,n(e(l).mochaChainId),1),a(" is also an accepted alias.")])]),B,s("div",T,[k,v,s("pre",f,[s("code",null,[s("span",q,[S,s("span",A,"'/Users/js/.celestia-light-"+n(e(l).mochaChainId)+"'",1)]),a(` `),s("span",I,[w,s("span",P,'"/Users/js/.celestia-light-'+n(e(l).mochaChainId)+'/config.toml"}',1)]),a(` `),N,a(` `),D,a(` diff --git a/pr-1815/assets/how-to-guides_quick-start.md.75f45a26.lean.js b/pr-1815/assets/how-to-guides_quick-start.md.869e21a3.lean.js similarity index 99% rename from pr-1815/assets/how-to-guides_quick-start.md.75f45a26.lean.js rename to pr-1815/assets/how-to-guides_quick-start.md.869e21a3.lean.js index 25162d035..77d291e11 100644 --- a/pr-1815/assets/how-to-guides_quick-start.md.75f45a26.lean.js +++ b/pr-1815/assets/how-to-guides_quick-start.md.869e21a3.lean.js @@ -1,4 +1,4 @@ -import{c as l}from"./chunks/constants.b02263eb.js";import{m as t}from"./chunks/mocha_versions.1f7c0f1d.js";import{o as p,c,k as s,t as n,l as e,a,Q as o}from"./chunks/framework.2959b752.js";const r=o("",7),i={class:"language-bash vp-adaptive-theme"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),d={class:"shiki github-dark vp-code-dark"},h={class:"line"},_=o("",14),F={style:{color:"#9ECBFF"}},u={class:"shiki github-light vp-code-light"},C={class:"line"},g=o("",14),b={style:{color:"#032F62"}},m=o("",6),B=o("",2),T={class:"language-bash vp-adaptive-theme"},k=s("button",{title:"Copy Code",class:"copy"},null,-1),v=s("span",{class:"lang"},"bash",-1),f={class:"shiki github-dark vp-code-dark"},q={class:"line"},S=o("",16),A={style:{color:"#9ECBFF"}},I={class:"line"},w=o("",12),P={style:{color:"#9ECBFF"}},N=o("",1),D=o("",1),V={class:"line"},R=o("",24),x={style:{color:"#9ECBFF"}},O=o("",1),H=s("span",{class:"line"},null,-1),L=s("span",{class:"line"},[s("span",{style:{color:"#B392F0"}},"NAME:"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"my_celes_key")],-1),U=s("span",{class:"line"},[s("span",{style:{color:"#B392F0"}},"ADDRESS:"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"celestia1lgvzg4ek9v499pl5vvsvqpquhwfg0jznpwd92m")],-1),z=o("",1),G=o("",1),j=s("span",{class:"line"},null,-1),Y=o("",1),M={class:"shiki github-light vp-code-light"},$={class:"line"},K=o("",16),W={style:{color:"#032F62"}},Q={class:"line"},J=o("",12),X={style:{color:"#032F62"}},Z=o("",1),ss=o("",1),as={class:"line"},os=o("",24),ns={style:{color:"#032F62"}},es=o("",1),ls=s("span",{class:"line"},null,-1),ts=s("span",{class:"line"},[s("span",{style:{color:"#6F42C1"}},"NAME:"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"my_celes_key")],-1),ps=s("span",{class:"line"},[s("span",{style:{color:"#6F42C1"}},"ADDRESS:"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"celestia1lgvzg4ek9v499pl5vvsvqpquhwfg0jznpwd92m")],-1),cs=o("",1),rs=o("",1),is=s("span",{class:"line"},null,-1),ys=o("",1),Es=s("blockquote",null,[s("p",null,"Logs above have the timestamps removed for brevity. And yes, that's a Rickroll mnemonic. 😜")],-1),ds=s("h4",{id:"set-the-trusted-hash",tabindex:"-1"},[a("Set the trusted hash "),s("a",{class:"header-anchor",href:"#set-the-trusted-hash","aria-label":'Permalink to "Set the trusted hash"'},"​")],-1),hs=s("p",null,[a("Setting and syncing to a trusted hash and height means your light node will not sample the entire chain. This is useful when you want to sync your light node quickly. However, it's important to note that this adds the trust assumption that you trust the entity where you get the hash and height from, in this case, the "),s("a",{href:"https://pops.one",target:"_blank",rel:"noreferrer"},"P-OPS"),a(" team's consensus endpoint.")],-1),_s=s("p",null,"Let's set the trusted hash!",-1),Fs=o("",1),us=s("p",null,"Set the trusted height & hash",-1),Cs=s("code",null,"config.toml",-1),gs=s("li",null,[a("Set "),s("code",null,"DASer.SampleFrom"),a(" to the trusted height (e.g. "),s("code",null,"SampleFrom = 123456"),a(")")],-1),bs=o("",7),ms={class:"language-bash vp-adaptive-theme"},Bs=s("button",{title:"Copy Code",class:"copy"},null,-1),Ts=s("span",{class:"lang"},"bash",-1),ks={class:"shiki github-dark vp-code-dark"},vs=o("",1),fs=s("span",{class:"line"},null,-1),qs=o("",1),Ss={class:"line"},As=s("span",{style:{color:"#B392F0"}},"node",-1),Is=s("span",{style:{color:"#E1E4E8"}}," ",-1),ws=s("span",{style:{color:"#9ECBFF"}},"version:",-1),Ps=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ns={style:{color:"#9ECBFF"}},Ds=o("",1),Vs={class:"line"},Rs=s("span",{style:{color:"#B392F0"}},"network:",-1),xs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Os={style:{color:"#9ECBFF"}},Hs=s("span",{class:"line"},null,-1),Ls=o("",1),Us={class:"shiki github-light vp-code-light"},zs=o("",1),Gs=s("span",{class:"line"},null,-1),js=o("",1),Ys={class:"line"},Ms=s("span",{style:{color:"#6F42C1"}},"node",-1),$s=s("span",{style:{color:"#24292E"}}," ",-1),Ks=s("span",{style:{color:"#032F62"}},"version:",-1),Ws=s("span",{style:{color:"#24292E"}}," ",-1),Qs={style:{color:"#032F62"}},Js=o("",1),Xs={class:"line"},Zs=s("span",{style:{color:"#6F42C1"}},"network:",-1),sa=s("span",{style:{color:"#24292E"}}," ",-1),aa={style:{color:"#032F62"}},oa=s("span",{class:"line"},null,-1),na=o("",1),ea=o("",45),la=o("",6),da=JSON.parse('{"title":"Quick-start guide","description":"Learn how to get started and post your first blob to Celestia.","frontmatter":{"description":"Learn how to get started and post your first blob to Celestia.","head":[["meta",{"property":"og:title","content":"Quick-start guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to get started and post your first blob to Celestia."}]]},"headers":[],"relativePath":"how-to-guides/quick-start.md","filePath":"how-to-guides/quick-start.md","lastUpdated":1732776394000}'),ta={name:"how-to-guides/quick-start.md"},ha=Object.assign(ta,{setup(pa){return(ca,ra)=>(p(),c("div",null,[r,s("div",i,[y,E,s("pre",d,[s("code",null,[s("span",h,[_,s("span",F,n(e(t)["node-latest-tag"]),1)])])]),s("pre",u,[s("code",null,[s("span",C,[g,s("span",b,n(e(t)["node-latest-tag"]),1)])])])]),m,s("blockquote",null,[s("p",null,[a("The chain ID "),s("code",null,n(e(l).mochaChainId),1),a(" is also an accepted alias.")])]),B,s("div",T,[k,v,s("pre",f,[s("code",null,[s("span",q,[S,s("span",A,"'/Users/js/.celestia-light-"+n(e(l).mochaChainId)+"'",1)]),a(` +import{c as l}from"./chunks/constants.b02263eb.js";import{m as t}from"./chunks/mocha_versions.1f7c0f1d.js";import{o as p,c,k as s,t as n,l as e,a,Q as o}from"./chunks/framework.2959b752.js";const r=o("",7),i={class:"language-bash vp-adaptive-theme"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),E=s("span",{class:"lang"},"bash",-1),d={class:"shiki github-dark vp-code-dark"},h={class:"line"},_=o("",14),F={style:{color:"#9ECBFF"}},u={class:"shiki github-light vp-code-light"},C={class:"line"},g=o("",14),b={style:{color:"#032F62"}},m=o("",6),B=o("",2),T={class:"language-bash vp-adaptive-theme"},k=s("button",{title:"Copy Code",class:"copy"},null,-1),v=s("span",{class:"lang"},"bash",-1),f={class:"shiki github-dark vp-code-dark"},q={class:"line"},S=o("",16),A={style:{color:"#9ECBFF"}},I={class:"line"},w=o("",12),P={style:{color:"#9ECBFF"}},N=o("",1),D=o("",1),V={class:"line"},R=o("",24),x={style:{color:"#9ECBFF"}},O=o("",1),H=s("span",{class:"line"},null,-1),L=s("span",{class:"line"},[s("span",{style:{color:"#B392F0"}},"NAME:"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"my_celes_key")],-1),U=s("span",{class:"line"},[s("span",{style:{color:"#B392F0"}},"ADDRESS:"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"celestia1lgvzg4ek9v499pl5vvsvqpquhwfg0jznpwd92m")],-1),z=o("",1),G=o("",1),j=s("span",{class:"line"},null,-1),Y=o("",1),M={class:"shiki github-light vp-code-light"},$={class:"line"},K=o("",16),W={style:{color:"#032F62"}},Q={class:"line"},J=o("",12),X={style:{color:"#032F62"}},Z=o("",1),ss=o("",1),as={class:"line"},os=o("",24),ns={style:{color:"#032F62"}},es=o("",1),ls=s("span",{class:"line"},null,-1),ts=s("span",{class:"line"},[s("span",{style:{color:"#6F42C1"}},"NAME:"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"my_celes_key")],-1),ps=s("span",{class:"line"},[s("span",{style:{color:"#6F42C1"}},"ADDRESS:"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"celestia1lgvzg4ek9v499pl5vvsvqpquhwfg0jznpwd92m")],-1),cs=o("",1),rs=o("",1),is=s("span",{class:"line"},null,-1),ys=o("",1),Es=s("blockquote",null,[s("p",null,"Logs above have the timestamps removed for brevity. And yes, that's a Rickroll mnemonic. 😜")],-1),ds=s("h4",{id:"set-the-trusted-hash",tabindex:"-1"},[a("Set the trusted hash "),s("a",{class:"header-anchor",href:"#set-the-trusted-hash","aria-label":'Permalink to "Set the trusted hash"'},"​")],-1),hs=s("p",null,[a("Setting and syncing to a trusted hash and height means your light node will not sample the entire chain. This is useful when you want to sync your light node quickly. However, it's important to note that this adds the trust assumption that you trust the entity where you get the hash and height from, in this case, the "),s("a",{href:"https://pops.one",target:"_blank",rel:"noreferrer"},"P-OPS"),a(" team's consensus endpoint.")],-1),_s=s("p",null,"Let's set the trusted hash!",-1),Fs=o("",1),us=s("p",null,"Set the trusted height & hash",-1),Cs=s("code",null,"config.toml",-1),gs=s("li",null,[a("Set "),s("code",null,"DASer.SampleFrom"),a(" to the trusted height (e.g. "),s("code",null,"SampleFrom = 123456"),a(")")],-1),bs=o("",7),ms={class:"language-bash vp-adaptive-theme"},Bs=s("button",{title:"Copy Code",class:"copy"},null,-1),Ts=s("span",{class:"lang"},"bash",-1),ks={class:"shiki github-dark vp-code-dark"},vs=o("",1),fs=s("span",{class:"line"},null,-1),qs=o("",1),Ss={class:"line"},As=s("span",{style:{color:"#B392F0"}},"node",-1),Is=s("span",{style:{color:"#E1E4E8"}}," ",-1),ws=s("span",{style:{color:"#9ECBFF"}},"version:",-1),Ps=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ns={style:{color:"#9ECBFF"}},Ds=o("",1),Vs={class:"line"},Rs=s("span",{style:{color:"#B392F0"}},"network:",-1),xs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Os={style:{color:"#9ECBFF"}},Hs=s("span",{class:"line"},null,-1),Ls=o("",1),Us={class:"shiki github-light vp-code-light"},zs=o("",1),Gs=s("span",{class:"line"},null,-1),js=o("",1),Ys={class:"line"},Ms=s("span",{style:{color:"#6F42C1"}},"node",-1),$s=s("span",{style:{color:"#24292E"}}," ",-1),Ks=s("span",{style:{color:"#032F62"}},"version:",-1),Ws=s("span",{style:{color:"#24292E"}}," ",-1),Qs={style:{color:"#032F62"}},Js=o("",1),Xs={class:"line"},Zs=s("span",{style:{color:"#6F42C1"}},"network:",-1),sa=s("span",{style:{color:"#24292E"}}," ",-1),aa={style:{color:"#032F62"}},oa=s("span",{class:"line"},null,-1),na=o("",1),ea=o("",45),la=o("",6),da=JSON.parse('{"title":"Quick-start guide","description":"Learn how to get started and post your first blob to Celestia.","frontmatter":{"description":"Learn how to get started and post your first blob to Celestia.","head":[["meta",{"property":"og:title","content":"Quick-start guide | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to get started and post your first blob to Celestia."}]]},"headers":[],"relativePath":"how-to-guides/quick-start.md","filePath":"how-to-guides/quick-start.md","lastUpdated":1732777479000}'),ta={name:"how-to-guides/quick-start.md"},ha=Object.assign(ta,{setup(pa){return(ca,ra)=>(p(),c("div",null,[r,s("div",i,[y,E,s("pre",d,[s("code",null,[s("span",h,[_,s("span",F,n(e(t)["node-latest-tag"]),1)])])]),s("pre",u,[s("code",null,[s("span",C,[g,s("span",b,n(e(t)["node-latest-tag"]),1)])])])]),m,s("blockquote",null,[s("p",null,[a("The chain ID "),s("code",null,n(e(l).mochaChainId),1),a(" is also an accepted alias.")])]),B,s("div",T,[k,v,s("pre",f,[s("code",null,[s("span",q,[S,s("span",A,"'/Users/js/.celestia-light-"+n(e(l).mochaChainId)+"'",1)]),a(` `),s("span",I,[w,s("span",P,'"/Users/js/.celestia-light-'+n(e(l).mochaChainId)+'/config.toml"}',1)]),a(` `),N,a(` `),D,a(` diff --git a/pr-1815/assets/how-to-guides_rollup-stacks.md.7b355d9c.js b/pr-1815/assets/how-to-guides_rollup-stacks.md.ac8fa6e2.js similarity index 99% rename from pr-1815/assets/how-to-guides_rollup-stacks.md.7b355d9c.js rename to pr-1815/assets/how-to-guides_rollup-stacks.md.ac8fa6e2.js index 8cac1cb28..b105d23fa 100644 --- a/pr-1815/assets/how-to-guides_rollup-stacks.md.7b355d9c.js +++ b/pr-1815/assets/how-to-guides_rollup-stacks.md.ac8fa6e2.js @@ -1 +1 @@ -import{_ as p,o as l,c as r,k as t,t as i,e as d,H as e,Q as s,a as n}from"./chunks/framework.2959b752.js";const h="/docs-preview/pr-1815/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},g=["href"],b={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function _(c,u,o,R,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",b,[t("img",{src:o.imageSrc,alt:"",class:"button-icon"},null,8,f),t("span",y,i(o.text),1),o.notes?(l(),r("span",k,i(o.notes),1)):d("",!0)])],8,g)}const a=p(m,[["render",_],["__scopeId","data-v-21baf7e3"]]),w=s('

    Rollup stacks

    If you're a developer and want to know what the benefits of modular blockchains are for you, you’ve come to the right place. This page will give you the rundown on modular blockchains and their benefits for developers like you.

    This section provides various guides and tutorials that cover different options for deploying rollups on Celestia.

    Quickstart - Building on Celestia

    Choose a framework

    So, you’re ready to start experimenting and building on Celestia? Here are a few options that are currently available for developers.

    ',6),x={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},v=t("h3",{id:"rollups-as-a-service",tabindex:"-1"},[n("Rollups as a Service "),t("a",{class:"header-anchor",href:"#rollups-as-a-service","aria-label":'Permalink to "Rollups as a Service"'},"​")],-1),S=t("p",null,"Deploy your rollup with a RaaS provider.",-1),C={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},P=t("h3",{id:"smart-contracts",tabindex:"-1"},[n("Smart contracts "),t("a",{class:"header-anchor",href:"#smart-contracts","aria-label":'Permalink to "Smart contracts"'},"​")],-1),A=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),q={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},V=s('

    What is a rollup?

    A rollup is a type of blockchain that offloads some work to a layer 1, like Celestia. Rollups host applications and process user transactions. Once those transactions get processed, they are then published to layer 1. It’s layer 1s job to order those transactions and check that they are available, at minimum.

    What is a modular blockchain?

    With blockchains there are more or less four core functions that they do.

    • Execution: transaction execution and state update.
    • Settlement: finality and dispute resolution.
    • Consensus: agreement on transaction ordering.
    • Data availability: prove data was published to the network.

    Modular blockchains specialize in one or two of these functions rather than doing all of them like a monolithic blockchain. You probably know about layer 1s and layer 2s. That’s the general idea.

    A typical example of a modular blockchain you might’ve heard of is a rollup. Rollups host smart contracts and execute transactions, much like any monolithic chain. But, the data of those transactions get sent to a layer 1 blockchain to carry out the remaining functions.

    If you want to brush up on your understanding of modular blockchains, head over to learn modular.

    Benefits of modular blockchains

    Ease of deploying a chain

    One of the goals of modular blockchains is to make it as easy to deploy a blockchain as a smart contract. There are a few unique ways that modular blockchains can significantly reduce the cost of deploying a new blockchain.

    1. No validator set is required. Rollups can deploy without sourcing their own set of validators or sequencers.
    2. Inherit security from the start. Rollups don’t need to build all their security from scratch.
    3. Any part of the stack can be delegated. Development time can be reduced by outsourcing functions of the rollup to external providers.

    All in all, builders will be able to outsource as much of the stack as they need. Deploying a new blockchain will be as simple as clicking a few options to initialize a production-ready rollup.

    Scaling

    Of course, a much higher scale is necessary if we want to support many more users. And modular blockchains use some new innovative technologies that can help us get there.

    • Data availability sampling enables modular blockchains like Celestia to scale data availability with the number of light nodes - that means more capacity for rollups.
    • Fraud and validity proofs make rollups vastly more efficient to verify. Nodes only need to verify a small proof of transaction validity (validity proof) or assume transactions are valid by default (fraud proof). This means rollups don’t require every node in the network to re-execute every transaction.

    image

    • Decoupling execution from consensus lets developers define the VM that best fits the scaling needs of their application.
    • Separating applications across multiple rollups isolates congestion. If an application congests the execution capacity of one rollup, all other rollups remain unaffected in their execution capacity.

    All these scaling properties combined make new types of applications and features possible, like onchain gaming, dynamic metadata, and ephemeral rollups, to name a few.

    Customizability

    By design, modular blockchains don’t lock in any feature set. They promote experimentation and customization.

    Remember how decoupling execution from consensus enables VM customizability? Well, rollups are the execution component. Applications can run on their own rollup and adjust the VM to maximize their application's performance. Developers have that flexibility because Celestia's execution logic doesn't restrict rollups.

    Basically, rollups can be customized to integrate any new or existing VM stack.

    With existing rollup frameworks, developers can run rollup testnets using the EVM or Cosmos SDK. In the future, one can imagine a variety of VMs that rollup frameworks support, providing developers with more out-of-the-box options for their applications.

    Some customizations that could be made to a rollup's VM include custom precompiles, changing transaction processing from sequential to parallel, or adding support for private smart contracts.

    All of this only scratches the surface.

    ',26),B=JSON.parse('{"title":"Rollup stacks","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"property":"og:title","content":"Rollup stacks | Celestia Docs"}],["meta",{"property":"og:description","content":"Advantages of building on modular blockchains like Celestia."}]]},"headers":[],"relativePath":"how-to-guides/rollup-stacks.md","filePath":"how-to-guides/rollup-stacks.md","lastUpdated":1732776394000}'),O={name:"how-to-guides/rollup-stacks.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[w,t("div",x,[e(a,{url:"/how-to-guides/intro-to-op-stack",imageSrc:"/build/opstack.webp",text:"OP Stack",notes:"EVM",target:"_self",alt:"OP Stack logo","aria-label":"OP Stack"}),e(a,{url:"/how-to-guides/arbitrum-integration",imageSrc:"/build/arbitrum.webp",text:"Arbitrum Orbit",notes:"EVM",target:"_self",alt:"Arbitrum logo","aria-label":"Arbitrum"}),e(a,{url:"https://github.com/Sovereign-Labs/sovereign-sdk/tree/stable/examples/demo-rollup#demo-rollup",imageSrc:"/build/sovereign.webp",text:"Sovereign SDK",notes:"Sovereign",alt:"Sovereign logo","aria-label":"Sovereign"}),e(a,{url:"https://docs.dymension.xyz/",imageSrc:"/build/dymension.webp",text:"Dymension",alt:"Dymension logo","aria-label":"Dymension"}),e(a,{url:"https://docs.stf.xyz",imageSrc:"/build/stackr.webp",text:"Stackr",alt:"Stackr logo","aria-label":"Stackr"}),e(a,{url:"https://rollkit.dev",imageSrc:"/build/rollkit.webp",text:"Rollkit",notes:"Sovereign",alt:"Rollkit logo","aria-label":"Rollkit"})]),v,S,t("div",C,[e(a,{url:"https://altlayer.io/raas/",imageSrc:"/build/altlayer.webp",text:"AltLayer",notes:"Orbit, OP Stack",alt:"AltLayer logo","aria-label":"AltLayer"}),e(a,{url:"https://www.astria.org/",imageSrc:"/build/astria.webp",text:"Astria",alt:"Astria logo","aria-label":"Astria"}),e(a,{url:"https://www.caldera.xyz/",imageSrc:"/build/caldera.webp",text:"Caldera",notes:"Orbit, OP Stack",alt:"Caldera logo","aria-label":"Caldera"}),e(a,{url:"https://conduit.xyz/",imageSrc:"/build/conduit.webp",text:"Conduit",notes:"Orbit, OP Stack",alt:"Conduit logo","aria-label":"Conduit"}),e(a,{url:"https://www.gelato.network/",imageSrc:"/build/gelato.webp",text:"Gelato",notes:"Orbit, OP Stack",alt:"Gelato logo","aria-label":"Gelato"}),e(a,{url:"https://www.karnot.xyz/",imageSrc:"/build/karnot.webp",text:"Karnot",notes:"Starknet",alt:"Karnot logo","aria-label":"Karnot"}),e(a,{url:"https://docs.vistara.dev/",imageSrc:"/build/vistara.webp",text:"Vistara",alt:"Vistara logo","aria-label":"Vistara"}),e(a,{url:"https://www.zeeve.io/",imageSrc:"/build/zeeve.webp",text:"Zeeve",notes:"Orbit, OP Stack",alt:"Zeeve logo","aria-label":"Zeeve"})]),P,A,t("div",q,[e(a,{url:"https://bubstestnet.com/",imageSrc:"/build/caldera.webp",text:"Bubs testnet",notes:"OP Stack",alt:"Caldera logo","aria-label":"Caldera Bubs testnet"}),e(a,{url:"https://raas.gelato.network/rollups/details/public/opcelestia-raspberry",imageSrc:"/build/gelato.webp",text:"Raspberry testnet",notes:"OP Stack",alt:"Gelato logo","aria-label":"Gelato Raspberry testnet"})]),V]))}});export{B as __pageData,I as default}; +import{_ as p,o as l,c as r,k as t,t as i,e as d,H as e,Q as s,a as n}from"./chunks/framework.2959b752.js";const h="/docs-preview/pr-1815/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},g=["href"],b={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function _(c,u,o,R,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",b,[t("img",{src:o.imageSrc,alt:"",class:"button-icon"},null,8,f),t("span",y,i(o.text),1),o.notes?(l(),r("span",k,i(o.notes),1)):d("",!0)])],8,g)}const a=p(m,[["render",_],["__scopeId","data-v-21baf7e3"]]),w=s('

    Rollup stacks

    If you're a developer and want to know what the benefits of modular blockchains are for you, you’ve come to the right place. This page will give you the rundown on modular blockchains and their benefits for developers like you.

    This section provides various guides and tutorials that cover different options for deploying rollups on Celestia.

    Quickstart - Building on Celestia

    Choose a framework

    So, you’re ready to start experimenting and building on Celestia? Here are a few options that are currently available for developers.

    ',6),x={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},v=t("h3",{id:"rollups-as-a-service",tabindex:"-1"},[n("Rollups as a Service "),t("a",{class:"header-anchor",href:"#rollups-as-a-service","aria-label":'Permalink to "Rollups as a Service"'},"​")],-1),S=t("p",null,"Deploy your rollup with a RaaS provider.",-1),C={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},P=t("h3",{id:"smart-contracts",tabindex:"-1"},[n("Smart contracts "),t("a",{class:"header-anchor",href:"#smart-contracts","aria-label":'Permalink to "Smart contracts"'},"​")],-1),A=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),q={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},V=s('

    What is a rollup?

    A rollup is a type of blockchain that offloads some work to a layer 1, like Celestia. Rollups host applications and process user transactions. Once those transactions get processed, they are then published to layer 1. It’s layer 1s job to order those transactions and check that they are available, at minimum.

    What is a modular blockchain?

    With blockchains there are more or less four core functions that they do.

    • Execution: transaction execution and state update.
    • Settlement: finality and dispute resolution.
    • Consensus: agreement on transaction ordering.
    • Data availability: prove data was published to the network.

    Modular blockchains specialize in one or two of these functions rather than doing all of them like a monolithic blockchain. You probably know about layer 1s and layer 2s. That’s the general idea.

    A typical example of a modular blockchain you might’ve heard of is a rollup. Rollups host smart contracts and execute transactions, much like any monolithic chain. But, the data of those transactions get sent to a layer 1 blockchain to carry out the remaining functions.

    If you want to brush up on your understanding of modular blockchains, head over to learn modular.

    Benefits of modular blockchains

    Ease of deploying a chain

    One of the goals of modular blockchains is to make it as easy to deploy a blockchain as a smart contract. There are a few unique ways that modular blockchains can significantly reduce the cost of deploying a new blockchain.

    1. No validator set is required. Rollups can deploy without sourcing their own set of validators or sequencers.
    2. Inherit security from the start. Rollups don’t need to build all their security from scratch.
    3. Any part of the stack can be delegated. Development time can be reduced by outsourcing functions of the rollup to external providers.

    All in all, builders will be able to outsource as much of the stack as they need. Deploying a new blockchain will be as simple as clicking a few options to initialize a production-ready rollup.

    Scaling

    Of course, a much higher scale is necessary if we want to support many more users. And modular blockchains use some new innovative technologies that can help us get there.

    • Data availability sampling enables modular blockchains like Celestia to scale data availability with the number of light nodes - that means more capacity for rollups.
    • Fraud and validity proofs make rollups vastly more efficient to verify. Nodes only need to verify a small proof of transaction validity (validity proof) or assume transactions are valid by default (fraud proof). This means rollups don’t require every node in the network to re-execute every transaction.

    image

    • Decoupling execution from consensus lets developers define the VM that best fits the scaling needs of their application.
    • Separating applications across multiple rollups isolates congestion. If an application congests the execution capacity of one rollup, all other rollups remain unaffected in their execution capacity.

    All these scaling properties combined make new types of applications and features possible, like onchain gaming, dynamic metadata, and ephemeral rollups, to name a few.

    Customizability

    By design, modular blockchains don’t lock in any feature set. They promote experimentation and customization.

    Remember how decoupling execution from consensus enables VM customizability? Well, rollups are the execution component. Applications can run on their own rollup and adjust the VM to maximize their application's performance. Developers have that flexibility because Celestia's execution logic doesn't restrict rollups.

    Basically, rollups can be customized to integrate any new or existing VM stack.

    With existing rollup frameworks, developers can run rollup testnets using the EVM or Cosmos SDK. In the future, one can imagine a variety of VMs that rollup frameworks support, providing developers with more out-of-the-box options for their applications.

    Some customizations that could be made to a rollup's VM include custom precompiles, changing transaction processing from sequential to parallel, or adding support for private smart contracts.

    All of this only scratches the surface.

    ',26),B=JSON.parse('{"title":"Rollup stacks","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"property":"og:title","content":"Rollup stacks | Celestia Docs"}],["meta",{"property":"og:description","content":"Advantages of building on modular blockchains like Celestia."}]]},"headers":[],"relativePath":"how-to-guides/rollup-stacks.md","filePath":"how-to-guides/rollup-stacks.md","lastUpdated":1732777479000}'),O={name:"how-to-guides/rollup-stacks.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[w,t("div",x,[e(a,{url:"/how-to-guides/intro-to-op-stack",imageSrc:"/build/opstack.webp",text:"OP Stack",notes:"EVM",target:"_self",alt:"OP Stack logo","aria-label":"OP Stack"}),e(a,{url:"/how-to-guides/arbitrum-integration",imageSrc:"/build/arbitrum.webp",text:"Arbitrum Orbit",notes:"EVM",target:"_self",alt:"Arbitrum logo","aria-label":"Arbitrum"}),e(a,{url:"https://github.com/Sovereign-Labs/sovereign-sdk/tree/stable/examples/demo-rollup#demo-rollup",imageSrc:"/build/sovereign.webp",text:"Sovereign SDK",notes:"Sovereign",alt:"Sovereign logo","aria-label":"Sovereign"}),e(a,{url:"https://docs.dymension.xyz/",imageSrc:"/build/dymension.webp",text:"Dymension",alt:"Dymension logo","aria-label":"Dymension"}),e(a,{url:"https://docs.stf.xyz",imageSrc:"/build/stackr.webp",text:"Stackr",alt:"Stackr logo","aria-label":"Stackr"}),e(a,{url:"https://rollkit.dev",imageSrc:"/build/rollkit.webp",text:"Rollkit",notes:"Sovereign",alt:"Rollkit logo","aria-label":"Rollkit"})]),v,S,t("div",C,[e(a,{url:"https://altlayer.io/raas/",imageSrc:"/build/altlayer.webp",text:"AltLayer",notes:"Orbit, OP Stack",alt:"AltLayer logo","aria-label":"AltLayer"}),e(a,{url:"https://www.astria.org/",imageSrc:"/build/astria.webp",text:"Astria",alt:"Astria logo","aria-label":"Astria"}),e(a,{url:"https://www.caldera.xyz/",imageSrc:"/build/caldera.webp",text:"Caldera",notes:"Orbit, OP Stack",alt:"Caldera logo","aria-label":"Caldera"}),e(a,{url:"https://conduit.xyz/",imageSrc:"/build/conduit.webp",text:"Conduit",notes:"Orbit, OP Stack",alt:"Conduit logo","aria-label":"Conduit"}),e(a,{url:"https://www.gelato.network/",imageSrc:"/build/gelato.webp",text:"Gelato",notes:"Orbit, OP Stack",alt:"Gelato logo","aria-label":"Gelato"}),e(a,{url:"https://www.karnot.xyz/",imageSrc:"/build/karnot.webp",text:"Karnot",notes:"Starknet",alt:"Karnot logo","aria-label":"Karnot"}),e(a,{url:"https://docs.vistara.dev/",imageSrc:"/build/vistara.webp",text:"Vistara",alt:"Vistara logo","aria-label":"Vistara"}),e(a,{url:"https://www.zeeve.io/",imageSrc:"/build/zeeve.webp",text:"Zeeve",notes:"Orbit, OP Stack",alt:"Zeeve logo","aria-label":"Zeeve"})]),P,A,t("div",q,[e(a,{url:"https://bubstestnet.com/",imageSrc:"/build/caldera.webp",text:"Bubs testnet",notes:"OP Stack",alt:"Caldera logo","aria-label":"Caldera Bubs testnet"}),e(a,{url:"https://raas.gelato.network/rollups/details/public/opcelestia-raspberry",imageSrc:"/build/gelato.webp",text:"Raspberry testnet",notes:"OP Stack",alt:"Gelato logo","aria-label":"Gelato Raspberry testnet"})]),V]))}});export{B as __pageData,I as default}; diff --git a/pr-1815/assets/how-to-guides_rollup-stacks.md.7b355d9c.lean.js b/pr-1815/assets/how-to-guides_rollup-stacks.md.ac8fa6e2.lean.js similarity index 98% rename from pr-1815/assets/how-to-guides_rollup-stacks.md.7b355d9c.lean.js rename to pr-1815/assets/how-to-guides_rollup-stacks.md.ac8fa6e2.lean.js index 058f2efd7..654d191b4 100644 --- a/pr-1815/assets/how-to-guides_rollup-stacks.md.7b355d9c.lean.js +++ b/pr-1815/assets/how-to-guides_rollup-stacks.md.ac8fa6e2.lean.js @@ -1 +1 @@ -import{_ as p,o as l,c as r,k as t,t as i,e as d,H as e,Q as s,a as n}from"./chunks/framework.2959b752.js";const h="/docs-preview/pr-1815/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},g=["href"],b={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function _(c,u,o,R,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",b,[t("img",{src:o.imageSrc,alt:"",class:"button-icon"},null,8,f),t("span",y,i(o.text),1),o.notes?(l(),r("span",k,i(o.notes),1)):d("",!0)])],8,g)}const a=p(m,[["render",_],["__scopeId","data-v-21baf7e3"]]),w=s("",6),x={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},v=t("h3",{id:"rollups-as-a-service",tabindex:"-1"},[n("Rollups as a Service "),t("a",{class:"header-anchor",href:"#rollups-as-a-service","aria-label":'Permalink to "Rollups as a Service"'},"​")],-1),S=t("p",null,"Deploy your rollup with a RaaS provider.",-1),C={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},P=t("h3",{id:"smart-contracts",tabindex:"-1"},[n("Smart contracts "),t("a",{class:"header-anchor",href:"#smart-contracts","aria-label":'Permalink to "Smart contracts"'},"​")],-1),A=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),q={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},V=s("",26),B=JSON.parse('{"title":"Rollup stacks","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"property":"og:title","content":"Rollup stacks | Celestia Docs"}],["meta",{"property":"og:description","content":"Advantages of building on modular blockchains like Celestia."}]]},"headers":[],"relativePath":"how-to-guides/rollup-stacks.md","filePath":"how-to-guides/rollup-stacks.md","lastUpdated":1732776394000}'),O={name:"how-to-guides/rollup-stacks.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[w,t("div",x,[e(a,{url:"/how-to-guides/intro-to-op-stack",imageSrc:"/build/opstack.webp",text:"OP Stack",notes:"EVM",target:"_self",alt:"OP Stack logo","aria-label":"OP Stack"}),e(a,{url:"/how-to-guides/arbitrum-integration",imageSrc:"/build/arbitrum.webp",text:"Arbitrum Orbit",notes:"EVM",target:"_self",alt:"Arbitrum logo","aria-label":"Arbitrum"}),e(a,{url:"https://github.com/Sovereign-Labs/sovereign-sdk/tree/stable/examples/demo-rollup#demo-rollup",imageSrc:"/build/sovereign.webp",text:"Sovereign SDK",notes:"Sovereign",alt:"Sovereign logo","aria-label":"Sovereign"}),e(a,{url:"https://docs.dymension.xyz/",imageSrc:"/build/dymension.webp",text:"Dymension",alt:"Dymension logo","aria-label":"Dymension"}),e(a,{url:"https://docs.stf.xyz",imageSrc:"/build/stackr.webp",text:"Stackr",alt:"Stackr logo","aria-label":"Stackr"}),e(a,{url:"https://rollkit.dev",imageSrc:"/build/rollkit.webp",text:"Rollkit",notes:"Sovereign",alt:"Rollkit logo","aria-label":"Rollkit"})]),v,S,t("div",C,[e(a,{url:"https://altlayer.io/raas/",imageSrc:"/build/altlayer.webp",text:"AltLayer",notes:"Orbit, OP Stack",alt:"AltLayer logo","aria-label":"AltLayer"}),e(a,{url:"https://www.astria.org/",imageSrc:"/build/astria.webp",text:"Astria",alt:"Astria logo","aria-label":"Astria"}),e(a,{url:"https://www.caldera.xyz/",imageSrc:"/build/caldera.webp",text:"Caldera",notes:"Orbit, OP Stack",alt:"Caldera logo","aria-label":"Caldera"}),e(a,{url:"https://conduit.xyz/",imageSrc:"/build/conduit.webp",text:"Conduit",notes:"Orbit, OP Stack",alt:"Conduit logo","aria-label":"Conduit"}),e(a,{url:"https://www.gelato.network/",imageSrc:"/build/gelato.webp",text:"Gelato",notes:"Orbit, OP Stack",alt:"Gelato logo","aria-label":"Gelato"}),e(a,{url:"https://www.karnot.xyz/",imageSrc:"/build/karnot.webp",text:"Karnot",notes:"Starknet",alt:"Karnot logo","aria-label":"Karnot"}),e(a,{url:"https://docs.vistara.dev/",imageSrc:"/build/vistara.webp",text:"Vistara",alt:"Vistara logo","aria-label":"Vistara"}),e(a,{url:"https://www.zeeve.io/",imageSrc:"/build/zeeve.webp",text:"Zeeve",notes:"Orbit, OP Stack",alt:"Zeeve logo","aria-label":"Zeeve"})]),P,A,t("div",q,[e(a,{url:"https://bubstestnet.com/",imageSrc:"/build/caldera.webp",text:"Bubs testnet",notes:"OP Stack",alt:"Caldera logo","aria-label":"Caldera Bubs testnet"}),e(a,{url:"https://raas.gelato.network/rollups/details/public/opcelestia-raspberry",imageSrc:"/build/gelato.webp",text:"Raspberry testnet",notes:"OP Stack",alt:"Gelato logo","aria-label":"Gelato Raspberry testnet"})]),V]))}});export{B as __pageData,I as default}; +import{_ as p,o as l,c as r,k as t,t as i,e as d,H as e,Q as s,a as n}from"./chunks/framework.2959b752.js";const h="/docs-preview/pr-1815/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},g=["href"],b={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function _(c,u,o,R,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",b,[t("img",{src:o.imageSrc,alt:"",class:"button-icon"},null,8,f),t("span",y,i(o.text),1),o.notes?(l(),r("span",k,i(o.notes),1)):d("",!0)])],8,g)}const a=p(m,[["render",_],["__scopeId","data-v-21baf7e3"]]),w=s("",6),x={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},v=t("h3",{id:"rollups-as-a-service",tabindex:"-1"},[n("Rollups as a Service "),t("a",{class:"header-anchor",href:"#rollups-as-a-service","aria-label":'Permalink to "Rollups as a Service"'},"​")],-1),S=t("p",null,"Deploy your rollup with a RaaS provider.",-1),C={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},P=t("h3",{id:"smart-contracts",tabindex:"-1"},[n("Smart contracts "),t("a",{class:"header-anchor",href:"#smart-contracts","aria-label":'Permalink to "Smart contracts"'},"​")],-1),A=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),q={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},V=s("",26),B=JSON.parse('{"title":"Rollup stacks","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"property":"og:title","content":"Rollup stacks | Celestia Docs"}],["meta",{"property":"og:description","content":"Advantages of building on modular blockchains like Celestia."}]]},"headers":[],"relativePath":"how-to-guides/rollup-stacks.md","filePath":"how-to-guides/rollup-stacks.md","lastUpdated":1732777479000}'),O={name:"how-to-guides/rollup-stacks.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[w,t("div",x,[e(a,{url:"/how-to-guides/intro-to-op-stack",imageSrc:"/build/opstack.webp",text:"OP Stack",notes:"EVM",target:"_self",alt:"OP Stack logo","aria-label":"OP Stack"}),e(a,{url:"/how-to-guides/arbitrum-integration",imageSrc:"/build/arbitrum.webp",text:"Arbitrum Orbit",notes:"EVM",target:"_self",alt:"Arbitrum logo","aria-label":"Arbitrum"}),e(a,{url:"https://github.com/Sovereign-Labs/sovereign-sdk/tree/stable/examples/demo-rollup#demo-rollup",imageSrc:"/build/sovereign.webp",text:"Sovereign SDK",notes:"Sovereign",alt:"Sovereign logo","aria-label":"Sovereign"}),e(a,{url:"https://docs.dymension.xyz/",imageSrc:"/build/dymension.webp",text:"Dymension",alt:"Dymension logo","aria-label":"Dymension"}),e(a,{url:"https://docs.stf.xyz",imageSrc:"/build/stackr.webp",text:"Stackr",alt:"Stackr logo","aria-label":"Stackr"}),e(a,{url:"https://rollkit.dev",imageSrc:"/build/rollkit.webp",text:"Rollkit",notes:"Sovereign",alt:"Rollkit logo","aria-label":"Rollkit"})]),v,S,t("div",C,[e(a,{url:"https://altlayer.io/raas/",imageSrc:"/build/altlayer.webp",text:"AltLayer",notes:"Orbit, OP Stack",alt:"AltLayer logo","aria-label":"AltLayer"}),e(a,{url:"https://www.astria.org/",imageSrc:"/build/astria.webp",text:"Astria",alt:"Astria logo","aria-label":"Astria"}),e(a,{url:"https://www.caldera.xyz/",imageSrc:"/build/caldera.webp",text:"Caldera",notes:"Orbit, OP Stack",alt:"Caldera logo","aria-label":"Caldera"}),e(a,{url:"https://conduit.xyz/",imageSrc:"/build/conduit.webp",text:"Conduit",notes:"Orbit, OP Stack",alt:"Conduit logo","aria-label":"Conduit"}),e(a,{url:"https://www.gelato.network/",imageSrc:"/build/gelato.webp",text:"Gelato",notes:"Orbit, OP Stack",alt:"Gelato logo","aria-label":"Gelato"}),e(a,{url:"https://www.karnot.xyz/",imageSrc:"/build/karnot.webp",text:"Karnot",notes:"Starknet",alt:"Karnot logo","aria-label":"Karnot"}),e(a,{url:"https://docs.vistara.dev/",imageSrc:"/build/vistara.webp",text:"Vistara",alt:"Vistara logo","aria-label":"Vistara"}),e(a,{url:"https://www.zeeve.io/",imageSrc:"/build/zeeve.webp",text:"Zeeve",notes:"Orbit, OP Stack",alt:"Zeeve logo","aria-label":"Zeeve"})]),P,A,t("div",q,[e(a,{url:"https://bubstestnet.com/",imageSrc:"/build/caldera.webp",text:"Bubs testnet",notes:"OP Stack",alt:"Caldera logo","aria-label":"Caldera Bubs testnet"}),e(a,{url:"https://raas.gelato.network/rollups/details/public/opcelestia-raspberry",imageSrc:"/build/gelato.webp",text:"Raspberry testnet",notes:"OP Stack",alt:"Gelato logo","aria-label":"Gelato Raspberry testnet"})]),V]))}});export{B as __pageData,I as default}; diff --git a/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.28f2de08.js b/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.d5e590db.js similarity index 98% rename from pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.28f2de08.js rename to pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.d5e590db.js index 6b3dd6ce4..33ae4402c 100644 --- a/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.28f2de08.js +++ b/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.d5e590db.js @@ -1,3 +1,3 @@ -import{_ as e,o,c as t,Q as s}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/sp1-blobstream-deploy.md","filePath":"how-to-guides/sp1-blobstream-deploy.md","lastUpdated":1732776394000}'),a={name:"how-to-guides/sp1-blobstream-deploy.md"},l=s(`

    New SP1 Blobstream deployments

    This document provides instructions for deploying SP1 Blobstream to a new chain.

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    Deploying the contracts

    To deploy SP1 Blobstream to a new chain, follow these steps:

    1. Clone the sp1-blobstream repository:
    shell
    git clone https://github.com/succinctlabs/sp1-blobstream
    +import{_ as e,o,c as t,Q as s}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/sp1-blobstream-deploy.md","filePath":"how-to-guides/sp1-blobstream-deploy.md","lastUpdated":1732777479000}'),a={name:"how-to-guides/sp1-blobstream-deploy.md"},l=s(`

    New SP1 Blobstream deployments

    This document provides instructions for deploying SP1 Blobstream to a new chain.

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    Deploying the contracts

    To deploy SP1 Blobstream to a new chain, follow these steps:

    1. Clone the sp1-blobstream repository:
    shell
    git clone https://github.com/succinctlabs/sp1-blobstream
     cd sp1-blobstream
    git clone https://github.com/succinctlabs/sp1-blobstream
     cd sp1-blobstream
    1. Follow the deployment instructions in the sp1-blobstream README.

    2. If you're deploying on a chain where there isn't a canonical verifier listed in the SP1 contract addresses, you'll need to:

      a. Deploy your own SP1 Verifier from the sp1-contracts matching your sp1-sdk version. b. Set the SP1_VERIFIER_ADDRESS in your .env file to the address of your deployed verifier.

    3. To run the prover:

      • For local proving, set SP1_PROVER=local in your environment.
      • To use the Succinct Proving Network for remote proving, set SP1_PROVER=network.
      • We recommend an instance with 64 vCPU and 128GB of RAM for local proving.

    Note: Any whitelisting for custom provers would need to be implemented in the application's smart contracts (e.g., by using an approvedProvers mapping).

    `,9),n=[l];function r(p,c,i,d,h,b){return o(),t("div",null,n)}const y=e(a,[["render",r]]);export{u as __pageData,y as default}; diff --git a/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.28f2de08.lean.js b/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.d5e590db.lean.js similarity index 91% rename from pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.28f2de08.lean.js rename to pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.d5e590db.lean.js index ddf6c3534..ab27c7fd1 100644 --- a/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.28f2de08.lean.js +++ b/pr-1815/assets/how-to-guides_sp1-blobstream-deploy.md.d5e590db.lean.js @@ -1 +1 @@ -import{_ as e,o,c as t,Q as s}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/sp1-blobstream-deploy.md","filePath":"how-to-guides/sp1-blobstream-deploy.md","lastUpdated":1732776394000}'),a={name:"how-to-guides/sp1-blobstream-deploy.md"},l=s("",9),n=[l];function r(p,c,i,d,h,b){return o(),t("div",null,n)}const y=e(a,[["render",r]]);export{u as __pageData,y as default}; +import{_ as e,o,c as t,Q as s}from"./chunks/framework.2959b752.js";const u=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Overview of Blobstream X","link":"/how-to-guides/blobstreamx"},"head":[["meta",{"property":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/sp1-blobstream-deploy.md","filePath":"how-to-guides/sp1-blobstream-deploy.md","lastUpdated":1732777479000}'),a={name:"how-to-guides/sp1-blobstream-deploy.md"},l=s("",9),n=[l];function r(p,c,i,d,h,b){return o(),t("div",null,n)}const y=e(a,[["render",r]]);export{u as __pageData,y as default}; diff --git a/pr-1815/assets/how-to-guides_submit-data.md.706c0143.js b/pr-1815/assets/how-to-guides_submit-data.md.dfcce169.js similarity index 99% rename from pr-1815/assets/how-to-guides_submit-data.md.706c0143.js rename to pr-1815/assets/how-to-guides_submit-data.md.dfcce169.js index 56696a256..7bb0563c0 100644 --- a/pr-1815/assets/how-to-guides_submit-data.md.706c0143.js +++ b/pr-1815/assets/how-to-guides_submit-data.md.dfcce169.js @@ -1,4 +1,4 @@ -import{_ as t,o as a,c as n,k as s,a as l,Q as e}from"./chunks/framework.2959b752.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"head":[["meta",{"property":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/submit-data.md","filePath":"how-to-guides/submit-data.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/submit-data.md"},p=e('

    Submitting data blobs to Celestia

    To submit data to Celestia, users submit blob transactions (BlobTx). Blob transactions contain two components, a standard Cosmos-SDK transaction called MsgPayForBlobs and one or more Blobs of data.

    Maximum blob size

    The maximum total blob size in a transaction is just under 2 MiB (1,973,786 bytes), based on a 64x64 share grid (4096 shares). With one share for the PFB transaction, 4095 shares remain: 1 at 478 bytes and 4094 at 482 bytes each.

    This is subject to change based on governance parameters. Learn more on the Mainnet Beta page under "Maximum bytes".

    It is advisable to submit transactions where the total blob size is significantly smaller than 1.8 MiB (e.g. 500 KiB) in order for your transaction to get included in a block quickly. If a tx contains blobs approaching 1.8 MiB then there will be no room for any other transactions. This means that your transaction will only be included in a block if it has a higher gas price than every other transaction in the mempool.

    Fee market and mempool

    Celestia makes use of a standard gas-priced prioritized mempool. By default, transactions with gas prices higher than that of other transactions in the mempool will be prioritized by validators.

    Fees and gas limits

    As of version v1.0.0 of the application (celestia-app), there is no protocol enforced minimum fee (similar to EIP-1559 in Ethereum). Instead, each consensus node running a mempool uses a locally configured gas price threshold that must be met in order for that node to accept a transaction, either directly from a user or gossiped from another node, into its mempool.

    As of version v1.0.0 of the application (celestia-app), gas is not refunded. Instead, transaction fees are deducted by a flat fee, originally specified by the user in their tx (where fees = gasLimit * gasPrice). This means that users should use an accurate gas limit value if they do not wish to overpay.

    Under the hood, fees are currently handled by specifying and deducting a flat fee. However gas price is often specified by users instead of calculating the flat fee from the gas used and the gas price. Since the state machine does not refund users for unused gas, gas price is calculated by dividing the total fee by the gas limit.

    Estimating PFB gas

    Generally, the gas used by a PFB transaction involves a static fixed cost and a dynamic cost based on the size of each blob in the transaction.

    NOTE

    For a general use case of a normal account submitting a PFB, the static costs can be treated as such. However, due to the description above of how gas works in the Cosmos-SDK this is not always the case. Notably, if a vesting account or the feegrant modules are used, then these static costs change.

    The fixed cost is an approximation of the gas consumed by operations outside the function GasToConsume (for example, signature verification, tx size, read access to accounts), which has a default value of 65,000 gas.

    NOTE

    The first transaction sent by an account (sequence number == 0) has an additional one time gas cost of 10,000 gas. If this is the case, this should be accounted for.

    Each blob in the PFB contributes to the total gas cost based on its size. The function GasToConsume calculates the total gas consumed by all the blobs involved in a PFB, where each blob's gas cost is computed by first determining how many shares are needed to store the blob size. Then, it computes the product of the number of shares, the number of bytes per share, and the gasPerByte parameter. Finally, it adds a static amount per blob.

    The blob.GasPerBlobByte and auth.TxSizeCostPerByte are parameters that could potentially be adjusted through the system's governance mechanisms. Hence, actual costs may vary depending on the current state of these parameters.

    Gas fee calculation

    The total fee for a transaction is calculated as the product of the gas limit for the transaction and the gas price set by the user:

    ',21),r={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},c={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"34.471ex",height:"1.781ex",role:"img",focusable:"false",viewBox:"0 -705 15236 787","aria-hidden":"true"},i=e('',1),Q=[i],T=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Total Fee"),s("mo",null,"="),s("mtext",null,"Gas Limit"),s("mo",null,"×"),s("mtext",null,"Gas Price")])],-1),y=s("p",null,"The gas limit for a transaction is the maximum amount of gas that a user is willing to spend on a transaction. It is determined by both a static fixed cost (FC) and a variable dynamic cost based on the size of each blob involved in the transaction:",-1),E={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},d={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"50.774ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 22442.1 1132.9","aria-hidden":"true"},h=e('',1),m=[h],u=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Gas Limit"),s("mo",null,"="),s("mi",null,"F"),s("mi",null,"C"),s("mo",null,"+"),s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")"),s("mo",null,"×"),s("mi",null,"S"),s("mi",null,"S"),s("mo",null,"×"),s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),g=s("p",null,"Where:",-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},F={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"3.414ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1509 727","aria-hidden":"true"},f=e('',1),H=[f],w=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"F"),s("mi",null,"C")])],-1),C={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"14.695ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 6495.3 1132.9","aria-hidden":"true"},k=e('',1),B=[k],D=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")")])],-1),V={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},L={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},A=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),_=[A],v=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),M={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},q={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},Z=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),P=[Z],S=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),I={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},N={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.919ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1290 727","aria-hidden":"true"},j=e('',1),G=[j],O=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"S"),s("mi",null,"S")])],-1),z={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"8.631ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 3815 727","aria-hidden":"true"},W=e('',1),J=[W],K=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),U=e(`

    The gas fee is set by the user when they submit a transaction. The fee is often specified by users directly. The total cost for the transaction is then calculated as the product of the estimated gas limit and the gas price. Since the state machine does not refund users for unused gas, it's important for users to estimate the gas limit accurately to avoid overpaying.

    For more details on how gas is calculated per blob, refer to the PayForBlobs function that consumes gas based on the blob sizes. This function uses the GasToConsume function to calculate the extra gas charged to pay for a set of blobs in a MsgPayForBlobs transaction. This function calculates the total shares used by all blobs and multiplies it by the ShareSize and gasPerByte to get the total gas to consume.

    For estimating the total gas required for a set of blobs, refer to the EstimateGas function. This function estimates the gas based on a linear model that is dependent on the governance parameters: gasPerByte and txSizeCost. It assumes other variables are constant, including the assumption that the MsgPayForBlobs is the only message in the transaction. The DefaultEstimateGas function runs EstimateGas with the system defaults.

    Estimating gas programmatically

    Users can estimate an efficient gas limit by using this function:

    go
    import (
    +import{_ as t,o as a,c as n,k as s,a as l,Q as e}from"./chunks/framework.2959b752.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"head":[["meta",{"property":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/submit-data.md","filePath":"how-to-guides/submit-data.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/submit-data.md"},p=e('

    Submitting data blobs to Celestia

    To submit data to Celestia, users submit blob transactions (BlobTx). Blob transactions contain two components, a standard Cosmos-SDK transaction called MsgPayForBlobs and one or more Blobs of data.

    Maximum blob size

    The maximum total blob size in a transaction is just under 2 MiB (1,973,786 bytes), based on a 64x64 share grid (4096 shares). With one share for the PFB transaction, 4095 shares remain: 1 at 478 bytes and 4094 at 482 bytes each.

    This is subject to change based on governance parameters. Learn more on the Mainnet Beta page under "Maximum bytes".

    It is advisable to submit transactions where the total blob size is significantly smaller than 1.8 MiB (e.g. 500 KiB) in order for your transaction to get included in a block quickly. If a tx contains blobs approaching 1.8 MiB then there will be no room for any other transactions. This means that your transaction will only be included in a block if it has a higher gas price than every other transaction in the mempool.

    Fee market and mempool

    Celestia makes use of a standard gas-priced prioritized mempool. By default, transactions with gas prices higher than that of other transactions in the mempool will be prioritized by validators.

    Fees and gas limits

    As of version v1.0.0 of the application (celestia-app), there is no protocol enforced minimum fee (similar to EIP-1559 in Ethereum). Instead, each consensus node running a mempool uses a locally configured gas price threshold that must be met in order for that node to accept a transaction, either directly from a user or gossiped from another node, into its mempool.

    As of version v1.0.0 of the application (celestia-app), gas is not refunded. Instead, transaction fees are deducted by a flat fee, originally specified by the user in their tx (where fees = gasLimit * gasPrice). This means that users should use an accurate gas limit value if they do not wish to overpay.

    Under the hood, fees are currently handled by specifying and deducting a flat fee. However gas price is often specified by users instead of calculating the flat fee from the gas used and the gas price. Since the state machine does not refund users for unused gas, gas price is calculated by dividing the total fee by the gas limit.

    Estimating PFB gas

    Generally, the gas used by a PFB transaction involves a static fixed cost and a dynamic cost based on the size of each blob in the transaction.

    NOTE

    For a general use case of a normal account submitting a PFB, the static costs can be treated as such. However, due to the description above of how gas works in the Cosmos-SDK this is not always the case. Notably, if a vesting account or the feegrant modules are used, then these static costs change.

    The fixed cost is an approximation of the gas consumed by operations outside the function GasToConsume (for example, signature verification, tx size, read access to accounts), which has a default value of 65,000 gas.

    NOTE

    The first transaction sent by an account (sequence number == 0) has an additional one time gas cost of 10,000 gas. If this is the case, this should be accounted for.

    Each blob in the PFB contributes to the total gas cost based on its size. The function GasToConsume calculates the total gas consumed by all the blobs involved in a PFB, where each blob's gas cost is computed by first determining how many shares are needed to store the blob size. Then, it computes the product of the number of shares, the number of bytes per share, and the gasPerByte parameter. Finally, it adds a static amount per blob.

    The blob.GasPerBlobByte and auth.TxSizeCostPerByte are parameters that could potentially be adjusted through the system's governance mechanisms. Hence, actual costs may vary depending on the current state of these parameters.

    Gas fee calculation

    The total fee for a transaction is calculated as the product of the gas limit for the transaction and the gas price set by the user:

    ',21),r={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},c={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"34.471ex",height:"1.781ex",role:"img",focusable:"false",viewBox:"0 -705 15236 787","aria-hidden":"true"},i=e('',1),Q=[i],T=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Total Fee"),s("mo",null,"="),s("mtext",null,"Gas Limit"),s("mo",null,"×"),s("mtext",null,"Gas Price")])],-1),y=s("p",null,"The gas limit for a transaction is the maximum amount of gas that a user is willing to spend on a transaction. It is determined by both a static fixed cost (FC) and a variable dynamic cost based on the size of each blob involved in the transaction:",-1),E={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},d={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"50.774ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 22442.1 1132.9","aria-hidden":"true"},h=e('',1),m=[h],u=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Gas Limit"),s("mo",null,"="),s("mi",null,"F"),s("mi",null,"C"),s("mo",null,"+"),s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")"),s("mo",null,"×"),s("mi",null,"S"),s("mi",null,"S"),s("mo",null,"×"),s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),g=s("p",null,"Where:",-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},F={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"3.414ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1509 727","aria-hidden":"true"},f=e('',1),H=[f],w=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"F"),s("mi",null,"C")])],-1),C={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"14.695ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 6495.3 1132.9","aria-hidden":"true"},k=e('',1),B=[k],D=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")")])],-1),V={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},L={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},A=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),_=[A],v=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),M={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},q={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},Z=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),P=[Z],S=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),I={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},N={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.919ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1290 727","aria-hidden":"true"},j=e('',1),G=[j],O=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"S"),s("mi",null,"S")])],-1),z={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"8.631ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 3815 727","aria-hidden":"true"},W=e('',1),J=[W],K=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),U=e(`

    The gas fee is set by the user when they submit a transaction. The fee is often specified by users directly. The total cost for the transaction is then calculated as the product of the estimated gas limit and the gas price. Since the state machine does not refund users for unused gas, it's important for users to estimate the gas limit accurately to avoid overpaying.

    For more details on how gas is calculated per blob, refer to the PayForBlobs function that consumes gas based on the blob sizes. This function uses the GasToConsume function to calculate the extra gas charged to pay for a set of blobs in a MsgPayForBlobs transaction. This function calculates the total shares used by all blobs and multiplies it by the ShareSize and gasPerByte to get the total gas to consume.

    For estimating the total gas required for a set of blobs, refer to the EstimateGas function. This function estimates the gas based on a linear model that is dependent on the governance parameters: gasPerByte and txSizeCost. It assumes other variables are constant, including the assumption that the MsgPayForBlobs is the only message in the transaction. The DefaultEstimateGas function runs EstimateGas with the system defaults.

    Estimating gas programmatically

    Users can estimate an efficient gas limit by using this function:

    go
    import (
         blobtypes "github.com/celestiaorg/celestia-app/x/blob/types"
     )
     gasLimit := blobtypes.DefaultEstimateGas([]uint32{uint32(sizeOfDataInBytes)})
    import (
    diff --git a/pr-1815/assets/how-to-guides_submit-data.md.706c0143.lean.js b/pr-1815/assets/how-to-guides_submit-data.md.dfcce169.lean.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_submit-data.md.706c0143.lean.js
    rename to pr-1815/assets/how-to-guides_submit-data.md.dfcce169.lean.js
    index 7c013fb33..3cca949fb 100644
    --- a/pr-1815/assets/how-to-guides_submit-data.md.706c0143.lean.js
    +++ b/pr-1815/assets/how-to-guides_submit-data.md.dfcce169.lean.js
    @@ -1 +1 @@
    -import{_ as t,o as a,c as n,k as s,a as l,Q as e}from"./chunks/framework.2959b752.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"head":[["meta",{"property":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/submit-data.md","filePath":"how-to-guides/submit-data.md","lastUpdated":1732776394000}'),o={name:"how-to-guides/submit-data.md"},p=e("",21),r={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},c={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"34.471ex",height:"1.781ex",role:"img",focusable:"false",viewBox:"0 -705 15236 787","aria-hidden":"true"},i=e("",1),Q=[i],T=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Total Fee"),s("mo",null,"="),s("mtext",null,"Gas Limit"),s("mo",null,"×"),s("mtext",null,"Gas Price")])],-1),y=s("p",null,"The gas limit for a transaction is the maximum amount of gas that a user is willing to spend on a transaction. It is determined by both a static fixed cost (FC) and a variable dynamic cost based on the size of each blob involved in the transaction:",-1),E={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},d={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"50.774ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 22442.1 1132.9","aria-hidden":"true"},h=e("",1),m=[h],u=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Gas Limit"),s("mo",null,"="),s("mi",null,"F"),s("mi",null,"C"),s("mo",null,"+"),s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")"),s("mo",null,"×"),s("mi",null,"S"),s("mi",null,"S"),s("mo",null,"×"),s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),g=s("p",null,"Where:",-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},F={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"3.414ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1509 727","aria-hidden":"true"},f=e("",1),H=[f],w=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"F"),s("mi",null,"C")])],-1),C={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"14.695ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 6495.3 1132.9","aria-hidden":"true"},k=e("",1),B=[k],D=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")")])],-1),V={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},L={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},A=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),_=[A],v=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),M={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},q={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},Z=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),P=[Z],S=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),I={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},N={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.919ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1290 727","aria-hidden":"true"},j=e("",1),G=[j],O=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"S"),s("mi",null,"S")])],-1),z={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"8.631ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 3815 727","aria-hidden":"true"},W=e("",1),J=[W],K=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),U=e("",33);function X($,Y,ss,as,ns,es){return a(),n("div",null,[p,s("p",null,[s("mjx-container",r,[(a(),n("svg",c,Q)),T])]),y,s("p",null,[s("mjx-container",E,[(a(),n("svg",d,m)),u])]),g,s("ul",null,[s("li",null,[s("mjx-container",b,[(a(),n("svg",F,H)),w]),l(" = Fixed Cost, is a static value (65,000 gas)")]),s("li",null,[s("mjx-container",C,[(a(),n("svg",x,B)),D]),l(" = SparseSharesNeeded for the "),s("mjx-container",V,[(a(),n("svg",L,_)),v]),l("th Blob, is the number of shares needed for the "),s("mjx-container",M,[(a(),n("svg",q,P)),S]),l("th blob in the transaction")]),s("li",null,[s("mjx-container",I,[(a(),n("svg",N,G)),O]),l(" = Share Size, is the size of each share")]),s("li",null,[s("mjx-container",z,[(a(),n("svg",R,J)),K]),l(" = Gas Cost Per Blob Byte, is a parameter that could potentially be adjusted through the system's governance mechanisms.")])]),U])}const os=t(o,[["render",X]]);export{ts as __pageData,os as default};
    +import{_ as t,o as a,c as n,k as s,a as l,Q as e}from"./chunks/framework.2959b752.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/how-to-guides/blobstream-rollups"},"head":[["meta",{"property":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"how-to-guides/submit-data.md","filePath":"how-to-guides/submit-data.md","lastUpdated":1732777479000}'),o={name:"how-to-guides/submit-data.md"},p=e("",21),r={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},c={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"34.471ex",height:"1.781ex",role:"img",focusable:"false",viewBox:"0 -705 15236 787","aria-hidden":"true"},i=e("",1),Q=[i],T=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Total Fee"),s("mo",null,"="),s("mtext",null,"Gas Limit"),s("mo",null,"×"),s("mtext",null,"Gas Price")])],-1),y=s("p",null,"The gas limit for a transaction is the maximum amount of gas that a user is willing to spend on a transaction. It is determined by both a static fixed cost (FC) and a variable dynamic cost based on the size of each blob involved in the transaction:",-1),E={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},d={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"50.774ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 22442.1 1132.9","aria-hidden":"true"},h=e("",1),m=[h],u=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mtext",null,"Gas Limit"),s("mo",null,"="),s("mi",null,"F"),s("mi",null,"C"),s("mo",null,"+"),s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")"),s("mo",null,"×"),s("mi",null,"S"),s("mi",null,"S"),s("mo",null,"×"),s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),g=s("p",null,"Where:",-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},F={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"3.414ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1509 727","aria-hidden":"true"},f=e("",1),H=[f],w=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"F"),s("mi",null,"C")])],-1),C={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.777ex"},xmlns:"http://www.w3.org/2000/svg",width:"14.695ex",height:"2.563ex",role:"img",focusable:"false",viewBox:"0 -789.6 6495.3 1132.9","aria-hidden":"true"},k=e("",1),B=[k],D=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("munderover",null,[s("mo",{"data-mjx-texclass":"OP"},"∑"),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"i"),s("mo",null,"="),s("mn",null,"1")]),s("mrow",{"data-mjx-texclass":"ORD"},[s("mi",null,"n")])]),s("mi",null,"S"),s("mi",null,"S"),s("mi",null,"N"),s("mo",{stretchy:"false"},"("),s("msub",null,[s("mi",null,"B"),s("mi",null,"i")]),s("mo",{stretchy:"false"},")")])],-1),V={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},L={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},A=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),_=[A],v=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),M={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},q={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"0.781ex",height:"1.52ex",role:"img",focusable:"false",viewBox:"0 -661 345 672","aria-hidden":"true"},Z=s("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[s("g",{"data-mml-node":"math"},[s("g",{"data-mml-node":"mi"},[s("path",{"data-c":"1D456",d:"M184 600Q184 624 203 642T247 661Q265 661 277 649T290 619Q290 596 270 577T226 557Q211 557 198 567T184 600ZM21 287Q21 295 30 318T54 369T98 420T158 442Q197 442 223 419T250 357Q250 340 236 301T196 196T154 83Q149 61 149 51Q149 26 166 26Q175 26 185 29T208 43T235 78T260 137Q263 149 265 151T282 153Q302 153 302 143Q302 135 293 112T268 61T223 11T161 -11Q129 -11 102 10T74 74Q74 91 79 106T122 220Q160 321 166 341T173 380Q173 404 156 404H154Q124 404 99 371T61 287Q60 286 59 284T58 281T56 279T53 278T49 278T41 278H27Q21 284 21 287Z",style:{"stroke-width":"3"}})])])],-1),P=[Z],S=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"i")])],-1),I={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},N={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.919ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 1290 727","aria-hidden":"true"},j=e("",1),G=[j],O=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"S"),s("mi",null,"S")])],-1),z={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.05ex"},xmlns:"http://www.w3.org/2000/svg",width:"8.631ex",height:"1.645ex",role:"img",focusable:"false",viewBox:"0 -705 3815 727","aria-hidden":"true"},W=e("",1),J=[W],K=s("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[s("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[s("mi",null,"G"),s("mi",null,"C"),s("mi",null,"P"),s("mi",null,"B"),s("mi",null,"B")])],-1),U=e("",33);function X($,Y,ss,as,ns,es){return a(),n("div",null,[p,s("p",null,[s("mjx-container",r,[(a(),n("svg",c,Q)),T])]),y,s("p",null,[s("mjx-container",E,[(a(),n("svg",d,m)),u])]),g,s("ul",null,[s("li",null,[s("mjx-container",b,[(a(),n("svg",F,H)),w]),l(" = Fixed Cost, is a static value (65,000 gas)")]),s("li",null,[s("mjx-container",C,[(a(),n("svg",x,B)),D]),l(" = SparseSharesNeeded for the "),s("mjx-container",V,[(a(),n("svg",L,_)),v]),l("th Blob, is the number of shares needed for the "),s("mjx-container",M,[(a(),n("svg",q,P)),S]),l("th blob in the transaction")]),s("li",null,[s("mjx-container",I,[(a(),n("svg",N,G)),O]),l(" = Share Size, is the size of each share")]),s("li",null,[s("mjx-container",z,[(a(),n("svg",R,J)),K]),l(" = Gas Cost Per Blob Byte, is a parameter that could potentially be adjusted through the system's governance mechanisms.")])]),U])}const os=t(o,[["render",X]]);export{ts as __pageData,os as default};
    diff --git a/pr-1815/assets/how-to-guides_systemd.md.32f00e62.js b/pr-1815/assets/how-to-guides_systemd.md.def256dc.js
    similarity index 99%
    rename from pr-1815/assets/how-to-guides_systemd.md.32f00e62.js
    rename to pr-1815/assets/how-to-guides_systemd.md.def256dc.js
    index 980a3fede..0a4101ec9 100644
    --- a/pr-1815/assets/how-to-guides_systemd.md.32f00e62.js
    +++ b/pr-1815/assets/how-to-guides_systemd.md.def256dc.js
    @@ -1,4 +1,4 @@
    -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up your node as a background process with SystemD","description":"Learn how to setup your node as a background process with SystemD.","frontmatter":{"description":"Learn how to setup your node as a background process with SystemD.","head":[["meta",{"property":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to setup your node as a background process with SystemD."}]]},"headers":[],"relativePath":"how-to-guides/systemd.md","filePath":"how-to-guides/systemd.md","lastUpdated":1732776394000}'),e={name:"how-to-guides/systemd.md"},p=l(`

    Setting up your node as a background process with SystemD

    SystemD is a daemon service useful for running applications as background processes.

    Consensus nodes

    If you are running a validator or consensus node, here are the steps to setting up celestia-appd as a background process.

    Start the celestia-app with SystemD

    SystemD is a daemon service useful for running applications as background processes.

    Create Celestia-App systemd file:

    sh
    sudo tee <<EOF >/dev/null /etc/systemd/system/celestia-appd.service
    +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up your node as a background process with SystemD","description":"Learn how to setup your node as a background process with SystemD.","frontmatter":{"description":"Learn how to setup your node as a background process with SystemD.","head":[["meta",{"property":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to setup your node as a background process with SystemD."}]]},"headers":[],"relativePath":"how-to-guides/systemd.md","filePath":"how-to-guides/systemd.md","lastUpdated":1732777479000}'),e={name:"how-to-guides/systemd.md"},p=l(`

    Setting up your node as a background process with SystemD

    SystemD is a daemon service useful for running applications as background processes.

    Consensus nodes

    If you are running a validator or consensus node, here are the steps to setting up celestia-appd as a background process.

    Start the celestia-app with SystemD

    SystemD is a daemon service useful for running applications as background processes.

    Create Celestia-App systemd file:

    sh
    sudo tee <<EOF >/dev/null /etc/systemd/system/celestia-appd.service
     [Unit]
     Description=celestia-appd Cosmos daemon
     After=network-online.target
    diff --git a/pr-1815/assets/how-to-guides_systemd.md.32f00e62.lean.js b/pr-1815/assets/how-to-guides_systemd.md.def256dc.lean.js
    similarity index 85%
    rename from pr-1815/assets/how-to-guides_systemd.md.32f00e62.lean.js
    rename to pr-1815/assets/how-to-guides_systemd.md.def256dc.lean.js
    index 98b7473b8..02d63d2f2 100644
    --- a/pr-1815/assets/how-to-guides_systemd.md.32f00e62.lean.js
    +++ b/pr-1815/assets/how-to-guides_systemd.md.def256dc.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up your node as a background process with SystemD","description":"Learn how to setup your node as a background process with SystemD.","frontmatter":{"description":"Learn how to setup your node as a background process with SystemD.","head":[["meta",{"property":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to setup your node as a background process with SystemD."}]]},"headers":[],"relativePath":"how-to-guides/systemd.md","filePath":"how-to-guides/systemd.md","lastUpdated":1732776394000}'),e={name:"how-to-guides/systemd.md"},p=l("",52),o=[p];function t(c,r,i,y,d,E){return a(),n("div",null,o)}const u=s(e,[["render",t]]);export{h as __pageData,u as default};
    +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Setting up your node as a background process with SystemD","description":"Learn how to setup your node as a background process with SystemD.","frontmatter":{"description":"Learn how to setup your node as a background process with SystemD.","head":[["meta",{"property":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to setup your node as a background process with SystemD."}]]},"headers":[],"relativePath":"how-to-guides/systemd.md","filePath":"how-to-guides/systemd.md","lastUpdated":1732777479000}'),e={name:"how-to-guides/systemd.md"},p=l("",52),o=[p];function t(c,r,i,y,d,E){return a(),n("div",null,o)}const u=s(e,[["render",t]]);export{h as __pageData,u as default};
    diff --git a/pr-1815/assets/how-to-guides_transaction-resubmission.md.c43abb47.js b/pr-1815/assets/how-to-guides_transaction-resubmission.md.075e6fb0.js
    similarity index 97%
    rename from pr-1815/assets/how-to-guides_transaction-resubmission.md.c43abb47.js
    rename to pr-1815/assets/how-to-guides_transaction-resubmission.md.075e6fb0.js
    index 78e41b595..64f250da8 100644
    --- a/pr-1815/assets/how-to-guides_transaction-resubmission.md.c43abb47.js
    +++ b/pr-1815/assets/how-to-guides_transaction-resubmission.md.075e6fb0.js
    @@ -1 +1 @@
    -import{_ as e,o as i,c as s,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Transaction resubmission","description":"This is a guide on transaction resubmission on Celestia.","frontmatter":{"description":"This is a guide on transaction resubmission on Celestia.","head":[["meta",{"property":"og:title","content":"Transaction resubmission | Celestia Docs"}],["meta",{"property":"og:description","content":"This is a guide on transaction resubmission on Celestia."}]]},"headers":[],"relativePath":"how-to-guides/transaction-resubmission.md","filePath":"how-to-guides/transaction-resubmission.md","lastUpdated":1732776394000}'),t={name:"how-to-guides/transaction-resubmission.md"},n=o('

    Transaction resubmission

    In cases where transactions are not included within a 75-second window, resubmission is necessary. This is especially important during network congestion, as transactions with relatively low fees may not be processed even after the network clears up.

    Regardless of whether they originate from celestia-app or celestia-node, transactions will not be re-gossiped, except in the presence of a new peer.

    If you are running a production application on Celestia, it is recommended to use a high-availability, production RPC provider for Mainnet Beta,Mocha, or Arabica.

    Monitoring and resubmission

    Monitor the status of your transactions. If a transaction is not included within a 75-second window, it should be resubmitted. This can be done manually or through automated processes.

    Changes introduced in celestiaorg/celestia-core#1089 may affect transaction gossiping and inclusion speed.

    Notes

    • All transactions, regardless of their origin, are subject to being sorted and pruned based on fees.
    • It is the user or developer's responsibility to monitor and possibly resubmit transactions if they are not included in a 75-second window.
    ',9),a=[n];function r(c,d,l,u,p,h){return i(),s("div",null,a)}const g=e(t,[["render",r]]);export{b as __pageData,g as default}; +import{_ as e,o as i,c as s,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Transaction resubmission","description":"This is a guide on transaction resubmission on Celestia.","frontmatter":{"description":"This is a guide on transaction resubmission on Celestia.","head":[["meta",{"property":"og:title","content":"Transaction resubmission | Celestia Docs"}],["meta",{"property":"og:description","content":"This is a guide on transaction resubmission on Celestia."}]]},"headers":[],"relativePath":"how-to-guides/transaction-resubmission.md","filePath":"how-to-guides/transaction-resubmission.md","lastUpdated":1732777479000}'),t={name:"how-to-guides/transaction-resubmission.md"},n=o('

    Transaction resubmission

    In cases where transactions are not included within a 75-second window, resubmission is necessary. This is especially important during network congestion, as transactions with relatively low fees may not be processed even after the network clears up.

    Regardless of whether they originate from celestia-app or celestia-node, transactions will not be re-gossiped, except in the presence of a new peer.

    If you are running a production application on Celestia, it is recommended to use a high-availability, production RPC provider for Mainnet Beta,Mocha, or Arabica.

    Monitoring and resubmission

    Monitor the status of your transactions. If a transaction is not included within a 75-second window, it should be resubmitted. This can be done manually or through automated processes.

    Changes introduced in celestiaorg/celestia-core#1089 may affect transaction gossiping and inclusion speed.

    Notes

    • All transactions, regardless of their origin, are subject to being sorted and pruned based on fees.
    • It is the user or developer's responsibility to monitor and possibly resubmit transactions if they are not included in a 75-second window.
    ',9),a=[n];function r(c,d,l,u,p,h){return i(),s("div",null,a)}const g=e(t,[["render",r]]);export{b as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_transaction-resubmission.md.c43abb47.lean.js b/pr-1815/assets/how-to-guides_transaction-resubmission.md.075e6fb0.lean.js similarity index 92% rename from pr-1815/assets/how-to-guides_transaction-resubmission.md.c43abb47.lean.js rename to pr-1815/assets/how-to-guides_transaction-resubmission.md.075e6fb0.lean.js index 3f29340c6..c1fbe98ea 100644 --- a/pr-1815/assets/how-to-guides_transaction-resubmission.md.c43abb47.lean.js +++ b/pr-1815/assets/how-to-guides_transaction-resubmission.md.075e6fb0.lean.js @@ -1 +1 @@ -import{_ as e,o as i,c as s,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Transaction resubmission","description":"This is a guide on transaction resubmission on Celestia.","frontmatter":{"description":"This is a guide on transaction resubmission on Celestia.","head":[["meta",{"property":"og:title","content":"Transaction resubmission | Celestia Docs"}],["meta",{"property":"og:description","content":"This is a guide on transaction resubmission on Celestia."}]]},"headers":[],"relativePath":"how-to-guides/transaction-resubmission.md","filePath":"how-to-guides/transaction-resubmission.md","lastUpdated":1732776394000}'),t={name:"how-to-guides/transaction-resubmission.md"},n=o("",9),a=[n];function r(c,d,l,u,p,h){return i(),s("div",null,a)}const g=e(t,[["render",r]]);export{b as __pageData,g as default}; +import{_ as e,o as i,c as s,Q as o}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Transaction resubmission","description":"This is a guide on transaction resubmission on Celestia.","frontmatter":{"description":"This is a guide on transaction resubmission on Celestia.","head":[["meta",{"property":"og:title","content":"Transaction resubmission | Celestia Docs"}],["meta",{"property":"og:description","content":"This is a guide on transaction resubmission on Celestia."}]]},"headers":[],"relativePath":"how-to-guides/transaction-resubmission.md","filePath":"how-to-guides/transaction-resubmission.md","lastUpdated":1732777479000}'),t={name:"how-to-guides/transaction-resubmission.md"},n=o("",9),a=[n];function r(c,d,l,u,p,h){return i(),s("div",null,a)}const g=e(t,[["render",r]]);export{b as __pageData,g as default}; diff --git a/pr-1815/assets/how-to-guides_validator-node.md.e6b62962.js b/pr-1815/assets/how-to-guides_validator-node.md.5e3cb47d.js similarity index 96% rename from pr-1815/assets/how-to-guides_validator-node.md.e6b62962.js rename to pr-1815/assets/how-to-guides_validator-node.md.5e3cb47d.js index cfdb86b27..90a9ede6d 100644 --- a/pr-1815/assets/how-to-guides_validator-node.md.e6b62962.js +++ b/pr-1815/assets/how-to-guides_validator-node.md.5e3cb47d.js @@ -1,4 +1,4 @@ -import{c as o}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,a,t as n,l as t,Q as e}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/validator.png",r=e('

    Setting up a Celestia validator node

    This tutorial will guide you through setting up a validator node on Celestia. Validator nodes allow you to participate in consensus in the Celestia network.

    validator node

    Hardware requirements

    The following hardware minimum requirements are recommended for running a validator node:

    • Memory: 16 GB RAM
    • CPU: 8 cores
    • Disk: 2 TB SSD Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up a validator node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    First, follow the instructions on setting up a consensus node.

    Wallet

    Follow the tutorial on creating a wallet.

    Delegate stake to a validator

    Create an environment variable for the address:

    bash
    VALIDATOR_WALLET=<validator-wallet-name>
    VALIDATOR_WALLET=<validator-wallet-name>

    If you want to delegate more stake to any validator, including your own you will need the celesvaloper address of the validator in question. You can run the command below to get the celesvaloper of your local validator wallet in case you want to delegate more to it:

    bash
    celestia-appd keys show $VALIDATOR_WALLET --bech val -a
    celestia-appd keys show $VALIDATOR_WALLET --bech val -a

    After entering the wallet passphrase you should see a similar output:

    bash
    Enter keyring passphrase:
    +import{c as n}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,a,t as o,l as t,Q as e}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/validator.png",r=e('

    Setting up a Celestia validator node

    This tutorial will guide you through setting up a validator node on Celestia. Validator nodes allow you to participate in consensus in the Celestia network.

    validator node

    Hardware requirements

    The following hardware minimum requirements are recommended for running a validator node:

    • Memory: 16 GB RAM
    • CPU: 8 cores
    • Disk: 2 TB SSD Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up a validator node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    First, follow the instructions on setting up a consensus node.

    Wallet

    Follow the tutorial on creating a wallet.

    Delegate stake to a validator

    Create an environment variable for the address:

    bash
    VALIDATOR_WALLET=<validator-wallet-name>
    VALIDATOR_WALLET=<validator-wallet-name>

    If you want to delegate more stake to any validator, including your own you will need the celesvaloper address of the validator in question. You can run the command below to get the celesvaloper of your local validator wallet in case you want to delegate more to it:

    bash
    celestia-appd keys show $VALIDATOR_WALLET --bech val -a
    celestia-appd keys show $VALIDATOR_WALLET --bech val -a

    After entering the wallet passphrase you should see a similar output:

    bash
    Enter keyring passphrase:
     celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hd
    Enter keyring passphrase:
     celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hd

    To delegate tokens to the celestiavaloper validator, as an example you can run:

    `,19),i={class:"language-bash vp-adaptive-theme"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},_=e('celestia-appd tx staking delegate \\',1),y=e('celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p 1000000utia \\',1),g={class:"line"},E=s("span",{style:{color:"#E1E4E8"}},"--from=$VALIDATOR_WALLET ",-1),C={style:{color:"#79B8FF"}},m=s("span",{style:{color:"#E1E4E8"}}," ",-1),F=s("span",{style:{color:"#79B8FF"}},"\\",-1),v=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),b={class:"shiki github-light vp-code-light"},T=e('celestia-appd tx staking delegate \\',1),k=e('celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p 1000000utia \\',1),f={class:"line"},A=s("span",{style:{color:"#24292E"}},"--from=$VALIDATOR_WALLET ",-1),S={style:{color:"#005CC5"}},B=s("span",{style:{color:"#24292E"}}," ",-1),x=s("span",{style:{color:"#005CC5"}},"\\",-1),q=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"--fees=21000utia")],-1),w=e(`

    If successful, you should see a similar output as:

    console
    code: 0
     codespace: ""
    @@ -22,7 +22,7 @@ import{c as o}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,a
     raw_log: '[]'
     timestamp: ""
     tx: null
    -txhash: <tx-hash>

    You can check if the TX hash went through using the block explorer by inputting the txhash ID that was returned.

    Optional: Deploy the celestia-node

    Running a bridge node is critical to the Celestia network as it enables the data availability and consensus nodes to communicate with one another. It is recommended to support the data availability network, but is not required for celestia-app.

    If you are not running a bridge node, you can skip to run a validator node.

    This section describes part 2 of Celestia validator node setup: running a Celestia bridge node daemon.

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Initialize the bridge node

    Run the following:

    bash
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, initialize your node.

    Run the bridge node

    Run the following:

    bash
    celestia bridge start
    celestia bridge start

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    Run the validator node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    After completing all the necessary steps, you are now ready to run a validator! In order to create your validator onchain, follow the instructions below. Keep in mind that these steps are necessary ONLY if you want to participate in the consensus.

    Pick a moniker name of your choice! This is the validator name that will show up on public dashboards and explorers. VALIDATOR_WALLET must be the same you defined previously. Parameter --min-self-delegation=1000000 defines the amount of tokens that are self delegated from your validator wallet.

    Now, connect to the network of your choice.

    You have the following option of connecting to list of networks shown below:

    Continuing the validator tutorial, here are the steps to connect your validator to Mocha:

    `,30),I={class:"language-bash vp-adaptive-theme"},P=s("button",{title:"Copy Code",class:"copy"},null,-1),V=s("span",{class:"lang"},"bash",-1),R={class:"shiki github-dark vp-code-dark"},D=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"MONIKER"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"your_moniker"')],-1),L=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"validator"')],-1),N=s("span",{class:"line"},null,-1),O=e('celestia-appd tx staking create-validator \\',1),M=e(' --amount=1000000utia \\',1),z=e(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),W=e(' --moniker=$MONIKER \\',1),U={class:"line"},$=s("span",{style:{color:"#E1E4E8"}}," ",-1),H={style:{color:"#79B8FF"}},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),G=s("span",{style:{color:"#79B8FF"}},"\\",-1),K=e(' --commission-rate=0.1 \\',1),j=e(' --commission-max-rate=0.2 \\',1),J=e(' --commission-max-change-rate=0.01 \\',1),Q=e(' --min-self-delegation=1000000 \\',1),X=e(' --from=$VALIDATOR_WALLET \\',1),Z=e(' --keyring-backend=test \\',1),ss=e(' --fees=21000utia \\',1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),es={class:"shiki github-light vp-code-light"},os=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"MONIKER"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"your_moniker"')],-1),ns=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"validator"')],-1),ts=s("span",{class:"line"},null,-1),ls=e('celestia-appd tx staking create-validator \\',1),ps=e(' --amount=1000000utia \\',1),cs=e(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),rs=e(' --moniker=$MONIKER \\',1),is={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#005CC5"}},us=s("span",{style:{color:"#24292E"}}," ",-1),_s=s("span",{style:{color:"#005CC5"}},"\\",-1),ys=e(' --commission-rate=0.1 \\',1),gs=e(' --commission-max-rate=0.2 \\',1),Es=e(' --commission-max-change-rate=0.01 \\',1),Cs=e(' --min-self-delegation=1000000 \\',1),ms=e(' --from=$VALIDATOR_WALLET \\',1),Fs=e(' --keyring-backend=test \\',1),vs=e(' --fees=21000utia \\',1),bs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=e(`

    You will be prompted to confirm the transaction:

    console
    confirm transaction before signing and broadcasting [y/N]: y
    confirm transaction before signing and broadcasting [y/N]: y

    Inputting y should provide an output similar to:

    console
    code: 0
    +txhash: <tx-hash>

    You can check if the TX hash went through using the block explorer by inputting the txhash ID that was returned.

    Optional: Deploy the celestia-node

    Running a bridge node is critical to the Celestia network as it enables the data availability and consensus nodes to communicate with one another. It is recommended to support the data availability network, but is not required for celestia-app.

    If you are not running a bridge node, you can skip to run a validator node.

    This section describes part 2 of Celestia validator node setup: running a Celestia bridge node daemon.

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Initialize the bridge node

    Run the following:

    bash
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, initialize your node.

    Run the bridge node

    Run the following:

    bash
    celestia bridge start
    celestia bridge start

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    Run the validator node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    After completing all the necessary steps, you are now ready to run a validator! In order to create your validator onchain, follow the instructions below. Keep in mind that these steps are necessary ONLY if you want to participate in the consensus.

    Pick a moniker name of your choice! This is the validator name that will show up on public dashboards and explorers. VALIDATOR_WALLET must be the same you defined previously. Parameter --min-self-delegation=1000000 defines the amount of tokens that are self delegated from your validator wallet.

    Now, connect to the network of your choice.

    You have the following option of connecting to list of networks shown below:

    Continuing the validator tutorial, here are the steps to connect your validator to Mocha:

    `,30),I={class:"language-bash vp-adaptive-theme"},P=s("button",{title:"Copy Code",class:"copy"},null,-1),V=s("span",{class:"lang"},"bash",-1),R={class:"shiki github-dark vp-code-dark"},D=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"MONIKER"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"your_moniker"')],-1),N=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"validator"')],-1),L=s("span",{class:"line"},null,-1),O=e('celestia-appd tx staking create-validator \\',1),M=e(' --amount=1000000utia \\',1),z=e(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),W=e(' --moniker=$MONIKER \\',1),H={class:"line"},U=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#79B8FF"}},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),K=s("span",{style:{color:"#79B8FF"}},"\\",-1),X=e(' --commission-rate=0.1 \\',1),G=e(' --commission-max-rate=0.2 \\',1),J=e(' --commission-max-change-rate=0.01 \\',1),Q=e(' --min-self-delegation=1000000 \\',1),j=e(' --from=$VALIDATOR_WALLET \\',1),Z=e(' --keyring-backend=test \\',1),ss=e(' --fees=21000utia \\',1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),es={class:"shiki github-light vp-code-light"},ns=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"MONIKER"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"your_moniker"')],-1),os=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"validator"')],-1),ts=s("span",{class:"line"},null,-1),ls=e('celestia-appd tx staking create-validator \\',1),ps=e(' --amount=1000000utia \\',1),cs=e(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),rs=e(' --moniker=$MONIKER \\',1),is={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#005CC5"}},us=s("span",{style:{color:"#24292E"}}," ",-1),_s=s("span",{style:{color:"#005CC5"}},"\\",-1),ys=e(' --commission-rate=0.1 \\',1),gs=e(' --commission-max-rate=0.2 \\',1),Es=e(' --commission-max-change-rate=0.01 \\',1),Cs=e(' --min-self-delegation=1000000 \\',1),ms=e(' --from=$VALIDATOR_WALLET \\',1),Fs=e(' --keyring-backend=test \\',1),vs=e(' --fees=21000utia \\',1),bs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=e(`

    You will be prompted to confirm the transaction:

    console
    confirm transaction before signing and broadcasting [y/N]: y
    confirm transaction before signing and broadcasting [y/N]: y

    Inputting y should provide an output similar to:

    console
    code: 0
     codespace: ""
     data: ""
     gas_used: "0"
    @@ -44,35 +44,35 @@ import{c as o}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,a
     raw_log: '[]'
     timestamp: ""
     tx: null
    -txhash: <tx-hash>

    You should now be able to see your validator from a block explorer

    Submit your validator information

    After starting your node, please submit your node as a seed and peer to the networks repository.

    Optional: Transaction indexer configuration options

    Follow the instructions under transaction indexer configuration options to configure your config.toml file to select which transactions to index.

    Additional resources

    For additional resources, refer to the extra resources for consensus nodessection of the consensus node page.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to update your binary to the latest version and restart your node with the relevant --v2-upgrade-height for the network you're running on. If your node still can't sync to the tip of the chain after the above steps, consider a celestia-appd tendermint reset-state to reset your node and start syncing from the genesis block.

    1. [Optional] Back up your validator keys.
    2. [Optional] Back up the data/priv_validator_state.json inside your CELESTIA_HOME directory.
    3. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    4. Remove the data/application.db inside your CELESTIA_HOME directory.
    5. Download the latest binary for your network.
    6. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    `,17),qs=JSON.parse('{"title":"Setting up a Celestia validator node","description":"Learn how to set up a Celestia validator node.","frontmatter":{"description":"Learn how to set up a Celestia validator node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia validator node."}]]},"headers":[],"relativePath":"how-to-guides/validator-node.md","filePath":"how-to-guides/validator-node.md","lastUpdated":1732776394000}'),ks={name:"how-to-guides/validator-node.md"},ws=Object.assign(ks,{setup(fs){return(As,Ss)=>(l(),p("div",null,[r,s("div",i,[d,h,s("pre",u,[s("code",null,[_,a(` +txhash: <tx-hash>

    You should now be able to see your validator from a block explorer

    Submit your validator information

    After starting your node, please submit your node as a seed and peer to the networks repository.

    Optional: Transaction indexer configuration options

    Follow the instructions under transaction indexer configuration options to configure your config.toml file to select which transactions to index.

    Additional resources

    For additional resources, refer to the extra resources for consensus nodessection of the consensus node page.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\\nruntime/debug.Stack()\\n\\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\\npanic({0x1b91180?, 0x400153b240?})\\n\\t/usr/local/go/src/runtime/panic.go:770 +0x124\\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\\n\\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to update your binary to the latest version and restart your node with the relevant --v2-upgrade-height for the network you're running on. If your node still can't sync to the tip of the chain after the above steps, consider a celestia-appd tendermint reset-state to reset your node and start syncing from the genesis block.

    1. [Optional] Back up your validator keys.
    2. [Optional] Back up the data/priv_validator_state.json inside your CELESTIA_HOME directory.
    3. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    4. Remove the data/application.db inside your CELESTIA_HOME directory.
    5. Download the latest binary for your network.
    6. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    `,17),qs=JSON.parse('{"title":"Setting up a Celestia validator node","description":"Learn how to set up a Celestia validator node.","frontmatter":{"description":"Learn how to set up a Celestia validator node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia validator node."}]]},"headers":[],"relativePath":"how-to-guides/validator-node.md","filePath":"how-to-guides/validator-node.md","lastUpdated":1732777479000}'),ks={name:"how-to-guides/validator-node.md"},ws=Object.assign(ks,{setup(fs){return(As,Ss)=>(l(),p("div",null,[r,s("div",i,[d,h,s("pre",u,[s("code",null,[_,a(` `),y,a(` -`),s("span",g,[E,s("span",C,"--chain-id="+n(t(o).mochaChainId),1),m,F]),a(` +`),s("span",g,[E,s("span",C,"--chain-id="+o(t(n).mochaChainId),1),m,F]),a(` `),v])]),s("pre",b,[s("code",null,[T,a(` `),k,a(` -`),s("span",f,[A,s("span",S,"--chain-id="+n(t(o).mochaChainId),1),B,x]),a(` +`),s("span",f,[A,s("span",S,"--chain-id="+o(t(n).mochaChainId),1),B,x]),a(` `),q])])]),w,s("div",I,[P,V,s("pre",R,[s("code",null,[D,a(` -`),L,a(` `),N,a(` +`),L,a(` `),O,a(` `),M,a(` `),z,a(` `),W,a(` -`),s("span",U,[$,s("span",H,"--chain-id="+n(t(o).mochaChainId),1),Y,G]),a(` -`),K,a(` -`),j,a(` +`),s("span",H,[U,s("span",$,"--chain-id="+o(t(n).mochaChainId),1),Y,K]),a(` +`),X,a(` +`),G,a(` `),J,a(` `),Q,a(` -`),X,a(` +`),j,a(` `),Z,a(` `),ss,a(` -`),as])]),s("pre",es,[s("code",null,[os,a(` -`),ns,a(` +`),as])]),s("pre",es,[s("code",null,[ns,a(` +`),os,a(` `),ts,a(` `),ls,a(` `),ps,a(` `),cs,a(` `),rs,a(` -`),s("span",is,[ds,s("span",hs,"--chain-id="+n(t(o).mochaChainId),1),us,_s]),a(` +`),s("span",is,[ds,s("span",hs,"--chain-id="+o(t(n).mochaChainId),1),us,_s]),a(` `),ys,a(` `),gs,a(` `),Es,a(` diff --git a/pr-1815/assets/how-to-guides_validator-node.md.e6b62962.lean.js b/pr-1815/assets/how-to-guides_validator-node.md.5e3cb47d.lean.js similarity index 76% rename from pr-1815/assets/how-to-guides_validator-node.md.e6b62962.lean.js rename to pr-1815/assets/how-to-guides_validator-node.md.5e3cb47d.lean.js index 5a7961ce3..fc780164f 100644 --- a/pr-1815/assets/how-to-guides_validator-node.md.e6b62962.lean.js +++ b/pr-1815/assets/how-to-guides_validator-node.md.5e3cb47d.lean.js @@ -1,32 +1,32 @@ -import{c as o}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,a,t as n,l as t,Q as e}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/validator.png",r=e("",19),i={class:"language-bash vp-adaptive-theme"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},_=e("",1),y=e("",1),g={class:"line"},E=s("span",{style:{color:"#E1E4E8"}},"--from=$VALIDATOR_WALLET ",-1),C={style:{color:"#79B8FF"}},m=s("span",{style:{color:"#E1E4E8"}}," ",-1),F=s("span",{style:{color:"#79B8FF"}},"\\",-1),v=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),b={class:"shiki github-light vp-code-light"},T=e("",1),k=e("",1),f={class:"line"},A=s("span",{style:{color:"#24292E"}},"--from=$VALIDATOR_WALLET ",-1),S={style:{color:"#005CC5"}},B=s("span",{style:{color:"#24292E"}}," ",-1),x=s("span",{style:{color:"#005CC5"}},"\\",-1),q=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"--fees=21000utia")],-1),w=e("",30),I={class:"language-bash vp-adaptive-theme"},P=s("button",{title:"Copy Code",class:"copy"},null,-1),V=s("span",{class:"lang"},"bash",-1),R={class:"shiki github-dark vp-code-dark"},D=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"MONIKER"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"your_moniker"')],-1),L=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"validator"')],-1),N=s("span",{class:"line"},null,-1),O=e("",1),M=e("",1),z=e("",1),W=e("",1),U={class:"line"},$=s("span",{style:{color:"#E1E4E8"}}," ",-1),H={style:{color:"#79B8FF"}},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),G=s("span",{style:{color:"#79B8FF"}},"\\",-1),K=e("",1),j=e("",1),J=e("",1),Q=e("",1),X=e("",1),Z=e("",1),ss=e("",1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),es={class:"shiki github-light vp-code-light"},os=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"MONIKER"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"your_moniker"')],-1),ns=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"validator"')],-1),ts=s("span",{class:"line"},null,-1),ls=e("",1),ps=e("",1),cs=e("",1),rs=e("",1),is={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#005CC5"}},us=s("span",{style:{color:"#24292E"}}," ",-1),_s=s("span",{style:{color:"#005CC5"}},"\\",-1),ys=e("",1),gs=e("",1),Es=e("",1),Cs=e("",1),ms=e("",1),Fs=e("",1),vs=e("",1),bs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=e("",17),qs=JSON.parse('{"title":"Setting up a Celestia validator node","description":"Learn how to set up a Celestia validator node.","frontmatter":{"description":"Learn how to set up a Celestia validator node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia validator node."}]]},"headers":[],"relativePath":"how-to-guides/validator-node.md","filePath":"how-to-guides/validator-node.md","lastUpdated":1732776394000}'),ks={name:"how-to-guides/validator-node.md"},ws=Object.assign(ks,{setup(fs){return(As,Ss)=>(l(),p("div",null,[r,s("div",i,[d,h,s("pre",u,[s("code",null,[_,a(` +import{c as n}from"./chunks/constants.b02263eb.js";import{o as l,c as p,k as s,a,t as o,l as t,Q as e}from"./chunks/framework.2959b752.js";const c="/docs-preview/pr-1815/img/nodes/validator.png",r=e("",19),i={class:"language-bash vp-adaptive-theme"},d=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("span",{class:"lang"},"bash",-1),u={class:"shiki github-dark vp-code-dark"},_=e("",1),y=e("",1),g={class:"line"},E=s("span",{style:{color:"#E1E4E8"}},"--from=$VALIDATOR_WALLET ",-1),C={style:{color:"#79B8FF"}},m=s("span",{style:{color:"#E1E4E8"}}," ",-1),F=s("span",{style:{color:"#79B8FF"}},"\\",-1),v=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),b={class:"shiki github-light vp-code-light"},T=e("",1),k=e("",1),f={class:"line"},A=s("span",{style:{color:"#24292E"}},"--from=$VALIDATOR_WALLET ",-1),S={style:{color:"#005CC5"}},B=s("span",{style:{color:"#24292E"}}," ",-1),x=s("span",{style:{color:"#005CC5"}},"\\",-1),q=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"--fees=21000utia")],-1),w=e("",30),I={class:"language-bash vp-adaptive-theme"},P=s("button",{title:"Copy Code",class:"copy"},null,-1),V=s("span",{class:"lang"},"bash",-1),R={class:"shiki github-dark vp-code-dark"},D=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"MONIKER"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"your_moniker"')],-1),N=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#F97583"}},"="),s("span",{style:{color:"#9ECBFF"}},'"validator"')],-1),L=s("span",{class:"line"},null,-1),O=e("",1),M=e("",1),z=e("",1),W=e("",1),H={class:"line"},U=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#79B8FF"}},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),K=s("span",{style:{color:"#79B8FF"}},"\\",-1),X=e("",1),G=e("",1),J=e("",1),Q=e("",1),j=e("",1),Z=e("",1),ss=e("",1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),es={class:"shiki github-light vp-code-light"},ns=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"MONIKER"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"your_moniker"')],-1),os=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"VALIDATOR_WALLET"),s("span",{style:{color:"#D73A49"}},"="),s("span",{style:{color:"#032F62"}},'"validator"')],-1),ts=s("span",{class:"line"},null,-1),ls=e("",1),ps=e("",1),cs=e("",1),rs=e("",1),is={class:"line"},ds=s("span",{style:{color:"#24292E"}}," ",-1),hs={style:{color:"#005CC5"}},us=s("span",{style:{color:"#24292E"}}," ",-1),_s=s("span",{style:{color:"#005CC5"}},"\\",-1),ys=e("",1),gs=e("",1),Es=e("",1),Cs=e("",1),ms=e("",1),Fs=e("",1),vs=e("",1),bs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=e("",17),qs=JSON.parse('{"title":"Setting up a Celestia validator node","description":"Learn how to set up a Celestia validator node.","frontmatter":{"description":"Learn how to set up a Celestia validator node.","outline":"deep","head":[["meta",{"property":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to set up a Celestia validator node."}]]},"headers":[],"relativePath":"how-to-guides/validator-node.md","filePath":"how-to-guides/validator-node.md","lastUpdated":1732777479000}'),ks={name:"how-to-guides/validator-node.md"},ws=Object.assign(ks,{setup(fs){return(As,Ss)=>(l(),p("div",null,[r,s("div",i,[d,h,s("pre",u,[s("code",null,[_,a(` `),y,a(` -`),s("span",g,[E,s("span",C,"--chain-id="+n(t(o).mochaChainId),1),m,F]),a(` +`),s("span",g,[E,s("span",C,"--chain-id="+o(t(n).mochaChainId),1),m,F]),a(` `),v])]),s("pre",b,[s("code",null,[T,a(` `),k,a(` -`),s("span",f,[A,s("span",S,"--chain-id="+n(t(o).mochaChainId),1),B,x]),a(` +`),s("span",f,[A,s("span",S,"--chain-id="+o(t(n).mochaChainId),1),B,x]),a(` `),q])])]),w,s("div",I,[P,V,s("pre",R,[s("code",null,[D,a(` -`),L,a(` `),N,a(` +`),L,a(` `),O,a(` `),M,a(` `),z,a(` `),W,a(` -`),s("span",U,[$,s("span",H,"--chain-id="+n(t(o).mochaChainId),1),Y,G]),a(` -`),K,a(` -`),j,a(` +`),s("span",H,[U,s("span",$,"--chain-id="+o(t(n).mochaChainId),1),Y,K]),a(` +`),X,a(` +`),G,a(` `),J,a(` `),Q,a(` -`),X,a(` +`),j,a(` `),Z,a(` `),ss,a(` -`),as])]),s("pre",es,[s("code",null,[os,a(` -`),ns,a(` +`),as])]),s("pre",es,[s("code",null,[ns,a(` +`),os,a(` `),ts,a(` `),ls,a(` `),ps,a(` `),cs,a(` `),rs,a(` -`),s("span",is,[ds,s("span",hs,"--chain-id="+n(t(o).mochaChainId),1),us,_s]),a(` +`),s("span",is,[ds,s("span",hs,"--chain-id="+o(t(n).mochaChainId),1),us,_s]),a(` `),ys,a(` `),gs,a(` `),Es,a(` diff --git a/pr-1815/assets/index.md.301f8cf4.js b/pr-1815/assets/index.md.5f15dd4a.js similarity index 96% rename from pr-1815/assets/index.md.301f8cf4.js rename to pr-1815/assets/index.md.5f15dd4a.js index f879b0eac..e98415e00 100644 --- a/pr-1815/assets/index.md.301f8cf4.js +++ b/pr-1815/assets/index.md.5f15dd4a.js @@ -1 +1 @@ -import{_ as t,o as e,c as i}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"","titleTemplate":":title","description":"","frontmatter":{"layout":"home","titleTemplate":":title","hero":{"name":"Celestia","text":"The first modular blockchain network","tagline":"Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.","image":{"src":"/modular.svg","alt":"Celestia"},"actions":[{"theme":"brand","text":"Quick start","link":"/how-to-guides/quick-start"},{"theme":"alt","text":"Introduction","link":"/learn/how-celestia-works/overview"}]},"features":[{"title":"Learn","details":"Celestia allows you to deploy your own blockchain in minutes, as easily as a smart contract.","link":"/learn/how-celestia-works/overview","icon":"🏗️"},{"title":"How-to guides","details":"Explore step-by-step guides for running a node, posting data blobs, building applications and sovereign rollups on Celestia.","link":"/how-to-guides/quick-start","icon":"📈"},{"title":"Tutorials","details":"Access tutorials for interacting with Celestia, starting with celestia-node through the node API.","link":"/tutorials/node-api","icon":"⚙️"},{"title":"Community","details":"Join the Celestia discord to connect, collaborate, and contribute to the future of modular blockchains.","link":"https://discord.gg/celestiacommunity","icon":"🏰"}],"head":[["meta",{"property":"og:title","content":"Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1732776394000}'),a={name:"index.md"};function o(n,s,l,r,c,d){return e(),i("div")}const m=t(a,[["render",o]]);export{h as __pageData,m as default}; +import{_ as t,o as e,c as i}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"","titleTemplate":":title","description":"","frontmatter":{"layout":"home","titleTemplate":":title","hero":{"name":"Celestia","text":"The first modular blockchain network","tagline":"Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.","image":{"src":"/modular.svg","alt":"Celestia"},"actions":[{"theme":"brand","text":"Quick start","link":"/how-to-guides/quick-start"},{"theme":"alt","text":"Introduction","link":"/learn/how-celestia-works/overview"}]},"features":[{"title":"Learn","details":"Celestia allows you to deploy your own blockchain in minutes, as easily as a smart contract.","link":"/learn/how-celestia-works/overview","icon":"🏗️"},{"title":"How-to guides","details":"Explore step-by-step guides for running a node, posting data blobs, building applications and sovereign rollups on Celestia.","link":"/how-to-guides/quick-start","icon":"📈"},{"title":"Tutorials","details":"Access tutorials for interacting with Celestia, starting with celestia-node through the node API.","link":"/tutorials/node-api","icon":"⚙️"},{"title":"Community","details":"Join the Celestia discord to connect, collaborate, and contribute to the future of modular blockchains.","link":"https://discord.gg/celestiacommunity","icon":"🏰"}],"head":[["meta",{"property":"og:title","content":"Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1732777479000}'),a={name:"index.md"};function o(n,s,l,r,c,d){return e(),i("div")}const m=t(a,[["render",o]]);export{h as __pageData,m as default}; diff --git a/pr-1815/assets/index.md.301f8cf4.lean.js b/pr-1815/assets/index.md.5f15dd4a.lean.js similarity index 96% rename from pr-1815/assets/index.md.301f8cf4.lean.js rename to pr-1815/assets/index.md.5f15dd4a.lean.js index f879b0eac..e98415e00 100644 --- a/pr-1815/assets/index.md.301f8cf4.lean.js +++ b/pr-1815/assets/index.md.5f15dd4a.lean.js @@ -1 +1 @@ -import{_ as t,o as e,c as i}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"","titleTemplate":":title","description":"","frontmatter":{"layout":"home","titleTemplate":":title","hero":{"name":"Celestia","text":"The first modular blockchain network","tagline":"Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.","image":{"src":"/modular.svg","alt":"Celestia"},"actions":[{"theme":"brand","text":"Quick start","link":"/how-to-guides/quick-start"},{"theme":"alt","text":"Introduction","link":"/learn/how-celestia-works/overview"}]},"features":[{"title":"Learn","details":"Celestia allows you to deploy your own blockchain in minutes, as easily as a smart contract.","link":"/learn/how-celestia-works/overview","icon":"🏗️"},{"title":"How-to guides","details":"Explore step-by-step guides for running a node, posting data blobs, building applications and sovereign rollups on Celestia.","link":"/how-to-guides/quick-start","icon":"📈"},{"title":"Tutorials","details":"Access tutorials for interacting with Celestia, starting with celestia-node through the node API.","link":"/tutorials/node-api","icon":"⚙️"},{"title":"Community","details":"Join the Celestia discord to connect, collaborate, and contribute to the future of modular blockchains.","link":"https://discord.gg/celestiacommunity","icon":"🏰"}],"head":[["meta",{"property":"og:title","content":"Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1732776394000}'),a={name:"index.md"};function o(n,s,l,r,c,d){return e(),i("div")}const m=t(a,[["render",o]]);export{h as __pageData,m as default}; +import{_ as t,o as e,c as i}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"","titleTemplate":":title","description":"","frontmatter":{"layout":"home","titleTemplate":":title","hero":{"name":"Celestia","text":"The first modular blockchain network","tagline":"Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.","image":{"src":"/modular.svg","alt":"Celestia"},"actions":[{"theme":"brand","text":"Quick start","link":"/how-to-guides/quick-start"},{"theme":"alt","text":"Introduction","link":"/learn/how-celestia-works/overview"}]},"features":[{"title":"Learn","details":"Celestia allows you to deploy your own blockchain in minutes, as easily as a smart contract.","link":"/learn/how-celestia-works/overview","icon":"🏗️"},{"title":"How-to guides","details":"Explore step-by-step guides for running a node, posting data blobs, building applications and sovereign rollups on Celestia.","link":"/how-to-guides/quick-start","icon":"📈"},{"title":"Tutorials","details":"Access tutorials for interacting with Celestia, starting with celestia-node through the node API.","link":"/tutorials/node-api","icon":"⚙️"},{"title":"Community","details":"Join the Celestia discord to connect, collaborate, and contribute to the future of modular blockchains.","link":"https://discord.gg/celestiacommunity","icon":"🏰"}],"head":[["meta",{"property":"og:title","content":"Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1732777479000}'),a={name:"index.md"};function o(n,s,l,r,c,d){return e(),i("div")}const m=t(a,[["render",o]]);export{h as __pageData,m as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.05200684.js b/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.7e26d360.js similarity index 99% rename from pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.05200684.js rename to pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.7e26d360.js index af78896c4..80fde2d2f 100644 --- a/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.05200684.js +++ b/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.7e26d360.js @@ -1 +1 @@ -import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-storage.png",v=JSON.parse('{"title":"Data availability FAQ","description":"Frequently asked questions related to Data Availability.","frontmatter":{"description":"Frequently asked questions related to Data Availability.","next":{"text":"Overview of TIA","link":"/learn/tia"},"head":[["meta",{"property":"og:title","content":"Data availability FAQ | Celestia Docs"}],["meta",{"property":"og:description","content":"Frequently asked questions related to Data Availability."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1732776394000}'),r={name:"learn/how-celestia-works/data-availability-faq.md"},l=i('

    Data availability FAQ

    What is data availability?

    Data availability answers the question, has this data been published? Specifically, a node will verify data availability when it receives a new block that is getting added to the chain. The node will attempt to download all the transaction data for the new block to verify availability. If the node can download all the transaction data, then it successfully verified data availability, proving that the block data was actually published to the network.

    Modular VS Monolithic

    As you’ll see, modular blockchains like Celestia employ other primitives that allow nodes to verify data availability more efficiently. Data availability is critical to the security of any blockchain because it ensures that anyone can inspect the ledger of transactions and verify it. Data availability becomes particularly problematic when scaling blockchains. As the blocks get bigger, it becomes impractical for normal users to download all the data, and therefore users can no longer verify the chain.

    What is the data availability problem?

    The problem with data availability occurs when the transaction data for a newly proposed block cannot be downloaded and verified. This type of attack by a block producer is called a data withholding attack, which sees the block producer withhold transaction data of a new block.

    Since transaction data is withheld, nodes cannot update to the latest state. Such an attack can have numerous consequences, from halting a chain to gaining the ability to steal funds. The severity of the consequences will depend on the type of blockchain (L1 or L2) and whether data availability is kept onchain or offchain. The data availability problem commonly arises around L2 scaling solutions like rollups and validiums.

    How do nodes verify data availability in Celestia?

    In most blockchains, nodes that verify data availability do so by downloading all transaction data for a block. If they are able to download all the data, they have verified its availability. In Celestia, light nodes have access to a new mechanism to verify data availability without needing to download all the data for a block. This new primitive for verifying data availability is called data availability sampling.

    What is data availability sampling?

    Data availability sampling is a mechanism for light nodes to verify data availability without having to download all data for a block. Data availability sampling (DAS) works by having light nodes conduct multiple rounds of random sampling for small portions of block data. As a light node completes more rounds of sampling for block data, it increases its confidence that data is available. Once the light node successfully reaches a predetermined confidence level (e.g. 99%) it will consider the block data as available.

    Want a simpler explanation? Check out this thread on how data availability sampling is like flipping a coin.

    What are some of the security assumptions that Celestia makes for data availability sampling?

    Celestia assumes that there is a minimum number of light nodes that are conducting data availability sampling for a given block size. This assumption is necessary so that a full node can reconstruct an entire block from the portions of data light nodes sampled and stored. The amount of light nodes that are needed will depend on the block size - for bigger blocks more light nodes are assumed to be running.

    A second notable assumption that is made by light nodes is that they are connected to at least one honest full node. This ensures that they can receive fraud proofs for incorrectly erasure coded blocks. If a light node is not connected to an honest full node, such as during an eclipse attack, it can’t verify that the block is improperly constructed.

    Why is block reconstruction necessary for security?

    In Celestia, blocks need to be erasure coded so that there is redundant data to aid the data availability sampling process. However, nodes tasked with erasure coding the data could do so incorrectly. Since Celestia uses fraud proofs to verify that erasure coding is incorrect, the full block data is needed to generate a bad encoding fraud proof.

    There could be a situation where validators only provide data to light nodes and not full nodes. If the full nodes don’t have the ability to reconstruct the full block from the portions of data stored by light nodes, they wouldn’t be able to generate a bad encoding fraud proof.

    What is data storage?

    Data storage is concerned with the ability to store and access past transaction data.

    Modular VS Monolithic

    Data storage and retrieval is needed for multiple purposes, such as:

    • Reading the information of a previous transaction
    • Syncing a node
    • Indexing and serving transaction data
    • Retrieving NFT information

    What is the problem around data storage?

    The issue with data storage is whether past transaction data can be stored and successfully retrieved at a later time. The inability to retrieve historical transaction data can cause problems, such as users being unable to access information about their past transactions or nodes that cannot sync from genesis. Luckily, the assumptions around storing and accessing past data are weak. Only a single copy of a blockchain’s history needs to be accessible for users to gain access to historical transaction data. In other words, data storage security is a 1 of N honesty assumption.

    What is the difference between data availability and data storage?

    Data availability is about verifying that transaction data for a new block is public and available. In contrast, data storage involves storing and accessing past transaction data from old blocks.

    Where does blockchain state fit into this?

    Up until now it’s been all about transaction data, but blockchain state is a related topic. The state is different from transaction data. Specifically, the state is like a current snapshot of the network, which includes information about account balances, smart contract balances, and validator set info. Problems that arise from the size of the state are different in nature than those around data availability and retrievability.

    Why doesn’t Celestia incentivize storage of historical data?

    Most blockchains don’t incentivize storage of data because it shouldn’t be the responsibility of a blockchain to guarantee past data will be retrievable forever. In addition, the data storage problem only requires a single party to store and provide the data for users, which is not a strong problem. As such, Celestia’s purpose is to provide a secure and scalable way to verify the availability of data. Once data has been verified as available, the job of storing and retrieving historical data is left up to other entities that require the data. Luckily, there are natural incentives for outside parties to store and serve historical data to users.

    Who may store historical data if there is no reward?

    There are multiple types of actors that may be likely to store historical data. Some of those include:

    • Block explorers that provide access to past transaction data.
    • Indexers that provide API queries for past data.
    • Applications or rollups that require historical data for certain processes.
    • Users that want to guarantee that they will have access to their transaction history.

    What are some things blockchains can do to provide stronger assurances of data retrievability?

    • Reward nodes based on the amount of transaction data they store and requests for data they serve (this is the case with some data storage blockchains, like Filecoin).
    • Publish transaction data onto a data storage blockchain that incentivizes storing and serving requests for historical data.
    ',37),n=[l];function d(h,c,b,u,f,p){return t(),e("div",null,n)}const m=a(r,[["render",d]]);export{v as __pageData,m as default}; +import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-storage.png",v=JSON.parse('{"title":"Data availability FAQ","description":"Frequently asked questions related to Data Availability.","frontmatter":{"description":"Frequently asked questions related to Data Availability.","next":{"text":"Overview of TIA","link":"/learn/tia"},"head":[["meta",{"property":"og:title","content":"Data availability FAQ | Celestia Docs"}],["meta",{"property":"og:description","content":"Frequently asked questions related to Data Availability."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1732777479000}'),r={name:"learn/how-celestia-works/data-availability-faq.md"},l=i('

    Data availability FAQ

    What is data availability?

    Data availability answers the question, has this data been published? Specifically, a node will verify data availability when it receives a new block that is getting added to the chain. The node will attempt to download all the transaction data for the new block to verify availability. If the node can download all the transaction data, then it successfully verified data availability, proving that the block data was actually published to the network.

    Modular VS Monolithic

    As you’ll see, modular blockchains like Celestia employ other primitives that allow nodes to verify data availability more efficiently. Data availability is critical to the security of any blockchain because it ensures that anyone can inspect the ledger of transactions and verify it. Data availability becomes particularly problematic when scaling blockchains. As the blocks get bigger, it becomes impractical for normal users to download all the data, and therefore users can no longer verify the chain.

    What is the data availability problem?

    The problem with data availability occurs when the transaction data for a newly proposed block cannot be downloaded and verified. This type of attack by a block producer is called a data withholding attack, which sees the block producer withhold transaction data of a new block.

    Since transaction data is withheld, nodes cannot update to the latest state. Such an attack can have numerous consequences, from halting a chain to gaining the ability to steal funds. The severity of the consequences will depend on the type of blockchain (L1 or L2) and whether data availability is kept onchain or offchain. The data availability problem commonly arises around L2 scaling solutions like rollups and validiums.

    How do nodes verify data availability in Celestia?

    In most blockchains, nodes that verify data availability do so by downloading all transaction data for a block. If they are able to download all the data, they have verified its availability. In Celestia, light nodes have access to a new mechanism to verify data availability without needing to download all the data for a block. This new primitive for verifying data availability is called data availability sampling.

    What is data availability sampling?

    Data availability sampling is a mechanism for light nodes to verify data availability without having to download all data for a block. Data availability sampling (DAS) works by having light nodes conduct multiple rounds of random sampling for small portions of block data. As a light node completes more rounds of sampling for block data, it increases its confidence that data is available. Once the light node successfully reaches a predetermined confidence level (e.g. 99%) it will consider the block data as available.

    Want a simpler explanation? Check out this thread on how data availability sampling is like flipping a coin.

    What are some of the security assumptions that Celestia makes for data availability sampling?

    Celestia assumes that there is a minimum number of light nodes that are conducting data availability sampling for a given block size. This assumption is necessary so that a full node can reconstruct an entire block from the portions of data light nodes sampled and stored. The amount of light nodes that are needed will depend on the block size - for bigger blocks more light nodes are assumed to be running.

    A second notable assumption that is made by light nodes is that they are connected to at least one honest full node. This ensures that they can receive fraud proofs for incorrectly erasure coded blocks. If a light node is not connected to an honest full node, such as during an eclipse attack, it can’t verify that the block is improperly constructed.

    Why is block reconstruction necessary for security?

    In Celestia, blocks need to be erasure coded so that there is redundant data to aid the data availability sampling process. However, nodes tasked with erasure coding the data could do so incorrectly. Since Celestia uses fraud proofs to verify that erasure coding is incorrect, the full block data is needed to generate a bad encoding fraud proof.

    There could be a situation where validators only provide data to light nodes and not full nodes. If the full nodes don’t have the ability to reconstruct the full block from the portions of data stored by light nodes, they wouldn’t be able to generate a bad encoding fraud proof.

    What is data storage?

    Data storage is concerned with the ability to store and access past transaction data.

    Modular VS Monolithic

    Data storage and retrieval is needed for multiple purposes, such as:

    • Reading the information of a previous transaction
    • Syncing a node
    • Indexing and serving transaction data
    • Retrieving NFT information

    What is the problem around data storage?

    The issue with data storage is whether past transaction data can be stored and successfully retrieved at a later time. The inability to retrieve historical transaction data can cause problems, such as users being unable to access information about their past transactions or nodes that cannot sync from genesis. Luckily, the assumptions around storing and accessing past data are weak. Only a single copy of a blockchain’s history needs to be accessible for users to gain access to historical transaction data. In other words, data storage security is a 1 of N honesty assumption.

    What is the difference between data availability and data storage?

    Data availability is about verifying that transaction data for a new block is public and available. In contrast, data storage involves storing and accessing past transaction data from old blocks.

    Where does blockchain state fit into this?

    Up until now it’s been all about transaction data, but blockchain state is a related topic. The state is different from transaction data. Specifically, the state is like a current snapshot of the network, which includes information about account balances, smart contract balances, and validator set info. Problems that arise from the size of the state are different in nature than those around data availability and retrievability.

    Why doesn’t Celestia incentivize storage of historical data?

    Most blockchains don’t incentivize storage of data because it shouldn’t be the responsibility of a blockchain to guarantee past data will be retrievable forever. In addition, the data storage problem only requires a single party to store and provide the data for users, which is not a strong problem. As such, Celestia’s purpose is to provide a secure and scalable way to verify the availability of data. Once data has been verified as available, the job of storing and retrieving historical data is left up to other entities that require the data. Luckily, there are natural incentives for outside parties to store and serve historical data to users.

    Who may store historical data if there is no reward?

    There are multiple types of actors that may be likely to store historical data. Some of those include:

    • Block explorers that provide access to past transaction data.
    • Indexers that provide API queries for past data.
    • Applications or rollups that require historical data for certain processes.
    • Users that want to guarantee that they will have access to their transaction history.

    What are some things blockchains can do to provide stronger assurances of data retrievability?

    • Reward nodes based on the amount of transaction data they store and requests for data they serve (this is the case with some data storage blockchains, like Filecoin).
    • Publish transaction data onto a data storage blockchain that incentivizes storing and serving requests for historical data.
    ',37),n=[l];function d(h,c,b,u,f,p){return t(),e("div",null,n)}const m=a(r,[["render",d]]);export{v as __pageData,m as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.05200684.lean.js b/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.7e26d360.lean.js similarity index 93% rename from pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.05200684.lean.js rename to pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.7e26d360.lean.js index c35829a1e..10de1422f 100644 --- a/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.05200684.lean.js +++ b/pr-1815/assets/learn_how-celestia-works_data-availability-faq.md.7e26d360.lean.js @@ -1 +1 @@ -import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-storage.png",v=JSON.parse('{"title":"Data availability FAQ","description":"Frequently asked questions related to Data Availability.","frontmatter":{"description":"Frequently asked questions related to Data Availability.","next":{"text":"Overview of TIA","link":"/learn/tia"},"head":[["meta",{"property":"og:title","content":"Data availability FAQ | Celestia Docs"}],["meta",{"property":"og:description","content":"Frequently asked questions related to Data Availability."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1732776394000}'),r={name:"learn/how-celestia-works/data-availability-faq.md"},l=i("",37),n=[l];function d(h,c,b,u,f,p){return t(),e("div",null,n)}const m=a(r,[["render",d]]);export{v as __pageData,m as default}; +import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.2959b752.js";const o="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1815/img/learn/data-availability-faq/Data-storage.png",v=JSON.parse('{"title":"Data availability FAQ","description":"Frequently asked questions related to Data Availability.","frontmatter":{"description":"Frequently asked questions related to Data Availability.","next":{"text":"Overview of TIA","link":"/learn/tia"},"head":[["meta",{"property":"og:title","content":"Data availability FAQ | Celestia Docs"}],["meta",{"property":"og:description","content":"Frequently asked questions related to Data Availability."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1732777479000}'),r={name:"learn/how-celestia-works/data-availability-faq.md"},l=i("",37),n=[l];function d(h,c,b,u,f,p){return t(),e("div",null,n)}const m=a(r,[["render",d]]);export{v as __pageData,m as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.95575ef0.js b/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.4b8bfd66.js similarity index 99% rename from pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.95575ef0.js rename to pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.4b8bfd66.js index e1615229c..e37fa0128 100644 --- a/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.95575ef0.js +++ b/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.4b8bfd66.js @@ -1 +1 @@ -import{_ as l,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1815/img/learn/nmt.png",r="/docs-preview/pr-1815/img/learn/celestia-app.png",g4=JSON.parse(`{"title":"Celestia's data availability layer","description":"Celestia's Data Availability layer and its key features.","frontmatter":{"description":"Celestia's Data Availability layer and its key features.","head":[["meta",{"property":"og:title","content":"Celestia's data availability layer | Celestia Docs"}],["meta",{"property":"og:description","content":"Celestia's Data Availability layer and its key features."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1732776394000}`),T={name:"learn/how-celestia-works/data-availability-layer.md"},d=s('

    Celestia's data availability layer

    Celestia is a data availability (DA) layer that provides a scalable solution to the data availability problem. Due to the permissionless nature of the blockchain networks, a DA layer must provide a mechanism for the execution and settlement layers to check in a trust-minimized way whether transaction data is indeed available.

    Two key features of Celestia's DA layer are data availability sampling (DAS) and Namespaced Merkle trees (NMTs). Both features are novel blockchain scaling solutions: DAS enables light nodes to verify data availability without needing to download an entire block; NMTs enable execution and settlement layers on Celestia to download transactions that are only relevant to them.

    Data availability sampling (DAS)

    In general, light nodes download only block headers that contain commitments (i.e., Merkle roots) of the block data (i.e., the list of transactions).

    ',5),Q={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},h={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},c=s('',1),m=[c],p=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),g={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},u=s('',1),_=[u],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),f={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},k=s('',1),y=[k],v=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),L={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H=s('',1),V=[H],S=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),C=e("p",null,[e("img",{src:i,alt:"2D Reed-Soloman (RS) Encoding"})],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},A={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},j=s('',1),Z=[j],P=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),N=e("p",null,[t("Every light node randomly chooses a set of unique coordinates in the extended matrix and queries full nodes for the data shares and the corresponding Merkle proofs at those coordinates. If light nodes receive a valid response for each sampling query, then there is a "),e("a",{href:"https://github.com/celestiaorg/celestia-node/issues/805#issuecomment-1150081075",target:"_blank",rel:"noreferrer"},"high probability guarantee"),t(" that the whole block's data is available.")],-1),I=e("em",null,"i.e.",-1),B={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},q=s('',1),E=[q],z=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),G=e("p",null,[t("For more details on DAS, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(".")],-1),J=e("h3",{id:"scalability",tabindex:"-1"},[t("Scalability "),e("a",{class:"header-anchor",href:"#scalability","aria-label":'Permalink to "Scalability"'},"​")],-1),F=e("p",null,"DAS enables Celestia to scale the DA layer. DAS can be performed by resource-limited light nodes since each light node only samples a small portion of the block data. The more light nodes there are in the network, the more data they can collectively download and store.",-1),O=e("em",null,"i.e.",-1),$={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},W={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},K=s('',1),U=[K],X=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),Y={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},e1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},t1=s('',1),a1=[t1],o1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),s1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},l1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},i1=s('',1),n1=[i1],r1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),T1=e("h3",{id:"fraud-proofs-of-incorrectly-extended-data",tabindex:"-1"},[t("Fraud proofs of incorrectly extended data "),e("a",{class:"header-anchor",href:"#fraud-proofs-of-incorrectly-extended-data","aria-label":'Permalink to "Fraud proofs of incorrectly extended data"'},"​")],-1),d1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},Q1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},h1=s('',1),c1=[h1],m1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),p1=e("em",null,"i.e.",-1),g1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},u1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),_1=[u1],w1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),f1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},k1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),y1=[k1],v1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),L1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H1=s('',1),V1=[H1],S1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k")])],-1),C1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},D1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},A1=s('',1),j1=[A1],Z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),P1=e("p",null,"The downside of the standard Reed-Solomon encoding is dealing with malicious block producers that generate the extended data incorrectly.",-1),N1=e("strong",null,[t("Celestia does not require a majority of the consensus ("),e("em",null,"i.e."),t(", block producers) to be honest to guarantee data availability.")],-1),I1=e("em",null,"i.e.",-1),B1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},q1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),E1=[q1],z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),G1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},J1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},F1=s('',1),O1=[F1],$1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),W1=e("em",null,"Fraud Proofs of Incorrectly Generated Extended Data",-1),K1=e("em",null,"i.e.",-1),U1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},X1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},Y1=s('',1),e4=[Y1],t4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),a4={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},o4={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},s4=s('',1),l4=[s4],i4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),n4=s('

    Namespaced Merkle trees (NMTs)

    Celestia partitions the block data into multiple namespaces, one for every application (e.g., rollup) using the DA layer. As a result, every application needs to download only its own data and can ignore the data of other applications.

    For this to work, the DA layer must be able to prove that the provided data is complete, i.e., all the data for a given namespace is returned. To this end, Celestia is using Namespaced Merkle trees (NMTs).

    An NMT is a Merkle tree with the leafs ordered by the namespace identifiers and the hash function modified so that every node in the tree includes the range of namespaces of all its descendants. The following figure shows an example of an NMT with height three (i.e., eight data shares). The data is partitioned into three namespaces.

    Namespaced Merkle Tree

    When an application requests the data for namespace 2, the DA layer must provide the data shares D3, D4, D5, and D6 and the nodes N2, N8 and N7 as proof (note that the application already has the root N14 from the block header).

    As a result, the application is able to check that the provided data is part of the block data. Furthermore, the application can verify that all the data for namespace 2 was provided. If the DA layer provides for example only the data shares D4 and D5, it must also provide nodes N12 and N11 as proofs. However, the application can identify that the data is incomplete by checking the namespace range of the two nodes, i.e., both N12 and N11 have descendants part of namespace 2.

    For more details on NMTs, refer to the original paper.

    Building a PoS blockchain for DA

    Providing data availability

    The Celestia DA layer consists of a PoS blockchain. Celestia is dubbing this blockchain as the celestia-app, an application that provides transactions to facilitate the DA layer and is built using Cosmos SDK. The following figure shows the main components of celestia-app.

    Main components of celestia-app

    celestia-app is built on top of celestia-core, a modified version of the Tendermint consensus algorithm. Among the more important changes to vanilla Tendermint, celestia-core:

    • Enables the erasure coding of block data (using the 2-dimensional Reed-Solomon encoding scheme).
    • Replaces the regular Merkle tree used by Tendermint to store block data with a Namespaced Merkle tree that enables the above layers (i.e., execution and settlement) to only download the needed data (for more details, see the section below describing use cases).

    For more details on the changes to Tendermint, take a look at the ADRs. Notice that celestia-core nodes are still using the Tendermint p2p network.

    Similarly to Tendermint, celestia-core is connected to the application layer (i.e., the state machine) by ABCI++, a major evolution of ABCI (Application Blockchain Interface).

    The celestia-app state machine is necessary to execute the PoS logic and to enable the governance of the DA layer.

    However, the celestia-app is data-agnostic -- the state machine neither validates nor stores the data that is made available by the celestia-app.

    ',18);function r4(T4,d4,Q4,h4,c4,m4){return a(),o("div",null,[d,e("p",null,[t("To make DAS possible, Celestia uses a 2-dimensional Reed-Solomon encoding scheme to encode the block data: every block data is split into "),e("mjx-container",Q,[(a(),o("svg",h,m)),p]),t(" shares, arranged in a "),e("mjx-container",g,[(a(),o("svg",x,_)),w]),t(" matrix, and extended with parity data into a "),e("mjx-container",f,[(a(),o("svg",b,y)),v]),t(" extended matrix by applying multiple times Reed-Solomon encoding.")]),e("p",null,[t("Then, "),e("mjx-container",L,[(a(),o("svg",M,V)),S]),t(" separate Merkle roots are computed for the rows and columns of the extended matrix; the Merkle root of these Merkle roots is used as the block data commitment in the block header.")]),C,e("p",null,[t("To verify that the data is available, Celestia light nodes are sampling the "),e("mjx-container",D,[(a(),o("svg",A,Z)),P]),t(" data shares.")]),N,e("p",null,[t("Additionally, every received data share with a correct Merkle proof is gossiped to the network. As a result, as long as the Celestia light nodes are sampling together enough data shares ("),I,t(", at least "),e("mjx-container",B,[(a(),o("svg",R,E)),z]),t(" unique shares), the full block can be recovered by honest full nodes.")]),G,J,F,e("p",null,[t("This means that increasing the number of light nodes performing DAS allows for larger blocks ("),O,t(", with more transactions), while still keeping DAS feasible for resource-limited light nodes. However, in order to validate block headers, Celestia light nodes need to download the "),e("mjx-container",$,[(a(),o("svg",W,U)),X]),t(" intermediate Merkle roots.")]),e("p",null,[t("For a block data size of "),e("mjx-container",Y,[(a(),o("svg",e1,a1)),o1]),t(" bytes, this means that every light node must download "),e("mjx-container",s1,[(a(),o("svg",l1,n1)),r1]),t(" bytes. Therefore, any improvement in the bandwidth capacity of Celestia light nodes has a quadratic effect on the throughput of Celestia's DA layer.")]),T1,e("p",null,[t("The requirement of downloading the "),e("mjx-container",d1,[(a(),o("svg",Q1,c1)),m1]),t(" intermediate Merkle roots is a consequence of using a 2-dimensional Reed-Solomon encoding scheme. Alternatively, DAS could be designed with a standard ("),p1,t(", 1-dimensional) Reed-Solomon encoding, where the original data is split into "),e("mjx-container",g1,[(a(),o("svg",x1,_1)),w1]),t(" shares and extended with "),e("mjx-container",f1,[(a(),o("svg",b1,y1)),v1]),t(" additional shares of parity data. Since the block data commitment is the Merkle root of the "),e("mjx-container",L1,[(a(),o("svg",M1,V1)),S1]),t(" resulting data shares, light nodes no longer need to download "),e("mjx-container",C1,[(a(),o("svg",D1,j1)),Z1]),t(" bytes to validate block headers.")]),P1,e("p",null,[t("This is possible as "),N1,t(" Thus, if the extended data is invalid, the original data might not be recoverable, even if the light nodes are sampling sufficient unique shares ("),I1,t(", at least "),e("mjx-container",B1,[(a(),o("svg",R1,E1)),z1]),t(" for a standard encoding and "),e("mjx-container",G1,[(a(),o("svg",J1,O1)),$1]),t(" for a 2-dimensional encoding).")]),e("p",null,[t("As a solution, "),W1,t(" enable light nodes to reject blocks with invalid extended data. Such proofs require reconstructing the encoding and verifying the mismatch. With standard Reed-Solomon encoding, this entails downloading the original data, "),K1,t(", "),e("mjx-container",U1,[(a(),o("svg",X1,e4)),t4]),t(" bytes. Contrastingly, with 2-dimensional Reed-Solomon encoding, only "),e("mjx-container",a4,[(a(),o("svg",o4,l4)),i4]),t(" bytes are required as it is sufficient to verify only one row or one column of the extended matrix.")]),n4])}const x4=l(T,[["render",r4]]);export{g4 as __pageData,x4 as default}; +import{_ as l,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1815/img/learn/nmt.png",r="/docs-preview/pr-1815/img/learn/celestia-app.png",g4=JSON.parse(`{"title":"Celestia's data availability layer","description":"Celestia's Data Availability layer and its key features.","frontmatter":{"description":"Celestia's Data Availability layer and its key features.","head":[["meta",{"property":"og:title","content":"Celestia's data availability layer | Celestia Docs"}],["meta",{"property":"og:description","content":"Celestia's Data Availability layer and its key features."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1732777479000}`),T={name:"learn/how-celestia-works/data-availability-layer.md"},d=s('

    Celestia's data availability layer

    Celestia is a data availability (DA) layer that provides a scalable solution to the data availability problem. Due to the permissionless nature of the blockchain networks, a DA layer must provide a mechanism for the execution and settlement layers to check in a trust-minimized way whether transaction data is indeed available.

    Two key features of Celestia's DA layer are data availability sampling (DAS) and Namespaced Merkle trees (NMTs). Both features are novel blockchain scaling solutions: DAS enables light nodes to verify data availability without needing to download an entire block; NMTs enable execution and settlement layers on Celestia to download transactions that are only relevant to them.

    Data availability sampling (DAS)

    In general, light nodes download only block headers that contain commitments (i.e., Merkle roots) of the block data (i.e., the list of transactions).

    ',5),Q={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},h={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},c=s('',1),m=[c],p=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),g={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},u=s('',1),_=[u],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),f={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},k=s('',1),y=[k],v=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),L={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H=s('',1),V=[H],S=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),C=e("p",null,[e("img",{src:i,alt:"2D Reed-Soloman (RS) Encoding"})],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},A={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},j=s('',1),Z=[j],P=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),N=e("p",null,[t("Every light node randomly chooses a set of unique coordinates in the extended matrix and queries full nodes for the data shares and the corresponding Merkle proofs at those coordinates. If light nodes receive a valid response for each sampling query, then there is a "),e("a",{href:"https://github.com/celestiaorg/celestia-node/issues/805#issuecomment-1150081075",target:"_blank",rel:"noreferrer"},"high probability guarantee"),t(" that the whole block's data is available.")],-1),I=e("em",null,"i.e.",-1),B={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},q=s('',1),E=[q],z=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),G=e("p",null,[t("For more details on DAS, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(".")],-1),J=e("h3",{id:"scalability",tabindex:"-1"},[t("Scalability "),e("a",{class:"header-anchor",href:"#scalability","aria-label":'Permalink to "Scalability"'},"​")],-1),F=e("p",null,"DAS enables Celestia to scale the DA layer. DAS can be performed by resource-limited light nodes since each light node only samples a small portion of the block data. The more light nodes there are in the network, the more data they can collectively download and store.",-1),O=e("em",null,"i.e.",-1),$={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},W={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},K=s('',1),U=[K],X=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),Y={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},e1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},t1=s('',1),a1=[t1],o1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),s1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},l1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},i1=s('',1),n1=[i1],r1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),T1=e("h3",{id:"fraud-proofs-of-incorrectly-extended-data",tabindex:"-1"},[t("Fraud proofs of incorrectly extended data "),e("a",{class:"header-anchor",href:"#fraud-proofs-of-incorrectly-extended-data","aria-label":'Permalink to "Fraud proofs of incorrectly extended data"'},"​")],-1),d1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},Q1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},h1=s('',1),c1=[h1],m1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),p1=e("em",null,"i.e.",-1),g1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},u1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),_1=[u1],w1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),f1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},k1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),y1=[k1],v1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),L1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H1=s('',1),V1=[H1],S1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k")])],-1),C1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},D1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},A1=s('',1),j1=[A1],Z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),P1=e("p",null,"The downside of the standard Reed-Solomon encoding is dealing with malicious block producers that generate the extended data incorrectly.",-1),N1=e("strong",null,[t("Celestia does not require a majority of the consensus ("),e("em",null,"i.e."),t(", block producers) to be honest to guarantee data availability.")],-1),I1=e("em",null,"i.e.",-1),B1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},q1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),E1=[q1],z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),G1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},J1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},F1=s('',1),O1=[F1],$1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),W1=e("em",null,"Fraud Proofs of Incorrectly Generated Extended Data",-1),K1=e("em",null,"i.e.",-1),U1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},X1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},Y1=s('',1),e4=[Y1],t4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),a4={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},o4={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},s4=s('',1),l4=[s4],i4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),n4=s('

    Namespaced Merkle trees (NMTs)

    Celestia partitions the block data into multiple namespaces, one for every application (e.g., rollup) using the DA layer. As a result, every application needs to download only its own data and can ignore the data of other applications.

    For this to work, the DA layer must be able to prove that the provided data is complete, i.e., all the data for a given namespace is returned. To this end, Celestia is using Namespaced Merkle trees (NMTs).

    An NMT is a Merkle tree with the leafs ordered by the namespace identifiers and the hash function modified so that every node in the tree includes the range of namespaces of all its descendants. The following figure shows an example of an NMT with height three (i.e., eight data shares). The data is partitioned into three namespaces.

    Namespaced Merkle Tree

    When an application requests the data for namespace 2, the DA layer must provide the data shares D3, D4, D5, and D6 and the nodes N2, N8 and N7 as proof (note that the application already has the root N14 from the block header).

    As a result, the application is able to check that the provided data is part of the block data. Furthermore, the application can verify that all the data for namespace 2 was provided. If the DA layer provides for example only the data shares D4 and D5, it must also provide nodes N12 and N11 as proofs. However, the application can identify that the data is incomplete by checking the namespace range of the two nodes, i.e., both N12 and N11 have descendants part of namespace 2.

    For more details on NMTs, refer to the original paper.

    Building a PoS blockchain for DA

    Providing data availability

    The Celestia DA layer consists of a PoS blockchain. Celestia is dubbing this blockchain as the celestia-app, an application that provides transactions to facilitate the DA layer and is built using Cosmos SDK. The following figure shows the main components of celestia-app.

    Main components of celestia-app

    celestia-app is built on top of celestia-core, a modified version of the Tendermint consensus algorithm. Among the more important changes to vanilla Tendermint, celestia-core:

    • Enables the erasure coding of block data (using the 2-dimensional Reed-Solomon encoding scheme).
    • Replaces the regular Merkle tree used by Tendermint to store block data with a Namespaced Merkle tree that enables the above layers (i.e., execution and settlement) to only download the needed data (for more details, see the section below describing use cases).

    For more details on the changes to Tendermint, take a look at the ADRs. Notice that celestia-core nodes are still using the Tendermint p2p network.

    Similarly to Tendermint, celestia-core is connected to the application layer (i.e., the state machine) by ABCI++, a major evolution of ABCI (Application Blockchain Interface).

    The celestia-app state machine is necessary to execute the PoS logic and to enable the governance of the DA layer.

    However, the celestia-app is data-agnostic -- the state machine neither validates nor stores the data that is made available by the celestia-app.

    ',18);function r4(T4,d4,Q4,h4,c4,m4){return a(),o("div",null,[d,e("p",null,[t("To make DAS possible, Celestia uses a 2-dimensional Reed-Solomon encoding scheme to encode the block data: every block data is split into "),e("mjx-container",Q,[(a(),o("svg",h,m)),p]),t(" shares, arranged in a "),e("mjx-container",g,[(a(),o("svg",x,_)),w]),t(" matrix, and extended with parity data into a "),e("mjx-container",f,[(a(),o("svg",b,y)),v]),t(" extended matrix by applying multiple times Reed-Solomon encoding.")]),e("p",null,[t("Then, "),e("mjx-container",L,[(a(),o("svg",M,V)),S]),t(" separate Merkle roots are computed for the rows and columns of the extended matrix; the Merkle root of these Merkle roots is used as the block data commitment in the block header.")]),C,e("p",null,[t("To verify that the data is available, Celestia light nodes are sampling the "),e("mjx-container",D,[(a(),o("svg",A,Z)),P]),t(" data shares.")]),N,e("p",null,[t("Additionally, every received data share with a correct Merkle proof is gossiped to the network. As a result, as long as the Celestia light nodes are sampling together enough data shares ("),I,t(", at least "),e("mjx-container",B,[(a(),o("svg",R,E)),z]),t(" unique shares), the full block can be recovered by honest full nodes.")]),G,J,F,e("p",null,[t("This means that increasing the number of light nodes performing DAS allows for larger blocks ("),O,t(", with more transactions), while still keeping DAS feasible for resource-limited light nodes. However, in order to validate block headers, Celestia light nodes need to download the "),e("mjx-container",$,[(a(),o("svg",W,U)),X]),t(" intermediate Merkle roots.")]),e("p",null,[t("For a block data size of "),e("mjx-container",Y,[(a(),o("svg",e1,a1)),o1]),t(" bytes, this means that every light node must download "),e("mjx-container",s1,[(a(),o("svg",l1,n1)),r1]),t(" bytes. Therefore, any improvement in the bandwidth capacity of Celestia light nodes has a quadratic effect on the throughput of Celestia's DA layer.")]),T1,e("p",null,[t("The requirement of downloading the "),e("mjx-container",d1,[(a(),o("svg",Q1,c1)),m1]),t(" intermediate Merkle roots is a consequence of using a 2-dimensional Reed-Solomon encoding scheme. Alternatively, DAS could be designed with a standard ("),p1,t(", 1-dimensional) Reed-Solomon encoding, where the original data is split into "),e("mjx-container",g1,[(a(),o("svg",x1,_1)),w1]),t(" shares and extended with "),e("mjx-container",f1,[(a(),o("svg",b1,y1)),v1]),t(" additional shares of parity data. Since the block data commitment is the Merkle root of the "),e("mjx-container",L1,[(a(),o("svg",M1,V1)),S1]),t(" resulting data shares, light nodes no longer need to download "),e("mjx-container",C1,[(a(),o("svg",D1,j1)),Z1]),t(" bytes to validate block headers.")]),P1,e("p",null,[t("This is possible as "),N1,t(" Thus, if the extended data is invalid, the original data might not be recoverable, even if the light nodes are sampling sufficient unique shares ("),I1,t(", at least "),e("mjx-container",B1,[(a(),o("svg",R1,E1)),z1]),t(" for a standard encoding and "),e("mjx-container",G1,[(a(),o("svg",J1,O1)),$1]),t(" for a 2-dimensional encoding).")]),e("p",null,[t("As a solution, "),W1,t(" enable light nodes to reject blocks with invalid extended data. Such proofs require reconstructing the encoding and verifying the mismatch. With standard Reed-Solomon encoding, this entails downloading the original data, "),K1,t(", "),e("mjx-container",U1,[(a(),o("svg",X1,e4)),t4]),t(" bytes. Contrastingly, with 2-dimensional Reed-Solomon encoding, only "),e("mjx-container",a4,[(a(),o("svg",o4,l4)),i4]),t(" bytes are required as it is sufficient to verify only one row or one column of the extended matrix.")]),n4])}const x4=l(T,[["render",r4]]);export{g4 as __pageData,x4 as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.95575ef0.lean.js b/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.4b8bfd66.lean.js similarity index 99% rename from pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.95575ef0.lean.js rename to pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.4b8bfd66.lean.js index 405054240..27402895b 100644 --- a/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.95575ef0.lean.js +++ b/pr-1815/assets/learn_how-celestia-works_data-availability-layer.md.4b8bfd66.lean.js @@ -1 +1 @@ -import{_ as l,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1815/img/learn/nmt.png",r="/docs-preview/pr-1815/img/learn/celestia-app.png",g4=JSON.parse(`{"title":"Celestia's data availability layer","description":"Celestia's Data Availability layer and its key features.","frontmatter":{"description":"Celestia's Data Availability layer and its key features.","head":[["meta",{"property":"og:title","content":"Celestia's data availability layer | Celestia Docs"}],["meta",{"property":"og:description","content":"Celestia's Data Availability layer and its key features."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1732776394000}`),T={name:"learn/how-celestia-works/data-availability-layer.md"},d=s("",5),Q={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},h={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},c=s("",1),m=[c],p=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),g={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},u=s("",1),_=[u],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),f={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},k=s("",1),y=[k],v=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),L={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H=s("",1),V=[H],S=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),C=e("p",null,[e("img",{src:i,alt:"2D Reed-Soloman (RS) Encoding"})],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},A={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},j=s("",1),Z=[j],P=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),N=e("p",null,[t("Every light node randomly chooses a set of unique coordinates in the extended matrix and queries full nodes for the data shares and the corresponding Merkle proofs at those coordinates. If light nodes receive a valid response for each sampling query, then there is a "),e("a",{href:"https://github.com/celestiaorg/celestia-node/issues/805#issuecomment-1150081075",target:"_blank",rel:"noreferrer"},"high probability guarantee"),t(" that the whole block's data is available.")],-1),I=e("em",null,"i.e.",-1),B={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},q=s("",1),E=[q],z=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),G=e("p",null,[t("For more details on DAS, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(".")],-1),J=e("h3",{id:"scalability",tabindex:"-1"},[t("Scalability "),e("a",{class:"header-anchor",href:"#scalability","aria-label":'Permalink to "Scalability"'},"​")],-1),F=e("p",null,"DAS enables Celestia to scale the DA layer. DAS can be performed by resource-limited light nodes since each light node only samples a small portion of the block data. The more light nodes there are in the network, the more data they can collectively download and store.",-1),O=e("em",null,"i.e.",-1),$={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},W={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},K=s("",1),U=[K],X=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),Y={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},e1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},t1=s("",1),a1=[t1],o1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),s1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},l1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},i1=s("",1),n1=[i1],r1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),T1=e("h3",{id:"fraud-proofs-of-incorrectly-extended-data",tabindex:"-1"},[t("Fraud proofs of incorrectly extended data "),e("a",{class:"header-anchor",href:"#fraud-proofs-of-incorrectly-extended-data","aria-label":'Permalink to "Fraud proofs of incorrectly extended data"'},"​")],-1),d1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},Q1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},h1=s("",1),c1=[h1],m1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),p1=e("em",null,"i.e.",-1),g1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},u1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),_1=[u1],w1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),f1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},k1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),y1=[k1],v1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),L1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H1=s("",1),V1=[H1],S1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k")])],-1),C1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},D1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},A1=s("",1),j1=[A1],Z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),P1=e("p",null,"The downside of the standard Reed-Solomon encoding is dealing with malicious block producers that generate the extended data incorrectly.",-1),N1=e("strong",null,[t("Celestia does not require a majority of the consensus ("),e("em",null,"i.e."),t(", block producers) to be honest to guarantee data availability.")],-1),I1=e("em",null,"i.e.",-1),B1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},q1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),E1=[q1],z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),G1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},J1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},F1=s("",1),O1=[F1],$1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),W1=e("em",null,"Fraud Proofs of Incorrectly Generated Extended Data",-1),K1=e("em",null,"i.e.",-1),U1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},X1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},Y1=s("",1),e4=[Y1],t4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),a4={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},o4={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},s4=s("",1),l4=[s4],i4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),n4=s("",18);function r4(T4,d4,Q4,h4,c4,m4){return a(),o("div",null,[d,e("p",null,[t("To make DAS possible, Celestia uses a 2-dimensional Reed-Solomon encoding scheme to encode the block data: every block data is split into "),e("mjx-container",Q,[(a(),o("svg",h,m)),p]),t(" shares, arranged in a "),e("mjx-container",g,[(a(),o("svg",x,_)),w]),t(" matrix, and extended with parity data into a "),e("mjx-container",f,[(a(),o("svg",b,y)),v]),t(" extended matrix by applying multiple times Reed-Solomon encoding.")]),e("p",null,[t("Then, "),e("mjx-container",L,[(a(),o("svg",M,V)),S]),t(" separate Merkle roots are computed for the rows and columns of the extended matrix; the Merkle root of these Merkle roots is used as the block data commitment in the block header.")]),C,e("p",null,[t("To verify that the data is available, Celestia light nodes are sampling the "),e("mjx-container",D,[(a(),o("svg",A,Z)),P]),t(" data shares.")]),N,e("p",null,[t("Additionally, every received data share with a correct Merkle proof is gossiped to the network. As a result, as long as the Celestia light nodes are sampling together enough data shares ("),I,t(", at least "),e("mjx-container",B,[(a(),o("svg",R,E)),z]),t(" unique shares), the full block can be recovered by honest full nodes.")]),G,J,F,e("p",null,[t("This means that increasing the number of light nodes performing DAS allows for larger blocks ("),O,t(", with more transactions), while still keeping DAS feasible for resource-limited light nodes. However, in order to validate block headers, Celestia light nodes need to download the "),e("mjx-container",$,[(a(),o("svg",W,U)),X]),t(" intermediate Merkle roots.")]),e("p",null,[t("For a block data size of "),e("mjx-container",Y,[(a(),o("svg",e1,a1)),o1]),t(" bytes, this means that every light node must download "),e("mjx-container",s1,[(a(),o("svg",l1,n1)),r1]),t(" bytes. Therefore, any improvement in the bandwidth capacity of Celestia light nodes has a quadratic effect on the throughput of Celestia's DA layer.")]),T1,e("p",null,[t("The requirement of downloading the "),e("mjx-container",d1,[(a(),o("svg",Q1,c1)),m1]),t(" intermediate Merkle roots is a consequence of using a 2-dimensional Reed-Solomon encoding scheme. Alternatively, DAS could be designed with a standard ("),p1,t(", 1-dimensional) Reed-Solomon encoding, where the original data is split into "),e("mjx-container",g1,[(a(),o("svg",x1,_1)),w1]),t(" shares and extended with "),e("mjx-container",f1,[(a(),o("svg",b1,y1)),v1]),t(" additional shares of parity data. Since the block data commitment is the Merkle root of the "),e("mjx-container",L1,[(a(),o("svg",M1,V1)),S1]),t(" resulting data shares, light nodes no longer need to download "),e("mjx-container",C1,[(a(),o("svg",D1,j1)),Z1]),t(" bytes to validate block headers.")]),P1,e("p",null,[t("This is possible as "),N1,t(" Thus, if the extended data is invalid, the original data might not be recoverable, even if the light nodes are sampling sufficient unique shares ("),I1,t(", at least "),e("mjx-container",B1,[(a(),o("svg",R1,E1)),z1]),t(" for a standard encoding and "),e("mjx-container",G1,[(a(),o("svg",J1,O1)),$1]),t(" for a 2-dimensional encoding).")]),e("p",null,[t("As a solution, "),W1,t(" enable light nodes to reject blocks with invalid extended data. Such proofs require reconstructing the encoding and verifying the mismatch. With standard Reed-Solomon encoding, this entails downloading the original data, "),K1,t(", "),e("mjx-container",U1,[(a(),o("svg",X1,e4)),t4]),t(" bytes. Contrastingly, with 2-dimensional Reed-Solomon encoding, only "),e("mjx-container",a4,[(a(),o("svg",o4,l4)),i4]),t(" bytes are required as it is sufficient to verify only one row or one column of the extended matrix.")]),n4])}const x4=l(T,[["render",r4]]);export{g4 as __pageData,x4 as default}; +import{_ as l,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const i="/docs-preview/pr-1815/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1815/img/learn/nmt.png",r="/docs-preview/pr-1815/img/learn/celestia-app.png",g4=JSON.parse(`{"title":"Celestia's data availability layer","description":"Celestia's Data Availability layer and its key features.","frontmatter":{"description":"Celestia's Data Availability layer and its key features.","head":[["meta",{"property":"og:title","content":"Celestia's data availability layer | Celestia Docs"}],["meta",{"property":"og:description","content":"Celestia's Data Availability layer and its key features."}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1732777479000}`),T={name:"learn/how-celestia-works/data-availability-layer.md"},d=s("",5),Q={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},h={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},c=s("",1),m=[c],p=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),g={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},u=s("",1),_=[u],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),f={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},k=s("",1),y=[k],v=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),L={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H=s("",1),V=[H],S=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),C=e("p",null,[e("img",{src:i,alt:"2D Reed-Soloman (RS) Encoding"})],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},A={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},j=s("",1),Z=[j],P=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),N=e("p",null,[t("Every light node randomly chooses a set of unique coordinates in the extended matrix and queries full nodes for the data shares and the corresponding Merkle proofs at those coordinates. If light nodes receive a valid response for each sampling query, then there is a "),e("a",{href:"https://github.com/celestiaorg/celestia-node/issues/805#issuecomment-1150081075",target:"_blank",rel:"noreferrer"},"high probability guarantee"),t(" that the whole block's data is available.")],-1),I=e("em",null,"i.e.",-1),B={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},q=s("",1),E=[q],z=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),G=e("p",null,[t("For more details on DAS, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(".")],-1),J=e("h3",{id:"scalability",tabindex:"-1"},[t("Scalability "),e("a",{class:"header-anchor",href:"#scalability","aria-label":'Permalink to "Scalability"'},"​")],-1),F=e("p",null,"DAS enables Celestia to scale the DA layer. DAS can be performed by resource-limited light nodes since each light node only samples a small portion of the block data. The more light nodes there are in the network, the more data they can collectively download and store.",-1),O=e("em",null,"i.e.",-1),$={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},W={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},K=s("",1),U=[K],X=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),Y={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},e1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},t1=s("",1),a1=[t1],o1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),s1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},l1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},i1=s("",1),n1=[i1],r1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),T1=e("h3",{id:"fraud-proofs-of-incorrectly-extended-data",tabindex:"-1"},[t("Fraud proofs of incorrectly extended data "),e("a",{class:"header-anchor",href:"#fraud-proofs-of-incorrectly-extended-data","aria-label":'Permalink to "Fraud proofs of incorrectly extended data"'},"​")],-1),d1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},Q1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},h1=s("",1),c1=[h1],m1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),p1=e("em",null,"i.e.",-1),g1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},x1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},u1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),_1=[u1],w1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),f1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},b1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},k1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),y1=[k1],v1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),L1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},M1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},H1=s("",1),V1=[H1],S1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k")])],-1),C1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},D1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},A1=s("",1),j1=[A1],Z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),P1=e("p",null,"The downside of the standard Reed-Solomon encoding is dealing with malicious block producers that generate the extended data incorrectly.",-1),N1=e("strong",null,[t("Celestia does not require a majority of the consensus ("),e("em",null,"i.e."),t(", block producers) to be honest to guarantee data availability.")],-1),I1=e("em",null,"i.e.",-1),B1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},R1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"1.179ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 521 705","aria-hidden":"true"},q1=e("g",{stroke:"currentColor",fill:"currentColor","stroke-width":"0",transform:"scale(1,-1)"},[e("g",{"data-mml-node":"math"},[e("g",{"data-mml-node":"mi"},[e("path",{"data-c":"1D458",d:"M121 647Q121 657 125 670T137 683Q138 683 209 688T282 694Q294 694 294 686Q294 679 244 477Q194 279 194 272Q213 282 223 291Q247 309 292 354T362 415Q402 442 438 442Q468 442 485 423T503 369Q503 344 496 327T477 302T456 291T438 288Q418 288 406 299T394 328Q394 353 410 369T442 390L458 393Q446 405 434 405H430Q398 402 367 380T294 316T228 255Q230 254 243 252T267 246T293 238T320 224T342 206T359 180T365 147Q365 130 360 106T354 66Q354 26 381 26Q429 26 459 145Q461 153 479 153H483Q499 153 499 144Q499 139 496 130Q455 -11 378 -11Q333 -11 305 15T277 90Q277 108 280 121T283 145Q283 167 269 183T234 206T200 217T182 220H180Q168 178 159 139T145 81T136 44T129 20T122 7T111 -2Q98 -11 83 -11Q66 -11 57 -1T48 16Q48 26 85 176T158 471L195 616Q196 629 188 632T149 637H144Q134 637 131 637T124 640T121 647Z",style:{"stroke-width":"3"}})])])],-1),E1=[q1],z1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k")])],-1),G1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},J1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},F1=s("",1),O1=[F1],$1=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),W1=e("em",null,"Fraud Proofs of Incorrectly Generated Extended Data",-1),K1=e("em",null,"i.e.",-1),U1={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},X1={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.345ex",height:"1.912ex",role:"img",focusable:"false",viewBox:"0 -833.9 1036.6 844.9","aria-hidden":"true"},Y1=s("",1),e4=[Y1],t4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("msup",null,[e("mi",null,"n"),e("mn",null,"2")])])],-1),a4={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},o4={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.566ex"},xmlns:"http://www.w3.org/2000/svg",width:"4.844ex",height:"2.262ex",role:"img",focusable:"false",viewBox:"0 -750 2141 1000","aria-hidden":"true"},s4=s("",1),l4=[s4],i4=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"O"),e("mo",{stretchy:"false"},"("),e("mi",null,"n"),e("mo",{stretchy:"false"},")")])],-1),n4=s("",18);function r4(T4,d4,Q4,h4,c4,m4){return a(),o("div",null,[d,e("p",null,[t("To make DAS possible, Celestia uses a 2-dimensional Reed-Solomon encoding scheme to encode the block data: every block data is split into "),e("mjx-container",Q,[(a(),o("svg",h,m)),p]),t(" shares, arranged in a "),e("mjx-container",g,[(a(),o("svg",x,_)),w]),t(" matrix, and extended with parity data into a "),e("mjx-container",f,[(a(),o("svg",b,y)),v]),t(" extended matrix by applying multiple times Reed-Solomon encoding.")]),e("p",null,[t("Then, "),e("mjx-container",L,[(a(),o("svg",M,V)),S]),t(" separate Merkle roots are computed for the rows and columns of the extended matrix; the Merkle root of these Merkle roots is used as the block data commitment in the block header.")]),C,e("p",null,[t("To verify that the data is available, Celestia light nodes are sampling the "),e("mjx-container",D,[(a(),o("svg",A,Z)),P]),t(" data shares.")]),N,e("p",null,[t("Additionally, every received data share with a correct Merkle proof is gossiped to the network. As a result, as long as the Celestia light nodes are sampling together enough data shares ("),I,t(", at least "),e("mjx-container",B,[(a(),o("svg",R,E)),z]),t(" unique shares), the full block can be recovered by honest full nodes.")]),G,J,F,e("p",null,[t("This means that increasing the number of light nodes performing DAS allows for larger blocks ("),O,t(", with more transactions), while still keeping DAS feasible for resource-limited light nodes. However, in order to validate block headers, Celestia light nodes need to download the "),e("mjx-container",$,[(a(),o("svg",W,U)),X]),t(" intermediate Merkle roots.")]),e("p",null,[t("For a block data size of "),e("mjx-container",Y,[(a(),o("svg",e1,a1)),o1]),t(" bytes, this means that every light node must download "),e("mjx-container",s1,[(a(),o("svg",l1,n1)),r1]),t(" bytes. Therefore, any improvement in the bandwidth capacity of Celestia light nodes has a quadratic effect on the throughput of Celestia's DA layer.")]),T1,e("p",null,[t("The requirement of downloading the "),e("mjx-container",d1,[(a(),o("svg",Q1,c1)),m1]),t(" intermediate Merkle roots is a consequence of using a 2-dimensional Reed-Solomon encoding scheme. Alternatively, DAS could be designed with a standard ("),p1,t(", 1-dimensional) Reed-Solomon encoding, where the original data is split into "),e("mjx-container",g1,[(a(),o("svg",x1,_1)),w1]),t(" shares and extended with "),e("mjx-container",f1,[(a(),o("svg",b1,y1)),v1]),t(" additional shares of parity data. Since the block data commitment is the Merkle root of the "),e("mjx-container",L1,[(a(),o("svg",M1,V1)),S1]),t(" resulting data shares, light nodes no longer need to download "),e("mjx-container",C1,[(a(),o("svg",D1,j1)),Z1]),t(" bytes to validate block headers.")]),P1,e("p",null,[t("This is possible as "),N1,t(" Thus, if the extended data is invalid, the original data might not be recoverable, even if the light nodes are sampling sufficient unique shares ("),I1,t(", at least "),e("mjx-container",B1,[(a(),o("svg",R1,E1)),z1]),t(" for a standard encoding and "),e("mjx-container",G1,[(a(),o("svg",J1,O1)),$1]),t(" for a 2-dimensional encoding).")]),e("p",null,[t("As a solution, "),W1,t(" enable light nodes to reject blocks with invalid extended data. Such proofs require reconstructing the encoding and verifying the mismatch. With standard Reed-Solomon encoding, this entails downloading the original data, "),K1,t(", "),e("mjx-container",U1,[(a(),o("svg",X1,e4)),t4]),t(" bytes. Contrastingly, with 2-dimensional Reed-Solomon encoding, only "),e("mjx-container",a4,[(a(),o("svg",o4,l4)),i4]),t(" bytes are required as it is sufficient to verify only one row or one column of the extended matrix.")]),n4])}const x4=l(T,[["render",r4]]);export{g4 as __pageData,x4 as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.js b/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.js similarity index 98% rename from pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.js rename to pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.js index ec4201747..882077da4 100644 --- a/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.js +++ b/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/learn/monolithic-modular.png",b=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"property":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"}],["meta",{"property":"og:description","content":"Comparison between monolithic and modular blockchains."}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1732776394000}'),i={name:"learn/how-celestia-works/monolithic-vs-modular.md"},s=a('

    Monolithic vs. modular blockchains

    Blockchains instantiate replicated state machines: the nodes in a permissionless distributed network apply an ordered sequence of deterministic transactions to an initial state resulting in a common final state.

    In other words, this means that nodes in a network all follow the same set of rules (i.e., an ordered sequence of transactions) to go from a starting point (i.e., an initial state) to an ending point (i.e., a common final state). This process ensures that all nodes in the network agree on the final state of the blockchain, even though they operate independently.

    This means blockchains require the following four functions:

    • Execution entails executing transactions that update the state correctly. Thus, execution must ensure that only valid transactions are executed, i.e., transactions that result in valid state machine transitions.
    • Settlement entails an environment for execution layers to verify proofs, resolve fraud disputes, and bridge between other execution layers.
    • Consensus entails agreeing on the order of the transactions.
    • Data Availability (DA) entails making the transaction data available. Note that execution, settlement, and consensus require DA.

    Traditional blockchains, i.e. monolithic blockchains, implement all four functions together in a single base consensus layer. The problem with monolithic blockchains is that the consensus layer must perform numerous different tasks, and it cannot be optimized for only one of these functions. As a result, the monolithic paradigm limits the throughput of the system.

    Modular VS Monolithic

    As a solution, modular blockchains decouple these functions among multiple specialized layers as part of a modular stack. Due to the flexibility that specialization provides, there are many possibilities in which that stack can be arranged. For example, one such arrangement is the separation of the four functions into three specialized layers.

    The base layer consists of DA and consensus and thus, is referred to as the Consensus and DA layer (or for brevity, the DA layer), while both settlement and execution are moved on top in their own layers. As a result, every layer can be specialized to optimally perform only its function, and thus, increase the throughput of the system. Furthermore, this modular paradigm enables multiple execution layers, i.e., rollups, to use the same settlement and DA layers.

    ',9),r=[s];function l(c,h,m,d,u,p){return t(),o("div",null,r)}const g=e(i,[["render",l]]);export{b as __pageData,g as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/learn/monolithic-modular.png",b=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"property":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"}],["meta",{"property":"og:description","content":"Comparison between monolithic and modular blockchains."}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1732777479000}'),i={name:"learn/how-celestia-works/monolithic-vs-modular.md"},s=a('

    Monolithic vs. modular blockchains

    Blockchains instantiate replicated state machines: the nodes in a permissionless distributed network apply an ordered sequence of deterministic transactions to an initial state resulting in a common final state.

    In other words, this means that nodes in a network all follow the same set of rules (i.e., an ordered sequence of transactions) to go from a starting point (i.e., an initial state) to an ending point (i.e., a common final state). This process ensures that all nodes in the network agree on the final state of the blockchain, even though they operate independently.

    This means blockchains require the following four functions:

    • Execution entails executing transactions that update the state correctly. Thus, execution must ensure that only valid transactions are executed, i.e., transactions that result in valid state machine transitions.
    • Settlement entails an environment for execution layers to verify proofs, resolve fraud disputes, and bridge between other execution layers.
    • Consensus entails agreeing on the order of the transactions.
    • Data Availability (DA) entails making the transaction data available. Note that execution, settlement, and consensus require DA.

    Traditional blockchains, i.e. monolithic blockchains, implement all four functions together in a single base consensus layer. The problem with monolithic blockchains is that the consensus layer must perform numerous different tasks, and it cannot be optimized for only one of these functions. As a result, the monolithic paradigm limits the throughput of the system.

    Modular VS Monolithic

    As a solution, modular blockchains decouple these functions among multiple specialized layers as part of a modular stack. Due to the flexibility that specialization provides, there are many possibilities in which that stack can be arranged. For example, one such arrangement is the separation of the four functions into three specialized layers.

    The base layer consists of DA and consensus and thus, is referred to as the Consensus and DA layer (or for brevity, the DA layer), while both settlement and execution are moved on top in their own layers. As a result, every layer can be specialized to optimally perform only its function, and thus, increase the throughput of the system. Furthermore, this modular paradigm enables multiple execution layers, i.e., rollups, to use the same settlement and DA layers.

    ',9),r=[s];function l(c,h,m,d,u,p){return t(),o("div",null,r)}const g=e(i,[["render",l]]);export{b as __pageData,g as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.lean.js b/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.lean.js similarity index 93% rename from pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.lean.js rename to pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.lean.js index e9d9c1ba9..d6ef88dcc 100644 --- a/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.06a2d712.lean.js +++ b/pr-1815/assets/learn_how-celestia-works_monolithic-vs-modular.md.ee4811c6.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/learn/monolithic-modular.png",b=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"property":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"}],["meta",{"property":"og:description","content":"Comparison between monolithic and modular blockchains."}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1732776394000}'),i={name:"learn/how-celestia-works/monolithic-vs-modular.md"},s=a("",9),r=[s];function l(c,h,m,d,u,p){return t(),o("div",null,r)}const g=e(i,[["render",l]]);export{b as __pageData,g as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.2959b752.js";const n="/docs-preview/pr-1815/img/learn/monolithic-modular.png",b=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"property":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"}],["meta",{"property":"og:description","content":"Comparison between monolithic and modular blockchains."}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1732777479000}'),i={name:"learn/how-celestia-works/monolithic-vs-modular.md"},s=a("",9),r=[s];function l(c,h,m,d,u,p){return t(),o("div",null,r)}const g=e(i,[["render",l]]);export{b as __pageData,g as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_overview.md.91ddd823.js b/pr-1815/assets/learn_how-celestia-works_overview.md.ed78821c.js similarity index 97% rename from pr-1815/assets/learn_how-celestia-works_overview.md.91ddd823.js rename to pr-1815/assets/learn_how-celestia-works_overview.md.ed78821c.js index 28ed2a8a8..907874971 100644 --- a/pr-1815/assets/learn_how-celestia-works_overview.md.91ddd823.js +++ b/pr-1815/assets/learn_how-celestia-works_overview.md.ed78821c.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Introduction | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1732776394000}'),i={name:"learn/how-celestia-works/overview.md"},o=r('

    Introduction

    Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.

    Celestia enables the next generation of scalable blockchain architectures - modular blockchains. Celestia scales by decoupling execution from consensus and introducing a new primitive, data availability sampling.

    The former entails that Celestia is only responsible for ordering transactions and guaranteeing their data availability; this is similar to reducing consensus to atomic broadcast.

    The latter provides an efficient solution to the data availability problem by only requiring resource-limited light nodes to sample a small number of random shares from each block to verify data availability.

    Interestingly, more light nodes that participate in sampling increases the amount of data that the network can safely handle, enabling the block size to increase without equally increasing the cost to verify the chain.

    ',6),n=[o];function s(l,c,h,d,p,u){return a(),t("div",null,n)}const b=e(i,[["render",s]]);export{f as __pageData,b as default}; +import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Introduction | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1732777479000}'),i={name:"learn/how-celestia-works/overview.md"},o=r('

    Introduction

    Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.

    Celestia enables the next generation of scalable blockchain architectures - modular blockchains. Celestia scales by decoupling execution from consensus and introducing a new primitive, data availability sampling.

    The former entails that Celestia is only responsible for ordering transactions and guaranteeing their data availability; this is similar to reducing consensus to atomic broadcast.

    The latter provides an efficient solution to the data availability problem by only requiring resource-limited light nodes to sample a small number of random shares from each block to verify data availability.

    Interestingly, more light nodes that participate in sampling increases the amount of data that the network can safely handle, enabling the block size to increase without equally increasing the cost to verify the chain.

    ',6),n=[o];function s(l,c,h,d,p,u){return a(),t("div",null,n)}const b=e(i,[["render",s]]);export{f as __pageData,b as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_overview.md.91ddd823.lean.js b/pr-1815/assets/learn_how-celestia-works_overview.md.ed78821c.lean.js similarity index 90% rename from pr-1815/assets/learn_how-celestia-works_overview.md.91ddd823.lean.js rename to pr-1815/assets/learn_how-celestia-works_overview.md.ed78821c.lean.js index 636e4d80e..7605e9b86 100644 --- a/pr-1815/assets/learn_how-celestia-works_overview.md.91ddd823.lean.js +++ b/pr-1815/assets/learn_how-celestia-works_overview.md.ed78821c.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Introduction | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1732776394000}'),i={name:"learn/how-celestia-works/overview.md"},o=r("",6),n=[o];function s(l,c,h,d,p,u){return a(),t("div",null,n)}const b=e(i,[["render",s]]);export{f as __pageData,b as default}; +import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Introduction | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1732777479000}'),i={name:"learn/how-celestia-works/overview.md"},o=r("",6),n=[o];function s(l,c,h,d,p,u){return a(),t("div",null,n)}const b=e(i,[["render",s]]);export{f as __pageData,b as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.c8f48715.js b/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.dbc95259.js similarity index 99% rename from pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.c8f48715.js rename to pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.dbc95259.js index a4eed4bbf..e4a61ebb4 100644 --- a/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.c8f48715.js +++ b/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.dbc95259.js @@ -1 +1 @@ -import{_ as i}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/learn/consensus-da.png",K=JSON.parse('{"title":"The lifecycle of a celestia-app transaction","description":"Learn what is the lifecycle of a celestia-app transaction.","frontmatter":{"description":"Learn what is the lifecycle of a celestia-app transaction.","head":[["meta",{"property":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn what is the lifecycle of a celestia-app transaction."}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1732776394000}'),r={name:"learn/how-celestia-works/transaction-lifecycle.md"},c=s('

    The lifecycle of a celestia-app transaction

    Users request the celestia-app to make data available by sending PayForBlobs transactions. Every such transaction consists of the identity of the sender, the data to be made available, also referred to as the message, the data size, the namespace, and a signature. Every block producer batches multiple PayForBlobs transactions into a block.

    Before proposing the block though, the producer passes it to the state machine via ABCI++, where each PayForBlobs transaction is split into a namespaced message (denoted by Msg in the figure below), i.e., the data together with the namespace ID, and an executable transaction (denoted by e-Tx in the figure below) that does not contain the data, but only a commitment that can be used at a later time to prove that the data was indeed made available.

    Thus, the block data consists of data partitioned into namespaces and executable transactions. Note that only these transactions are executed by the Celestia state machine once the block is committed.

    Lifecycle of a celestia-app Transaction

    ',5),h=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),d={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},T={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},Q=s('',1),p=[Q],m=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),u=e("li",null,"It splits the executable transactions and the namespaced data into shares. Every share consists of some bytes prefixed by a namespace. To this end, the executable transactions are associated with a reserved namespace.",-1),_={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},g={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},f=s('',1),x=[f],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},k={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},y=s('',1),v=[y],L=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),H=e("li",null,"It computes a commitment for every row and column of the extended matrix using the NMTs described above.",-1),V=e("p",null,"Thus, the commitment of the block data is the root of a Merkle tree with the leaves the roots of a forest of Namespaced Merkle subtrees, one for every row and column of the extended matrix.",-1),M=e("h2",{id:"checking-data-availability",tabindex:"-1"},[t("Checking data availability "),e("a",{class:"header-anchor",href:"#checking-data-availability","aria-label":'Permalink to "Checking data availability"'},"​")],-1),A=e("p",null,[e("img",{src:l,alt:"DA network"})],-1),C=e("p",null,[t("To enhance connectivity, the celestia-node augments the celestia-app with a separate libp2p network, "),e("em",null,"i.e."),t(", the so-called "),e("em",null,"DA network"),t(", that serves DAS requests.")],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},S={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},I=s('',1),P=[I],N=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),j=e("p",null,[t("Note that although it is recommended, performing DAS is optional -- light nodes could just trust that the data corresponding to the commitments in the block headers was indeed made available by the Celestia DA layer. In addition, light nodes can also submit transactions to the celestia-app, i.e., "),e("code",null,"PayForBlobs"),t(" transactions.")],-1),B=e("p",null,"While performing DAS for a block header, every light node queries Celestia Nodes for a number of random data shares from the extended matrix and the corresponding Merkle proofs. If all the queries are successful, then the light node accepts the block header as valid (from a DA perspective).",-1),Z=e("p",null,"If at least one of the queries fails (i.e., either the data share is not received or the Merkle proof is invalid), then the light node rejects the block header and tries again later. The retrial is necessary to deal with false negatives, i.e., block headers being rejected although the block data is available. This may happen due to network congestion for example.",-1),q=e("p",null,[t("Alternatively, light nodes may accept a block header although the data is not available, i.e., a "),e("em",null,"false positive"),t(". This is possible since the soundness property (i.e., if an honest light node accepts a block as available, then at least one honest full node will eventually have the entire block data) is probabilistically guaranteed (for more details, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(").")],-1),E=e("p",null,"By fine tuning Celestia's parameters (e.g., the number of data shares sampled by each light node) the likelihood of false positives can be sufficiently reduced such that block producers have no incentive to withhold the block data.",-1);function z(R,J,F,G,$,U){return a(),o("div",null,[c,e("p",null,[t("Next, the block producer adds to the block header a commitment of the block data. As "),h,t(", the commitment is the Merkle root of the "),e("mjx-container",d,[(a(),o("svg",T,p)),m]),t(" intermediate Merkle roots (i.e., one for each row and column of the extended matrix). To compute this commitment, the block producer performs the following operations:")]),e("ul",null,[u,e("li",null,[t("It arranges these shares into a square matrix (row-wise). Note that the shares are padded to the next power of two. The outcome square of size "),e("mjx-container",_,[(a(),o("svg",g,x)),w]),t(" is referred to as the original data.")]),e("li",null,[t("It extends the original data to a "),e("mjx-container",b,[(a(),o("svg",k,v)),L]),t(" square matrix using the 2-dimensional Reed-Solomon encoding scheme described above. The extended shares (i.e., containing erasure data) are associated with another reserved namespace.")]),H]),V,M,A,C,e("p",null,[t("Light nodes connect to a celestia-node in the DA network, listen to extended block headers (i.e., the block headers together with the relevant DA metadata, such as the "),e("mjx-container",D,[(a(),o("svg",S,P)),N]),t(" intermediate Merkle roots), and perform DAS on the received headers (i.e., ask for random data shares).")]),j,B,Z,q,E])}const X=n(r,[["render",z]]);export{K as __pageData,X as default}; +import{_ as i}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/learn/consensus-da.png",K=JSON.parse('{"title":"The lifecycle of a celestia-app transaction","description":"Learn what is the lifecycle of a celestia-app transaction.","frontmatter":{"description":"Learn what is the lifecycle of a celestia-app transaction.","head":[["meta",{"property":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn what is the lifecycle of a celestia-app transaction."}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1732777479000}'),r={name:"learn/how-celestia-works/transaction-lifecycle.md"},c=s('

    The lifecycle of a celestia-app transaction

    Users request the celestia-app to make data available by sending PayForBlobs transactions. Every such transaction consists of the identity of the sender, the data to be made available, also referred to as the message, the data size, the namespace, and a signature. Every block producer batches multiple PayForBlobs transactions into a block.

    Before proposing the block though, the producer passes it to the state machine via ABCI++, where each PayForBlobs transaction is split into a namespaced message (denoted by Msg in the figure below), i.e., the data together with the namespace ID, and an executable transaction (denoted by e-Tx in the figure below) that does not contain the data, but only a commitment that can be used at a later time to prove that the data was indeed made available.

    Thus, the block data consists of data partitioned into namespaces and executable transactions. Note that only these transactions are executed by the Celestia state machine once the block is committed.

    Lifecycle of a celestia-app Transaction

    ',5),h=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),d={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},T={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},Q=s('',1),p=[Q],m=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),u=e("li",null,"It splits the executable transactions and the namespaced data into shares. Every share consists of some bytes prefixed by a namespace. To this end, the executable transactions are associated with a reserved namespace.",-1),_={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},g={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},f=s('',1),x=[f],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},k={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},y=s('',1),v=[y],L=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),H=e("li",null,"It computes a commitment for every row and column of the extended matrix using the NMTs described above.",-1),V=e("p",null,"Thus, the commitment of the block data is the root of a Merkle tree with the leaves the roots of a forest of Namespaced Merkle subtrees, one for every row and column of the extended matrix.",-1),M=e("h2",{id:"checking-data-availability",tabindex:"-1"},[t("Checking data availability "),e("a",{class:"header-anchor",href:"#checking-data-availability","aria-label":'Permalink to "Checking data availability"'},"​")],-1),A=e("p",null,[e("img",{src:l,alt:"DA network"})],-1),C=e("p",null,[t("To enhance connectivity, the celestia-node augments the celestia-app with a separate libp2p network, "),e("em",null,"i.e."),t(", the so-called "),e("em",null,"DA network"),t(", that serves DAS requests.")],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},S={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},I=s('',1),P=[I],N=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),j=e("p",null,[t("Note that although it is recommended, performing DAS is optional -- light nodes could just trust that the data corresponding to the commitments in the block headers was indeed made available by the Celestia DA layer. In addition, light nodes can also submit transactions to the celestia-app, i.e., "),e("code",null,"PayForBlobs"),t(" transactions.")],-1),B=e("p",null,"While performing DAS for a block header, every light node queries Celestia Nodes for a number of random data shares from the extended matrix and the corresponding Merkle proofs. If all the queries are successful, then the light node accepts the block header as valid (from a DA perspective).",-1),Z=e("p",null,"If at least one of the queries fails (i.e., either the data share is not received or the Merkle proof is invalid), then the light node rejects the block header and tries again later. The retrial is necessary to deal with false negatives, i.e., block headers being rejected although the block data is available. This may happen due to network congestion for example.",-1),q=e("p",null,[t("Alternatively, light nodes may accept a block header although the data is not available, i.e., a "),e("em",null,"false positive"),t(". This is possible since the soundness property (i.e., if an honest light node accepts a block as available, then at least one honest full node will eventually have the entire block data) is probabilistically guaranteed (for more details, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(").")],-1),E=e("p",null,"By fine tuning Celestia's parameters (e.g., the number of data shares sampled by each light node) the likelihood of false positives can be sufficiently reduced such that block producers have no incentive to withhold the block data.",-1);function z(R,J,F,G,$,U){return a(),o("div",null,[c,e("p",null,[t("Next, the block producer adds to the block header a commitment of the block data. As "),h,t(", the commitment is the Merkle root of the "),e("mjx-container",d,[(a(),o("svg",T,p)),m]),t(" intermediate Merkle roots (i.e., one for each row and column of the extended matrix). To compute this commitment, the block producer performs the following operations:")]),e("ul",null,[u,e("li",null,[t("It arranges these shares into a square matrix (row-wise). Note that the shares are padded to the next power of two. The outcome square of size "),e("mjx-container",_,[(a(),o("svg",g,x)),w]),t(" is referred to as the original data.")]),e("li",null,[t("It extends the original data to a "),e("mjx-container",b,[(a(),o("svg",k,v)),L]),t(" square matrix using the 2-dimensional Reed-Solomon encoding scheme described above. The extended shares (i.e., containing erasure data) are associated with another reserved namespace.")]),H]),V,M,A,C,e("p",null,[t("Light nodes connect to a celestia-node in the DA network, listen to extended block headers (i.e., the block headers together with the relevant DA metadata, such as the "),e("mjx-container",D,[(a(),o("svg",S,P)),N]),t(" intermediate Merkle roots), and perform DAS on the received headers (i.e., ask for random data shares).")]),j,B,Z,q,E])}const X=n(r,[["render",z]]);export{K as __pageData,X as default}; diff --git a/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.c8f48715.lean.js b/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.dbc95259.lean.js similarity index 99% rename from pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.c8f48715.lean.js rename to pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.dbc95259.lean.js index bfacc3bf6..02a8521d4 100644 --- a/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.c8f48715.lean.js +++ b/pr-1815/assets/learn_how-celestia-works_transaction-lifecycle.md.dbc95259.lean.js @@ -1 +1 @@ -import{_ as i}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/learn/consensus-da.png",K=JSON.parse('{"title":"The lifecycle of a celestia-app transaction","description":"Learn what is the lifecycle of a celestia-app transaction.","frontmatter":{"description":"Learn what is the lifecycle of a celestia-app transaction.","head":[["meta",{"property":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn what is the lifecycle of a celestia-app transaction."}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1732776394000}'),r={name:"learn/how-celestia-works/transaction-lifecycle.md"},c=s("",5),h=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),d={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},T={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},Q=s("",1),p=[Q],m=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),u=e("li",null,"It splits the executable transactions and the namespaced data into shares. Every share consists of some bytes prefixed by a namespace. To this end, the executable transactions are associated with a reserved namespace.",-1),_={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},g={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},f=s("",1),x=[f],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},k={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},y=s("",1),v=[y],L=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),H=e("li",null,"It computes a commitment for every row and column of the extended matrix using the NMTs described above.",-1),V=e("p",null,"Thus, the commitment of the block data is the root of a Merkle tree with the leaves the roots of a forest of Namespaced Merkle subtrees, one for every row and column of the extended matrix.",-1),M=e("h2",{id:"checking-data-availability",tabindex:"-1"},[t("Checking data availability "),e("a",{class:"header-anchor",href:"#checking-data-availability","aria-label":'Permalink to "Checking data availability"'},"​")],-1),A=e("p",null,[e("img",{src:l,alt:"DA network"})],-1),C=e("p",null,[t("To enhance connectivity, the celestia-node augments the celestia-app with a separate libp2p network, "),e("em",null,"i.e."),t(", the so-called "),e("em",null,"DA network"),t(", that serves DAS requests.")],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},S={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},I=s("",1),P=[I],N=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),j=e("p",null,[t("Note that although it is recommended, performing DAS is optional -- light nodes could just trust that the data corresponding to the commitments in the block headers was indeed made available by the Celestia DA layer. In addition, light nodes can also submit transactions to the celestia-app, i.e., "),e("code",null,"PayForBlobs"),t(" transactions.")],-1),B=e("p",null,"While performing DAS for a block header, every light node queries Celestia Nodes for a number of random data shares from the extended matrix and the corresponding Merkle proofs. If all the queries are successful, then the light node accepts the block header as valid (from a DA perspective).",-1),Z=e("p",null,"If at least one of the queries fails (i.e., either the data share is not received or the Merkle proof is invalid), then the light node rejects the block header and tries again later. The retrial is necessary to deal with false negatives, i.e., block headers being rejected although the block data is available. This may happen due to network congestion for example.",-1),q=e("p",null,[t("Alternatively, light nodes may accept a block header although the data is not available, i.e., a "),e("em",null,"false positive"),t(". This is possible since the soundness property (i.e., if an honest light node accepts a block as available, then at least one honest full node will eventually have the entire block data) is probabilistically guaranteed (for more details, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(").")],-1),E=e("p",null,"By fine tuning Celestia's parameters (e.g., the number of data shares sampled by each light node) the likelihood of false positives can be sufficiently reduced such that block producers have no incentive to withhold the block data.",-1);function z(R,J,F,G,$,U){return a(),o("div",null,[c,e("p",null,[t("Next, the block producer adds to the block header a commitment of the block data. As "),h,t(", the commitment is the Merkle root of the "),e("mjx-container",d,[(a(),o("svg",T,p)),m]),t(" intermediate Merkle roots (i.e., one for each row and column of the extended matrix). To compute this commitment, the block producer performs the following operations:")]),e("ul",null,[u,e("li",null,[t("It arranges these shares into a square matrix (row-wise). Note that the shares are padded to the next power of two. The outcome square of size "),e("mjx-container",_,[(a(),o("svg",g,x)),w]),t(" is referred to as the original data.")]),e("li",null,[t("It extends the original data to a "),e("mjx-container",b,[(a(),o("svg",k,v)),L]),t(" square matrix using the 2-dimensional Reed-Solomon encoding scheme described above. The extended shares (i.e., containing erasure data) are associated with another reserved namespace.")]),H]),V,M,A,C,e("p",null,[t("Light nodes connect to a celestia-node in the DA network, listen to extended block headers (i.e., the block headers together with the relevant DA metadata, such as the "),e("mjx-container",D,[(a(),o("svg",S,P)),N]),t(" intermediate Merkle roots), and perform DAS on the received headers (i.e., ask for random data shares).")]),j,B,Z,q,E])}const X=n(r,[["render",z]]);export{K as __pageData,X as default}; +import{_ as i}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.2959b752.js";const l="/docs-preview/pr-1815/img/learn/consensus-da.png",K=JSON.parse('{"title":"The lifecycle of a celestia-app transaction","description":"Learn what is the lifecycle of a celestia-app transaction.","frontmatter":{"description":"Learn what is the lifecycle of a celestia-app transaction.","head":[["meta",{"property":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn what is the lifecycle of a celestia-app transaction."}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1732777479000}'),r={name:"learn/how-celestia-works/transaction-lifecycle.md"},c=s("",5),h=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),d={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},T={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},Q=s("",1),p=[Q],m=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),u=e("li",null,"It splits the executable transactions and the namespaced data into shares. Every share consists of some bytes prefixed by a namespace. To this end, the executable transactions are associated with a reserved namespace.",-1),_={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},g={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"5.123ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 2264.4 705","aria-hidden":"true"},f=s("",1),x=[f],w=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mi",null,"k"),e("mo",null,"×"),e("mi",null,"k")])],-1),b={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},k={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"7.386ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 3264.4 705","aria-hidden":"true"},y=s("",1),v=[y],L=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"2"),e("mi",null,"k"),e("mo",null,"×"),e("mn",null,"2"),e("mi",null,"k")])],-1),H=e("li",null,"It computes a commitment for every row and column of the extended matrix using the NMTs described above.",-1),V=e("p",null,"Thus, the commitment of the block data is the root of a Merkle tree with the leaves the roots of a forest of Namespaced Merkle subtrees, one for every row and column of the extended matrix.",-1),M=e("h2",{id:"checking-data-availability",tabindex:"-1"},[t("Checking data availability "),e("a",{class:"header-anchor",href:"#checking-data-availability","aria-label":'Permalink to "Checking data availability"'},"​")],-1),A=e("p",null,[e("img",{src:l,alt:"DA network"})],-1),C=e("p",null,[t("To enhance connectivity, the celestia-node augments the celestia-app with a separate libp2p network, "),e("em",null,"i.e."),t(", the so-called "),e("em",null,"DA network"),t(", that serves DAS requests.")],-1),D={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},S={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.025ex"},xmlns:"http://www.w3.org/2000/svg",width:"2.31ex",height:"1.595ex",role:"img",focusable:"false",viewBox:"0 -694 1021 705","aria-hidden":"true"},I=s("",1),P=[I],N=e("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[e("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[e("mn",null,"4"),e("mi",null,"k")])],-1),j=e("p",null,[t("Note that although it is recommended, performing DAS is optional -- light nodes could just trust that the data corresponding to the commitments in the block headers was indeed made available by the Celestia DA layer. In addition, light nodes can also submit transactions to the celestia-app, i.e., "),e("code",null,"PayForBlobs"),t(" transactions.")],-1),B=e("p",null,"While performing DAS for a block header, every light node queries Celestia Nodes for a number of random data shares from the extended matrix and the corresponding Merkle proofs. If all the queries are successful, then the light node accepts the block header as valid (from a DA perspective).",-1),Z=e("p",null,"If at least one of the queries fails (i.e., either the data share is not received or the Merkle proof is invalid), then the light node rejects the block header and tries again later. The retrial is necessary to deal with false negatives, i.e., block headers being rejected although the block data is available. This may happen due to network congestion for example.",-1),q=e("p",null,[t("Alternatively, light nodes may accept a block header although the data is not available, i.e., a "),e("em",null,"false positive"),t(". This is possible since the soundness property (i.e., if an honest light node accepts a block as available, then at least one honest full node will eventually have the entire block data) is probabilistically guaranteed (for more details, take a look at the "),e("a",{href:"https://arxiv.org/abs/1809.09044",target:"_blank",rel:"noreferrer"},"original paper"),t(").")],-1),E=e("p",null,"By fine tuning Celestia's parameters (e.g., the number of data shares sampled by each light node) the likelihood of false positives can be sufficiently reduced such that block producers have no incentive to withhold the block data.",-1);function z(R,J,F,G,$,U){return a(),o("div",null,[c,e("p",null,[t("Next, the block producer adds to the block header a commitment of the block data. As "),h,t(", the commitment is the Merkle root of the "),e("mjx-container",d,[(a(),o("svg",T,p)),m]),t(" intermediate Merkle roots (i.e., one for each row and column of the extended matrix). To compute this commitment, the block producer performs the following operations:")]),e("ul",null,[u,e("li",null,[t("It arranges these shares into a square matrix (row-wise). Note that the shares are padded to the next power of two. The outcome square of size "),e("mjx-container",_,[(a(),o("svg",g,x)),w]),t(" is referred to as the original data.")]),e("li",null,[t("It extends the original data to a "),e("mjx-container",b,[(a(),o("svg",k,v)),L]),t(" square matrix using the 2-dimensional Reed-Solomon encoding scheme described above. The extended shares (i.e., containing erasure data) are associated with another reserved namespace.")]),H]),V,M,A,C,e("p",null,[t("Light nodes connect to a celestia-node in the DA network, listen to extended block headers (i.e., the block headers together with the relevant DA metadata, such as the "),e("mjx-container",D,[(a(),o("svg",S,P)),N]),t(" intermediate Merkle roots), and perform DAS on the received headers (i.e., ask for random data shares).")]),j,B,Z,q,E])}const X=n(r,[["render",z]]);export{K as __pageData,X as default}; diff --git a/pr-1815/assets/learn_how-to-stake-tia.md.0f1811ff.js b/pr-1815/assets/learn_how-to-stake-tia.md.961588e1.js similarity index 98% rename from pr-1815/assets/learn_how-to-stake-tia.md.0f1811ff.js rename to pr-1815/assets/learn_how-to-stake-tia.md.961588e1.js index f321778cd..3510974e2 100644 --- a/pr-1815/assets/learn_how-to-stake-tia.md.0f1811ff.js +++ b/pr-1815/assets/learn_how-to-stake-tia.md.961588e1.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/keplr.png",i="/docs-preview/pr-1815/img/leap.png",l="/docs-preview/pr-1815/img/gem.png",s="/docs-preview/pr-1815/img/keplr/keplr1.gif",n="/docs-preview/pr-1815/img/keplr/keplr2.gif",p="/docs-preview/pr-1815/img/keplr/keplr3.gif",c="/docs-preview/pr-1815/img/keplr/keplr4.gif",d="/docs-preview/pr-1815/img/leap/leap1.gif",h="/docs-preview/pr-1815/img/leap/leap2.gif",m="/docs-preview/pr-1815/img/leap/leap3.gif",w="/docs-preview/pr-1815/img/gem/gem1.gif",k="/docs-preview/pr-1815/img/gem/gem2.gif",u="/docs-preview/pr-1815/img/gem/gem3.gif",g="/docs-preview/pr-1815/img/gem/gem4.gif",C=JSON.parse('{"title":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","frontmatter":{"sidebar_label":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","head":[["meta",{"property":"og:title","content":"How to stake TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet"}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1732776394000}'),f={name:"learn/how-to-stake-tia.md"},_=o('

    How to stake TIA

    Celestia is a proof-of-stake blockchain based on the Cosmos SDK.

    Staking TIA as a delegator allows you to secure the Celestia network. This means that you can stake the native token TIA and vote on governance proposals.

    In this tutorial, you will learn how to stake TIA tokens via Keplr, Leap, and Gem wallets.

    Select your preferred wallet

    Keplr
    Leap
    Gem Wallet

    Stake TIA with Keplr wallet

    1️⃣ Open your Keplr browser extension

    Navigate to Staked and select Stake with Keplr Dashboard.

    This will open the Keplr dashboard in a new browser page.

    Keplr1

    2️⃣ Select Celestia network and search for a validator

    In the Keplr dashboard, select the Celestia network and pick a validator of your choice.

    Keplr1

    3️⃣ Stake your TIA tokens

    On the following screen enter amount of TIA tokens and select Stake.

    A Keplr popup will appear, requesting your approval for the transaction. Select Approve.

    Keplr1

    4️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Leap wallet

    1️⃣ Open your Leap browser extension

    In top right select Celestia network and navigate to Stake.

    Similarly to previous step, select the +Stake button.

    Keplr1

    2️⃣ Select a validator and stake TIA

    On the following screen choose a validator of your choice, enter the desired amount, and click Review.

    Following that, review the transaction details and select Stake, then wait for the transaction to finalize.

    Keplr1

    3️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Gem wallet

    1️⃣ Open your Gem Wallet app

    Navigate to Celestia and select Stake.

    Gem1

    2️⃣ Choose the amount of Celestia and search for a validator.

    Select the amount of Celestia tokens and choose a validator from the list.

    Gem2

    3️⃣ Stake your TIA tokens

    Review the network terms and commission, then press Confirm to proceed.

    Gem3

    4️⃣ Manage your TIA

    After your transaction is confirmed, you will have access to a control panel where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Gem4

    ',48),v=[_];function y(b,T,A,I,S,q){return a(),t("div",null,v)}const K=e(f,[["render",y]]);export{C as __pageData,K as default}; +import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/keplr.png",i="/docs-preview/pr-1815/img/leap.png",l="/docs-preview/pr-1815/img/gem.png",s="/docs-preview/pr-1815/img/keplr/keplr1.gif",n="/docs-preview/pr-1815/img/keplr/keplr2.gif",p="/docs-preview/pr-1815/img/keplr/keplr3.gif",c="/docs-preview/pr-1815/img/keplr/keplr4.gif",d="/docs-preview/pr-1815/img/leap/leap1.gif",h="/docs-preview/pr-1815/img/leap/leap2.gif",m="/docs-preview/pr-1815/img/leap/leap3.gif",w="/docs-preview/pr-1815/img/gem/gem1.gif",k="/docs-preview/pr-1815/img/gem/gem2.gif",u="/docs-preview/pr-1815/img/gem/gem3.gif",g="/docs-preview/pr-1815/img/gem/gem4.gif",C=JSON.parse('{"title":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","frontmatter":{"sidebar_label":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","head":[["meta",{"property":"og:title","content":"How to stake TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet"}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1732777479000}'),f={name:"learn/how-to-stake-tia.md"},_=o('

    How to stake TIA

    Celestia is a proof-of-stake blockchain based on the Cosmos SDK.

    Staking TIA as a delegator allows you to secure the Celestia network. This means that you can stake the native token TIA and vote on governance proposals.

    In this tutorial, you will learn how to stake TIA tokens via Keplr, Leap, and Gem wallets.

    Select your preferred wallet

    Keplr
    Leap
    Gem Wallet

    Stake TIA with Keplr wallet

    1️⃣ Open your Keplr browser extension

    Navigate to Staked and select Stake with Keplr Dashboard.

    This will open the Keplr dashboard in a new browser page.

    Keplr1

    2️⃣ Select Celestia network and search for a validator

    In the Keplr dashboard, select the Celestia network and pick a validator of your choice.

    Keplr1

    3️⃣ Stake your TIA tokens

    On the following screen enter amount of TIA tokens and select Stake.

    A Keplr popup will appear, requesting your approval for the transaction. Select Approve.

    Keplr1

    4️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Leap wallet

    1️⃣ Open your Leap browser extension

    In top right select Celestia network and navigate to Stake.

    Similarly to previous step, select the +Stake button.

    Keplr1

    2️⃣ Select a validator and stake TIA

    On the following screen choose a validator of your choice, enter the desired amount, and click Review.

    Following that, review the transaction details and select Stake, then wait for the transaction to finalize.

    Keplr1

    3️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Gem wallet

    1️⃣ Open your Gem Wallet app

    Navigate to Celestia and select Stake.

    Gem1

    2️⃣ Choose the amount of Celestia and search for a validator.

    Select the amount of Celestia tokens and choose a validator from the list.

    Gem2

    3️⃣ Stake your TIA tokens

    Review the network terms and commission, then press Confirm to proceed.

    Gem3

    4️⃣ Manage your TIA

    After your transaction is confirmed, you will have access to a control panel where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Gem4

    ',48),v=[_];function y(b,T,A,I,S,q){return a(),t("div",null,v)}const K=e(f,[["render",y]]);export{C as __pageData,K as default}; diff --git a/pr-1815/assets/learn_how-to-stake-tia.md.0f1811ff.lean.js b/pr-1815/assets/learn_how-to-stake-tia.md.961588e1.lean.js similarity index 91% rename from pr-1815/assets/learn_how-to-stake-tia.md.0f1811ff.lean.js rename to pr-1815/assets/learn_how-to-stake-tia.md.961588e1.lean.js index 81231dfc6..2b83604e3 100644 --- a/pr-1815/assets/learn_how-to-stake-tia.md.0f1811ff.lean.js +++ b/pr-1815/assets/learn_how-to-stake-tia.md.961588e1.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/keplr.png",i="/docs-preview/pr-1815/img/leap.png",l="/docs-preview/pr-1815/img/gem.png",s="/docs-preview/pr-1815/img/keplr/keplr1.gif",n="/docs-preview/pr-1815/img/keplr/keplr2.gif",p="/docs-preview/pr-1815/img/keplr/keplr3.gif",c="/docs-preview/pr-1815/img/keplr/keplr4.gif",d="/docs-preview/pr-1815/img/leap/leap1.gif",h="/docs-preview/pr-1815/img/leap/leap2.gif",m="/docs-preview/pr-1815/img/leap/leap3.gif",w="/docs-preview/pr-1815/img/gem/gem1.gif",k="/docs-preview/pr-1815/img/gem/gem2.gif",u="/docs-preview/pr-1815/img/gem/gem3.gif",g="/docs-preview/pr-1815/img/gem/gem4.gif",C=JSON.parse('{"title":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","frontmatter":{"sidebar_label":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","head":[["meta",{"property":"og:title","content":"How to stake TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet"}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1732776394000}'),f={name:"learn/how-to-stake-tia.md"},_=o("",48),v=[_];function y(b,T,A,I,S,q){return a(),t("div",null,v)}const K=e(f,[["render",y]]);export{C as __pageData,K as default}; +import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/keplr.png",i="/docs-preview/pr-1815/img/leap.png",l="/docs-preview/pr-1815/img/gem.png",s="/docs-preview/pr-1815/img/keplr/keplr1.gif",n="/docs-preview/pr-1815/img/keplr/keplr2.gif",p="/docs-preview/pr-1815/img/keplr/keplr3.gif",c="/docs-preview/pr-1815/img/keplr/keplr4.gif",d="/docs-preview/pr-1815/img/leap/leap1.gif",h="/docs-preview/pr-1815/img/leap/leap2.gif",m="/docs-preview/pr-1815/img/leap/leap3.gif",w="/docs-preview/pr-1815/img/gem/gem1.gif",k="/docs-preview/pr-1815/img/gem/gem2.gif",u="/docs-preview/pr-1815/img/gem/gem3.gif",g="/docs-preview/pr-1815/img/gem/gem4.gif",C=JSON.parse('{"title":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","frontmatter":{"sidebar_label":"How to stake TIA","description":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet","head":[["meta",{"property":"og:title","content":"How to stake TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"This tutorial covers how to stake TIA with Keplr, Leap, or Gem wallet"}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1732777479000}'),f={name:"learn/how-to-stake-tia.md"},_=o("",48),v=[_];function y(b,T,A,I,S,q){return a(),t("div",null,v)}const K=e(f,[["render",y]]);export{C as __pageData,K as default}; diff --git a/pr-1815/assets/learn_paying-for-blobspace.md.c34353bd.js b/pr-1815/assets/learn_paying-for-blobspace.md.119c2d85.js similarity index 97% rename from pr-1815/assets/learn_paying-for-blobspace.md.c34353bd.js rename to pr-1815/assets/learn_paying-for-blobspace.md.119c2d85.js index f36fafbf7..894be1387 100644 --- a/pr-1815/assets/learn_paying-for-blobspace.md.c34353bd.js +++ b/pr-1815/assets/learn_paying-for-blobspace.md.119c2d85.js @@ -1 +1 @@ -import{_ as a}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as e,o as t,c as o,Q as i}from"./chunks/framework.2959b752.js";const _=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Paying for blobspace | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1732776394000}'),s={name:"learn/paying-for-blobspace.md"},r=i('

    Paying for blobspace

    PayForBlobs transactions

    To publish data on Celestia, developers can submit PayForBlobs transactions. A PayForBlobs transaction consists of the identity of the sender, the data to be made available, the data size, the namespace, and a signature.

    Each PayForBlobs transaction is split into two parts: the blob or blobs which include the data to be made available along with the namespace, and the executable payment transaction which includes a commitment to the data.

    Both the blobs and executable payment transactions are put into the block within the appropriate namespace. The block data is extended using erasure coding and then Merkelized into a data root commitment included in the block header.

    Lifecycle of a celestia-app Transaction

    See the detailed life cycle of a Celestia transaction.

    Learn how to submit data to Celestia’s data availability layer.

    Fee market overview

    Celestia uses a standard gas-price prioritised mempool. This means that transactions with higher fees will be prioritised by validators. Fees are comprised of a flat fee per transaction and then a variable fee based on the size of each blob in the transaction.

    Understand how fees are calculated on Celestia in the overview on submitting PFB transactions.

    ',11),n=[r];function c(l,d,p,h,b,m){return t(),o("div",null,n)}const y=e(s,[["render",c]]);export{_ as __pageData,y as default}; +import{_ as a}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as e,o as t,c as o,Q as i}from"./chunks/framework.2959b752.js";const _=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Paying for blobspace | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1732777479000}'),s={name:"learn/paying-for-blobspace.md"},r=i('

    Paying for blobspace

    PayForBlobs transactions

    To publish data on Celestia, developers can submit PayForBlobs transactions. A PayForBlobs transaction consists of the identity of the sender, the data to be made available, the data size, the namespace, and a signature.

    Each PayForBlobs transaction is split into two parts: the blob or blobs which include the data to be made available along with the namespace, and the executable payment transaction which includes a commitment to the data.

    Both the blobs and executable payment transactions are put into the block within the appropriate namespace. The block data is extended using erasure coding and then Merkelized into a data root commitment included in the block header.

    Lifecycle of a celestia-app Transaction

    See the detailed life cycle of a Celestia transaction.

    Learn how to submit data to Celestia’s data availability layer.

    Fee market overview

    Celestia uses a standard gas-price prioritised mempool. This means that transactions with higher fees will be prioritised by validators. Fees are comprised of a flat fee per transaction and then a variable fee based on the size of each blob in the transaction.

    Understand how fees are calculated on Celestia in the overview on submitting PFB transactions.

    ',11),n=[r];function c(l,d,p,h,b,m){return t(),o("div",null,n)}const y=e(s,[["render",c]]);export{_ as __pageData,y as default}; diff --git a/pr-1815/assets/learn_paying-for-blobspace.md.c34353bd.lean.js b/pr-1815/assets/learn_paying-for-blobspace.md.119c2d85.lean.js similarity index 90% rename from pr-1815/assets/learn_paying-for-blobspace.md.c34353bd.lean.js rename to pr-1815/assets/learn_paying-for-blobspace.md.119c2d85.lean.js index 037566cf5..c0590db0e 100644 --- a/pr-1815/assets/learn_paying-for-blobspace.md.c34353bd.lean.js +++ b/pr-1815/assets/learn_paying-for-blobspace.md.119c2d85.lean.js @@ -1 +1 @@ -import{_ as a}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as e,o as t,c as o,Q as i}from"./chunks/framework.2959b752.js";const _=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Paying for blobspace | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1732776394000}'),s={name:"learn/paying-for-blobspace.md"},r=i("",11),n=[r];function c(l,d,p,h,b,m){return t(),o("div",null,n)}const y=e(s,[["render",c]]);export{_ as __pageData,y as default}; +import{_ as a}from"./chunks/tx-lifecycle.2bc0a3c2.js";import{_ as e,o as t,c as o,Q as i}from"./chunks/framework.2959b752.js";const _=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Paying for blobspace | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1732777479000}'),s={name:"learn/paying-for-blobspace.md"},r=i("",11),n=[r];function c(l,d,p,h,b,m){return t(),o("div",null,n)}const y=e(s,[["render",c]]);export{_ as __pageData,y as default}; diff --git a/pr-1815/assets/learn_retrievability.md.2e5aa538.js b/pr-1815/assets/learn_retrievability.md.d172ae26.js similarity index 98% rename from pr-1815/assets/learn_retrievability.md.2e5aa538.js rename to pr-1815/assets/learn_retrievability.md.d172ae26.js index a7296a73f..9add48f57 100644 --- a/pr-1815/assets/learn_retrievability.md.2e5aa538.js +++ b/pr-1815/assets/learn_retrievability.md.d172ae26.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","frontmatter":{"sidebar_label":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","head":[["meta",{"property":"og:title","content":"Data retrievability and pruning | Celestia Docs"}],["meta",{"property":"og:description","content":"Practices and expectations for data retrievability and pruning on Celestia."}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1732776394000}'),o={name:"learn/retrievability.md"},r=i('

    Data retrievability and pruning

    The purpose of data availability layers such as Celestia is to ensure that block data is provably published, so that applications and rollups can know what the state of their chain is, and store that data. Once the data is published, data availability layers do not inherently guarantee that historical data will be permanently stored and remain retrievable.

    In this document, we discuss the state of data retrievability and pruning in Celestia, as well as some tips for rollup developers in order to ensure that syncing new rollup nodes is possible.

    Data retrievability and pruning in celestia-node

    As of version v0.13.0, celestia-node has implemented a light node sampling window of 30 days, as specified in CIP-4. This means that once pruning is implemented, light nodes will now only sample blocks within a 30-day window instead of sampling all blocks from genesis. This change introduces the concept of pruning to celestia-node, where data outside of the 30-day window may not be stored by light nodes, marking a significant update in how data retrievability and storage are managed within the network (v0.13.0 release notes).

    Data blobs older than the recency window will be pruned by default on light nodes, after pruning is fully implemented, but will continue to be stored by archival nodes that do not prune data. Light nodes will be able to query historic blob data in namespaces from archival nodes, as long as archival nodes exist on the public network.

    Once pruning is fully implemented, light nodes will only perform data availability sampling for blocks within the data recency window of 30 days.

    Suggested practices for rollups

    Rollups may need to access historic data in order to allow new rollup nodes to reconstruct the latest state by replaying historical blocks. Once data has been published on Celestia and guaranteed to have been made available, rollups and applications are responsible for storing their historical data.

    While it is possible to continue to do this by using the GetAll API method in celestia-node on historic blocks as long as archival nodes exist on the public Celestia network, rollup developers should not rely on this as the only method to access historical data, as archival nodes serving requests for historical data for free is not guaranteed. Below are some other suggested methods to access historical data.

    • Use professional archival node or data providers. It is expected that professional infrastructure providers will provide paid access to archival nodes, where historical data can be retrieved, for example using the GetAll API method. This provides better guarantees than solely relying on free archival nodes on the public Celestia network.
    • Share snapshots of rollup nodes. Rollups could share snapshots of their data directories which can be downloaded manually by users bootstrapping new nodes. These snapshots could contain the latest state of the rollup, and/or all the historical blocks.
    • Add peer-to-peer support for historical block sync. A less manual version of sharing snapshots, where rollup nodes could implement built-in support for block sync, where rollup nodes download historical block data from each other over a peer-to-peer network.
      • Namespace pinning. In the future, celestia-node is expected to allow nodes to choose to "pin" data from selected namespaces that they wish to store and make available for other nodes. This will allow rollup nodes to be responsible for storing their data, without needing to implement their own peer-to-peer historical block sync mechanism.
    ',11),n=[r];function s(l,d,c,h,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{g as __pageData,f as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","frontmatter":{"sidebar_label":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","head":[["meta",{"property":"og:title","content":"Data retrievability and pruning | Celestia Docs"}],["meta",{"property":"og:description","content":"Practices and expectations for data retrievability and pruning on Celestia."}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1732777479000}'),o={name:"learn/retrievability.md"},r=i('

    Data retrievability and pruning

    The purpose of data availability layers such as Celestia is to ensure that block data is provably published, so that applications and rollups can know what the state of their chain is, and store that data. Once the data is published, data availability layers do not inherently guarantee that historical data will be permanently stored and remain retrievable.

    In this document, we discuss the state of data retrievability and pruning in Celestia, as well as some tips for rollup developers in order to ensure that syncing new rollup nodes is possible.

    Data retrievability and pruning in celestia-node

    As of version v0.13.0, celestia-node has implemented a light node sampling window of 30 days, as specified in CIP-4. This means that once pruning is implemented, light nodes will now only sample blocks within a 30-day window instead of sampling all blocks from genesis. This change introduces the concept of pruning to celestia-node, where data outside of the 30-day window may not be stored by light nodes, marking a significant update in how data retrievability and storage are managed within the network (v0.13.0 release notes).

    Data blobs older than the recency window will be pruned by default on light nodes, after pruning is fully implemented, but will continue to be stored by archival nodes that do not prune data. Light nodes will be able to query historic blob data in namespaces from archival nodes, as long as archival nodes exist on the public network.

    Once pruning is fully implemented, light nodes will only perform data availability sampling for blocks within the data recency window of 30 days.

    Suggested practices for rollups

    Rollups may need to access historic data in order to allow new rollup nodes to reconstruct the latest state by replaying historical blocks. Once data has been published on Celestia and guaranteed to have been made available, rollups and applications are responsible for storing their historical data.

    While it is possible to continue to do this by using the GetAll API method in celestia-node on historic blocks as long as archival nodes exist on the public Celestia network, rollup developers should not rely on this as the only method to access historical data, as archival nodes serving requests for historical data for free is not guaranteed. Below are some other suggested methods to access historical data.

    • Use professional archival node or data providers. It is expected that professional infrastructure providers will provide paid access to archival nodes, where historical data can be retrieved, for example using the GetAll API method. This provides better guarantees than solely relying on free archival nodes on the public Celestia network.
    • Share snapshots of rollup nodes. Rollups could share snapshots of their data directories which can be downloaded manually by users bootstrapping new nodes. These snapshots could contain the latest state of the rollup, and/or all the historical blocks.
    • Add peer-to-peer support for historical block sync. A less manual version of sharing snapshots, where rollup nodes could implement built-in support for block sync, where rollup nodes download historical block data from each other over a peer-to-peer network.
      • Namespace pinning. In the future, celestia-node is expected to allow nodes to choose to "pin" data from selected namespaces that they wish to store and make available for other nodes. This will allow rollup nodes to be responsible for storing their data, without needing to implement their own peer-to-peer historical block sync mechanism.
    ',11),n=[r];function s(l,d,c,h,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{g as __pageData,f as default}; diff --git a/pr-1815/assets/learn_retrievability.md.2e5aa538.lean.js b/pr-1815/assets/learn_retrievability.md.d172ae26.lean.js similarity index 92% rename from pr-1815/assets/learn_retrievability.md.2e5aa538.lean.js rename to pr-1815/assets/learn_retrievability.md.d172ae26.lean.js index 8097a9199..c786c2d5f 100644 --- a/pr-1815/assets/learn_retrievability.md.2e5aa538.lean.js +++ b/pr-1815/assets/learn_retrievability.md.d172ae26.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","frontmatter":{"sidebar_label":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","head":[["meta",{"property":"og:title","content":"Data retrievability and pruning | Celestia Docs"}],["meta",{"property":"og:description","content":"Practices and expectations for data retrievability and pruning on Celestia."}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1732776394000}'),o={name:"learn/retrievability.md"},r=i("",11),n=[r];function s(l,d,c,h,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{g as __pageData,f as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","frontmatter":{"sidebar_label":"Data retrievability and pruning","description":"Practices and expectations for data retrievability and pruning on Celestia.","head":[["meta",{"property":"og:title","content":"Data retrievability and pruning | Celestia Docs"}],["meta",{"property":"og:description","content":"Practices and expectations for data retrievability and pruning on Celestia."}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1732777479000}'),o={name:"learn/retrievability.md"},r=i("",11),n=[r];function s(l,d,c,h,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{g as __pageData,f as default}; diff --git a/pr-1815/assets/learn_staking-governance-supply.md.8e42e486.js b/pr-1815/assets/learn_staking-governance-supply.md.315bdc22.js similarity index 99% rename from pr-1815/assets/learn_staking-governance-supply.md.8e42e486.js rename to pr-1815/assets/learn_staking-governance-supply.md.315bdc22.js index 966b68745..fe827b9fe 100644 --- a/pr-1815/assets/learn_staking-governance-supply.md.8e42e486.js +++ b/pr-1815/assets/learn_staking-governance-supply.md.315bdc22.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1815/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1815/img/learn/Celestia_TIA_Available_Supply.png",k=JSON.parse('{"title":"Staking, governance, & supply","description":"Learn about proof-of-stake on Celestia","frontmatter":{"description":"Learn about proof-of-stake on Celestia","head":[["meta",{"property":"og:title","content":"Staking, governance, & supply | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about proof-of-stake on Celestia"}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1732776394000}'),i={name:"learn/staking-governance-supply.md"},l=o('

    Staking, governance, & supply

    Proof-of-stake on Celestia

    Celestia is a proof-of-stake blockchain based on CometBFT and the Cosmos SDK. Celestia supports in-protocol delegation and will start with an initial validator set of 100.

    Staking TIA as a validator or delegator enables you to earn staking rewards from the network. Validators charge a fee to delegators which gives them a percentage of staking rewards.

    Learn how proof of stake works on Cosmos SDK chains like Celestia.

    Consensus mechanismProof-of-stake
    Blockchain frameworkCosmos SDK
    Validator set size100
    Delegation supportYes

    Learn how to stake on your own at the community dashboards.

    Inflation

    TIA inflation starts at 8% annually and decreases by 10% every year until it reaches the long term issuance rate of 1.5%. Exact annual inflation rates can be found in the diagram below.

    inflation diagram

    The annual provisions for inflation are calculated based on the total supply of TIA at the beginning of each year. To calculate how many TIA to issue per block, Celestia uses the block timestamp rather than the block height since the time between blocks can vary and cause actual issuance to be higher than the target.

    For an in-depth understanding, refer to ADR019.

    Decentralised governance

    Network parameters

    TIA holders (not just stakers) can propose and vote on governance proposals to change a subset of network parameters. To learn more, see a complete list of both the changeable and non-changeable parameters and their values. Additionally, learn how to submit and vote on governance proposals.

    Community pool

    Starting at genesis, Celestia’s community pool receives 2% of all Celestia block rewards. TIA stakers may vote to fund ecosystem initiatives as in many other Cosmos SDK chains.

    Learn how to submit a governance proposal to spend community pool funds.

    TIA allocation at genesis

    Celestia will have a total supply of 1,000,000,000 TIA at genesis, split across five categories described in the chart and table below.

    allocation diagram

    CategoryDescription%
    Public AllocationGenesis Drop and Incentivized Testnet: 7.41%
    Future initiatives: 12.59%
    20.00%
    R&D & EcosystemTokens allocated to the Celestia Foundation and core devs for research, development, and ecosystem initiatives including:
    - Protocol maintenance and development
    - Programs for rollup developers, infrastructure, and node operators
    26.79%
    Early Backers: Series A&BEarly supporters of Celestia19.67%
    Early Backers: SeedEarly supporters of Celestia15.90%
    Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.64%

    Unlocks

    Celestia’s 1 billion TIA supply at genesis will be subject to several different unlock schedules. All tokens, locked or unlocked, may be staked, but staking rewards are unlocked upon receipt and will add to the circulating supply.

    Circulating supply is defined as the amount of TIA tokens in general circulation without onchain transfer restrictions.

    Available supply is defined as the amount of TIA tokens that are either part of the circulating supply or are unlocked but subject to some form of governance to determine when the tokens are allocated. This includes the unlocked portion of the R&D & Ecosystem tokens and the tokens set aside for future initiatives.

    The definitions for circulating and available supply were adapted from Optimism’s definitions.

    supply diagram

    Unlock schedule by category is described in the table below.

    Note: Due to 2024 being a leap year, the yearly unlock intervals will occur on October 30th of each year. For example, unlocks at year 1 will occur on October 30, 2024.

    CategoryUnlock Schedule
    Public AllocationFully unlocked at launch.
    R&D & Ecosystem25.00% unlocked at launch.
    Remaining 75.00% unlocks continuously from year 1 to year 4.
    Initial Core Contributors33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 3.
    Early Backers: Seed33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    Early Backers: Series A&B33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    ',31),c=[l];function d(p,h,u,m,g,f){return t(),a("div",null,c)}const y=e(i,[["render",d]]);export{k as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1815/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1815/img/learn/Celestia_TIA_Available_Supply.png",k=JSON.parse('{"title":"Staking, governance, & supply","description":"Learn about proof-of-stake on Celestia","frontmatter":{"description":"Learn about proof-of-stake on Celestia","head":[["meta",{"property":"og:title","content":"Staking, governance, & supply | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about proof-of-stake on Celestia"}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1732777479000}'),i={name:"learn/staking-governance-supply.md"},l=o('

    Staking, governance, & supply

    Proof-of-stake on Celestia

    Celestia is a proof-of-stake blockchain based on CometBFT and the Cosmos SDK. Celestia supports in-protocol delegation and will start with an initial validator set of 100.

    Staking TIA as a validator or delegator enables you to earn staking rewards from the network. Validators charge a fee to delegators which gives them a percentage of staking rewards.

    Learn how proof of stake works on Cosmos SDK chains like Celestia.

    Consensus mechanismProof-of-stake
    Blockchain frameworkCosmos SDK
    Validator set size100
    Delegation supportYes

    Learn how to stake on your own at the community dashboards.

    Inflation

    TIA inflation starts at 8% annually and decreases by 10% every year until it reaches the long term issuance rate of 1.5%. Exact annual inflation rates can be found in the diagram below.

    inflation diagram

    The annual provisions for inflation are calculated based on the total supply of TIA at the beginning of each year. To calculate how many TIA to issue per block, Celestia uses the block timestamp rather than the block height since the time between blocks can vary and cause actual issuance to be higher than the target.

    For an in-depth understanding, refer to ADR019.

    Decentralised governance

    Network parameters

    TIA holders (not just stakers) can propose and vote on governance proposals to change a subset of network parameters. To learn more, see a complete list of both the changeable and non-changeable parameters and their values. Additionally, learn how to submit and vote on governance proposals.

    Community pool

    Starting at genesis, Celestia’s community pool receives 2% of all Celestia block rewards. TIA stakers may vote to fund ecosystem initiatives as in many other Cosmos SDK chains.

    Learn how to submit a governance proposal to spend community pool funds.

    TIA allocation at genesis

    Celestia will have a total supply of 1,000,000,000 TIA at genesis, split across five categories described in the chart and table below.

    allocation diagram

    CategoryDescription%
    Public AllocationGenesis Drop and Incentivized Testnet: 7.41%
    Future initiatives: 12.59%
    20.00%
    R&D & EcosystemTokens allocated to the Celestia Foundation and core devs for research, development, and ecosystem initiatives including:
    - Protocol maintenance and development
    - Programs for rollup developers, infrastructure, and node operators
    26.79%
    Early Backers: Series A&BEarly supporters of Celestia19.67%
    Early Backers: SeedEarly supporters of Celestia15.90%
    Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.64%

    Unlocks

    Celestia’s 1 billion TIA supply at genesis will be subject to several different unlock schedules. All tokens, locked or unlocked, may be staked, but staking rewards are unlocked upon receipt and will add to the circulating supply.

    Circulating supply is defined as the amount of TIA tokens in general circulation without onchain transfer restrictions.

    Available supply is defined as the amount of TIA tokens that are either part of the circulating supply or are unlocked but subject to some form of governance to determine when the tokens are allocated. This includes the unlocked portion of the R&D & Ecosystem tokens and the tokens set aside for future initiatives.

    The definitions for circulating and available supply were adapted from Optimism’s definitions.

    supply diagram

    Unlock schedule by category is described in the table below.

    Note: Due to 2024 being a leap year, the yearly unlock intervals will occur on October 30th of each year. For example, unlocks at year 1 will occur on October 30, 2024.

    CategoryUnlock Schedule
    Public AllocationFully unlocked at launch.
    R&D & Ecosystem25.00% unlocked at launch.
    Remaining 75.00% unlocks continuously from year 1 to year 4.
    Initial Core Contributors33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 3.
    Early Backers: Seed33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    Early Backers: Series A&B33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    ',31),c=[l];function d(p,h,u,m,g,f){return t(),a("div",null,c)}const y=e(i,[["render",d]]);export{k as __pageData,y as default}; diff --git a/pr-1815/assets/learn_staking-governance-supply.md.8e42e486.lean.js b/pr-1815/assets/learn_staking-governance-supply.md.315bdc22.lean.js similarity index 93% rename from pr-1815/assets/learn_staking-governance-supply.md.8e42e486.lean.js rename to pr-1815/assets/learn_staking-governance-supply.md.315bdc22.lean.js index 9742101c6..ad423168b 100644 --- a/pr-1815/assets/learn_staking-governance-supply.md.8e42e486.lean.js +++ b/pr-1815/assets/learn_staking-governance-supply.md.315bdc22.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1815/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1815/img/learn/Celestia_TIA_Available_Supply.png",k=JSON.parse('{"title":"Staking, governance, & supply","description":"Learn about proof-of-stake on Celestia","frontmatter":{"description":"Learn about proof-of-stake on Celestia","head":[["meta",{"property":"og:title","content":"Staking, governance, & supply | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about proof-of-stake on Celestia"}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1732776394000}'),i={name:"learn/staking-governance-supply.md"},l=o("",31),c=[l];function d(p,h,u,m,g,f){return t(),a("div",null,c)}const y=e(i,[["render",d]]);export{k as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.2959b752.js";const r="/docs-preview/pr-1815/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1815/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1815/img/learn/Celestia_TIA_Available_Supply.png",k=JSON.parse('{"title":"Staking, governance, & supply","description":"Learn about proof-of-stake on Celestia","frontmatter":{"description":"Learn about proof-of-stake on Celestia","head":[["meta",{"property":"og:title","content":"Staking, governance, & supply | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn about proof-of-stake on Celestia"}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1732777479000}'),i={name:"learn/staking-governance-supply.md"},l=o("",31),c=[l];function d(p,h,u,m,g,f){return t(),a("div",null,c)}const y=e(i,[["render",d]]);export{k as __pageData,y as default}; diff --git a/pr-1815/assets/learn_staking.md.7608d6a2.js b/pr-1815/assets/learn_staking.md.4211cf86.js similarity index 97% rename from pr-1815/assets/learn_staking.md.7608d6a2.js rename to pr-1815/assets/learn_staking.md.4211cf86.js index c7c6d732d..c6bedc14b 100644 --- a/pr-1815/assets/learn_staking.md.7608d6a2.js +++ b/pr-1815/assets/learn_staking.md.4211cf86.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Staking on Celestia","description":"Learn how to stake your tokens on the Celestia network.","frontmatter":{"description":"Learn how to stake your tokens on the Celestia network.","head":[["meta",{"property":"og:title","content":"Staking on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to stake your tokens on the Celestia network."}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1732776394000}'),s={name:"learn/staking.md"},r=n('

    Staking on Celestia

    Engage with the Celestia network at a deeper level through staking. An essential mechanism to a proof-of-stake network, users can secure the network by delegating to a validator and receive a share of its staking rewards.

    Mainnet Beta

    Currently, the following staking interfaces exist for the Mainnet Beta.

    Just connect your wallet to get started!

    Mocha testnet

    Currently, the following staking interfaces exist for the Mocha testnet.

    Just connect your wallet to get started!

    ',10),o=[r];function i(l,h,c,p,k,d){return t(),a("div",null,o)}const _=e(s,[["render",i]]);export{f as __pageData,_ as default}; +import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Staking on Celestia","description":"Learn how to stake your tokens on the Celestia network.","frontmatter":{"description":"Learn how to stake your tokens on the Celestia network.","head":[["meta",{"property":"og:title","content":"Staking on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to stake your tokens on the Celestia network."}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1732777479000}'),s={name:"learn/staking.md"},r=n('

    Staking on Celestia

    Engage with the Celestia network at a deeper level through staking. An essential mechanism to a proof-of-stake network, users can secure the network by delegating to a validator and receive a share of its staking rewards.

    Mainnet Beta

    Currently, the following staking interfaces exist for the Mainnet Beta.

    Just connect your wallet to get started!

    Mocha testnet

    Currently, the following staking interfaces exist for the Mocha testnet.

    Just connect your wallet to get started!

    ',10),o=[r];function i(l,h,c,p,k,d){return t(),a("div",null,o)}const _=e(s,[["render",i]]);export{f as __pageData,_ as default}; diff --git a/pr-1815/assets/learn_staking.md.7608d6a2.lean.js b/pr-1815/assets/learn_staking.md.4211cf86.lean.js similarity index 91% rename from pr-1815/assets/learn_staking.md.7608d6a2.lean.js rename to pr-1815/assets/learn_staking.md.4211cf86.lean.js index 39bf5db4e..020da15cd 100644 --- a/pr-1815/assets/learn_staking.md.7608d6a2.lean.js +++ b/pr-1815/assets/learn_staking.md.4211cf86.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Staking on Celestia","description":"Learn how to stake your tokens on the Celestia network.","frontmatter":{"description":"Learn how to stake your tokens on the Celestia network.","head":[["meta",{"property":"og:title","content":"Staking on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to stake your tokens on the Celestia network."}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1732776394000}'),s={name:"learn/staking.md"},r=n("",10),o=[r];function i(l,h,c,p,k,d){return t(),a("div",null,o)}const _=e(s,[["render",i]]);export{f as __pageData,_ as default}; +import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.2959b752.js";const f=JSON.parse('{"title":"Staking on Celestia","description":"Learn how to stake your tokens on the Celestia network.","frontmatter":{"description":"Learn how to stake your tokens on the Celestia network.","head":[["meta",{"property":"og:title","content":"Staking on Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to stake your tokens on the Celestia network."}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1732777479000}'),s={name:"learn/staking.md"},r=n("",10),o=[r];function i(l,h,c,p,k,d){return t(),a("div",null,o)}const _=e(s,[["render",i]]);export{f as __pageData,_ as default}; diff --git a/pr-1815/assets/learn_tia.md.e94f8580.js b/pr-1815/assets/learn_tia.md.8cf214a7.js similarity index 99% rename from pr-1815/assets/learn_tia.md.e94f8580.js rename to pr-1815/assets/learn_tia.md.8cf214a7.js index 7d716714e..a7998ded4 100644 --- a/pr-1815/assets/learn_tia.md.e94f8580.js +++ b/pr-1815/assets/learn_tia.md.8cf214a7.js @@ -1 +1 @@ -import{_ as s,o as t,c as e,k as a,a as o,Q as n}from"./chunks/framework.2959b752.js";const A=JSON.parse('{"title":"Overview of TIA","description":"","frontmatter":{"prev":{"text":"Data availability FAQ","link":"/learn/how-celestia-works/data-availability-faq"},"head":[["meta",{"property":"og:title","content":"Overview of TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1732776394000}'),i={name:"learn/tia.md"},r=a("h1",{id:"overview-of-tia",tabindex:"-1"},[o("Overview of TIA "),a("a",{class:"header-anchor",href:"#overview-of-tia","aria-label":'Permalink to "Overview of TIA"'},"​")],-1),l=a("h2",{id:"tia-at-a-glance",tabindex:"-1"},[o("TIA at a glance "),a("a",{class:"header-anchor",href:"#tia-at-a-glance","aria-label":'Permalink to "TIA at a glance"'},"​")],-1),d=a("thead",null,[a("tr",null,[a("th",null,"Property"),a("th",null,"Details")])],-1),c=a("tr",null,[a("td",null,"Abbreviation"),a("td",null,"TIA")],-1),h=a("tr",null,[a("td",null,"Total supply at genesis"),a("td",null,"1,000,000,000 TIA")],-1),p=a("tr",null,[a("td",null,"Inflation schedule"),a("td",null,"8% in the first year, decreasing 10% per year until reaching an inflation floor of 1.5% annually")],-1),Q=a("tr",null,[a("td",null,"Decimals"),a("td",null,"6")],-1),T=a("td",null,"Conversion",-1),m={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},u={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"21.526ex",height:"2.14ex",role:"img",focusable:"false",viewBox:"0 -864 9514.7 946","aria-hidden":"true"},f=n('',1),g=[f],H=a("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[a("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[a("mtext",null,"1 uTIA"),a("mo",null,"="),a("mtext",null,"TIA"),a("mo",null,"×"),a("msup",null,[a("mn",null,"10"),a("mrow",{"data-mjx-texclass":"ORD"},[a("mo",null,"−"),a("mn",null,"6")])])])],-1),k=n('

    Role of TIA

    Paying for blobspace

    Celestia’s native asset, TIA, is an essential part of how developers build on the first modular blockchain network. To use Celestia for data availability, rollup developers submit PayForBlobs transactions on the network for a fee, denominated in TIA.

    Bootstrapping new rollups

    A core part of the Celestia vision is that deploying a blockchain should be as easy as deploying a smart contract. In the modular era, developers no longer need to issue a token to launch their own blockchain.

    Similarly to ETH on Ethereum-based rollups, developers may opt to bootstrap their chain quickly by using TIA as a gas token and currency, in addition to paying for data availability. In this mode, developers can focus on creating their application or execution layer, instead of issuing a token right away.

    Proof-of-stake

    As a permissionless network built with Cosmos SDK, Celestia uses proof-of-stake to secure its own consensus. Like in other Cosmos networks, any user can help secure the network by delegating their TIA to a Celestia validator for a portion of their validator’s staking rewards.

    Learn how proof-of-stake works in Cosmos.

    Decentralised governance

    TIA staking also allows the community to play a critical role in decentralised governance over key parts of Celestia, such as voting on network parameters through governance proposals, and governing the community pool, which receives 2% of block rewards.

    Learn more about Celestia’s decentralised governance model.

    Denominations

    TIA: display token

    TIA is the DisplayDenom that you will typically see in wallets and user interfaces.

    utia: staking denomination

    utia is the BondDenom and stands for "micro TIA", with 1 TIA = 1,000,000 utia. This is the native staking denomination.

    In staking operations or transactions, if no denomination is specified, utia is assumed.

    microtia: staking denomination alias

    microtia is the BondDenomAlias, an alias for utia.

    ',20);function b(_,w,V,y,v,x){return t(),e("div",null,[r,l,a("table",null,[d,a("tbody",null,[c,h,p,Q,a("tr",null,[T,a("td",null,[a("mjx-container",m,[(t(),e("svg",u,g)),H])])])])]),k])}const I=s(i,[["render",b]]);export{A as __pageData,I as default}; +import{_ as s,o as t,c as e,k as a,a as o,Q as n}from"./chunks/framework.2959b752.js";const A=JSON.parse('{"title":"Overview of TIA","description":"","frontmatter":{"prev":{"text":"Data availability FAQ","link":"/learn/how-celestia-works/data-availability-faq"},"head":[["meta",{"property":"og:title","content":"Overview of TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1732777479000}'),i={name:"learn/tia.md"},r=a("h1",{id:"overview-of-tia",tabindex:"-1"},[o("Overview of TIA "),a("a",{class:"header-anchor",href:"#overview-of-tia","aria-label":'Permalink to "Overview of TIA"'},"​")],-1),l=a("h2",{id:"tia-at-a-glance",tabindex:"-1"},[o("TIA at a glance "),a("a",{class:"header-anchor",href:"#tia-at-a-glance","aria-label":'Permalink to "TIA at a glance"'},"​")],-1),d=a("thead",null,[a("tr",null,[a("th",null,"Property"),a("th",null,"Details")])],-1),c=a("tr",null,[a("td",null,"Abbreviation"),a("td",null,"TIA")],-1),h=a("tr",null,[a("td",null,"Total supply at genesis"),a("td",null,"1,000,000,000 TIA")],-1),p=a("tr",null,[a("td",null,"Inflation schedule"),a("td",null,"8% in the first year, decreasing 10% per year until reaching an inflation floor of 1.5% annually")],-1),Q=a("tr",null,[a("td",null,"Decimals"),a("td",null,"6")],-1),T=a("td",null,"Conversion",-1),m={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},u={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"21.526ex",height:"2.14ex",role:"img",focusable:"false",viewBox:"0 -864 9514.7 946","aria-hidden":"true"},f=n('',1),g=[f],H=a("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[a("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[a("mtext",null,"1 uTIA"),a("mo",null,"="),a("mtext",null,"TIA"),a("mo",null,"×"),a("msup",null,[a("mn",null,"10"),a("mrow",{"data-mjx-texclass":"ORD"},[a("mo",null,"−"),a("mn",null,"6")])])])],-1),k=n('

    Role of TIA

    Paying for blobspace

    Celestia’s native asset, TIA, is an essential part of how developers build on the first modular blockchain network. To use Celestia for data availability, rollup developers submit PayForBlobs transactions on the network for a fee, denominated in TIA.

    Bootstrapping new rollups

    A core part of the Celestia vision is that deploying a blockchain should be as easy as deploying a smart contract. In the modular era, developers no longer need to issue a token to launch their own blockchain.

    Similarly to ETH on Ethereum-based rollups, developers may opt to bootstrap their chain quickly by using TIA as a gas token and currency, in addition to paying for data availability. In this mode, developers can focus on creating their application or execution layer, instead of issuing a token right away.

    Proof-of-stake

    As a permissionless network built with Cosmos SDK, Celestia uses proof-of-stake to secure its own consensus. Like in other Cosmos networks, any user can help secure the network by delegating their TIA to a Celestia validator for a portion of their validator’s staking rewards.

    Learn how proof-of-stake works in Cosmos.

    Decentralised governance

    TIA staking also allows the community to play a critical role in decentralised governance over key parts of Celestia, such as voting on network parameters through governance proposals, and governing the community pool, which receives 2% of block rewards.

    Learn more about Celestia’s decentralised governance model.

    Denominations

    TIA: display token

    TIA is the DisplayDenom that you will typically see in wallets and user interfaces.

    utia: staking denomination

    utia is the BondDenom and stands for "micro TIA", with 1 TIA = 1,000,000 utia. This is the native staking denomination.

    In staking operations or transactions, if no denomination is specified, utia is assumed.

    microtia: staking denomination alias

    microtia is the BondDenomAlias, an alias for utia.

    ',20);function b(_,w,V,y,v,x){return t(),e("div",null,[r,l,a("table",null,[d,a("tbody",null,[c,h,p,Q,a("tr",null,[T,a("td",null,[a("mjx-container",m,[(t(),e("svg",u,g)),H])])])])]),k])}const I=s(i,[["render",b]]);export{A as __pageData,I as default}; diff --git a/pr-1815/assets/learn_tia.md.e94f8580.lean.js b/pr-1815/assets/learn_tia.md.8cf214a7.lean.js similarity index 97% rename from pr-1815/assets/learn_tia.md.e94f8580.lean.js rename to pr-1815/assets/learn_tia.md.8cf214a7.lean.js index f41cfd654..fd165de75 100644 --- a/pr-1815/assets/learn_tia.md.e94f8580.lean.js +++ b/pr-1815/assets/learn_tia.md.8cf214a7.lean.js @@ -1 +1 @@ -import{_ as s,o as t,c as e,k as a,a as o,Q as n}from"./chunks/framework.2959b752.js";const A=JSON.parse('{"title":"Overview of TIA","description":"","frontmatter":{"prev":{"text":"Data availability FAQ","link":"/learn/how-celestia-works/data-availability-faq"},"head":[["meta",{"property":"og:title","content":"Overview of TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1732776394000}'),i={name:"learn/tia.md"},r=a("h1",{id:"overview-of-tia",tabindex:"-1"},[o("Overview of TIA "),a("a",{class:"header-anchor",href:"#overview-of-tia","aria-label":'Permalink to "Overview of TIA"'},"​")],-1),l=a("h2",{id:"tia-at-a-glance",tabindex:"-1"},[o("TIA at a glance "),a("a",{class:"header-anchor",href:"#tia-at-a-glance","aria-label":'Permalink to "TIA at a glance"'},"​")],-1),d=a("thead",null,[a("tr",null,[a("th",null,"Property"),a("th",null,"Details")])],-1),c=a("tr",null,[a("td",null,"Abbreviation"),a("td",null,"TIA")],-1),h=a("tr",null,[a("td",null,"Total supply at genesis"),a("td",null,"1,000,000,000 TIA")],-1),p=a("tr",null,[a("td",null,"Inflation schedule"),a("td",null,"8% in the first year, decreasing 10% per year until reaching an inflation floor of 1.5% annually")],-1),Q=a("tr",null,[a("td",null,"Decimals"),a("td",null,"6")],-1),T=a("td",null,"Conversion",-1),m={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},u={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"21.526ex",height:"2.14ex",role:"img",focusable:"false",viewBox:"0 -864 9514.7 946","aria-hidden":"true"},f=n("",1),g=[f],H=a("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[a("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[a("mtext",null,"1 uTIA"),a("mo",null,"="),a("mtext",null,"TIA"),a("mo",null,"×"),a("msup",null,[a("mn",null,"10"),a("mrow",{"data-mjx-texclass":"ORD"},[a("mo",null,"−"),a("mn",null,"6")])])])],-1),k=n("",20);function b(_,w,V,y,v,x){return t(),e("div",null,[r,l,a("table",null,[d,a("tbody",null,[c,h,p,Q,a("tr",null,[T,a("td",null,[a("mjx-container",m,[(t(),e("svg",u,g)),H])])])])]),k])}const I=s(i,[["render",b]]);export{A as __pageData,I as default}; +import{_ as s,o as t,c as e,k as a,a as o,Q as n}from"./chunks/framework.2959b752.js";const A=JSON.parse('{"title":"Overview of TIA","description":"","frontmatter":{"prev":{"text":"Data availability FAQ","link":"/learn/how-celestia-works/data-availability-faq"},"head":[["meta",{"property":"og:title","content":"Overview of TIA | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1732777479000}'),i={name:"learn/tia.md"},r=a("h1",{id:"overview-of-tia",tabindex:"-1"},[o("Overview of TIA "),a("a",{class:"header-anchor",href:"#overview-of-tia","aria-label":'Permalink to "Overview of TIA"'},"​")],-1),l=a("h2",{id:"tia-at-a-glance",tabindex:"-1"},[o("TIA at a glance "),a("a",{class:"header-anchor",href:"#tia-at-a-glance","aria-label":'Permalink to "TIA at a glance"'},"​")],-1),d=a("thead",null,[a("tr",null,[a("th",null,"Property"),a("th",null,"Details")])],-1),c=a("tr",null,[a("td",null,"Abbreviation"),a("td",null,"TIA")],-1),h=a("tr",null,[a("td",null,"Total supply at genesis"),a("td",null,"1,000,000,000 TIA")],-1),p=a("tr",null,[a("td",null,"Inflation schedule"),a("td",null,"8% in the first year, decreasing 10% per year until reaching an inflation floor of 1.5% annually")],-1),Q=a("tr",null,[a("td",null,"Decimals"),a("td",null,"6")],-1),T=a("td",null,"Conversion",-1),m={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},u={style:{overflow:"visible","min-height":"1px","min-width":"1px","vertical-align":"-0.186ex"},xmlns:"http://www.w3.org/2000/svg",width:"21.526ex",height:"2.14ex",role:"img",focusable:"false",viewBox:"0 -864 9514.7 946","aria-hidden":"true"},f=n("",1),g=[f],H=a("mjx-assistive-mml",{unselectable:"on",display:"inline",style:{top:"0px",left:"0px",clip:"rect(1px, 1px, 1px, 1px)","-webkit-touch-callout":"none","-webkit-user-select":"none","-khtml-user-select":"none","-moz-user-select":"none","-ms-user-select":"none","user-select":"none",position:"absolute",padding:"1px 0px 0px 0px",border:"0px",display:"block",width:"auto",overflow:"hidden"}},[a("math",{xmlns:"http://www.w3.org/1998/Math/MathML"},[a("mtext",null,"1 uTIA"),a("mo",null,"="),a("mtext",null,"TIA"),a("mo",null,"×"),a("msup",null,[a("mn",null,"10"),a("mrow",{"data-mjx-texclass":"ORD"},[a("mo",null,"−"),a("mn",null,"6")])])])],-1),k=n("",20);function b(_,w,V,y,v,x){return t(),e("div",null,[r,l,a("table",null,[d,a("tbody",null,[c,h,p,Q,a("tr",null,[T,a("td",null,[a("mjx-container",m,[(t(),e("svg",u,g)),H])])])])]),k])}const I=s(i,[["render",b]]);export{A as __pageData,I as default}; diff --git a/pr-1815/assets/tutorials_celestia-node-key.md.369cf494.js b/pr-1815/assets/tutorials_celestia-node-key.md.30b8a442.js similarity index 98% rename from pr-1815/assets/tutorials_celestia-node-key.md.369cf494.js rename to pr-1815/assets/tutorials_celestia-node-key.md.30b8a442.js index daa0eb08e..a2a9d2e1b 100644 --- a/pr-1815/assets/tutorials_celestia-node-key.md.369cf494.js +++ b/pr-1815/assets/tutorials_celestia-node-key.md.30b8a442.js @@ -4,19 +4,19 @@ import{m as o}from"./chunks/mocha_versions.1f7c0f1d.js";import{o as p,c as t,k a make cel-key
    # dumps binary in current working directory, accessible via \`./cel-key\`
     make cel-key

    or

    sh
    # installs binary in GOBIN path, accessible via \`cel-key\`
     make install-key
    # installs binary in GOBIN path, accessible via \`cel-key\`
    -make install-key

    For the purpose of this guide, we will use the make cel-key command.

    Steps for generating node keys

    To generate a key for a Celestia node, select the tab for your node type:

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    bash
    ./cel-key add <key-name> --keyring-backend test --node.type bridge \\
    +make install-key

    For the purpose of this guide, we will use the make cel-key command.

    Steps for generating node keys

    To generate a key for a Celestia node, select the tab for your node type:

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    bash
    ./cel-key add <key-name> --keyring-backend test --node.type bridge \\
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type bridge \\
       --p2p.network <network>
    bash
    ./cel-key add <key-name> --keyring-backend test --node.type full \\
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type full \\
       --p2p.network <network>
    bash
    ./cel-key add <key-name> --keyring-backend test --node.type light \\
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type light \\
    -  --p2p.network <network>

    This will load the key <key-name> into the directory of the node.

    Further flags you can use to customize your key are the following:

    • --p2p.network: Specifies which network you want the key for. Values are arabica and mocha. Please note the default network will be mocha.

    Keep in mind that your celestia-node will only pick up keys that are inside the default directory under /keys so you should make sure to point cel-key utility to the correct directory via the p2p.network or home flags if you have specified a custom directory or network other than Arabica, Mocha, or Mainnet Beta.

    Also keep in mind that if you do not specify a network with --p2p.network, the default one will always be celestia (Mainnet Beta).

    Steps for exporting node keys

    You can export a private key from the local keyring in encrypted and ASCII-armored format.

    bash
    ./cel-key export <key-name> --keyring-backend test --node.type bridge \\
    +  --p2p.network <network>

    This will load the key <key-name> into the directory of the node.

    Further flags you can use to customize your key are the following:

    • --p2p.network: Specifies which network you want the key for. Values are arabica and mocha. Please note the default network will be mocha.

    Keep in mind that your celestia-node will only pick up keys that are inside the default directory under /keys so you should make sure to point cel-key utility to the correct directory via the p2p.network or home flags if you have specified a custom directory or network other than Arabica, Mocha, or Mainnet Beta.

    Also keep in mind that if you do not specify a network with --p2p.network, the default one will always be celestia (Mainnet Beta).

    Steps for exporting node keys

    You can export a private key from the local keyring in encrypted and ASCII-armored format.

    bash
    ./cel-key export <key-name> --keyring-backend test --node.type bridge \\
       --p2p.network <network>
    ./cel-key export <key-name> --keyring-backend test --node.type bridge \\
       --p2p.network <network>
    bash
    ./cel-key export <key-name> --keyring-backend test --node.type full \\
       --p2p.network <network>
    ./cel-key export <key-name> --keyring-backend test --node.type full \\
       --p2p.network <network>
    bash
    ./cel-key export <key-name> --keyring-backend test --node.type light \\
       --p2p.network <network>
    ./cel-key export <key-name> --keyring-backend test --node.type light \\
    -  --p2p.network <network>

    Steps for importing node keys

    To import from a mnemonic, use the following command, then enter your bip39 mnemonic:

    bash
    ./cel-key add <key-name> --recover --keyring-backend test \\
    +  --p2p.network <network>

    Steps for importing node keys

    To import from a mnemonic, use the following command, then enter your bip39 mnemonic:

    bash
    ./cel-key add <key-name> --recover --keyring-backend test \\
       --node.type bridge --p2p.network <network>
    ./cel-key add <key-name> --recover --keyring-backend test \\
       --node.type bridge --p2p.network <network>
    bash
    ./cel-key add <key-name> --recover --keyring-backend test \\
       --node.type full --p2p.network <network>
    ./cel-key add <key-name> --recover --keyring-backend test \\
    @@ -56,7 +56,7 @@ import{m as o}from"./chunks/mocha_versions.1f7c0f1d.js";import{o as p,c as t,k a
     - address: celestia1wkhyhr7ngf0ayqlpnsnxg4d72hfs5453dvunm9
       name: my_celes_key
       pubkey: '{"@type":"/cosmos.crypto.secp256k1.PubKey","key":"A1/NsoY0RGL7Hqt4VWLg441GQKJsZ2fBUnZXipgns8oV"}'
    -  type: local
    `,24),S=JSON.parse('{"title":"Create a wallet with celestia-node","description":"Use the cel-key utility to generate a wallet on celestia-node.","frontmatter":{"description":"Use the cel-key utility to generate a wallet on celestia-node.","prev":{"text":"New Blobstream X deployments","link":"/how-to-guides/blobstream-x-deploy"},"head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Use the cel-key utility to generate a wallet on celestia-node."}]]},"headers":[],"relativePath":"tutorials/celestia-node-key.md","filePath":"tutorials/celestia-node-key.md","lastUpdated":1732776394000}'),w={name:"tutorials/celestia-node-key.md"},x=Object.assign(w,{setup(A){return(f,D)=>(p(),t("div",null,[c,s("div",r,[y,i,s("pre",E,[s("code",null,[d,n(` + type: local
    `,24),S=JSON.parse('{"title":"Create a wallet with celestia-node","description":"Use the cel-key utility to generate a wallet on celestia-node.","frontmatter":{"description":"Use the cel-key utility to generate a wallet on celestia-node.","prev":{"text":"New Blobstream X deployments","link":"/how-to-guides/blobstream-x-deploy"},"head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Use the cel-key utility to generate a wallet on celestia-node."}]]},"headers":[],"relativePath":"tutorials/celestia-node-key.md","filePath":"tutorials/celestia-node-key.md","lastUpdated":1732777479000}'),w={name:"tutorials/celestia-node-key.md"},x=Object.assign(w,{setup(A){return(f,D)=>(p(),t("div",null,[c,s("div",r,[y,i,s("pre",E,[s("code",null,[d,n(` `),s("span",F,[s("span",h,"ghcr.io/celestiaorg/celestia-node:"+l(e(o)["node-latest-tag"])+" ",1),g]),n(` `),k])]),s("pre",u,[s("code",null,[C,n(` `),s("span",b,[s("span",v,"ghcr.io/celestiaorg/celestia-node:"+l(e(o)["node-latest-tag"])+" ",1),m]),n(` diff --git a/pr-1815/assets/tutorials_celestia-node-key.md.369cf494.lean.js b/pr-1815/assets/tutorials_celestia-node-key.md.30b8a442.lean.js similarity index 96% rename from pr-1815/assets/tutorials_celestia-node-key.md.369cf494.lean.js rename to pr-1815/assets/tutorials_celestia-node-key.md.30b8a442.lean.js index ff2210f35..fdfd8f745 100644 --- a/pr-1815/assets/tutorials_celestia-node-key.md.369cf494.lean.js +++ b/pr-1815/assets/tutorials_celestia-node-key.md.30b8a442.lean.js @@ -1,4 +1,4 @@ -import{m as o}from"./chunks/mocha_versions.1f7c0f1d.js";import{o as p,c as t,k as s,a as n,t as l,l as e,Q as a}from"./chunks/framework.2959b752.js";const c=a("",37),r={class:"language-bash vp-adaptive-theme"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),i=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},d=a("",1),F={class:"line"},h={style:{color:"#E1E4E8"}},g=a("",7),k=a("",1),u={class:"shiki github-light vp-code-light"},C=a("",1),b={class:"line"},v={style:{color:"#24292E"}},m=a("",7),B=a("",1),_=a("",24),S=JSON.parse('{"title":"Create a wallet with celestia-node","description":"Use the cel-key utility to generate a wallet on celestia-node.","frontmatter":{"description":"Use the cel-key utility to generate a wallet on celestia-node.","prev":{"text":"New Blobstream X deployments","link":"/how-to-guides/blobstream-x-deploy"},"head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Use the cel-key utility to generate a wallet on celestia-node."}]]},"headers":[],"relativePath":"tutorials/celestia-node-key.md","filePath":"tutorials/celestia-node-key.md","lastUpdated":1732776394000}'),w={name:"tutorials/celestia-node-key.md"},x=Object.assign(w,{setup(A){return(f,D)=>(p(),t("div",null,[c,s("div",r,[y,i,s("pre",E,[s("code",null,[d,n(` +import{m as o}from"./chunks/mocha_versions.1f7c0f1d.js";import{o as p,c as t,k as s,a as n,t as l,l as e,Q as a}from"./chunks/framework.2959b752.js";const c=a("",37),r={class:"language-bash vp-adaptive-theme"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),i=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},d=a("",1),F={class:"line"},h={style:{color:"#E1E4E8"}},g=a("",7),k=a("",1),u={class:"shiki github-light vp-code-light"},C=a("",1),b={class:"line"},v={style:{color:"#24292E"}},m=a("",7),B=a("",1),_=a("",24),S=JSON.parse('{"title":"Create a wallet with celestia-node","description":"Use the cel-key utility to generate a wallet on celestia-node.","frontmatter":{"description":"Use the cel-key utility to generate a wallet on celestia-node.","prev":{"text":"New Blobstream X deployments","link":"/how-to-guides/blobstream-x-deploy"},"head":[["meta",{"property":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"}],["meta",{"property":"og:description","content":"Use the cel-key utility to generate a wallet on celestia-node."}]]},"headers":[],"relativePath":"tutorials/celestia-node-key.md","filePath":"tutorials/celestia-node-key.md","lastUpdated":1732777479000}'),w={name:"tutorials/celestia-node-key.md"},x=Object.assign(w,{setup(A){return(f,D)=>(p(),t("div",null,[c,s("div",r,[y,i,s("pre",E,[s("code",null,[d,n(` `),s("span",F,[s("span",h,"ghcr.io/celestiaorg/celestia-node:"+l(e(o)["node-latest-tag"])+" ",1),g]),n(` `),k])]),s("pre",u,[s("code",null,[C,n(` `),s("span",b,[s("span",v,"ghcr.io/celestiaorg/celestia-node:"+l(e(o)["node-latest-tag"])+" ",1),m]),n(` diff --git a/pr-1815/assets/tutorials_golang-client-tutorial.md.7cc06461.js b/pr-1815/assets/tutorials_golang-client-tutorial.md.24f89eb7.js similarity index 99% rename from pr-1815/assets/tutorials_golang-client-tutorial.md.7cc06461.js rename to pr-1815/assets/tutorials_golang-client-tutorial.md.24f89eb7.js index fd5e5c574..21d992cb9 100644 --- a/pr-1815/assets/tutorials_golang-client-tutorial.md.7cc06461.js +++ b/pr-1815/assets/tutorials_golang-client-tutorial.md.24f89eb7.js @@ -1,4 +1,4 @@ -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Golang client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/golang-client-tutorial.md","filePath":"tutorials/golang-client-tutorial.md","lastUpdated":1732776394000}'),p={name:"tutorials/golang-client-tutorial.md"},o=l(`

    Golang client library tutorial

    This tutorial section will guide you through using the most common RPC endpoints with the golang client library.

    Install dependencies and celestia-node if you have not already.

    Project setup

    To start, add celestia-openrpc as a dependency to your project:

    bash
    go get github.com/celestiaorg/celestia-openrpc
    go get github.com/celestiaorg/celestia-openrpc

    To use the following methods, you will need the node URL and your auth token. To get your auth token, see this guide. To run your node without an auth token, you can use the --rpc.skip-auth flag when starting your node. This allows you to pass an empty string as your auth token.

    The default URL is http://localhost:26658. If you would like to use subscription methods, such as SubscribeHeaders below, you must use the ws protocol in place of http: ws://localhost:26658.

    Submitting and retrieving blobs

    The blob.Submit method takes a slice of blobs and a gas price, returning the height the blob was successfully posted at.

    • The namespace can be generated with share.NewBlobNamespaceV0.
    • The blobs can be generated with blob.NewBlobV0.
    • You can use blob.NewSubmitOptions(), which has celestia-node automatically determine an appropriate gas price. To set your own gas price, use blob.NewSubmitOptions().WithGasPrice(X). The available options are WithGasPrice, WithGas, WithKeyName, WithSignerAddress, and WithFeeGranterAddress.

    The blob.GetAll method takes a height and slice of namespaces, returning the slice of blobs found in the given namespaces.

    go
    import (
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Golang client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/golang-client-tutorial.md","filePath":"tutorials/golang-client-tutorial.md","lastUpdated":1732777479000}'),p={name:"tutorials/golang-client-tutorial.md"},o=l(`

    Golang client library tutorial

    This tutorial section will guide you through using the most common RPC endpoints with the golang client library.

    Install dependencies and celestia-node if you have not already.

    Project setup

    To start, add celestia-openrpc as a dependency to your project:

    bash
    go get github.com/celestiaorg/celestia-openrpc
    go get github.com/celestiaorg/celestia-openrpc

    To use the following methods, you will need the node URL and your auth token. To get your auth token, see this guide. To run your node without an auth token, you can use the --rpc.skip-auth flag when starting your node. This allows you to pass an empty string as your auth token.

    The default URL is http://localhost:26658. If you would like to use subscription methods, such as SubscribeHeaders below, you must use the ws protocol in place of http: ws://localhost:26658.

    Submitting and retrieving blobs

    The blob.Submit method takes a slice of blobs and a gas price, returning the height the blob was successfully posted at.

    • The namespace can be generated with share.NewBlobNamespaceV0.
    • The blobs can be generated with blob.NewBlobV0.
    • You can use blob.NewSubmitOptions(), which has celestia-node automatically determine an appropriate gas price. To set your own gas price, use blob.NewSubmitOptions().WithGasPrice(X). The available options are WithGasPrice, WithGas, WithKeyName, WithSignerAddress, and WithFeeGranterAddress.

    The blob.GetAll method takes a height and slice of namespaces, returning the slice of blobs found in the given namespaces.

    go
    import (
     	"bytes"
     	"context"
     	"fmt"
    diff --git a/pr-1815/assets/tutorials_golang-client-tutorial.md.7cc06461.lean.js b/pr-1815/assets/tutorials_golang-client-tutorial.md.24f89eb7.lean.js
    similarity index 90%
    rename from pr-1815/assets/tutorials_golang-client-tutorial.md.7cc06461.lean.js
    rename to pr-1815/assets/tutorials_golang-client-tutorial.md.24f89eb7.lean.js
    index 413cfb0f8..3c41a9755 100644
    --- a/pr-1815/assets/tutorials_golang-client-tutorial.md.7cc06461.lean.js
    +++ b/pr-1815/assets/tutorials_golang-client-tutorial.md.24f89eb7.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Golang client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/golang-client-tutorial.md","filePath":"tutorials/golang-client-tutorial.md","lastUpdated":1732776394000}'),p={name:"tutorials/golang-client-tutorial.md"},o=l("",24),e=[o];function t(r,c,E,y,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{b as __pageData,u as default};
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Golang client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/golang-client-tutorial.md","filePath":"tutorials/golang-client-tutorial.md","lastUpdated":1732777479000}'),p={name:"tutorials/golang-client-tutorial.md"},o=l("",24),e=[o];function t(r,c,E,y,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{b as __pageData,u as default};
    diff --git a/pr-1815/assets/tutorials_integrate-celestia.md.5881eeca.js b/pr-1815/assets/tutorials_integrate-celestia.md.2c9ea427.js
    similarity index 98%
    rename from pr-1815/assets/tutorials_integrate-celestia.md.5881eeca.js
    rename to pr-1815/assets/tutorials_integrate-celestia.md.2c9ea427.js
    index 036121f4b..421fa15e0 100644
    --- a/pr-1815/assets/tutorials_integrate-celestia.md.5881eeca.js
    +++ b/pr-1815/assets/tutorials_integrate-celestia.md.2c9ea427.js
    @@ -1 +1 @@
    -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Integrate Celestia for service providers","description":"Learn how service providers can integrate with the Celestia network.","frontmatter":{"description":"Learn how service providers can integrate with the Celestia network.","prev":{"text":"Integrating Wallets for developers","link":"/tutorials/wallets"},"head":[["meta",{"property":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how service providers can integrate with the Celestia network."}]]},"headers":[],"relativePath":"tutorials/integrate-celestia.md","filePath":"tutorials/integrate-celestia.md","lastUpdated":1732776394000}'),r={name:"tutorials/integrate-celestia.md"},s=i('

    Integrate Celestia for service providers

    This document is for third-party service providers, such as custodians and explorers, integrating the Celestia network.

    Getting started

    When getting started with Celestia, we recommend checking out these resources first:

    Celestia service provider notes

    Celestia is a fairly standard Cosmos-SDK based chain. We use the latest version of Tendermint and the Cosmos-SDK, with only minor modifications to each. This means that we are:

    • Using the default Cosmos-SDK modules: auth, bank, distribution, staking, slashing, mint, crisis, ibchost, genutil, evidence, ibctransfer, params, gov (limited in some TBD capacities), upgrade, vesting, feegrant, capability, and payment.
    • Use the standard digital keys schemes provided by the Cosmos-SDK and Tendermint, those being secp256k1 for user transactions, and tm-ed25519 for signing and verifying consensus messages.

    While exactly which modules used is subject to change, Celestia aims to be as minimal as possible.

    Custody and key management

    Celestia supports many already existing key management systems, as we rely on the Cosmos-SDK and Tendermint libraries for signing and verifying transactions. Learn more in the Cosmos-SDK documentation

    RPC and querying

    In celestia-app, only the standard RPC endpoints for Tendermint and the Cosmos-SDK are exposed. We do not currently add or subtract any core functionality, but this could change in the future. The same goes for querying data from the chain.

    In celestia-node, the Data Availability node client, there is a JSON-RPC API that allows you to interact directly with Celestia's Data Availability layer. Learn how to use the API in this tutorial.

    Compatibility

    Linux, particularly Ubuntu 20.04 LTS, is the most well tested. Potentially compatible with other OSs, but they are currently untested. Some of the cryptography libraries used for erasure data are not guaranteed to work on other platforms.

    Syncing

    Since we utilize Tendermint and the Cosmos-SDK, syncing the chain can be performed by any method that is supported by those libraries. This includes fast-sync, state sync, and quick sync.

    Notable exceptions relative to other blockchains

    Relative to other Tendermint based chains, Celestia will have significantly longer blocktimes of roughly 12* seconds. The reason behind this block time is to optimize the bandwidth used by light clients that are sampling the chain, and is not because we have modified Tendermint consensus in any meaningful way. Validators will likely download/upload relatively large blocks. It should be noted that while these blocks are large, very little typical blockchain state execution is actually occurring on Celestia. Meaning that the bandwidth requirements will likely be larger than that of a typical Cosmos-SDK based blockchain full node, the computing requirements should be similar in magnitude.

    *Subject to Change

    ',21),n=[s];function o(l,c,d,h,u,p){return t(),a("div",null,n)}const y=e(r,[["render",o]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Integrate Celestia for service providers","description":"Learn how service providers can integrate with the Celestia network.","frontmatter":{"description":"Learn how service providers can integrate with the Celestia network.","prev":{"text":"Integrating Wallets for developers","link":"/tutorials/wallets"},"head":[["meta",{"property":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how service providers can integrate with the Celestia network."}]]},"headers":[],"relativePath":"tutorials/integrate-celestia.md","filePath":"tutorials/integrate-celestia.md","lastUpdated":1732777479000}'),r={name:"tutorials/integrate-celestia.md"},s=i('

    Integrate Celestia for service providers

    This document is for third-party service providers, such as custodians and explorers, integrating the Celestia network.

    Getting started

    When getting started with Celestia, we recommend checking out these resources first:

    Celestia service provider notes

    Celestia is a fairly standard Cosmos-SDK based chain. We use the latest version of Tendermint and the Cosmos-SDK, with only minor modifications to each. This means that we are:

    • Using the default Cosmos-SDK modules: auth, bank, distribution, staking, slashing, mint, crisis, ibchost, genutil, evidence, ibctransfer, params, gov (limited in some TBD capacities), upgrade, vesting, feegrant, capability, and payment.
    • Use the standard digital keys schemes provided by the Cosmos-SDK and Tendermint, those being secp256k1 for user transactions, and tm-ed25519 for signing and verifying consensus messages.

    While exactly which modules used is subject to change, Celestia aims to be as minimal as possible.

    Custody and key management

    Celestia supports many already existing key management systems, as we rely on the Cosmos-SDK and Tendermint libraries for signing and verifying transactions. Learn more in the Cosmos-SDK documentation

    RPC and querying

    In celestia-app, only the standard RPC endpoints for Tendermint and the Cosmos-SDK are exposed. We do not currently add or subtract any core functionality, but this could change in the future. The same goes for querying data from the chain.

    In celestia-node, the Data Availability node client, there is a JSON-RPC API that allows you to interact directly with Celestia's Data Availability layer. Learn how to use the API in this tutorial.

    Compatibility

    Linux, particularly Ubuntu 20.04 LTS, is the most well tested. Potentially compatible with other OSs, but they are currently untested. Some of the cryptography libraries used for erasure data are not guaranteed to work on other platforms.

    Syncing

    Since we utilize Tendermint and the Cosmos-SDK, syncing the chain can be performed by any method that is supported by those libraries. This includes fast-sync, state sync, and quick sync.

    Notable exceptions relative to other blockchains

    Relative to other Tendermint based chains, Celestia will have significantly longer blocktimes of roughly 12* seconds. The reason behind this block time is to optimize the bandwidth used by light clients that are sampling the chain, and is not because we have modified Tendermint consensus in any meaningful way. Validators will likely download/upload relatively large blocks. It should be noted that while these blocks are large, very little typical blockchain state execution is actually occurring on Celestia. Meaning that the bandwidth requirements will likely be larger than that of a typical Cosmos-SDK based blockchain full node, the computing requirements should be similar in magnitude.

    *Subject to Change

    ',21),n=[s];function o(l,c,d,h,u,p){return t(),a("div",null,n)}const y=e(r,[["render",o]]);export{g as __pageData,y as default}; diff --git a/pr-1815/assets/tutorials_integrate-celestia.md.5881eeca.lean.js b/pr-1815/assets/tutorials_integrate-celestia.md.2c9ea427.lean.js similarity index 93% rename from pr-1815/assets/tutorials_integrate-celestia.md.5881eeca.lean.js rename to pr-1815/assets/tutorials_integrate-celestia.md.2c9ea427.lean.js index 04ba16e02..2d24af165 100644 --- a/pr-1815/assets/tutorials_integrate-celestia.md.5881eeca.lean.js +++ b/pr-1815/assets/tutorials_integrate-celestia.md.2c9ea427.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Integrate Celestia for service providers","description":"Learn how service providers can integrate with the Celestia network.","frontmatter":{"description":"Learn how service providers can integrate with the Celestia network.","prev":{"text":"Integrating Wallets for developers","link":"/tutorials/wallets"},"head":[["meta",{"property":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how service providers can integrate with the Celestia network."}]]},"headers":[],"relativePath":"tutorials/integrate-celestia.md","filePath":"tutorials/integrate-celestia.md","lastUpdated":1732776394000}'),r={name:"tutorials/integrate-celestia.md"},s=i("",21),n=[s];function o(l,c,d,h,u,p){return t(),a("div",null,n)}const y=e(r,[["render",o]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.2959b752.js";const g=JSON.parse('{"title":"Integrate Celestia for service providers","description":"Learn how service providers can integrate with the Celestia network.","frontmatter":{"description":"Learn how service providers can integrate with the Celestia network.","prev":{"text":"Integrating Wallets for developers","link":"/tutorials/wallets"},"head":[["meta",{"property":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how service providers can integrate with the Celestia network."}]]},"headers":[],"relativePath":"tutorials/integrate-celestia.md","filePath":"tutorials/integrate-celestia.md","lastUpdated":1732777479000}'),r={name:"tutorials/integrate-celestia.md"},s=i("",21),n=[s];function o(l,c,d,h,u,p){return t(),a("div",null,n)}const y=e(r,[["render",o]]);export{g as __pageData,y as default}; diff --git a/pr-1815/assets/tutorials_node-api.md.60c7bf4f.js b/pr-1815/assets/tutorials_node-api.md.42cef958.js similarity index 96% rename from pr-1815/assets/tutorials_node-api.md.60c7bf4f.js rename to pr-1815/assets/tutorials_node-api.md.42cef958.js index bd01be651..3ee258691 100644 --- a/pr-1815/assets/tutorials_node-api.md.60c7bf4f.js +++ b/pr-1815/assets/tutorials_node-api.md.42cef958.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const w=JSON.parse('{"title":"Node API","description":"An overview of the celestia-node API.","frontmatter":{"description":"An overview of the celestia-node API.","head":[["meta",{"property":"og:title","content":"Node API | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the celestia-node API."}]]},"headers":[],"relativePath":"tutorials/node-api.md","filePath":"tutorials/node-api.md","lastUpdated":1732776394000}'),o={name:"tutorials/node-api.md"},i=r('

    Node API

    The celestia-node API is made for interacting with celestia-node. There are two ways in which a user and developer can interact with the API, the RPC API and the Gateway API. View the API's documentation.

    RPC API

    The RPC API primarily focuses on developers and projects building on top of Celestia, who are willing to run their own DA nodes. The RPC API provides a richer set of features and a superior user experience. Unlike the Gateway API, the RPC API allows access to the internal wallet and keyring of the DA node, as well as other sensitive and administrative capabilities.

    Library

    The node can be used as a Golang library and designed for programmatic API access.

    RPC

    The RPC API is also exposed to OpenRPC(JSON-RPC 2.0) for users wanting to run their DA node as a separate DA service. It provides the same set of features as the library with an additional authentication system with different permissions levels to protect the wallet and signing + providing RPC-level DOS protection.

    RPC API tutorial

    The quick start guide is the easiest way to get started.

    The node tutorial, which uses the RPC CLI, is the recommended way to learn more about interacting with your Celestia node.

    Other ways to get started are with the Rust and Golang tutorials.

    Gateway API

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    The gateway API is a REST API which is meant to be deployed by infra providers to enable the public read-only gateway to the DA network for external users who don't want or can't run light nodes (like browsers currently) over HTTP. It has no wallet or signing functionality.

    Gateway API tutorial

    Check out the Prompt scavenger gateway API tutorial for more details.

    ',17),n=[i];function s(l,d,h,c,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{w as __pageData,f as default}; +import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const w=JSON.parse('{"title":"Node API","description":"An overview of the celestia-node API.","frontmatter":{"description":"An overview of the celestia-node API.","head":[["meta",{"property":"og:title","content":"Node API | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the celestia-node API."}]]},"headers":[],"relativePath":"tutorials/node-api.md","filePath":"tutorials/node-api.md","lastUpdated":1732777479000}'),o={name:"tutorials/node-api.md"},i=r('

    Node API

    The celestia-node API is made for interacting with celestia-node. There are two ways in which a user and developer can interact with the API, the RPC API and the Gateway API. View the API's documentation.

    RPC API

    The RPC API primarily focuses on developers and projects building on top of Celestia, who are willing to run their own DA nodes. The RPC API provides a richer set of features and a superior user experience. Unlike the Gateway API, the RPC API allows access to the internal wallet and keyring of the DA node, as well as other sensitive and administrative capabilities.

    Library

    The node can be used as a Golang library and designed for programmatic API access.

    RPC

    The RPC API is also exposed to OpenRPC(JSON-RPC 2.0) for users wanting to run their DA node as a separate DA service. It provides the same set of features as the library with an additional authentication system with different permissions levels to protect the wallet and signing + providing RPC-level DOS protection.

    RPC API tutorial

    The quick start guide is the easiest way to get started.

    The node tutorial, which uses the RPC CLI, is the recommended way to learn more about interacting with your Celestia node.

    Other ways to get started are with the Rust and Golang tutorials.

    Gateway API

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    The gateway API is a REST API which is meant to be deployed by infra providers to enable the public read-only gateway to the DA network for external users who don't want or can't run light nodes (like browsers currently) over HTTP. It has no wallet or signing functionality.

    Gateway API tutorial

    Check out the Prompt scavenger gateway API tutorial for more details.

    ',17),n=[i];function s(l,d,h,c,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{w as __pageData,f as default}; diff --git a/pr-1815/assets/tutorials_node-api.md.60c7bf4f.lean.js b/pr-1815/assets/tutorials_node-api.md.42cef958.lean.js similarity index 81% rename from pr-1815/assets/tutorials_node-api.md.60c7bf4f.lean.js rename to pr-1815/assets/tutorials_node-api.md.42cef958.lean.js index 621d5fdc1..9a7e2222e 100644 --- a/pr-1815/assets/tutorials_node-api.md.60c7bf4f.lean.js +++ b/pr-1815/assets/tutorials_node-api.md.42cef958.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const w=JSON.parse('{"title":"Node API","description":"An overview of the celestia-node API.","frontmatter":{"description":"An overview of the celestia-node API.","head":[["meta",{"property":"og:title","content":"Node API | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the celestia-node API."}]]},"headers":[],"relativePath":"tutorials/node-api.md","filePath":"tutorials/node-api.md","lastUpdated":1732776394000}'),o={name:"tutorials/node-api.md"},i=r("",17),n=[i];function s(l,d,h,c,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{w as __pageData,f as default}; +import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.2959b752.js";const w=JSON.parse('{"title":"Node API","description":"An overview of the celestia-node API.","frontmatter":{"description":"An overview of the celestia-node API.","head":[["meta",{"property":"og:title","content":"Node API | Celestia Docs"}],["meta",{"property":"og:description","content":"An overview of the celestia-node API."}]]},"headers":[],"relativePath":"tutorials/node-api.md","filePath":"tutorials/node-api.md","lastUpdated":1732777479000}'),o={name:"tutorials/node-api.md"},i=r("",17),n=[i];function s(l,d,h,c,p,u){return a(),t("div",null,n)}const f=e(o,[["render",s]]);export{w as __pageData,f as default}; diff --git a/pr-1815/assets/tutorials_node-tutorial.md.577dbc08.js b/pr-1815/assets/tutorials_node-tutorial.md.bebac79b.js similarity index 99% rename from pr-1815/assets/tutorials_node-tutorial.md.577dbc08.js rename to pr-1815/assets/tutorials_node-tutorial.md.bebac79b.js index ff00f26b6..4b0cf38ed 100644 --- a/pr-1815/assets/tutorials_node-tutorial.md.577dbc08.js +++ b/pr-1815/assets/tutorials_node-tutorial.md.bebac79b.js @@ -1,8 +1,8 @@ -import{c as a}from"./chunks/constants.b02263eb.js";import{o as e,c as t,k as s,t as n,l as o,a as p,Q as l}from"./chunks/framework.2959b752.js";const c=l(`

    Celestia-node RPC CLI tutorial

    In this tutorial, we will cover how to use the celestia-node RPC API to submit and retrieve data (blobs) from the data availability layer by their namespace.

    Introduction

    Blobs

    Data is posted to Celestia's DA layer by using MsgPayForBlobs transactions to the core network. Read more about MsgPayForBlobs.

    Namespaces

    Celestia partitions the block data into multiple namespaces, one for every application. This allows applications to only download their data, and not the data of other applications. Read more about Namespaced Merkle trees (NMTs).

    TIP

    If you already have a running and funded node, you can skip to the RPC CLI guide section.

    If you would like to skip syncing, you can use this guide to sync from trusted hash and height.

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 50 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Setting up dependencies

    Install dependencies and celestia-node if you have not already.

    Instantiate a Celestia light node

    Now, let's instantiate a Celestia Light node:

    TIP

    RPC endpoints are exposed in all celestia-node types such as light, bridge and full nodes.

    bash
    celestia light init
    celestia light init
    bash
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    bash
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    Instantiating (or initializing) the node means setting up a node store on your machine. This is where the data and your keys will be stored.

    Connect to a core endpoint

    Let's now run the Celestia Light node with a gRPC connection to an example core endpoint. Connecting to a core endpoint provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Note: You are also encouraged to find an RPC endpoint for Mainnet Beta, Mocha testnet, or Arabica devnet. If you are running a production application, use a production endpoint.

    bash
    celestia light start --core.ip <URI>
    celestia light start --core.ip <URI>
    bash
    celestia light start --core.ip <URI> --p2p.network mocha
    celestia light start --core.ip <URI> --p2p.network mocha
    bash
    celestia light start --core.ip <URI> --p2p.network arabica
    celestia light start --core.ip <URI> --p2p.network arabica

    TIP

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    For example, your command along with an RPC endpoint might look like this:

    bash
    celestia light start --core.ip consensus.lunaroasis.net
    celestia light start --core.ip consensus.lunaroasis.net
    bash
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    bash
    celestia light start --core.ip validator-1.celestia-arabica-11.com \\
    +import{c as a}from"./chunks/constants.b02263eb.js";import{o as e,c as t,k as s,t as n,l as o,a as p,Q as l}from"./chunks/framework.2959b752.js";const c=l(`

    Celestia-node RPC CLI tutorial

    In this tutorial, we will cover how to use the celestia-node RPC API to submit and retrieve data (blobs) from the data availability layer by their namespace.

    Introduction

    Blobs

    Data is posted to Celestia's DA layer by using MsgPayForBlobs transactions to the core network. Read more about MsgPayForBlobs.

    Namespaces

    Celestia partitions the block data into multiple namespaces, one for every application. This allows applications to only download their data, and not the data of other applications. Read more about Namespaced Merkle trees (NMTs).

    TIP

    If you already have a running and funded node, you can skip to the RPC CLI guide section.

    If you would like to skip syncing, you can use this guide to sync from trusted hash and height.

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 50 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Setting up dependencies

    Install dependencies and celestia-node if you have not already.

    Instantiate a Celestia light node

    Now, let's instantiate a Celestia Light node:

    TIP

    RPC endpoints are exposed in all celestia-node types such as light, bridge and full nodes.

    bash
    celestia light init
    celestia light init
    bash
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    bash
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    Instantiating (or initializing) the node means setting up a node store on your machine. This is where the data and your keys will be stored.

    Connect to a core endpoint

    Let's now run the Celestia Light node with a gRPC connection to an example core endpoint. Connecting to a core endpoint provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Note: You are also encouraged to find an RPC endpoint for Mainnet Beta, Mocha testnet, or Arabica devnet. If you are running a production application, use a production endpoint.

    bash
    celestia light start --core.ip <URI>
    celestia light start --core.ip <URI>
    bash
    celestia light start --core.ip <URI> --p2p.network mocha
    celestia light start --core.ip <URI> --p2p.network mocha
    bash
    celestia light start --core.ip <URI> --p2p.network arabica
    celestia light start --core.ip <URI> --p2p.network arabica

    TIP

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    For example, your command along with an RPC endpoint might look like this:

    bash
    celestia light start --core.ip consensus.lunaroasis.net
    celestia light start --core.ip consensus.lunaroasis.net
    bash
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    bash
    celestia light start --core.ip validator-1.celestia-arabica-11.com \\
       --p2p.network arabica
    celestia light start --core.ip validator-1.celestia-arabica-11.com \\
       --p2p.network arabica

    Keys and wallets

    You can create your key for your node by running the following command from the celestia-node directory:

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    bash
    ./cel-key add <key-name> --keyring-backend test --node.type light \\
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type light \\
    -  --p2p.network <network>

    You can start your light node with the key created by running the following command:

    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \\
    +  --p2p.network <network>

    You can start your light node with the key created by running the following command:

    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \\
       --p2p.network mocha
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \\
       --p2p.network mocha
    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \\
       --p2p.network arabica
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \\
    @@ -394,4 +394,4 @@ import{c as a}from"./chunks/constants.b02263eb.js";import{o as e,c as t,k as s,t
         ],
         0.002
       ]
    -}' 127.0.0.1:26658
    1. Upon successful blob submission, the result will show the block height:
    bash
    {"jsonrpc":"2.0","result":362101,"id":1}
    {"jsonrpc":"2.0","result":362101,"id":1}

    The example transaction can be found on Celenium.

    Post an SVG as a PFB

    If you'd like to create your own SVG, post it to Celestia, and retrieve it, you can check out the Base64 SVG Tutorial.

    Troubleshooting

    If you encounter an error like:

    sh
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"

    It is possible that the account you are trying to submit a PayForBlobs from doesn't have testnet tokens yet. Ensure the testnet faucet has funded your account with tokens and then try again.

    `,93),R=JSON.parse('{"title":"Celestia-node RPC CLI tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/node-tutorial.md","filePath":"tutorials/node-tutorial.md","lastUpdated":1732776394000}'),D={name:"tutorials/node-tutorial.md"},U=Object.assign(D,{setup(_){return(x,T)=>(e(),t("div",null,[c,s("p",null,"To set a custom node store for a light node on "+n(o(a).mochaChainId)+", you can use the following command:",1),s("div",r,[y,i,s("pre",E,[s("code",null,[s("span",d,[u,F,h,C,s("span",g,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])]),s("pre",b,[s("code",null,[s("span",q,[B,m,v,k,s("span",A,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])])]),f,s("p",null,[p("Here is an example command to retrieve the data from above, on "),s("code",null,n(o(a).arabicaChainId),1),p(":")]),w]))}});export{R as __pageData,U as default}; +}' 127.0.0.1:26658
    1. Upon successful blob submission, the result will show the block height:
    bash
    {"jsonrpc":"2.0","result":362101,"id":1}
    {"jsonrpc":"2.0","result":362101,"id":1}

    The example transaction can be found on Celenium.

    Post an SVG as a PFB

    If you'd like to create your own SVG, post it to Celestia, and retrieve it, you can check out the Base64 SVG Tutorial.

    Troubleshooting

    If you encounter an error like:

    sh
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"

    It is possible that the account you are trying to submit a PayForBlobs from doesn't have testnet tokens yet. Ensure the testnet faucet has funded your account with tokens and then try again.

    `,93),R=JSON.parse('{"title":"Celestia-node RPC CLI tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/node-tutorial.md","filePath":"tutorials/node-tutorial.md","lastUpdated":1732777479000}'),D={name:"tutorials/node-tutorial.md"},S=Object.assign(D,{setup(_){return(x,T)=>(e(),t("div",null,[c,s("p",null,"To set a custom node store for a light node on "+n(o(a).mochaChainId)+", you can use the following command:",1),s("div",r,[y,i,s("pre",E,[s("code",null,[s("span",d,[u,F,h,C,s("span",g,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])]),s("pre",b,[s("code",null,[s("span",q,[B,m,v,k,s("span",A,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])])]),f,s("p",null,[p("Here is an example command to retrieve the data from above, on "),s("code",null,n(o(a).arabicaChainId),1),p(":")]),w]))}});export{R as __pageData,S as default}; diff --git a/pr-1815/assets/tutorials_node-tutorial.md.577dbc08.lean.js b/pr-1815/assets/tutorials_node-tutorial.md.bebac79b.lean.js similarity index 94% rename from pr-1815/assets/tutorials_node-tutorial.md.577dbc08.lean.js rename to pr-1815/assets/tutorials_node-tutorial.md.bebac79b.lean.js index 15b18f80e..767b9209a 100644 --- a/pr-1815/assets/tutorials_node-tutorial.md.577dbc08.lean.js +++ b/pr-1815/assets/tutorials_node-tutorial.md.bebac79b.lean.js @@ -1 +1 @@ -import{c as a}from"./chunks/constants.b02263eb.js";import{o as e,c as t,k as s,t as n,l as o,a as p,Q as l}from"./chunks/framework.2959b752.js";const c=l("",71),r={class:"language-bash vp-adaptive-theme"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),i=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},d={class:"line"},u=s("span",{style:{color:"#F97583"}},"export",-1),F=s("span",{style:{color:"#E1E4E8"}}," NODE_STORE",-1),h=s("span",{style:{color:"#F97583"}},"=",-1),C=s("span",{style:{color:"#E1E4E8"}},"$HOME",-1),g={style:{color:"#9ECBFF"}},b={class:"shiki github-light vp-code-light"},q={class:"line"},B=s("span",{style:{color:"#D73A49"}},"export",-1),m=s("span",{style:{color:"#24292E"}}," NODE_STORE",-1),v=s("span",{style:{color:"#D73A49"}},"=",-1),k=s("span",{style:{color:"#24292E"}},"$HOME",-1),A={style:{color:"#032F62"}},f=l("",36),w=l("",93),R=JSON.parse('{"title":"Celestia-node RPC CLI tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/node-tutorial.md","filePath":"tutorials/node-tutorial.md","lastUpdated":1732776394000}'),D={name:"tutorials/node-tutorial.md"},U=Object.assign(D,{setup(_){return(x,T)=>(e(),t("div",null,[c,s("p",null,"To set a custom node store for a light node on "+n(o(a).mochaChainId)+", you can use the following command:",1),s("div",r,[y,i,s("pre",E,[s("code",null,[s("span",d,[u,F,h,C,s("span",g,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])]),s("pre",b,[s("code",null,[s("span",q,[B,m,v,k,s("span",A,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])])]),f,s("p",null,[p("Here is an example command to retrieve the data from above, on "),s("code",null,n(o(a).arabicaChainId),1),p(":")]),w]))}});export{R as __pageData,U as default}; +import{c as a}from"./chunks/constants.b02263eb.js";import{o as e,c as t,k as s,t as n,l as o,a as p,Q as l}from"./chunks/framework.2959b752.js";const c=l("",71),r={class:"language-bash vp-adaptive-theme"},y=s("button",{title:"Copy Code",class:"copy"},null,-1),i=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},d={class:"line"},u=s("span",{style:{color:"#F97583"}},"export",-1),F=s("span",{style:{color:"#E1E4E8"}}," NODE_STORE",-1),h=s("span",{style:{color:"#F97583"}},"=",-1),C=s("span",{style:{color:"#E1E4E8"}},"$HOME",-1),g={style:{color:"#9ECBFF"}},b={class:"shiki github-light vp-code-light"},q={class:"line"},B=s("span",{style:{color:"#D73A49"}},"export",-1),m=s("span",{style:{color:"#24292E"}}," NODE_STORE",-1),v=s("span",{style:{color:"#D73A49"}},"=",-1),k=s("span",{style:{color:"#24292E"}},"$HOME",-1),A={style:{color:"#032F62"}},f=l("",36),w=l("",93),R=JSON.parse('{"title":"Celestia-node RPC CLI tutorial","description":"","frontmatter":{"head":[["meta",{"property":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/node-tutorial.md","filePath":"tutorials/node-tutorial.md","lastUpdated":1732777479000}'),D={name:"tutorials/node-tutorial.md"},S=Object.assign(D,{setup(_){return(x,T)=>(e(),t("div",null,[c,s("p",null,"To set a custom node store for a light node on "+n(o(a).mochaChainId)+", you can use the following command:",1),s("div",r,[y,i,s("pre",E,[s("code",null,[s("span",d,[u,F,h,C,s("span",g,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])]),s("pre",b,[s("code",null,[s("span",q,[B,m,v,k,s("span",A,"/your-custom-path/celestia-light-"+n(o(a).mochaChainId),1)])])])]),f,s("p",null,[p("Here is an example command to retrieve the data from above, on "),s("code",null,n(o(a).arabicaChainId),1),p(":")]),w]))}});export{R as __pageData,S as default}; diff --git a/pr-1815/assets/tutorials_prompt-scavenger.md.40cac2ec.js b/pr-1815/assets/tutorials_prompt-scavenger.md.65befca9.js similarity index 99% rename from pr-1815/assets/tutorials_prompt-scavenger.md.40cac2ec.js rename to pr-1815/assets/tutorials_prompt-scavenger.md.65befca9.js index 871c11948..e9c3b40b7 100644 --- a/pr-1815/assets/tutorials_prompt-scavenger.md.40cac2ec.js +++ b/pr-1815/assets/tutorials_prompt-scavenger.md.65befca9.js @@ -1,4 +1,4 @@ -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Prompt scavenger","description":"Learn how to interact with the Celestia Node API with this tutorial.","frontmatter":{"description":"Learn how to interact with the Celestia Node API with this tutorial.","prev":{"text":"Rust client tutorial","link":"/tutorials/rust-client-tutorial"},"head":[["meta",{"property":"og:title","content":"Prompt scavenger | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to interact with the Celestia Node API with this tutorial."}]]},"headers":[],"relativePath":"tutorials/prompt-scavenger.md","filePath":"tutorials/prompt-scavenger.md","lastUpdated":1732776394000}'),p={name:"tutorials/prompt-scavenger.md"},o=l(`

    Prompt scavenger

    Welcome to the world of Prompt Scavenger, a game where you’ll be using Celestia’s Node API and OpenAI’s GPT-3.5 to decode hidden messages scattered throughout Celestia’s blockchain. In this tutorial, we’ll be using Golang to write the code for the game.

    Through this tutorial, you’ll gain experience using Celestia’s Node API to fetch data from the blockchain, process it, and submit new transactions with that data. You’ll also learn how to integrate OpenAI’s GPT-3.5 API to generate fun responses based on the data you’ve found.

    So if you’re ready to embark on an adventure that combines blockchain technology with the power of AI, and learn some Golang along the way, let’s get started!

    Dependencies

    The following dependencies are needed to be installed or obtained:

    Install Celestia Node and run a light node

    First, install the celestia-node binary.

    Let's start by initializing our light node and funding our account with some tokens. We will be using the Arabica testnet for this tutorial.

    sh
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    You will see an output ending with something looking like this:

    2024-05-22T14:15:49.554+0200	INFO	node	nodebuilder/init.go:211	NO KEY FOUND IN STORE, GENERATING NEW KEY...
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Prompt scavenger","description":"Learn how to interact with the Celestia Node API with this tutorial.","frontmatter":{"description":"Learn how to interact with the Celestia Node API with this tutorial.","prev":{"text":"Rust client tutorial","link":"/tutorials/rust-client-tutorial"},"head":[["meta",{"property":"og:title","content":"Prompt scavenger | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to interact with the Celestia Node API with this tutorial."}]]},"headers":[],"relativePath":"tutorials/prompt-scavenger.md","filePath":"tutorials/prompt-scavenger.md","lastUpdated":1732777479000}'),p={name:"tutorials/prompt-scavenger.md"},o=l(`

    Prompt scavenger

    Welcome to the world of Prompt Scavenger, a game where you’ll be using Celestia’s Node API and OpenAI’s GPT-3.5 to decode hidden messages scattered throughout Celestia’s blockchain. In this tutorial, we’ll be using Golang to write the code for the game.

    Through this tutorial, you’ll gain experience using Celestia’s Node API to fetch data from the blockchain, process it, and submit new transactions with that data. You’ll also learn how to integrate OpenAI’s GPT-3.5 API to generate fun responses based on the data you’ve found.

    So if you’re ready to embark on an adventure that combines blockchain technology with the power of AI, and learn some Golang along the way, let’s get started!

    Dependencies

    The following dependencies are needed to be installed or obtained:

    Install Celestia Node and run a light node

    First, install the celestia-node binary.

    Let's start by initializing our light node and funding our account with some tokens. We will be using the Arabica testnet for this tutorial.

    sh
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    You will see an output ending with something looking like this:

    2024-05-22T14:15:49.554+0200	INFO	node	nodebuilder/init.go:211	NO KEY FOUND IN STORE, GENERATING NEW KEY...
     2024-05-22T14:15:49.564+0200	INFO	node	nodebuilder/init.go:216	NEW KEY GENERATED...
     
     NAME: my_celes_key
    diff --git a/pr-1815/assets/tutorials_prompt-scavenger.md.40cac2ec.lean.js b/pr-1815/assets/tutorials_prompt-scavenger.md.65befca9.lean.js
    similarity index 92%
    rename from pr-1815/assets/tutorials_prompt-scavenger.md.40cac2ec.lean.js
    rename to pr-1815/assets/tutorials_prompt-scavenger.md.65befca9.lean.js
    index 5f5b26809..7cb0a9e50 100644
    --- a/pr-1815/assets/tutorials_prompt-scavenger.md.40cac2ec.lean.js
    +++ b/pr-1815/assets/tutorials_prompt-scavenger.md.65befca9.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Prompt scavenger","description":"Learn how to interact with the Celestia Node API with this tutorial.","frontmatter":{"description":"Learn how to interact with the Celestia Node API with this tutorial.","prev":{"text":"Rust client tutorial","link":"/tutorials/rust-client-tutorial"},"head":[["meta",{"property":"og:title","content":"Prompt scavenger | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to interact with the Celestia Node API with this tutorial."}]]},"headers":[],"relativePath":"tutorials/prompt-scavenger.md","filePath":"tutorials/prompt-scavenger.md","lastUpdated":1732776394000}'),p={name:"tutorials/prompt-scavenger.md"},o=l("",64),e=[o];function t(c,r,E,y,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{h as __pageData,u as default};
    +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Prompt scavenger","description":"Learn how to interact with the Celestia Node API with this tutorial.","frontmatter":{"description":"Learn how to interact with the Celestia Node API with this tutorial.","prev":{"text":"Rust client tutorial","link":"/tutorials/rust-client-tutorial"},"head":[["meta",{"property":"og:title","content":"Prompt scavenger | Celestia Docs"}],["meta",{"property":"og:description","content":"Learn how to interact with the Celestia Node API with this tutorial."}]]},"headers":[],"relativePath":"tutorials/prompt-scavenger.md","filePath":"tutorials/prompt-scavenger.md","lastUpdated":1732777479000}'),p={name:"tutorials/prompt-scavenger.md"},o=l("",64),e=[o];function t(c,r,E,y,i,F){return n(),a("div",null,e)}const u=s(p,[["render",t]]);export{h as __pageData,u as default};
    diff --git a/pr-1815/assets/tutorials_rust-client-tutorial.md.17a60e73.js b/pr-1815/assets/tutorials_rust-client-tutorial.md.a22c75a7.js
    similarity index 99%
    rename from pr-1815/assets/tutorials_rust-client-tutorial.md.17a60e73.js
    rename to pr-1815/assets/tutorials_rust-client-tutorial.md.a22c75a7.js
    index b8925669b..e30d6fc0d 100644
    --- a/pr-1815/assets/tutorials_rust-client-tutorial.md.17a60e73.js
    +++ b/pr-1815/assets/tutorials_rust-client-tutorial.md.a22c75a7.js
    @@ -1,4 +1,4 @@
    -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/tutorials/prompt-scavenger"},"head":[["meta",{"property":"og:title","content":"Rust client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/rust-client-tutorial.md","filePath":"tutorials/rust-client-tutorial.md","lastUpdated":1732776394000}'),p={name:"tutorials/rust-client-tutorial.md"},o=l(`

    Rust client library tutorial

    This tutorial section will guide you through using the most common RPC endpoints with Lumina's rust client library.

    Install dependencies and celestia-node if you have not already.

    Project setup

    To start, add celestia_rpc and celestia_types as a dependency to your project:

    bash
    cargo add celestia_rpc celestia_types
    cargo add celestia_rpc celestia_types

    To use the following methods, you will need the node URL and your auth token. To get your auth token, see this guide. To run your node without an auth token, you can use the --rpc.skip-auth flag when starting your node. This allows you to pass an empty string as your auth token.

    The default URL is http://localhost:26658. If you would like to use subscription methods, such as SubscribeHeaders below, you must use the ws protocol in place of http: ws://localhost:26658.

    Submitting and retrieving blobs

    The blob.Submit method takes an array of blobs and a gas price, returning the height the blob was successfully posted at.

    • The namespace can be generated with Namespace::new_v0.
    • The blobs can be generated with Blob::new.
    • You can set GasPrice::default() as the gas price to have celestia-node automatically determine an appropriate gas price.

    The blob.GetAll method takes a height and array of namespaces, returning the array of blobs found in the given namespaces.

    rust
    use celestia_rpc::{BlobClient, Client, HeaderClient, ShareClient};
    +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/tutorials/prompt-scavenger"},"head":[["meta",{"property":"og:title","content":"Rust client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/rust-client-tutorial.md","filePath":"tutorials/rust-client-tutorial.md","lastUpdated":1732777479000}'),p={name:"tutorials/rust-client-tutorial.md"},o=l(`

    Rust client library tutorial

    This tutorial section will guide you through using the most common RPC endpoints with Lumina's rust client library.

    Install dependencies and celestia-node if you have not already.

    Project setup

    To start, add celestia_rpc and celestia_types as a dependency to your project:

    bash
    cargo add celestia_rpc celestia_types
    cargo add celestia_rpc celestia_types

    To use the following methods, you will need the node URL and your auth token. To get your auth token, see this guide. To run your node without an auth token, you can use the --rpc.skip-auth flag when starting your node. This allows you to pass an empty string as your auth token.

    The default URL is http://localhost:26658. If you would like to use subscription methods, such as SubscribeHeaders below, you must use the ws protocol in place of http: ws://localhost:26658.

    Submitting and retrieving blobs

    The blob.Submit method takes an array of blobs and a gas price, returning the height the blob was successfully posted at.

    • The namespace can be generated with Namespace::new_v0.
    • The blobs can be generated with Blob::new.
    • You can set GasPrice::default() as the gas price to have celestia-node automatically determine an appropriate gas price.

    The blob.GetAll method takes a height and array of namespaces, returning the array of blobs found in the given namespaces.

    rust
    use celestia_rpc::{BlobClient, Client, HeaderClient, ShareClient};
     use celestia_types::{nmt::Namespace, Blob, blob::SubmitOptions};
     
     async fn submit_blob(url: &str, token: &str) {
    diff --git a/pr-1815/assets/tutorials_rust-client-tutorial.md.17a60e73.lean.js b/pr-1815/assets/tutorials_rust-client-tutorial.md.a22c75a7.lean.js
    similarity index 91%
    rename from pr-1815/assets/tutorials_rust-client-tutorial.md.17a60e73.lean.js
    rename to pr-1815/assets/tutorials_rust-client-tutorial.md.a22c75a7.lean.js
    index 4bb54ecc5..35ade9daa 100644
    --- a/pr-1815/assets/tutorials_rust-client-tutorial.md.17a60e73.lean.js
    +++ b/pr-1815/assets/tutorials_rust-client-tutorial.md.a22c75a7.lean.js
    @@ -1 +1 @@
    -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/tutorials/prompt-scavenger"},"head":[["meta",{"property":"og:title","content":"Rust client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/rust-client-tutorial.md","filePath":"tutorials/rust-client-tutorial.md","lastUpdated":1732776394000}'),p={name:"tutorials/rust-client-tutorial.md"},o=l("",21),e=[o];function t(c,r,E,y,i,F){return a(),n("div",null,e)}const u=s(p,[["render",t]]);export{h as __pageData,u as default};
    +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.2959b752.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/tutorials/prompt-scavenger"},"head":[["meta",{"property":"og:title","content":"Rust client library tutorial | Celestia Docs"}],["meta",{"property":"og:description","content":"The first modular blockchain network."}]]},"headers":[],"relativePath":"tutorials/rust-client-tutorial.md","filePath":"tutorials/rust-client-tutorial.md","lastUpdated":1732777479000}'),p={name:"tutorials/rust-client-tutorial.md"},o=l("",21),e=[o];function t(c,r,E,y,i,F){return a(),n("div",null,e)}const u=s(p,[["render",t]]);export{h as __pageData,u as default};
    diff --git a/pr-1815/assets/tutorials_wallets.md.a064e878.js b/pr-1815/assets/tutorials_wallets.md.8dad253d.js
    similarity index 92%
    rename from pr-1815/assets/tutorials_wallets.md.a064e878.js
    rename to pr-1815/assets/tutorials_wallets.md.8dad253d.js
    index 708d0ec50..7c4478825 100644
    --- a/pr-1815/assets/tutorials_wallets.md.a064e878.js
    +++ b/pr-1815/assets/tutorials_wallets.md.8dad253d.js
    @@ -1,4 +1,4 @@
    -import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.2959b752.js";const r={data(){return{constants:p}}},hn=JSON.parse('{"title":"Wallet integrations with Celestia","description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","frontmatter":{"description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","head":[["meta",{"property":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation."}]]},"headers":[],"relativePath":"tutorials/wallets.md","filePath":"tutorials/wallets.md","lastUpdated":1732776394000}'),i=o(`

    Wallet integrations with Celestia

    This page covers how developers can use Keplr and React to add Celestia network parameters to wallets, and how to add custom networks to Leap and Cosmostation.

    Add Celestia network parameters to Keplr with React

    Before we demonstrate how to export the specific parameters for Celestia's testnets, we need to create a ReactJS component that allows us to connect directly to Keplr and pass it the network parameters.

    In the following code, we show how you can export a component that detects whether Keplr is installed and sets the network params for it:

    jsx
    // @site/src/components/AddNetworkKeplr.js
    +import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.2959b752.js";const r={data(){return{constants:p}}},hn=JSON.parse('{"title":"Wallet integrations with Celestia","description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","frontmatter":{"description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","head":[["meta",{"property":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation."}]]},"headers":[],"relativePath":"tutorials/wallets.md","filePath":"tutorials/wallets.md","lastUpdated":1732777479000}'),i=o(`

    Wallet integrations with Celestia

    This page covers how developers can use Keplr and React to add Celestia network parameters to wallets, and how to add custom networks to Leap and Cosmostation.

    Add Celestia network parameters to Keplr with React

    Before we demonstrate how to export the specific parameters for Celestia's testnets, we need to create a ReactJS component that allows us to connect directly to Keplr and pass it the network parameters.

    In the following code, we show how you can export a component that detects whether Keplr is installed and sets the network params for it:

    jsx
    // @site/src/components/AddNetworkKeplr.js
     import React from "react";
     import styles from "./Keplr.module.css";
     
    @@ -146,28 +146,28 @@ import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s
           </button>
         </div>
       );
    -}

    We still need to pass the Celestia network parameters to the AddNetworkKeplr function:

    `,7),E={class:"vp-code-group vp-adaptive-theme"},y=o('
    ',1),d={class:"blocks"},_={class:"language-js vp-adaptive-theme active"},h=s("button",{title:"Copy Code",class:"copy"},null,-1),u=s("span",{class:"lang"},"js",-1),F={class:"shiki github-dark vp-code-dark"},A=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),C=s("span",{class:"line"},null,-1),m=o('export const MAINNET_PARAMS = {`{',1),w={class:"line"},T={style:{color:"#9ECBFF"}},q=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Celestia',")],-1),b={class:"line"},g={style:{color:"#9ECBFF"}},k={class:"line"},D={style:{color:"#9ECBFF"}},B=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),I=s("span",{class:"line"},null,-1),P=o('{<AddNetworkKeplr params={MAINNET_PARAMS}/>}',1),S={class:"shiki github-light vp-code-light"},v=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),N=s("span",{class:"line"},null,-1),f=o('export const MAINNET_PARAMS = {`{',1),R={class:"line"},x={style:{color:"#032F62"}},V=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Celestia',")],-1),M={class:"line"},K={style:{color:"#032F62"}},L={class:"line"},U={style:{color:"#032F62"}},j=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),G=s("span",{class:"line"},null,-1),W=o('{<AddNetworkKeplr params={MAINNET_PARAMS}/>}',1),H={class:"language-js vp-adaptive-theme"},O=s("button",{title:"Copy Code",class:"copy"},null,-1),Q=s("span",{class:"lang"},"js",-1),Y={class:"shiki github-dark vp-code-dark"},J=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),Z=s("span",{class:"line"},null,-1),z=o('export const MOCHA_PARAMS = {`{',1),X={class:"line"},$={style:{color:"#9ECBFF"}},ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Mocha testnet',")],-1),ns={class:"line"},as={style:{color:"#9ECBFF"}},ls={class:"line"},os={style:{color:"#9ECBFF"}},ps=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),es=s("span",{class:"line"},null,-1),ts=o('{<AddNetworkKeplr params={MOCHA_PARAMS}/>}',1),cs={class:"shiki github-light vp-code-light"},rs=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),is=s("span",{class:"line"},null,-1),Es=o('export const MOCHA_PARAMS = {`{',1),ys={class:"line"},ds={style:{color:"#032F62"}},_s=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Mocha testnet',")],-1),hs={class:"line"},us={style:{color:"#032F62"}},Fs={class:"line"},As={style:{color:"#032F62"}},Cs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),ms=s("span",{class:"line"},null,-1),ws=o('{<AddNetworkKeplr params={MOCHA_PARAMS}/>}',1),Ts={class:"language-js vp-adaptive-theme"},qs=s("button",{title:"Copy Code",class:"copy"},null,-1),bs=s("span",{class:"lang"},"js",-1),gs={class:"shiki github-dark vp-code-dark"},ks=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),Ds=s("span",{class:"line"},null,-1),Bs=o('export const ARABICA_PARAMS = {`{',1),Is={class:"line"},Ps={style:{color:"#9ECBFF"}},Ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Arabica devnet',")],-1),vs={class:"line"},Ns={style:{color:"#9ECBFF"}},fs={class:"line"},Rs={style:{color:"#9ECBFF"}},xs=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),Vs=s("span",{class:"line"},null,-1),Ms=o('{<AddNetworkKeplr params={ARABICA_PARAMS}/>}',1),Ks={class:"shiki github-light vp-code-light"},Ls=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),Us=s("span",{class:"line"},null,-1),js=o('export const ARABICA_PARAMS = {`{',1),Gs={class:"line"},Ws={style:{color:"#032F62"}},Hs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Os={class:"line"},Qs={style:{color:"#032F62"}},Ys={class:"line"},Js={style:{color:"#032F62"}},Zs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),zs=s("span",{class:"line"},null,-1),Xs=o('{<AddNetworkKeplr params={ARABICA_PARAMS}/>}',1),$s=s("p",null,"Now, we can connect to the network that you would like to use in Keplr wallet.",-1),sn=s("h2",{id:"adding-a-custom-chain-to-leap",tabindex:"-1"},[n("Adding a custom chain to Leap "),s("a",{class:"header-anchor",href:"#adding-a-custom-chain-to-leap","aria-label":'Permalink to "Adding a custom chain to Leap"'},"​")],-1),nn=s("p",null,"If you want to add a custom chain to Leap, you can do so by:",-1),an=s("ol",null,[s("li",null,"Clicking the Cosmos logo in the top corner of Leap wallet"),s("li",null,'Scrolling down and clicking "Add new chain"')],-1),ln=s("p",null,"You can then add the following parameters:",-1),on=o("
  • Chain Name: Arabica devnet
  • New RPC URL: https://rpc.celestia-arabica-11.com/
  • New REST URL: https://api.celestia-arabica-11.com
  • Address Prefix: celestia
  • Native Denom: utia
  • Coin Type: 118
  • Decimals: 6
  • Block explorer URL (optional): https://explorer.celestia-arabica-10.com
  • ",8),pn=o('

    Now, click Add chain and you will be able to view your Arabica account balance and transactions in Leap wallet.

    You'll see that you're connected to Arabica Devnet.

    Adding a custom chain to Cosmostation

    Click the hamburger menu icon in the top corner of Cosmostation wallet. Scroll down and click "Add Custom Chain"

    You can then add the following parameters:

    • Custom Chain name: Mocha testnet
    • Rest URL: https://api-mocha.pops.one
    • New RPC URL: https://rpc-mocha.pops.one
    • Currency symbol: TIA
    • Address prefix: celestia
    • Denom: utia
    • Symbol image URL (optional): https://raw.githubusercontent.com/cosmos/chain-registry/master/testnets/celestiatestnet/images/celestia.svg
    • Explorer URL (optional): https://testnet.mintscan.io/celestia-testnet
    • Coin Type: 118
    • Decimals: 6
    • Gas rate Tiny: 0.1
    • Gas rate Low: 0.25
    • Gas rate Average: 0.5

    Now, click Add a custom chain and you will be able to view your Celestia account balance and transactions in Cosmostation wallet.

    Switch chains to "Mocha testnet" and you'll see that you're connected to Celestia's Mocha testnet!

    ',8);function en(tn,cn,rn,En,a,yn){return t(),c("div",null,[i,s("div",E,[y,s("div",d,[s("div",_,[h,u,s("pre",F,[s("code",null,[A,n(` +}

    We still need to pass the Celestia network parameters to the AddNetworkKeplr function:

    `,7),E={class:"vp-code-group vp-adaptive-theme"},y=o('
    ',1),d={class:"blocks"},_={class:"language-js vp-adaptive-theme active"},h=s("button",{title:"Copy Code",class:"copy"},null,-1),u=s("span",{class:"lang"},"js",-1),F={class:"shiki github-dark vp-code-dark"},A=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),C=s("span",{class:"line"},null,-1),m=o('export const MAINNET_PARAMS = {`{',1),w={class:"line"},T={style:{color:"#9ECBFF"}},b=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Celestia',")],-1),q={class:"line"},g={style:{color:"#9ECBFF"}},D={class:"line"},k={style:{color:"#9ECBFF"}},B=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),I=s("span",{class:"line"},null,-1),P=o('{<AddNetworkKeplr params={MAINNET_PARAMS}/>}',1),S={class:"shiki github-light vp-code-light"},N=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),v=s("span",{class:"line"},null,-1),f=o('export const MAINNET_PARAMS = {`{',1),R={class:"line"},x={style:{color:"#032F62"}},V=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Celestia',")],-1),M={class:"line"},K={style:{color:"#032F62"}},U={class:"line"},L={style:{color:"#032F62"}},G=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),j=s("span",{class:"line"},null,-1),H=o('{<AddNetworkKeplr params={MAINNET_PARAMS}/>}',1),W={class:"language-js vp-adaptive-theme"},J=s("button",{title:"Copy Code",class:"copy"},null,-1),O=s("span",{class:"lang"},"js",-1),Q={class:"shiki github-dark vp-code-dark"},Y=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),z=s("span",{class:"line"},null,-1),X=o('export const MOCHA_PARAMS = {`{',1),Z={class:"line"},$={style:{color:"#9ECBFF"}},ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Mocha testnet',")],-1),ns={class:"line"},as={style:{color:"#9ECBFF"}},ls={class:"line"},os={style:{color:"#9ECBFF"}},ps=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),es=s("span",{class:"line"},null,-1),ts=o('{<AddNetworkKeplr params={MOCHA_PARAMS}/>}',1),cs={class:"shiki github-light vp-code-light"},rs=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),is=s("span",{class:"line"},null,-1),Es=o('export const MOCHA_PARAMS = {`{',1),ys={class:"line"},ds={style:{color:"#032F62"}},_s=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Mocha testnet',")],-1),hs={class:"line"},us={style:{color:"#032F62"}},Fs={class:"line"},As={style:{color:"#032F62"}},Cs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),ms=s("span",{class:"line"},null,-1),ws=o('{<AddNetworkKeplr params={MOCHA_PARAMS}/>}',1),Ts={class:"language-js vp-adaptive-theme"},bs=s("button",{title:"Copy Code",class:"copy"},null,-1),qs=s("span",{class:"lang"},"js",-1),gs={class:"shiki github-dark vp-code-dark"},Ds=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),ks=s("span",{class:"line"},null,-1),Bs=o('export const ARABICA_PARAMS = {`{',1),Is={class:"line"},Ps={style:{color:"#9ECBFF"}},Ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Arabica devnet',")],-1),Ns={class:"line"},vs={style:{color:"#9ECBFF"}},fs={class:"line"},Rs={style:{color:"#9ECBFF"}},xs=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),Vs=s("span",{class:"line"},null,-1),Ms=o('{<AddNetworkKeplr params={ARABICA_PARAMS}/>}',1),Ks={class:"shiki github-light vp-code-light"},Us=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),Ls=s("span",{class:"line"},null,-1),Gs=o('export const ARABICA_PARAMS = {`{',1),js={class:"line"},Hs={style:{color:"#032F62"}},Ws=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Js={class:"line"},Os={style:{color:"#032F62"}},Qs={class:"line"},Ys={style:{color:"#032F62"}},zs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Xs=s("span",{class:"line"},null,-1),Zs=o('{<AddNetworkKeplr params={ARABICA_PARAMS}/>}',1),$s=s("p",null,"Now, we can connect to the network that you would like to use in Keplr wallet.",-1),sn=s("h2",{id:"adding-a-custom-chain-to-leap",tabindex:"-1"},[n("Adding a custom chain to Leap "),s("a",{class:"header-anchor",href:"#adding-a-custom-chain-to-leap","aria-label":'Permalink to "Adding a custom chain to Leap"'},"​")],-1),nn=s("p",null,"If you want to add a custom chain to Leap, you can do so by:",-1),an=s("ol",null,[s("li",null,"Clicking the Cosmos logo in the top corner of Leap wallet"),s("li",null,'Scrolling down and clicking "Add new chain"')],-1),ln=s("p",null,"You can then add the following parameters:",-1),on=o("
  • Chain Name: Arabica devnet
  • New RPC URL: https://rpc.celestia-arabica-11.com/
  • New REST URL: https://api.celestia-arabica-11.com
  • Address Prefix: celestia
  • Native Denom: utia
  • Coin Type: 118
  • Decimals: 6
  • Block explorer URL (optional): https://explorer.celestia-arabica-10.com
  • ",8),pn=o('

    Now, click Add chain and you will be able to view your Arabica account balance and transactions in Leap wallet.

    You'll see that you're connected to Arabica Devnet.

    Adding a custom chain to Cosmostation

    Click the hamburger menu icon in the top corner of Cosmostation wallet. Scroll down and click "Add Custom Chain"

    You can then add the following parameters:

    • Custom Chain name: Mocha testnet
    • Rest URL: https://api-mocha.pops.one
    • New RPC URL: https://rpc-mocha.pops.one
    • Currency symbol: TIA
    • Address prefix: celestia
    • Denom: utia
    • Symbol image URL (optional): https://raw.githubusercontent.com/cosmos/chain-registry/master/testnets/celestiatestnet/images/celestia.svg
    • Explorer URL (optional): https://testnet.mintscan.io/celestia-testnet
    • Coin Type: 118
    • Decimals: 6
    • Gas rate Tiny: 0.1
    • Gas rate Low: 0.25
    • Gas rate Average: 0.5

    Now, click Add a custom chain and you will be able to view your Celestia account balance and transactions in Cosmostation wallet.

    Switch chains to "Mocha testnet" and you'll see that you're connected to Celestia's Mocha testnet!

    ',8);function en(tn,cn,rn,En,a,yn){return t(),c("div",null,[i,s("div",E,[y,s("div",d,[s("div",_,[h,u,s("pre",F,[s("code",null,[A,n(` `),C,n(` `),m,n(` `),s("span",w,[s("span",T," chainId: '"+l(a.constants.mainnetChainId)+"',",1)]),n(` -`),q,n(` -`),s("span",b,[s("span",g," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` -`),s("span",k,[s("span",D," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` +`),b,n(` +`),s("span",q,[s("span",g," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` +`),s("span",D,[s("span",k," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` `),B,n(` `),I,n(` -`),P])]),s("pre",S,[s("code",null,[v,n(` -`),N,n(` +`),P])]),s("pre",S,[s("code",null,[N,n(` +`),v,n(` `),f,n(` `),s("span",R,[s("span",x," chainId: '"+l(a.constants.mainnetChainId)+"',",1)]),n(` `),V,n(` `),s("span",M,[s("span",K," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` -`),s("span",L,[s("span",U," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` -`),j,n(` +`),s("span",U,[s("span",L," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` `),G,n(` -`),W])])]),s("div",H,[O,Q,s("pre",Y,[s("code",null,[J,n(` -`),Z,n(` +`),j,n(` +`),H])])]),s("div",W,[J,O,s("pre",Q,[s("code",null,[Y,n(` `),z,n(` -`),s("span",X,[s("span",$," chainId: '"+l(a.constants.mochaChainId)+"',",1)]),n(` +`),X,n(` +`),s("span",Z,[s("span",$," chainId: '"+l(a.constants.mochaChainId)+"',",1)]),n(` `),ss,n(` `),s("span",ns,[s("span",as," rpc: '"+l(a.constants.mochaRpcUrl)+"',",1)]),n(` `),s("span",ls,[s("span",os," rest: '"+l(a.constants.mochaRestUrl)+"'",1)]),n(` @@ -182,22 +182,22 @@ import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s `),s("span",Fs,[s("span",As," rest: '"+l(a.constants.mochaRestUrl)+"'",1)]),n(` `),Cs,n(` `),ms,n(` -`),ws])])]),s("div",Ts,[qs,bs,s("pre",gs,[s("code",null,[ks,n(` -`),Ds,n(` +`),ws])])]),s("div",Ts,[bs,qs,s("pre",gs,[s("code",null,[Ds,n(` +`),ks,n(` `),Bs,n(` `),s("span",Is,[s("span",Ps," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` `),Ss,n(` -`),s("span",vs,[s("span",Ns," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` +`),s("span",Ns,[s("span",vs," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` `),s("span",fs,[s("span",Rs," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` `),xs,n(` `),Vs,n(` -`),Ms])]),s("pre",Ks,[s("code",null,[Ls,n(` -`),Us,n(` -`),js,n(` -`),s("span",Gs,[s("span",Ws," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` -`),Hs,n(` -`),s("span",Os,[s("span",Qs," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` -`),s("span",Ys,[s("span",Js," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` -`),Zs,n(` +`),Ms])]),s("pre",Ks,[s("code",null,[Us,n(` +`),Ls,n(` +`),Gs,n(` +`),s("span",js,[s("span",Hs," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` +`),Ws,n(` +`),s("span",Js,[s("span",Os," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` +`),s("span",Qs,[s("span",Ys," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` `),zs,n(` -`),Xs])])])])]),$s,sn,nn,an,ln,s("ul",null,[s("li",null,[n("Chain Id: "),s("code",null,l(a.constants.arabicaChainId),1)]),on]),pn])}const un=e(r,[["render",en]]);export{hn as __pageData,un as default}; +`),Xs,n(` +`),Zs])])])])]),$s,sn,nn,an,ln,s("ul",null,[s("li",null,[n("Chain Id: "),s("code",null,l(a.constants.arabicaChainId),1)]),on]),pn])}const un=e(r,[["render",en]]);export{hn as __pageData,un as default}; diff --git a/pr-1815/assets/tutorials_wallets.md.a064e878.lean.js b/pr-1815/assets/tutorials_wallets.md.8dad253d.lean.js similarity index 67% rename from pr-1815/assets/tutorials_wallets.md.a064e878.lean.js rename to pr-1815/assets/tutorials_wallets.md.8dad253d.lean.js index 653b387d9..ca4a2c845 100644 --- a/pr-1815/assets/tutorials_wallets.md.a064e878.lean.js +++ b/pr-1815/assets/tutorials_wallets.md.8dad253d.lean.js @@ -1,25 +1,25 @@ -import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.2959b752.js";const r={data(){return{constants:p}}},hn=JSON.parse('{"title":"Wallet integrations with Celestia","description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","frontmatter":{"description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","head":[["meta",{"property":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation."}]]},"headers":[],"relativePath":"tutorials/wallets.md","filePath":"tutorials/wallets.md","lastUpdated":1732776394000}'),i=o("",7),E={class:"vp-code-group vp-adaptive-theme"},y=o("",1),d={class:"blocks"},_={class:"language-js vp-adaptive-theme active"},h=s("button",{title:"Copy Code",class:"copy"},null,-1),u=s("span",{class:"lang"},"js",-1),F={class:"shiki github-dark vp-code-dark"},A=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),C=s("span",{class:"line"},null,-1),m=o("",1),w={class:"line"},T={style:{color:"#9ECBFF"}},q=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Celestia',")],-1),b={class:"line"},g={style:{color:"#9ECBFF"}},k={class:"line"},D={style:{color:"#9ECBFF"}},B=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),I=s("span",{class:"line"},null,-1),P=o("",1),S={class:"shiki github-light vp-code-light"},v=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),N=s("span",{class:"line"},null,-1),f=o("",1),R={class:"line"},x={style:{color:"#032F62"}},V=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Celestia',")],-1),M={class:"line"},K={style:{color:"#032F62"}},L={class:"line"},U={style:{color:"#032F62"}},j=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),G=s("span",{class:"line"},null,-1),W=o("",1),H={class:"language-js vp-adaptive-theme"},O=s("button",{title:"Copy Code",class:"copy"},null,-1),Q=s("span",{class:"lang"},"js",-1),Y={class:"shiki github-dark vp-code-dark"},J=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),Z=s("span",{class:"line"},null,-1),z=o("",1),X={class:"line"},$={style:{color:"#9ECBFF"}},ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Mocha testnet',")],-1),ns={class:"line"},as={style:{color:"#9ECBFF"}},ls={class:"line"},os={style:{color:"#9ECBFF"}},ps=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),es=s("span",{class:"line"},null,-1),ts=o("",1),cs={class:"shiki github-light vp-code-light"},rs=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),is=s("span",{class:"line"},null,-1),Es=o("",1),ys={class:"line"},ds={style:{color:"#032F62"}},_s=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Mocha testnet',")],-1),hs={class:"line"},us={style:{color:"#032F62"}},Fs={class:"line"},As={style:{color:"#032F62"}},Cs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),ms=s("span",{class:"line"},null,-1),ws=o("",1),Ts={class:"language-js vp-adaptive-theme"},qs=s("button",{title:"Copy Code",class:"copy"},null,-1),bs=s("span",{class:"lang"},"js",-1),gs={class:"shiki github-dark vp-code-dark"},ks=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),Ds=s("span",{class:"line"},null,-1),Bs=o("",1),Is={class:"line"},Ps={style:{color:"#9ECBFF"}},Ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Arabica devnet',")],-1),vs={class:"line"},Ns={style:{color:"#9ECBFF"}},fs={class:"line"},Rs={style:{color:"#9ECBFF"}},xs=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),Vs=s("span",{class:"line"},null,-1),Ms=o("",1),Ks={class:"shiki github-light vp-code-light"},Ls=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),Us=s("span",{class:"line"},null,-1),js=o("",1),Gs={class:"line"},Ws={style:{color:"#032F62"}},Hs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Os={class:"line"},Qs={style:{color:"#032F62"}},Ys={class:"line"},Js={style:{color:"#032F62"}},Zs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),zs=s("span",{class:"line"},null,-1),Xs=o("",1),$s=s("p",null,"Now, we can connect to the network that you would like to use in Keplr wallet.",-1),sn=s("h2",{id:"adding-a-custom-chain-to-leap",tabindex:"-1"},[n("Adding a custom chain to Leap "),s("a",{class:"header-anchor",href:"#adding-a-custom-chain-to-leap","aria-label":'Permalink to "Adding a custom chain to Leap"'},"​")],-1),nn=s("p",null,"If you want to add a custom chain to Leap, you can do so by:",-1),an=s("ol",null,[s("li",null,"Clicking the Cosmos logo in the top corner of Leap wallet"),s("li",null,'Scrolling down and clicking "Add new chain"')],-1),ln=s("p",null,"You can then add the following parameters:",-1),on=o("",8),pn=o("",8);function en(tn,cn,rn,En,a,yn){return t(),c("div",null,[i,s("div",E,[y,s("div",d,[s("div",_,[h,u,s("pre",F,[s("code",null,[A,n(` +import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.2959b752.js";const r={data(){return{constants:p}}},hn=JSON.parse('{"title":"Wallet integrations with Celestia","description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","frontmatter":{"description":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation.","head":[["meta",{"property":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"}],["meta",{"property":"og:description","content":"How you can add Celestia network parameters to wallets such as Keplr, Leap, and Cosmostation."}]]},"headers":[],"relativePath":"tutorials/wallets.md","filePath":"tutorials/wallets.md","lastUpdated":1732777479000}'),i=o("",7),E={class:"vp-code-group vp-adaptive-theme"},y=o("",1),d={class:"blocks"},_={class:"language-js vp-adaptive-theme active"},h=s("button",{title:"Copy Code",class:"copy"},null,-1),u=s("span",{class:"lang"},"js",-1),F={class:"shiki github-dark vp-code-dark"},A=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),C=s("span",{class:"line"},null,-1),m=o("",1),w={class:"line"},T={style:{color:"#9ECBFF"}},b=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Celestia',")],-1),q={class:"line"},g={style:{color:"#9ECBFF"}},D={class:"line"},k={style:{color:"#9ECBFF"}},B=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),I=s("span",{class:"line"},null,-1),P=o("",1),S={class:"shiki github-light vp-code-light"},N=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),v=s("span",{class:"line"},null,-1),f=o("",1),R={class:"line"},x={style:{color:"#032F62"}},V=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Celestia',")],-1),M={class:"line"},K={style:{color:"#032F62"}},U={class:"line"},L={style:{color:"#032F62"}},G=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),j=s("span",{class:"line"},null,-1),H=o("",1),W={class:"language-js vp-adaptive-theme"},J=s("button",{title:"Copy Code",class:"copy"},null,-1),O=s("span",{class:"lang"},"js",-1),Q={class:"shiki github-dark vp-code-dark"},Y=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),z=s("span",{class:"line"},null,-1),X=o("",1),Z={class:"line"},$={style:{color:"#9ECBFF"}},ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Mocha testnet',")],-1),ns={class:"line"},as={style:{color:"#9ECBFF"}},ls={class:"line"},os={style:{color:"#9ECBFF"}},ps=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),es=s("span",{class:"line"},null,-1),ts=o("",1),cs={class:"shiki github-light vp-code-light"},rs=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),is=s("span",{class:"line"},null,-1),Es=o("",1),ys={class:"line"},ds={style:{color:"#032F62"}},_s=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Mocha testnet',")],-1),hs={class:"line"},us={style:{color:"#032F62"}},Fs={class:"line"},As={style:{color:"#032F62"}},Cs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),ms=s("span",{class:"line"},null,-1),ws=o("",1),Ts={class:"language-js vp-adaptive-theme"},bs=s("button",{title:"Copy Code",class:"copy"},null,-1),qs=s("span",{class:"lang"},"js",-1),gs={class:"shiki github-dark vp-code-dark"},Ds=s("span",{class:"line"},[s("span",{style:{color:"#F97583"}},"import"),s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#9ECBFF"}},"'@site/src/components/AddNetworkKeplr'")],-1),ks=s("span",{class:"line"},null,-1),Bs=o("",1),Is={class:"line"},Ps={style:{color:"#9ECBFF"}},Ss=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}}," chainName: 'Arabica devnet',")],-1),Ns={class:"line"},vs={style:{color:"#9ECBFF"}},fs={class:"line"},Rs={style:{color:"#9ECBFF"}},xs=s("span",{class:"line"},[s("span",{style:{color:"#9ECBFF"}},"}`"),s("span",{style:{color:"#E1E4E8"}},"}")],-1),Vs=s("span",{class:"line"},null,-1),Ms=o("",1),Ks={class:"shiki github-light vp-code-light"},Us=s("span",{class:"line"},[s("span",{style:{color:"#D73A49"}},"import"),s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#032F62"}},"'@site/src/components/AddNetworkKeplr'")],-1),Ls=s("span",{class:"line"},null,-1),Gs=o("",1),js={class:"line"},Hs={style:{color:"#032F62"}},Ws=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Js={class:"line"},Os={style:{color:"#032F62"}},Qs={class:"line"},Ys={style:{color:"#032F62"}},zs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Xs=s("span",{class:"line"},null,-1),Zs=o("",1),$s=s("p",null,"Now, we can connect to the network that you would like to use in Keplr wallet.",-1),sn=s("h2",{id:"adding-a-custom-chain-to-leap",tabindex:"-1"},[n("Adding a custom chain to Leap "),s("a",{class:"header-anchor",href:"#adding-a-custom-chain-to-leap","aria-label":'Permalink to "Adding a custom chain to Leap"'},"​")],-1),nn=s("p",null,"If you want to add a custom chain to Leap, you can do so by:",-1),an=s("ol",null,[s("li",null,"Clicking the Cosmos logo in the top corner of Leap wallet"),s("li",null,'Scrolling down and clicking "Add new chain"')],-1),ln=s("p",null,"You can then add the following parameters:",-1),on=o("",8),pn=o("",8);function en(tn,cn,rn,En,a,yn){return t(),c("div",null,[i,s("div",E,[y,s("div",d,[s("div",_,[h,u,s("pre",F,[s("code",null,[A,n(` `),C,n(` `),m,n(` `),s("span",w,[s("span",T," chainId: '"+l(a.constants.mainnetChainId)+"',",1)]),n(` -`),q,n(` -`),s("span",b,[s("span",g," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` -`),s("span",k,[s("span",D," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` +`),b,n(` +`),s("span",q,[s("span",g," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` +`),s("span",D,[s("span",k," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` `),B,n(` `),I,n(` -`),P])]),s("pre",S,[s("code",null,[v,n(` -`),N,n(` +`),P])]),s("pre",S,[s("code",null,[N,n(` +`),v,n(` `),f,n(` `),s("span",R,[s("span",x," chainId: '"+l(a.constants.mainnetChainId)+"',",1)]),n(` `),V,n(` `),s("span",M,[s("span",K," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` -`),s("span",L,[s("span",U," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` -`),j,n(` +`),s("span",U,[s("span",L," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` `),G,n(` -`),W])])]),s("div",H,[O,Q,s("pre",Y,[s("code",null,[J,n(` -`),Z,n(` +`),j,n(` +`),H])])]),s("div",W,[J,O,s("pre",Q,[s("code",null,[Y,n(` `),z,n(` -`),s("span",X,[s("span",$," chainId: '"+l(a.constants.mochaChainId)+"',",1)]),n(` +`),X,n(` +`),s("span",Z,[s("span",$," chainId: '"+l(a.constants.mochaChainId)+"',",1)]),n(` `),ss,n(` `),s("span",ns,[s("span",as," rpc: '"+l(a.constants.mochaRpcUrl)+"',",1)]),n(` `),s("span",ls,[s("span",os," rest: '"+l(a.constants.mochaRestUrl)+"'",1)]),n(` @@ -34,22 +34,22 @@ import{c as p}from"./chunks/constants.b02263eb.js";import{_ as e,o as t,c,k as s `),s("span",Fs,[s("span",As," rest: '"+l(a.constants.mochaRestUrl)+"'",1)]),n(` `),Cs,n(` `),ms,n(` -`),ws])])]),s("div",Ts,[qs,bs,s("pre",gs,[s("code",null,[ks,n(` -`),Ds,n(` +`),ws])])]),s("div",Ts,[bs,qs,s("pre",gs,[s("code",null,[Ds,n(` +`),ks,n(` `),Bs,n(` `),s("span",Is,[s("span",Ps," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` `),Ss,n(` -`),s("span",vs,[s("span",Ns," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` +`),s("span",Ns,[s("span",vs," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` `),s("span",fs,[s("span",Rs," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` `),xs,n(` `),Vs,n(` -`),Ms])]),s("pre",Ks,[s("code",null,[Ls,n(` -`),Us,n(` -`),js,n(` -`),s("span",Gs,[s("span",Ws," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` -`),Hs,n(` -`),s("span",Os,[s("span",Qs," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` -`),s("span",Ys,[s("span",Js," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` -`),Zs,n(` +`),Ms])]),s("pre",Ks,[s("code",null,[Us,n(` +`),Ls,n(` +`),Gs,n(` +`),s("span",js,[s("span",Hs," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` +`),Ws,n(` +`),s("span",Js,[s("span",Os," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` +`),s("span",Qs,[s("span",Ys," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` `),zs,n(` -`),Xs])])])])]),$s,sn,nn,an,ln,s("ul",null,[s("li",null,[n("Chain Id: "),s("code",null,l(a.constants.arabicaChainId),1)]),on]),pn])}const un=e(r,[["render",en]]);export{hn as __pageData,un as default}; +`),Xs,n(` +`),Zs])])])])]),$s,sn,nn,an,ln,s("ul",null,[s("li",null,[n("Chain Id: "),s("code",null,l(a.constants.arabicaChainId),1)]),on]),pn])}const un=e(r,[["render",en]]);export{hn as __pageData,un as default}; diff --git a/pr-1815/community/coc.html b/pr-1815/community/coc.html index 0c9e7a100..1f10cb531 100644 --- a/pr-1815/community/coc.html +++ b/pr-1815/community/coc.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Celestia.org Code of Conduct

    Our Pledge

    We as Celestia.org members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, caste, color, religion, or sexual identity and orientation.

    We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

    Our Standards

    Examples of behavior that contributes to a positive environment for our community include:

    • Demonstrating empathy and kindness toward other people
    • Being respectful of differing opinions, viewpoints, and experiences
    • Giving and gracefully accepting constructive feedback
    • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
    • Focusing on what is best not just for us as individuals, but for the overall community
    • Contributing to conversations about Celestia’s technology and ecosystem

    Examples of unacceptable behavior include:

    • The use of sexualized language or imagery, and sexual attention or advances of any kind
    • Trolling, insulting or derogatory comments, and personal or political attacks
    • Public or private harassment
    • Publishing others' private information, such as a physical or email address, without their explicit permission
    • Focusing on the prices of digital assets or tokens, or where they can be purchased
    • Other conduct which could reasonably be considered inappropriate in a professional setting

    Enforcement Responsibilities

    Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

    Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

    Scope

    This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

    Enforcement

    Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at Celestia.org Discord. All complaints will be reviewed and investigated promptly and fairly.

    All community leaders are obligated to respect the privacy and security of the reporter of any incident.

    Enforcement Guidelines

    Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

    1. Correction

    Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

    Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

    2. Warning

    Community Impact: A violation through a single incident or series of actions.

    Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

    3. Temporary Ban

    Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

    Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

    4. Permanent Ban

    Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

    Consequence: A permanent ban from any sort of public interaction within the community.

    Attribution

    This Code of Conduct is adapted from the Contributor Covenant, version 2.1, available at https://www.contributor-covenant.org/version/2/1/code_of_conduct.html.

    Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

    For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

    - +

    Celestia.org Code of Conduct

    Our Pledge

    We as Celestia.org members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, caste, color, religion, or sexual identity and orientation.

    We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

    Our Standards

    Examples of behavior that contributes to a positive environment for our community include:

    • Demonstrating empathy and kindness toward other people
    • Being respectful of differing opinions, viewpoints, and experiences
    • Giving and gracefully accepting constructive feedback
    • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
    • Focusing on what is best not just for us as individuals, but for the overall community
    • Contributing to conversations about Celestia’s technology and ecosystem

    Examples of unacceptable behavior include:

    • The use of sexualized language or imagery, and sexual attention or advances of any kind
    • Trolling, insulting or derogatory comments, and personal or political attacks
    • Public or private harassment
    • Publishing others' private information, such as a physical or email address, without their explicit permission
    • Focusing on the prices of digital assets or tokens, or where they can be purchased
    • Other conduct which could reasonably be considered inappropriate in a professional setting

    Enforcement Responsibilities

    Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

    Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

    Scope

    This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

    Enforcement

    Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at Celestia.org Discord. All complaints will be reviewed and investigated promptly and fairly.

    All community leaders are obligated to respect the privacy and security of the reporter of any incident.

    Enforcement Guidelines

    Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

    1. Correction

    Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

    Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

    2. Warning

    Community Impact: A violation through a single incident or series of actions.

    Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

    3. Temporary Ban

    Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

    Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

    4. Permanent Ban

    Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

    Consequence: A permanent ban from any sort of public interaction within the community.

    Attribution

    This Code of Conduct is adapted from the Contributor Covenant, version 2.1, available at https://www.contributor-covenant.org/version/2/1/code_of_conduct.html.

    Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

    For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

    + \ No newline at end of file diff --git a/pr-1815/community/foundation-delegation-program.html b/pr-1815/community/foundation-delegation-program.html index 28e515c22..7c7573173 100644 --- a/pr-1815/community/foundation-delegation-program.html +++ b/pr-1815/community/foundation-delegation-program.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    The Celestia Foundation Delegation Program

    Delegation program banner

    Objectives of the program

    The primary objectives of the Celestia Foundation Delegation Program are:

    • To provide a fair opportunity for Celestia’s users to join the validator set, while ensuring the validator set remains proficient, trustworthy, and dependable.
    • To maintain network stability by promoting a steady transition of validators and avoiding sudden and disruptive changes in participation.
    • To enable the Celestia Foundation to use its stake towards its mission of fostering a modular blockchain network that delivers exceptional performance.

    Foundation delegation process

    Program launch

    Prospective validators are welcome to apply to the program starting February 6, 2024. The application is designed to assess a validator’s uptime performance and contributions to the Celestia ecosystem. Of the 100 total slots in Celestia’s active validator set, up to 50 will receive delegations within the program.

    Application submissions will be reviewed by the Celestia Foundation. More details about the application and eligibility criteria are described below.

    Cohort process

    cohort timeline

    Every 4 months, the Celestia Foundation will distribute a portion of the Foundation’s total available stake to a cohort of validators who meet certain criteria, detailed below. Here is an overview of how the cohort process will work for Cohort 1 and what that means for future cohorts.

    Key Points

    • Initial Cohort (Cohort 1): 50 applicants will be accepted
      • Grading System: Applicants in Cohort 1 are divided into first, second, and third place based on eligibility criteria outlined in this document.
      • Delegation Duration: This varies based on the applicant’s placement in Cohort 1. First place receives 12 months of delegation, second place receives 8 months, third place receives 4 months.
    TierPlacementDelegation DurationRenewal By Cohort
    First PlaceApplicants 1-2012 monthsCohort 4
    Second PlaceApplicants 21-358 monthsCohort 3
    Third PlaceApplicants 36-504 monthsCohort 2
    • Subsequent Cohorts (Cohorts 2-onwards):
      • After Cohort 1, open slots may be filled by Cohort 1 members up for renewals or new applicants. There will be no Tiers (e.g. First Place, Second Place, Third Place) in cohorts after Cohort 1. This structure allows for a steady flow of both existing applicants and new applicants to maintain a stable set of participants in the program.

    During this period, so long as the validator maintains high uptime and does not violate the rules of the program, the validator will receive the delegation for the duration of the cohort they are currently in.

    Eligibility criteria

    The minimum requirements for participation in the program are as follows:

    • Run an active Mainnet Beta validator or an active Mocha testnet validator for at least 1 month before application deadline
    • Run a bridge node (on Mainnet Beta if you are already an active Mainnet Beta validator or on Mocha testnet if not) that is connected and reporting to the Celestia Labs OTEL collector (for new applicants - on testnet, so that we can evaluate performance)
    • Not jailed or slashed in the 6 months before application deadline
    • Not associated with an exchange or custodian
    • Not in the top 10 validators by delegation power, unless it enters the top 10 as a result of the Foundation’s delegation under this program
    • Have 10% or less commission
    • Not based within the US, within any country subject to economic sanctions, or within any other prohibited jurisdiction, and successfully complete a compliance screen
    • Dedicated email address so that the Foundation can reach you in the event of emergency upgrades and fixes
    • Maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha if selected for the program
    • Not running your infrastructure in Hetzner or OVH

    Not adhering to any of the criteria above will automatically disqualify your application, and violating any of the criteria after you have received delegation will result in withdrawal of the delegation. A participant who loses stake due to being jailed by the protocol may reapply to the program after 2 cohort periods.

    Applicants are also expected to have reviewed Celestia docs and recommended guides on devops and monitoring setups.

    Other optional but important criteria:

    • Develop and maintain developer tooling, services, applications, and dashboards
    • Work on projects aligned with Celestia's values
    • Contribute to documentation and new guides and tutorials
    • Quality of infrastructure
    • Operated within a location that improves geolocation of the validator set

    Undelegation criteria

    • Getting slashed/tombstoned (cannot apply for 1 year afterwards)
    • Getting jailed more than once during the cohort’s applicable delegation period
    • Violating the Celestia.org Community Code of Conduct or engaging in harmful activities towards the network
    • Failing to upgrade your node in a timely manner (24 hours or less)
    • If necessary to protect or secure Mainnet Beta or to comply with applicable law
    • For any other reason, in the Celestia Foundation’s sole discretion

    Application

    The program will be divided into cohorts with applications open for new applicants and renewal of existing applicants every 4 months. Validators will be delegated for up to a year. For each cohort, the deadline to apply/be evaluated (if you are reapplying) is exactly 1 month prior to the date of being delegated to.

    Application details

    Before applying, be ready to share the following:

    • General info
      • Security Email
      • Validator Entity Name
      • Discord ID
      • Mark if entity or individual
      • Website if any
      • Github page of your organization
      • Team experience and roster (including Twitter + Github links)
      • Which networks you validate on Mainnet Beta + links to your validators
      • A personal statement why you should receive delegation from the Foundation (max 1500 characters)
    • Infrastructure
      • Validator address and bridge node ID on Mainnet Beta
      • If you don't run an active Mainnet Beta validator, please provide us with validator address, bridge node ID and blobstream address on Mocha-4
      • Have you been slashed or jailed in the last 6 months on Celestia or other chains you validated on.
      • Hosting provider and Data Center location (Mainnet Beta and testnet if applicable)
      • Setup of the 2 components (validator and bridge)
        • Hardware
        • Security setup (servers, private keys)
        • Monitoring and alerting
    • Contributions
      • Please list all technical contributions for Celestia and its ecosystem
      • Please list all community contributions for Celestia and its ecosystem

    Please note, the objective of the program is to contribute to Celestia’s resilience and uptime. If you contribute a lot to the Celestia ecosystem, but your validator uptime is low, this will negatively impact your chance at selection for the program. Furthermore, merely receiving delegation from the Foundation under the program does not guarantee your placement in the active validator set.

    Get Started with the Application Form

    Cohort information

    The Foundation will report each cohort’s composition and the duration of their respective delegations.

    • Cohort 1: 50 Validator Seats
    • Cohort 2: 15 Validator Seats (Applications open June 1, 2024)
    • Cohort 3: 15 Validator Seats (Applications open October 1, 2024)
    • Cohort 4: 20 Validator Seats (Applications open February 1, 2025)

    IMPORTANT: Each validator selected for the program has to maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha.

    Feedback process

    Validators in the program will receive a feedback form every quarter, so the program can be continually improved.

    - +

    The Celestia Foundation Delegation Program

    Delegation program banner

    Objectives of the program

    The primary objectives of the Celestia Foundation Delegation Program are:

    • To provide a fair opportunity for Celestia’s users to join the validator set, while ensuring the validator set remains proficient, trustworthy, and dependable.
    • To maintain network stability by promoting a steady transition of validators and avoiding sudden and disruptive changes in participation.
    • To enable the Celestia Foundation to use its stake towards its mission of fostering a modular blockchain network that delivers exceptional performance.

    Foundation delegation process

    Program launch

    Prospective validators are welcome to apply to the program starting February 6, 2024. The application is designed to assess a validator’s uptime performance and contributions to the Celestia ecosystem. Of the 100 total slots in Celestia’s active validator set, up to 50 will receive delegations within the program.

    Application submissions will be reviewed by the Celestia Foundation. More details about the application and eligibility criteria are described below.

    Cohort process

    cohort timeline

    Every 4 months, the Celestia Foundation will distribute a portion of the Foundation’s total available stake to a cohort of validators who meet certain criteria, detailed below. Here is an overview of how the cohort process will work for Cohort 1 and what that means for future cohorts.

    Key Points

    • Initial Cohort (Cohort 1): 50 applicants will be accepted
      • Grading System: Applicants in Cohort 1 are divided into first, second, and third place based on eligibility criteria outlined in this document.
      • Delegation Duration: This varies based on the applicant’s placement in Cohort 1. First place receives 12 months of delegation, second place receives 8 months, third place receives 4 months.
    TierPlacementDelegation DurationRenewal By Cohort
    First PlaceApplicants 1-2012 monthsCohort 4
    Second PlaceApplicants 21-358 monthsCohort 3
    Third PlaceApplicants 36-504 monthsCohort 2
    • Subsequent Cohorts (Cohorts 2-onwards):
      • After Cohort 1, open slots may be filled by Cohort 1 members up for renewals or new applicants. There will be no Tiers (e.g. First Place, Second Place, Third Place) in cohorts after Cohort 1. This structure allows for a steady flow of both existing applicants and new applicants to maintain a stable set of participants in the program.

    During this period, so long as the validator maintains high uptime and does not violate the rules of the program, the validator will receive the delegation for the duration of the cohort they are currently in.

    Eligibility criteria

    The minimum requirements for participation in the program are as follows:

    • Run an active Mainnet Beta validator or an active Mocha testnet validator for at least 1 month before application deadline
    • Run a bridge node (on Mainnet Beta if you are already an active Mainnet Beta validator or on Mocha testnet if not) that is connected and reporting to the Celestia Labs OTEL collector (for new applicants - on testnet, so that we can evaluate performance)
    • Not jailed or slashed in the 6 months before application deadline
    • Not associated with an exchange or custodian
    • Not in the top 10 validators by delegation power, unless it enters the top 10 as a result of the Foundation’s delegation under this program
    • Have 10% or less commission
    • Not based within the US, within any country subject to economic sanctions, or within any other prohibited jurisdiction, and successfully complete a compliance screen
    • Dedicated email address so that the Foundation can reach you in the event of emergency upgrades and fixes
    • Maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha if selected for the program
    • Not running your infrastructure in Hetzner or OVH

    Not adhering to any of the criteria above will automatically disqualify your application, and violating any of the criteria after you have received delegation will result in withdrawal of the delegation. A participant who loses stake due to being jailed by the protocol may reapply to the program after 2 cohort periods.

    Applicants are also expected to have reviewed Celestia docs and recommended guides on devops and monitoring setups.

    Other optional but important criteria:

    • Develop and maintain developer tooling, services, applications, and dashboards
    • Work on projects aligned with Celestia's values
    • Contribute to documentation and new guides and tutorials
    • Quality of infrastructure
    • Operated within a location that improves geolocation of the validator set

    Undelegation criteria

    • Getting slashed/tombstoned (cannot apply for 1 year afterwards)
    • Getting jailed more than once during the cohort’s applicable delegation period
    • Violating the Celestia.org Community Code of Conduct or engaging in harmful activities towards the network
    • Failing to upgrade your node in a timely manner (24 hours or less)
    • If necessary to protect or secure Mainnet Beta or to comply with applicable law
    • For any other reason, in the Celestia Foundation’s sole discretion

    Application

    The program will be divided into cohorts with applications open for new applicants and renewal of existing applicants every 4 months. Validators will be delegated for up to a year. For each cohort, the deadline to apply/be evaluated (if you are reapplying) is exactly 1 month prior to the date of being delegated to.

    Application details

    Before applying, be ready to share the following:

    • General info
      • Security Email
      • Validator Entity Name
      • Discord ID
      • Mark if entity or individual
      • Website if any
      • Github page of your organization
      • Team experience and roster (including Twitter + Github links)
      • Which networks you validate on Mainnet Beta + links to your validators
      • A personal statement why you should receive delegation from the Foundation (max 1500 characters)
    • Infrastructure
      • Validator address and bridge node ID on Mainnet Beta
      • If you don't run an active Mainnet Beta validator, please provide us with validator address, bridge node ID and blobstream address on Mocha-4
      • Have you been slashed or jailed in the last 6 months on Celestia or other chains you validated on.
      • Hosting provider and Data Center location (Mainnet Beta and testnet if applicable)
      • Setup of the 2 components (validator and bridge)
        • Hardware
        • Security setup (servers, private keys)
        • Monitoring and alerting
    • Contributions
      • Please list all technical contributions for Celestia and its ecosystem
      • Please list all community contributions for Celestia and its ecosystem

    Please note, the objective of the program is to contribute to Celestia’s resilience and uptime. If you contribute a lot to the Celestia ecosystem, but your validator uptime is low, this will negatively impact your chance at selection for the program. Furthermore, merely receiving delegation from the Foundation under the program does not guarantee your placement in the active validator set.

    Get Started with the Application Form

    Cohort information

    The Foundation will report each cohort’s composition and the duration of their respective delegations.

    • Cohort 1: 50 Validator Seats
    • Cohort 2: 15 Validator Seats (Applications open June 1, 2024)
    • Cohort 3: 15 Validator Seats (Applications open October 1, 2024)
    • Cohort 4: 20 Validator Seats (Applications open February 1, 2025)

    IMPORTANT: Each validator selected for the program has to maintain a fully archival (non pruned) bridge node for both Mainnet Beta and Mocha.

    Feedback process

    Validators in the program will receive a feedback form every quarter, so the program can be continually improved.

    + \ No newline at end of file diff --git a/pr-1815/community/modular-meetup-guide.html b/pr-1815/community/modular-meetup-guide.html index ed3e3440a..6503b59fb 100644 --- a/pr-1815/community/modular-meetup-guide.html +++ b/pr-1815/community/modular-meetup-guide.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Modular Meetup guide

    These are recommended steps you can follow that can help you organize a successful Modular Meetup. You aren’t required to follow the entire checklist but it is available to help aid you in your journey to organize a Modular Meetup.

    Before the Meetup

    1. Determine the meetup topic and objectives.
    2. Select a suitable date and time for the event.
    3. Secure a convenient and accessible venue that can accommodate the expected number of attendees.
    4. Finalize a schedule or agenda for the event, including speakers, presentations, and activities.
    5. Prepare and send out invitations to potential attendees using various channels (email, social media, community platforms, etc.).
    6. Create and share promotional materials (graphics, blog posts, etc.) to raise awareness about the meetup.
    7. Confirm speakers, including their availability, presentation topics, and technical requirements. If you are working from a Speaker List, please reach out to Nat for any support needed on coordination with speakers.
    8. Arrange any necessary equipment, such as microphones, projectors, and whiteboards.
    9. Plan and arrange refreshments, if applicable.
    10. Prepare and print any required materials, like agendas, name tags, and feedback forms.
    11. Coordinate with volunteers or team members to help manage the event.
    12. Set up a registration system or RSVP process to track attendance.
    13. Send out reminder messages to registered attendees prior to the event.
    14. Conduct a final review of the event logistics, including venue setup, equipment functionality, and volunteer roles.

    During the Meetup

    1. Set up the venue, including arranging seating, preparing equipment, and displaying any promotional materials.
    2. Designate a registration area and ensure that someone is available to greet and check-in attendees.
    3. Welcome the attendees and provide an overview of the event schedule.
    4. Introduce speakers and facilitate any presentations or discussions.
    5. Encourage networking and interaction among attendees during breaks or dedicated activities.
    6. Capture the event with photos or videos for future promotions and documentation.
    7. Collect feedback from attendees using forms, online surveys, or informal conversations if needed.

    After the Meetup

    1. Send follow-up messages to attendees, thanking them for their participation and soliciting additional feedback.
    2. Evaluate the success of the event by reviewing feedback and assessing key performance indicators (e.g., attendance, engagement, etc.).
    3. Analyze and document lessons learned, identifying areas for improvement in future meetups.
    4. Share event highlights, photos, and key takeaways with the community through social media, blog posts, or newsletters.
    5. Connect with speakers, attendees, and volunteers to maintain and strengthen relationships.
    6. Begin planning for the next meetup, applying insights gained from the previous event to enhance the experience for future attendees.

    Logistics and guidance

    These are provided guidelines for different components of kickstarting a Modular Meetup to help you get started on the logistics of organizing a meetup. A lot of those guidelines are thanks to the wonderful write ups in Ethereum Meetup Support Program and Elastic Community Organizer Guides.

    Venue

    Selecting the perfect venue for your Modular Meetup is essential in creating a welcoming atmosphere for the Celestia community.

    1. Startup Incubators
      • Often they would have spaces for meetups.
    2. Libraries
      • Libraries can normally have spaces for meetups at little to no costs
    3. Co-working spaces:
      • Co-working spaces might be able to offer necessary equipment like microphones, projectors, and whiteboards.
    4. Restaurants:
      • Restaurants might have private rooms for larger groups of people that you can book, depending on the restaurant.
    5. Universities and Blockchain Clubs:
      • Partnering with universities and their local university clubs can offer you a lot of spaces for meetups, as well as necessary equipments if needed for giving a talk.
    6. Other options:
      • If you're having difficulty finding a venue, don't hesitate to ask for help within the Celestia community. Your fellow organizers and attendees may have valuable suggestions or connections.

    An ideal venue should offer:

    • Sufficient seating for the audience
    • A projector and screen
    • A microphone (especially for meetups with 10+ attendees)
    • Optional: A whiteboard for speakers or workshops (not always necessary, but a nice addition)

    Consider recording the event, even with a smartphone, to share with the community later. If the speaker uses a microphone, their voice will be more audible in the video. We might be able to post those recordings of the meetup talks on a meetup youtube channel after.

    Remember to negotiate on costs and seek discounts, emphasizing that your meetup benefits the community.

    Collaborate with your venue provider to explore options like borrowing recording equipment, tripods, or even having them record the event for you. Some providers may offer these services for free or at a reduced cost.

    Catering and refreshments

    Providing refreshments or catering for your Modular Meetup enhances the overall experience and encourages networking among attendees.

    1. Determine your budget
      • Identify the amount you can allocate for food and drinks at your event which will help you determine how much you can bring in refreshments. You can also contact the Celestia Devrel team for ideas and support. Costs for refreshments and drinks can vary depending on your location, so be mindful to be flexible on your plans according to your specific location and budget.
    2. Offer a variety of refreshments
      • If you're ordering in, pizza and finger foods work well, but you can also have more budget-friendly options for food.
      • Offering drinks like beer, soda, or lemonade are great, but water also works. Keep in mind that not everyone drinks alcohol so it’s not a requirement. But having at least water and plastic cups works well.
    3. Plan ahead
      • Order refreshments 1 or 2 days in advance and schedule delivery to avoid last-minute stress during the event.

    By following these recommendations, you'll be able to provide enjoyable refreshments for your Celestia Modular Meetup attendees while fostering a friendly and engaging atmosphere.

    Audience

    Understanding your audience and estimating attendance are crucial for organizing successful Modular Meetups for Celestia.

    1. Research the local tech scene:
      • Investigate the types of meetups and events popular in your area. Attend other technology-focused events to get a sense of the audience size and interests. This information will help you tailor your meetup to attract a larger audience.
    2. Assess the availability of speakers:
      • Before organizing a meetup, ensure that you have access to a pool of knowledgeable speakers. If you anticipate difficulty in securing speakers, consider joining forces with an existing meetup group or speaking at other events before launching a new group. This approach will help spread the word about your planned Modular Meetup and gauge interest. Speakers are covered in the following section with a reference to Speaker List offered by the Modular Meetup program.
    3. Establish connections with other user groups:
      • Forge relationships with other tech-focused meetup groups to mutually promote each other's events, potentially increasing attendance.
    4. Set a regular routine for your meetup:
      • Communicate how often you plan to hold meetups, whether it's monthly or quarterly, to help attendees manage their expectations and maintain their interest.
    5. Organize casual meetups:
      • If there's a gap between more formal events, arrange casual meetups at pubs or cafes to keep people engaged and connect with potential speakers for future events.
    6. Estimate the number of attendees:
      • Consider factors such as the size of your city, the popularity of the topic, and the appeal of the event description when estimating attendance.

    Speakers

    Securing engaging and knowledgeable speakers is key to hosting an exceptional Celestia Modular Meetup.

    1. Define your event topic
      • Determine the theme of your event, focusing on areas such as DeFi, Gaming, NFTs, coding workshops, protocol changes, rollups, data availability, or other topics relevant to the Modular ecosystem. This will help you find speakers with expertise in the chosen subject.
    2. Utilize the Speaker List provided by the Modular Meetup program
      • As a meetup organizer, you have access to a curated list of talented speakers from Celestia Labs and the broader Modular ecosystem. This valuable resource can connect you with experts who can share their knowledge with your meetup attendees.
    3. Aim for multiple speakers
      • Ideally, invite 2-3 speakers to your event, allotting 20-40 minutes per talk. Schedule short breaks between presentations to maintain audience engagement.
    4. Organize the speaker lineup
      • Discuss the topics and slides with your speakers before the event to ensure a smooth flow. Arrange the talks in a logical order, saving the most impactful presentation for last.
    5. Invite local speakers
      • For your first meetup, consider presenting an introduction to the Celestia ecosystem or a specific area of interest. Encourage local experts or enthusiasts to speak at future meetups. This approach fosters community involvement and helps build a network of potential speakers.
    6. Seek speaker referrals
      • Ask your current speakers, attendees, or other meetup organizers for referrals. Personal connections often lead to discovering new speakers with valuable insights.
    7. Leverage your meetup discussion board
      • Post a call for speakers on your meetup discussion board to reach out to potential presenters within your community. Be clear about the event theme and requirements to attract relevant speakers.
    8. Offer incentives and appreciation
      • Reward speakers with tokens of gratitude, such as T-shirts, gifts, or public recognition, to show your appreciation for their contribution to the meetup. The Celestia Labs Devrel team can help with swag logistics if needed.

    Sponsors

    Finding sponsors for your meetup can be challenging, but securing financial support is crucial for covering costs related to venue and refreshments.

    1. Leverage Celestia Labs' support
      • Celestia Labs may offer co-sponsorship for your meetup. However, they also encourage organizers to find local co-sponsors to help cover costs and create a more sustainable event.
    2. Offer value to your sponsors:
      • Show potential sponsors how partnering with your event will benefit them. Include their logo on event banners, mention them in the event description, and give them a shoutout at the beginning of the event. If they desire, allow them to place a rollup banner at the venue.
    3. Reach out to your network
      • Ask friends and acquaintances if they know of coworking spaces, schools, universities, or companies interested in sponsorship. A personal connection can significantly increase the chances of securing support.
    4. Approach speakers for sponsorship
      • Request speakers or their affiliated projects to contribute towards the event's expenses, such as catering costs. This can be an effective way to obtain additional funding.
    5. Create a sponsorship deck
      • Develop a compelling sponsorship deck to pitch your event to tech companies in your city or potential online sponsors. This presentation should highlight the benefits of supporting your event and showcase past successful meetups.
    6. Research local companies
      • Investigate businesses in your area that may be interested in sponsoring your event. Tailor your pitch to align with their industry and demonstrate how the meetup can benefit their company.
    7. Engage sponsors during the event
      • Allow sponsors to briefly address the audience, participate in Q&A sessions, or mention their hiring needs. Remember to avoid sales pitches, as they can negatively impact the meetup experience.
    8. Thank your sponsors
      • Express gratitude to your sponsors at the beginning and end of the meetup. Acknowledging their support encourages continued collaboration and enhances the credibility of your event.

    Communications and marketing

    Effectively marketing and announcing your Modular Meetup is essential for attracting attendees and ensuring a successful event.

    1. Plan your announcement
      • Announce your meetup at least two weeks prior. This gives your audience ample time to prepare and increases the likelihood of their attendance.
    2. Utilize Celestia Labs' resources
      • Celestia Labs can help co-promote your meetup on social media and Discord. They can also add your event to their online calendar, email local contacts, and share the event via their Developer Relations Team on Twitter. Don't hesitate to reach out to them for assistance.
    3. Share on social media
      • Promote your event on Twitter and any other popular social media platforms in your area. Tag speakers, sponsors, and use relevant hashtags to increase visibility.
    4. Leverage local community groups
      • Post your event in local Telegram, Discord, or other community groups relevant to your city. These groups often have many members who may be interested in attending your event.
    5. Engage speakers and the venue
      • Maintain communication with speakers and the venue to ensure any changes can be announced in advance. Trust is critical, so avoid canceling planned meetups whenever possible.
    6. Send reminders via meetup.com (optional)
      • After announcing your event, send a warm invite to your meetup group members through meetup.com. Additionally, send a reminder email one day before the event to encourage attendance.
    7. Share with friends and family
      • Invite your friends, family, and acquaintances to the meetup, as they may help spread the word or know someone interested in the event.
    8. Utilize conference groups
      • If you've attended conferences, share your meetup in the associated Telegram or social media groups, as there may be members nearby who would be interested in attending.

    Recording

    Recording and live-streaming your Modular Meetup can greatly benefit those who cannot attend in person and expand the reach of your event.

    1. Plan for recording
      • Consider recording your meetup to create additional learning resources and share the knowledge with a broader audience.
    2. Consider live-streaming
      • Live-streaming your event on platforms like Twitch, YouTube, or Twitter allows remote participants to watch and engage in the meetup. This can also boost your event's reach and create a sense of inclusion for those who couldn't attend in person.
    3. Coordinate with Celestia Labs
      • Celestia Labs can potentially help cover recording costs and promote recorded meetups. Reach out to them at meetups@celestia.org to discuss available options and support. They can also assist with finding local contacts for recording if you don't have one already.
    4. Utilize available resources
      • If you have a small budget, consider allocating some funds for recording and live-streaming your event. Look for local professionals or affordable equipment rentals to ensure high-quality recordings.
    5. Share recordings on Celestia Labs' channels
      • Celestia Labs can help promote recorded meetups by sharing videos in their meetups playlist on YouTube and hosting them on their website. Ensure you coordinate with Celestia Labs to provide them with the recorded video.
    6. Promote recorded content
      • Share the recordings on your social media channels and meetup group after the event. This helps attendees revisit the content and allows those who couldn't attend to learn from the talks.

    Utilizing Meetup.com platform

    Celestia Labs is committed to supporting your meetup efforts by helping you with meetup.com, from setting up the group to covering organizer dues. Below is a detailed overview of how Celestia Labs can assist you.

    1. Meetup.com organizer dues
      • Celestia Labs is happy to cover organizer dues for meetup.com. To get started, send an email to meetups@celestia.org and let them help you with the process.
    2. Co-organizing existing groups
      • If you already have a meetup.com group but need Celestia Labs' assistance with organizing or covering dues, email meetups@celestia.org to add one of their employees as the Organizer.
    3. Setting up groups on Meetup.com
      • Celestia Labs will help you set up your meetup group, including logos, naming, custom URLs, group description, and other essential details. They provide a unique logo for Celestia Modular Meetups, which you can use for your group.
    4. User group naming
      • Celestia Labs recommends naming your group "Celestia Modular Meetup" to encompass various aspects of the Celestia community and create a consistent brand.
    5. Custom URL for the group
      • Meetup.com allows you to create a custom URL for your user group. Celestia Labs encourages consistent URLs across regions, making it easy for people to find your meetup group.
    6. Group description
      • Celestia Labs has a standard group description to ensure consistency across all meetups. However, if you'd like to customize it, let them know.
    7. New member intake questions
      • To improve the quality of your meetups, Celestia Labs suggests a set of intake questions for new members. The answers can help you better understand their needs and interests, allowing you to plan engaging meetups.
    8. Welcome message
      • Celestia Labs provides a welcome message for new members joining your group. If you'd like to customize this message, let them know.

    Onboarding questions for community members joining a Modular Meetup

    1. Q1: How did you hear about this Modular Meetup?
      • Why: This information helps us understand the most effective channels for recruiting new participants to the meetup.
    2. Q2: What do you hope to gain by participating in this meetup? (e.g., networking, learning about Celestia, learning about Modularity, finding a job, etc.)
      • Why: This information helps us cater to the needs of the user group members. If most attendees are looking for networking opportunities, we can schedule casual meetups alongside informative talks.
    3. Q3: Are you currently using or planning to use Celestia, Rollkit, Celestia’s Node API or any of the rollups deployed on Celestia? Tell us all about it. We will use your response to help us better understand what talks would be most beneficial to the group.
      • Why: Responses to this question help us determine the most relevant talks for the group members. If we discover that most participants are interested in a specific area, we can tailor the talks accordingly.
    4. Q4: We love Celestia and the modular ecosystem, but we also appreciate other Web3 technologies. What other topics would you like to hear about? (e.g., Infrastructure, Data Storage, DID, MEV)
      • Why: Knowing our group participants' interests in other technical areas helps us understand what related topics would be useful and valuable to the group, which in turn helps when recruiting speakers.
    5. Q5: Would you be interested in speaking at a future meetup? We welcome 2-minute lightning talks to 1-hour deep dives. Would you be interested in hosting a meetup? If you answer yes to this question, the group organizers will contact you to follow up.
      • Why: One of the challenges in hosting regular meetups is finding speakers. We hope this question will identify people eager to share their stories and expertise with the group, making the lives of organizers easier.
    - +

    Modular Meetup guide

    These are recommended steps you can follow that can help you organize a successful Modular Meetup. You aren’t required to follow the entire checklist but it is available to help aid you in your journey to organize a Modular Meetup.

    Before the Meetup

    1. Determine the meetup topic and objectives.
    2. Select a suitable date and time for the event.
    3. Secure a convenient and accessible venue that can accommodate the expected number of attendees.
    4. Finalize a schedule or agenda for the event, including speakers, presentations, and activities.
    5. Prepare and send out invitations to potential attendees using various channels (email, social media, community platforms, etc.).
    6. Create and share promotional materials (graphics, blog posts, etc.) to raise awareness about the meetup.
    7. Confirm speakers, including their availability, presentation topics, and technical requirements. If you are working from a Speaker List, please reach out to Nat for any support needed on coordination with speakers.
    8. Arrange any necessary equipment, such as microphones, projectors, and whiteboards.
    9. Plan and arrange refreshments, if applicable.
    10. Prepare and print any required materials, like agendas, name tags, and feedback forms.
    11. Coordinate with volunteers or team members to help manage the event.
    12. Set up a registration system or RSVP process to track attendance.
    13. Send out reminder messages to registered attendees prior to the event.
    14. Conduct a final review of the event logistics, including venue setup, equipment functionality, and volunteer roles.

    During the Meetup

    1. Set up the venue, including arranging seating, preparing equipment, and displaying any promotional materials.
    2. Designate a registration area and ensure that someone is available to greet and check-in attendees.
    3. Welcome the attendees and provide an overview of the event schedule.
    4. Introduce speakers and facilitate any presentations or discussions.
    5. Encourage networking and interaction among attendees during breaks or dedicated activities.
    6. Capture the event with photos or videos for future promotions and documentation.
    7. Collect feedback from attendees using forms, online surveys, or informal conversations if needed.

    After the Meetup

    1. Send follow-up messages to attendees, thanking them for their participation and soliciting additional feedback.
    2. Evaluate the success of the event by reviewing feedback and assessing key performance indicators (e.g., attendance, engagement, etc.).
    3. Analyze and document lessons learned, identifying areas for improvement in future meetups.
    4. Share event highlights, photos, and key takeaways with the community through social media, blog posts, or newsletters.
    5. Connect with speakers, attendees, and volunteers to maintain and strengthen relationships.
    6. Begin planning for the next meetup, applying insights gained from the previous event to enhance the experience for future attendees.

    Logistics and guidance

    These are provided guidelines for different components of kickstarting a Modular Meetup to help you get started on the logistics of organizing a meetup. A lot of those guidelines are thanks to the wonderful write ups in Ethereum Meetup Support Program and Elastic Community Organizer Guides.

    Venue

    Selecting the perfect venue for your Modular Meetup is essential in creating a welcoming atmosphere for the Celestia community.

    1. Startup Incubators
      • Often they would have spaces for meetups.
    2. Libraries
      • Libraries can normally have spaces for meetups at little to no costs
    3. Co-working spaces:
      • Co-working spaces might be able to offer necessary equipment like microphones, projectors, and whiteboards.
    4. Restaurants:
      • Restaurants might have private rooms for larger groups of people that you can book, depending on the restaurant.
    5. Universities and Blockchain Clubs:
      • Partnering with universities and their local university clubs can offer you a lot of spaces for meetups, as well as necessary equipments if needed for giving a talk.
    6. Other options:
      • If you're having difficulty finding a venue, don't hesitate to ask for help within the Celestia community. Your fellow organizers and attendees may have valuable suggestions or connections.

    An ideal venue should offer:

    • Sufficient seating for the audience
    • A projector and screen
    • A microphone (especially for meetups with 10+ attendees)
    • Optional: A whiteboard for speakers or workshops (not always necessary, but a nice addition)

    Consider recording the event, even with a smartphone, to share with the community later. If the speaker uses a microphone, their voice will be more audible in the video. We might be able to post those recordings of the meetup talks on a meetup youtube channel after.

    Remember to negotiate on costs and seek discounts, emphasizing that your meetup benefits the community.

    Collaborate with your venue provider to explore options like borrowing recording equipment, tripods, or even having them record the event for you. Some providers may offer these services for free or at a reduced cost.

    Catering and refreshments

    Providing refreshments or catering for your Modular Meetup enhances the overall experience and encourages networking among attendees.

    1. Determine your budget
      • Identify the amount you can allocate for food and drinks at your event which will help you determine how much you can bring in refreshments. You can also contact the Celestia Devrel team for ideas and support. Costs for refreshments and drinks can vary depending on your location, so be mindful to be flexible on your plans according to your specific location and budget.
    2. Offer a variety of refreshments
      • If you're ordering in, pizza and finger foods work well, but you can also have more budget-friendly options for food.
      • Offering drinks like beer, soda, or lemonade are great, but water also works. Keep in mind that not everyone drinks alcohol so it’s not a requirement. But having at least water and plastic cups works well.
    3. Plan ahead
      • Order refreshments 1 or 2 days in advance and schedule delivery to avoid last-minute stress during the event.

    By following these recommendations, you'll be able to provide enjoyable refreshments for your Celestia Modular Meetup attendees while fostering a friendly and engaging atmosphere.

    Audience

    Understanding your audience and estimating attendance are crucial for organizing successful Modular Meetups for Celestia.

    1. Research the local tech scene:
      • Investigate the types of meetups and events popular in your area. Attend other technology-focused events to get a sense of the audience size and interests. This information will help you tailor your meetup to attract a larger audience.
    2. Assess the availability of speakers:
      • Before organizing a meetup, ensure that you have access to a pool of knowledgeable speakers. If you anticipate difficulty in securing speakers, consider joining forces with an existing meetup group or speaking at other events before launching a new group. This approach will help spread the word about your planned Modular Meetup and gauge interest. Speakers are covered in the following section with a reference to Speaker List offered by the Modular Meetup program.
    3. Establish connections with other user groups:
      • Forge relationships with other tech-focused meetup groups to mutually promote each other's events, potentially increasing attendance.
    4. Set a regular routine for your meetup:
      • Communicate how often you plan to hold meetups, whether it's monthly or quarterly, to help attendees manage their expectations and maintain their interest.
    5. Organize casual meetups:
      • If there's a gap between more formal events, arrange casual meetups at pubs or cafes to keep people engaged and connect with potential speakers for future events.
    6. Estimate the number of attendees:
      • Consider factors such as the size of your city, the popularity of the topic, and the appeal of the event description when estimating attendance.

    Speakers

    Securing engaging and knowledgeable speakers is key to hosting an exceptional Celestia Modular Meetup.

    1. Define your event topic
      • Determine the theme of your event, focusing on areas such as DeFi, Gaming, NFTs, coding workshops, protocol changes, rollups, data availability, or other topics relevant to the Modular ecosystem. This will help you find speakers with expertise in the chosen subject.
    2. Utilize the Speaker List provided by the Modular Meetup program
      • As a meetup organizer, you have access to a curated list of talented speakers from Celestia Labs and the broader Modular ecosystem. This valuable resource can connect you with experts who can share their knowledge with your meetup attendees.
    3. Aim for multiple speakers
      • Ideally, invite 2-3 speakers to your event, allotting 20-40 minutes per talk. Schedule short breaks between presentations to maintain audience engagement.
    4. Organize the speaker lineup
      • Discuss the topics and slides with your speakers before the event to ensure a smooth flow. Arrange the talks in a logical order, saving the most impactful presentation for last.
    5. Invite local speakers
      • For your first meetup, consider presenting an introduction to the Celestia ecosystem or a specific area of interest. Encourage local experts or enthusiasts to speak at future meetups. This approach fosters community involvement and helps build a network of potential speakers.
    6. Seek speaker referrals
      • Ask your current speakers, attendees, or other meetup organizers for referrals. Personal connections often lead to discovering new speakers with valuable insights.
    7. Leverage your meetup discussion board
      • Post a call for speakers on your meetup discussion board to reach out to potential presenters within your community. Be clear about the event theme and requirements to attract relevant speakers.
    8. Offer incentives and appreciation
      • Reward speakers with tokens of gratitude, such as T-shirts, gifts, or public recognition, to show your appreciation for their contribution to the meetup. The Celestia Labs Devrel team can help with swag logistics if needed.

    Sponsors

    Finding sponsors for your meetup can be challenging, but securing financial support is crucial for covering costs related to venue and refreshments.

    1. Leverage Celestia Labs' support
      • Celestia Labs may offer co-sponsorship for your meetup. However, they also encourage organizers to find local co-sponsors to help cover costs and create a more sustainable event.
    2. Offer value to your sponsors:
      • Show potential sponsors how partnering with your event will benefit them. Include their logo on event banners, mention them in the event description, and give them a shoutout at the beginning of the event. If they desire, allow them to place a rollup banner at the venue.
    3. Reach out to your network
      • Ask friends and acquaintances if they know of coworking spaces, schools, universities, or companies interested in sponsorship. A personal connection can significantly increase the chances of securing support.
    4. Approach speakers for sponsorship
      • Request speakers or their affiliated projects to contribute towards the event's expenses, such as catering costs. This can be an effective way to obtain additional funding.
    5. Create a sponsorship deck
      • Develop a compelling sponsorship deck to pitch your event to tech companies in your city or potential online sponsors. This presentation should highlight the benefits of supporting your event and showcase past successful meetups.
    6. Research local companies
      • Investigate businesses in your area that may be interested in sponsoring your event. Tailor your pitch to align with their industry and demonstrate how the meetup can benefit their company.
    7. Engage sponsors during the event
      • Allow sponsors to briefly address the audience, participate in Q&A sessions, or mention their hiring needs. Remember to avoid sales pitches, as they can negatively impact the meetup experience.
    8. Thank your sponsors
      • Express gratitude to your sponsors at the beginning and end of the meetup. Acknowledging their support encourages continued collaboration and enhances the credibility of your event.

    Communications and marketing

    Effectively marketing and announcing your Modular Meetup is essential for attracting attendees and ensuring a successful event.

    1. Plan your announcement
      • Announce your meetup at least two weeks prior. This gives your audience ample time to prepare and increases the likelihood of their attendance.
    2. Utilize Celestia Labs' resources
      • Celestia Labs can help co-promote your meetup on social media and Discord. They can also add your event to their online calendar, email local contacts, and share the event via their Developer Relations Team on Twitter. Don't hesitate to reach out to them for assistance.
    3. Share on social media
      • Promote your event on Twitter and any other popular social media platforms in your area. Tag speakers, sponsors, and use relevant hashtags to increase visibility.
    4. Leverage local community groups
      • Post your event in local Telegram, Discord, or other community groups relevant to your city. These groups often have many members who may be interested in attending your event.
    5. Engage speakers and the venue
      • Maintain communication with speakers and the venue to ensure any changes can be announced in advance. Trust is critical, so avoid canceling planned meetups whenever possible.
    6. Send reminders via meetup.com (optional)
      • After announcing your event, send a warm invite to your meetup group members through meetup.com. Additionally, send a reminder email one day before the event to encourage attendance.
    7. Share with friends and family
      • Invite your friends, family, and acquaintances to the meetup, as they may help spread the word or know someone interested in the event.
    8. Utilize conference groups
      • If you've attended conferences, share your meetup in the associated Telegram or social media groups, as there may be members nearby who would be interested in attending.

    Recording

    Recording and live-streaming your Modular Meetup can greatly benefit those who cannot attend in person and expand the reach of your event.

    1. Plan for recording
      • Consider recording your meetup to create additional learning resources and share the knowledge with a broader audience.
    2. Consider live-streaming
      • Live-streaming your event on platforms like Twitch, YouTube, or Twitter allows remote participants to watch and engage in the meetup. This can also boost your event's reach and create a sense of inclusion for those who couldn't attend in person.
    3. Coordinate with Celestia Labs
      • Celestia Labs can potentially help cover recording costs and promote recorded meetups. Reach out to them at meetups@celestia.org to discuss available options and support. They can also assist with finding local contacts for recording if you don't have one already.
    4. Utilize available resources
      • If you have a small budget, consider allocating some funds for recording and live-streaming your event. Look for local professionals or affordable equipment rentals to ensure high-quality recordings.
    5. Share recordings on Celestia Labs' channels
      • Celestia Labs can help promote recorded meetups by sharing videos in their meetups playlist on YouTube and hosting them on their website. Ensure you coordinate with Celestia Labs to provide them with the recorded video.
    6. Promote recorded content
      • Share the recordings on your social media channels and meetup group after the event. This helps attendees revisit the content and allows those who couldn't attend to learn from the talks.

    Utilizing Meetup.com platform

    Celestia Labs is committed to supporting your meetup efforts by helping you with meetup.com, from setting up the group to covering organizer dues. Below is a detailed overview of how Celestia Labs can assist you.

    1. Meetup.com organizer dues
      • Celestia Labs is happy to cover organizer dues for meetup.com. To get started, send an email to meetups@celestia.org and let them help you with the process.
    2. Co-organizing existing groups
      • If you already have a meetup.com group but need Celestia Labs' assistance with organizing or covering dues, email meetups@celestia.org to add one of their employees as the Organizer.
    3. Setting up groups on Meetup.com
      • Celestia Labs will help you set up your meetup group, including logos, naming, custom URLs, group description, and other essential details. They provide a unique logo for Celestia Modular Meetups, which you can use for your group.
    4. User group naming
      • Celestia Labs recommends naming your group "Celestia Modular Meetup" to encompass various aspects of the Celestia community and create a consistent brand.
    5. Custom URL for the group
      • Meetup.com allows you to create a custom URL for your user group. Celestia Labs encourages consistent URLs across regions, making it easy for people to find your meetup group.
    6. Group description
      • Celestia Labs has a standard group description to ensure consistency across all meetups. However, if you'd like to customize it, let them know.
    7. New member intake questions
      • To improve the quality of your meetups, Celestia Labs suggests a set of intake questions for new members. The answers can help you better understand their needs and interests, allowing you to plan engaging meetups.
    8. Welcome message
      • Celestia Labs provides a welcome message for new members joining your group. If you'd like to customize this message, let them know.

    Onboarding questions for community members joining a Modular Meetup

    1. Q1: How did you hear about this Modular Meetup?
      • Why: This information helps us understand the most effective channels for recruiting new participants to the meetup.
    2. Q2: What do you hope to gain by participating in this meetup? (e.g., networking, learning about Celestia, learning about Modularity, finding a job, etc.)
      • Why: This information helps us cater to the needs of the user group members. If most attendees are looking for networking opportunities, we can schedule casual meetups alongside informative talks.
    3. Q3: Are you currently using or planning to use Celestia, Rollkit, Celestia’s Node API or any of the rollups deployed on Celestia? Tell us all about it. We will use your response to help us better understand what talks would be most beneficial to the group.
      • Why: Responses to this question help us determine the most relevant talks for the group members. If we discover that most participants are interested in a specific area, we can tailor the talks accordingly.
    4. Q4: We love Celestia and the modular ecosystem, but we also appreciate other Web3 technologies. What other topics would you like to hear about? (e.g., Infrastructure, Data Storage, DID, MEV)
      • Why: Knowing our group participants' interests in other technical areas helps us understand what related topics would be useful and valuable to the group, which in turn helps when recruiting speakers.
    5. Q5: Would you be interested in speaking at a future meetup? We welcome 2-minute lightning talks to 1-hour deep dives. Would you be interested in hosting a meetup? If you answer yes to this question, the group organizers will contact you to follow up.
      • Why: One of the challenges in hosting regular meetups is finding speakers. We hope this question will identify people eager to share their stories and expertise with the group, making the lives of organizers easier.
    + \ No newline at end of file diff --git a/pr-1815/community/modular-meetup-intro.html b/pr-1815/community/modular-meetup-intro.html index 773e106de..b3c7d63e9 100644 --- a/pr-1815/community/modular-meetup-intro.html +++ b/pr-1815/community/modular-meetup-intro.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Celestia Modular Meetup program

    Modular Meetup Banner

    Welcome to the ultimate guide for Modular Meetup organizers! This collection of resources is designed for those enthusiastic about fostering grassroots Modular Meetups with support from Celestia around the world.

    Program description

    The Celestia Modular Meetup Program aims to empower meetup organizers, providing education and support, and encouraging collaboration within the Web3 ecosystem. This rapidly growing community has already achieved incredible success with the first Modular Meetup in Lisbon, and will grow from there.

    Join fellow enthusiasts, engage in enlightening discussions, and make the most of the insightful resources provided. These resources are designed to serve as a go-to playbook for meetup organizers, especially when starting your journey.

    Important info

    Celestia.org Community Code of Conduct

    The purpose of our Community Code of Conduct is to foster an inclusive, welcoming, and supportive environment for everyone participating in Celestia community events. We're all here to learn from each other, expand our skillsets, and enjoy a positive experience together.

    All meetup attendees, speakers, sponsors, and volunteers, including the event organizing team, are kindly asked to adhere to the following Code of Conduct. Organizers will respectfully enforce this code throughout the event. We genuinely appreciate the cooperation of all participants in maintaining a safe and empowering space for everyone.

    Signup form

    To become part of the program, please complete the registration form.

    Following the review and approval of your submission, you will receive an email confirmation and an invitation to participate in the upcoming Modular Meetup call. Furthermore, you will be granted access to the exclusive Discord channel labeled "#modular-meetup" on our Discord server. Please take note that joining our Discord is a prerequisite for channel access. It's essential to recognize that this program is tailored for dedicated organizers with a genuine interest in nurturing their local modular ecosystem community.

    Emails

    As a participant in the Celestia Modular Meetup Program, you can expect to receive the following emails:

    1. Welcome email with links to calendar events and Discord channel
    2. Monthly Catch-up call invites
    3. Recap emails with notes from calls

    Discord

    Your active participation is key to unlocking the full potential of this vibrant community. Our primary communication tool is Discord, providing an engaging platform to connect with fellow organizers:

    Materials

    As a meetup organizer, you'll gain access to the Celestia Modular Meetup Program's list of resources. This collection should become your trusted companion in organizing events. Drawing upon the wisdom of seasoned event organizers, this resource is available for you and your co-organizers to explore and learn.

    - +

    Celestia Modular Meetup program

    Modular Meetup Banner

    Welcome to the ultimate guide for Modular Meetup organizers! This collection of resources is designed for those enthusiastic about fostering grassroots Modular Meetups with support from Celestia around the world.

    Program description

    The Celestia Modular Meetup Program aims to empower meetup organizers, providing education and support, and encouraging collaboration within the Web3 ecosystem. This rapidly growing community has already achieved incredible success with the first Modular Meetup in Lisbon, and will grow from there.

    Join fellow enthusiasts, engage in enlightening discussions, and make the most of the insightful resources provided. These resources are designed to serve as a go-to playbook for meetup organizers, especially when starting your journey.

    Important info

    Celestia.org Community Code of Conduct

    The purpose of our Community Code of Conduct is to foster an inclusive, welcoming, and supportive environment for everyone participating in Celestia community events. We're all here to learn from each other, expand our skillsets, and enjoy a positive experience together.

    All meetup attendees, speakers, sponsors, and volunteers, including the event organizing team, are kindly asked to adhere to the following Code of Conduct. Organizers will respectfully enforce this code throughout the event. We genuinely appreciate the cooperation of all participants in maintaining a safe and empowering space for everyone.

    Signup form

    To become part of the program, please complete the registration form.

    Following the review and approval of your submission, you will receive an email confirmation and an invitation to participate in the upcoming Modular Meetup call. Furthermore, you will be granted access to the exclusive Discord channel labeled "#modular-meetup" on our Discord server. Please take note that joining our Discord is a prerequisite for channel access. It's essential to recognize that this program is tailored for dedicated organizers with a genuine interest in nurturing their local modular ecosystem community.

    Emails

    As a participant in the Celestia Modular Meetup Program, you can expect to receive the following emails:

    1. Welcome email with links to calendar events and Discord channel
    2. Monthly Catch-up call invites
    3. Recap emails with notes from calls

    Discord

    Your active participation is key to unlocking the full potential of this vibrant community. Our primary communication tool is Discord, providing an engaging platform to connect with fellow organizers:

    Materials

    As a meetup organizer, you'll gain access to the Celestia Modular Meetup Program's list of resources. This collection should become your trusted companion in organizing events. Drawing upon the wisdom of seasoned event organizers, this resource is available for you and your co-organizers to explore and learn.

    + \ No newline at end of file diff --git a/pr-1815/community/modular-meetup-toolkit.html b/pr-1815/community/modular-meetup-toolkit.html index cf54f4404..ce98f3777 100644 --- a/pr-1815/community/modular-meetup-toolkit.html +++ b/pr-1815/community/modular-meetup-toolkit.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Modular Meetup Toolkit

    Welcome to the Modular Meetups Toolkit! This kit is designed to help you run successful meetups for the Celestia community. As the first modular blockchain, Celestia offers a lot to discuss and explore. This kit includes useful resources and materials to help you plan and execute your meetups effectively.

    Celestia branding guidelines

    • Brand kit
      1. Includes logo files, color schemes, typography, icons and illustrations

    Sample “Introduction to Modularity” workshop presentation

    • Sample presentation - introduction to modularity
    • Summary: This is an overview presentation on Modular blockchains and dives deep into Celestia core technologies.
    • The sample presentation covers:
      1. What are modular blockchains?
      2. The benefits of modular over monolithic blockchains
      3. Introduction to Celestia: The first modular blockchain
      4. The concept of Data Availability Sampling
      5. Sovereign Rollups
      6. Q&A session

    Sample “Run a Celestia light node” workshop presentation

    • Sample presentation - run a light node
    • Summary: This is an overview presentation goes over running a Celestia light node. You can find existing video presentations for this here:
    • The sample presentation covers:
      1. What is a Celestia light node?
      2. The role of light nodes in the Celestia ecosystem
      3. Setting up a light node: hardware and software requirements
      4. Step-by-step guide on how to run a Celestia light node
      5. Troubleshooting common issues
      6. Best practices for maintaining a light node
      7. Q&A session

    Sample “Deploy a Sovereign Rollup” workshop presentation

    • Sample presentation - deploy a sovereign rollup
    • Summary: This is an overview presentation on deploying a sovereign rollup with Rollkit on Celestia. You can find existing video presentations for this here:
    • The sample presentation covers:
      1. What is a sovereign rollup?
      2. The role of sovereign rollups in the Celestia ecosystem
      3. Introduction to Rollkit
      4. Setting up a sovereign rollup: hardware and software requirements
      5. Q&A session

    Sample “Modular Meetup Introduction” workshop presentation

    Swag logistics

    With this Modular Meetups Organizer Kit, you’ll have everything you need to plan and execute engaging, informative, and successful meetups for the Celestia community. Happy organizing!

    - +

    Modular Meetup Toolkit

    Welcome to the Modular Meetups Toolkit! This kit is designed to help you run successful meetups for the Celestia community. As the first modular blockchain, Celestia offers a lot to discuss and explore. This kit includes useful resources and materials to help you plan and execute your meetups effectively.

    Celestia branding guidelines

    • Brand kit
      1. Includes logo files, color schemes, typography, icons and illustrations

    Sample “Introduction to Modularity” workshop presentation

    • Sample presentation - introduction to modularity
    • Summary: This is an overview presentation on Modular blockchains and dives deep into Celestia core technologies.
    • The sample presentation covers:
      1. What are modular blockchains?
      2. The benefits of modular over monolithic blockchains
      3. Introduction to Celestia: The first modular blockchain
      4. The concept of Data Availability Sampling
      5. Sovereign Rollups
      6. Q&A session

    Sample “Run a Celestia light node” workshop presentation

    • Sample presentation - run a light node
    • Summary: This is an overview presentation goes over running a Celestia light node. You can find existing video presentations for this here:
    • The sample presentation covers:
      1. What is a Celestia light node?
      2. The role of light nodes in the Celestia ecosystem
      3. Setting up a light node: hardware and software requirements
      4. Step-by-step guide on how to run a Celestia light node
      5. Troubleshooting common issues
      6. Best practices for maintaining a light node
      7. Q&A session

    Sample “Deploy a Sovereign Rollup” workshop presentation

    • Sample presentation - deploy a sovereign rollup
    • Summary: This is an overview presentation on deploying a sovereign rollup with Rollkit on Celestia. You can find existing video presentations for this here:
    • The sample presentation covers:
      1. What is a sovereign rollup?
      2. The role of sovereign rollups in the Celestia ecosystem
      3. Introduction to Rollkit
      4. Setting up a sovereign rollup: hardware and software requirements
      5. Q&A session

    Sample “Modular Meetup Introduction” workshop presentation

    Swag logistics

    With this Modular Meetups Organizer Kit, you’ll have everything you need to plan and execute engaging, informative, and successful meetups for the Celestia community. Happy organizing!

    + \ No newline at end of file diff --git a/pr-1815/community/speaker-list.html b/pr-1815/community/speaker-list.html index 07340121f..74be5b0f4 100644 --- a/pr-1815/community/speaker-list.html +++ b/pr-1815/community/speaker-list.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Speaker list

    As a Modular Meetup organizer, we understand the importance of delivering engaging and informative content to your attendees. That's why we've created an exclusive Speaker List specifically tailored for organizers participating in the Modular Meetup Program. This resource gives you access to a curated selection of top-tier speakers who are passionate about Celestia and the modular ecosystem. Due to privacy, the list is not shared publicly but is accessible to participants of the Modular Meetup program when they create a meetup.

    The Speaker List features experts from Celestia Labs, as well as prominent figures from the broader Celestia and modular communities. Each individual is well-versed in various aspects of the modular ecosystem, ensuring that your meetup attendees gain valuable insights and deepen their understanding of modular blockchains.

    By joining the Modular Meetup Program, you can enjoy the benefits of our Speaker List and bring a touch of expertise to your events. The speakers can participate either in person or virtually, depending on location and timing.

    You can expect benefits from the Speaker List including high-quality presentations, interactive Q&A sessions, and knowledge-sharing opportunities facilitated by the best and brightest in the Celestia ecosystem. With our Speaker List, you'll be able to create memorable and impactful Modular Meetups that foster genuine connections and promote growth within the community.

    - +

    Speaker list

    As a Modular Meetup organizer, we understand the importance of delivering engaging and informative content to your attendees. That's why we've created an exclusive Speaker List specifically tailored for organizers participating in the Modular Meetup Program. This resource gives you access to a curated selection of top-tier speakers who are passionate about Celestia and the modular ecosystem. Due to privacy, the list is not shared publicly but is accessible to participants of the Modular Meetup program when they create a meetup.

    The Speaker List features experts from Celestia Labs, as well as prominent figures from the broader Celestia and modular communities. Each individual is well-versed in various aspects of the modular ecosystem, ensuring that your meetup attendees gain valuable insights and deepen their understanding of modular blockchains.

    By joining the Modular Meetup Program, you can enjoy the benefits of our Speaker List and bring a touch of expertise to your events. The speakers can participate either in person or virtually, depending on location and timing.

    You can expect benefits from the Speaker List including high-quality presentations, interactive Q&A sessions, and knowledge-sharing opportunities facilitated by the best and brightest in the Celestia ecosystem. With our Speaker List, you'll be able to create memorable and impactful Modular Meetups that foster genuine connections and promote growth within the community.

    + \ No newline at end of file diff --git a/pr-1815/hashmap.json b/pr-1815/hashmap.json index f1312458b..78fff7552 100644 --- a/pr-1815/hashmap.json +++ b/pr-1815/hashmap.json @@ -1 +1 @@ -{"how-to-guides_arbitrum-integration.md":"eea707b4","community_modular-meetup-intro.md":"3c6093e3","how-to-guides_arbitrum-bridge.md":"67821b72","readme.md":"cdbe601e","how-to-guides_arabica-devnet.md":"99c9281a","how-to-guides_blobstream-contracts.md":"f87f3793","community_speaker-list.md":"43e3f62d","how-to-guides_arbitrum-full-node.md":"db590a7b","index.md":"301f8cf4","learn_how-celestia-works_data-availability-faq.md":"05200684","learn_how-celestia-works_monolithic-vs-modular.md":"06a2d712","learn_how-celestia-works_overview.md":"91ddd823","community_modular-meetup-toolkit.md":"67ff3975","how-to-guides_celestia-node-troubleshooting.md":"28daa8cd","how-to-guides_systemd.md":"32f00e62","learn_how-celestia-works_data-availability-layer.md":"95575ef0","how-to-guides_config-toml.md":"e0e7af97","how-to-guides_blobstream-offchain.md":"a1784f7d","how-to-guides_decide-node.md":"985bb243","how-to-guides_docker-images.md":"72749f80","how-to-guides_celestia-app-multisig.md":"0242053f","how-to-guides_celestia-app-upgrade-monitor.md":"8386e67a","how-to-guides_celestia-node-trusted-hash.md":"dcfb937e","how-to-guides_celestia-app-wallet.md":"98ae1a8e","how-to-guides_instantiate-testnet.md":"e040791e","how-to-guides_celestia-node-custom-networks.md":"a43d9768","community_coc.md":"24e8f6e5","how-to-guides_celestia-node-metrics.md":"6be6e0bb","how-to-guides_blobstream-x-requesting-data-commitment-ranges.md":"07985aad","how-to-guides_ethereum-fallback.md":"353433f7","how-to-guides_celestia-app-metrics.md":"c57e7d35","how-to-guides_ibc-relayer.md":"f1a48ea7","how-to-guides_full-storage-node.md":"35341887","community_foundation-delegation-program.md":"4ddabdc6","how-to-guides_bridge-node.md":"f12e478d","how-to-guides_blobstream.md":"2b135046","how-to-guides_participate.md":"090651cf","how-to-guides_quick-start.md":"75f45a26","how-to-guides_consensus-node.md":"26d064fd","how-to-guides_multiaccounts.md":"c40b388b","how-to-guides_blobstreamx.md":"139d5ab9","how-to-guides_celestia-app.md":"a9e559b1","how-to-guides_feegrant-for-blobs.md":"b58bc74e","how-to-guides_celestia-app-slashing.md":"d65d1c8a","how-to-guides_light-node.md":"faf1d5ee","tutorials_rust-client-tutorial.md":"17a60e73","tutorials_celestia-node-key.md":"369cf494","how-to-guides_mainnet.md":"1539ba72","how-to-guides_blobstream-proof-queries.md":"4afa5c35","how-to-guides_transaction-resubmission.md":"c43abb47","how-to-guides_celestia-app-commands.md":"e2443b6e","how-to-guides_optimism.md":"50d1f609","how-to-guides_environment.md":"33880087","how-to-guides_mocha-testnet.md":"94189cf4","how-to-guides_validator-node.md":"e6b62962","how-to-guides_arbitrum-deploy.md":"ab7e5910","how-to-guides_blobstream-x-deploy.md":"230cb897","how-to-guides_bubs-testnet.md":"b721ea5a","learn_retrievability.md":"2e5aa538","community_modular-meetup-guide.md":"b2c75b9f","learn_tia.md":"e94f8580","how-to-guides_optimism-devnet.md":"ef6600cc","tutorials_integrate-celestia.md":"5881eeca","learn_staking.md":"7608d6a2","tutorials_golang-client-tutorial.md":"7cc06461","how-to-guides_nodes-overview.md":"e7d3307b","learn_how-to-stake-tia.md":"0f1811ff","how-to-guides_sp1-blobstream-deploy.md":"28f2de08","tutorials_node-api.md":"60c7bf4f","tutorials_wallets.md":"a064e878","how-to-guides_local-testnet.md":"b7413a1e","tutorials_prompt-scavenger.md":"40cac2ec","how-to-guides_submit-data.md":"706c0143","how-to-guides_rollup-stacks.md":"7b355d9c","learn_paying-for-blobspace.md":"c34353bd","learn_how-celestia-works_transaction-lifecycle.md":"c8f48715","how-to-guides_network-upgrade-process.md":"0db1d530","how-to-guides_celestia-node-store-structure.md":"f13dec0a","learn_staking-governance-supply.md":"8e42e486","how-to-guides_intro-to-op-stack.md":"fc0653f2","how-to-guides_blobstream-rollups.md":"dc1ba5fc","how-to-guides_celestia-node.md":"a33fa5a8","how-to-guides_celestia-app-vesting.md":"b7b33049","tutorials_node-tutorial.md":"577dbc08"} +{"readme.md":"4cad7400","community_speaker-list.md":"d01ce1fd","how-to-guides_blobstream-contracts.md":"72c1a84f","how-to-guides_arbitrum-integration.md":"6c060e19","community_foundation-delegation-program.md":"6742c73d","community_modular-meetup-guide.md":"67b2cbce","how-to-guides_celestia-app-multisig.md":"e890db6c","how-to-guides_arbitrum-deploy.md":"f0ee059a","community_modular-meetup-toolkit.md":"ac790481","how-to-guides_arbitrum-bridge.md":"fc2c9c1e","how-to-guides_blobstream-offchain.md":"b3a72b46","how-to-guides_blobstream-x-requesting-data-commitment-ranges.md":"1e42197f","how-to-guides_blobstreamx.md":"1dcae78a","how-to-guides_ethereum-fallback.md":"7b275d7a","how-to-guides_celestia-app-metrics.md":"120ee0a3","how-to-guides_celestia-app-wallet.md":"81ff3a65","how-to-guides_arabica-devnet.md":"a7bda01d","how-to-guides_celestia-app-upgrade-monitor.md":"2dd4f678","community_coc.md":"59c70f94","how-to-guides_celestia-app.md":"e81846ef","how-to-guides_config-toml.md":"c55b64b5","how-to-guides_celestia-node-troubleshooting.md":"3ef61dbb","how-to-guides_celestia-app-slashing.md":"4d08bcea","learn_tia.md":"8cf214a7","how-to-guides_bridge-node.md":"51e7c8f0","how-to-guides_celestia-node-store-structure.md":"63b1cd30","how-to-guides_environment.md":"0bd51cab","how-to-guides_celestia-node-metrics.md":"6a48093e","how-to-guides_celestia-node.md":"e06533d5","how-to-guides_decide-node.md":"29d9cc16","tutorials_prompt-scavenger.md":"65befca9","how-to-guides_celestia-node-custom-networks.md":"3d44971b","how-to-guides_consensus-node.md":"a59f3838","tutorials_integrate-celestia.md":"2c9ea427","tutorials_node-api.md":"42cef958","how-to-guides_celestia-app-vesting.md":"b9f23b75","tutorials_node-tutorial.md":"bebac79b","tutorials_celestia-node-key.md":"30b8a442","how-to-guides_docker-images.md":"23a48650","how-to-guides_blobstream-rollups.md":"5bb93b32","tutorials_wallets.md":"8dad253d","how-to-guides_systemd.md":"def256dc","how-to-guides_arbitrum-full-node.md":"59ec28dd","learn_staking.md":"4211cf86","learn_how-celestia-works_data-availability-layer.md":"4b8bfd66","how-to-guides_celestia-node-trusted-hash.md":"4e90c5a9","learn_retrievability.md":"d172ae26","how-to-guides_light-node.md":"edb7fb97","how-to-guides_validator-node.md":"5e3cb47d","how-to-guides_submit-data.md":"dfcce169","how-to-guides_blobstream.md":"3a35dd4c","index.md":"5f15dd4a","learn_how-celestia-works_data-availability-faq.md":"7e26d360","learn_staking-governance-supply.md":"315bdc22","how-to-guides_participate.md":"7ccb450b","how-to-guides_quick-start.md":"869e21a3","how-to-guides_rollup-stacks.md":"ac8fa6e2","how-to-guides_sp1-blobstream-deploy.md":"d5e590db","how-to-guides_feegrant-for-blobs.md":"716309b7","how-to-guides_instantiate-testnet.md":"6d6bb2c0","how-to-guides_intro-to-op-stack.md":"41b9814c","how-to-guides_local-testnet.md":"d47ac3d0","how-to-guides_transaction-resubmission.md":"075e6fb0","community_modular-meetup-intro.md":"3fda013b","how-to-guides_multiaccounts.md":"54e5cfc9","how-to-guides_celestia-app-commands.md":"cf34f1c2","tutorials_rust-client-tutorial.md":"a22c75a7","how-to-guides_network-upgrade-process.md":"1493429a","how-to-guides_bubs-testnet.md":"7c4ccf62","learn_how-celestia-works_monolithic-vs-modular.md":"ee4811c6","learn_how-celestia-works_overview.md":"ed78821c","learn_paying-for-blobspace.md":"119c2d85","learn_how-to-stake-tia.md":"961588e1","learn_how-celestia-works_transaction-lifecycle.md":"dbc95259","how-to-guides_optimism.md":"b6848def","how-to-guides_mainnet.md":"8c474549","how-to-guides_full-storage-node.md":"12f43165","tutorials_golang-client-tutorial.md":"24f89eb7","how-to-guides_nodes-overview.md":"082b2343","how-to-guides_mocha-testnet.md":"4fde7245","how-to-guides_blobstream-x-deploy.md":"c70d2786","how-to-guides_blobstream-proof-queries.md":"b36c2659","how-to-guides_ibc-relayer.md":"54b5d7e7","how-to-guides_optimism-devnet.md":"ea2a7388"} diff --git a/pr-1815/how-to-guides/arabica-devnet.html b/pr-1815/how-to-guides/arabica-devnet.html index 31da13a57..3d0db04eb 100644 --- a/pr-1815/how-to-guides/arabica-devnet.html +++ b/pr-1815/how-to-guides/arabica-devnet.html @@ -7,14 +7,14 @@ - + - + - + @@ -52,8 +52,8 @@

    Arabica devnet

    arabica-devnet

    Arabica devnet is a testnet from Celestia Labs that is focused exclusively on providing developers with enhanced performance and the latest upgrades for testing their rollups and applications.

    Arabica does not focus on validator or consensus-level testing, rather, that is what Mocha testnet is used for. If you are a validator, we recommend testing your validator operations on the Mocha testnet.

    Network stability and upgrades

    Arabica has the latest updates from all Celestia's products deployed on it, it can be subject to many changes. Therefore, as a fair warning, Arabica can break unexpectedly, but given it will be continuously updated, it is a useful way to keep testing the latest changes in the software.

    Developers can still deploy on Mocha testnet their sovereign rollups if they chose to do so, it just will always lag behind Arabica devnet until Mocha undergoes network upgrades in coordination with validators.

    Network details

    DetailValue
    Chain IDarabica-11
    Genesis hash27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711
    Genesis file https://github.com/celestiaorg/networks/blob/master/arabica-11/genesis.json
    Peers file https://github.com/celestiaorg/networks/blob/master/arabica-11/peers.txt
    Validators 4

    Software version numbers

    SoftwareVersion
    celestia-nodev0.20.4-arabica
    celestia-appv3.0.1-arabica

    Integrations

    This guide contains the relevant sections for how to connect to Arabica devnet, depending on the type of node you are running. Your best approach to participating is to first determine which node you would like to run. Each node’s guide will link to the relevant network in order to show you how to connect to them. Learn about the different endpoint types in the Cosmos SDK documentation.

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    Community RPC endpoints

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    RPC endpoints and types of nodes you can run in order to participate in Arabica devnet:

    Node typeEndpoint typeEndpoint
    Consensus nodes (full)Consensus RPChttps://rpc.celestia-arabica-11.com
    APIhttps://api.celestia-arabica-11.com
    gRPCgrpc.celestia-arabica-11.com:443
    Direct endpoints with open portsOpen ports: 26656 (p2p), 26657 (RPC), 1317 (API), 9090 (GRPC)
    validator-1.celestia-arabica-11.com
    validator-2.celestia-arabica-11.com
    validator-3.celestia-arabica-11.com
    validator-4.celestia-arabica-11.com
    Data availability nodesDA Bridge Node Endpoints/dns4/da-bridge-1.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWGqwzdEqM54Dce6LXzfFr97Bnhvm6rN7KM7MFwdomfm4S
    (light, bridge, full)/dns4/da-bridge-2.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWCMGM5eZWVfCN9ZLAViGfLUWAfXP5pCm78NFKb9jpBtua
    /dns4/da-bridge-3.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWEWuqrjULANpukDFGVoHW3RoeUU53Ec9t9v5cwW3MkVdQ
    /dns4/da-bridge-4.celestia-arabica-11.com/tcp/2121/p2p/12D3KooWLT1ysSrD7XWSBjh7tU1HQanF5M64dHV6AuM6cYEJxMPk
    --core.ip string endpointsRefer to "Direct endpoints with open ports" above

    You can find the status of these endpoints.

    Using consensus endpoints with DA nodes

    Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    EXAMPLE

    bash
    celestia <da_type> start –core.ip <url> -–core.grpc.port <port>
    celestia <da_type> start –core.ip <url> -–core.grpc.port <port>

    RPCs for DA nodes to initialise or start your celestia-node to Arabica devnet with can be found in the table in the "Direct endpoints with open ports" section above.

    As an example, this command will work to start a light node with state access, using default ports:

    bash
    celestia light start --p2p.network arabica \
       --core.ip validator-1.celestia-arabica-11.com
    celestia light start --p2p.network arabica \
    -  --core.ip validator-1.celestia-arabica-11.com

    Bridge node runners

    Not all of the RPC endpoints do not guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

    Arabica devnet faucet

    WARNING

    USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

    Discord

    You can request from Arabica devnet Faucet on the #arabica-faucet channel on Celestia's Discord server with the following command:

    text
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

    NOTE

    Faucet has a limit of 10 tokens per week per address/Discord ID.

    Web

    The web faucet is available at https://faucet.celestia-arabica-11.com/.

    Explorers

    There are multiple explorers you can use for Arabica:

    Network upgrades

    Join our Telegram announcement channel for network upgrades.

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    - + --core.ip validator-1.celestia-arabica-11.com

    Bridge node runners

    Not all of the RPC endpoints do not guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

    Arabica devnet faucet

    WARNING

    USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

    Discord

    You can request from Arabica devnet Faucet on the #arabica-faucet channel on Celestia's Discord server with the following command:

    text
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

    NOTE

    Faucet has a limit of 10 tokens per week per address/Discord ID.

    Web

    The web faucet is available at https://faucet.celestia-arabica-11.com/.

    Explorers

    There are multiple explorers you can use for Arabica:

    Network upgrades

    Join our Telegram announcement channel for network upgrades.

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/arbitrum-bridge.html b/pr-1815/how-to-guides/arbitrum-bridge.html index f45177d4d..e7e55f4cc 100644 --- a/pr-1815/how-to-guides/arbitrum-bridge.html +++ b/pr-1815/how-to-guides/arbitrum-bridge.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Bridging in and out of your Orbit rollup

    This guide covers how to bridge in (deposit) and bridge out (withdrawal) from your Arbitrum Orbit L3 rollup.

    This guide will cover bridging in and out of your Orbit rollup.

    Below are two example transactions, one of a deposit and one of a withdrawal:

    bridge-overview-deposit-and-withdrawal-l3

    Bridge in (deposit) to your rollup

    Step 1: Add your custom chain config

    (1a) In the Arbitrum Bridge UI, click the menu dropdown in the top right. Select Settings.

    bridge-settings

    (1b) Under Developer Mode, select Turn on testnet mode. Add your custom chain config from outputInfo.json in the root of your orbit-setup-script directory.

    add-testnet-orbit-chain

    (1c) You'll then see the chain under Live Orbit Chains:

    live-orbit-chains

    Step 2: Deposit to your Orbit rollup

    (2a) Choose an amount of Arbitrum Sepolia ETH to bridge into your rollup. Click Move funds to <YOUR_ROLLUP_NAME>, in this case Move funds to Arbitrum L3 Rollup. Approve the transaction in your wallet.

    bridge-in-start

    (2b) You'll then see it load in the Pending transactions tab:

    bridge-in-pending

    (2c) Shortly after, in the Settled transactions tab you can see the transaction status. Click Success.

    bridge-in-settled-txs

    (2d) View the transaction on your local instance of Blockscout for your rollup:

    bridge-in-explorer-rollup-tx

    (2e) Optionally, click See Details for an overview of your deposit:

    bridge-in-success

    (2f) From the details page, you can also see the transaction for your deposit on Arbitrum Sepolia:

    bridge-in-sepolia-tx-explorer

    Bridge out (withdrawal) from your rollup

    Step 1: Choose an amount to withdraw from your rollup

    (1a) In the Arbitrum Bridge UI, choose your origin chain to your Arbitrum L3 Rollup and the destination chain as Arbitrum Sepolia.

    bridge-out-small-screenshot

    (1b) Click Move funds to Arbitrum Sepolia and read the disclaimer, check the boxes, and click Continue.

    bridge-out-begin

    (1c) Optionally, set a reminder on your calendar so you don't forget.

    (1d) After approving the transaction in your wallet, you'll be able to see the transaction in the Pending transactions tab:

    bridge-out-pending

    After approximately two hours, you will be able to proceed to Step 2: Claim your withdrawal.

    (1e) Click See details to see an overview of your withdrawal:

    bridge-out-begin-overview

    (1f) Optionally, view the transaction on your local explorer.

    bridge-out-tx-details

    (1g) To learn more about what is going on, click the Logs tab:

    bridge-out-logs-details-1

    bridge-out-logs-explorer-2

    Step 2: Claim your withdrawal

    After approximately 2 hours, you will be able to claim your withdrawal.

    (2a) Head back to the bridge UI and you will have a notification to claim your withdrawal. Click Claim in the details of the transaction:

    bridge-out-claim-withdrawal

    (2b) Approve the transaction in your wallet.

    (2c) After your transaction goes through, you can see the details in the bridge UI under Settled transactions:

    bridge-out-claim-success-withdrawal

    - +

    Bridging in and out of your Orbit rollup

    This guide covers how to bridge in (deposit) and bridge out (withdrawal) from your Arbitrum Orbit L3 rollup.

    This guide will cover bridging in and out of your Orbit rollup.

    Below are two example transactions, one of a deposit and one of a withdrawal:

    bridge-overview-deposit-and-withdrawal-l3

    Bridge in (deposit) to your rollup

    Step 1: Add your custom chain config

    (1a) In the Arbitrum Bridge UI, click the menu dropdown in the top right. Select Settings.

    bridge-settings

    (1b) Under Developer Mode, select Turn on testnet mode. Add your custom chain config from outputInfo.json in the root of your orbit-setup-script directory.

    add-testnet-orbit-chain

    (1c) You'll then see the chain under Live Orbit Chains:

    live-orbit-chains

    Step 2: Deposit to your Orbit rollup

    (2a) Choose an amount of Arbitrum Sepolia ETH to bridge into your rollup. Click Move funds to <YOUR_ROLLUP_NAME>, in this case Move funds to Arbitrum L3 Rollup. Approve the transaction in your wallet.

    bridge-in-start

    (2b) You'll then see it load in the Pending transactions tab:

    bridge-in-pending

    (2c) Shortly after, in the Settled transactions tab you can see the transaction status. Click Success.

    bridge-in-settled-txs

    (2d) View the transaction on your local instance of Blockscout for your rollup:

    bridge-in-explorer-rollup-tx

    (2e) Optionally, click See Details for an overview of your deposit:

    bridge-in-success

    (2f) From the details page, you can also see the transaction for your deposit on Arbitrum Sepolia:

    bridge-in-sepolia-tx-explorer

    Bridge out (withdrawal) from your rollup

    Step 1: Choose an amount to withdraw from your rollup

    (1a) In the Arbitrum Bridge UI, choose your origin chain to your Arbitrum L3 Rollup and the destination chain as Arbitrum Sepolia.

    bridge-out-small-screenshot

    (1b) Click Move funds to Arbitrum Sepolia and read the disclaimer, check the boxes, and click Continue.

    bridge-out-begin

    (1c) Optionally, set a reminder on your calendar so you don't forget.

    (1d) After approving the transaction in your wallet, you'll be able to see the transaction in the Pending transactions tab:

    bridge-out-pending

    After approximately two hours, you will be able to proceed to Step 2: Claim your withdrawal.

    (1e) Click See details to see an overview of your withdrawal:

    bridge-out-begin-overview

    (1f) Optionally, view the transaction on your local explorer.

    bridge-out-tx-details

    (1g) To learn more about what is going on, click the Logs tab:

    bridge-out-logs-details-1

    bridge-out-logs-explorer-2

    Step 2: Claim your withdrawal

    After approximately 2 hours, you will be able to claim your withdrawal.

    (2a) Head back to the bridge UI and you will have a notification to claim your withdrawal. Click Claim in the details of the transaction:

    bridge-out-claim-withdrawal

    (2b) Approve the transaction in your wallet.

    (2c) After your transaction goes through, you can see the details in the bridge UI under Settled transactions:

    bridge-out-claim-success-withdrawal

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/arbitrum-deploy.html b/pr-1815/how-to-guides/arbitrum-deploy.html index f43f58fff..6b2fcc71f 100644 --- a/pr-1815/how-to-guides/arbitrum-deploy.html +++ b/pr-1815/how-to-guides/arbitrum-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -157,8 +157,8 @@ Executor has been added to chain owners on TX: 0x97b50f60b60d0e658fdbf185969db0a0327bd0ae9e57cd65af2a7f9be0eeb5b0 Executing removeChainOwner through the UpgradeExecutor contract Transaction complete, rollup owner removed from chain owners on TX: 0x019850732270d8c436585c7921219252422228b5d0f559da0da219f0fa2b7216 - Done in 58.49s.

    Find your PFB on Celenium by looking at the namespace or account you posted from.

    See an example blob that was posted while making this guide.

    Congratulations with Celestia underneath

    Your local Orbit rollup is now running. You'll see an outputInfo.json file in the main directory of your script folder - this contains more information about your chain, including the addresses of your chain's base contracts.

    In the next guides, learn how to run a full and validating full node or bridge in and out of your rollup.

    Appendix

    Extra resources in Arbitrum documentation:

    Compatibility matrix

    ComponentVersionDetails
    Nitrov2.3.1-rc.1Includes the replay binary for the WASM root 0x10c65b27d5031ce2351c719072e58f3153228887f027f9f6d65300d2b5b30152. Read the overview for overall changes.
    Contractsv1.2.1-celestiaIntegrates Blobstream X functionality into nitro-contracts v1.2.1
    Orbit SDKv0.8.2 Orbit SDK for Celestia DAThis is not compatible with Orbit SDK v0.8.2 or with the latest changes to nitro-contracts for the Atlas upgrade. The Orbit SDK itself is in Alpha.
    celestia-nodev0.13.1This integration has only been tested with celestia-node 0.13.1 and only works with said version, and with future versions after that. Under the hood, the Nitro node uses this commit of celestia-openrpc.

    Blobstream X contract deployments

    The Orbit contracts depend on the following Blobstream X deployments. The current deployments, which can be found at 0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2 in both chains, relays headers from the Mocha-4 testnet to the chains below:

    • Arbitrum Sepolia
    • Base Sepolia

    Arbitrum Sepolia

    Base Sepolia

    • RollupCreator: 0x1Bb8ADd5e878b12Fa37756392642eB94C53A1Cf4
    • TokenBridgeCreator: 0xAa3b8B63cCCa3c98b948FD1d6eD875d378dE2C6c
    • TokenBridgeRetryableSender: 0x4270889AdcB82338C5FF5e64B45c0A3d31CFd08C
    • Find additional Base Sepolia deployments below

    Arbitrum Sepolia additional deployments

    ContractAddress
    Bridge0x95FEA00e689e8D1CBa909836E1Ef1b941D5f21b1
    SequencerInbox0x95CBDa89325db5529eAF1813E181f66B83A7d65a
    Inbox0x3681Cbb0E95AB50b63F2FC524FbBcC78adEfBd33
    RollupEventInbox0x61e154128b6a1400ea8090B4431B4aA1DBb80Cc4
    Outbox0x5187a92539bB4A2befe1fc078745c84AB6d37171
    ERC20Bridge0xD0a6699Fc7519966685181c80BF98D35aFa1fC95
    SequencerInbox0x2588867F19E2DE51f90F0aB852C7Ad11228e3d83
    ERC20Inbox0x6cB49605f10831749c6090AD09918bC61439bacE
    ERC20RollupEventInbox0x7fC4D9A24949680faD666FeEe7cD6a100E39C4F0
    ERC20Outbox0xA773e19DC9e822933A7e72Df9c87eD1578701D29
    BridgeCreator0x3Bc040EAca40b91FA06cf55Ea91842FaC88b1AF4
    OneStepProver00x5810F0916BAE1067Ca1efcc00AaaF30301af001c
    OneStepProverMemory0xaC3427E621C6F10dC2ABdAB00188D92690503914
    OneStepProverMath0xFB612fb83959b8ACD3E49540B29C93c5A67e05f1
    OneStepProverHostIo0x630093954CbF19Fe4532A2edD0bD3B10dEcA7A4D
    OneStepProofEntry0x53DEA3A90Fd6C82840a1f7224F799D622f142Df4
    ChallengeManager0x01B5905B154F21a393F5B5a0C6d15B53a493C05e
    RollupAdminLogic0xe371AFcb8437bF61bd831EF57Be7A2496D88488B
    RollupUserLogic0xE24a60b758b51b0a3dA5E8F4F6ddf1cd0aFF646C
    ValidatorUtils0x7973D0b475E898082dF25c1617CBce1917cFED17
    ValidatorWalletCreator0xe2662ff9b41f39e63A850E50E013Ea66e60A4F37
    RollupCreator0x79751B011BCc20F413a2c4E3AF019b6E2a9738B9
    DeployHelper0xd2D353916B34a877793628049c99858f04123eE1

    Base Sepolia additional deployments

    ContractAddress
    Bridge0xb6052122545AACD2BDda0Ca9FA56416bD968cDbc
    SequencerInbox0xcd9FCa5015b5ce2B06a2266e4a5dd54D9ca39F1a
    Inbox0x44B412b291fEf00398501B2cA353EA912AD0fe13
    RollupEventInbox0x51D196e07a27DBA0F4461Dd6CC26108424F196f7
    Outbox0x5A48aDf22f526eBD06e3e8856cFEa2490923CC55
    ERC20Bridge0x9abC41fEfAe7E7543a01FA837AeC909F96147280
    SequencerInbox0x8f97Cb7c643Acd7f79f3B13841b24a243dA51242
    ERC20Inbox0x40f8c63e0a20B399bCd9631A22E57BB988a9400e
    ERC20RollupEventInbox0x3B6e845fb9f0c8Ee4E9F6D44781f6547d9c6359a
    ERC20Outbox0xc99eEA0B8e67D5b2226AB6D37882DAAf6dd7593b
    BridgeCreator0xC7535F078CB3880a0FD5E54FA7A3B4EAf09b3924
    OneStepProver00xf889a3174Fddd9f78E6cd250Ebf4c16F1bDd1b6a
    OneStepProverMemory0x61254e43e5c1e9E801F9C56B47a9ac3EADF6d1E9
    OneStepProverMath0x55527d53fdA37Dbf1924482b40AcF8625E1cAA5B
    OneStepProverHostIo0x03B43F7B61Fa100611191F481Ef48aa1fc98F434
    OneStepProofEntry0x89b7c7970c13BB587893a70697AD6d2A335b6A15
    ChallengeManager0x04CAe899Fc0B7Ef45c529f8Bf075D54F6fB70eD9
    RollupAdminLogic0x99E9D2F04352B42C18F1DA5Dd93a970F82C08aFe
    RollupUserLogic0x1ae3A8DC1e7eFD37F418B2987D3DF74c5a917a8B
    ValidatorUtils0x1cc4551922C069A9aDE06756BF14bF0410eA44fF
    ValidatorWalletCreator0x78f8B2941ddE5a8A312814Ebd29c2E2A36f25E91
    RollupCreator0x1Bb8ADd5e878b12Fa37756392642eB94C53A1Cf4
    DeployHelper0x20d8153AaCC4E6D29558fa3916BfF422BEDE9B5E
    - + Done in 58.49s.

    Find your PFB on Celenium by looking at the namespace or account you posted from.

    See an example blob that was posted while making this guide.

    Congratulations with Celestia underneath

    Your local Orbit rollup is now running. You'll see an outputInfo.json file in the main directory of your script folder - this contains more information about your chain, including the addresses of your chain's base contracts.

    In the next guides, learn how to run a full and validating full node or bridge in and out of your rollup.

    Appendix

    Extra resources in Arbitrum documentation:

    Compatibility matrix

    ComponentVersionDetails
    Nitrov2.3.1-rc.1Includes the replay binary for the WASM root 0x10c65b27d5031ce2351c719072e58f3153228887f027f9f6d65300d2b5b30152. Read the overview for overall changes.
    Contractsv1.2.1-celestiaIntegrates Blobstream X functionality into nitro-contracts v1.2.1
    Orbit SDKv0.8.2 Orbit SDK for Celestia DAThis is not compatible with Orbit SDK v0.8.2 or with the latest changes to nitro-contracts for the Atlas upgrade. The Orbit SDK itself is in Alpha.
    celestia-nodev0.13.1This integration has only been tested with celestia-node 0.13.1 and only works with said version, and with future versions after that. Under the hood, the Nitro node uses this commit of celestia-openrpc.

    Blobstream X contract deployments

    The Orbit contracts depend on the following Blobstream X deployments. The current deployments, which can be found at 0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2 in both chains, relays headers from the Mocha-4 testnet to the chains below:

    • Arbitrum Sepolia
    • Base Sepolia

    Arbitrum Sepolia

    Base Sepolia

    • RollupCreator: 0x1Bb8ADd5e878b12Fa37756392642eB94C53A1Cf4
    • TokenBridgeCreator: 0xAa3b8B63cCCa3c98b948FD1d6eD875d378dE2C6c
    • TokenBridgeRetryableSender: 0x4270889AdcB82338C5FF5e64B45c0A3d31CFd08C
    • Find additional Base Sepolia deployments below

    Arbitrum Sepolia additional deployments

    ContractAddress
    Bridge0x95FEA00e689e8D1CBa909836E1Ef1b941D5f21b1
    SequencerInbox0x95CBDa89325db5529eAF1813E181f66B83A7d65a
    Inbox0x3681Cbb0E95AB50b63F2FC524FbBcC78adEfBd33
    RollupEventInbox0x61e154128b6a1400ea8090B4431B4aA1DBb80Cc4
    Outbox0x5187a92539bB4A2befe1fc078745c84AB6d37171
    ERC20Bridge0xD0a6699Fc7519966685181c80BF98D35aFa1fC95
    SequencerInbox0x2588867F19E2DE51f90F0aB852C7Ad11228e3d83
    ERC20Inbox0x6cB49605f10831749c6090AD09918bC61439bacE
    ERC20RollupEventInbox0x7fC4D9A24949680faD666FeEe7cD6a100E39C4F0
    ERC20Outbox0xA773e19DC9e822933A7e72Df9c87eD1578701D29
    BridgeCreator0x3Bc040EAca40b91FA06cf55Ea91842FaC88b1AF4
    OneStepProver00x5810F0916BAE1067Ca1efcc00AaaF30301af001c
    OneStepProverMemory0xaC3427E621C6F10dC2ABdAB00188D92690503914
    OneStepProverMath0xFB612fb83959b8ACD3E49540B29C93c5A67e05f1
    OneStepProverHostIo0x630093954CbF19Fe4532A2edD0bD3B10dEcA7A4D
    OneStepProofEntry0x53DEA3A90Fd6C82840a1f7224F799D622f142Df4
    ChallengeManager0x01B5905B154F21a393F5B5a0C6d15B53a493C05e
    RollupAdminLogic0xe371AFcb8437bF61bd831EF57Be7A2496D88488B
    RollupUserLogic0xE24a60b758b51b0a3dA5E8F4F6ddf1cd0aFF646C
    ValidatorUtils0x7973D0b475E898082dF25c1617CBce1917cFED17
    ValidatorWalletCreator0xe2662ff9b41f39e63A850E50E013Ea66e60A4F37
    RollupCreator0x79751B011BCc20F413a2c4E3AF019b6E2a9738B9
    DeployHelper0xd2D353916B34a877793628049c99858f04123eE1

    Base Sepolia additional deployments

    ContractAddress
    Bridge0xb6052122545AACD2BDda0Ca9FA56416bD968cDbc
    SequencerInbox0xcd9FCa5015b5ce2B06a2266e4a5dd54D9ca39F1a
    Inbox0x44B412b291fEf00398501B2cA353EA912AD0fe13
    RollupEventInbox0x51D196e07a27DBA0F4461Dd6CC26108424F196f7
    Outbox0x5A48aDf22f526eBD06e3e8856cFEa2490923CC55
    ERC20Bridge0x9abC41fEfAe7E7543a01FA837AeC909F96147280
    SequencerInbox0x8f97Cb7c643Acd7f79f3B13841b24a243dA51242
    ERC20Inbox0x40f8c63e0a20B399bCd9631A22E57BB988a9400e
    ERC20RollupEventInbox0x3B6e845fb9f0c8Ee4E9F6D44781f6547d9c6359a
    ERC20Outbox0xc99eEA0B8e67D5b2226AB6D37882DAAf6dd7593b
    BridgeCreator0xC7535F078CB3880a0FD5E54FA7A3B4EAf09b3924
    OneStepProver00xf889a3174Fddd9f78E6cd250Ebf4c16F1bDd1b6a
    OneStepProverMemory0x61254e43e5c1e9E801F9C56B47a9ac3EADF6d1E9
    OneStepProverMath0x55527d53fdA37Dbf1924482b40AcF8625E1cAA5B
    OneStepProverHostIo0x03B43F7B61Fa100611191F481Ef48aa1fc98F434
    OneStepProofEntry0x89b7c7970c13BB587893a70697AD6d2A335b6A15
    ChallengeManager0x04CAe899Fc0B7Ef45c529f8Bf075D54F6fB70eD9
    RollupAdminLogic0x99E9D2F04352B42C18F1DA5Dd93a970F82C08aFe
    RollupUserLogic0x1ae3A8DC1e7eFD37F418B2987D3DF74c5a917a8B
    ValidatorUtils0x1cc4551922C069A9aDE06756BF14bF0410eA44fF
    ValidatorWalletCreator0x78f8B2941ddE5a8A312814Ebd29c2E2A36f25E91
    RollupCreator0x1Bb8ADd5e878b12Fa37756392642eB94C53A1Cf4
    DeployHelper0x20d8153AaCC4E6D29558fa3916BfF422BEDE9B5E
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/arbitrum-full-node.html b/pr-1815/how-to-guides/arbitrum-full-node.html index 692ea5de7..379f525d0 100644 --- a/pr-1815/how-to-guides/arbitrum-full-node.html +++ b/pr-1815/how-to-guides/arbitrum-full-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -49,8 +49,8 @@

    Running a full node and/or validator

    Prerequisites

    Running a full node

    To run a full node, you can follow the steps outlined in the Arbitrum docs, with the difference being that you will use this image: dfcelestia/nitro-node-dev:latest instead of the one mentioned in the Arbitrum docs.

    Note that you can either use the flags in the nitro binary + the flags found in the celestia package, or you can just provide a node config.json file with the celestia-cfg for them to run it, which would look something like this:

    json
    docker run --rm -v "$HOME/Documents/configs/nodeConfig.json:/config.json:ro" \
       --network host celestia-nitro:v2.3.1-rc.1 --conf.file /config.json
    docker run --rm -v "$HOME/Documents/configs/nodeConfig.json:/config.json:ro" \
    -  --network host celestia-nitro:v2.3.1-rc.1 --conf.file /config.json

    Running a full node with validation

    The information above applies to the steps outlined to run a validating full node (validator).

    Finally, note that this will require connection to a DA node, and we recommend running a Bridge node if you will be instantiating multiple rollups.

    - + --network host celestia-nitro:v2.3.1-rc.1 --conf.file /config.json

    Running a full node with validation

    The information above applies to the steps outlined to run a validating full node (validator).

    Finally, note that this will require connection to a DA node, and we recommend running a Bridge node if you will be instantiating multiple rollups.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/arbitrum-integration.html b/pr-1815/how-to-guides/arbitrum-integration.html index 88130b408..417e5452e 100644 --- a/pr-1815/how-to-guides/arbitrum-integration.html +++ b/pr-1815/how-to-guides/arbitrum-integration.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Introduction to Arbitrum rollups with Celestia as DA

    Celestia_Arbitrum

    Overview

    The integration of Celestia with Arbitrum Orbit and the Nitro tech stack marks the first external contribution to the Arbitrum Orbit protocol layer, offering developers an additional option for selecting a data availability layer alongside Arbitrum AnyTrust. The integration allows developers to deploy an Orbit Chain that uses Celestia for data availability and settles on Arbitrum One, Ethereum, or other EVM chains.

    Learn more about Orbit in Arbitrum's introduction.

    Key components

    The integration of Celestia with Arbitrum orbit is possible thanks to 3 key components:

    Additionally, the Ethereum fallback mechanism is a feature of the integration, which is native in Nitro.

    DA provider implementation

    The Arbitrum Nitro code has a DataAvailabilityProvider interface that is used across the codebase to store and retrieve data from a specific provider (eip4844 blobs, Anytrust, and now Celestia).

    This integration implements the DataAvailabilityProvider interface for Celestia DA

    Additionally, this integration comes with the necessary code for a Nitro chain node to post and retrieve data from Celestia.

    The core logic behind posting and retrieving data happens in celestia.go where data is stored on Celestia and serialized into a small batch of data that gets published once the necessary range of headers (data roots) has been relayed to the BlobstreamX contract. Then the Read logic takes care of taking the deserialized Blob Pointer struct and consuming it in order to fetch the data from Celestia and additionally inform the fetcher about the position of the data on Celestia (we'll get back to this in the next section).

    The following represents a non-exhaustive list of considerations when running a Batch Poster node for a chain with Celestia underneath:

    • You will need to use a consensus node RPC endpoint, you can find a list of them for Mocha
    • The Batch Poster will only post a Celestia batch to the underlying chain if the height for which it posted is in a recent range in BlobstreamX and if the verification succeeds, otherwise it will discard the batch. Since it will wait until a range is relayed, it can take several minutes for a batch to be posted, but one can always make an on-chain request for the BlobstreamX contract to relay a header promptly.

    The following represents a non-exhaustive list of considerations when running a Nitro node for a chain with Celestia underneath:

    • The TendermintRpc endpoint is only needed by the batch poster, every other node can operate without a connection to a full node.
    • The message header flag for Celestia batches is 0x0c.
    • You will need to know the namespace for the chain that you are trying to connect to, but don't worry if you don't find it, as the information in the BlobPointer can be used to identify where a batch of data is in the Celestia Data Square for a given height, and thus can be used to find out the namespace as well!

    Preimage Oracle Implementation

    In order to support fraud proofs, this integration has the necessary code for a Nitro validator to populate its preimage mapping with Celestia hashes that then get "unpeeled" in order to reveal the full data for a Blob. You can read more about the "Hash Oracle Trick".

    The data structures and hashing functions for this can be found in the nitro/das/celestia/tree folder

    You can see where the preimage oracle gets used in the fraud proof replay binary here

    Something important to note is that the preimage oracle only keeps track of hashes for the rows in the Celestia data square in which a blob resides in, this way each Orbit chain with Celestia underneath does not need validators to recompute an entire Celestia Data Square, but instead, only have to compute the row roots for the rows in which it's data lives in, and the header data root, which is the binary merkle tree hash built using the row roots and column roots fetched from a Celestia node. Because only data roots that can be confirmed on Blobstream get accepted into the sequencer inbox, one can have a high degree of certainty that the canonical data root being unpeeled as well as the row roots are in fact correct.

    Blobstream X implementation

    Finally, the integration only accepts batches with information that can be confirmed on BlobstreamX, which gives us a high certainty that data was made available on Celestia.

    You can see how BlobstreamX is integrated into the SequencerInbox.sol contract here, which allows us to discard batches with otherwise faulty data roots, thus giving us a high degree of confidence that the data root can be safely unpacked in case of a challenge.

    The Celestia and Arbitrum integration also includes Blobstream, which relays commitments to Celestia’s data root to an onchain light client on Ethereum. This allows L2 solutions that settle on Ethereum to benefit from the scalability Celestia’s data availability layer can provide.

    Ethereum fallback mechanism in Nitro

    By default in Arbitrum Nitro, the Ethereum fallback mechanism in the BatchPoster function is handling the process of storing data, with a fallback mechanism to store data onchain if the primary data availability storage fails.

    The @celestiaorg/nitro integration uses the same fallback mechanism.

    More information can be found on the Ethereum fallback mechanisms for Celestia, which enables Ethereum L2s (or L3s) to “fall back” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta.

    The fallback logic for Celestia DA is configurable, providing an alternative to the previous default fallback mechanism. Additionally, an ability has been added to the Arbitrum node software which allows the sequencer to call VerifyAttestation to check if a data root has been posted on Blobstream or not, before it sends the sequencer message (data pointer) to the underlying chain.

    Next steps

    In the next page, learn how to deploy an Arbitrum rollup devnet using Celestia as DA.

    - +

    Introduction to Arbitrum rollups with Celestia as DA

    Celestia_Arbitrum

    Overview

    The integration of Celestia with Arbitrum Orbit and the Nitro tech stack marks the first external contribution to the Arbitrum Orbit protocol layer, offering developers an additional option for selecting a data availability layer alongside Arbitrum AnyTrust. The integration allows developers to deploy an Orbit Chain that uses Celestia for data availability and settles on Arbitrum One, Ethereum, or other EVM chains.

    Learn more about Orbit in Arbitrum's introduction.

    Key components

    The integration of Celestia with Arbitrum orbit is possible thanks to 3 key components:

    Additionally, the Ethereum fallback mechanism is a feature of the integration, which is native in Nitro.

    DA provider implementation

    The Arbitrum Nitro code has a DataAvailabilityProvider interface that is used across the codebase to store and retrieve data from a specific provider (eip4844 blobs, Anytrust, and now Celestia).

    This integration implements the DataAvailabilityProvider interface for Celestia DA

    Additionally, this integration comes with the necessary code for a Nitro chain node to post and retrieve data from Celestia.

    The core logic behind posting and retrieving data happens in celestia.go where data is stored on Celestia and serialized into a small batch of data that gets published once the necessary range of headers (data roots) has been relayed to the BlobstreamX contract. Then the Read logic takes care of taking the deserialized Blob Pointer struct and consuming it in order to fetch the data from Celestia and additionally inform the fetcher about the position of the data on Celestia (we'll get back to this in the next section).

    The following represents a non-exhaustive list of considerations when running a Batch Poster node for a chain with Celestia underneath:

    • You will need to use a consensus node RPC endpoint, you can find a list of them for Mocha
    • The Batch Poster will only post a Celestia batch to the underlying chain if the height for which it posted is in a recent range in BlobstreamX and if the verification succeeds, otherwise it will discard the batch. Since it will wait until a range is relayed, it can take several minutes for a batch to be posted, but one can always make an on-chain request for the BlobstreamX contract to relay a header promptly.

    The following represents a non-exhaustive list of considerations when running a Nitro node for a chain with Celestia underneath:

    • The TendermintRpc endpoint is only needed by the batch poster, every other node can operate without a connection to a full node.
    • The message header flag for Celestia batches is 0x0c.
    • You will need to know the namespace for the chain that you are trying to connect to, but don't worry if you don't find it, as the information in the BlobPointer can be used to identify where a batch of data is in the Celestia Data Square for a given height, and thus can be used to find out the namespace as well!

    Preimage Oracle Implementation

    In order to support fraud proofs, this integration has the necessary code for a Nitro validator to populate its preimage mapping with Celestia hashes that then get "unpeeled" in order to reveal the full data for a Blob. You can read more about the "Hash Oracle Trick".

    The data structures and hashing functions for this can be found in the nitro/das/celestia/tree folder

    You can see where the preimage oracle gets used in the fraud proof replay binary here

    Something important to note is that the preimage oracle only keeps track of hashes for the rows in the Celestia data square in which a blob resides in, this way each Orbit chain with Celestia underneath does not need validators to recompute an entire Celestia Data Square, but instead, only have to compute the row roots for the rows in which it's data lives in, and the header data root, which is the binary merkle tree hash built using the row roots and column roots fetched from a Celestia node. Because only data roots that can be confirmed on Blobstream get accepted into the sequencer inbox, one can have a high degree of certainty that the canonical data root being unpeeled as well as the row roots are in fact correct.

    Blobstream X implementation

    Finally, the integration only accepts batches with information that can be confirmed on BlobstreamX, which gives us a high certainty that data was made available on Celestia.

    You can see how BlobstreamX is integrated into the SequencerInbox.sol contract here, which allows us to discard batches with otherwise faulty data roots, thus giving us a high degree of confidence that the data root can be safely unpacked in case of a challenge.

    The Celestia and Arbitrum integration also includes Blobstream, which relays commitments to Celestia’s data root to an onchain light client on Ethereum. This allows L2 solutions that settle on Ethereum to benefit from the scalability Celestia’s data availability layer can provide.

    Ethereum fallback mechanism in Nitro

    By default in Arbitrum Nitro, the Ethereum fallback mechanism in the BatchPoster function is handling the process of storing data, with a fallback mechanism to store data onchain if the primary data availability storage fails.

    The @celestiaorg/nitro integration uses the same fallback mechanism.

    More information can be found on the Ethereum fallback mechanisms for Celestia, which enables Ethereum L2s (or L3s) to “fall back” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta.

    The fallback logic for Celestia DA is configurable, providing an alternative to the previous default fallback mechanism. Additionally, an ability has been added to the Arbitrum node software which allows the sequencer to call VerifyAttestation to check if a data root has been posted on Blobstream or not, before it sends the sequencer message (data pointer) to the underlying chain.

    Next steps

    In the next page, learn how to deploy an Arbitrum rollup devnet using Celestia as DA.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream-contracts.html b/pr-1815/how-to-guides/blobstream-contracts.html index 17320904c..b73211b50 100644 --- a/pr-1815/how-to-guides/blobstream-contracts.html +++ b/pr-1815/how-to-guides/blobstream-contracts.html @@ -7,11 +7,11 @@ - + - - + + @@ -133,8 +133,8 @@ ) private pure returns (bool) { return true; } -}

    Data structures

    Each DataRootTuple is a tuple of block height and data root. It is analogous to a Celestia block header. DataRootTuples are relayed in batches, committed to as a DataRootTuples root (i.e. a Merkle root of DataRootTuples).

    The BinaryMerkleProof is an RFC-6962-compliant Merkle proof. Since DataRootTuples are Merkleized in a binary Merkle tree, verifying the inclusion of a DataRootTuple against a DataRootTuples root requires verifying a Merkle inclusion proof.

    Interface

    The IDAOracle (Data Availability Oracle Interface) interface allows L2 contracts on Ethereum to query the BlobstreamX.sol contract for relayed DataRootTuples. The single interface method verifyAttestation verifies a Merkle inclusion proof that a DataRootTuple is included under a specific batch (indexed by batch nonce). In other words, analogously it verifies that a specific block header is included in the Celestia chain.

    Querying the proof

    To prove that the data was published to Celestia, check out the proof queries documentation to understand how to query the proofs from Celestia consensus nodes and make them usable in the Blobstream X verifier contract.

    Verifying data inclusion for fraud proofs

    A high-level overview of how a fraud-proof based L2 would interact with Blobstream can be found in the inclusion proofs documentation.

    The DAVerifier library is available at blobstream-contracts/lib/verifier/DAVerifier.sol, and provides functions to verify the inclusion of individual (or multiple) shares against a DataRootTuple. The library is stateless, and allows to pass an IDAOracle interface as a parameter to verify inclusion against it.

    In the DAVerifier library, we find functions that help with data inclusion verification and calculating the square size of a Celestia block. These functions work with the Blobstream X smart contract, using different proofs to check and confirm the data's availability. Let's take a closer look at these functions:

    • verifySharesToDataRootTupleRoot: This function verifies that the shares, which were posted to Celestia, were committed to by the Blobstream X smart contract. It checks that the data root was committed to by the Blobstream X smart contract and that the shares were committed to by the rows roots.
    • verifyRowRootToDataRootTupleRoot: This function verifies that a row/column root, from a Celestia block, was committed to by the Blobstream X smart contract. It checks that the data root was committed to by the Blobstream X smart contract and that the row root commits to the data root.
    • verifyMultiRowRootsToDataRootTupleRoot: This function verifies that a set of rows/columns, from a Celestia block, were committed to by the Blobstream X smart contract. It checks that the data root was committed to by the Blobstream X smart contract and that the rows roots commit to the data root.
    • computeSquareSizeFromRowProof: This function computes the Celestia block square size from a row/column root to data root binary Merkle proof. It is the user's responsibility to verify that the proof is valid and was successfully committed to using the verifyRowRootToDataRootTupleRoot() method.
    • computeSquareSizeFromShareProof: This function computes the Celestia block square size from a shares to row/column root proof. It is the user's responsibility to verify that the proof is valid and that the shares were successfully committed to using the verifySharesToDataRootTupleRoot() method.

    For an overview of a demo rollup implementation, head to the next section.

    - +}

    Data structures

    Each DataRootTuple is a tuple of block height and data root. It is analogous to a Celestia block header. DataRootTuples are relayed in batches, committed to as a DataRootTuples root (i.e. a Merkle root of DataRootTuples).

    The BinaryMerkleProof is an RFC-6962-compliant Merkle proof. Since DataRootTuples are Merkleized in a binary Merkle tree, verifying the inclusion of a DataRootTuple against a DataRootTuples root requires verifying a Merkle inclusion proof.

    Interface

    The IDAOracle (Data Availability Oracle Interface) interface allows L2 contracts on Ethereum to query the BlobstreamX.sol contract for relayed DataRootTuples. The single interface method verifyAttestation verifies a Merkle inclusion proof that a DataRootTuple is included under a specific batch (indexed by batch nonce). In other words, analogously it verifies that a specific block header is included in the Celestia chain.

    Querying the proof

    To prove that the data was published to Celestia, check out the proof queries documentation to understand how to query the proofs from Celestia consensus nodes and make them usable in the Blobstream X verifier contract.

    Verifying data inclusion for fraud proofs

    A high-level overview of how a fraud-proof based L2 would interact with Blobstream can be found in the inclusion proofs documentation.

    The DAVerifier library is available at blobstream-contracts/lib/verifier/DAVerifier.sol, and provides functions to verify the inclusion of individual (or multiple) shares against a DataRootTuple. The library is stateless, and allows to pass an IDAOracle interface as a parameter to verify inclusion against it.

    In the DAVerifier library, we find functions that help with data inclusion verification and calculating the square size of a Celestia block. These functions work with the Blobstream X smart contract, using different proofs to check and confirm the data's availability. Let's take a closer look at these functions:

    • verifySharesToDataRootTupleRoot: This function verifies that the shares, which were posted to Celestia, were committed to by the Blobstream X smart contract. It checks that the data root was committed to by the Blobstream X smart contract and that the shares were committed to by the rows roots.
    • verifyRowRootToDataRootTupleRoot: This function verifies that a row/column root, from a Celestia block, was committed to by the Blobstream X smart contract. It checks that the data root was committed to by the Blobstream X smart contract and that the row root commits to the data root.
    • verifyMultiRowRootsToDataRootTupleRoot: This function verifies that a set of rows/columns, from a Celestia block, were committed to by the Blobstream X smart contract. It checks that the data root was committed to by the Blobstream X smart contract and that the rows roots commit to the data root.
    • computeSquareSizeFromRowProof: This function computes the Celestia block square size from a row/column root to data root binary Merkle proof. It is the user's responsibility to verify that the proof is valid and was successfully committed to using the verifyRowRootToDataRootTupleRoot() method.
    • computeSquareSizeFromShareProof: This function computes the Celestia block square size from a shares to row/column root proof. It is the user's responsibility to verify that the proof is valid and that the shares were successfully committed to using the verifySharesToDataRootTupleRoot() method.

    For an overview of a demo rollup implementation, head to the next section.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream-offchain.html b/pr-1815/how-to-guides/blobstream-offchain.html index d3d71aa78..881ef4573 100644 --- a/pr-1815/how-to-guides/blobstream-offchain.html +++ b/pr-1815/how-to-guides/blobstream-offchain.html @@ -7,11 +7,11 @@ - + - - + + @@ -343,8 +343,8 @@ Header: header, }, ) -}

    This outline of a Blobstream rollup isn't doing execution or state transitions induced by the transactions, however, that step would occur here. If fraud is detected, the fraud proof process will begin. The only difference between the fraud proof process of a normal optimistic rollup and a rollup that uses Blobstream for DA is that the full node would first prove the fraudulent transaction was committed to by the Sequencer using the Span in the header and before proceeding with the normal process.

    More documentation

    Proving inclusion via Blobstream

    Blobstream inclusion proof docs and the verifier helper contracts.

    Submitting block data to Celestia via light node

    As linked above, use the Celestia light node RPC to submit the data to Celestia.

    Posting headers to Ethereum

    How headers are posted to Ethereum is entirely dependent upon how the rollup light client contracts work. For examples of interacting with the Ethereum blockchain programmatically, please see the go-ethereum book or one of the many other resources for submitting transactions or writing contracts.

    - +}

    This outline of a Blobstream rollup isn't doing execution or state transitions induced by the transactions, however, that step would occur here. If fraud is detected, the fraud proof process will begin. The only difference between the fraud proof process of a normal optimistic rollup and a rollup that uses Blobstream for DA is that the full node would first prove the fraudulent transaction was committed to by the Sequencer using the Span in the header and before proceeding with the normal process.

    More documentation

    Proving inclusion via Blobstream

    Blobstream inclusion proof docs and the verifier helper contracts.

    Submitting block data to Celestia via light node

    As linked above, use the Celestia light node RPC to submit the data to Celestia.

    Posting headers to Ethereum

    How headers are posted to Ethereum is entirely dependent upon how the rollup light client contracts work. For examples of interacting with the Ethereum blockchain programmatically, please see the go-ethereum book or one of the many other resources for submitting transactions or writing contracts.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream-proof-queries.html b/pr-1815/how-to-guides/blobstream-proof-queries.html index ed85e5be7..da52e4520 100644 --- a/pr-1815/how-to-guides/blobstream-proof-queries.html +++ b/pr-1815/how-to-guides/blobstream-proof-queries.html @@ -7,11 +7,11 @@ - + - - + + @@ -73,7 +73,7 @@ if err != nil { ... } - }(trpc)

    The <rpc_endpoint> can be retrieved from Mainnet Beta for and Mocha for the Mocha testnet.

    In case the reader wants to interact with an on-chain contract that can be used to verify that data was posted to Celestia, the bindings of that contract are needed.

    For Blobstream, the golang bindings can be found in the following links:

    text
    https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
    https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
    text
    https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go
    https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go

    For other languages, the corresponding smart contract bindings should be generated. Refer to abigen for more information.

    Overview of the proof queries

    To prove the inclusion of PayForBlobs (PFB) transactions, blobs or shares, committed to in a Celestia block, we use the Celestia consensus node's RPC to query for proofs that can be verified in a rollup settlement contract via Blobstream. In fact, when a PFB transaction is included in a block, it gets separated into a PFB transaction (without the blob), and the actual data blob that it carries. These two are split into shares, which are the low level constructs of a Celestia block, and saved to the corresponding Celestia block. Learn more about shares in the shares specs.

    The two diagrams below summarize how a single share, which can contain a PFB transaction, or a part of the rollup data that was posted using a PFB, is committed to in Blobstream.

    The share is highlighted in green. R0, R1 etc, represent the respective row and column roots, the blue and pink gradients are erasure encoded data. More details on the square layout can be found in the data square layout and data structures portion of the specs.

    The Celestia square

    Square

    The commitment scheme

    Blobstream Commitment Diagram

    So to prove inclusion of a share to a Celestia block, we use Blobstream as a source of truth. In a nutshell, Blobstream attests to the data posted to Celestia in the zk-Blobstream contract via verifying a zk-proof of the headers of a batch of Celestia blocks. Then, it keeps reference of that batch of blocks using the merkleized commitment of their (dataRoot, height) resulting in a data root tuple root. Check the above diagram which shows:

    • 0: those are the shares, that when unified, contain the PFB or the rollup data blob.
    • 1: the row and column roots are the namespace merkle tree roots over the shares. More information on the NMT in the NMT specs. These commit to the rows and columns containing the above shares.
    • 2: the data roots: which are the binary merkle tree commitment over the row and column roots. This means that if you can prove that a share is part of a row, using a namespace merkle proof. Then prove that this row is committed to by the data root. Then you can be sure that that share was published to the corresponding block.
    • 3: in order to batch multiple blocks into the same commitment, we create a commitment over the (dataRoot, height) tuple for a batch of blocks, which results in a data root tuple root. It's this commitment that gets stored in the Blobstream smart contract.

    So, if we're able to prove:

    • That a share is part of a row, then that row is committed to by a data root.
    • Then, prove that that data root along with its height is committed to by the data root tuple root, which gets saved to the Blobstream contract.

    We can be sure that that share was committed to in the corresponding Celestia block.

    In this document, we will provide details on how to query the above proofs, and how to adapt them to be sent to a rollup contract for verification.

    Hands-on demonstration

    This part will provide the details of proof generation, and the way to make the results of the proofs queries ready to be consumed by the target rollup contract.

    NOTE

    For the go client snippets, make sure to have the following replaces in your go.mod:

    go
    // go.mod
    +	}(trpc)

    The <rpc_endpoint> can be retrieved from Mainnet Beta for and Mocha for the Mocha testnet.

    In case the reader wants to interact with an on-chain contract that can be used to verify that data was posted to Celestia, the bindings of that contract are needed.

    For Blobstream, the golang bindings can be found in the following links:

    text
    https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
    https://github.com/succinctlabs/blobstreamx/blob/main/bindings/BlobstreamX.go
    text
    https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go
    https://github.com/succinctlabs/sp1-blobstream/blob/main/bindings/SP1Blobstream.go

    For other languages, the corresponding smart contract bindings should be generated. Refer to abigen for more information.

    Overview of the proof queries

    To prove the inclusion of PayForBlobs (PFB) transactions, blobs or shares, committed to in a Celestia block, we use the Celestia consensus node's RPC to query for proofs that can be verified in a rollup settlement contract via Blobstream. In fact, when a PFB transaction is included in a block, it gets separated into a PFB transaction (without the blob), and the actual data blob that it carries. These two are split into shares, which are the low level constructs of a Celestia block, and saved to the corresponding Celestia block. Learn more about shares in the shares specs.

    The two diagrams below summarize how a single share, which can contain a PFB transaction, or a part of the rollup data that was posted using a PFB, is committed to in Blobstream.

    The share is highlighted in green. R0, R1 etc, represent the respective row and column roots, the blue and pink gradients are erasure encoded data. More details on the square layout can be found in the data square layout and data structures portion of the specs.

    The Celestia square

    Square

    The commitment scheme

    Blobstream Commitment Diagram

    So to prove inclusion of a share to a Celestia block, we use Blobstream as a source of truth. In a nutshell, Blobstream attests to the data posted to Celestia in the zk-Blobstream contract via verifying a zk-proof of the headers of a batch of Celestia blocks. Then, it keeps reference of that batch of blocks using the merkleized commitment of their (dataRoot, height) resulting in a data root tuple root. Check the above diagram which shows:

    • 0: those are the shares, that when unified, contain the PFB or the rollup data blob.
    • 1: the row and column roots are the namespace merkle tree roots over the shares. More information on the NMT in the NMT specs. These commit to the rows and columns containing the above shares.
    • 2: the data roots: which are the binary merkle tree commitment over the row and column roots. This means that if you can prove that a share is part of a row, using a namespace merkle proof. Then prove that this row is committed to by the data root. Then you can be sure that that share was published to the corresponding block.
    • 3: in order to batch multiple blocks into the same commitment, we create a commitment over the (dataRoot, height) tuple for a batch of blocks, which results in a data root tuple root. It's this commitment that gets stored in the Blobstream smart contract.

    So, if we're able to prove:

    • That a share is part of a row, then that row is committed to by a data root.
    • Then, prove that that data root along with its height is committed to by the data root tuple root, which gets saved to the Blobstream contract.

    We can be sure that that share was committed to in the corresponding Celestia block.

    In this document, we will provide details on how to query the above proofs, and how to adapt them to be sent to a rollup contract for verification.

    Hands-on demonstration

    This part will provide the details of proof generation, and the way to make the results of the proofs queries ready to be consumed by the target rollup contract.

    NOTE

    For the go client snippets, make sure to have the following replaces in your go.mod:

    go
    // go.mod
         github.com/cosmos/cosmos-sdk => github.com/celestiaorg/cosmos-sdk v1.18.3-sdk-v0.46.14
         github.com/gogo/protobuf => github.com/regen-network/protobuf v1.3.3-alpha.regen.1
         github.com/syndtr/goleveldb => github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7
    @@ -171,7 +171,7 @@
     		os.Exit(1)
     	}
     	fmt.Println(dcProof.Proof.String())
    -}

    Full example of proving that a Celestia block was committed to by Blobstream contract

    go
    package main
    +}

    Full example of proving that a Celestia block was committed to by Blobstream contract

    go
    package main
     
     import (
     	"context"
    @@ -1171,7 +1171,7 @@
     			NumLeaves: big.NewInt(dataRootInclusionProof.Total),
     		},
     	}
    -}

    With the nonce being the attestation nonce, which can be retrieved using Blobstream contract events. Check below for an example. And height being the Celestia Block height that contains the rollup data, along with the blockDataRoot being the data root of the block height. Finally, dataRootInclusionProof is the Celestia block data root inclusion proof to the data root tuple root that was queried at the beginning of this page.

    If the dataRoot or the tupleRootNonce is unknown during the verification:

    • dataRoot: can be queried using the /block?height=15 query (15 in this example endpoint), and taking the data_hash field from the response.
    • tupleRootNonce: can be retried via querying the data commitment stored events from the Blobstream contract and looking for the nonce attesting to the corresponding data.

    Querying the proof's tupleRootNonce

    go
    	// get the nonce corresponding to the block height that contains the PayForBlob transaction
    +}

    With the nonce being the attestation nonce, which can be retrieved using Blobstream contract events. Check below for an example. And height being the Celestia Block height that contains the rollup data, along with the blockDataRoot being the data root of the block height. Finally, dataRootInclusionProof is the Celestia block data root inclusion proof to the data root tuple root that was queried at the beginning of this page.

    If the dataRoot or the tupleRootNonce is unknown during the verification:

    • dataRoot: can be queried using the /block?height=15 query (15 in this example endpoint), and taking the data_hash field from the response.
    • tupleRootNonce: can be retried via querying the data commitment stored events from the Blobstream contract and looking for the nonce attesting to the corresponding data.

    Querying the proof's tupleRootNonce

    go
    	// get the nonce corresponding to the block height that contains the PayForBlob transaction
     	// since BlobstreamX emits events when new batches are submitted, we will query the events
     	// and look for the range committing to the blob
     	// first, connect to an EVM RPC endpoint
    @@ -1295,7 +1295,7 @@
     import {
         sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
     } 
    -// and use the `BlobstreamDataCommitmentStored` event instead.

    Listening for new data commitments

    For listening for new data commitment stored events, sequencers can use the WatchDataCommitmentStored as follows:

    go
        ethClient, err := ethclient.Dial("evm_rpc")
    +// and use the `BlobstreamDataCommitmentStored` event instead.

    Listening for new data commitments

    For listening for new data commitment stored events, sequencers can use the WatchDataCommitmentStored as follows:

    go
        ethClient, err := ethclient.Dial("evm_rpc")
         if err != nil {
     	    return err
         }
    @@ -1413,7 +1413,7 @@
             // (4) verify invalid state transition
             // (5) effects
         }
    -}

    Then, you can submit the fraud proof using golang as follows:

    go
    package main
    +}

    Then, you can submit the fraud proof using golang as follows:

    go
    package main
     
     import (
     	"context"
    @@ -1887,8 +1887,8 @@
     import {
         sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
     } 
    -// and use the `BlobstreamDataCommitmentStored` event instead.

    For the step (2), check the rollup inclusion proofs documentation for more information.

    For an example BlobstreamX project that uses the above proof queries, checkout the blobstreamx-example sample project. Learn more on the Lightlink docs.

    Conclusion

    After creating all the proofs, and verifying them:

    1. Verify inclusion proof of the transaction to Celestia data root
    2. Prove that the data root tuple is committed to by the Blobstream X smart contract

    We can be sure that the data was published to Celestia, and then rollups can proceed with their normal fraud proving mechanism.

    NOTE

    The above proof constructions are implemented in Solidity, and may require different approaches in other programming languages.

    - +// and use the `BlobstreamDataCommitmentStored` event instead.

    For the step (2), check the rollup inclusion proofs documentation for more information.

    For an example BlobstreamX project that uses the above proof queries, checkout the blobstreamx-example sample project. Learn more on the Lightlink docs.

    Conclusion

    After creating all the proofs, and verifying them:

    1. Verify inclusion proof of the transaction to Celestia data root
    2. Prove that the data root tuple is committed to by the Blobstream X smart contract

    We can be sure that the data was published to Celestia, and then rollups can proceed with their normal fraud proving mechanism.

    NOTE

    The above proof constructions are implemented in Solidity, and may require different approaches in other programming languages.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream-rollups.html b/pr-1815/how-to-guides/blobstream-rollups.html index a150732d1..e24b1e305 100644 --- a/pr-1815/how-to-guides/blobstream-rollups.html +++ b/pr-1815/how-to-guides/blobstream-rollups.html @@ -7,11 +7,11 @@ - + - - + + @@ -49,8 +49,8 @@

    Introduction to Blobstream rollups

    Blobstream is the first data availability solution for EVM chains that securely scales with the number of users. It allows rollups to post their data on Celestia while proving their availability in the rollup settlement contract.

    This document will outline a few ways to build optimistic or zk-rollups that post their data to Celestia and use Blobstream to prove that data's availability.

    Concepts

    This section will go over two constructs that can be used in building Blobstream rollups. Each with its pros and cons and the rollup developer can choose which one suits their needs better.

    Note: Only the sequence of spans method can be used currently to build Blobstream rollups. The blob share commitment way still requires some tooling that will be built in the upcoming months.

    Blob share commitment

    The blob share commitment is a commitment over the data contained in the MsgPayForBlobs transaction. This commitment allows proving that the corresponding data exists on Celestia efficiently.

    Blob share commitment: Proof details

    To prove that the data corresponding to a blob share commitment was posted to Celestia using Blobstream, the following proofs need to be verified:

    1. share inclusion proof to the blob share commitment: meaning creating two merkle proofs:
      1. share merkle proof up to the subtree root corresponding to that share
      2. subtree root merkle proof to the blob share commitment
    2. blob share commitment inclusion proof to the data root tuple root: meaning four merkle proofs:
      1. subtree roots merkle proofs to the blob share commitment: to make sure the subtree roots are valid
      2. subtree roots merkle proofs up to the row roots: to prove that the subtree roots belong to a set of rows in the Celestia block
      3. row roots proofs to the data root: to prove that those rows belong to the Celestia Block
      4. data root tuple proof to the data root tuple: to prove that the Celestia block referenced by its height and data root, was committed to by Blobstream.

    More details on the blob share commitment inclusion proof can be found in the commitment scheme docs and also the data square layout.

    If all of these proofs are valid, then you successfully managed to prove that the data corresponding to that blob share commitment has been posted to Celestia.

    NOTE

    Generating/verifying blob share commitment proofs is still not supported. It still needs tooling to generate the proofs on the node side, and verifying them on the Solidity side which will be built in the upcoming months.

    Blob share commitment: Compact proofs

    There is a way to have compact proofs, when using blob share commitments, unlike the ones defined above; that allow less costly inclusion proofs. These require the ability to parse the protobuf encoded PFBs.

    In fact, if the rollup project has a way to parse the protobuf encoded PFB, either in a smart contract or a zk-circuit, they will be able to create compact proofs of the rollup data.

    These proofs will work as follows:

    • Parsing the PFB and taking out the blob share commitment
    • Comparing the PFB commitment to the one saved in the rollup contract
    • Proving inclusion of the PFB to the data root tuple root. This will be a compact proof since we will only be proving two shares regardless of the size of the rollup data.

    More details on compact proofs can be found in ADR-011.

    Blob share commitment: Pros

    The pros of referencing rollup data using a blob share commitment:

    • Using the same commitment that exists on the PFB, without having to find another way of referencing the rollup data.
    • If the team has access to protobuf parsing, it allows for compact proof, but the parsing costs need to be investigated.

    Blob share commitment: Cons

    • Large/expensive proofs in the case of having no way to parse the protobuf PFB encoding.
    • In the optimistic rollups construction, defined below, this requires waiting for the Celestia block to be committed to by Blobstream before saving updating the settlement contract. This might require waiting for a few hours, depending on the batches size on each chain, to finally submit the rollup update.

    Given these limitations, an alternative design will be discussed in the next section.

    Sequence of spans

    An alternative way of referencing rollup data in the rollup settlement contract is using a sequence of spans.

    A sequence of spans is a data pointer that allows pointing to the rollup data inside a Celestia square using its location inside the square. It can be defined using the following information:

    • height: The height of the Celestia block containing the rollup data.
    • startIndex: The index of the first share containing the rollup data.
    • dataLen: The number of shares containing the rollup data.

    The startIndex and the dataLen can be queried from Celestia after the corresponding transaction gets included in a block and committed to the chain. An example of how to query them can be found in the verify command. The TxShareRange returns the start and end share of the data referenced by a transaction hash.

    NOTE

    If the rollup data is submitted in multiple blocks, the above sequence of spans can be generalized to include multiple blocks. For simplicity, we will stick with the data only submitted to a single Celestia block.

    Sequence of spans: Proof details

    Using sequence of spans is different from using the blob share commitment because we're referencing a location in the square, and not actual data commitment. So, the proof types and their generation are different.

    Sequence of spans: Proving unavailable data

    By construction, if the sequence of spans refers to a certain location in the square, that location is the data. This location can be in the reserved namespaces, the parity bytes, etc. What matters is that it's part of the square. So to prove that the sequence of spans is invalid, i.e., refers to data that is not available on Celestia, it is necessary and sufficient to show that the sequence of spans doesn't belong to the Celestia block, i.e., the span is out of bounds.

    We could create this proof via generating a binary Merkle proof of any row/column to the Celestia data root. This proof will provide the total which is the number of rows/columns in the extended data square. This can be used to calculate the square size. The computeSquareSizeFromRowProof method in the DAVerifier library allows calculating the square size from a row proof or a share proof.

    Then, we will use that information to check if the provided share index, in the header, is out of the square size bounds. In order words, we will check if the startIndex and the startIndex + dataLen are included in the range [0, 4*square_size].

    NOTE

    The square size is the number of rows of the original square.

    For the data root, we will use a binary Merkle proof to prove its inclusion in a data root tuple root that was committed to by the Blobstream smart contract. More on this in the data root inclusion proofs section.

    Sequence of spans: Proving inclusion of some data

    The difference between using a blob share commitment and a sequence of spans is that when using a blob share commitment, an extra merkle proof is needed to prove inclusion of the share to the blob share commitment. However, in the case of a sequence of spans, only the usual inclusion proof of a share to the data root tuple root is needed. The inclusion of the share to the sequence of spans is gotten using the same proof.

    In fact, proving that a share is part of the sequence of spans, i.e., part of the rollup data is done as follows:

    1. Prove that the data root tuple is committed to by the Blobstream smart contract:

      To prove the data root is committed to by the Blobstream smart contract, we will need to provide a Merkle proof of the data root tuple to a data root tuple root. This can be created using the data_root_inclusion_proof query. More on this can be found in the data root inclusion proofs documentation.

    2. Verify inclusion proof of the data to Celestia data root:

      To prove that the data is part of the data root, we will need to provide two proofs: a namespace Merkle proof of the data to a row root. This could be done via proving the shares that contain the data to the row root using a namespace Merkle proof. And, a binary Merkle proof of the row root to the data root.

      These proofs can be generated using the ProveShares query.

      More details on these proofs can be found in the transaction inclusion proof documentation.

    3. Prove that the data is in the sequence spans:

      To prove that the data is part of the rollup sequence of spans, we take the authenticated share proofs in step (2) and use the shares begin/end key to define the shares' positions in the row.

      Then, we use the row proof to get the row index in the extended Celestia square and get the index of the share in row major order:

      solidity
      uint256 shareIndexInRow = shareProof.shareProofs[0].beginKey;
       uint256 shareIndexInRowMajorOrder = shareIndexInRow + shareProof.rowProofs[0].numLeaves * shareProof.rowProofs[0].key;
      uint256 shareIndexInRow = shareProof.shareProofs[0].beginKey;
      -uint256 shareIndexInRowMajorOrder = shareIndexInRow + shareProof.rowProofs[0].numLeaves * shareProof.rowProofs[0].key;

    Finally, we can compare the computed index with the sequence of spans, and be sure that the data/shares is part of the rollup data.

    Sequence of spans: Pros

    • Using a sequence of spans instead of the blob share commitment allows for simpler proofs

    Sequence of spans: Cons

    None

    Optimistic rollups

    One type of rollups that can be built with Blobstream is optimistic rollups. An optimistic rollup is a rollup that commits optimistically to a set of blocks, and allows the other parties to verify that the blocks are valid, and if they're not, they can create fraud proofs to signal that.

    Celestia allows optimistic rollups to post their data on its DA layer, and to prove that the data is available using Blobstream.

    To build an optimistic rollup that uses Celestia as a DA layer, the following constructions can be inspired by.

    Optimistic rollups that use a sequence of spans

    Optimistic rollups can post their data in Celestia, then in the rollup settlement contract, they can reference optimistically that data using a sequence of spans. Then, rollup full nodes can verify if that data is valid. If not, they can trigger a fraud proof.

    When using a sequence of spans, triggering the data availability fraud proofs, which are different from the state transitions fraud proofs (left for the rollup to define), goes back to the following cases:

    Optimistic rollups that use a sequence of spans: Pros

    • Not needing to verify anything at the moment of submitting the commitments to the rollup settlement contracts
    • The fraud proofs are simple and can be reduced to a single share: if, for example, a single transaction in the rollup data that was posted to Celestia is faulty, only the shares containing that transaction, which can be as minimal as a single share, need to be proven on chain and verified.

    Optimistic rollups that use a sequence of spans: Cons

    None

    Optimistic rollups that use a sequence of spans: Example

    An example optimistic rollup that uses sequence of spans to reference its data can be found in the RollupInclusionProofs. It portrays the different possible data availability proofs, constructs them and shows how to verify them.

    Also, more details on querying these kinds of proofs can be found in the proof queries documentation.

    Optimistic rollups that use blob share commitments

    Another way to build a rollup is to replace the sequence of spans with a height and a blob share commitment. Then, users/rollup full nodes will be able to query that data and validate it. If the rollup data is not valid, they can create a fraud proof.

    The first difference between the sequence of spans construction and the share commitment construction is having to verify that the provided blob share commitment is part of the Celestia block, referenced by its height in the moment of submitting the rollup commitments to the settlement contract. This is necessary to make sure that the commitment is part of Celestia. Otherwise, rollup sequencers can commit to random blob share commitments and there won't be a way to prove they're invalid.

    The second difference is the proof types. In the case of a fraud proof, the proofs outlined in the proofs details of blob share commitment section would need to be verified to be sure that the share containing the invalid state transition is part of the rollup data. Alternatively, the rollup settlement contract would need to have a library to parse protobuf encoded PFBs, as explained in the compact proofs of blob share commitment section, to have less expensive proofs. The cost of parsing the protobuf is not included in this analysis and needs to be investigated separately.

    Optimistic rollups that use blob share commitments: Pros

    • Using the same blob share commitment as the one saved in Celestia which gives access to existing tooling

    Optimistic rollups that use blob share commitments: Cons

    • The proofs are expensive in the base case. And if the settlement contract is able to parse the PFBs, thorough investigations of the cost of that would need to be done.

    Zk-rollups

    Zk-rollups, aka validity rollups, can also use Celestia as a DA and Blobstream to verify that the data was posted. However, the submission process is different from the above constructions, since there are no fraud proofs, and everything should be verified when submitting the commitment to the settlement contract.

    Similar to the optimistic case, the rollup settlement contract can reference the rollup data using either the sequence of spans approach or the blob share commitments. We will discuss both in this section.

    Zk-rollups that use sequence of spans

    When submitting the commitments to the rollup settlement contract, this latter will need to verify the following:

    1. Zk-proof of the state transitions, which is left for the rollup to define.
    2. Verify that the sequence of spans is valid, i.e., is part of the Celestia block referenced by its height, as described in the proof details section.
    3. Zk-proof of the rollup data to the data root. The verification process of this should accept a commitment as input so that the settlement contract makes sure it's the correct value that's being saved. The commitment can be the data root and the sequence of spans. And, when the rollup data is proven inside the circuit to the data root, the used data root is asserted to be the input one. Similarly, the data's location is asserted to be the same as the input sequence of spans. These arguments are the ones used in the sequence of spans verification in (2).

    Once these are valid, the settlement contract can be sure that the rollup data was posted to Celestia, and the sequence of spans references it correctly.

    Zk-rollups that use sequence of spans: Pros

    • The inclusion proof inside the zk-circuit is a simple proof that uses traditional merkle tree. In the case of using blob share commitment, as will be explained below, additional libraries that can be expensive to prove are required.

    Zk-rollups that use sequence of spans: Cons

    None

    Zk-rollups that use blob share commitments

    To use blob share commitments to reference rollup data in the zk-rollup settlement contract, the zk-circuits need to be able to deserialize protobuf encoded messages. Alternatively, more involved merkle proofs will need to be verified.

    Protobuf deserialization inside a zk-circuit

    One way of using the blob share commitment to reference the rollup data in zk-rollups is via using a protobuf deserialization library inside the zk-circuit. And the verification would proceed as follows:

    1. Zk-proof of the state transitions, which is left to the rollup team to define.
    2. Verify that the blob share commitment is valid using the proofs laid out in the proof details of blob share commitment section.
    3. The zk-proof verifier would take as argument the data root and the blob share commitment. Then, inside the circuit, the protobuf encoded PFB transaction will be deserialized and then verify the following:
    • The deserialized blob share commitment is the same as the one provided as input
    • The circuit will prove the inclusion of the PFB to the data root, then assert that the data root is the same as the one provided as input.

    If the above conditions are valid, the rollup settlement contract can be sure that the rollup data was posted to Celestia and is correctly referenced.

    Zk-rollups that use blob share commitments: Pros

    None

    Zk-rollups that use blob share commitments: Cons

    • This approach requires having access to a protobuf decoder inside a zk-circuit which is not straightforward to have. Also, the relative costs will need to be investigated.

    Heavy merkle proofs usage

    Similar to Protobuf deserialization inside a zk-circuit, the zk-circuit will proceed to the verification of the availability of the data. The difference is that instead of parsing the encoded protobuf, the proofs defined under the blob share commitment proof details section will need to be verified inside the zk-circuit as follows:

    1. Zk-proof of the state transitions, which is left to the rollup team to define.
    2. Verify that the blob share commitment is valid using the proofs laid out in the blob share commitment proof details section.
    3. The zk-proof verifier would take as argument the data root and the blob share commitment. Then, inside the circuit:
    • It will verify that the input blob share commitment corresponds to the rollup data.
    • Verify that the input data root commits to that blob share commitment. Check the blob share commitment proof details for more details

    Once these proofs are valid, the rollup settlement contract can be sure that the rollup data was posted to Celestia and is correctly referenced.

    heavy merkle proofs usage: Pros

    None

    heavy merkle proofs usage: Cons

    • More heavy usage of merkle proofs inside and outside the zk-circuit.

    Conclusion

    Given the above details, using the sequence of spans is the better solution in the general case as explained in the optimistic rollups that uses a sequence of spans and zk-rollups that use sequence of spans sections. The proof sizes are small and allow for greater flexibility. However, if the rollup team has different requirements, then the other designs can be explored.

    FAQ

    Should I use the Celestia transaction hash to reference the rollup data?

    This is asked a lot since it's the most intuitive way of referencing data. However, in Celestia, referencing the data using the transaction hash is not recommended.

    A transaction proof in Celestia goes back to providing an inclusion proof of the shares containing the transaction. This means if the transaction hash is used to reference data in a Celestia block, the rollup verification mechanism should do the following:

    • Verify an inclusion proof of the shares comprising the transaction up to the data root tuple root
    • Decode those shares and parse the transaction, then hash its components to generate the transaction hash
    • Verify that the generated transaction hash matches the one used to reference the data

    At this level, the transaction hash is authenticated and the verification contract has the shares of the transaction. Then, the verification contract needs to take the share commitment from the parsed transaction and follow the steps outlined in the blob share commitment section.

    As observed, using the transaction hash is expensive and doesn't yield any advantages over using the blob share commitment, which in turn is more expensive than using the sequence of spans.

    So, unless there are more reasons to use the transaction hash to reference the rollup data, the sequence of spans approach remains better.

    - +uint256 shareIndexInRowMajorOrder = shareIndexInRow + shareProof.rowProofs[0].numLeaves * shareProof.rowProofs[0].key;

    Finally, we can compare the computed index with the sequence of spans, and be sure that the data/shares is part of the rollup data.

    Sequence of spans: Pros

    • Using a sequence of spans instead of the blob share commitment allows for simpler proofs

    Sequence of spans: Cons

    None

    Optimistic rollups

    One type of rollups that can be built with Blobstream is optimistic rollups. An optimistic rollup is a rollup that commits optimistically to a set of blocks, and allows the other parties to verify that the blocks are valid, and if they're not, they can create fraud proofs to signal that.

    Celestia allows optimistic rollups to post their data on its DA layer, and to prove that the data is available using Blobstream.

    To build an optimistic rollup that uses Celestia as a DA layer, the following constructions can be inspired by.

    Optimistic rollups that use a sequence of spans

    Optimistic rollups can post their data in Celestia, then in the rollup settlement contract, they can reference optimistically that data using a sequence of spans. Then, rollup full nodes can verify if that data is valid. If not, they can trigger a fraud proof.

    When using a sequence of spans, triggering the data availability fraud proofs, which are different from the state transitions fraud proofs (left for the rollup to define), goes back to the following cases:

    Optimistic rollups that use a sequence of spans: Pros

    • Not needing to verify anything at the moment of submitting the commitments to the rollup settlement contracts
    • The fraud proofs are simple and can be reduced to a single share: if, for example, a single transaction in the rollup data that was posted to Celestia is faulty, only the shares containing that transaction, which can be as minimal as a single share, need to be proven on chain and verified.

    Optimistic rollups that use a sequence of spans: Cons

    None

    Optimistic rollups that use a sequence of spans: Example

    An example optimistic rollup that uses sequence of spans to reference its data can be found in the RollupInclusionProofs. It portrays the different possible data availability proofs, constructs them and shows how to verify them.

    Also, more details on querying these kinds of proofs can be found in the proof queries documentation.

    Optimistic rollups that use blob share commitments

    Another way to build a rollup is to replace the sequence of spans with a height and a blob share commitment. Then, users/rollup full nodes will be able to query that data and validate it. If the rollup data is not valid, they can create a fraud proof.

    The first difference between the sequence of spans construction and the share commitment construction is having to verify that the provided blob share commitment is part of the Celestia block, referenced by its height in the moment of submitting the rollup commitments to the settlement contract. This is necessary to make sure that the commitment is part of Celestia. Otherwise, rollup sequencers can commit to random blob share commitments and there won't be a way to prove they're invalid.

    The second difference is the proof types. In the case of a fraud proof, the proofs outlined in the proofs details of blob share commitment section would need to be verified to be sure that the share containing the invalid state transition is part of the rollup data. Alternatively, the rollup settlement contract would need to have a library to parse protobuf encoded PFBs, as explained in the compact proofs of blob share commitment section, to have less expensive proofs. The cost of parsing the protobuf is not included in this analysis and needs to be investigated separately.

    Optimistic rollups that use blob share commitments: Pros

    • Using the same blob share commitment as the one saved in Celestia which gives access to existing tooling

    Optimistic rollups that use blob share commitments: Cons

    • The proofs are expensive in the base case. And if the settlement contract is able to parse the PFBs, thorough investigations of the cost of that would need to be done.

    Zk-rollups

    Zk-rollups, aka validity rollups, can also use Celestia as a DA and Blobstream to verify that the data was posted. However, the submission process is different from the above constructions, since there are no fraud proofs, and everything should be verified when submitting the commitment to the settlement contract.

    Similar to the optimistic case, the rollup settlement contract can reference the rollup data using either the sequence of spans approach or the blob share commitments. We will discuss both in this section.

    Zk-rollups that use sequence of spans

    When submitting the commitments to the rollup settlement contract, this latter will need to verify the following:

    1. Zk-proof of the state transitions, which is left for the rollup to define.
    2. Verify that the sequence of spans is valid, i.e., is part of the Celestia block referenced by its height, as described in the proof details section.
    3. Zk-proof of the rollup data to the data root. The verification process of this should accept a commitment as input so that the settlement contract makes sure it's the correct value that's being saved. The commitment can be the data root and the sequence of spans. And, when the rollup data is proven inside the circuit to the data root, the used data root is asserted to be the input one. Similarly, the data's location is asserted to be the same as the input sequence of spans. These arguments are the ones used in the sequence of spans verification in (2).

    Once these are valid, the settlement contract can be sure that the rollup data was posted to Celestia, and the sequence of spans references it correctly.

    Zk-rollups that use sequence of spans: Pros

    • The inclusion proof inside the zk-circuit is a simple proof that uses traditional merkle tree. In the case of using blob share commitment, as will be explained below, additional libraries that can be expensive to prove are required.

    Zk-rollups that use sequence of spans: Cons

    None

    Zk-rollups that use blob share commitments

    To use blob share commitments to reference rollup data in the zk-rollup settlement contract, the zk-circuits need to be able to deserialize protobuf encoded messages. Alternatively, more involved merkle proofs will need to be verified.

    Protobuf deserialization inside a zk-circuit

    One way of using the blob share commitment to reference the rollup data in zk-rollups is via using a protobuf deserialization library inside the zk-circuit. And the verification would proceed as follows:

    1. Zk-proof of the state transitions, which is left to the rollup team to define.
    2. Verify that the blob share commitment is valid using the proofs laid out in the proof details of blob share commitment section.
    3. The zk-proof verifier would take as argument the data root and the blob share commitment. Then, inside the circuit, the protobuf encoded PFB transaction will be deserialized and then verify the following:
    • The deserialized blob share commitment is the same as the one provided as input
    • The circuit will prove the inclusion of the PFB to the data root, then assert that the data root is the same as the one provided as input.

    If the above conditions are valid, the rollup settlement contract can be sure that the rollup data was posted to Celestia and is correctly referenced.

    Zk-rollups that use blob share commitments: Pros

    None

    Zk-rollups that use blob share commitments: Cons

    • This approach requires having access to a protobuf decoder inside a zk-circuit which is not straightforward to have. Also, the relative costs will need to be investigated.

    Heavy merkle proofs usage

    Similar to Protobuf deserialization inside a zk-circuit, the zk-circuit will proceed to the verification of the availability of the data. The difference is that instead of parsing the encoded protobuf, the proofs defined under the blob share commitment proof details section will need to be verified inside the zk-circuit as follows:

    1. Zk-proof of the state transitions, which is left to the rollup team to define.
    2. Verify that the blob share commitment is valid using the proofs laid out in the blob share commitment proof details section.
    3. The zk-proof verifier would take as argument the data root and the blob share commitment. Then, inside the circuit:
    • It will verify that the input blob share commitment corresponds to the rollup data.
    • Verify that the input data root commits to that blob share commitment. Check the blob share commitment proof details for more details

    Once these proofs are valid, the rollup settlement contract can be sure that the rollup data was posted to Celestia and is correctly referenced.

    heavy merkle proofs usage: Pros

    None

    heavy merkle proofs usage: Cons

    • More heavy usage of merkle proofs inside and outside the zk-circuit.

    Conclusion

    Given the above details, using the sequence of spans is the better solution in the general case as explained in the optimistic rollups that uses a sequence of spans and zk-rollups that use sequence of spans sections. The proof sizes are small and allow for greater flexibility. However, if the rollup team has different requirements, then the other designs can be explored.

    FAQ

    Should I use the Celestia transaction hash to reference the rollup data?

    This is asked a lot since it's the most intuitive way of referencing data. However, in Celestia, referencing the data using the transaction hash is not recommended.

    A transaction proof in Celestia goes back to providing an inclusion proof of the shares containing the transaction. This means if the transaction hash is used to reference data in a Celestia block, the rollup verification mechanism should do the following:

    • Verify an inclusion proof of the shares comprising the transaction up to the data root tuple root
    • Decode those shares and parse the transaction, then hash its components to generate the transaction hash
    • Verify that the generated transaction hash matches the one used to reference the data

    At this level, the transaction hash is authenticated and the verification contract has the shares of the transaction. Then, the verification contract needs to take the share commitment from the parsed transaction and follow the steps outlined in the blob share commitment section.

    As observed, using the transaction hash is expensive and doesn't yield any advantages over using the blob share commitment, which in turn is more expensive than using the sequence of spans.

    So, unless there are more reasons to use the transaction hash to reference the rollup data, the sequence of spans approach remains better.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream-x-deploy.html b/pr-1815/how-to-guides/blobstream-x-deploy.html index 295f16ced..e39947160 100644 --- a/pr-1815/how-to-guides/blobstream-x-deploy.html +++ b/pr-1815/how-to-guides/blobstream-x-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -219,8 +219,8 @@ # ^ This copies the verifier build to the blobstreamx folder mkdir -p build && RUST_LOG=debug cargo run --bin header_range_1024 --release build --wrapper-path verifier-build/ && mv ./target/release/header_range_1024 ./build/header_range_1024 ls build -# ^ should return something like: 0x007d0b2a2e2b013612e8.circuit 0x9039e58b2089e5f9abbb.circuit 0xce1636cfaf2bd5497c11.circuit FunctionVerifier.sol main.circuit 0x8e1ede4ce0865b41d714.circuit 0xa2140c9bde000dc5e21e.circuit 0xf6759ff933786ddacb92.circuit header_range_1024

    The header_range_1024 is a specific circuit. Other circuit names can be used there. The current circuits that we have for BlobstreamX:

    • header_range_1024: skip function circuit for batches that are <= 1024 block.
    • header_range_2048: skip function circuit for batches that are <= 2048 block.
    • next_header: step function circuit.

    All the deployments currently rely on two circuits: a header range circuit, either the 1024 or the 2048, depending on the frequency of the batches; The 1024 is mainly for batches that are at a ~1hr frequency and the 2048 for batches that are at a ~3-4hr frequency; and a next header circuit. So, if you're re-building the circuits, make sure to build the correct two circuits for your target deployment.

    Now, if you check the build folder, you will find a file called FunctionVerifier.sol, which is the function verifier contract for your circuit that you can deploy on-chain.

    Also, you will find the header_range_1024 under build folder which is the binary used to generate the proofs. It is mainly used by the operator to generate the plonky2x proofs that will be PLONK wrapped later using the generated verifier-build.

    At this level, you can deploy the FunctionVerifier.sol onchain, then register it in the SuccinctGateway, then use the generated header_range_1024 circuit and the verifier to generate the proofs and submit them onchain. These steps are detailed in the previous section.

    NOTE: In a scaleway instance of 64CPU and 504G RAM, the build takes ~10 minutes to complete. Make sure to run it on a beefy machine.

    - +# ^ should return something like: 0x007d0b2a2e2b013612e8.circuit 0x9039e58b2089e5f9abbb.circuit 0xce1636cfaf2bd5497c11.circuit FunctionVerifier.sol main.circuit 0x8e1ede4ce0865b41d714.circuit 0xa2140c9bde000dc5e21e.circuit 0xf6759ff933786ddacb92.circuit header_range_1024

    The header_range_1024 is a specific circuit. Other circuit names can be used there. The current circuits that we have for BlobstreamX:

    • header_range_1024: skip function circuit for batches that are <= 1024 block.
    • header_range_2048: skip function circuit for batches that are <= 2048 block.
    • next_header: step function circuit.

    All the deployments currently rely on two circuits: a header range circuit, either the 1024 or the 2048, depending on the frequency of the batches; The 1024 is mainly for batches that are at a ~1hr frequency and the 2048 for batches that are at a ~3-4hr frequency; and a next header circuit. So, if you're re-building the circuits, make sure to build the correct two circuits for your target deployment.

    Now, if you check the build folder, you will find a file called FunctionVerifier.sol, which is the function verifier contract for your circuit that you can deploy on-chain.

    Also, you will find the header_range_1024 under build folder which is the binary used to generate the proofs. It is mainly used by the operator to generate the plonky2x proofs that will be PLONK wrapped later using the generated verifier-build.

    At this level, you can deploy the FunctionVerifier.sol onchain, then register it in the SuccinctGateway, then use the generated header_range_1024 circuit and the verifier to generate the proofs and submit them onchain. These steps are detailed in the previous section.

    NOTE: In a scaleway instance of 64CPU and 504G RAM, the build takes ~10 minutes to complete. Make sure to run it on a beefy machine.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges.html b/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges.html index 825321681..ecb235158 100644 --- a/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges.html +++ b/pr-1815/how-to-guides/blobstream-x-requesting-data-commitment-ranges.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Requesting data commitment ranges

    By default, the Blobstream X deployments on Ethereum will be updated every 4 hours, and on Arbitrum One and Base, updating every 1 hour. If you wish for the Blobstream X contract to be updated at a different cadence, then you have several different options for how to update the smart contract.

    To request proofs to be submitted to the Blobstream X contract at a different cadence, you can do one of the following:

    NOTE: The requested proof ranges cannot include blocks that were already used in a previous batch. The ranges should start from the last proven block, aka, latest_block and they should end in a block already committed by Celestia. In other words, it's the end-inclusive range defined by [latest_block, target_block] with target_block <= Celestia tip.

    Local proving

    To run the Blobstream X operator with local proving, follow this guide.

    Local proving allows self-generating the proofs and submitting them to an existing BlobstreamX contract. Alternatively, if a team needs a very specific cadence that starts at very specific heights, they can deploy their own BlobstreamX contract and submit proofs to it. Deployment instructions can be found in the BlobstreamX deploy documentation.

    TIP

    Requires a large cloud machine to run in a reasonable amount of time. EC2 r6a.16xlarge, i.e., 64CPU 512GB RAM, takes ~30 minutes to generate a header range proof.

    Request proofs from the Succinct platform

    NOTE: Requesting a proof from the succinct platform requires having a Succinct API key. It can be requested using this form.

    Run the Blobstream X operator with hosted proving on the Succinct platform, by running an operator script that pings the platform with proof requests at a specified cadence.

    Follow these instructions to run the operator script.

    Here are example values for the .env file:

    1. TENDERMINT_RPC_URL from the public Celestia list.
    2. SUCCINCT_RPC_URL = https://alpha.succinct.xyz/api
    3. Request for SUCCINCT_API_KEY from the Succinct team.
    4. CHAIN_ID is the chain ID of the deployed Blobstream X contract.
    5. CONTRACT_ADDRESS: Blobstream X proxy contract address.
    6. NEXT_HEADER_FUNCTION_ID & HEADER_RANGE_FUNCTION_ID: Get the functionId's from the Blobstream X contract by using the nextHeaderFunctionId and headerRangeFunctionId respectively, which are public storage variables.

    Request proofs onchain

    Directly request a proof via the Blobstream X contract interface. Unlike the Blobstream X operator which handles requests off-chain, requesting on-chain requires gas, but the proof will be generated and relayed by the Succinct platform.

    1. Call requestHeaderRange(uint64 _targetBlock) with the end of the range you want a commitment for.

    2. A DataCommitmentStored(uint256, uint64, uint64, bytes32) will be emitted for the requested range when it is stored in the contract. Listen to this event to know that the proof has been generated successfully.

    - +

    Requesting data commitment ranges

    By default, the Blobstream X deployments on Ethereum will be updated every 4 hours, and on Arbitrum One and Base, updating every 1 hour. If you wish for the Blobstream X contract to be updated at a different cadence, then you have several different options for how to update the smart contract.

    To request proofs to be submitted to the Blobstream X contract at a different cadence, you can do one of the following:

    NOTE: The requested proof ranges cannot include blocks that were already used in a previous batch. The ranges should start from the last proven block, aka, latest_block and they should end in a block already committed by Celestia. In other words, it's the end-inclusive range defined by [latest_block, target_block] with target_block <= Celestia tip.

    Local proving

    To run the Blobstream X operator with local proving, follow this guide.

    Local proving allows self-generating the proofs and submitting them to an existing BlobstreamX contract. Alternatively, if a team needs a very specific cadence that starts at very specific heights, they can deploy their own BlobstreamX contract and submit proofs to it. Deployment instructions can be found in the BlobstreamX deploy documentation.

    TIP

    Requires a large cloud machine to run in a reasonable amount of time. EC2 r6a.16xlarge, i.e., 64CPU 512GB RAM, takes ~30 minutes to generate a header range proof.

    Request proofs from the Succinct platform

    NOTE: Requesting a proof from the succinct platform requires having a Succinct API key. It can be requested using this form.

    Run the Blobstream X operator with hosted proving on the Succinct platform, by running an operator script that pings the platform with proof requests at a specified cadence.

    Follow these instructions to run the operator script.

    Here are example values for the .env file:

    1. TENDERMINT_RPC_URL from the public Celestia list.
    2. SUCCINCT_RPC_URL = https://alpha.succinct.xyz/api
    3. Request for SUCCINCT_API_KEY from the Succinct team.
    4. CHAIN_ID is the chain ID of the deployed Blobstream X contract.
    5. CONTRACT_ADDRESS: Blobstream X proxy contract address.
    6. NEXT_HEADER_FUNCTION_ID & HEADER_RANGE_FUNCTION_ID: Get the functionId's from the Blobstream X contract by using the nextHeaderFunctionId and headerRangeFunctionId respectively, which are public storage variables.

    Request proofs onchain

    Directly request a proof via the Blobstream X contract interface. Unlike the Blobstream X operator which handles requests off-chain, requesting on-chain requires gas, but the proof will be generated and relayed by the Succinct platform.

    1. Call requestHeaderRange(uint64 _targetBlock) with the end of the range you want a commitment for.

    2. A DataCommitmentStored(uint256, uint64, uint64, bytes32) will be emitted for the requested range when it is stored in the contract. Listen to this event to know that the proof has been generated successfully.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstream.html b/pr-1815/how-to-guides/blobstream.html index 34dfcb299..37e0b915f 100644 --- a/pr-1815/how-to-guides/blobstream.html +++ b/pr-1815/how-to-guides/blobstream.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Blobstream: Streaming modular DA to Ethereum

    Blobstream logo

    What is Blobstream?

    Blobstream is the first data availability solution for Ethereum that securely scales with the number of users. Formerly known as the Quantum Gravity Bridge (QGB), Blobstream relays commitments to Celestia's data root to an onchain light client on Ethereum, for integration by developers into L2 contracts. This enables Ethereum developers to build high-throughput L2s using Celestia's optimised DA layer, the first with Data Availability Sampling (DAS). Any ecosystem can deploy a Blobstream light client onchain to allow L2s and L3s to access DA from Celestia.

    An implementation of Blobstream, by Succinct, called Blobstream X, is out and will be used in the upcoming deployments. This implementation proves the validity of Celestia block headers on a target EVM chain using zero-knowledge (ZK) proofs, which allow inheriting all the security guarantees of Celestia.

    The latest implementation of Blobstream X is SP1 Blobstream, which is written in Rust for the SP1 zkVM. SP1 Blobstream offers improved performance and efficiency while maintaining the security guarantees of the original Blobstream X.

    Please note: Blobstream remains early-stage, experimental software and users should use Blobstream at their own risk.

    Implementations of Blobstream

    Blobstream vs. data availability committees (DACs)

    Decentralization and security

    Blobstream is built on Celestia, which uses a CometBFT-based proof-of-stake system. Blobstream shares the same security assumptions as Celestia. In contrast, data availability committees (DACs), are typically centralized or semi-centralized, relying on a specific set of entities or individuals to vouch for data availability.

    Mechanism of verification

    Blobstream uses data availability attestations, which are Merkle roots of the batched L2 data, to confirm that the necessary data is present on Celestia. The L2 contract on Ethereum can check directly with Blobstream if the data is published on Celestia. Similarly, a DAC would rely on attestations or confirmations from its permissioned members.

    Flexibility and scalability

    Blobstream is designed to offer high-throughput data availability for Ethereum L2s, aiming to strike a balance between scalability and security. It operates independently of Ethereum's gas costs, as Celestia's resource pricing is more byte-focused rather than computation-centric. On the other hand, the scalability and flexibility of a DAC would depend on its specific design and implementation.

    In summary, both Blobstream and DACs aim to ensure offchain data availability, but Blobstream offers a more decentralized, secure, and scalable solution compared to the potential centralized nature of DACs.

    What is SP1 Blobstream?

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    SP1 Blobstream is the latest implementation of Blobstream with a ZK light client that bridges Celestia’s modular DA layer to Ethereum to allow high-throughput rollups to use Celestia’s DA while settling on Ethereum.

    Optimistic or ZK rollups that settle on Ethereum, but wish to use Celestia for DA, require a mechanism for bridging Celestia’s data root to Ethereum as part of the settlement process. This data root is used during inclusion proofs to prove that particular rollup transactions were included and made available in the Celestia network.

    Bridging Celestia’s data root to Ethereum requires running a Celestia light client as a smart contract on Ethereum, to make the latest state of the Celestia chain known on Ethereum and available to rollups. SP1 Blobstream uses the latest advances in ZK proofs to generate a succinct proof that enough Celestia validators have come to consensus (according to the CometBFT consensus protocol) on a block header, and verifies this proof in the SP1 Blobstream Ethereum smart contract to update it with the latest Celestia header.

    The SP1 Blobstream ZK proof not only verifies the consensus of Celestia validators, but it also merkelizes and hashes all the data roots in the block range from the previous update to the current update, making accessible all Celestia data roots (verifiable with a Merkle inclusion proof against the stored Merkle root) to rollups.

    If you're looking to deploy SP1 blobstream to a new chain, see new Sp1 Blobstream deployments.

    Learn more at the sp1-blobstream repo.

    NOTE

    The current Blobstream deployments all use SP1 Blobstream.

    Integrate with SP1 Blobstream

    The following docs go over how developers can integrate SP1 Blobstream.

    You can find the repository for SP1 Blobstream along with code for:

    The first deployments of SP1 Blobstream will be maintained on the following chains: Arbitrum One, Base and Ethereum Mainnet. Every 1 hour, the prover/relayer will post an update to the Blobstream contract that will include a new data commitment range that covers a 1-hour block range from the latestBlock in the contract. On Ethereum Mainnet, the contract will be updated every 4 hours.

    How to integrate with Blobstream

    Integrating your L2 with Blobstream requires two components: your onchain smart contract logic, and your offchain client logic for your rollup. The next three sections cover these topics:

    Blobstream rollups

    More on the different ways to build a blobstream rollup can be found in the blobstream rollups documentation.

    Deployed contracts

    You can interact with the SP1 Blobstream contracts today. The SP1 Blobstream Solidity smart contracts are currently deployed on the following chains:

    ContractEVM networkContract addressAttested data on CelestiaLink to Celenium
    SP1 BlobstreamEthereum Mainnet0x7Cf3876F681Dbb6EdA8f6FfC45D66B996Df08fAeMainnet BetaDeployment on Celenium
    SP1 BlobstreamArbitrum One0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamBase0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamSepolia0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1eMocha testnetDeployment on Celenium
    SP1 BlobstreamArbitrum Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    SP1 BlobstreamBase Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    - +

    Blobstream: Streaming modular DA to Ethereum

    Blobstream logo

    What is Blobstream?

    Blobstream is the first data availability solution for Ethereum that securely scales with the number of users. Formerly known as the Quantum Gravity Bridge (QGB), Blobstream relays commitments to Celestia's data root to an onchain light client on Ethereum, for integration by developers into L2 contracts. This enables Ethereum developers to build high-throughput L2s using Celestia's optimised DA layer, the first with Data Availability Sampling (DAS). Any ecosystem can deploy a Blobstream light client onchain to allow L2s and L3s to access DA from Celestia.

    An implementation of Blobstream, by Succinct, called Blobstream X, is out and will be used in the upcoming deployments. This implementation proves the validity of Celestia block headers on a target EVM chain using zero-knowledge (ZK) proofs, which allow inheriting all the security guarantees of Celestia.

    The latest implementation of Blobstream X is SP1 Blobstream, which is written in Rust for the SP1 zkVM. SP1 Blobstream offers improved performance and efficiency while maintaining the security guarantees of the original Blobstream X.

    Please note: Blobstream remains early-stage, experimental software and users should use Blobstream at their own risk.

    Implementations of Blobstream

    Blobstream vs. data availability committees (DACs)

    Decentralization and security

    Blobstream is built on Celestia, which uses a CometBFT-based proof-of-stake system. Blobstream shares the same security assumptions as Celestia. In contrast, data availability committees (DACs), are typically centralized or semi-centralized, relying on a specific set of entities or individuals to vouch for data availability.

    Mechanism of verification

    Blobstream uses data availability attestations, which are Merkle roots of the batched L2 data, to confirm that the necessary data is present on Celestia. The L2 contract on Ethereum can check directly with Blobstream if the data is published on Celestia. Similarly, a DAC would rely on attestations or confirmations from its permissioned members.

    Flexibility and scalability

    Blobstream is designed to offer high-throughput data availability for Ethereum L2s, aiming to strike a balance between scalability and security. It operates independently of Ethereum's gas costs, as Celestia's resource pricing is more byte-focused rather than computation-centric. On the other hand, the scalability and flexibility of a DAC would depend on its specific design and implementation.

    In summary, both Blobstream and DACs aim to ensure offchain data availability, but Blobstream offers a more decentralized, secure, and scalable solution compared to the potential centralized nature of DACs.

    What is SP1 Blobstream?

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    SP1 Blobstream is the latest implementation of Blobstream with a ZK light client that bridges Celestia’s modular DA layer to Ethereum to allow high-throughput rollups to use Celestia’s DA while settling on Ethereum.

    Optimistic or ZK rollups that settle on Ethereum, but wish to use Celestia for DA, require a mechanism for bridging Celestia’s data root to Ethereum as part of the settlement process. This data root is used during inclusion proofs to prove that particular rollup transactions were included and made available in the Celestia network.

    Bridging Celestia’s data root to Ethereum requires running a Celestia light client as a smart contract on Ethereum, to make the latest state of the Celestia chain known on Ethereum and available to rollups. SP1 Blobstream uses the latest advances in ZK proofs to generate a succinct proof that enough Celestia validators have come to consensus (according to the CometBFT consensus protocol) on a block header, and verifies this proof in the SP1 Blobstream Ethereum smart contract to update it with the latest Celestia header.

    The SP1 Blobstream ZK proof not only verifies the consensus of Celestia validators, but it also merkelizes and hashes all the data roots in the block range from the previous update to the current update, making accessible all Celestia data roots (verifiable with a Merkle inclusion proof against the stored Merkle root) to rollups.

    If you're looking to deploy SP1 blobstream to a new chain, see new Sp1 Blobstream deployments.

    Learn more at the sp1-blobstream repo.

    NOTE

    The current Blobstream deployments all use SP1 Blobstream.

    Integrate with SP1 Blobstream

    The following docs go over how developers can integrate SP1 Blobstream.

    You can find the repository for SP1 Blobstream along with code for:

    The first deployments of SP1 Blobstream will be maintained on the following chains: Arbitrum One, Base and Ethereum Mainnet. Every 1 hour, the prover/relayer will post an update to the Blobstream contract that will include a new data commitment range that covers a 1-hour block range from the latestBlock in the contract. On Ethereum Mainnet, the contract will be updated every 4 hours.

    How to integrate with Blobstream

    Integrating your L2 with Blobstream requires two components: your onchain smart contract logic, and your offchain client logic for your rollup. The next three sections cover these topics:

    Blobstream rollups

    More on the different ways to build a blobstream rollup can be found in the blobstream rollups documentation.

    Deployed contracts

    You can interact with the SP1 Blobstream contracts today. The SP1 Blobstream Solidity smart contracts are currently deployed on the following chains:

    ContractEVM networkContract addressAttested data on CelestiaLink to Celenium
    SP1 BlobstreamEthereum Mainnet0x7Cf3876F681Dbb6EdA8f6FfC45D66B996Df08fAeMainnet BetaDeployment on Celenium
    SP1 BlobstreamArbitrum One0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamBase0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
    SP1 BlobstreamSepolia0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1eMocha testnetDeployment on Celenium
    SP1 BlobstreamArbitrum Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    SP1 BlobstreamBase Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/blobstreamx.html b/pr-1815/how-to-guides/blobstreamx.html index 313cdb457..8ba8b8967 100644 --- a/pr-1815/how-to-guides/blobstreamx.html +++ b/pr-1815/how-to-guides/blobstreamx.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Blobstream X: the previous zk implementation of Blobstream

    blobstream x draft diagram

    What is Blobstream X?

    Blobstream X is the previous implementation of Blobstream. It uses plonky2x to create circuits that verify the Celestia consensus and generate the corresponding proofs.

    Blobstream X is built and deployed with Succinct's protocol.

    NOTE

    The Blobstream deployments below don't use the BlobstreamX circuits.

    You can find the repository for Blobstream X along with code for:

    NOTE

    Custom ranges can be requested using the BlobstreamX contract to create proofs for specific Celestia block batches. These ranges can be constructed as [latestBlock, customTargetBlock), with latestBlock as the latest block height that was committed to by the BlobstreamX contract, and latestBlock > customTargetBlock, and customTargetBlock - latestBlock <= DATA_COMMITMENT_MAX.

    Block ranges that are before the contract's latestBlock can't be proven a second time in different batches.

    More information can be found in the requestHeaderRange(...) method.

    How Blobstream X works

    As shown in the diagram below, the entrypoint for updates to the Blobstream X contract is through the SuccinctGateway smart contract, which is a simple entrypoint contract that verifies proofs (against a deployed onchain verifier for the Blobstream X circuit) and then calls the BlobstreamX.sol contract to update it. Find more information about the SuccinctGateway.

    blobstream x overview diagram draft

    NOTE

    If the Blobstream X contract is not deployed on a desired chain, it needs to be deployed before it can be used by your rollup. See the deployment documentation for more details.

    Deploy Blobstream X

    It is possible to deploy and maintain a Blobstream x instance and have the same security guarantees.

    First, you will need to create a multisig that governs the Blobstream X contract and also the function identifiers. The function identifiers can be registered in the Succinct gateway.

    Then, check the deployment documentation for how to deploy the contract.

    Then, you will need to run a relayer, which will generate the proofs and relay them to your deployed Blobstream X contract. Check the local proving documentation for more information.

    Community implementations

    Learn more about the community implementation of Blobstream proofs by CryptoKass.

    - +

    Blobstream X: the previous zk implementation of Blobstream

    blobstream x draft diagram

    What is Blobstream X?

    Blobstream X is the previous implementation of Blobstream. It uses plonky2x to create circuits that verify the Celestia consensus and generate the corresponding proofs.

    Blobstream X is built and deployed with Succinct's protocol.

    NOTE

    The Blobstream deployments below don't use the BlobstreamX circuits.

    You can find the repository for Blobstream X along with code for:

    NOTE

    Custom ranges can be requested using the BlobstreamX contract to create proofs for specific Celestia block batches. These ranges can be constructed as [latestBlock, customTargetBlock), with latestBlock as the latest block height that was committed to by the BlobstreamX contract, and latestBlock > customTargetBlock, and customTargetBlock - latestBlock <= DATA_COMMITMENT_MAX.

    Block ranges that are before the contract's latestBlock can't be proven a second time in different batches.

    More information can be found in the requestHeaderRange(...) method.

    How Blobstream X works

    As shown in the diagram below, the entrypoint for updates to the Blobstream X contract is through the SuccinctGateway smart contract, which is a simple entrypoint contract that verifies proofs (against a deployed onchain verifier for the Blobstream X circuit) and then calls the BlobstreamX.sol contract to update it. Find more information about the SuccinctGateway.

    blobstream x overview diagram draft

    NOTE

    If the Blobstream X contract is not deployed on a desired chain, it needs to be deployed before it can be used by your rollup. See the deployment documentation for more details.

    Deploy Blobstream X

    It is possible to deploy and maintain a Blobstream x instance and have the same security guarantees.

    First, you will need to create a multisig that governs the Blobstream X contract and also the function identifiers. The function identifiers can be registered in the Succinct gateway.

    Then, check the deployment documentation for how to deploy the contract.

    Then, you will need to run a relayer, which will generate the proofs and relay them to your deployed Blobstream X contract. Check the local proving documentation for more information.

    Community implementations

    Learn more about the community implementation of Blobstream proofs by CryptoKass.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/bridge-node.html b/pr-1815/how-to-guides/bridge-node.html index a00d69d61..adea22fcb 100644 --- a/pr-1815/how-to-guides/bridge-node.html +++ b/pr-1815/how-to-guides/bridge-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,14 +47,14 @@

    Setting up a Celestia bridge node

    This tutorial will go over the steps to setting up your Celestia bridge node.

    Bridge nodes connect the data availability layer and the consensus layer.

    Overview of bridge nodes

    A Celestia bridge node has the following properties:

    1. Import and process “raw” headers & blocks from a trusted core process (meaning a trusted RPC connection to a celestia-core node) in the Consensus network. Bridge nodes can run this core process internally (embedded) or simply connect to a remote endpoint. Bridge nodes also have the option of being an active validator in the consensus network.
    2. Validate and erasure code the “raw” blocks
    3. Supply block shares with data availability headers to light nodes in the DA network.

    bridge-node-diagram

    From an implementation perspective, Bridge nodes run two separate processes:

    1. celestia-app with celestia-core (see repo)

      • celestia-app is the state machine where the application and the proof-of-stake logic is run. celestia-app is built on Cosmos SDK and also encompasses celestia-core.
      • celestia-core is the state interaction, consensus and block production layer. celestia-core is built on Tendermint Core, modified to store data roots of erasure coded blocks among other changes (see ADRs).
    2. celestia-node (see repo)

      • celestia-node augments the above with a separate libp2p network that serves data availability sampling requests. The team sometimes refers to this as the “halo” network.

    Hardware requirements

    The following hardware minimum requirements are recommended for running the bridge node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your bridge node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    Follow the tutorial for installing the dependencies.

    Deploy the Celestia bridge node

    Install Celestia Node

    Install the celestia-node binary, which will be used to run the bridge node.

    Follow the tutorial for installing celestia-node.

    Initialize the bridge node

    Run the following:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from the list on the Mocha testnet page or list on the Arabica devnet page, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Here is an example of initializing the bridge node:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>
    sh
    celestia bridge init --core.ip <URI> --p2p.network mocha
    celestia bridge init --core.ip <URI> --p2p.network mocha
    sh
    celestia bridge init --core.ip <URI> --p2p.network arabica
    celestia bridge init --core.ip <URI> --p2p.network arabica

    Run the bridge node

    Start the bridge node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    sh
    celestia bridge start --core.ip <URI>
    celestia bridge start --core.ip <URI>

    Here is an example of starting the bridge node on Mocha:

    sh
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha

    And on Arabica:

    sh
    celestia bridge start --core.ip validator-1.celestia-arabica-11.com \
    +

    Setting up a Celestia bridge node

    This tutorial will go over the steps to setting up your Celestia bridge node.

    Bridge nodes connect the data availability layer and the consensus layer.

    Overview of bridge nodes

    A Celestia bridge node has the following properties:

    1. Import and process “raw” headers & blocks from a trusted core process (meaning a trusted RPC connection to a celestia-core node) in the Consensus network. Bridge nodes can run this core process internally (embedded) or simply connect to a remote endpoint. Bridge nodes also have the option of being an active validator in the consensus network.
    2. Validate and erasure code the “raw” blocks
    3. Supply block shares with data availability headers to light nodes in the DA network.

    bridge-node-diagram

    From an implementation perspective, Bridge nodes run two separate processes:

    1. celestia-app with celestia-core (see repo)

      • celestia-app is the state machine where the application and the proof-of-stake logic is run. celestia-app is built on Cosmos SDK and also encompasses celestia-core.
      • celestia-core is the state interaction, consensus and block production layer. celestia-core is built on Tendermint Core, modified to store data roots of erasure coded blocks among other changes (see ADRs).
    2. celestia-node (see repo)

      • celestia-node augments the above with a separate libp2p network that serves data availability sampling requests. The team sometimes refers to this as the “halo” network.

    Hardware requirements

    The following hardware minimum requirements are recommended for running the bridge node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your bridge node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    Follow the tutorial for installing the dependencies.

    Deploy the Celestia bridge node

    Install Celestia Node

    Install the celestia-node binary, which will be used to run the bridge node.

    Follow the tutorial for installing celestia-node.

    Initialize the bridge node

    Run the following:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from the list on the Mocha testnet page or list on the Arabica devnet page, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Here is an example of initializing the bridge node:

    sh
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>
    sh
    celestia bridge init --core.ip <URI> --p2p.network mocha
    celestia bridge init --core.ip <URI> --p2p.network mocha
    sh
    celestia bridge init --core.ip <URI> --p2p.network arabica
    celestia bridge init --core.ip <URI> --p2p.network arabica

    Run the bridge node

    Start the bridge node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    sh
    celestia bridge start --core.ip <URI>
    celestia bridge start --core.ip <URI>

    Here is an example of starting the bridge node on Mocha:

    sh
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha
    celestia bridge start --core.ip rpc-mocha.pops.one:26657 --p2p.network mocha

    And on Arabica:

    sh
    celestia bridge start --core.ip validator-1.celestia-arabica-11.com \
       --p2p.network arabica
    celestia bridge start --core.ip validator-1.celestia-arabica-11.com \
    -  --p2p.network arabica

    You can create your key for your node by following the cel-key instructions.

    Once you start the bridge node, a wallet key will be generated for you. You will need to fund that address with Testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a bridge node for your validator it is highly recommended to request Mocha testnet tokens as this is the testnet used to test out validator operations.

    Optional: run the bridge node with a custom key

    In order to run a bridge node using a custom key:

    1. The custom key must exist inside the celestia bridge node directory at the correct path (default: ~/.celestia-bridge/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \
    +  --p2p.network arabica

    You can create your key for your node by following the cel-key instructions.

    Once you start the bridge node, a wallet key will be generated for you. You will need to fund that address with Testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type bridge --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a bridge node for your validator it is highly recommended to request Mocha testnet tokens as this is the testnet used to test out validator operations.

    Optional: run the bridge node with a custom key

    In order to run a bridge node using a custom key:

    1. The custom key must exist inside the celestia bridge node directory at the correct path (default: ~/.celestia-bridge/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key>
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \
       --p2p.network mocha
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \
       --p2p.network mocha
    sh
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \
       --p2p.network arabica
    celestia bridge start --core.ip <URI> --keyring.keyname <name-of-custom-key> \
    -  --p2p.network arabica

    Optional: Migrate node id to another server

    To migrate a bridge node ID:

    1. You need to back up two files located in the celestia-bridge node directory at the correct path (default: ~/.celestia-bridge/keys).
    2. Upload the files to the new server and start the node.

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    - + --p2p.network arabica

    Optional: Migrate node id to another server

    To migrate a bridge node ID:

    1. You need to back up two files located in the celestia-bridge node directory at the correct path (default: ~/.celestia-bridge/keys).
    2. Upload the files to the new server and start the node.

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/bubs-testnet.html b/pr-1815/how-to-guides/bubs-testnet.html index 03f68a663..46996089a 100644 --- a/pr-1815/how-to-guides/bubs-testnet.html +++ b/pr-1815/how-to-guides/bubs-testnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Bubs testnet

    Bubs testnet

    Bubs Testnet is a the first OP Stack testnet with Celestia underneath hosted by Caldera with support from Celestia Labs. Bubs is dedicated to providing developers with an EVM-compatible execution layer to deploy their EVM applications on.

    Built with the OP Stack and Celestia

    The Bubs Testnet is a testnet rollup, a modified version of optimism-bedrock that uses Celestia as a data availability (DA) layer. This integration can be found in the @celestiaorg/optimism repository. The testnet is hosted by Caldera, who makes it easy to launch rollups with no code required. Bubs' data is posted to Celestia on the Mocha testnet. View the namespace for Bubs on Celestia's Mocha testnet.

    Learn more about the setup of the integration in the introduction.

    Building on Bubs

    Bubs Testnet provides a robust environment for developers to test their Ethereum Virtual Machine (EVM) applications. It offers an EVM-compatible execution layer, making it an ideal platform for developers looking to build and test applications in a setting that closely mirrors an OP Stack rollup on Celestia.

    Learn more at https://bubs-sepolia.hub.caldera.xyz/.

    RPC URLs

    Remote Procedure Call (RPC) URLs are endpoints that allow developers to interact with the blockchain. They are essential for sending transactions, querying blockchain data, and performing other interactions with the blockchain.

    For the Bubs Testnet, you can connect to the following RPC URLs:

    HTTPS

    • https://bubs-sepolia.rpc.caldera.xyz/http

    WSS

    • wss://bubs-sepolia.rpc.caldera.xyz/ws

    This URL serves as the entry point to the Bubs Testnet. You can use it in your applications to connect to the testnet and interact with the smart contracts you deploy there.

    Remember, Bubs Testnet is a testing environment!

    Bridge

    Bridging is a process that enables the transfer of assets between different blockchains.

    To bridge between Ethereum Sepolia and Bubs Testnet, visit the Bubs Testnet bridge.

    Faucet

    To visit the Bubs testnet faucet, go to https://bubs-sepolia.hub.caldera.xyz/ and click the "Faucet" tab.

    Explorer

    To visit the explorer, go to https://bubs-sepolia.explorer.caldera.xyz/.

    Status

    To see the status and uptime information for Bubs, visit the status page.

    Next steps

    Now that you have a better understanding of the Bubs Testnet and its integration of OP Stack and Celestia, you can start exploring its capabilities.

    - +

    Bubs testnet

    Bubs testnet

    Bubs Testnet is a the first OP Stack testnet with Celestia underneath hosted by Caldera with support from Celestia Labs. Bubs is dedicated to providing developers with an EVM-compatible execution layer to deploy their EVM applications on.

    Built with the OP Stack and Celestia

    The Bubs Testnet is a testnet rollup, a modified version of optimism-bedrock that uses Celestia as a data availability (DA) layer. This integration can be found in the @celestiaorg/optimism repository. The testnet is hosted by Caldera, who makes it easy to launch rollups with no code required. Bubs' data is posted to Celestia on the Mocha testnet. View the namespace for Bubs on Celestia's Mocha testnet.

    Learn more about the setup of the integration in the introduction.

    Building on Bubs

    Bubs Testnet provides a robust environment for developers to test their Ethereum Virtual Machine (EVM) applications. It offers an EVM-compatible execution layer, making it an ideal platform for developers looking to build and test applications in a setting that closely mirrors an OP Stack rollup on Celestia.

    Learn more at https://bubs-sepolia.hub.caldera.xyz/.

    RPC URLs

    Remote Procedure Call (RPC) URLs are endpoints that allow developers to interact with the blockchain. They are essential for sending transactions, querying blockchain data, and performing other interactions with the blockchain.

    For the Bubs Testnet, you can connect to the following RPC URLs:

    HTTPS

    • https://bubs-sepolia.rpc.caldera.xyz/http

    WSS

    • wss://bubs-sepolia.rpc.caldera.xyz/ws

    This URL serves as the entry point to the Bubs Testnet. You can use it in your applications to connect to the testnet and interact with the smart contracts you deploy there.

    Remember, Bubs Testnet is a testing environment!

    Bridge

    Bridging is a process that enables the transfer of assets between different blockchains.

    To bridge between Ethereum Sepolia and Bubs Testnet, visit the Bubs Testnet bridge.

    Faucet

    To visit the Bubs testnet faucet, go to https://bubs-sepolia.hub.caldera.xyz/ and click the "Faucet" tab.

    Explorer

    To visit the explorer, go to https://bubs-sepolia.explorer.caldera.xyz/.

    Status

    To see the status and uptime information for Bubs, visit the status page.

    Next steps

    Now that you have a better understanding of the Bubs Testnet and its integration of OP Stack and Celestia, you can start exploring its capabilities.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-commands.html b/pr-1815/how-to-guides/celestia-app-commands.html index 273fba130..824c381b5 100644 --- a/pr-1815/how-to-guides/celestia-app-commands.html +++ b/pr-1815/how-to-guides/celestia-app-commands.html @@ -7,11 +7,11 @@ - + - - + + @@ -259,8 +259,8 @@ --commission-max-rate=0.2 \ --commission-max-change-rate=0.01 \ --min-self-delegation=1 \ - --evm-address=$EVM_ADDRESS \

    You can then share your gentx JSON file on the networks repo in the respective network directory you are participating in.

    - + --evm-address=$EVM_ADDRESS \

    You can then share your gentx JSON file on the networks repo in the respective network directory you are participating in.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-metrics.html b/pr-1815/how-to-guides/celestia-app-metrics.html index 3e6cf13b5..045c2dd41 100644 --- a/pr-1815/how-to-guides/celestia-app-metrics.html +++ b/pr-1815/how-to-guides/celestia-app-metrics.html @@ -7,11 +7,11 @@ - + - - + + @@ -129,8 +129,8 @@ static_configs: # Point to the same endpoint that Celestia is publishing on - - targets: ["localhost:26660"]

    Note, that Prometheus by default runs its server on :9090. If you are running this on the same machine as your consensus node, it will collide with gRPC which runs on the same port. To avoid this, either switch off gRPC (if it's not needed), change the gRPC port in app.toml, or run Prometheus on a different port e.g. --web.listen-address="0.0.0.0:8000"

    To run the prometheus server:

    bash
    prometheus --config.file="$HOME/.celestia-app/config/prometheus.yml"
    prometheus --config.file="$HOME/.celestia-app/config/prometheus.yml"

    A prometheus server can scrape metrics from multiple nodes at once; a good way of bringing together information from many machines to one place.

    To visualize the information, you can use Grafana: either with their cloud option or run the open source code yourself.

    Once setup, run:

    bash
    grafana server
    grafana server

    which will begin a server on localhost:3000. If you open the url on your browser you will see the Grafana login page. Use admin for both the user and password to log in.

    You will need to link the prometheus server as a data source. To do that go to "Configuration" in the sidebar and then "Data Sources". Add a new data source specifying the URL of the Prometheus instance (default at localhost:9090). Click "Save & test" to confirm.

    Lastly, you will need to setup a dashboard. You can choose to do this yourself, handpicking the metrics that are important or you can simply export an existing design. Fortunately the cosmos ecosystem has conjured a "Cosmos Dashboard". On the sidebar, click "Dashboards" and then "import". Enter the following dashboard ID: 11036 and then link it to the "Prometheus" data source you just set up. Finally click the "Import" button and the "Cosmos Dashboard" should appear.

    Node exporter

    Celestia's metrics include a plethora of application specific trackers but it's also important to keep an eye on system level metrics such as memory usage and disk space. This can be best achieved by running Node Exporter. Follow the guide in the link to get set up, adding the port number to the prometheus.yml file.

    Alerts

    The final cherry on the cake is to integrate your monitoring system with a mechanism for producing alerts to warn you if your node has crashed or is no longer able to stay at the head of the chain.

    Since we're already using Grafana, we can install the Grafana OnCall plugin. OnCall allows you to setup integrations. It could be a webhook or a direct integration into Telegram or Slack. You can find more information on Grafana's Docs Page.

    - + - targets: ["localhost:26660"]

    Note, that Prometheus by default runs its server on :9090. If you are running this on the same machine as your consensus node, it will collide with gRPC which runs on the same port. To avoid this, either switch off gRPC (if it's not needed), change the gRPC port in app.toml, or run Prometheus on a different port e.g. --web.listen-address="0.0.0.0:8000"

    To run the prometheus server:

    bash
    prometheus --config.file="$HOME/.celestia-app/config/prometheus.yml"
    prometheus --config.file="$HOME/.celestia-app/config/prometheus.yml"

    A prometheus server can scrape metrics from multiple nodes at once; a good way of bringing together information from many machines to one place.

    To visualize the information, you can use Grafana: either with their cloud option or run the open source code yourself.

    Once setup, run:

    bash
    grafana server
    grafana server

    which will begin a server on localhost:3000. If you open the url on your browser you will see the Grafana login page. Use admin for both the user and password to log in.

    You will need to link the prometheus server as a data source. To do that go to "Configuration" in the sidebar and then "Data Sources". Add a new data source specifying the URL of the Prometheus instance (default at localhost:9090). Click "Save & test" to confirm.

    Lastly, you will need to setup a dashboard. You can choose to do this yourself, handpicking the metrics that are important or you can simply export an existing design. Fortunately the cosmos ecosystem has conjured a "Cosmos Dashboard". On the sidebar, click "Dashboards" and then "import". Enter the following dashboard ID: 11036 and then link it to the "Prometheus" data source you just set up. Finally click the "Import" button and the "Cosmos Dashboard" should appear.

    Node exporter

    Celestia's metrics include a plethora of application specific trackers but it's also important to keep an eye on system level metrics such as memory usage and disk space. This can be best achieved by running Node Exporter. Follow the guide in the link to get set up, adding the port number to the prometheus.yml file.

    Alerts

    The final cherry on the cake is to integrate your monitoring system with a mechanism for producing alerts to warn you if your node has crashed or is no longer able to stay at the head of the chain.

    Since we're already using Grafana, we can install the Grafana OnCall plugin. OnCall allows you to setup integrations. It could be a webhook or a direct integration into Telegram or Slack. You can find more information on Grafana's Docs Page.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-multisig.html b/pr-1815/how-to-guides/celestia-app-multisig.html index ae151104b..4f4587bed 100644 --- a/pr-1815/how-to-guides/celestia-app-multisig.html +++ b/pr-1815/how-to-guides/celestia-app-multisig.html @@ -7,11 +7,11 @@ - + - - + + @@ -149,8 +149,8 @@ celestia-appd tx multisign unsignedTx.json multisig \ test1sig.json test2sig.json \ --output-document signedTx.json \ - --chain-id $CHAIN_ID

    Resources

    - + --chain-id $CHAIN_ID

    Resources

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-slashing.html b/pr-1815/how-to-guides/celestia-app-slashing.html index fed2469f6..713da8e1f 100644 --- a/pr-1815/how-to-guides/celestia-app-slashing.html +++ b/pr-1815/how-to-guides/celestia-app-slashing.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Jailing and slashing on Celestia

    Slashing is a mechanism employed in proof of stake blockchains that is used to deter and punish malicious behavior. It functions by removing a percentage of a validator's stake each time they act harmfully towards the network.

    Celestia is built with the Cosmos SDK and uses the x/slashing module.

    If a validator gets slashed, delegators bonded to that validator will also have the same percentage of their delegated funds slashed.

    The following are the conditions for a validator to get jailed or slashed:

    1. Downtime: If a validator is offline for more than 25% of a rolling window of the last 5,000 blocks, they will be jailed for 1 minute. During this period, the validator is removed from the validator set temporarily, and will be unable to propose new blocks or earn rewards. After the jail period, the validator can send an unjail request to rejoin the validator set.

    2. Double signing: This is a more severe offense and results in getting slashed. If a validator engages in double signing, the validator will lose 2% of their stake and the remainder of their stake will be returned to them. The validator will be permanently removed from the validator set and will not have the ability to unjail. Delegators bonded to that validator will automatically enter the unbonding period for 21 days, and can delegate to another validator after they have been unbonded.

    For more details on the jailing and slashing parameters, refer to the celestia-app specifications page.

    - +

    Jailing and slashing on Celestia

    Slashing is a mechanism employed in proof of stake blockchains that is used to deter and punish malicious behavior. It functions by removing a percentage of a validator's stake each time they act harmfully towards the network.

    Celestia is built with the Cosmos SDK and uses the x/slashing module.

    If a validator gets slashed, delegators bonded to that validator will also have the same percentage of their delegated funds slashed.

    The following are the conditions for a validator to get jailed or slashed:

    1. Downtime: If a validator is offline for more than 25% of a rolling window of the last 5,000 blocks, they will be jailed for 1 minute. During this period, the validator is removed from the validator set temporarily, and will be unable to propose new blocks or earn rewards. After the jail period, the validator can send an unjail request to rejoin the validator set.

    2. Double signing: This is a more severe offense and results in getting slashed. If a validator engages in double signing, the validator will lose 2% of their stake and the remainder of their stake will be returned to them. The validator will be permanently removed from the validator set and will not have the ability to unjail. Delegators bonded to that validator will automatically enter the unbonding period for 21 days, and can delegate to another validator after they have been unbonded.

    For more details on the jailing and slashing parameters, refer to the celestia-app specifications page.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-upgrade-monitor.html b/pr-1815/how-to-guides/celestia-app-upgrade-monitor.html index 12c4057a1..1c6fc1495 100644 --- a/pr-1815/how-to-guides/celestia-app-upgrade-monitor.html +++ b/pr-1815/how-to-guides/celestia-app-upgrade-monitor.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Upgrade Monitor

    Upgrade monitor is a binary that monitors that status of upgrades on a Celestia network. See the README for instructions on how to install and use the binary.

    - +

    Upgrade Monitor

    Upgrade monitor is a binary that monitors that status of upgrades on a Celestia network. See the README for instructions on how to install and use the binary.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-vesting.html b/pr-1815/how-to-guides/celestia-app-vesting.html index 0940296bf..bd4521c4c 100644 --- a/pr-1815/how-to-guides/celestia-app-vesting.html +++ b/pr-1815/how-to-guides/celestia-app-vesting.html @@ -7,11 +7,11 @@ - + - - + + @@ -261,8 +261,8 @@ # <host>:<port> to Tendermint RPC interface for this chain node = "tcp://rpc-mocha.pops.one:443" # Transaction broadcasting mode (sync|async|block) -broadcast-mode = "sync"

    Notes

    Not all vesting accounts can be created with a message, some need to be set at genesis. You can learn more in the Cosmos Network documentation.

    Conclusion

    Congratulations! You've learned how to create a local devnet, create a vesting account on it, and how to make a vesting account on the Mocha testnet!

    - +broadcast-mode = "sync"

    Notes

    Not all vesting accounts can be created with a message, some need to be set at genesis. You can learn more in the Cosmos Network documentation.

    Conclusion

    Congratulations! You've learned how to create a local devnet, create a vesting account on it, and how to make a vesting account on the Mocha testnet!

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app-wallet.html b/pr-1815/how-to-guides/celestia-app-wallet.html index be4a5d3e6..99a70f32c 100644 --- a/pr-1815/how-to-guides/celestia-app-wallet.html +++ b/pr-1815/how-to-guides/celestia-app-wallet.html @@ -7,11 +7,11 @@ - + - - + + @@ -49,8 +49,8 @@

    Create a wallet with celestia-app

    For this guide, we will go over how you can generate a Celestia wallet using celestia-app.

    Prerequisites

    Note, you do not need to install celestia-node for this tutorial.

    Create a wallet

    First, create an application CLI configuration file:

    sh
    celestia-appd config keyring-backend test
    celestia-appd config keyring-backend test

    You can pick whatever wallet name you want. For our example we used "validator" as the wallet name:

    sh
    celestia-appd keys add validator --interactive
    celestia-appd keys add validator --interactive

    Save the mnemonic output as this is the only way to recover your validator wallet in case you lose it!

    To check all your wallets you can run:

    sh
    celestia-appd keys list
    celestia-appd keys list

    Fund a wallet

    For the public celestia address, you can fund the previously created wallet via Discord by sending this message to either the #mocha-faucet or #arabica-faucet channel:

    text
    $request celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    $request celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

    Wait to see if you get a confirmation that the tokens have been successfully sent. To check if tokens have arrived successfully to the destination wallet run the command below replacing the public address with your own:

    sh
    celestia-appd start
     celestia-appd query bank balances celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    celestia-appd start
    -celestia-appd query bank balances celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    - +celestia-appd query bank balances celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-app.html b/pr-1815/how-to-guides/celestia-app.html index 6037a2e97..817aed7ed 100644 --- a/pr-1815/how-to-guides/celestia-app.html +++ b/pr-1815/how-to-guides/celestia-app.html @@ -7,14 +7,14 @@ - + - + - + @@ -56,8 +56,8 @@ cd celestia-app
    cd $HOME
     rm -rf celestia-app
     git clone https://github.com/celestiaorg/celestia-app.git
    -cd celestia-app
  • Check out to the desired version, based on the network you will use:

    bash
    git checkout tags/v2.3.1
    git checkout tags/v2.3.1
    bash
    git checkout tags/v3.0.1-mocha
    git checkout tags/v3.0.1-mocha
    bash
    git checkout tags/v3.0.1-arabica
    git checkout tags/v3.0.1-arabica
  • Build and install the celestia-appd binary:

    bash
    make install
    make install
  • To check if the binary was successfully installed you can run the binary using the --help flag:

    sh
    celestia-appd --help
    celestia-appd --help
  • You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia consensus node. Releases after celestia-app v1.3.0 should have these binaries available.

    The steps below will download a binary file named celestia-appd. Depending on the setup that you choose during installation, the celestia-appd binary will be available at either:

    • $HOME/celestia-app-temp/celestia-appd
    • /usr/local/bin/celestia-appd

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    To install the latest pre-built binary you can run this command in your terminal:

    bash
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"

    Follow the instructions in the terminal output to choose your installation preferences.

    You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    View the script to learn more about what it is doing.

    Ports

    When interacting with a consensus node, you may need to open ports on your machine to allow communication between nodes, such as bridge nodes. It is essential that specific ports are accessible. Make sure that your firewall allows connections to the correct ports.

    If you run a node on a cloud server, make sure that the ports are open on the server's firewall. If you run a node at home, make sure that your router allows connections to the correct ports.

    For example, validator ports 9090 and 26657 need to be accessible by the bridge, and port 2121 is required for P2P connections for all node types.

    The following ports are used by Celestia app nodes:

    PortProtocolAddressDescriptionEnabled by default on nodeFlag
    2121TCP/UDPlocalhostP2PtrueN/A
    9090HTTP0.0.0.0gRPCtrue--grpc.address string
    26657TCPlocalhostRPCfalse (only open to localhost)--rpc.laddr string
    - +cd celestia-app
  • Check out to the desired version, based on the network you will use:

    bash
    git checkout tags/v2.3.1
    git checkout tags/v2.3.1
    bash
    git checkout tags/v3.0.1-mocha
    git checkout tags/v3.0.1-mocha
    bash
    git checkout tags/v3.0.1-arabica
    git checkout tags/v3.0.1-arabica
  • Build and install the celestia-appd binary:

    bash
    make install
    make install
  • To check if the binary was successfully installed you can run the binary using the --help flag:

    sh
    celestia-appd --help
    celestia-appd --help
  • You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia consensus node. Releases after celestia-app v1.3.0 should have these binaries available.

    The steps below will download a binary file named celestia-appd. Depending on the setup that you choose during installation, the celestia-appd binary will be available at either:

    • $HOME/celestia-app-temp/celestia-appd
    • /usr/local/bin/celestia-appd

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    To install the latest pre-built binary you can run this command in your terminal:

    bash
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/celestia-app.sh)"

    Follow the instructions in the terminal output to choose your installation preferences.

    You will see an output with the menu for celestia-appd. Learn more on the helpful CLI commands page

    View the script to learn more about what it is doing.

    Ports

    When interacting with a consensus node, you may need to open ports on your machine to allow communication between nodes, such as bridge nodes. It is essential that specific ports are accessible. Make sure that your firewall allows connections to the correct ports.

    If you run a node on a cloud server, make sure that the ports are open on the server's firewall. If you run a node at home, make sure that your router allows connections to the correct ports.

    For example, validator ports 9090 and 26657 need to be accessible by the bridge, and port 2121 is required for P2P connections for all node types.

    The following ports are used by Celestia app nodes:

    PortProtocolAddressDescriptionEnabled by default on nodeFlag
    2121TCP/UDPlocalhostP2PtrueN/A
    9090HTTP0.0.0.0gRPCtrue--grpc.address string
    26657TCPlocalhostRPCfalse (only open to localhost)--rpc.laddr string
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-node-custom-networks.html b/pr-1815/how-to-guides/celestia-node-custom-networks.html index 9f4ec0269..0ed4d59e5 100644 --- a/pr-1815/how-to-guides/celestia-node-custom-networks.html +++ b/pr-1815/how-to-guides/celestia-node-custom-networks.html @@ -7,11 +7,11 @@ - + - - + + @@ -59,8 +59,8 @@ export CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"
    export BRIDGE="/ip4/151.115.14.33/tcp/2121/p2p/12D3KooWKEeRtzVMPUdxYsZo2edqps6mS67n6LT5mPdULSkPSxBQ"
     export GENESIS_HASH=580B3DFF8A7C716968161D91116A1E171F486298D582874E93714E489C9E6E88
     export NETWORK=custom
    -export CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"

    Then, start your node with:

    bash
    celestia <node-type> start [flags...]
    celestia <node-type> start [flags...]
    - +export CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"

    Then, start your node with:

    bash
    celestia <node-type> start [flags...]
    celestia <node-type> start [flags...]
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-node-metrics.html b/pr-1815/how-to-guides/celestia-node-metrics.html index 6f3e83f29..9f583a271 100644 --- a/pr-1815/how-to-guides/celestia-node-metrics.html +++ b/pr-1815/how-to-guides/celestia-node-metrics.html @@ -7,11 +7,11 @@ - + - - + + @@ -79,8 +79,8 @@ # To disable TLS connection celestia <node-type> start --metrics.tls=false --metrics \ --metrics.endpoint <URI> \ - --p2p.network <network> --core.ip <URI>

    Metrics endpoint design considerations

    At the moment, the architecture of celestia-node metrics works as specified in the following ADR #010.

    Essentially, the design considerations here will necessitate running an OpenTelemetry (OTEL) collector that connects to Celestia light node.

    For an overview of OTEL, check out the guide.

    The ADR and the OTEL docs will help you run your collector on the metrics endpoint. This will then allow you to process the data in the collector on a Prometheus server which can then be viewed on a Grafana dashboard.

    In the future, we do want to open-source some developer toolings around this infrastructure to allow for node operators to be able to monitor their data availability nodes.

    - + --p2p.network <network> --core.ip <URI>

    Metrics endpoint design considerations

    At the moment, the architecture of celestia-node metrics works as specified in the following ADR #010.

    Essentially, the design considerations here will necessitate running an OpenTelemetry (OTEL) collector that connects to Celestia light node.

    For an overview of OTEL, check out the guide.

    The ADR and the OTEL docs will help you run your collector on the metrics endpoint. This will then allow you to process the data in the collector on a Prometheus server which can then be viewed on a Grafana dashboard.

    In the future, we do want to open-source some developer toolings around this infrastructure to allow for node operators to be able to monitor their data availability nodes.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-node-store-structure.html b/pr-1815/how-to-guides/celestia-node-store-structure.html index ed9cec79b..411df66b0 100644 --- a/pr-1815/how-to-guides/celestia-node-store-structure.html +++ b/pr-1815/how-to-guides/celestia-node-store-structure.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    celestia-node datastore

    The node's datastore refers to the storage structure used to manage the data that supports the node's operation. It consists of directories and files that contain the node's state, configuration, and other information relevant to the node.

    The following are the directories and files found in the datastore:

    • /blocks: This directory stores blocks. Each file contained in this directory represents a block on Celestia and contains its associated data. This directory is present in the datastore for bridge and full nodes but not light nodes, as light nodes do not store blocks.

    • /data: This directory contains block headers and various files belonging to the node's log-structured merge (LSM) storage system. The LSM files (such as DISCARD, KEYREGISTRY, and MANIFEST) manage the efficient storage and retrieval of data.

    • /index: This directory stores the index files that handle mapping specific keys such as block heights, to the corresponding data. Similar to /blocks, the light node's datastore does not include this directory, as they do not perform indexing.

    • /inverted_index: This directory stores the inverted index files used for mapping queries to the corresponding data location, along with associated LSM storage system files. The light node's datastore does not contain this directory.

    • /keys: This directory stores the cryptographic key pairs that are used to operate the node.

    • /transients: This directory contains temporary data such as cache files that are used while the node is operating, but are not a part of the permanent blockchain state.

    • config.toml: Located in the node's root directory, this is the primary configuration file that defines core settings such as network parameters, P2P configuration, and API endpoints. This file is generated during node initialization.

    - +

    celestia-node datastore

    The node's datastore refers to the storage structure used to manage the data that supports the node's operation. It consists of directories and files that contain the node's state, configuration, and other information relevant to the node.

    The following are the directories and files found in the datastore:

    • /blocks: This directory stores blocks. Each file contained in this directory represents a block on Celestia and contains its associated data. This directory is present in the datastore for bridge and full nodes but not light nodes, as light nodes do not store blocks.

    • /data: This directory contains block headers and various files belonging to the node's log-structured merge (LSM) storage system. The LSM files (such as DISCARD, KEYREGISTRY, and MANIFEST) manage the efficient storage and retrieval of data.

    • /index: This directory stores the index files that handle mapping specific keys such as block heights, to the corresponding data. Similar to /blocks, the light node's datastore does not include this directory, as they do not perform indexing.

    • /inverted_index: This directory stores the inverted index files used for mapping queries to the corresponding data location, along with associated LSM storage system files. The light node's datastore does not contain this directory.

    • /keys: This directory stores the cryptographic key pairs that are used to operate the node.

    • /transients: This directory contains temporary data such as cache files that are used while the node is operating, but are not a part of the permanent blockchain state.

    • config.toml: Located in the node's root directory, this is the primary configuration file that defines core settings such as network parameters, P2P configuration, and API endpoints. This file is generated during node initialization.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-node-troubleshooting.html b/pr-1815/how-to-guides/celestia-node-troubleshooting.html index ff12ca6d5..858afa316 100644 --- a/pr-1815/how-to-guides/celestia-node-troubleshooting.html +++ b/pr-1815/how-to-guides/celestia-node-troubleshooting.html @@ -7,12 +7,12 @@ - + - + - + @@ -108,8 +108,8 @@ ...
    [Service]
     ...
     LimitNOFILE=1400000
    -...

    NOTE

    Be cautious when increasing file descriptor limits. Setting this value too high might affect system performance. Ensure the value is appropriate for your system's capabilities.

    1. Reload daemon and restart bridge service:
    bash
    sudo systemctl daemon-reload
    sudo systemctl daemon-reload
    bash
    sudo systemctl restart celestia-bridge
    sudo systemctl restart celestia-bridge
    - +...

    NOTE

    Be cautious when increasing file descriptor limits. Setting this value too high might affect system performance. Ensure the value is appropriate for your system's capabilities.

    1. Reload daemon and restart bridge service:
    bash
    sudo systemctl daemon-reload
    sudo systemctl daemon-reload
    bash
    sudo systemctl restart celestia-bridge
    sudo systemctl restart celestia-bridge
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-node-trusted-hash.html b/pr-1815/how-to-guides/celestia-node-trusted-hash.html index 6e36da90b..b1bec3cbc 100644 --- a/pr-1815/how-to-guides/celestia-node-trusted-hash.html +++ b/pr-1815/how-to-guides/celestia-node-trusted-hash.html @@ -7,11 +7,11 @@ - + - - + + @@ -49,8 +49,8 @@

    Syncing a light node from a trusted hash

    This guide goes over how to sync a DA light node from a trusted hash. The example is with Mainnet Beta. You will need to adjust the commands accordingly for Mocha, Arabica, or a custom network.

    WARNING

    Syncing to a trusted hash means that you will not sample the entire chain. This adds a trust assumption that you trust the history of the chain up to that point and that you trust the entity where you get the hash from. In this example, the trusted entity is a consensus endpoint or Celenium.

    1. Get trusted height & hash from a consensus endpoint or Celenium.

    2. Initialize the node store

      sh
      celestia light init --p2p.network <network>
      celestia light init --p2p.network <network>
    3. Set the trusted height & hash

      1. Open your config.toml at .celestia-light/config.toml (or .celestia-light-<other-network>/config.toml)
      2. Set DASer.SampleFrom to the trusted height (e.g. SampleFrom = 123456)
    4. Run the node with the hash and flag:

    sh
    celestia light start --headers.trusted-hash <hash_of_block_n> \
         --p2p.network <network> --core.ip <consensus-node-rpc>
    celestia light start --headers.trusted-hash <hash_of_block_n> \
    -    --p2p.network <network> --core.ip <consensus-node-rpc>

    For service operators

    If you're using multiple light nodes for similar services like tracking the same rollup, it is recommended to use the same hash and height for them all services using the same starting height.

    - + --p2p.network <network> --core.ip <consensus-node-rpc>

    For service operators

    If you're using multiple light nodes for similar services like tracking the same rollup, it is recommended to use the same hash and height for them all services using the same starting height.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/celestia-node.html b/pr-1815/how-to-guides/celestia-node.html index ff464bee9..b05119eb2 100644 --- a/pr-1815/how-to-guides/celestia-node.html +++ b/pr-1815/how-to-guides/celestia-node.html @@ -7,14 +7,14 @@ - + - + - + @@ -56,7 +56,7 @@ cd celestia-node/
    cd $HOME
     rm -rf celestia-node
     git clone https://github.com/celestiaorg/celestia-node.git
    -cd celestia-node/
  • Check out to the desired version, based on the network you will use:

    bash
    git checkout tags/v0.20.4
    git checkout tags/v0.20.4
    bash
    git checkout tags/v0.20.4-mocha
    git checkout tags/v0.20.4-mocha
    bash
    git checkout tags/v0.20.4-arabica
    git checkout tags/v0.20.4-arabica
  • Build the celestia binary:

    a. Standard build

    bash
    make build
    make build

    b. Experimental build

    OPTIONAL

    If you're a node operator comfortable with experimental features and seeking optimal performance with minimal RAM usage, this option is recommended for you.

    bash
    make build-jemalloc
    make build-jemalloc

    This build option enables CGO, and downloads and installs jemalloc. Learn more about the build command.

  • Install the binary:

    bash
    make install
    make install
  • Build the cel-key utility:

    bash
    make cel-key
    make cel-key
  • Verify that the binary is working and check the version:

    bash
    celestia version
    celestia version
  • The output will show the semantic version of celestia-node, commit hash, build date, system version, and Golang version.

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia data availability node. Releases after celestia-node v0.13.3 have these binaries available.

    The installation script will download a binary file named celestia. Depending on your chosen installation option, the celestia binary will be available at one of these locations:

    • $GOPATH/bin/celestia (if Go is installed)
    • /usr/local/bin/celestia
    • $HOME/celestia-node-temp/celestia

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    Installation Options

    You can install the latest version or specify a particular version:

    bash
    # Install latest version
    +cd celestia-node/
  • Check out to the desired version, based on the network you will use:

    bash
    git checkout tags/v0.20.4
    git checkout tags/v0.20.4
    bash
    git checkout tags/v0.20.4-mocha
    git checkout tags/v0.20.4-mocha
    bash
    git checkout tags/v0.20.4-arabica
    git checkout tags/v0.20.4-arabica
  • Build the celestia binary:

    a. Standard build

    bash
    make build
    make build

    b. Experimental build

    OPTIONAL

    If you're a node operator comfortable with experimental features and seeking optimal performance with minimal RAM usage, this option is recommended for you.

    bash
    make build-jemalloc
    make build-jemalloc

    This build option enables CGO, and downloads and installs jemalloc. Learn more about the build command.

  • Install the binary:

    bash
    make install
    make install
  • Build the cel-key utility:

    bash
    make cel-key
    make cel-key
  • Verify that the binary is working and check the version:

    bash
    celestia version
    celestia version
  • The output will show the semantic version of celestia-node, commit hash, build date, system version, and Golang version.

    Installing a pre-built binary

    Installing a pre-built binary is the fastest way to get started with your Celestia data availability node. Releases after celestia-node v0.13.3 have these binaries available.

    The installation script will download a binary file named celestia. Depending on your chosen installation option, the celestia binary will be available at one of these locations:

    • $GOPATH/bin/celestia (if Go is installed)
    • /usr/local/bin/celestia
    • $HOME/celestia-node-temp/celestia

    Pre-built binaries are available for:

    • Operating systems: Darwin (Apple), Linux
    • Architectures: x86_64 (amd64), arm64

    Installation Options

    You can install the latest version or specify a particular version:

    bash
    # Install latest version
     bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"
     
     # Install specific version, Mainnet Beta in this example
    @@ -64,8 +64,8 @@
     bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"
     
     # Install specific version, Mainnet Beta in this example
    -bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)" -- -v v0.20.4

    The script will:

    1. Detect your system's operating system and architecture
    2. Download the appropriate binary
    3. Verify the checksum for security
    4. Provide installation location options based on your environment:
      • If Go is installed:
        • Go bin directory ($GOPATH/bin)
        • System bin directory (/usr/local/bin)
        • Keep in current directory
      • If Go is not installed:
        • System bin directory (/usr/local/bin)
        • Keep in current directory

    Follow the instructions in the terminal output to choose your installation preferences. After installation, you can verify the setup by checking the version:

    bash
    celestia version && celestia --help
    celestia version && celestia --help

    View the script to learn more about what it is doing.

    Note: The script maintains a log file at $HOME/celestia-node-temp/logfile.log for troubleshooting purposes.

    Next steps

    First, we recommend reading the overview of our node types, if you haven't yet.

    Now that you've installed Celestia Node, it's time to pick your node type and run your node!

    If you're planning to run a light node, we recommend the node RPC CLI tutorial.

    Upgrading your binary

    To upgrade your binary, you can install the latest version from the instructions above and restart your node. If you run into any issues, Refer to the troubleshooting section.

    - +bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)" -- -v v0.20.4

    The script will:

    1. Detect your system's operating system and architecture
    2. Download the appropriate binary
    3. Verify the checksum for security
    4. Provide installation location options based on your environment:
      • If Go is installed:
        • Go bin directory ($GOPATH/bin)
        • System bin directory (/usr/local/bin)
        • Keep in current directory
      • If Go is not installed:
        • System bin directory (/usr/local/bin)
        • Keep in current directory

    Follow the instructions in the terminal output to choose your installation preferences. After installation, you can verify the setup by checking the version:

    bash
    celestia version && celestia --help
    celestia version && celestia --help

    View the script to learn more about what it is doing.

    Note: The script maintains a log file at $HOME/celestia-node-temp/logfile.log for troubleshooting purposes.

    Next steps

    First, we recommend reading the overview of our node types, if you haven't yet.

    Now that you've installed Celestia Node, it's time to pick your node type and run your node!

    If you're planning to run a light node, we recommend the node RPC CLI tutorial.

    Upgrading your binary

    To upgrade your binary, you can install the latest version from the instructions above and restart your node. If you run into any issues, Refer to the troubleshooting section.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/config-toml.html b/pr-1815/how-to-guides/config-toml.html index 0b4ea74a2..0b6a654c6 100644 --- a/pr-1815/how-to-guides/config-toml.html +++ b/pr-1815/how-to-guides/config-toml.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    config.toml guide

    Pre-requisites

    Please, make sure that you have installed and initialized celestia-node

    Viewing the help menu

    In order to view all flags and their descriptions, use:

    bash
    celestia light start --help
    celestia light start --help

    Understanding config.toml

    After initialization, for any type of node, you will find a config.toml in the following path (default location):

    • $HOME/.celestia-bridge/config.toml for bridge node
    • $HOME/.celestia-light/config.toml for light node
    • $HOME/.celestia-full/config.toml for a full DA node

    Let's break down some of the most used sections.

    Core

    This section is needed for the Celestia bridge node. By default, Remote = false. Still for devnet, we are going to use the remote core option and this can also be set by the command line flag --core.remote.

    P2P

    Bootstrap

    Bootstrappers help new nodes to find peers faster in the network. By default, the Bootstrapper = false and the BootstrapPeers is empty. If you want your node to be a bootstrapper, then activate Bootstrapper = true. BootstrapPeers are already provided by default during initialisation. If you want to add your own manually, you need to provide the multiaddresses of the peers.

    Mutual peers

    The purpose of this config is to set up a bidirectional communication. This is usually the case for Celestia bridge nodes. In addition, you need to change the field PeerExchange from false to true.

    Services

    TrustedHash and TrustedPeer

    TrustedHash is needed to properly initialize a Celestia bridge node with an already-running Remote celestia-core node. Celestia light node will take a genesis hash as the trusted one, if no hash is manually provided during initialization phase.

    TrustedPeers is the array of bridge nodes' peers that Celestia light node trusts. By default, bootstrap peers becomes trusted peers for Celestia light nodes if a user is not setting the trusted peer params in config file.

    Any Celestia bridge node can be a trusted peer for the light one. However, the light node by design can not be a trusted peer for another light node.

    - +

    config.toml guide

    Pre-requisites

    Please, make sure that you have installed and initialized celestia-node

    Viewing the help menu

    In order to view all flags and their descriptions, use:

    bash
    celestia light start --help
    celestia light start --help

    Understanding config.toml

    After initialization, for any type of node, you will find a config.toml in the following path (default location):

    • $HOME/.celestia-bridge/config.toml for bridge node
    • $HOME/.celestia-light/config.toml for light node
    • $HOME/.celestia-full/config.toml for a full DA node

    Let's break down some of the most used sections.

    Core

    This section is needed for the Celestia bridge node. By default, Remote = false. Still for devnet, we are going to use the remote core option and this can also be set by the command line flag --core.remote.

    P2P

    Bootstrap

    Bootstrappers help new nodes to find peers faster in the network. By default, the Bootstrapper = false and the BootstrapPeers is empty. If you want your node to be a bootstrapper, then activate Bootstrapper = true. BootstrapPeers are already provided by default during initialisation. If you want to add your own manually, you need to provide the multiaddresses of the peers.

    Mutual peers

    The purpose of this config is to set up a bidirectional communication. This is usually the case for Celestia bridge nodes. In addition, you need to change the field PeerExchange from false to true.

    Services

    TrustedHash and TrustedPeer

    TrustedHash is needed to properly initialize a Celestia bridge node with an already-running Remote celestia-core node. Celestia light node will take a genesis hash as the trusted one, if no hash is manually provided during initialization phase.

    TrustedPeers is the array of bridge nodes' peers that Celestia light node trusts. By default, bootstrap peers becomes trusted peers for Celestia light nodes if a user is not setting the trusted peer params in config file.

    Any Celestia bridge node can be a trusted peer for the light one. However, the light node by design can not be a trusted peer for another light node.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/consensus-node.html b/pr-1815/how-to-guides/consensus-node.html index 0cede7732..ae2253f58 100644 --- a/pr-1815/how-to-guides/consensus-node.html +++ b/pr-1815/how-to-guides/consensus-node.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,7 +48,7 @@

    Consensus node

    This guide covers how to set up a consensus node on Celestia. Consensus nodes allow you to sync the entire blockchain history in the Celestia consensus layer.

    consensus node

    Minimum hardware requirements

    The following minimum hardware requirements are recommended for running a consensus node:

    • Memory: 16 GB RAM
    • CPU: Quad-Core
    • Disk: 2 TB SSD Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Set up a consensus node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up the dependencies

    Follow the instructions on installing dependencies.

    Install celestia-app

    Follow the tutorial on installing celestia-app.

    Set up the P2P networks

    To initialize the network, pick a "node-name" that describes your node. Keep in mind that this might change if a new testnet is deployed.

    bash
    celestia-appd init "node-name" --chain-id celestia
    celestia-appd init "node-name" --chain-id celestia
    bash
    celestia-appd init "node-name" --chain-id mocha-4
    celestia-appd init "node-name" --chain-id mocha-4
    bash
    celestia-appd init "node-name" --chain-id arabica-11
    celestia-appd init "node-name" --chain-id arabica-11

    Download the genesis.json file:

    bash
    celestia-appd download-genesis celestia
    celestia-appd download-genesis celestia
    bash
    celestia-appd download-genesis mocha-4
    celestia-appd download-genesis mocha-4
    bash
    celestia-appd download-genesis arabica-11
    celestia-appd download-genesis arabica-11

    Set seeds in the $HOME/.celestia-app/config/config.toml file:

    bash
    SEEDS=$(curl -sL https://raw.githubusercontent.com/celestiaorg/networks/master/celestia/seeds.txt | tr '\n' ',')
    +

    Consensus node

    This guide covers how to set up a consensus node on Celestia. Consensus nodes allow you to sync the entire blockchain history in the Celestia consensus layer.

    consensus node

    Minimum hardware requirements

    The following minimum hardware requirements are recommended for running a consensus node:

    • Memory: 16 GB RAM
    • CPU: Quad-Core
    • Disk: 2 TB SSD Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Set up a consensus node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up the dependencies

    Follow the instructions on installing dependencies.

    Install celestia-app

    Follow the tutorial on installing celestia-app.

    Set up the P2P networks

    To initialize the network, pick a "node-name" that describes your node. Keep in mind that this might change if a new testnet is deployed.

    bash
    celestia-appd init "node-name" --chain-id celestia
    celestia-appd init "node-name" --chain-id celestia
    bash
    celestia-appd init "node-name" --chain-id mocha-4
    celestia-appd init "node-name" --chain-id mocha-4
    bash
    celestia-appd init "node-name" --chain-id arabica-11
    celestia-appd init "node-name" --chain-id arabica-11

    Download the genesis.json file:

    bash
    celestia-appd download-genesis celestia
    celestia-appd download-genesis celestia
    bash
    celestia-appd download-genesis mocha-4
    celestia-appd download-genesis mocha-4
    bash
    celestia-appd download-genesis arabica-11
    celestia-appd download-genesis arabica-11

    Set seeds in the $HOME/.celestia-app/config/config.toml file:

    bash
    SEEDS=$(curl -sL https://raw.githubusercontent.com/celestiaorg/networks/master/celestia/seeds.txt | tr '\n' ',')
     echo $SEEDS
     sed -i.bak -e "s/^seeds *=.*/seeds = \"$SEEDS\"/" $HOME/.celestia-app/config/config.toml
    SEEDS=$(curl -sL https://raw.githubusercontent.com/celestiaorg/networks/master/celestia/seeds.txt | tr '\n' ',')
     echo $SEEDS
    @@ -62,7 +62,7 @@
     seeds = ""
    # For Arabica, you can set seeds manually in the
     # `$HOME/.celestia-app/config/config.toml` file:
     # Comma separated list of seed nodes to connect to
    -seeds = ""
    Optional: Set persistent peers

    Optionally, you can set persistent peers in your config.toml file. If you set persistent peers, your node will always try to connect to these peers. This is useful when running a local devnet, for example, when you would always want to connect to the same local nodes in your devnet. In production, setting persistent peers is advised only if you are running a sentry node.

    You can get the persistent peers from the @cosmos/chain-registry repository (for Mainnet Beta) or @celestiaorg/networks repository repo (for Mocha and Arabica) with the following commands:

    bash
    PERSISTENT_PEERS=$(curl -s https://raw.githubusercontent.com/cosmos/chain-registry/master/celestia/chain.json | jq -r '.peers.persistent_peers[].address' | tr '\n' ',' | sed 's/,$/\n/')
    +seeds = ""
    Optional: Set persistent peers

    Optionally, you can set persistent peers in your config.toml file. If you set persistent peers, your node will always try to connect to these peers. This is useful when running a local devnet, for example, when you would always want to connect to the same local nodes in your devnet. In production, setting persistent peers is advised only if you are running a sentry node.

    You can get the persistent peers from the @cosmos/chain-registry repository (for Mainnet Beta) or @celestiaorg/networks repository repo (for Mocha and Arabica) with the following commands:

    bash
    PERSISTENT_PEERS=$(curl -s https://raw.githubusercontent.com/cosmos/chain-registry/master/celestia/chain.json | jq -r '.peers.persistent_peers[].address' | tr '\n' ',' | sed 's/,$/\n/')
     echo $PERSISTENT_PEERS
     sed -i.bak -e "s/^persistent_peers *=.*/persistent_peers = \"$PERSISTENT_PEERS\"/" $HOME/.celestia-app/config/config.toml
    PERSISTENT_PEERS=$(curl -s https://raw.githubusercontent.com/cosmos/chain-registry/master/celestia/chain.json | jq -r '.peers.persistent_peers[].address' | tr '\n' ',' | sed 's/,$/\n/')
     echo $PERSISTENT_PEERS
    @@ -88,7 +88,7 @@
     ###         State Sync Configuration Options        ###
     #######################################################
     [statesync]
    -enable = true

    To their respective fields. At least two different rpc endpoints should be provided. The more, the greater the chance of detecting any fraudulent behavior.

    Once setup, you should be ready to start the node as normal. In the logs, you should see: Discovering snapshots. This may take a few minutes before snapshots are found depending on the network topology.

    TIP

    If you are looking to quickly sync a consensus node, and do not need historical blocks, you can use the following scripts and state sync. Remember to checkout to the correct version and run make install before running the scripts:

    The public networks will use state sync so they'll get to the tip very quickly, but won't work for your use case if you need historical blocks.

    Option 3: Quick sync

    Quick sync effectively downloads the entire data directory from a third-party provider meaning the node has all the application and blockchain state as the node it was copied from.

    Run the following command to quick-sync from a snapshot:

    bash
    cd $HOME
    +enable = true

    To their respective fields. At least two different rpc endpoints should be provided. The more, the greater the chance of detecting any fraudulent behavior.

    Once setup, you should be ready to start the node as normal. In the logs, you should see: Discovering snapshots. This may take a few minutes before snapshots are found depending on the network topology.

    TIP

    If you are looking to quickly sync a consensus node, and do not need historical blocks, you can use the following scripts and state sync. Remember to checkout to the correct version and run make install before running the scripts:

    The public networks will use state sync so they'll get to the tip very quickly, but won't work for your use case if you need historical blocks.

    Option 3: Quick sync

    Quick sync effectively downloads the entire data directory from a third-party provider meaning the node has all the application and blockchain state as the node it was copied from.

    Run the following command to quick-sync from a snapshot:

    bash
    cd $HOME
     rm -rf ~/.celestia-app/data
     mkdir -p ~/.celestia-app/data
     SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \
    @@ -124,12 +124,12 @@
     SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \
         egrep -o ">arabica-11.*tar" | tr -d ">")
     aria2c -x 16 -s 16 -o celestia-snap.tar "https://snaps.qubelabs.io/celestia/${SNAP_NAME}"
    -tar xf celestia-snap.tar -C ~/.celestia-app/data/

    Start the consensus node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    Optional: If you would like celestia-app to run as a background process, you can follow the SystemD tutorial.

    Extra resources for consensus nodes

    Optional: Reset network

    This will delete all data folders so we can start fresh:

    sh
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app

    Optional: Configure an RPC endpoint

    You can configure your consensus node to be a public RPC endpoint. This allows it to accept connections from data availability nodes and serve requests for the data availability API.

    Expose RPC

    By default, the RPC service listens on localhost which means it can't be accessed from other machines. To make the RPC service available publicly, you need to bind it to a public IP or 0.0.0.0 (which means listening on all available network interfaces).

    You can do this by editing the config.toml file:

    sh
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml

    This command replaces the localhost IP address with 0.0.0.0, making the RPC service listen on all available network interfaces.

    Note on external-address

    The external-address field in the configuration is used when your node is behind a NAT and you need to advertise a different address for peers to dial. Populating this field is not necessary for making the RPC endpoint public.

    sh
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)
    +tar xf celestia-snap.tar -C ~/.celestia-app/data/

    Start the consensus node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    Optional: If you would like celestia-app to run as a background process, you can follow the SystemD tutorial.

    Extra resources for consensus nodes

    Optional: Reset network

    This will delete all data folders so we can start fresh:

    sh
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app
    celestia-appd tendermint unsafe-reset-all --home $HOME/.celestia-app

    Optional: Configure an RPC endpoint

    You can configure your consensus node to be a public RPC endpoint. This allows it to accept connections from data availability nodes and serve requests for the data availability API.

    Expose RPC

    By default, the RPC service listens on localhost which means it can't be accessed from other machines. To make the RPC service available publicly, you need to bind it to a public IP or 0.0.0.0 (which means listening on all available network interfaces).

    You can do this by editing the config.toml file:

    sh
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml
    sed -i 's#"tcp://127.0.0.1:26657"#"tcp://0.0.0.0:26657"#g' ~/.celestia-app/config/config.toml

    This command replaces the localhost IP address with 0.0.0.0, making the RPC service listen on all available network interfaces.

    Note on external-address

    The external-address field in the configuration is used when your node is behind a NAT and you need to advertise a different address for peers to dial. Populating this field is not necessary for making the RPC endpoint public.

    sh
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)
     sed -i.bak -e "s/^external-address = ""/external-address = "$EXTERNAL-ADDRESS:26656"/" \
         $HOME/.celestia-app/config/config.toml
    EXTERNAL-ADDRESS=$(wget -qO- eth0.me)
     sed -i.bak -e "s/^external-address = ""/external-address = "$EXTERNAL-ADDRESS:26656"/" \
    -    $HOME/.celestia-app/config/config.toml

    Restart the node

    After making these changes, restart celestia-appd to load the new configurations.

    Optional: Transaction indexer configuration options

    This section guides you on how to configure your config.toml file in celestia-app to select which transactions to index. Depending on the application's configuration, a node operator may decide which transactions to index.

    The available options are:

    1. null: This option disables indexing. If you don't need to query transactions, you can choose this option to save space.
    2. kv (default): This is the simplest indexer, backed by key-value storage (defaults to levelDB; see DBBackend). When kv is chosen, tx.height and tx.hash will always be indexed. This option is suitable for basic queries on transactions.
    3. psql: This indexer is backed by PostgreSQL. When psql is chosen, tx.height and tx.hash will always be indexed. This option is suitable for complex queries on transactions.

    An example to set the value to kv in config.toml is:

    toml
    indexer = "kv"
    indexer = "kv"

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    Optional: Discard ABCI responses configuration

    This section will guide you on how to configure your config.toml file in celestia-app to manage the storage of ABCI responses. ABCI responses are the results of executing transactions and are used for /block_results RPC queries and to reindex events in the command-line tool.

    The discard_abci_responses option allows you to control whether these responses are persisted in the state store:

    • false (default): ABCI responses are stored in the state store. This ensures that ABCI responses are available for /block_results RPC queries and for reindexing events. However, it can consume a significant amount of disk space.
    • true: ABCI responses are not stored in the state store. This can save a considerable amount of disk space, but /block_results RPC queries and event reindexing will not be available.

    An example to set the value to false in config.toml is:

    toml
    discard_abci_responses = false
    discard_abci_responses = false

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to:

    1. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    2. Remove the data/application.db inside your CELESTIA_HOME directory.
    3. Download the latest binary for your network.
    4. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    - + $HOME/.celestia-app/config/config.toml

    Restart the node

    After making these changes, restart celestia-appd to load the new configurations.

    Optional: Transaction indexer configuration options

    This section guides you on how to configure your config.toml file in celestia-app to select which transactions to index. Depending on the application's configuration, a node operator may decide which transactions to index.

    The available options are:

    1. null: This option disables indexing. If you don't need to query transactions, you can choose this option to save space.
    2. kv (default): This is the simplest indexer, backed by key-value storage (defaults to levelDB; see DBBackend). When kv is chosen, tx.height and tx.hash will always be indexed. This option is suitable for basic queries on transactions.
    3. psql: This indexer is backed by PostgreSQL. When psql is chosen, tx.height and tx.hash will always be indexed. This option is suitable for complex queries on transactions.

    An example to set the value to kv in config.toml is:

    toml
    indexer = "kv"
    indexer = "kv"

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    Optional: Discard ABCI responses configuration

    This section will guide you on how to configure your config.toml file in celestia-app to manage the storage of ABCI responses. ABCI responses are the results of executing transactions and are used for /block_results RPC queries and to reindex events in the command-line tool.

    The discard_abci_responses option allows you to control whether these responses are persisted in the state store:

    • false (default): ABCI responses are stored in the state store. This ensures that ABCI responses are available for /block_results RPC queries and for reindexing events. However, it can consume a significant amount of disk space.
    • true: ABCI responses are not stored in the state store. This can save a considerable amount of disk space, but /block_results RPC queries and event reindexing will not be available.

    An example to set the value to false in config.toml is:

    toml
    discard_abci_responses = false
    discard_abci_responses = false

    Remember to restart celestia-appd after making changes to the configuration to load the new settings.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to:

    1. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    2. Remove the data/application.db inside your CELESTIA_HOME directory.
    3. Download the latest binary for your network.
    4. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/decide-node.html b/pr-1815/how-to-guides/decide-node.html index bbc10e40e..eb9220833 100644 --- a/pr-1815/how-to-guides/decide-node.html +++ b/pr-1815/how-to-guides/decide-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Deciding which node to run

    Now that you have installed the basic dependencies, you can start exploring which nodes to run!

    Light node

    It is highly recommended to get started with running a data availability light node.

    You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

    Other DA nodes

    Depending on your use case, you also may want to run a bridge node or a full DA node.

    Consensus node

    If you are looking to run a consensus node, please follow the tutorial for running a consensus node.

    Note that running a validator means you must also run a bridge node, which is covered in this section.

    - +

    Deciding which node to run

    Now that you have installed the basic dependencies, you can start exploring which nodes to run!

    Light node

    It is highly recommended to get started with running a data availability light node.

    You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

    Other DA nodes

    Depending on your use case, you also may want to run a bridge node or a full DA node.

    Consensus node

    If you are looking to run a consensus node, please follow the tutorial for running a consensus node.

    Note that running a validator means you must also run a bridge node, which is covered in this section.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/docker-images.html b/pr-1815/how-to-guides/docker-images.html index bffd0e247..becfe4258 100644 --- a/pr-1815/how-to-guides/docker-images.html +++ b/pr-1815/how-to-guides/docker-images.html @@ -7,14 +7,14 @@ - + - + - + @@ -50,7 +50,7 @@

    🐳 Docker setup

    This page has instructions to run celestia-node using Docker. If you are looking for instructions to run celestia-node using a binary, please refer to the celestia-node page.

    Using Docker is the easiest way to run celestia-node for most users. Docker is a containerization platform that allows you to run celestia-node in an isolated environment.

    This means that you can run celestia-node on your machine without having to worry about installing and configuring all of the dependencies required to run the node.

    If you would like to learn more about key management in Docker, visit the Docker and cel-key section.

    The easiest way to install Docker is to use the Docker Desktop installer or Ubuntu. You can follow the instructions for your operating system.

    Prerequisites

    Quick start

    1. Set the network you would like to run your node on:

      bash
      export NETWORK=celestia
      export NETWORK=celestia
      bash
      export NETWORK=mocha
      export NETWORK=mocha
      bash
      export NETWORK=arabica
      export NETWORK=arabica
    2. Set the node type

      bash
      export NODE_TYPE=light
      export NODE_TYPE=light
      bash
      export NODE_TYPE=bridge
      export NODE_TYPE=bridge
      bash
      export NODE_TYPE=full
      export NODE_TYPE=full
    3. Set an RPC endpoint for either Mainnet Beta, Mocha, or Arabica using the bare URL (without http or https):

      bash
      export RPC_URL=this-is-an-rpc-url.com
      export RPC_URL=this-is-an-rpc-url.com
    4. Run the image from the command line:

      bash
      docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
      +

    🐳 Docker setup

    This page has instructions to run celestia-node using Docker. If you are looking for instructions to run celestia-node using a binary, please refer to the celestia-node page.

    Using Docker is the easiest way to run celestia-node for most users. Docker is a containerization platform that allows you to run celestia-node in an isolated environment.

    This means that you can run celestia-node on your machine without having to worry about installing and configuring all of the dependencies required to run the node.

    If you would like to learn more about key management in Docker, visit the Docker and cel-key section.

    The easiest way to install Docker is to use the Docker Desktop installer or Ubuntu. You can follow the instructions for your operating system.

    Prerequisites

    Quick start

    1. Set the network you would like to run your node on:

      bash
      export NETWORK=celestia
      export NETWORK=celestia
      bash
      export NETWORK=mocha
      export NETWORK=mocha
      bash
      export NETWORK=arabica
      export NETWORK=arabica
    2. Set the node type

      bash
      export NODE_TYPE=light
      export NODE_TYPE=light
      bash
      export NODE_TYPE=bridge
      export NODE_TYPE=bridge
      bash
      export NODE_TYPE=full
      export NODE_TYPE=full
    3. Set an RPC endpoint for either Mainnet Beta, Mocha, or Arabica using the bare URL (without http or https):

      bash
      export RPC_URL=this-is-an-rpc-url.com
      export RPC_URL=this-is-an-rpc-url.com
    4. Run the image from the command line:

      bash
      docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
           ghcr.io/celestiaorg/celestia-node:v0.20.4 \
           celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK
      docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
           ghcr.io/celestiaorg/celestia-node:v0.20.4 \
      @@ -64,11 +64,11 @@
           ghcr.io/celestiaorg/celestia-node:v0.20.4-arabica \
           celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK

    Congratulations! You now have a celestia-node running!

    If you would like to run the node with custom flags, you can refer to the celestia-node tutorial page. Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Light node setup with persistent storage

    If you delete a container that you started above, all data will be lost. To avoid this, you can mount a volume to the container. This will allow you to persist data even after the container is deleted.

    First, you will need to create a directory on your host machine. This directory will be used to store the data for the container. Create a directory on your host machine and give it a name. For example, you can name it my-node-store:

    bash
    cd $HOME
     mkdir my-node-store
    cd $HOME
    -mkdir my-node-store

    Now, you can mount this directory to the container. Before mounting a volume, you may need to set permissions for the user on the host machine by running:

    bash
    sudo chown 10001:10001 $HOME/my-node-store
    sudo chown 10001:10001 $HOME/my-node-store
    bash
    # you're good to go 😎
    # you're good to go 😎

    Initialize the node store and key

    In order to mount a volume to the container, you need to specify the path to the volume. When you run your container, you can specify the path to the volume using the --volume (or -v for short) flag. In this command, we'll create our key and initialize the node store, using the variables we set in the quick start section:

    bash
    # --volume == -v [local path]:[container path]
    +mkdir my-node-store

    Now, you can mount this directory to the container. Before mounting a volume, you may need to set permissions for the user on the host machine by running:

    bash
    sudo chown 10001:10001 $HOME/my-node-store
    sudo chown 10001:10001 $HOME/my-node-store
    bash
    # you're good to go 😎
    # you're good to go 😎

    Initialize the node store and key

    In order to mount a volume to the container, you need to specify the path to the volume. When you run your container, you can specify the path to the volume using the --volume (or -v for short) flag. In this command, we'll create our key and initialize the node store, using the variables we set in the quick start section:

    bash
    # --volume == -v [local path]:[container path]
     docker run [args...] -v $HOME/my-node-store:/home/celestia \
         celestia $NODE_TYPE init [args...]
    # --volume == -v [local path]:[container path]
     docker run [args...] -v $HOME/my-node-store:/home/celestia \
    -    celestia $NODE_TYPE init [args...]

    An example init command will look similar to below:

    bash
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
    +    celestia $NODE_TYPE init [args...]

    An example init command will look similar to below:

    bash
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
         -v $HOME/my-node-store:/home/celestia \
         ghcr.io/celestiaorg/celestia-node:v0.20.4 \
         celestia light init --p2p.network $NETWORK
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
    @@ -90,7 +90,7 @@
     docker run [...args] -v $HOME/my-node-store:/home/celestia \
         celestia <node-type> start [...args]
    # --volume == -v [local path]:[container path]
     docker run [...args] -v $HOME/my-node-store:/home/celestia \
    -    celestia <node-type> start [...args]

    A full start command will look similar to below.

    bash
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
    +    celestia <node-type> start [...args]

    A full start command will look similar to below.

    bash
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
         -v $HOME/my-node-store:/home/celestia \
         ghcr.io/celestiaorg/celestia-node:v0.20.4 \
         celestia light start --core.ip $RPC_URL --p2p.network $NETWORK
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
    @@ -108,8 +108,8 @@
         celestia light start --core.ip $RPC_URL --p2p.network $NETWORK
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
         -v $HOME/my-node-store:/home/celestia \
         ghcr.io/celestiaorg/celestia-node:v0.20.4-arabica \
    -    celestia light start --core.ip $RPC_URL --p2p.network $NETWORK

    Congratulations! You now have a node running with persistent storage.

    Video walkthrough

    2.5 minute version

    Troubleshooting

    For security purposes Celestia expects to interact with your node's keys in a read-only manner. This is enforced using linux style permissions on the filesystem. Windows NTFS does not support these types of permissions. As a result the recommended path for Windows users to mount a persisted volume is to do so within WSL. You can find instructions for installing WSL.

    - + celestia light start --core.ip $RPC_URL --p2p.network $NETWORK

    Congratulations! You now have a node running with persistent storage.

    Video walkthrough

    2.5 minute version

    Troubleshooting

    For security purposes Celestia expects to interact with your node's keys in a read-only manner. This is enforced using linux style permissions on the filesystem. Windows NTFS does not support these types of permissions. As a result the recommended path for Windows users to mount a persisted volume is to do so within WSL. You can find instructions for installing WSL.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/environment.html b/pr-1815/how-to-guides/environment.html index a1514c9e9..0c186a7de 100644 --- a/pr-1815/how-to-guides/environment.html +++ b/pr-1815/how-to-guides/environment.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,7 +48,7 @@

    Development environment

    This page will go over setting up your development environment to run Celestia software. This environment can be used for development, building binaries, and running nodes.

    Install dependencies

    1. If you are on Ubuntu, first update and upgrade your OS:

      bash
      sudo apt update && sudo apt upgrade -y
      sudo apt update && sudo apt upgrade -y
      bash
      sudo yum update
      sudo yum update
    2. Install essential packages that are necessary to execute many tasks like downloading files, compiling, and monitoring the node:

      bash
      sudo apt install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \
      +

    Development environment

    This page will go over setting up your development environment to run Celestia software. This environment can be used for development, building binaries, and running nodes.

    Install dependencies

    1. If you are on Ubuntu, first update and upgrade your OS:

      bash
      sudo apt update && sudo apt upgrade -y
      sudo apt update && sudo apt upgrade -y
      bash
      sudo yum update
      sudo yum update
    2. Install essential packages that are necessary to execute many tasks like downloading files, compiling, and monitoring the node:

      bash
      sudo apt install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \
       git make ncdu -y
      sudo apt install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \
       git make ncdu -y
      bash
      sudo yum install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \
       git make ncdu -y
      sudo yum install curl tar wget aria2 clang pkg-config libssl-dev jq build-essential \
      @@ -62,7 +62,7 @@
       /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
       
       # then install wget & jq
      -brew install wget && brew install jq

    Install Golang

    celestia-node is written in Golang so we must install Golang to build and run our node.

    1. Set the version for your desired network:

      bash
      ver="1.23.0"
      ver="1.23.0"
      bash
      ver="1.23.2"
      ver="1.23.2"
      bash
      ver="1.23.2"
      ver="1.23.2"
    2. Download and install Golang:

      bash
      cd $HOME
      +brew install wget && brew install jq

    Install Golang

    celestia-node is written in Golang so we must install Golang to build and run our node.

    1. Set the version for your desired network:

      bash
      ver="1.23.0"
      ver="1.23.0"
      bash
      ver="1.23.2"
      ver="1.23.2"
      bash
      ver="1.23.2"
      ver="1.23.2"
    2. Download and install Golang:

      bash
      cd $HOME
       wget "https://golang.org/dl/go$ver.linux-amd64.tar.gz"
       sudo rm -rf /usr/local/go
       sudo tar -C /usr/local -xzf "go$ver.linux-amd64.tar.gz"
      @@ -94,12 +94,12 @@
       wget "https://golang.org/dl/go$ver.darwin-amd64.tar.gz"
       sudo rm -rf /usr/local/go
       sudo tar -C /usr/local -xzf "go$ver.darwin-amd64.tar.gz"
      -rm "go$ver.darwin-amd64.tar.gz"
    3. Add your /usr/local/go/bin directory to your $PATH if you have not already:

      bash
      echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
      +rm "go$ver.darwin-amd64.tar.gz"
    4. Add your /usr/local/go/bin directory to your $PATH if you have not already:

      bash
      echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
       source $HOME/.bash_profile
      echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.bash_profile
       source $HOME/.bash_profile
      bash
      echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.zshrc
       source $HOME/.zshrc
      echo "export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin" >> $HOME/.zshrc
      -source $HOME/.zshrc

      TIP

      Use echo $SHELL to figure out what type of shell you are using!

    5. To verify that the correct version of Go was installed correctly run:

      bash
      go version
      go version

    The output will show the version installed.

    - +source $HOME/.zshrc

    TIP

    Use echo $SHELL to figure out what type of shell you are using!

  • To verify that the correct version of Go was installed correctly run:

    bash
    go version
    go version
  • The output will show the version installed.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/ethereum-fallback.html b/pr-1815/how-to-guides/ethereum-fallback.html index f2dc54b5d..50b6f8c1f 100644 --- a/pr-1815/how-to-guides/ethereum-fallback.html +++ b/pr-1815/how-to-guides/ethereum-fallback.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Ethereum fallback

    Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fallback” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta. This feature is currently supported by Celestia integrations with:

    In the case of Celestia downtime or temporary unavailability, L2s can fallback to posting transactions as calldata on Ethereum or another DA layer for data availability instead of posting to Celestia. This mechanism ensures users can continue to transact securely and seamlessly, preventing disruptions and helping to ensure user funds do not get stuck in the L2's bridge on Ethereum.

    Ethereum fallback is triggered whenever the sequencer has an error sending the PayForBlobs transaction on Celestia. Fallback can be triggered due to a congested mempool or nonce error and can be simulated with an error such as low balance or incorrect sequence. Fallback can also be triggered in the event Blobstream stops relaying attestations.

    Ethereum fallback

    - +

    Ethereum fallback

    Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fallback” to using Ethereum calldata for data availability in the event of downtime on Celestia Mainnet Beta. This feature is currently supported by Celestia integrations with:

    In the case of Celestia downtime or temporary unavailability, L2s can fallback to posting transactions as calldata on Ethereum or another DA layer for data availability instead of posting to Celestia. This mechanism ensures users can continue to transact securely and seamlessly, preventing disruptions and helping to ensure user funds do not get stuck in the L2's bridge on Ethereum.

    Ethereum fallback is triggered whenever the sequencer has an error sending the PayForBlobs transaction on Celestia. Fallback can be triggered due to a congested mempool or nonce error and can be simulated with an error such as low balance or incorrect sequence. Fallback can also be triggered in the event Blobstream stops relaying attestations.

    Ethereum fallback

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/feegrant-for-blobs.html b/pr-1815/how-to-guides/feegrant-for-blobs.html index bb84867ed..8c919ff25 100644 --- a/pr-1815/how-to-guides/feegrant-for-blobs.html +++ b/pr-1815/how-to-guides/feegrant-for-blobs.html @@ -7,11 +7,11 @@ - + - - + + @@ -109,8 +109,8 @@ --broadcast-mode block \ --yes

    Example: FeeGrant transaction on Mocha

    Optional: Checking the granter's account

    To confirm that the fees have been deducted from the granter's account that granted the fee allowance, run:

    bash
    celestia-appd query bank balances $GRANTER_ADDRESS \
     --node https://rpc-mocha.pops.one:443 --denom utia
    celestia-appd query bank balances $GRANTER_ADDRESS \
    ---node https://rpc-mocha.pops.one:443 --denom utia

    This output will show the remaining balance after fees have been deducted, confirming that the FeeGrant module is working as intended.

    - +--node https://rpc-mocha.pops.one:443 --denom utia

    This output will show the remaining balance after fees have been deducted, confirming that the FeeGrant module is working as intended.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/full-storage-node.html b/pr-1815/how-to-guides/full-storage-node.html index 199b0a7d3..fddad8965 100644 --- a/pr-1815/how-to-guides/full-storage-node.html +++ b/pr-1815/how-to-guides/full-storage-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,7 +47,7 @@

    Setting up a Celestia full storage Node

    This tutorial will guide you through setting up a Celestia full storage node, which is a celestia-node that doesn't connect to celestia-app (hence not a consensus node), but stores all the data.

    Overview of full storage nodes

    Full storage nodes are Celestia nodes that store all the data. Full storage nodes send block shares, headers, and fraud proofs to light nodes. The light nodes gossip headers, fraud proofs, and sometimes block shares, between one another.

    Full storage node

    Hardware requirements

    The following hardware minimum requirements are recommended for running the full storage node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your full storage node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    You can follow the tutorial for setting up your dependencies

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Run the full storage node

    Initialize the full storage node

    Run the following command:

    sh
    celestia full init
    celestia full init
    sh
    celestia full init --p2p.network mocha
    celestia full init --p2p.network mocha
    sh
    celestia full init --p2p.network arabica
    celestia full init --p2p.network arabica

    Start the full storage node

    Start the full storage node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get/submit state-related information, such as the ability to submit PayForBlob transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia full start --core.ip <URI>
    celestia full start --core.ip <URI>

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    You can create your key for your node by following the cel-key instructions

    Once you start the full storage node, a wallet key will be generated for you. You will need to fund that address with testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a full-storage node for your sovereign rollup, it is highly recommended to request Arabica devnet tokens as Arabica has the latest changes that can be used to test for developing your sovereign rollup. You can still use Mocha testnet as well, it is just mostly used for validator operations.

    Optional: run the full storage node with a custom key

    In order to run a full storage node using a custom key:

    1. The custom key must exist inside the celestia full storage node directory at the correct path (default: ~/.celestia-full/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia full start --core.ip <URI> \
    +

    Setting up a Celestia full storage Node

    This tutorial will guide you through setting up a Celestia full storage node, which is a celestia-node that doesn't connect to celestia-app (hence not a consensus node), but stores all the data.

    Overview of full storage nodes

    Full storage nodes are Celestia nodes that store all the data. Full storage nodes send block shares, headers, and fraud proofs to light nodes. The light nodes gossip headers, fraud proofs, and sometimes block shares, between one another.

    Full storage node

    Hardware requirements

    The following hardware minimum requirements are recommended for running the full storage node:

    • Memory: 16 GB RAM (minimum)
    • CPU: 6 cores
    • Disk: 2 TB NVME Storage
    • Bandwidth: 1 Gbps for Download/1 Gbps for Upload

    Setting up your full storage node

    The following tutorial is done on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Setup the dependencies

    You can follow the tutorial for setting up your dependencies

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Run the full storage node

    Initialize the full storage node

    Run the following command:

    sh
    celestia full init
    celestia full init
    sh
    celestia full init --p2p.network mocha
    celestia full init --p2p.network mocha
    sh
    celestia full init --p2p.network arabica
    celestia full init --p2p.network arabica

    Start the full storage node

    Start the full storage node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get/submit state-related information, such as the ability to submit PayForBlob transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia full start --core.ip <URI>
    celestia full start --core.ip <URI>

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, start your node.

    Connecting to a core endpoint with --core.ip string provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    You can create your key for your node by following the cel-key instructions

    Once you start the full storage node, a wallet key will be generated for you. You will need to fund that address with testnet tokens to pay for PayForBlob transactions. You can find the address by running the following command:

    sh
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>
    ./cel-key list --node.type full --keyring-backend test --p2p.network <network>

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    You can get testnet tokens from:

    NOTE

    If you are running a full-storage node for your sovereign rollup, it is highly recommended to request Arabica devnet tokens as Arabica has the latest changes that can be used to test for developing your sovereign rollup. You can still use Mocha testnet as well, it is just mostly used for validator operations.

    Optional: run the full storage node with a custom key

    In order to run a full storage node using a custom key:

    1. The custom key must exist inside the celestia full storage node directory at the correct path (default: ~/.celestia-full/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia full start --core.ip <URI> \
       --keyring.keyname <name-of-custom-key> \
    celestia full start --core.ip <URI> \
       --keyring.keyname <name-of-custom-key> \
    sh
    celestia full start --core.ip <URI> \
       --keyring.keyname <name-of-custom-key> \
    @@ -57,8 +57,8 @@
       --keyring.keyname <name-of-custom-key> \
       --p2p.network arabica
    celestia full start --core.ip <URI> \
       --keyring.keyname <name-of-custom-key> \
    -  --p2p.network arabica

    Optional: Migrate node id to another server

    To migrate a full storage node ID:

    1. You need to back up two files located in the celestia-full node directory at the correct path (default: ~/.celestia-full/keys).
    2. Upload the files to the new server and start the node.

    Optional: start the full storage node with SystemD

    If you would like to run the full storage node as a background process, follow the SystemD tutorial.

    With that, you are now running a Celestia full storage node.

    Stop the full storage node

    In order to gracefully stop the full storage node, use Control + C in the terminal window where the node is running. Be sure to only do this once as the shutdown will not be instantaneous.

    - + --p2p.network arabica

    Optional: Migrate node id to another server

    To migrate a full storage node ID:

    1. You need to back up two files located in the celestia-full node directory at the correct path (default: ~/.celestia-full/keys).
    2. Upload the files to the new server and start the node.

    Optional: start the full storage node with SystemD

    If you would like to run the full storage node as a background process, follow the SystemD tutorial.

    With that, you are now running a Celestia full storage node.

    Stop the full storage node

    In order to gracefully stop the full storage node, use Control + C in the terminal window where the node is running. Be sure to only do this once as the shutdown will not be instantaneous.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/ibc-relayer.html b/pr-1815/how-to-guides/ibc-relayer.html index d4e6852c2..1f1e36094 100644 --- a/pr-1815/how-to-guides/ibc-relayer.html +++ b/pr-1815/how-to-guides/ibc-relayer.html @@ -7,11 +7,11 @@ - + - - + + @@ -501,8 +501,8 @@ policy = 'allow' list = [ ['transfer', 'channel-3108'], # mocha-4 -]

    Start the relayer

    Start the relayer via hermes start

    Transfer

    The Celestia state machine is built with the IBC transfer module, allowing for the native Celestia token to be transferred to any other IBC enabled chain. Transfer can be initialized through the celestia-appd CLI. Information can be found via the help label as follows:

    bash
    celestia-appd tx ibc-transfer transfer --help
    celestia-appd tx ibc-transfer transfer --help

    Token filter

    The transfer module uses a token filter middleware which serves to prevent non-native Celestia tokens from being on Celestia. If a user is to try to send a token from another chain across, it will be simply rejected and the token returned back to the user.

    - +]

    Start the relayer

    Start the relayer via hermes start

    Transfer

    The Celestia state machine is built with the IBC transfer module, allowing for the native Celestia token to be transferred to any other IBC enabled chain. Transfer can be initialized through the celestia-appd CLI. Information can be found via the help label as follows:

    bash
    celestia-appd tx ibc-transfer transfer --help
    celestia-appd tx ibc-transfer transfer --help

    Token filter

    The transfer module uses a token filter middleware which serves to prevent non-native Celestia tokens from being on Celestia. If a user is to try to send a token from another chain across, it will be simply rejected and the token returned back to the user.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/instantiate-testnet.html b/pr-1815/how-to-guides/instantiate-testnet.html index a1c92a48a..32a03b23b 100644 --- a/pr-1815/how-to-guides/instantiate-testnet.html +++ b/pr-1815/how-to-guides/instantiate-testnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -67,8 +67,8 @@ NODE_ID=$(celestia-appd tendermint show-node-id) PORT_NUMBER=26656

    Note that the default port is 26656

    Now you can run the following command to output your validator node address:

    sh
    PEER="$NODE_ID@$IP_ADDRESS:$PORT_NUMBER"
     echo $PEER
    PEER="$NODE_ID@$IP_ADDRESS:$PORT_NUMBER"
    -echo $PEER

    The output is your validator node address which you can share with other validators so they can peer with you.

    Instantiate the network

    You can start your node by running the following command:

    sh
    celestia-appd start
    celestia-appd start

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Now you have a new Celestia testnet to play around with!

    - +echo $PEER

    The output is your validator node address which you can share with other validators so they can peer with you.

    Instantiate the network

    You can start your node by running the following command:

    sh
    celestia-appd start
    celestia-appd start

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Now you have a new Celestia testnet to play around with!

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/intro-to-op-stack.html b/pr-1815/how-to-guides/intro-to-op-stack.html index 9284bf6ea..2d555d225 100644 --- a/pr-1815/how-to-guides/intro-to-op-stack.html +++ b/pr-1815/how-to-guides/intro-to-op-stack.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Introduction to OP Stack integration

    Optimism is a low-cost and lightning-fast Ethereum L2 blockchain, built with the OP Stack.

    Celestia is a modular consensus and data availability (DA) network, built to enable anyone to easily deploy their own blockchain with minimal overhead.

    Together, they allow developers to create rollups that post data to Celestia and settle on Ethereum.

    About the integration

    Optimism uses Ethereum as a DA layer. Currently, settlement and DA for Optimism are on Ethereum, both onchain. op-batcher batches up rollup blocks and posts to Ethereum.

    The integration of OP Stack with Celestia underneath for DA allows rollup operators to reduce overhead that is associated with posting data as calldata on Ethereum. Instead, op-batcher batches up rollup blocks and posts them to Celestia's DA network.

    Data is managed in two ways. First, data is written to the data availability (DA) layer i.e. in this case Celestia, then the data commitment is written to the op-batcher. When reading op-node simply reads the data back from the DA layer by reading the data commitment from the op-batcher first, then reading the data from the DA layer using the data commitment. While previously op-node was reading from calldata on Ethereum, it now reads data from Celestia.

    There are a few tools involved in the data handling process. op-batcher batches up rollup blocks and posts them to Ethereum. op-geth handles execution, while op-proposer is responsible for state commitment submission.

    By using Celestia as a DA layer, existing L2s can switch from posting their data as calldata on Ethereum, to posting to Celestia. The commitment to the block is posted on Celestia, which is purpose-built for data availability. This is a more scalable than the traditional method of posting this data as calldata on monolithic chains.

    GitHub repository

    Find the repository for this integration at https://github.com/celestiaorg/optimism.

    WARNING

    This is a beta integration and we are working on resolving open issues.

    Next steps

    Now that you understand the integration, you can start learning about the Bubs testnet, built with OP Stack and Celestia! This testnet is a great way to explore the possibilities of this integration and test your applications in a live environment.

    - +

    Introduction to OP Stack integration

    Optimism is a low-cost and lightning-fast Ethereum L2 blockchain, built with the OP Stack.

    Celestia is a modular consensus and data availability (DA) network, built to enable anyone to easily deploy their own blockchain with minimal overhead.

    Together, they allow developers to create rollups that post data to Celestia and settle on Ethereum.

    About the integration

    Optimism uses Ethereum as a DA layer. Currently, settlement and DA for Optimism are on Ethereum, both onchain. op-batcher batches up rollup blocks and posts to Ethereum.

    The integration of OP Stack with Celestia underneath for DA allows rollup operators to reduce overhead that is associated with posting data as calldata on Ethereum. Instead, op-batcher batches up rollup blocks and posts them to Celestia's DA network.

    Data is managed in two ways. First, data is written to the data availability (DA) layer i.e. in this case Celestia, then the data commitment is written to the op-batcher. When reading op-node simply reads the data back from the DA layer by reading the data commitment from the op-batcher first, then reading the data from the DA layer using the data commitment. While previously op-node was reading from calldata on Ethereum, it now reads data from Celestia.

    There are a few tools involved in the data handling process. op-batcher batches up rollup blocks and posts them to Ethereum. op-geth handles execution, while op-proposer is responsible for state commitment submission.

    By using Celestia as a DA layer, existing L2s can switch from posting their data as calldata on Ethereum, to posting to Celestia. The commitment to the block is posted on Celestia, which is purpose-built for data availability. This is a more scalable than the traditional method of posting this data as calldata on monolithic chains.

    GitHub repository

    Find the repository for this integration at https://github.com/celestiaorg/optimism.

    WARNING

    This is a beta integration and we are working on resolving open issues.

    Next steps

    Now that you understand the integration, you can start learning about the Bubs testnet, built with OP Stack and Celestia! This testnet is a great way to explore the possibilities of this integration and test your applications in a live environment.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/light-node.html b/pr-1815/how-to-guides/light-node.html index be7f5ae26..d586dc67e 100644 --- a/pr-1815/how-to-guides/light-node.html +++ b/pr-1815/how-to-guides/light-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,9 +47,9 @@

    Setting up a Celestia light node

    This tutorial will guide you through setting up a Celestia light node, which will allow you to perform data availability sampling (DAS) on Celestia's data availability (DA) network.

    Overview of light nodes

    Light nodes ensure data availability. This is the most common way to interact with Celestia networks.

    light-node

    Light nodes have the following behavior:

    1. They listen for ExtendedHeaders, i.e. wrapped “raw” headers, that notify Celestia nodes of new block headers and relevant DA metadata.
    2. They perform DAS on the received headers

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 100 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Quickstart: Run a light node in your browser

    The easiest way to run a Celestia light node is with Lumina.rs in your browser.

    Lumina.rs in browser

    You can also run Lumina on the first decentralized block explorer, Celenium.

    Celenium running a light node with Lumina.rs

    Setting up your light node

    This tutorial was performed on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up dependencies on the setting up environment page.

    Install celestia-node

    Install the celestia binary by building and installing celestia-node.

    Initialize the light node

    Run the following command:

    sh
    celestia light init
    celestia light init
    sh
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    sh
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    The output in your terminal will show the location of your node store and config. It will also show confirmation that the node store has been initialized.

    Start the light node

    Start the light node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get and submit state-related information, such as the ability to submit PayForBlobs transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    sh
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    sh
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica

    Tip: you can replace the core.ip with a consensus node RPC endpoint from Mainnet Beta, Mocha testnet, or Arabica devnet.

    Keys and wallets

    You can create your key for your node by running the following command with the cel-key utility in the celestia-node directory:

    sh
    ./cel-key add <key-name> --keyring-backend test \
    +

    Setting up a Celestia light node

    This tutorial will guide you through setting up a Celestia light node, which will allow you to perform data availability sampling (DAS) on Celestia's data availability (DA) network.

    Overview of light nodes

    Light nodes ensure data availability. This is the most common way to interact with Celestia networks.

    light-node

    Light nodes have the following behavior:

    1. They listen for ExtendedHeaders, i.e. wrapped “raw” headers, that notify Celestia nodes of new block headers and relevant DA metadata.
    2. They perform DAS on the received headers

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 100 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Quickstart: Run a light node in your browser

    The easiest way to run a Celestia light node is with Lumina.rs in your browser.

    Lumina.rs in browser

    You can also run Lumina on the first decentralized block explorer, Celenium.

    Celenium running a light node with Lumina.rs

    Setting up your light node

    This tutorial was performed on an Ubuntu Linux 20.04 (LTS) x64 instance machine.

    Set up dependencies on the setting up environment page.

    Install celestia-node

    Install the celestia binary by building and installing celestia-node.

    Initialize the light node

    Run the following command:

    sh
    celestia light init
    celestia light init
    sh
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    sh
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    The output in your terminal will show the location of your node store and config. It will also show confirmation that the node store has been initialized.

    Start the light node

    Start the light node with a connection to a validator node's gRPC endpoint (which is usually exposed on port 9090):

    In order for access to the ability to get and submit state-related information, such as the ability to submit PayForBlobs transactions, or query for the node's account balance, a gRPC endpoint of a validator (core) node must be passed as directed below.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    sh
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    celestia light start --core.ip rpc.celestia.pops.one --p2p.network celestia
    sh
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    sh
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica
    celestia light start --core.ip validator-1.celestia-arabica-11.com --p2p.network arabica

    Tip: you can replace the core.ip with a consensus node RPC endpoint from Mainnet Beta, Mocha testnet, or Arabica devnet.

    Keys and wallets

    You can create your key for your node by running the following command with the cel-key utility in the celestia-node directory:

    sh
    ./cel-key add <key-name> --keyring-backend test \
         --node.type light --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test \
    -    --node.type light --p2p.network <network>

    You can start your light node with the key created above by running the following command:

    sh
    celestia light start --keyring.keyname my_celes_key \
    +    --node.type light --p2p.network <network>

    You can start your light node with the key created above by running the following command:

    sh
    celestia light start --keyring.keyname my_celes_key \
         --core.ip consensus.lunaroasis.net
    celestia light start --keyring.keyname my_celes_key \
         --core.ip consensus.lunaroasis.net
    sh
    celestia light start --keyring.keyname my_celes_key \
         --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --keyring.keyname my_celes_key \
    @@ -59,7 +59,7 @@
         --core.ip validator-1.celestia-arabica-11.com \
         --p2p.network arabica

    Once you start the light node, a wallet key will be generated for you. You will need to fund that address with testnet tokens to pay for PayForBlob transactions.

    You can find the address using the RPC CLI or by running the following command in the celestia-node directory:

    sh
    ./cel-key list --node.type light --keyring-backend test \
         --p2p.network <network>
    ./cel-key list --node.type light --keyring-backend test \
    -    --p2p.network <network>

    Testnet tokens

    You have two networks to get testnet tokens from:

    You can request funds to your wallet address using the following command in Discord:

    console
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is the celestia1****** address generated when you created the wallet.

    Optional: run the light node with a custom key

    In order to run a light node using a custom key:

    1. The custom key must exist inside the celestia light node directory at the correct path (default: ~/.celestia-light/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia light start --core.ip <URI> \
    +    --p2p.network <network>

    Testnet tokens

    You have two networks to get testnet tokens from:

    You can request funds to your wallet address using the following command in Discord:

    console
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is the celestia1****** address generated when you created the wallet.

    Optional: run the light node with a custom key

    In order to run a light node using a custom key:

    1. The custom key must exist inside the celestia light node directory at the correct path (default: ~/.celestia-light/keys/keyring-test)
    2. The name of the custom key must be passed upon start, like so:
    sh
    celestia light start --core.ip <URI> \
         --keyring.keyname <name-of-custom-key> \
    celestia light start --core.ip <URI> \
         --keyring.keyname <name-of-custom-key> \
    sh
    celestia light start --core.ip <URI> \
         --keyring.keyname <name-of-custom-key> \
    @@ -69,8 +69,8 @@
         --keyring.keyname <name-of-custom-key> \
         --p2p.network mocha
    celestia light start --core.ip <URI> \
         --keyring.keyname <name-of-custom-key> \
    -    --p2p.network mocha

    Optional: Migrate node id to another server

    To migrate a light node ID:

    1. You need to back up two files located in the celestia-light node directory at the correct path (default: ~/.celestia-light/keys).
    2. Upload the files to the new server and start the node.

    Optional: start light node with SystemD

    Follow the tutorial on setting up the light node as a background process with SystemD.

    Data availability sampling

    With your light node running, you can check out this tutorial on submitting PayForBlob transactions.

    - + --p2p.network mocha

    Optional: Migrate node id to another server

    To migrate a light node ID:

    1. You need to back up two files located in the celestia-light node directory at the correct path (default: ~/.celestia-light/keys).
    2. Upload the files to the new server and start the node.

    Optional: start light node with SystemD

    Follow the tutorial on setting up the light node as a background process with SystemD.

    Data availability sampling

    With your light node running, you can check out this tutorial on submitting PayForBlob transactions.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/local-testnet.html b/pr-1815/how-to-guides/local-testnet.html index cd915c41f..edab4dae0 100644 --- a/pr-1815/how-to-guides/local-testnet.html +++ b/pr-1815/how-to-guides/local-testnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,9 +47,9 @@

    Setting up a Celestia local testnet

    This guide walks through setting up a local Celestia testnet with a validator node, bridge node, and light node.

    Prerequisites

    • celestia-app installed (based on compatible versions)
    • celestia node binary installed
    • jq installed

    Starting the validator node

    First, navigate to the celestia-app scripts directory and run the single node script:

    bash
    cd celestia-app/scripts
    +

    Setting up a Celestia local testnet

    This guide walks through setting up a local Celestia testnet with a validator node, bridge node, and light node.

    Prerequisites

    • celestia-app installed (based on compatible versions)
    • celestia node binary installed
    • jq installed
    • nc (netcat) installed

    Bash script

    This method will start up the testnet with a bash script. It still assumes you have the prerequisites installed.

    bash
    bash -c "$(curl -sL https://docs.celestia.org/start-local.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/start-local.sh)"

    To interact with the nodes, you can use the celestia and celestia-appd CLIs. Use the funding and testing section below as a guide.

    Manual setup

    Starting the validator node

    First, navigate to the celestia-app scripts directory and run the single node script:

    bash
    cd celestia-app/scripts
     bash single-node.sh
    cd celestia-app/scripts
    -bash single-node.sh

    Setting up the bridge node

    Once your validator node is running, get the genesis block hash:

    bash
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'

    This will return a hash like:

    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Set this as an environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the bridge node:

    bash
    celestia bridge init \
    +bash single-node.sh

    Setting up the bridge node

    Once your validator node is running, get the genesis block hash:

    bash
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'
    curl -X GET "localhost:26657/block?height=1" | jq -r '.result .block_id.hash'

    This will return a hash like:

    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Set this as an environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the bridge node:

    bash
    celestia bridge init \
         --node.store $HOME/.celestia-custom-bridge \
         --core.ip localhost \
         --core.grpc.port 9090 \
    @@ -69,7 +69,7 @@
         --core.ip localhost \
         --core.grpc.port 9090 \
         --core.rpc.port 26657 \
    -    --p2p.network test

    Setting up the light node

    In a new terminal, set the same environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the light node:

    bash
    celestia light init \
    +    --p2p.network test

    Setting up the light node

    In a new terminal, set the same environment variable:

    bash
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595
    export CELESTIA_CUSTOM=test:1D53B32ACB02563E425BA1F8B5178B06A748E0F7B9748A8B1D07C34B454AF595

    Initialize the light node:

    bash
    celestia light init \
         --p2p.network test \
         --core.ip localhost:26657 \
         --node.store $HOME/.celestia-custom-light/
    celestia light init \
    @@ -111,7 +111,7 @@
         --core.ip localhost:26657 \
         --node.store $HOME/.celestia-custom-light/ \
         --headers.trusted-peers /ip4/10.0.0.125/udp/2121/webrtc-direct/certhash/uEiBXDYwH1McBsLM2aEc3SdvAuhq2ZQ0RUgbjgTvXMQm7LA/p2p/12D3KooWAVsZ36CdczaEXNNnDpsPcVyAnbeBe5EPG7AjttRGfux7 \
    -    --rpc.port 42069

    Funding and testing

    Get the bridge node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-bridge
    celestia state account-address --node.store $HOME/.celestia-custom-bridge

    Get the light node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069

    Send funds to the light node:

    bash
    celestia-appd tx bank send validator celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3 10000000utia \
    +    --rpc.port 42069

    Funding and testing

    Get the bridge node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-bridge
    celestia state account-address --node.store $HOME/.celestia-custom-bridge

    Get the light node's account address:

    bash
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069
    celestia state account-address --node.store $HOME/.celestia-custom-light --url http://localhost:42069

    Send funds to the light node:

    bash
    celestia-appd tx bank send validator celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3 10000000utia \
         --chain-id test \
         --keyring-backend test \
         --fees 500utia
    celestia-appd tx bank send validator celestia1p8yx4yveuu6ushyccepsuknaqpqn9ppq07m4n3 10000000utia \
    @@ -121,8 +121,8 @@
         --node.store $HOME/.celestia-custom-light \
         --url http://localhost:42069
    celestia blob submit 0x4772756763686174 '"Simplicity is the ultimate sophistication." -Leonardo da Vinci' \
         --node.store $HOME/.celestia-custom-light \
    -    --url http://localhost:42069
    - + --url http://localhost:42069 + \ No newline at end of file diff --git a/pr-1815/how-to-guides/mainnet.html b/pr-1815/how-to-guides/mainnet.html index 7ec1a45a6..46f0d29d2 100644 --- a/pr-1815/how-to-guides/mainnet.html +++ b/pr-1815/how-to-guides/mainnet.html @@ -7,14 +7,14 @@ - + - + - + @@ -50,8 +50,8 @@

    Mainnet Beta

    Mainnet Beta

    Welcome to the guide for Celestia’s Mainnet Beta, the production network that marks the pinnacle of Celestia’s evolution since its inception in 2019. This network is where all components of the Celestia ecosystem come to life in a real-world environment.

    Mainnet Beta is the culmination of rigorous community testing, upgrades, and feedback. It serves as the platform for deploying Mainnet Beta rollups and applications.

    Network stability and upgrades

    Mainnet Beta is a stable network, but will still receive updates and improvements. Any changes or upgrades will be coordinated with node operators and the broader Celestia community to ensure seamless integration and minimal service interruptions.

    As we step into unexplored territories with groundbreaking technologies like data availability sampling, it's crucial to remember that Mainnet Beta remains experimental at this stage. While the network is live and functional, users may encounter occasional instability or reduced performance.

    Network details

    DetailValue
    Chain IDcelestia
    Genesis hash6BE39EFD10BA412A9DB5288488303F5DD32CF386707A5BEF33617F4C43301872
    Genesis file https://github.com/celestiaorg/networks/blob/master/celestia/genesis.json
    Peers file https://github.com/celestiaorg/networks/blob/master/celestia/peers.txt
    Validators 100

    Software version numbers

    SoftwareVersion
    celestia-nodev0.20.4
    celestia-appv2.3.1

    Network parameters

    Full network parameters, such as max bytes, can be found in the celestia-app specifications.

    CIP-13 has been drafted to create a living document for these parameters as a part of the CIP process.

    Maximum bytes

    There is a hard limit on the total blob size in a transaction, which is determined by the effective maximum square size. Given that the current governance maximum square size is 64, the total blob size in a transaction must be slightly less than ~2 MiB, or 1,973,786 bytes to be exact.

    The following provides an approximation of the maximum block size:

    • The maximum square size is 64x64, which gives us 4096 shares.
    • One share is reserved for the PFB transaction, leaving us with 4095 shares.
    • The first sparse share has 478 bytes available, and the remaining sparse shares have 482 bytes each.

    This can be calculated as follows:

    Total Bytes=(1×478bytes)+(4094×482bytes)=1,973,786bytes

    Please note that there isn't a precise upper bound on the maximum total blob size. It depends on several factors:

    • The maximum square size, which is determined by a governance parameter and a versioned constant.
    • The maximum bytes in a block, which is determined by a governance parameter and a hard-coded constant in CometBFT.
    • The number of shares occupied by the PFB transaction share.

    These factors can cause the maximum total blob size that can be included in one block to vary.

    See the code in celestia-app and celestia-node.

    Integrations

    This guide contains the relevant sections for how to connect to Mainnet Beta, depending on the type of node you are running. Your best approach to participating is to first determine which node you would like to run. Each node’s guide will link to the relevant network in order to show you how to connect to them. Learn about the different endpoint types in the Cosmos SDK documentation.

    Here is a list of options of the types of nodes you can run in order to participate in Mainnet Beta:

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Consensus nodes

    Community consensus RPC endpoints

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs.

    • public-celestia-rpc.numia.xyz
    • rpc.celestia.pops.one
    • rpc.lunaroasis.net
    • rpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com
    • celestia.rpc.stakin-nodes.com
    • celestia.cumulo.org.es
    • rpc.archive.celestia.cumulo.com.es
    • rpc-celestia-01.stakeflow.io
    • rpc-celestia.alphab.ai
    • rpc-celestia-full.avril14th.org
    • celestia-rpc.easy2stake.com
    • celestia.rpc.kjnodes.com
    • celestia-rpc.0xcryptovestor.com
    • rpc-celestia-mainnet.trusted-point.com
    • celestia-rpc.chainode.tech:33373
    • celestia-mainnet-rpc.itrocket.net:443

    Community API endpoints

    • public-celestia-lcd.numia.xyz
    • celestia-rest.mesa.newmetric.xyz
    • api.celestia.pops.one
    • api.lunaroasis.net
    • api.celestia.nodestake.top
    • celestia-rpc.brightlystake.com/api
    • celestia.rest.stakin-nodes.com
    • celestia.api.cumulo.org.es
    • api.archive.celestia.cumulo.com.es
    • api-celestia.mzonder.com
    • api-celestia-01.stakeflow.io
    • api-celestia.alphab.ai
    • api-celestia-full.avril14th.org
    • celestia-lcd.easy2stake.com
    • celestia.api.kjnodes.com
    • api-celestia-mainnet.trusted-point.com
    • celestia-api.chainode.tech
    • celestia-mainnet-api.itrocket.net:443

    Community gRPC endpoints

    • public-celestia-grpc.numia.xyz
    • celestia-grpc.mesa.newmetric.xyz
    • grpc.celestia.pops.one
    • grpc.lunaroasis.net:443
    • grpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com:9090
    • celestia.grpc.stakin-nodes.com:443
    • celestia.grpc.cumulo.org.es:443
    • grpc.archive.celestia.cumulo.com.es:443
    • grpc-celestia-01.stakeflow.io:15002
    • rpc-celestia.alphab.ai:9090
    • grpc-celestia-full.avril14th.org
    • celestia.grpc.kjnodes.com:443
    • grpc-celestia-mainnet.trusted-point.com:9095
    • celestia-grpc.chainode.tech:443
    • celestia-mainnet-grpc.itrocket.net:443

    Community WebSocket endpoints

    • wss://celestia-ws.chainode.tech:33373/websocket
    • wss://celestia-mainnet-ws.itrocket.net:443/websocket
    • wss://celestia.cumulo.org.es:443/websocket
    • wss://rpc.archive.celestia.cumulo.com.es:443/websocket

    Data availability nodes

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    TIP

    bash
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>

    Bridge nodes

    Not all RPC endpoints guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

    RPCs for DA nodes to initialise or start your celestia-node to Mainnet Beta with:

    • public-celestia-consensus.numia.xyz
      • gRPC: port 9090
      • RPC: port 26657
    • rpc.celestia.pops.one
      • gRPC: port 9090
      • RPC: port 26657
    • consensus.lunaroasis.net
      • gRPC: port 9090
      • RPC: port 26657
    • rpc-celestia.alphab.ai
      • gRPC: port 9090
      • RPC: port 26657
    • celestia-mainnet-consensus.itrocket.net
      • gRPC: port 9090
      • RPC: port 26657

    DA full and light nodes might have troubles connecting to the networks, so you can check out this Grafana dashboard to see health/uptime status of DA bootstrappers (now celestia network only).

    You can find the status of these endpoints.

    Archival DA RPC endpoints

    By default, light nodes prune recent data to save on storage space. Archival data availability (DA) nodes store the entire history of the chain without pruning any data so all data available data is retrievable. You can read more about light vs archival nodes.

    Grove archival endpoints

    You can provision your own Celestia Archival endpoint on Grove. Learn more about Celestia on Grove, or find the fully supported spec.

    There is a sandbox you can leverage for testing straight in your browser:

    grove-sandbox

    Explorers

    There are multiple explorers you can use for Mainnet Beta:

    Analytics

    The following websites provide analytics for Celestia:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mainnet Beta:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    - +

    Mainnet Beta

    Mainnet Beta

    Welcome to the guide for Celestia’s Mainnet Beta, the production network that marks the pinnacle of Celestia’s evolution since its inception in 2019. This network is where all components of the Celestia ecosystem come to life in a real-world environment.

    Mainnet Beta is the culmination of rigorous community testing, upgrades, and feedback. It serves as the platform for deploying Mainnet Beta rollups and applications.

    Network stability and upgrades

    Mainnet Beta is a stable network, but will still receive updates and improvements. Any changes or upgrades will be coordinated with node operators and the broader Celestia community to ensure seamless integration and minimal service interruptions.

    As we step into unexplored territories with groundbreaking technologies like data availability sampling, it's crucial to remember that Mainnet Beta remains experimental at this stage. While the network is live and functional, users may encounter occasional instability or reduced performance.

    Network details

    DetailValue
    Chain IDcelestia
    Genesis hash6BE39EFD10BA412A9DB5288488303F5DD32CF386707A5BEF33617F4C43301872
    Genesis file https://github.com/celestiaorg/networks/blob/master/celestia/genesis.json
    Peers file https://github.com/celestiaorg/networks/blob/master/celestia/peers.txt
    Validators 100

    Software version numbers

    SoftwareVersion
    celestia-nodev0.20.4
    celestia-appv2.3.1

    Network parameters

    Full network parameters, such as max bytes, can be found in the celestia-app specifications.

    CIP-13 has been drafted to create a living document for these parameters as a part of the CIP process.

    Maximum bytes

    There is a hard limit on the total blob size in a transaction, which is determined by the effective maximum square size. Given that the current governance maximum square size is 64, the total blob size in a transaction must be slightly less than ~2 MiB, or 1,973,786 bytes to be exact.

    The following provides an approximation of the maximum block size:

    • The maximum square size is 64x64, which gives us 4096 shares.
    • One share is reserved for the PFB transaction, leaving us with 4095 shares.
    • The first sparse share has 478 bytes available, and the remaining sparse shares have 482 bytes each.

    This can be calculated as follows:

    Total Bytes=(1×478bytes)+(4094×482bytes)=1,973,786bytes

    Please note that there isn't a precise upper bound on the maximum total blob size. It depends on several factors:

    • The maximum square size, which is determined by a governance parameter and a versioned constant.
    • The maximum bytes in a block, which is determined by a governance parameter and a hard-coded constant in CometBFT.
    • The number of shares occupied by the PFB transaction share.

    These factors can cause the maximum total blob size that can be included in one block to vary.

    See the code in celestia-app and celestia-node.

    Integrations

    This guide contains the relevant sections for how to connect to Mainnet Beta, depending on the type of node you are running. Your best approach to participating is to first determine which node you would like to run. Each node’s guide will link to the relevant network in order to show you how to connect to them. Learn about the different endpoint types in the Cosmos SDK documentation.

    Here is a list of options of the types of nodes you can run in order to participate in Mainnet Beta:

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Consensus nodes

    Community consensus RPC endpoints

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs.

    • public-celestia-rpc.numia.xyz
    • rpc.celestia.pops.one
    • rpc.lunaroasis.net
    • rpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com
    • celestia.rpc.stakin-nodes.com
    • celestia.cumulo.org.es
    • rpc.archive.celestia.cumulo.com.es
    • rpc-celestia-01.stakeflow.io
    • rpc-celestia.alphab.ai
    • rpc-celestia-full.avril14th.org
    • celestia-rpc.easy2stake.com
    • celestia.rpc.kjnodes.com
    • celestia-rpc.0xcryptovestor.com
    • rpc-celestia-mainnet.trusted-point.com
    • celestia-rpc.chainode.tech:33373
    • celestia-mainnet-rpc.itrocket.net:443

    Community API endpoints

    • public-celestia-lcd.numia.xyz
    • celestia-rest.mesa.newmetric.xyz
    • api.celestia.pops.one
    • api.lunaroasis.net
    • api.celestia.nodestake.top
    • celestia-rpc.brightlystake.com/api
    • celestia.rest.stakin-nodes.com
    • celestia.api.cumulo.org.es
    • api.archive.celestia.cumulo.com.es
    • api-celestia.mzonder.com
    • api-celestia-01.stakeflow.io
    • api-celestia.alphab.ai
    • api-celestia-full.avril14th.org
    • celestia-lcd.easy2stake.com
    • celestia.api.kjnodes.com
    • api-celestia-mainnet.trusted-point.com
    • celestia-api.chainode.tech
    • celestia-mainnet-api.itrocket.net:443

    Community gRPC endpoints

    • public-celestia-grpc.numia.xyz
    • celestia-grpc.mesa.newmetric.xyz
    • grpc.celestia.pops.one
    • grpc.lunaroasis.net:443
    • grpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com:9090
    • celestia.grpc.stakin-nodes.com:443
    • celestia.grpc.cumulo.org.es:443
    • grpc.archive.celestia.cumulo.com.es:443
    • grpc-celestia-01.stakeflow.io:15002
    • rpc-celestia.alphab.ai:9090
    • grpc-celestia-full.avril14th.org
    • celestia.grpc.kjnodes.com:443
    • grpc-celestia-mainnet.trusted-point.com:9095
    • celestia-grpc.chainode.tech:443
    • celestia-mainnet-grpc.itrocket.net:443

    Community WebSocket endpoints

    • wss://celestia-ws.chainode.tech:33373/websocket
    • wss://celestia-mainnet-ws.itrocket.net:443/websocket
    • wss://celestia.cumulo.org.es:443/websocket
    • wss://rpc.archive.celestia.cumulo.com.es:443/websocket

    Data availability nodes

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    TIP

    bash
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>
    celestia <da_type> start --core.ip <url> -–core.grpc.port <port>

    Bridge nodes

    Not all RPC endpoints guarantee the full block history. Find an archive endpoint on the community dashboard or run your own consensus node with no pruning for your bridge node.

    RPCs for DA nodes to initialise or start your celestia-node to Mainnet Beta with:

    • public-celestia-consensus.numia.xyz
      • gRPC: port 9090
      • RPC: port 26657
    • rpc.celestia.pops.one
      • gRPC: port 9090
      • RPC: port 26657
    • consensus.lunaroasis.net
      • gRPC: port 9090
      • RPC: port 26657
    • rpc-celestia.alphab.ai
      • gRPC: port 9090
      • RPC: port 26657
    • celestia-mainnet-consensus.itrocket.net
      • gRPC: port 9090
      • RPC: port 26657

    DA full and light nodes might have troubles connecting to the networks, so you can check out this Grafana dashboard to see health/uptime status of DA bootstrappers (now celestia network only).

    You can find the status of these endpoints.

    Archival DA RPC endpoints

    By default, light nodes prune recent data to save on storage space. Archival data availability (DA) nodes store the entire history of the chain without pruning any data so all data available data is retrievable. You can read more about light vs archival nodes.

    Grove archival endpoints

    You can provision your own Celestia Archival endpoint on Grove. Learn more about Celestia on Grove, or find the fully supported spec.

    There is a sandbox you can leverage for testing straight in your browser:

    grove-sandbox

    Explorers

    There are multiple explorers you can use for Mainnet Beta:

    Analytics

    The following websites provide analytics for Celestia:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mainnet Beta:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/mocha-testnet.html b/pr-1815/how-to-guides/mocha-testnet.html index 86bcc574f..735f8ba10 100644 --- a/pr-1815/how-to-guides/mocha-testnet.html +++ b/pr-1815/how-to-guides/mocha-testnet.html @@ -7,14 +7,14 @@ - + - + - + @@ -50,8 +50,8 @@

    Mocha testnet

    mocha-testnet

    This guide contains the relevant sections for how to connect to Mocha, depending on the type of node you are running. Mocha testnet is designed to help validators test out their infrastructure and node software. Developers are encouraged to deploy their sovereign rollups on Mocha, but we also recommend Arabica devnet for that as it is designed for development purposes.

    Mocha is a milestone in Celestia, allowing everyone to test out core functionalities on the network. Read the announcement. Your best approach to participating is to first determine which node you would like to run. Each node's guide will link to the relevant networks, to show you how to connect to them.

    You have a list of options on the types of nodes you can run to participate in Mocha:

    Consensus:

    Data Availability:

    Select the type of node you would like to run and follow the instructions on each respective page. Whenever you are asked to select the type of network you want to connect to in those guides, select Mocha to refer to the correct instructions on this page on how to connect to Mocha.

    Network details

    DetailValue
    Chain IDmocha-4
    Genesis hashB93BBE20A0FBFDF955811B6420F8433904664D45DB4BF51022BE4200C1A1680D
    Genesis file https://github.com/celestiaorg/networks/blob/master/mocha-4/genesis.json
    Peers file https://github.com/celestiaorg/networks/blob/master/mocha-4/peers.txt
    Validators 100

    Software version numbers

    SoftwareVersion
    celestia-nodev0.20.4-mocha
    celestia-appv3.0.1-mocha

    RPC for DA bridge, full, and light nodes

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    Bridge nodes

    Mentioned below RPC endpoints do not guarantee you the download of full blocks from them. We advise that if you are running a bridge node, that you also run a local consensus node in order to download full blocks from it.

    • public-celestia-mocha4-consensus.numia.xyz
    • mocha-4-consensus.mesa.newmetric.xyz
    • full.consensus.mocha-4.celestia-mocha.com
    • consensus-full-mocha-4.celestia-mocha.com
    • rpc-mocha.pops.one
    • celestia-testnet-consensus.itrocket.net
      • RPC port: 26657
      • gRPC port: 9090
    • rpc-celestia-testnet.cryptech.com.ua
      • gRPC: grpc-celestia-testnet.cryptech.com.ua:443

    Community RPC endpoints

    The RPC endpoint is to allow users to interact with Celestia's nodes by querying the node's state and broadcasting transactions on the Celestia network. The default port is 26657.

    • public-celestia-mocha4-consensus.numia.xyz:26657
    • mocha-4-consensus.mesa.newmetric.xyz:26657
    • celestia-testnet.brightlystake.com
    • rpc-celestia-mocha.trusted-point.com
    • rpc-celestia-testnet-01.stakeflow.io
    • mocha.celestia.rpc.cumulo.me
    • rpc.archive.mocha.cumulo.com.es
    • rpc-mocha-full.avril14th.org
    • rpc-1.testnet.celestia.nodes.guru
    • rpc-2.testnet.celestia.nodes.guru
    • celestia-testnet-rpc.itrocket.net:443
    • rpc-celestia-testnet.cryptech.com.ua:443

    Community API endpoints

    The API endpoint is to allow users to interact with the REST API in Cosmos SDK which is implemented using gRPC-gateway, which exposes gRPC endpoints as REST endpoints. This allows for communication with the node using REST calls, which can be useful if the client does not support gRPC or HTTP2. The default port is 1317.

    Community gRPC endpoints

    The gRPC endpoint is to allow users to interact with a Celestia Node using gRPC, a modern open-source and high-performance RPC framework. The default port is 9090. In the Cosmos SDK, gRPC is used to define state queries and broadcast transactions.

    • public-celestia-mocha4-consensus.numia.xyz:9090
    • mocha-4-consensus.mesa.newmetric.xyz:9090
    • grpc-mocha.pops.one
    • grpc.celestia-mocha.com:443
    • full.consensus.mocha-4.celestia-mocha.com:9090
    • consensus-full-mocha-4.celestia-mocha.com:9090
    • celestia-testnet.brightlystake.com:9390
    • grpc-celestia-mocha.trusted-point.com:9099
    • grpc-celestia-testnet-01.stakeflow.io:16002
    • mocha.grpc.cumulo.me:443
    • grpc.archive.mocha.cumulo.com.es:443
    • grpc-mocha-full.avril14th.org
    • grpc-1.testnet.celestia.nodes.guru:10790
    • grpc-2.testnet.celestia.nodes.guru:10790
    • celestia-testnet-grpc.itrocket.net:443
    • grpc-celestia-testnet.cryptech.com.ua:443

    Community bridge and full node endpoints

    The endpoints below are for bridge and full nodes only. They can be used to find bootstrapper peers in the p2p network.

    Bridge node 1:

    • da-bridge-mocha-4.celestia-mocha.com
    • bridge-mocha-4.da.celestia-mocha.com

    Bridge node 2:

    • da-bridge-mocha-4-2.celestia-mocha.com
    • bridge-mocha-4-2.da.celestia-mocha.com

    Full node 1:

    • da-full-1-mocha-4.celestia-mocha.com
    • full-1-mocha-4.da.celestia-mocha.com

    Full node 2:

    • da-full-2-mocha-4.celestia-mocha.com
    • full-2-mocha-4.da.celestia-mocha.com

    Mocha testnet faucet

    WARNING

    USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

    You can request from Mocha testnet Faucet on the #mocha-faucet channel on Celestia's Discord server with the following command:

    text
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

    NOTE

    Faucet has a limit of 10 tokens per week per address/Discord ID.

    Analytics

    The following websites provide analytics for Mocha Testnet:

    Explorers

    There are several explorers you can use for Mocha:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mocha testnet:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    - +

    Mocha testnet

    mocha-testnet

    This guide contains the relevant sections for how to connect to Mocha, depending on the type of node you are running. Mocha testnet is designed to help validators test out their infrastructure and node software. Developers are encouraged to deploy their sovereign rollups on Mocha, but we also recommend Arabica devnet for that as it is designed for development purposes.

    Mocha is a milestone in Celestia, allowing everyone to test out core functionalities on the network. Read the announcement. Your best approach to participating is to first determine which node you would like to run. Each node's guide will link to the relevant networks, to show you how to connect to them.

    You have a list of options on the types of nodes you can run to participate in Mocha:

    Consensus:

    Data Availability:

    Select the type of node you would like to run and follow the instructions on each respective page. Whenever you are asked to select the type of network you want to connect to in those guides, select Mocha to refer to the correct instructions on this page on how to connect to Mocha.

    Network details

    DetailValue
    Chain IDmocha-4
    Genesis hashB93BBE20A0FBFDF955811B6420F8433904664D45DB4BF51022BE4200C1A1680D
    Genesis file https://github.com/celestiaorg/networks/blob/master/mocha-4/genesis.json
    Peers file https://github.com/celestiaorg/networks/blob/master/mocha-4/peers.txt
    Validators 100

    Software version numbers

    SoftwareVersion
    celestia-nodev0.20.4-mocha
    celestia-appv3.0.1-mocha

    RPC for DA bridge, full, and light nodes

    Production RPC endpoints

    These RPC providers are meant to be used in production environments.

    ProviderURL
    NewMetrichttps://app.newmetric.xyz/start
    NumiaFor RPC access: https://docs.numia.xyz/overview/rpc-api-access
    NumiaFor data warehouse access: https://docs.numia.xyz/overview/sql-access/chains/celestia
    Grovehttps://www.grove.city/

    WARNING

    Do not rely on the free community endpoints listed below for production deployments. Production deployments should rely on service providers with SLAs or your own node.

    Community Data availability (DA) RPC endpoints for bridge node sync

    These RPC endpoints allow bridge nodes to sync blocks from the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default RPC port at 26657 to their respective DA node.

    Community Data availability (DA) gRPC endpoints for state access

    These gRPC endpoints for DA nodes provide state access for querying the chain’s state and broadcasting transactions (balances, blobs, etc.) to the Celestia network. For users, they will need to provide a –core.ip string from a consensus node’s URL or IP that populates a default gRPC port at 9090 to their respective DA node.

    Bridge nodes

    Mentioned below RPC endpoints do not guarantee you the download of full blocks from them. We advise that if you are running a bridge node, that you also run a local consensus node in order to download full blocks from it.

    • public-celestia-mocha4-consensus.numia.xyz
    • mocha-4-consensus.mesa.newmetric.xyz
    • full.consensus.mocha-4.celestia-mocha.com
    • consensus-full-mocha-4.celestia-mocha.com
    • rpc-mocha.pops.one
    • celestia-testnet-consensus.itrocket.net
      • RPC port: 26657
      • gRPC port: 9090
    • rpc-celestia-testnet.cryptech.com.ua
      • gRPC: grpc-celestia-testnet.cryptech.com.ua:443

    Community RPC endpoints

    The RPC endpoint is to allow users to interact with Celestia's nodes by querying the node's state and broadcasting transactions on the Celestia network. The default port is 26657.

    • public-celestia-mocha4-consensus.numia.xyz:26657
    • mocha-4-consensus.mesa.newmetric.xyz:26657
    • celestia-testnet.brightlystake.com
    • rpc-celestia-mocha.trusted-point.com
    • rpc-celestia-testnet-01.stakeflow.io
    • mocha.celestia.rpc.cumulo.me
    • rpc.archive.mocha.cumulo.com.es
    • rpc-mocha-full.avril14th.org
    • rpc-1.testnet.celestia.nodes.guru
    • rpc-2.testnet.celestia.nodes.guru
    • celestia-testnet-rpc.itrocket.net:443
    • rpc-celestia-testnet.cryptech.com.ua:443

    Community API endpoints

    The API endpoint is to allow users to interact with the REST API in Cosmos SDK which is implemented using gRPC-gateway, which exposes gRPC endpoints as REST endpoints. This allows for communication with the node using REST calls, which can be useful if the client does not support gRPC or HTTP2. The default port is 1317.

    Community gRPC endpoints

    The gRPC endpoint is to allow users to interact with a Celestia Node using gRPC, a modern open-source and high-performance RPC framework. The default port is 9090. In the Cosmos SDK, gRPC is used to define state queries and broadcast transactions.

    • public-celestia-mocha4-consensus.numia.xyz:9090
    • mocha-4-consensus.mesa.newmetric.xyz:9090
    • grpc-mocha.pops.one
    • grpc.celestia-mocha.com:443
    • full.consensus.mocha-4.celestia-mocha.com:9090
    • consensus-full-mocha-4.celestia-mocha.com:9090
    • celestia-testnet.brightlystake.com:9390
    • grpc-celestia-mocha.trusted-point.com:9099
    • grpc-celestia-testnet-01.stakeflow.io:16002
    • mocha.grpc.cumulo.me:443
    • grpc.archive.mocha.cumulo.com.es:443
    • grpc-mocha-full.avril14th.org
    • grpc-1.testnet.celestia.nodes.guru:10790
    • grpc-2.testnet.celestia.nodes.guru:10790
    • celestia-testnet-grpc.itrocket.net:443
    • grpc-celestia-testnet.cryptech.com.ua:443

    Community bridge and full node endpoints

    The endpoints below are for bridge and full nodes only. They can be used to find bootstrapper peers in the p2p network.

    Bridge node 1:

    • da-bridge-mocha-4.celestia-mocha.com
    • bridge-mocha-4.da.celestia-mocha.com

    Bridge node 2:

    • da-bridge-mocha-4-2.celestia-mocha.com
    • bridge-mocha-4-2.da.celestia-mocha.com

    Full node 1:

    • da-full-1-mocha-4.celestia-mocha.com
    • full-1-mocha-4.da.celestia-mocha.com

    Full node 2:

    • da-full-2-mocha-4.celestia-mocha.com
    • full-2-mocha-4.da.celestia-mocha.com

    Mocha testnet faucet

    WARNING

    USING THIS FAUCET DOES NOT ENTITLE YOU TO ANY AIRDROP OR OTHER DISTRIBUTION OF MAINNET CELESTIA TOKENS. THERE ARE NO PUBLIC SALES OF ANY MAINNET CELESTIA TOKENS.

    You can request from Mocha testnet Faucet on the #mocha-faucet channel on Celestia's Discord server with the following command:

    text
    $request <CELESTIA-ADDRESS>
    $request <CELESTIA-ADDRESS>

    Where <CELESTIA-ADDRESS> is a celestia1****** generated address.

    NOTE

    Faucet has a limit of 10 tokens per week per address/Discord ID.

    Analytics

    The following websites provide analytics for Mocha Testnet:

    Explorers

    There are several explorers you can use for Mocha:

    Network upgrades

    There are a few ways to stay informed about network upgrades on Mocha testnet:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/multiaccounts.html b/pr-1815/how-to-guides/multiaccounts.html index 66b6bfe77..2b6afca82 100644 --- a/pr-1815/how-to-guides/multiaccounts.html +++ b/pr-1815/how-to-guides/multiaccounts.html @@ -7,11 +7,11 @@ - + - - + + @@ -51,8 +51,8 @@ --p2p.network=arabica --keyring.keyname testKey
    celestia light start --core.ip=consensus.celestia-arabica-11.com \
         --p2p.network=arabica --keyring.keyname testKey

    In this example, testKey becomes the default node key, and the node's address will change accordingly.

    Submitting blobs with a different signer/key name

    Option 1: Submit passing key name

    You can submit a blob by specifying a different key name:

    sh
    celestia blob submit 0x42690c204d39600fddd3 'gm' --key.name testKey2
    celestia blob submit 0x42690c204d39600fddd3 'gm' --key.name testKey2

    This transaction will be signed by the address associated with testKey2.

    Option 2: Submit passing signer address

    Alternatively, you can submit a blob by specifying the signer's address:

    sh
    celestia blob submit 0x42690c204d39600fddd3 'gm' --signer $SIGNER_ADDRESS
    celestia blob submit 0x42690c204d39600fddd3 'gm' --signer $SIGNER_ADDRESS

    Both options achieve the same result but use different inputs. The testKey2 points to SIGNER_ADDRESS in the KeyStore.

    Key management

    All keys and addresses must be added to the KeyStore. To create a new key, use the cel-key library:

    Creating a new key

    sh
    ./cel-key add testKey --keyring-backend test \
         --node.type light --p2p.network arabica
    ./cel-key add testKey --keyring-backend test \
    -    --node.type light --p2p.network arabica

    Importing an existing key

    sh
    ./cel-key import
    ./cel-key import

    Learn more on the Create a wallet with celestia-node page.

    Optional flags for write transactions

    All other flags are now optional for all write transactions. This means you don't have to specify gas/fee parameters each time. The configuration can handle it for you automatically.

    The default configuration applies to all write transactions, including those in the state module and blob.Submit. This simplifies the process of submitting transactions and reduces the need for manual input.

    For reference, see the:

    - + --node.type light --p2p.network arabica

    Importing an existing key

    sh
    ./cel-key import
    ./cel-key import

    Learn more on the Create a wallet with celestia-node page.

    Optional flags for write transactions

    All other flags are now optional for all write transactions. This means you don't have to specify gas/fee parameters each time. The configuration can handle it for you automatically.

    The default configuration applies to all write transactions, including those in the state module and blob.Submit. This simplifies the process of submitting transactions and reduces the need for manual input.

    For reference, see the:

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/network-upgrade-process.html b/pr-1815/how-to-guides/network-upgrade-process.html index 3c805408e..b663b39b9 100644 --- a/pr-1815/how-to-guides/network-upgrade-process.html +++ b/pr-1815/how-to-guides/network-upgrade-process.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Celestia network upgrade process

    Blockchain networks often need to upgrade with new features which require coordination work among the community of developers, validators, and node operators prior to activating the upgrades. This process is called a network upgrade, which can be breaking or non-breaking. During planned network upgrades the community will coordinate to prepare for the upcoming upgrade. Breaking network upgrades are not backward-compatible with older versions of the network software, which is why it is important that validators upgrade their software to continue validating on the network. Non-breaking network upgrades are backward-compatible and require less coordination.

    Network upgrade coordination

    As of the Lemongrass upgrade in September 2024, Celestia has implemented CIP-10, which establishes two methods for coordinating network upgrades:

    1. Pre-programmed height: Used for the Lemongrass network upgrade (v2)
    2. In-protocol signaling: Used for all subsequent upgrades (v3+)

    Under the in-protocol signaling mechanism, validators submit messages to signal their readiness and preference for the next version. The upgrade activates automatically once a quorum of 5/6 of validators have signaled for the same version.

    Upgrade process

    The upgrade process can be broken down into a few steps:

    1. Celestia Improvement Proposals (CIPs) are created for consensus-breaking changes and features that impact user experience. These CIPs are included in a meta-CIP, which define the scope of the upgrade.
    2. Celestia core developer teams implement the features defined in the CIPs.
    3. A new binary is released with the new features to be tested on testnets.
    4. Validators upgrade their nodes to the new binary, on Arabica devnet, Mocha testnet, and finally on Celestia Mainnet Beta.
      • Upgrades using pre-programmed height (v2) activate at a predetermined block number.
      • Upgrades using in-protocol signaling (v3+) activate one week after 5/6 of the voting power has signaled for a particular version

    Upcoming upgrade

    Ginger network upgrade

    The Ginger network upgrade (v3) will be the first to use the new in-protocol signaling mechanism defined in CIP-10. This upgrade includes changes defined in CIP-25:

    Key features include:

    • CIP-21: Introduce blob type with verified signer
    • CIP-24: Versioned Gas Scheduler Variables
    • CIP-26: Versioned timeouts
    • CIP-27: Block limits for number of PFBs and non-PFBs
    • CIP-28: Transaction size limit

    Unlike the Lemongrass upgrade, there will not be a pre-programmed upgrade height. Instead, validators will signal their readiness for v3 through in-protocol signaling, and the upgrade will automatically activate one week after 5/6 of voting power have signaled for a particular version.

    Learn more in the v3.0.0 release notes.

    INFO

    Validators should ensure they are running a v3 binary before signaling support for the upgrade.

    WARNING

    You do not need to use a tool like cosmovisor to upgrade the binary. Please upgrade your binary before signaling support for the new version.

    Past Upgrades

    Lemongrass network upgrade

    The Lemongrass network upgrade (v2) was the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass network upgrade included all of the CIPs listed in CIP-17 and implemented CIP-10 for future upgrades.

    NetworkChain IDDate and timeUpgrade height
    Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
    Mochamocha-42024/08/28 @ 14:00 UTC2585031
    Mainnet Betacelestia2024/09/18 @ 14:00 UTC2371495
    - +

    Celestia network upgrade process

    Blockchain networks often need to upgrade with new features which require coordination work among the community of developers, validators, and node operators prior to activating the upgrades. This process is called a network upgrade, which can be breaking or non-breaking. During planned network upgrades the community will coordinate to prepare for the upcoming upgrade. Breaking network upgrades are not backward-compatible with older versions of the network software, which is why it is important that validators upgrade their software to continue validating on the network. Non-breaking network upgrades are backward-compatible and require less coordination.

    Network upgrade coordination

    As of the Lemongrass upgrade in September 2024, Celestia has implemented CIP-10, which establishes two methods for coordinating network upgrades:

    1. Pre-programmed height: Used for the Lemongrass network upgrade (v2)
    2. In-protocol signaling: Used for all subsequent upgrades (v3+)

    Under the in-protocol signaling mechanism, validators submit messages to signal their readiness and preference for the next version. The upgrade activates automatically once a quorum of 5/6 of validators have signaled for the same version.

    Upgrade process

    The upgrade process can be broken down into a few steps:

    1. Celestia Improvement Proposals (CIPs) are created for consensus-breaking changes and features that impact user experience. These CIPs are included in a meta-CIP, which define the scope of the upgrade.
    2. Celestia core developer teams implement the features defined in the CIPs.
    3. A new binary is released with the new features to be tested on testnets.
    4. Validators upgrade their nodes to the new binary, on Arabica devnet, Mocha testnet, and finally on Celestia Mainnet Beta.
      • Upgrades using pre-programmed height (v2) activate at a predetermined block number.
      • Upgrades using in-protocol signaling (v3+) activate one week after 5/6 of the voting power has signaled for a particular version

    Upcoming upgrade

    Ginger network upgrade

    The Ginger network upgrade (v3) will be the first to use the new in-protocol signaling mechanism defined in CIP-10. This upgrade includes changes defined in CIP-25:

    Key features include:

    • CIP-21: Introduce blob type with verified signer
    • CIP-24: Versioned Gas Scheduler Variables
    • CIP-26: Versioned timeouts
    • CIP-27: Block limits for number of PFBs and non-PFBs
    • CIP-28: Transaction size limit

    Unlike the Lemongrass upgrade, there will not be a pre-programmed upgrade height. Instead, validators will signal their readiness for v3 through in-protocol signaling, and the upgrade will automatically activate one week after 5/6 of voting power have signaled for a particular version.

    Learn more in the v3.0.0 release notes.

    INFO

    Validators should ensure they are running a v3 binary before signaling support for the upgrade.

    WARNING

    You do not need to use a tool like cosmovisor to upgrade the binary. Please upgrade your binary before signaling support for the new version.

    Past Upgrades

    Lemongrass network upgrade

    The Lemongrass network upgrade (v2) was the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass network upgrade included all of the CIPs listed in CIP-17 and implemented CIP-10 for future upgrades.

    NetworkChain IDDate and timeUpgrade height
    Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
    Mochamocha-42024/08/28 @ 14:00 UTC2585031
    Mainnet Betacelestia2024/09/18 @ 14:00 UTC2371495
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/nodes-overview.html b/pr-1815/how-to-guides/nodes-overview.html index f750d787d..6eb741c2e 100644 --- a/pr-1815/how-to-guides/nodes-overview.html +++ b/pr-1815/how-to-guides/nodes-overview.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Overview to running nodes on Celestia

    There are many ways you can participate in the Celestia networks.

    Celestia node operators can run several options on the network.

    Consensus:

    • Validator node: This type of node participates in consensus by producing and voting on blocks.
    • Consensus node: A celestia-app full node to sync blockchain history.

    Data Availability:

    • Bridge node: This node bridges blocks between the Data-Availability network and the Consensus network.
    • Full storage node: This node stores all the data but does not connect to Consensus.
    • Light node: Light clients conduct data availability sampling on the Data Availability network.

    You can learn more about how to set up each different node by going through each tutorial guide.

    Data availability nodes

    Node typeMemoryCPUDiskBandwidth
    Light node500 MB RAMSingle core100 GB SSD56 Kbps
    Bridge node16 GB RAM6 cores2 TB NVME1 Gbps
    Full storage node16 GB RAMQuad-core2 TB NVME1 Gbps

    Consensus nodes

    Node typeMemoryCPUDiskBandwidth
    Validator16 GB RAM8 cores2 TB SSD1 Gbps
    Consensus node16 GB RAMQuad-core2 TB SSD1 Gbps

    Please provide any feedback on the tutorials and guides. If you notice a bug or issue, feel free to make a pull request or write up a Github issue!

    - +

    Overview to running nodes on Celestia

    There are many ways you can participate in the Celestia networks.

    Celestia node operators can run several options on the network.

    Consensus:

    • Validator node: This type of node participates in consensus by producing and voting on blocks.
    • Consensus node: A celestia-app full node to sync blockchain history.

    Data Availability:

    • Bridge node: This node bridges blocks between the Data-Availability network and the Consensus network.
    • Full storage node: This node stores all the data but does not connect to Consensus.
    • Light node: Light clients conduct data availability sampling on the Data Availability network.

    You can learn more about how to set up each different node by going through each tutorial guide.

    Data availability nodes

    Node typeMemoryCPUDiskBandwidth
    Light node500 MB RAMSingle core100 GB SSD56 Kbps
    Bridge node16 GB RAM6 cores2 TB NVME1 Gbps
    Full storage node16 GB RAMQuad-core2 TB NVME1 Gbps

    Consensus nodes

    Node typeMemoryCPUDiskBandwidth
    Validator16 GB RAM8 cores2 TB SSD1 Gbps
    Consensus node16 GB RAMQuad-core2 TB SSD1 Gbps

    Please provide any feedback on the tutorials and guides. If you notice a bug or issue, feel free to make a pull request or write up a Github issue!

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/optimism-devnet.html b/pr-1815/how-to-guides/optimism-devnet.html index 4b77d8052..b393f55e2 100644 --- a/pr-1815/how-to-guides/optimism-devnet.html +++ b/pr-1815/how-to-guides/optimism-devnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -121,8 +121,8 @@ value 0 yParity 0

    TIP

    You are looking for a batcher transaction to the address 0xFf00000000000000000000000000000000000901.

    First, remove the prefix 0xce. Now, set the input as the INPUT variable and encode it as base64:

    bash
    export INPUT=3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f
     export ENCODED_INPUT=$(echo "$INPUT" | xxd -r -p | base64)
    export INPUT=3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f
    -export ENCODED_INPUT=$(echo "$INPUT" | xxd -r -p | base64)

    TIP

    Remember to remove the 0xce prefix!

    Find the data on Celestia

    bash
    curl -s -X POST -H "Content-Type: application/json" -H "Authorization: Bearer $CELESTIA_NODE_AUTH_TOKEN" -d '{ "id": 1, "jsonrpc": "2.0", "method": "da.Get", "params": [["$ENCODED_INPUT"], "AAAAAAAAAAAAAAAAAAAAAAAAAAECAwQFBgcICRA="]}' http://127.0.0.1:26658
    curl -s -X POST -H "Content-Type: application/json" -H "Authorization: Bearer $CELESTIA_NODE_AUTH_TOKEN" -d '{ "id": 1, "jsonrpc": "2.0", "method": "da.Get", "params": [["$ENCODED_INPUT"], "AAAAAAAAAAAAAAAAAAAAAAAAAAECAwQFBgcICRA="]}' http://127.0.0.1:26658

    The params are []blobs, namespace, base64-encoded.

    Your result will look similar to the below!

    console
    {"jsonrpc":"2.0","result":["SGVsbG8gd28ybGQh"],"id":1}
    {"jsonrpc":"2.0","result":["SGVsbG8gd28ybGQh"],"id":1}

    Span batches

    Span batches can be enabled by setting OP_BATCHER_BATCH_TYPE: 1 in your docker-compose.yml file.

    Note that this requires the Delta activation time to be configured. For your devnet, you should set "l2GenesisDeltaTimeOffset": "0x0", in devnetL1-template.json. This will enable span batches and can be tested by grepping docker compose logs -f | grep batch_type which should include batch_type=SpanBatch and batch_type=1.

    - +export ENCODED_INPUT=$(echo "$INPUT" | xxd -r -p | base64)

    TIP

    Remember to remove the 0xce prefix!

    Find the data on Celestia

    bash
    curl -s -X POST -H "Content-Type: application/json" -H "Authorization: Bearer $CELESTIA_NODE_AUTH_TOKEN" -d '{ "id": 1, "jsonrpc": "2.0", "method": "da.Get", "params": [["$ENCODED_INPUT"], "AAAAAAAAAAAAAAAAAAAAAAAAAAECAwQFBgcICRA="]}' http://127.0.0.1:26658
    curl -s -X POST -H "Content-Type: application/json" -H "Authorization: Bearer $CELESTIA_NODE_AUTH_TOKEN" -d '{ "id": 1, "jsonrpc": "2.0", "method": "da.Get", "params": [["$ENCODED_INPUT"], "AAAAAAAAAAAAAAAAAAAAAAAAAAECAwQFBgcICRA="]}' http://127.0.0.1:26658

    The params are []blobs, namespace, base64-encoded.

    Your result will look similar to the below!

    console
    {"jsonrpc":"2.0","result":["SGVsbG8gd28ybGQh"],"id":1}
    {"jsonrpc":"2.0","result":["SGVsbG8gd28ybGQh"],"id":1}

    Span batches

    Span batches can be enabled by setting OP_BATCHER_BATCH_TYPE: 1 in your docker-compose.yml file.

    Note that this requires the Delta activation time to be configured. For your devnet, you should set "l2GenesisDeltaTimeOffset": "0x0", in devnetL1-template.json. This will enable span batches and can be tested by grepping docker compose logs -f | grep batch_type which should include batch_type=SpanBatch and batch_type=1.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/optimism.html b/pr-1815/how-to-guides/optimism.html index 6585a8b12..77d435514 100644 --- a/pr-1815/how-to-guides/optimism.html +++ b/pr-1815/how-to-guides/optimism.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,7 +48,7 @@

    Run an OP Stack rollup with Celestia underneath

    This guide will show you how to run your own OP Stack devnet and testnet that posts data to Celestia's Mocha testnet using roll-op and op-plasma-celestia.

    The roll-op tool is used to deploy and manage the OP Stack rollup environment, including the rollup, batcher, and other components. While the op-plasma-celestia integration allows the OP Stack to use Celestia as the data availability (DA) layer.

    This guide is in two parts:

    • First, you'll spin up a mock L1 environment and deploy a devnet that posts data to the Mocha testnet.
    • In the second part, you'll deploy a testnet that posts data to the Mocha testnet, but this time on a real L1 environment; the Ethereum Sepolia testnet. This will involve setting up a configuration file with the necessary details like Sepolia chain ID, RPC URL, and your deployment keys.

    After successful deployments, you'll be able to observe data blobs being successfully submitted to the Mocha testnet in the logs, as well as some activity on your rollup account on Celenium.

    If you don't have devops experience and would like to use a Rollups as a Service (RaaS) provider, see the RaaS category in the menu.

    This guide is also available on YouTube if you'd like to follow along with a video.

    Dependency setup

    Setting up your light node

    Sync and fund a Celestia light node. The light node must be fully synced and funded for you to be able to submit and retrieve PayForBlobs to Mocha Testnet. This allows your rollup to post and retrieve data without any errors.

    In order to mount existing data, you must have a node store that is in the default directory:

    bash
    $HOME/.celestia-light-mocha-4
    $HOME/.celestia-light-mocha-4
    bash
    $HOME/.celestia-light
    $HOME/.celestia-light
    bash
    $HOME/.celestia-light-arabica-11
    $HOME/.celestia-light-arabica-11

    By default, the node will run with the account named my_celes_key on Mocha. This is the account that needs to be funded.

    TIP

    Unless you changed your configuration, you won't have to change anything. 😎

    Deploying a devnet to Mocha

    See the Alt-DA x Celestia README for instructions on how to deploy a Devnet.

    TIP for macOS users

    If you are on macOS, you will need to run a venv before starting roll-op.

    sh
    cd $HOME/roll-op
    +

    Run an OP Stack rollup with Celestia underneath

    This guide will show you how to run your own OP Stack devnet and testnet that posts data to Celestia's Mocha testnet using roll-op and op-plasma-celestia.

    The roll-op tool is used to deploy and manage the OP Stack rollup environment, including the rollup, batcher, and other components. While the op-plasma-celestia integration allows the OP Stack to use Celestia as the data availability (DA) layer.

    This guide is in two parts:

    • First, you'll spin up a mock L1 environment and deploy a devnet that posts data to the Mocha testnet.
    • In the second part, you'll deploy a testnet that posts data to the Mocha testnet, but this time on a real L1 environment; the Ethereum Sepolia testnet. This will involve setting up a configuration file with the necessary details like Sepolia chain ID, RPC URL, and your deployment keys.

    After successful deployments, you'll be able to observe data blobs being successfully submitted to the Mocha testnet in the logs, as well as some activity on your rollup account on Celenium.

    If you don't have devops experience and would like to use a Rollups as a Service (RaaS) provider, see the RaaS category in the menu.

    This guide is also available on YouTube if you'd like to follow along with a video.

    Dependency setup

    Setting up your light node

    Sync and fund a Celestia light node. The light node must be fully synced and funded for you to be able to submit and retrieve PayForBlobs to Mocha Testnet. This allows your rollup to post and retrieve data without any errors.

    In order to mount existing data, you must have a node store that is in the default directory:

    bash
    $HOME/.celestia-light-mocha-4
    $HOME/.celestia-light-mocha-4
    bash
    $HOME/.celestia-light
    $HOME/.celestia-light
    bash
    $HOME/.celestia-light-arabica-11
    $HOME/.celestia-light-arabica-11

    By default, the node will run with the account named my_celes_key on Mocha. This is the account that needs to be funded.

    TIP

    Unless you changed your configuration, you won't have to change anything. 😎

    Deploying a devnet to Mocha

    See the Alt-DA x Celestia README for instructions on how to deploy a Devnet.

    TIP for macOS users

    If you are on macOS, you will need to run a venv before starting roll-op.

    sh
    cd $HOME/roll-op
     python3 -m venv ./venv
     source ./venv/bin/activate
    cd $HOME/roll-op
     python3 -m venv ./venv
    @@ -92,8 +92,8 @@
     admin_account = "0xaddress"
     admin_key = "privatekey"
     p2p_sequencer_account = "0xaddress"
    -p2p_sequencer_key = "privatekey"

    Your 0xaddress key must also be funded with testnet ETH. We recommend at least 10 SepoliaETH to get your chain started, but you will need more to keep it running longer.

    Congratulations

    Congrats! You now have an OP Stack rollup running with Celestia underneath.

    You can learn more about Alt-DA in Optimism docs.

    - +p2p_sequencer_key = "privatekey"

    Your 0xaddress key must also be funded with testnet ETH. We recommend at least 10 SepoliaETH to get your chain started, but you will need more to keep it running longer.

    Congratulations

    Congrats! You now have an OP Stack rollup running with Celestia underneath.

    You can learn more about Alt-DA in Optimism docs.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/participate.html b/pr-1815/how-to-guides/participate.html index de8f38632..a303fcf8b 100644 --- a/pr-1815/how-to-guides/participate.html +++ b/pr-1815/how-to-guides/participate.html @@ -7,10 +7,10 @@ - + - + @@ -18,7 +18,7 @@ - + @@ -54,8 +54,8 @@

    Participate in the Celestia networks

    Mainnet Beta

    Celestia’s Mainnet Beta is the production network for deploying Mainnet Beta rollups and applications. This marks the culmination of years of development and community testing. While the network is stable and continues to receive updates, it remains experimental and users may experience occasional instability or reduced performance.

    Compatible software versions for Mainnet Beta

    SoftwareVersion
    celestia-nodev0.20.4
    celestia-appv2.3.1

    Testnets

    Celestia currently has two existing testnets that you can participate in:

    Arabica Devnet

    Arabica devnet is a devnet focused on developers who want to deploy sovereign rollups on the latest changes from Celestia's codebase. Arabica will be updated frequently and might be unstable at times given new updates. Validators won't be able to validate on Arabica as it is not designed for validators to participate.

    Compatible software versions for Arabica devnet

    SoftwareVersion
    celestia-nodev0.20.4-arabica
    celestia-appv3.0.1-arabica

    Mocha testnet

    Mocha testnet is a testnet focused on enabling validators to test out their infrastructure by running nodes connected to the network. Developers can also deploy sovereign rollups on Mocha, it just will always be behind Arabica as Mocha upgrades are slower given they need to be done via breaking network upgrades in coordination with the validator community on Mocha.

    Compatible software versions for Mocha testnet

    SoftwareVersion
    celestia-nodev0.20.4-mocha
    celestia-appv3.0.1-mocha

    Network upgrades

    There are a few ways to stay informed about network upgrades:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    - +

    Participate in the Celestia networks

    Mainnet Beta

    Celestia’s Mainnet Beta is the production network for deploying Mainnet Beta rollups and applications. This marks the culmination of years of development and community testing. While the network is stable and continues to receive updates, it remains experimental and users may experience occasional instability or reduced performance.

    Compatible software versions for Mainnet Beta

    SoftwareVersion
    celestia-nodev0.20.4
    celestia-appv2.3.1

    Testnets

    Celestia currently has two existing testnets that you can participate in:

    Arabica Devnet

    Arabica devnet is a devnet focused on developers who want to deploy sovereign rollups on the latest changes from Celestia's codebase. Arabica will be updated frequently and might be unstable at times given new updates. Validators won't be able to validate on Arabica as it is not designed for validators to participate.

    Compatible software versions for Arabica devnet

    SoftwareVersion
    celestia-nodev0.20.4-arabica
    celestia-appv3.0.1-arabica

    Mocha testnet

    Mocha testnet is a testnet focused on enabling validators to test out their infrastructure by running nodes connected to the network. Developers can also deploy sovereign rollups on Mocha, it just will always be behind Arabica as Mocha upgrades are slower given they need to be done via breaking network upgrades in coordination with the validator community on Mocha.

    Compatible software versions for Mocha testnet

    SoftwareVersion
    celestia-nodev0.20.4-mocha
    celestia-appv3.0.1-mocha

    Network upgrades

    There are a few ways to stay informed about network upgrades:

    See the network upgrade process page to learn more about specific upgrades like the Ginger network upgrade.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/quick-start.html b/pr-1815/how-to-guides/quick-start.html index 103ee591e..8dbf9a472 100644 --- a/pr-1815/how-to-guides/quick-start.html +++ b/pr-1815/how-to-guides/quick-start.html @@ -7,13 +7,13 @@ - + - + - + @@ -137,8 +137,8 @@ "commitment": "0x715ab246772c923104c556dc28d5d4fcfca0398b0a252bcd19dd5705495756ac", "index": 29 } -}

    Let's break it down:

    • namespace: The namespace you used to categorize your data.
    • data: The data blob you posted to the network.
    • share_version: The version of the share. A share is a fixed-size data chunk that is associated with exactly one namespace.
    • commitment: The commitment of the data (see Blob Share Commitment Rules).
    • index: The index of the data share in the square.

    Congratulations! You've successfully learned how to run a light node to post and retrieve data from Celestia's Mocha testnet.

    Diving deeper into the stack

    This section covers some more in-depth topics that you may find useful when working with your Celestia light node.

    Get your auth token

    Your auth token may be useful when you want to interact with your Celestia light node from a client application. You can get your auth token by running:

    bash
    celestia light auth admin --p2p.network mocha
    celestia light auth admin --p2p.network mocha

    Use celestia light auth --help to learn more about the available options.

    Key management with cel-key

    In the first part of this guide, we generated a key when we initialized the light node.

    An advanced option for key management is using the cel-key utility, which is a separate tool from the celestia binary. cel-key is a key management tool that allows you to create, import, and manage keys for your Celestia DA node.

    If you're using the quickstart script above, you will have to build cel-key separately from source. You can find the instructions for building cel-key in the celestia-node documentation.

    Rust client tutorial

    If you're interested in writing a Rust program to interact with your Celestia light node, check out the Rust client tutorial.

    Golang client tutorial

    If you're interested in writing a Golang program to interact with your Celestia light node, check out the Golang client tutorial.

    Node store contents

    As described in the initialize the light node section above, the node store is created in the ~/.celestia-<node-type>-<network> directory.

    In this guide, the node store for ~/.celestia-light-mocha-4 contains the following directories and file types:

    • config.toml: Node configuration settings
    • data/: Contains database files
      • .vlog files: Value log files storing actual data
      • .sst files: Static sorted tables containing indexed data
      • System files: DISCARD, KEYREGISTRY, and MANIFEST for database management
    • keys/: Stores node identity and account keys
      • Contains encoded node identifiers
      • keyring-test/: Test keyring directory
        • .address files: Account addresses
        • .info files: Key metadata and information

    Troubleshooting

    If you run into issues, check out the troubleshooting page for common problems and solutions.

    Next steps

    Check out the rollup stacks page to get started learning about ways to build whatever with Celestia underneath.

    Head to the next page to learn about different node types for the consensus and DA networks.

    - +}

    Let's break it down:

    • namespace: The namespace you used to categorize your data.
    • data: The data blob you posted to the network.
    • share_version: The version of the share. A share is a fixed-size data chunk that is associated with exactly one namespace.
    • commitment: The commitment of the data (see Blob Share Commitment Rules).
    • index: The index of the data share in the square.

    Congratulations! You've successfully learned how to run a light node to post and retrieve data from Celestia's Mocha testnet.

    Diving deeper into the stack

    This section covers some more in-depth topics that you may find useful when working with your Celestia light node.

    Get your auth token

    Your auth token may be useful when you want to interact with your Celestia light node from a client application. You can get your auth token by running:

    bash
    celestia light auth admin --p2p.network mocha
    celestia light auth admin --p2p.network mocha

    Use celestia light auth --help to learn more about the available options.

    Key management with cel-key

    In the first part of this guide, we generated a key when we initialized the light node.

    An advanced option for key management is using the cel-key utility, which is a separate tool from the celestia binary. cel-key is a key management tool that allows you to create, import, and manage keys for your Celestia DA node.

    If you're using the quickstart script above, you will have to build cel-key separately from source. You can find the instructions for building cel-key in the celestia-node documentation.

    Rust client tutorial

    If you're interested in writing a Rust program to interact with your Celestia light node, check out the Rust client tutorial.

    Golang client tutorial

    If you're interested in writing a Golang program to interact with your Celestia light node, check out the Golang client tutorial.

    Node store contents

    As described in the initialize the light node section above, the node store is created in the ~/.celestia-<node-type>-<network> directory.

    In this guide, the node store for ~/.celestia-light-mocha-4 contains the following directories and file types:

    • config.toml: Node configuration settings
    • data/: Contains database files
      • .vlog files: Value log files storing actual data
      • .sst files: Static sorted tables containing indexed data
      • System files: DISCARD, KEYREGISTRY, and MANIFEST for database management
    • keys/: Stores node identity and account keys
      • Contains encoded node identifiers
      • keyring-test/: Test keyring directory
        • .address files: Account addresses
        • .info files: Key metadata and information

    Troubleshooting

    If you run into issues, check out the troubleshooting page for common problems and solutions.

    Next steps

    Check out the rollup stacks page to get started learning about ways to build whatever with Celestia underneath.

    Head to the next page to learn about different node types for the consensus and DA networks.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/rollup-stacks.html b/pr-1815/how-to-guides/rollup-stacks.html index 5bcc05c56..82a533eac 100644 --- a/pr-1815/how-to-guides/rollup-stacks.html +++ b/pr-1815/how-to-guides/rollup-stacks.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Rollup stacks

    If you're a developer and want to know what the benefits of modular blockchains are for you, you’ve come to the right place. This page will give you the rundown on modular blockchains and their benefits for developers like you.

    This section provides various guides and tutorials that cover different options for deploying rollups on Celestia.

    Quickstart - Building on Celestia

    Choose a framework

    So, you’re ready to start experimenting and building on Celestia? Here are a few options that are currently available for developers.

    Rollups as a Service

    Deploy your rollup with a RaaS provider.

    Smart contracts

    Deploy your smart contracts on dedicated EVM-compatible rollups.

    What is a rollup?

    A rollup is a type of blockchain that offloads some work to a layer 1, like Celestia. Rollups host applications and process user transactions. Once those transactions get processed, they are then published to layer 1. It’s layer 1s job to order those transactions and check that they are available, at minimum.

    What is a modular blockchain?

    With blockchains there are more or less four core functions that they do.

    • Execution: transaction execution and state update.
    • Settlement: finality and dispute resolution.
    • Consensus: agreement on transaction ordering.
    • Data availability: prove data was published to the network.

    Modular blockchains specialize in one or two of these functions rather than doing all of them like a monolithic blockchain. You probably know about layer 1s and layer 2s. That’s the general idea.

    A typical example of a modular blockchain you might’ve heard of is a rollup. Rollups host smart contracts and execute transactions, much like any monolithic chain. But, the data of those transactions get sent to a layer 1 blockchain to carry out the remaining functions.

    If you want to brush up on your understanding of modular blockchains, head over to learn modular.

    Benefits of modular blockchains

    Ease of deploying a chain

    One of the goals of modular blockchains is to make it as easy to deploy a blockchain as a smart contract. There are a few unique ways that modular blockchains can significantly reduce the cost of deploying a new blockchain.

    1. No validator set is required. Rollups can deploy without sourcing their own set of validators or sequencers.
    2. Inherit security from the start. Rollups don’t need to build all their security from scratch.
    3. Any part of the stack can be delegated. Development time can be reduced by outsourcing functions of the rollup to external providers.

    All in all, builders will be able to outsource as much of the stack as they need. Deploying a new blockchain will be as simple as clicking a few options to initialize a production-ready rollup.

    Scaling

    Of course, a much higher scale is necessary if we want to support many more users. And modular blockchains use some new innovative technologies that can help us get there.

    • Data availability sampling enables modular blockchains like Celestia to scale data availability with the number of light nodes - that means more capacity for rollups.
    • Fraud and validity proofs make rollups vastly more efficient to verify. Nodes only need to verify a small proof of transaction validity (validity proof) or assume transactions are valid by default (fraud proof). This means rollups don’t require every node in the network to re-execute every transaction.

    image

    • Decoupling execution from consensus lets developers define the VM that best fits the scaling needs of their application.
    • Separating applications across multiple rollups isolates congestion. If an application congests the execution capacity of one rollup, all other rollups remain unaffected in their execution capacity.

    All these scaling properties combined make new types of applications and features possible, like onchain gaming, dynamic metadata, and ephemeral rollups, to name a few.

    Customizability

    By design, modular blockchains don’t lock in any feature set. They promote experimentation and customization.

    Remember how decoupling execution from consensus enables VM customizability? Well, rollups are the execution component. Applications can run on their own rollup and adjust the VM to maximize their application's performance. Developers have that flexibility because Celestia's execution logic doesn't restrict rollups.

    Basically, rollups can be customized to integrate any new or existing VM stack.

    With existing rollup frameworks, developers can run rollup testnets using the EVM or Cosmos SDK. In the future, one can imagine a variety of VMs that rollup frameworks support, providing developers with more out-of-the-box options for their applications.

    Some customizations that could be made to a rollup's VM include custom precompiles, changing transaction processing from sequential to parallel, or adding support for private smart contracts.

    All of this only scratches the surface.

    - +

    Rollup stacks

    If you're a developer and want to know what the benefits of modular blockchains are for you, you’ve come to the right place. This page will give you the rundown on modular blockchains and their benefits for developers like you.

    This section provides various guides and tutorials that cover different options for deploying rollups on Celestia.

    Quickstart - Building on Celestia

    Choose a framework

    So, you’re ready to start experimenting and building on Celestia? Here are a few options that are currently available for developers.

    Rollups as a Service

    Deploy your rollup with a RaaS provider.

    Smart contracts

    Deploy your smart contracts on dedicated EVM-compatible rollups.

    What is a rollup?

    A rollup is a type of blockchain that offloads some work to a layer 1, like Celestia. Rollups host applications and process user transactions. Once those transactions get processed, they are then published to layer 1. It’s layer 1s job to order those transactions and check that they are available, at minimum.

    What is a modular blockchain?

    With blockchains there are more or less four core functions that they do.

    • Execution: transaction execution and state update.
    • Settlement: finality and dispute resolution.
    • Consensus: agreement on transaction ordering.
    • Data availability: prove data was published to the network.

    Modular blockchains specialize in one or two of these functions rather than doing all of them like a monolithic blockchain. You probably know about layer 1s and layer 2s. That’s the general idea.

    A typical example of a modular blockchain you might’ve heard of is a rollup. Rollups host smart contracts and execute transactions, much like any monolithic chain. But, the data of those transactions get sent to a layer 1 blockchain to carry out the remaining functions.

    If you want to brush up on your understanding of modular blockchains, head over to learn modular.

    Benefits of modular blockchains

    Ease of deploying a chain

    One of the goals of modular blockchains is to make it as easy to deploy a blockchain as a smart contract. There are a few unique ways that modular blockchains can significantly reduce the cost of deploying a new blockchain.

    1. No validator set is required. Rollups can deploy without sourcing their own set of validators or sequencers.
    2. Inherit security from the start. Rollups don’t need to build all their security from scratch.
    3. Any part of the stack can be delegated. Development time can be reduced by outsourcing functions of the rollup to external providers.

    All in all, builders will be able to outsource as much of the stack as they need. Deploying a new blockchain will be as simple as clicking a few options to initialize a production-ready rollup.

    Scaling

    Of course, a much higher scale is necessary if we want to support many more users. And modular blockchains use some new innovative technologies that can help us get there.

    • Data availability sampling enables modular blockchains like Celestia to scale data availability with the number of light nodes - that means more capacity for rollups.
    • Fraud and validity proofs make rollups vastly more efficient to verify. Nodes only need to verify a small proof of transaction validity (validity proof) or assume transactions are valid by default (fraud proof). This means rollups don’t require every node in the network to re-execute every transaction.

    image

    • Decoupling execution from consensus lets developers define the VM that best fits the scaling needs of their application.
    • Separating applications across multiple rollups isolates congestion. If an application congests the execution capacity of one rollup, all other rollups remain unaffected in their execution capacity.

    All these scaling properties combined make new types of applications and features possible, like onchain gaming, dynamic metadata, and ephemeral rollups, to name a few.

    Customizability

    By design, modular blockchains don’t lock in any feature set. They promote experimentation and customization.

    Remember how decoupling execution from consensus enables VM customizability? Well, rollups are the execution component. Applications can run on their own rollup and adjust the VM to maximize their application's performance. Developers have that flexibility because Celestia's execution logic doesn't restrict rollups.

    Basically, rollups can be customized to integrate any new or existing VM stack.

    With existing rollup frameworks, developers can run rollup testnets using the EVM or Cosmos SDK. In the future, one can imagine a variety of VMs that rollup frameworks support, providing developers with more out-of-the-box options for their applications.

    Some customizations that could be made to a rollup's VM include custom precompiles, changing transaction processing from sequential to parallel, or adding support for private smart contracts.

    All of this only scratches the surface.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/sp1-blobstream-deploy.html b/pr-1815/how-to-guides/sp1-blobstream-deploy.html index 0d86eab26..b62d289ad 100644 --- a/pr-1815/how-to-guides/sp1-blobstream-deploy.html +++ b/pr-1815/how-to-guides/sp1-blobstream-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -49,8 +49,8 @@

    New SP1 Blobstream deployments

    This document provides instructions for deploying SP1 Blobstream to a new chain.

    SP1 Blobstream is the latest implementation of Blobstream in Rust using the SP1 zkVM.

    Deploying the contracts

    To deploy SP1 Blobstream to a new chain, follow these steps:

    1. Clone the sp1-blobstream repository:
    shell
    git clone https://github.com/succinctlabs/sp1-blobstream
     cd sp1-blobstream
    git clone https://github.com/succinctlabs/sp1-blobstream
    -cd sp1-blobstream
    1. Follow the deployment instructions in the sp1-blobstream README.

    2. If you're deploying on a chain where there isn't a canonical verifier listed in the SP1 contract addresses, you'll need to:

      a. Deploy your own SP1 Verifier from the sp1-contracts matching your sp1-sdk version. b. Set the SP1_VERIFIER_ADDRESS in your .env file to the address of your deployed verifier.

    3. To run the prover:

      • For local proving, set SP1_PROVER=local in your environment.
      • To use the Succinct Proving Network for remote proving, set SP1_PROVER=network.
      • We recommend an instance with 64 vCPU and 128GB of RAM for local proving.

    Note: Any whitelisting for custom provers would need to be implemented in the application's smart contracts (e.g., by using an approvedProvers mapping).

    - +cd sp1-blobstream
    1. Follow the deployment instructions in the sp1-blobstream README.

    2. If you're deploying on a chain where there isn't a canonical verifier listed in the SP1 contract addresses, you'll need to:

      a. Deploy your own SP1 Verifier from the sp1-contracts matching your sp1-sdk version. b. Set the SP1_VERIFIER_ADDRESS in your .env file to the address of your deployed verifier.

    3. To run the prover:

      • For local proving, set SP1_PROVER=local in your environment.
      • To use the Succinct Proving Network for remote proving, set SP1_PROVER=network.
      • We recommend an instance with 64 vCPU and 128GB of RAM for local proving.

    Note: Any whitelisting for custom provers would need to be implemented in the application's smart contracts (e.g., by using an approvedProvers mapping).

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/submit-data.html b/pr-1815/how-to-guides/submit-data.html index cdfa6cfc1..0f5d24caf 100644 --- a/pr-1815/how-to-guides/submit-data.html +++ b/pr-1815/how-to-guides/submit-data.html @@ -7,11 +7,11 @@ - + - - + + @@ -345,8 +345,8 @@ } return err -}

    RPC to a celestia-node

    Using the JSON RPC API, submit data using the following methods:

    Learn more in the celestia-node API docs.

    Post a blob directly from Celenium

    Celenium provides a user-friendly interface to view and interact with data on Celestia, and allows for submitting blobs directly from the explorer interface.

    To submit a blob from Celenium, follow these steps:

    1. Navigate to the Celenium explorer and connect your wallet.
    2. Click on the terminal button in the top right corner of the screen and select the "Submit data blob" option.
    3. Next, ensure the file you are submitting is in a supported format and upload it.
    4. In the "Namespace" field, input the namespace you want to use for the blob in hex format.
    5. Finally, click on the "Continue" button to submit your blob, then approve the transaction in your wallet.

    Once the blob is submitted, you will see its hash on the screen. You can also use Celenium’s search bar to search for the blob's hash and view its details.

    - +}

    RPC to a celestia-node

    Using the JSON RPC API, submit data using the following methods:

    Learn more in the celestia-node API docs.

    Post a blob directly from Celenium

    Celenium provides a user-friendly interface to view and interact with data on Celestia, and allows for submitting blobs directly from the explorer interface.

    To submit a blob from Celenium, follow these steps:

    1. Navigate to the Celenium explorer and connect your wallet.
    2. Click on the terminal button in the top right corner of the screen and select the "Submit data blob" option.
    3. Next, ensure the file you are submitting is in a supported format and upload it.
    4. In the "Namespace" field, input the namespace you want to use for the blob in hex format.
    5. Finally, click on the "Continue" button to submit your blob, then approve the transaction in your wallet.

    Once the blob is submitted, you will see its hash on the screen. You can also use Celenium’s search bar to search for the blob's hash and view its details.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/systemd.html b/pr-1815/how-to-guides/systemd.html index cb9856131..887804c90 100644 --- a/pr-1815/how-to-guides/systemd.html +++ b/pr-1815/how-to-guides/systemd.html @@ -7,11 +7,11 @@ - + - - + + @@ -171,8 +171,8 @@ WantedBy=multi-user.target EOF

    If the file was created successfully you will be able to see its content:

    sh
    cat /etc/systemd/system/celestia-lightd.service
    cat /etc/systemd/system/celestia-lightd.service

    Enable and start celestia-lightd daemon:

    sh
    sudo systemctl enable celestia-lightd
     sudo systemctl start celestia-lightd
    sudo systemctl enable celestia-lightd
    -sudo systemctl start celestia-lightd

    Check if daemon has been started correctly:

    sh
    sudo systemctl status celestia-lightd
    sudo systemctl status celestia-lightd

    Check daemon logs in real time:

    sh
    sudo journalctl -u celestia-lightd.service -f
    sudo journalctl -u celestia-lightd.service -f

    Now, the Celestia light node will start syncing headers. After sync is finished, light node will do Data Availability Sampling (DAS) from the bridge node.

    - +sudo systemctl start celestia-lightd

    Check if daemon has been started correctly:

    sh
    sudo systemctl status celestia-lightd
    sudo systemctl status celestia-lightd

    Check daemon logs in real time:

    sh
    sudo journalctl -u celestia-lightd.service -f
    sudo journalctl -u celestia-lightd.service -f

    Now, the Celestia light node will start syncing headers. After sync is finished, light node will do Data Availability Sampling (DAS) from the bridge node.

    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/transaction-resubmission.html b/pr-1815/how-to-guides/transaction-resubmission.html index 36cf61d63..d39a65ea3 100644 --- a/pr-1815/how-to-guides/transaction-resubmission.html +++ b/pr-1815/how-to-guides/transaction-resubmission.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Transaction resubmission

    In cases where transactions are not included within a 75-second window, resubmission is necessary. This is especially important during network congestion, as transactions with relatively low fees may not be processed even after the network clears up.

    Regardless of whether they originate from celestia-app or celestia-node, transactions will not be re-gossiped, except in the presence of a new peer.

    If you are running a production application on Celestia, it is recommended to use a high-availability, production RPC provider for Mainnet Beta,Mocha, or Arabica.

    Monitoring and resubmission

    Monitor the status of your transactions. If a transaction is not included within a 75-second window, it should be resubmitted. This can be done manually or through automated processes.

    Changes introduced in celestiaorg/celestia-core#1089 may affect transaction gossiping and inclusion speed.

    Notes

    • All transactions, regardless of their origin, are subject to being sorted and pruned based on fees.
    • It is the user or developer's responsibility to monitor and possibly resubmit transactions if they are not included in a 75-second window.
    - +

    Transaction resubmission

    In cases where transactions are not included within a 75-second window, resubmission is necessary. This is especially important during network congestion, as transactions with relatively low fees may not be processed even after the network clears up.

    Regardless of whether they originate from celestia-app or celestia-node, transactions will not be re-gossiped, except in the presence of a new peer.

    If you are running a production application on Celestia, it is recommended to use a high-availability, production RPC provider for Mainnet Beta,Mocha, or Arabica.

    Monitoring and resubmission

    Monitor the status of your transactions. If a transaction is not included within a 75-second window, it should be resubmitted. This can be done manually or through automated processes.

    Changes introduced in celestiaorg/celestia-core#1089 may affect transaction gossiping and inclusion speed.

    Notes

    • All transactions, regardless of their origin, are subject to being sorted and pruned based on fees.
    • It is the user or developer's responsibility to monitor and possibly resubmit transactions if they are not included in a 75-second window.
    + \ No newline at end of file diff --git a/pr-1815/how-to-guides/validator-node.html b/pr-1815/how-to-guides/validator-node.html index bde8de340..938306737 100644 --- a/pr-1815/how-to-guides/validator-node.html +++ b/pr-1815/how-to-guides/validator-node.html @@ -7,12 +7,12 @@ - + - + - + @@ -78,7 +78,7 @@ raw_log: '[]' timestamp: "" tx: null -txhash: <tx-hash>

    You can check if the TX hash went through using the block explorer by inputting the txhash ID that was returned.

    Optional: Deploy the celestia-node

    Running a bridge node is critical to the Celestia network as it enables the data availability and consensus nodes to communicate with one another. It is recommended to support the data availability network, but is not required for celestia-app.

    If you are not running a bridge node, you can skip to run a validator node.

    This section describes part 2 of Celestia validator node setup: running a Celestia bridge node daemon.

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Initialize the bridge node

    Run the following:

    bash
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, initialize your node.

    Run the bridge node

    Run the following:

    bash
    celestia bridge start
    celestia bridge start

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    Run the validator node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    After completing all the necessary steps, you are now ready to run a validator! In order to create your validator onchain, follow the instructions below. Keep in mind that these steps are necessary ONLY if you want to participate in the consensus.

    Pick a moniker name of your choice! This is the validator name that will show up on public dashboards and explorers. VALIDATOR_WALLET must be the same you defined previously. Parameter --min-self-delegation=1000000 defines the amount of tokens that are self delegated from your validator wallet.

    Now, connect to the network of your choice.

    You have the following option of connecting to list of networks shown below:

    Continuing the validator tutorial, here are the steps to connect your validator to Mocha:

    bash
    MONIKER="your_moniker"
    +txhash: <tx-hash>

    You can check if the TX hash went through using the block explorer by inputting the txhash ID that was returned.

    Optional: Deploy the celestia-node

    Running a bridge node is critical to the Celestia network as it enables the data availability and consensus nodes to communicate with one another. It is recommended to support the data availability network, but is not required for celestia-app.

    If you are not running a bridge node, you can skip to run a validator node.

    This section describes part 2 of Celestia validator node setup: running a Celestia bridge node daemon.

    Install celestia-node

    You can follow the tutorial for installing celestia-node

    Initialize the bridge node

    Run the following:

    bash
    celestia bridge init --core.ip <URI>
    celestia bridge init --core.ip <URI>

    TIP

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    Using an RPC of your own, or one from Mainnet Beta, Mocha testnet or Arabica devnet, initialize your node.

    Run the bridge node

    Run the following:

    bash
    celestia bridge start
    celestia bridge start

    Optional: start the bridge node with SystemD

    Follow the tutorial on setting up the bridge node as a background process with SystemD.

    You have successfully set up a bridge node that is syncing with the network.

    Run the validator node

    If you are running celestia-app v1.x.x:

    sh
    celestia-appd start
    celestia-appd start

    If you are running celestia-app >= v2.0.0: then you'll want to start the node with a --v2-upgrade-height that is dependent on the network. The --v2-upgrade-height flag is only needed during the v2 upgrade height so after your node has executed the upgrade (e.g. you see the log upgraded from app version 1 to 2), you don't need to provide this flag for future celestia-appd start invocations.

    sh
    celestia-appd start --v2-upgrade-height 2371495
    celestia-appd start --v2-upgrade-height 2371495
    sh
    celestia-appd start --v2-upgrade-height 2585031
    celestia-appd start --v2-upgrade-height 2585031
    sh
    celestia-appd start --v2-upgrade-height 1751707
    celestia-appd start --v2-upgrade-height 1751707

    After completing all the necessary steps, you are now ready to run a validator! In order to create your validator onchain, follow the instructions below. Keep in mind that these steps are necessary ONLY if you want to participate in the consensus.

    Pick a moniker name of your choice! This is the validator name that will show up on public dashboards and explorers. VALIDATOR_WALLET must be the same you defined previously. Parameter --min-self-delegation=1000000 defines the amount of tokens that are self delegated from your validator wallet.

    Now, connect to the network of your choice.

    You have the following option of connecting to list of networks shown below:

    Continuing the validator tutorial, here are the steps to connect your validator to Mocha:

    bash
    MONIKER="your_moniker"
     VALIDATOR_WALLET="validator"
     
     celestia-appd tx staking create-validator \
    @@ -130,8 +130,8 @@
     raw_log: '[]'
     timestamp: ""
     tx: null
    -txhash: <tx-hash>

    You should now be able to see your validator from a block explorer

    Submit your validator information

    After starting your node, please submit your node as a seed and peer to the networks repository.

    Optional: Transaction indexer configuration options

    Follow the instructions under transaction indexer configuration options to configure your config.toml file to select which transactions to index.

    Additional resources

    For additional resources, refer to the extra resources for consensus nodessection of the consensus node page.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to update your binary to the latest version and restart your node with the relevant --v2-upgrade-height for the network you're running on. If your node still can't sync to the tip of the chain after the above steps, consider a celestia-appd tendermint reset-state to reset your node and start syncing from the genesis block.

    1. [Optional] Back up your validator keys.
    2. [Optional] Back up the data/priv_validator_state.json inside your CELESTIA_HOME directory.
    3. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    4. Remove the data/application.db inside your CELESTIA_HOME directory.
    5. Download the latest binary for your network.
    6. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    - +txhash: <tx-hash>

    You should now be able to see your validator from a block explorer

    Submit your validator information

    After starting your node, please submit your node as a seed and peer to the networks repository.

    Optional: Transaction indexer configuration options

    Follow the instructions under transaction indexer configuration options to configure your config.toml file to select which transactions to index.

    Additional resources

    For additional resources, refer to the extra resources for consensus nodessection of the consensus node page.

    FAQ

    +2/3 committed an invalid block: wrong Block.Header.Version

    If you encounter an error like:

    bash
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"
    2024-04-25 14:48:24 6:48PM ERR CONSENSUS FAILURE!!! err="+2/3 committed an invalid block: wrong Block.Header.Version. Expected {11 1}, got {11 2}" module=consensus stack="goroutine 214 [running]:\nruntime/debug.Stack()\n\t/usr/local/go/src/runtime/debug/stack.go:24 +0x64\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine.func2()\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:746 +0x44\npanic({0x1b91180?, 0x400153b240?})\n\t/usr/local/go/src/runtime/panic.go:770 +0x124\ngithub.com/tendermint/tendermint/consensus.(*State).finalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1637 +0xd30\ngithub.com/tendermint/tendermint/consensus.(*State).tryFinalizeCommit(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:1606 +0x26c\ngithub.com/tendermint/tendermint/consensus.(*State).handleCompleteProposal(0x400065ea88, 0x3)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:2001 +0x2d8\ngithub.com/tendermint/tendermint/consensus.(*State).handleMsg(0x400065ea88, {{0x2b30a00, 0x400143e048}, {0x40002a61b0, 0x28}})\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:856 +0x1c8\ngithub.com/tendermint/tendermint/consensus.(*State).receiveRoutine(0x400065ea88, 0x0)\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:782 +0x2c4\ncreated by github.com/tendermint/tendermint/consensus.(*State).OnStart in goroutine 169\n\t/go/pkg/mod/github.com/celestiaorg/celestia-core@v1.35.0-tm-v0.34.29/consensus/state.go:391 +0x110\n"

    then it is likely that the network has upgraded to a new app version but your consensus node was not prepared for the upgrade. To fix this, you'll need to update your binary to the latest version and restart your node with the relevant --v2-upgrade-height for the network you're running on. If your node still can't sync to the tip of the chain after the above steps, consider a celestia-appd tendermint reset-state to reset your node and start syncing from the genesis block.

    1. [Optional] Back up your validator keys.
    2. [Optional] Back up the data/priv_validator_state.json inside your CELESTIA_HOME directory.
    3. Remove DBs from your CELESTIA_HOME directory via: celestia-appd tendermint reset-state.
    4. Remove the data/application.db inside your CELESTIA_HOME directory.
    5. Download the latest binary for your network.
    6. Restart your consensus node with the relevant --v2-upgrade-height for the network you're running on.
    + \ No newline at end of file diff --git a/pr-1815/index.html b/pr-1815/index.html index 662a62b38..674912b3a 100644 --- a/pr-1815/index.html +++ b/pr-1815/index.html @@ -7,11 +7,11 @@ - + - - + + @@ -48,7 +48,7 @@ - + \ No newline at end of file diff --git a/pr-1815/learn/how-celestia-works/data-availability-faq.html b/pr-1815/learn/how-celestia-works/data-availability-faq.html index c3cefe997..caf81c075 100644 --- a/pr-1815/learn/how-celestia-works/data-availability-faq.html +++ b/pr-1815/learn/how-celestia-works/data-availability-faq.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Data availability FAQ

    What is data availability?

    Data availability answers the question, has this data been published? Specifically, a node will verify data availability when it receives a new block that is getting added to the chain. The node will attempt to download all the transaction data for the new block to verify availability. If the node can download all the transaction data, then it successfully verified data availability, proving that the block data was actually published to the network.

    Modular VS Monolithic

    As you’ll see, modular blockchains like Celestia employ other primitives that allow nodes to verify data availability more efficiently. Data availability is critical to the security of any blockchain because it ensures that anyone can inspect the ledger of transactions and verify it. Data availability becomes particularly problematic when scaling blockchains. As the blocks get bigger, it becomes impractical for normal users to download all the data, and therefore users can no longer verify the chain.

    What is the data availability problem?

    The problem with data availability occurs when the transaction data for a newly proposed block cannot be downloaded and verified. This type of attack by a block producer is called a data withholding attack, which sees the block producer withhold transaction data of a new block.

    Since transaction data is withheld, nodes cannot update to the latest state. Such an attack can have numerous consequences, from halting a chain to gaining the ability to steal funds. The severity of the consequences will depend on the type of blockchain (L1 or L2) and whether data availability is kept onchain or offchain. The data availability problem commonly arises around L2 scaling solutions like rollups and validiums.

    How do nodes verify data availability in Celestia?

    In most blockchains, nodes that verify data availability do so by downloading all transaction data for a block. If they are able to download all the data, they have verified its availability. In Celestia, light nodes have access to a new mechanism to verify data availability without needing to download all the data for a block. This new primitive for verifying data availability is called data availability sampling.

    What is data availability sampling?

    Data availability sampling is a mechanism for light nodes to verify data availability without having to download all data for a block. Data availability sampling (DAS) works by having light nodes conduct multiple rounds of random sampling for small portions of block data. As a light node completes more rounds of sampling for block data, it increases its confidence that data is available. Once the light node successfully reaches a predetermined confidence level (e.g. 99%) it will consider the block data as available.

    Want a simpler explanation? Check out this thread on how data availability sampling is like flipping a coin.

    What are some of the security assumptions that Celestia makes for data availability sampling?

    Celestia assumes that there is a minimum number of light nodes that are conducting data availability sampling for a given block size. This assumption is necessary so that a full node can reconstruct an entire block from the portions of data light nodes sampled and stored. The amount of light nodes that are needed will depend on the block size - for bigger blocks more light nodes are assumed to be running.

    A second notable assumption that is made by light nodes is that they are connected to at least one honest full node. This ensures that they can receive fraud proofs for incorrectly erasure coded blocks. If a light node is not connected to an honest full node, such as during an eclipse attack, it can’t verify that the block is improperly constructed.

    Why is block reconstruction necessary for security?

    In Celestia, blocks need to be erasure coded so that there is redundant data to aid the data availability sampling process. However, nodes tasked with erasure coding the data could do so incorrectly. Since Celestia uses fraud proofs to verify that erasure coding is incorrect, the full block data is needed to generate a bad encoding fraud proof.

    There could be a situation where validators only provide data to light nodes and not full nodes. If the full nodes don’t have the ability to reconstruct the full block from the portions of data stored by light nodes, they wouldn’t be able to generate a bad encoding fraud proof.

    What is data storage?

    Data storage is concerned with the ability to store and access past transaction data.

    Modular VS Monolithic

    Data storage and retrieval is needed for multiple purposes, such as:

    • Reading the information of a previous transaction
    • Syncing a node
    • Indexing and serving transaction data
    • Retrieving NFT information

    What is the problem around data storage?

    The issue with data storage is whether past transaction data can be stored and successfully retrieved at a later time. The inability to retrieve historical transaction data can cause problems, such as users being unable to access information about their past transactions or nodes that cannot sync from genesis. Luckily, the assumptions around storing and accessing past data are weak. Only a single copy of a blockchain’s history needs to be accessible for users to gain access to historical transaction data. In other words, data storage security is a 1 of N honesty assumption.

    What is the difference between data availability and data storage?

    Data availability is about verifying that transaction data for a new block is public and available. In contrast, data storage involves storing and accessing past transaction data from old blocks.

    Where does blockchain state fit into this?

    Up until now it’s been all about transaction data, but blockchain state is a related topic. The state is different from transaction data. Specifically, the state is like a current snapshot of the network, which includes information about account balances, smart contract balances, and validator set info. Problems that arise from the size of the state are different in nature than those around data availability and retrievability.

    Why doesn’t Celestia incentivize storage of historical data?

    Most blockchains don’t incentivize storage of data because it shouldn’t be the responsibility of a blockchain to guarantee past data will be retrievable forever. In addition, the data storage problem only requires a single party to store and provide the data for users, which is not a strong problem. As such, Celestia’s purpose is to provide a secure and scalable way to verify the availability of data. Once data has been verified as available, the job of storing and retrieving historical data is left up to other entities that require the data. Luckily, there are natural incentives for outside parties to store and serve historical data to users.

    Who may store historical data if there is no reward?

    There are multiple types of actors that may be likely to store historical data. Some of those include:

    • Block explorers that provide access to past transaction data.
    • Indexers that provide API queries for past data.
    • Applications or rollups that require historical data for certain processes.
    • Users that want to guarantee that they will have access to their transaction history.

    What are some things blockchains can do to provide stronger assurances of data retrievability?

    • Reward nodes based on the amount of transaction data they store and requests for data they serve (this is the case with some data storage blockchains, like Filecoin).
    • Publish transaction data onto a data storage blockchain that incentivizes storing and serving requests for historical data.
    - +

    Data availability FAQ

    What is data availability?

    Data availability answers the question, has this data been published? Specifically, a node will verify data availability when it receives a new block that is getting added to the chain. The node will attempt to download all the transaction data for the new block to verify availability. If the node can download all the transaction data, then it successfully verified data availability, proving that the block data was actually published to the network.

    Modular VS Monolithic

    As you’ll see, modular blockchains like Celestia employ other primitives that allow nodes to verify data availability more efficiently. Data availability is critical to the security of any blockchain because it ensures that anyone can inspect the ledger of transactions and verify it. Data availability becomes particularly problematic when scaling blockchains. As the blocks get bigger, it becomes impractical for normal users to download all the data, and therefore users can no longer verify the chain.

    What is the data availability problem?

    The problem with data availability occurs when the transaction data for a newly proposed block cannot be downloaded and verified. This type of attack by a block producer is called a data withholding attack, which sees the block producer withhold transaction data of a new block.

    Since transaction data is withheld, nodes cannot update to the latest state. Such an attack can have numerous consequences, from halting a chain to gaining the ability to steal funds. The severity of the consequences will depend on the type of blockchain (L1 or L2) and whether data availability is kept onchain or offchain. The data availability problem commonly arises around L2 scaling solutions like rollups and validiums.

    How do nodes verify data availability in Celestia?

    In most blockchains, nodes that verify data availability do so by downloading all transaction data for a block. If they are able to download all the data, they have verified its availability. In Celestia, light nodes have access to a new mechanism to verify data availability without needing to download all the data for a block. This new primitive for verifying data availability is called data availability sampling.

    What is data availability sampling?

    Data availability sampling is a mechanism for light nodes to verify data availability without having to download all data for a block. Data availability sampling (DAS) works by having light nodes conduct multiple rounds of random sampling for small portions of block data. As a light node completes more rounds of sampling for block data, it increases its confidence that data is available. Once the light node successfully reaches a predetermined confidence level (e.g. 99%) it will consider the block data as available.

    Want a simpler explanation? Check out this thread on how data availability sampling is like flipping a coin.

    What are some of the security assumptions that Celestia makes for data availability sampling?

    Celestia assumes that there is a minimum number of light nodes that are conducting data availability sampling for a given block size. This assumption is necessary so that a full node can reconstruct an entire block from the portions of data light nodes sampled and stored. The amount of light nodes that are needed will depend on the block size - for bigger blocks more light nodes are assumed to be running.

    A second notable assumption that is made by light nodes is that they are connected to at least one honest full node. This ensures that they can receive fraud proofs for incorrectly erasure coded blocks. If a light node is not connected to an honest full node, such as during an eclipse attack, it can’t verify that the block is improperly constructed.

    Why is block reconstruction necessary for security?

    In Celestia, blocks need to be erasure coded so that there is redundant data to aid the data availability sampling process. However, nodes tasked with erasure coding the data could do so incorrectly. Since Celestia uses fraud proofs to verify that erasure coding is incorrect, the full block data is needed to generate a bad encoding fraud proof.

    There could be a situation where validators only provide data to light nodes and not full nodes. If the full nodes don’t have the ability to reconstruct the full block from the portions of data stored by light nodes, they wouldn’t be able to generate a bad encoding fraud proof.

    What is data storage?

    Data storage is concerned with the ability to store and access past transaction data.

    Modular VS Monolithic

    Data storage and retrieval is needed for multiple purposes, such as:

    • Reading the information of a previous transaction
    • Syncing a node
    • Indexing and serving transaction data
    • Retrieving NFT information

    What is the problem around data storage?

    The issue with data storage is whether past transaction data can be stored and successfully retrieved at a later time. The inability to retrieve historical transaction data can cause problems, such as users being unable to access information about their past transactions or nodes that cannot sync from genesis. Luckily, the assumptions around storing and accessing past data are weak. Only a single copy of a blockchain’s history needs to be accessible for users to gain access to historical transaction data. In other words, data storage security is a 1 of N honesty assumption.

    What is the difference between data availability and data storage?

    Data availability is about verifying that transaction data for a new block is public and available. In contrast, data storage involves storing and accessing past transaction data from old blocks.

    Where does blockchain state fit into this?

    Up until now it’s been all about transaction data, but blockchain state is a related topic. The state is different from transaction data. Specifically, the state is like a current snapshot of the network, which includes information about account balances, smart contract balances, and validator set info. Problems that arise from the size of the state are different in nature than those around data availability and retrievability.

    Why doesn’t Celestia incentivize storage of historical data?

    Most blockchains don’t incentivize storage of data because it shouldn’t be the responsibility of a blockchain to guarantee past data will be retrievable forever. In addition, the data storage problem only requires a single party to store and provide the data for users, which is not a strong problem. As such, Celestia’s purpose is to provide a secure and scalable way to verify the availability of data. Once data has been verified as available, the job of storing and retrieving historical data is left up to other entities that require the data. Luckily, there are natural incentives for outside parties to store and serve historical data to users.

    Who may store historical data if there is no reward?

    There are multiple types of actors that may be likely to store historical data. Some of those include:

    • Block explorers that provide access to past transaction data.
    • Indexers that provide API queries for past data.
    • Applications or rollups that require historical data for certain processes.
    • Users that want to guarantee that they will have access to their transaction history.

    What are some things blockchains can do to provide stronger assurances of data retrievability?

    • Reward nodes based on the amount of transaction data they store and requests for data they serve (this is the case with some data storage blockchains, like Filecoin).
    • Publish transaction data onto a data storage blockchain that incentivizes storing and serving requests for historical data.
    + \ No newline at end of file diff --git a/pr-1815/learn/how-celestia-works/data-availability-layer.html b/pr-1815/learn/how-celestia-works/data-availability-layer.html index d7f58d715..c8cfab2a9 100644 --- a/pr-1815/learn/how-celestia-works/data-availability-layer.html +++ b/pr-1815/learn/how-celestia-works/data-availability-layer.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Celestia's data availability layer

    Celestia is a data availability (DA) layer that provides a scalable solution to the data availability problem. Due to the permissionless nature of the blockchain networks, a DA layer must provide a mechanism for the execution and settlement layers to check in a trust-minimized way whether transaction data is indeed available.

    Two key features of Celestia's DA layer are data availability sampling (DAS) and Namespaced Merkle trees (NMTs). Both features are novel blockchain scaling solutions: DAS enables light nodes to verify data availability without needing to download an entire block; NMTs enable execution and settlement layers on Celestia to download transactions that are only relevant to them.

    Data availability sampling (DAS)

    In general, light nodes download only block headers that contain commitments (i.e., Merkle roots) of the block data (i.e., the list of transactions).

    To make DAS possible, Celestia uses a 2-dimensional Reed-Solomon encoding scheme to encode the block data: every block data is split into k×k shares, arranged in a k×k matrix, and extended with parity data into a 2k×2k extended matrix by applying multiple times Reed-Solomon encoding.

    Then, 4k separate Merkle roots are computed for the rows and columns of the extended matrix; the Merkle root of these Merkle roots is used as the block data commitment in the block header.

    2D Reed-Soloman (RS) Encoding

    To verify that the data is available, Celestia light nodes are sampling the 2k×2k data shares.

    Every light node randomly chooses a set of unique coordinates in the extended matrix and queries full nodes for the data shares and the corresponding Merkle proofs at those coordinates. If light nodes receive a valid response for each sampling query, then there is a high probability guarantee that the whole block's data is available.

    Additionally, every received data share with a correct Merkle proof is gossiped to the network. As a result, as long as the Celestia light nodes are sampling together enough data shares (i.e., at least k×k unique shares), the full block can be recovered by honest full nodes.

    For more details on DAS, take a look at the original paper.

    Scalability

    DAS enables Celestia to scale the DA layer. DAS can be performed by resource-limited light nodes since each light node only samples a small portion of the block data. The more light nodes there are in the network, the more data they can collectively download and store.

    This means that increasing the number of light nodes performing DAS allows for larger blocks (i.e., with more transactions), while still keeping DAS feasible for resource-limited light nodes. However, in order to validate block headers, Celestia light nodes need to download the 4k intermediate Merkle roots.

    For a block data size of n2 bytes, this means that every light node must download O(n) bytes. Therefore, any improvement in the bandwidth capacity of Celestia light nodes has a quadratic effect on the throughput of Celestia's DA layer.

    Fraud proofs of incorrectly extended data

    The requirement of downloading the 4k intermediate Merkle roots is a consequence of using a 2-dimensional Reed-Solomon encoding scheme. Alternatively, DAS could be designed with a standard (i.e., 1-dimensional) Reed-Solomon encoding, where the original data is split into k shares and extended with k additional shares of parity data. Since the block data commitment is the Merkle root of the 2k resulting data shares, light nodes no longer need to download O(n) bytes to validate block headers.

    The downside of the standard Reed-Solomon encoding is dealing with malicious block producers that generate the extended data incorrectly.

    This is possible as Celestia does not require a majority of the consensus (i.e., block producers) to be honest to guarantee data availability. Thus, if the extended data is invalid, the original data might not be recoverable, even if the light nodes are sampling sufficient unique shares (i.e., at least k for a standard encoding and k×k for a 2-dimensional encoding).

    As a solution, Fraud Proofs of Incorrectly Generated Extended Data enable light nodes to reject blocks with invalid extended data. Such proofs require reconstructing the encoding and verifying the mismatch. With standard Reed-Solomon encoding, this entails downloading the original data, i.e., n2 bytes. Contrastingly, with 2-dimensional Reed-Solomon encoding, only O(n) bytes are required as it is sufficient to verify only one row or one column of the extended matrix.

    Namespaced Merkle trees (NMTs)

    Celestia partitions the block data into multiple namespaces, one for every application (e.g., rollup) using the DA layer. As a result, every application needs to download only its own data and can ignore the data of other applications.

    For this to work, the DA layer must be able to prove that the provided data is complete, i.e., all the data for a given namespace is returned. To this end, Celestia is using Namespaced Merkle trees (NMTs).

    An NMT is a Merkle tree with the leafs ordered by the namespace identifiers and the hash function modified so that every node in the tree includes the range of namespaces of all its descendants. The following figure shows an example of an NMT with height three (i.e., eight data shares). The data is partitioned into three namespaces.

    Namespaced Merkle Tree

    When an application requests the data for namespace 2, the DA layer must provide the data shares D3, D4, D5, and D6 and the nodes N2, N8 and N7 as proof (note that the application already has the root N14 from the block header).

    As a result, the application is able to check that the provided data is part of the block data. Furthermore, the application can verify that all the data for namespace 2 was provided. If the DA layer provides for example only the data shares D4 and D5, it must also provide nodes N12 and N11 as proofs. However, the application can identify that the data is incomplete by checking the namespace range of the two nodes, i.e., both N12 and N11 have descendants part of namespace 2.

    For more details on NMTs, refer to the original paper.

    Building a PoS blockchain for DA

    Providing data availability

    The Celestia DA layer consists of a PoS blockchain. Celestia is dubbing this blockchain as the celestia-app, an application that provides transactions to facilitate the DA layer and is built using Cosmos SDK. The following figure shows the main components of celestia-app.

    Main components of celestia-app

    celestia-app is built on top of celestia-core, a modified version of the Tendermint consensus algorithm. Among the more important changes to vanilla Tendermint, celestia-core:

    • Enables the erasure coding of block data (using the 2-dimensional Reed-Solomon encoding scheme).
    • Replaces the regular Merkle tree used by Tendermint to store block data with a Namespaced Merkle tree that enables the above layers (i.e., execution and settlement) to only download the needed data (for more details, see the section below describing use cases).

    For more details on the changes to Tendermint, take a look at the ADRs. Notice that celestia-core nodes are still using the Tendermint p2p network.

    Similarly to Tendermint, celestia-core is connected to the application layer (i.e., the state machine) by ABCI++, a major evolution of ABCI (Application Blockchain Interface).

    The celestia-app state machine is necessary to execute the PoS logic and to enable the governance of the DA layer.

    However, the celestia-app is data-agnostic -- the state machine neither validates nor stores the data that is made available by the celestia-app.

    - +

    Celestia's data availability layer

    Celestia is a data availability (DA) layer that provides a scalable solution to the data availability problem. Due to the permissionless nature of the blockchain networks, a DA layer must provide a mechanism for the execution and settlement layers to check in a trust-minimized way whether transaction data is indeed available.

    Two key features of Celestia's DA layer are data availability sampling (DAS) and Namespaced Merkle trees (NMTs). Both features are novel blockchain scaling solutions: DAS enables light nodes to verify data availability without needing to download an entire block; NMTs enable execution and settlement layers on Celestia to download transactions that are only relevant to them.

    Data availability sampling (DAS)

    In general, light nodes download only block headers that contain commitments (i.e., Merkle roots) of the block data (i.e., the list of transactions).

    To make DAS possible, Celestia uses a 2-dimensional Reed-Solomon encoding scheme to encode the block data: every block data is split into k×k shares, arranged in a k×k matrix, and extended with parity data into a 2k×2k extended matrix by applying multiple times Reed-Solomon encoding.

    Then, 4k separate Merkle roots are computed for the rows and columns of the extended matrix; the Merkle root of these Merkle roots is used as the block data commitment in the block header.

    2D Reed-Soloman (RS) Encoding

    To verify that the data is available, Celestia light nodes are sampling the 2k×2k data shares.

    Every light node randomly chooses a set of unique coordinates in the extended matrix and queries full nodes for the data shares and the corresponding Merkle proofs at those coordinates. If light nodes receive a valid response for each sampling query, then there is a high probability guarantee that the whole block's data is available.

    Additionally, every received data share with a correct Merkle proof is gossiped to the network. As a result, as long as the Celestia light nodes are sampling together enough data shares (i.e., at least k×k unique shares), the full block can be recovered by honest full nodes.

    For more details on DAS, take a look at the original paper.

    Scalability

    DAS enables Celestia to scale the DA layer. DAS can be performed by resource-limited light nodes since each light node only samples a small portion of the block data. The more light nodes there are in the network, the more data they can collectively download and store.

    This means that increasing the number of light nodes performing DAS allows for larger blocks (i.e., with more transactions), while still keeping DAS feasible for resource-limited light nodes. However, in order to validate block headers, Celestia light nodes need to download the 4k intermediate Merkle roots.

    For a block data size of n2 bytes, this means that every light node must download O(n) bytes. Therefore, any improvement in the bandwidth capacity of Celestia light nodes has a quadratic effect on the throughput of Celestia's DA layer.

    Fraud proofs of incorrectly extended data

    The requirement of downloading the 4k intermediate Merkle roots is a consequence of using a 2-dimensional Reed-Solomon encoding scheme. Alternatively, DAS could be designed with a standard (i.e., 1-dimensional) Reed-Solomon encoding, where the original data is split into k shares and extended with k additional shares of parity data. Since the block data commitment is the Merkle root of the 2k resulting data shares, light nodes no longer need to download O(n) bytes to validate block headers.

    The downside of the standard Reed-Solomon encoding is dealing with malicious block producers that generate the extended data incorrectly.

    This is possible as Celestia does not require a majority of the consensus (i.e., block producers) to be honest to guarantee data availability. Thus, if the extended data is invalid, the original data might not be recoverable, even if the light nodes are sampling sufficient unique shares (i.e., at least k for a standard encoding and k×k for a 2-dimensional encoding).

    As a solution, Fraud Proofs of Incorrectly Generated Extended Data enable light nodes to reject blocks with invalid extended data. Such proofs require reconstructing the encoding and verifying the mismatch. With standard Reed-Solomon encoding, this entails downloading the original data, i.e., n2 bytes. Contrastingly, with 2-dimensional Reed-Solomon encoding, only O(n) bytes are required as it is sufficient to verify only one row or one column of the extended matrix.

    Namespaced Merkle trees (NMTs)

    Celestia partitions the block data into multiple namespaces, one for every application (e.g., rollup) using the DA layer. As a result, every application needs to download only its own data and can ignore the data of other applications.

    For this to work, the DA layer must be able to prove that the provided data is complete, i.e., all the data for a given namespace is returned. To this end, Celestia is using Namespaced Merkle trees (NMTs).

    An NMT is a Merkle tree with the leafs ordered by the namespace identifiers and the hash function modified so that every node in the tree includes the range of namespaces of all its descendants. The following figure shows an example of an NMT with height three (i.e., eight data shares). The data is partitioned into three namespaces.

    Namespaced Merkle Tree

    When an application requests the data for namespace 2, the DA layer must provide the data shares D3, D4, D5, and D6 and the nodes N2, N8 and N7 as proof (note that the application already has the root N14 from the block header).

    As a result, the application is able to check that the provided data is part of the block data. Furthermore, the application can verify that all the data for namespace 2 was provided. If the DA layer provides for example only the data shares D4 and D5, it must also provide nodes N12 and N11 as proofs. However, the application can identify that the data is incomplete by checking the namespace range of the two nodes, i.e., both N12 and N11 have descendants part of namespace 2.

    For more details on NMTs, refer to the original paper.

    Building a PoS blockchain for DA

    Providing data availability

    The Celestia DA layer consists of a PoS blockchain. Celestia is dubbing this blockchain as the celestia-app, an application that provides transactions to facilitate the DA layer and is built using Cosmos SDK. The following figure shows the main components of celestia-app.

    Main components of celestia-app

    celestia-app is built on top of celestia-core, a modified version of the Tendermint consensus algorithm. Among the more important changes to vanilla Tendermint, celestia-core:

    • Enables the erasure coding of block data (using the 2-dimensional Reed-Solomon encoding scheme).
    • Replaces the regular Merkle tree used by Tendermint to store block data with a Namespaced Merkle tree that enables the above layers (i.e., execution and settlement) to only download the needed data (for more details, see the section below describing use cases).

    For more details on the changes to Tendermint, take a look at the ADRs. Notice that celestia-core nodes are still using the Tendermint p2p network.

    Similarly to Tendermint, celestia-core is connected to the application layer (i.e., the state machine) by ABCI++, a major evolution of ABCI (Application Blockchain Interface).

    The celestia-app state machine is necessary to execute the PoS logic and to enable the governance of the DA layer.

    However, the celestia-app is data-agnostic -- the state machine neither validates nor stores the data that is made available by the celestia-app.

    + \ No newline at end of file diff --git a/pr-1815/learn/how-celestia-works/monolithic-vs-modular.html b/pr-1815/learn/how-celestia-works/monolithic-vs-modular.html index ee191ca9c..0476f48f1 100644 --- a/pr-1815/learn/how-celestia-works/monolithic-vs-modular.html +++ b/pr-1815/learn/how-celestia-works/monolithic-vs-modular.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Monolithic vs. modular blockchains

    Blockchains instantiate replicated state machines: the nodes in a permissionless distributed network apply an ordered sequence of deterministic transactions to an initial state resulting in a common final state.

    In other words, this means that nodes in a network all follow the same set of rules (i.e., an ordered sequence of transactions) to go from a starting point (i.e., an initial state) to an ending point (i.e., a common final state). This process ensures that all nodes in the network agree on the final state of the blockchain, even though they operate independently.

    This means blockchains require the following four functions:

    • Execution entails executing transactions that update the state correctly. Thus, execution must ensure that only valid transactions are executed, i.e., transactions that result in valid state machine transitions.
    • Settlement entails an environment for execution layers to verify proofs, resolve fraud disputes, and bridge between other execution layers.
    • Consensus entails agreeing on the order of the transactions.
    • Data Availability (DA) entails making the transaction data available. Note that execution, settlement, and consensus require DA.

    Traditional blockchains, i.e. monolithic blockchains, implement all four functions together in a single base consensus layer. The problem with monolithic blockchains is that the consensus layer must perform numerous different tasks, and it cannot be optimized for only one of these functions. As a result, the monolithic paradigm limits the throughput of the system.

    Modular VS Monolithic

    As a solution, modular blockchains decouple these functions among multiple specialized layers as part of a modular stack. Due to the flexibility that specialization provides, there are many possibilities in which that stack can be arranged. For example, one such arrangement is the separation of the four functions into three specialized layers.

    The base layer consists of DA and consensus and thus, is referred to as the Consensus and DA layer (or for brevity, the DA layer), while both settlement and execution are moved on top in their own layers. As a result, every layer can be specialized to optimally perform only its function, and thus, increase the throughput of the system. Furthermore, this modular paradigm enables multiple execution layers, i.e., rollups, to use the same settlement and DA layers.

    - +

    Monolithic vs. modular blockchains

    Blockchains instantiate replicated state machines: the nodes in a permissionless distributed network apply an ordered sequence of deterministic transactions to an initial state resulting in a common final state.

    In other words, this means that nodes in a network all follow the same set of rules (i.e., an ordered sequence of transactions) to go from a starting point (i.e., an initial state) to an ending point (i.e., a common final state). This process ensures that all nodes in the network agree on the final state of the blockchain, even though they operate independently.

    This means blockchains require the following four functions:

    • Execution entails executing transactions that update the state correctly. Thus, execution must ensure that only valid transactions are executed, i.e., transactions that result in valid state machine transitions.
    • Settlement entails an environment for execution layers to verify proofs, resolve fraud disputes, and bridge between other execution layers.
    • Consensus entails agreeing on the order of the transactions.
    • Data Availability (DA) entails making the transaction data available. Note that execution, settlement, and consensus require DA.

    Traditional blockchains, i.e. monolithic blockchains, implement all four functions together in a single base consensus layer. The problem with monolithic blockchains is that the consensus layer must perform numerous different tasks, and it cannot be optimized for only one of these functions. As a result, the monolithic paradigm limits the throughput of the system.

    Modular VS Monolithic

    As a solution, modular blockchains decouple these functions among multiple specialized layers as part of a modular stack. Due to the flexibility that specialization provides, there are many possibilities in which that stack can be arranged. For example, one such arrangement is the separation of the four functions into three specialized layers.

    The base layer consists of DA and consensus and thus, is referred to as the Consensus and DA layer (or for brevity, the DA layer), while both settlement and execution are moved on top in their own layers. As a result, every layer can be specialized to optimally perform only its function, and thus, increase the throughput of the system. Furthermore, this modular paradigm enables multiple execution layers, i.e., rollups, to use the same settlement and DA layers.

    + \ No newline at end of file diff --git a/pr-1815/learn/how-celestia-works/overview.html b/pr-1815/learn/how-celestia-works/overview.html index b204b847a..dda68ab33 100644 --- a/pr-1815/learn/how-celestia-works/overview.html +++ b/pr-1815/learn/how-celestia-works/overview.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Introduction

    Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.

    Celestia enables the next generation of scalable blockchain architectures - modular blockchains. Celestia scales by decoupling execution from consensus and introducing a new primitive, data availability sampling.

    The former entails that Celestia is only responsible for ordering transactions and guaranteeing their data availability; this is similar to reducing consensus to atomic broadcast.

    The latter provides an efficient solution to the data availability problem by only requiring resource-limited light nodes to sample a small number of random shares from each block to verify data availability.

    Interestingly, more light nodes that participate in sampling increases the amount of data that the network can safely handle, enabling the block size to increase without equally increasing the cost to verify the chain.

    - +

    Introduction

    Celestia is a modular data availability network that securely scales with the number of users, making it easy for anyone to launch their own blockchain.

    Celestia enables the next generation of scalable blockchain architectures - modular blockchains. Celestia scales by decoupling execution from consensus and introducing a new primitive, data availability sampling.

    The former entails that Celestia is only responsible for ordering transactions and guaranteeing their data availability; this is similar to reducing consensus to atomic broadcast.

    The latter provides an efficient solution to the data availability problem by only requiring resource-limited light nodes to sample a small number of random shares from each block to verify data availability.

    Interestingly, more light nodes that participate in sampling increases the amount of data that the network can safely handle, enabling the block size to increase without equally increasing the cost to verify the chain.

    + \ No newline at end of file diff --git a/pr-1815/learn/how-celestia-works/transaction-lifecycle.html b/pr-1815/learn/how-celestia-works/transaction-lifecycle.html index e4987f238..8c9255382 100644 --- a/pr-1815/learn/how-celestia-works/transaction-lifecycle.html +++ b/pr-1815/learn/how-celestia-works/transaction-lifecycle.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,8 +48,8 @@

    The lifecycle of a celestia-app transaction

    Users request the celestia-app to make data available by sending PayForBlobs transactions. Every such transaction consists of the identity of the sender, the data to be made available, also referred to as the message, the data size, the namespace, and a signature. Every block producer batches multiple PayForBlobs transactions into a block.

    Before proposing the block though, the producer passes it to the state machine via ABCI++, where each PayForBlobs transaction is split into a namespaced message (denoted by Msg in the figure below), i.e., the data together with the namespace ID, and an executable transaction (denoted by e-Tx in the figure below) that does not contain the data, but only a commitment that can be used at a later time to prove that the data was indeed made available.

    Thus, the block data consists of data partitioned into namespaces and executable transactions. Note that only these transactions are executed by the Celestia state machine once the block is committed.

    Lifecycle of a celestia-app Transaction

    Next, the block producer adds to the block header a commitment of the block data. As described in the "Celestia's data availability layer" page, the commitment is the Merkle root of the 4k intermediate Merkle roots (i.e., one for each row and column of the extended matrix). To compute this commitment, the block producer performs the following operations:

    • It splits the executable transactions and the namespaced data into shares. Every share consists of some bytes prefixed by a namespace. To this end, the executable transactions are associated with a reserved namespace.
    • It arranges these shares into a square matrix (row-wise). Note that the shares are padded to the next power of two. The outcome square of size k×k is referred to as the original data.
    • It extends the original data to a 2k×2k square matrix using the 2-dimensional Reed-Solomon encoding scheme described above. The extended shares (i.e., containing erasure data) are associated with another reserved namespace.
    • It computes a commitment for every row and column of the extended matrix using the NMTs described above.

    Thus, the commitment of the block data is the root of a Merkle tree with the leaves the roots of a forest of Namespaced Merkle subtrees, one for every row and column of the extended matrix.

    Checking data availability

    DA network

    To enhance connectivity, the celestia-node augments the celestia-app with a separate libp2p network, i.e., the so-called DA network, that serves DAS requests.

    Light nodes connect to a celestia-node in the DA network, listen to extended block headers (i.e., the block headers together with the relevant DA metadata, such as the 4k intermediate Merkle roots), and perform DAS on the received headers (i.e., ask for random data shares).

    Note that although it is recommended, performing DAS is optional -- light nodes could just trust that the data corresponding to the commitments in the block headers was indeed made available by the Celestia DA layer. In addition, light nodes can also submit transactions to the celestia-app, i.e., PayForBlobs transactions.

    While performing DAS for a block header, every light node queries Celestia Nodes for a number of random data shares from the extended matrix and the corresponding Merkle proofs. If all the queries are successful, then the light node accepts the block header as valid (from a DA perspective).

    If at least one of the queries fails (i.e., either the data share is not received or the Merkle proof is invalid), then the light node rejects the block header and tries again later. The retrial is necessary to deal with false negatives, i.e., block headers being rejected although the block data is available. This may happen due to network congestion for example.

    Alternatively, light nodes may accept a block header although the data is not available, i.e., a false positive. This is possible since the soundness property (i.e., if an honest light node accepts a block as available, then at least one honest full node will eventually have the entire block data) is probabilistically guaranteed (for more details, take a look at the original paper).

    By fine tuning Celestia's parameters (e.g., the number of data shares sampled by each light node) the likelihood of false positives can be sufficiently reduced such that block producers have no incentive to withhold the block data.

    - +

    The lifecycle of a celestia-app transaction

    Users request the celestia-app to make data available by sending PayForBlobs transactions. Every such transaction consists of the identity of the sender, the data to be made available, also referred to as the message, the data size, the namespace, and a signature. Every block producer batches multiple PayForBlobs transactions into a block.

    Before proposing the block though, the producer passes it to the state machine via ABCI++, where each PayForBlobs transaction is split into a namespaced message (denoted by Msg in the figure below), i.e., the data together with the namespace ID, and an executable transaction (denoted by e-Tx in the figure below) that does not contain the data, but only a commitment that can be used at a later time to prove that the data was indeed made available.

    Thus, the block data consists of data partitioned into namespaces and executable transactions. Note that only these transactions are executed by the Celestia state machine once the block is committed.

    Lifecycle of a celestia-app Transaction

    Next, the block producer adds to the block header a commitment of the block data. As described in the "Celestia's data availability layer" page, the commitment is the Merkle root of the 4k intermediate Merkle roots (i.e., one for each row and column of the extended matrix). To compute this commitment, the block producer performs the following operations:

    • It splits the executable transactions and the namespaced data into shares. Every share consists of some bytes prefixed by a namespace. To this end, the executable transactions are associated with a reserved namespace.
    • It arranges these shares into a square matrix (row-wise). Note that the shares are padded to the next power of two. The outcome square of size k×k is referred to as the original data.
    • It extends the original data to a 2k×2k square matrix using the 2-dimensional Reed-Solomon encoding scheme described above. The extended shares (i.e., containing erasure data) are associated with another reserved namespace.
    • It computes a commitment for every row and column of the extended matrix using the NMTs described above.

    Thus, the commitment of the block data is the root of a Merkle tree with the leaves the roots of a forest of Namespaced Merkle subtrees, one for every row and column of the extended matrix.

    Checking data availability

    DA network

    To enhance connectivity, the celestia-node augments the celestia-app with a separate libp2p network, i.e., the so-called DA network, that serves DAS requests.

    Light nodes connect to a celestia-node in the DA network, listen to extended block headers (i.e., the block headers together with the relevant DA metadata, such as the 4k intermediate Merkle roots), and perform DAS on the received headers (i.e., ask for random data shares).

    Note that although it is recommended, performing DAS is optional -- light nodes could just trust that the data corresponding to the commitments in the block headers was indeed made available by the Celestia DA layer. In addition, light nodes can also submit transactions to the celestia-app, i.e., PayForBlobs transactions.

    While performing DAS for a block header, every light node queries Celestia Nodes for a number of random data shares from the extended matrix and the corresponding Merkle proofs. If all the queries are successful, then the light node accepts the block header as valid (from a DA perspective).

    If at least one of the queries fails (i.e., either the data share is not received or the Merkle proof is invalid), then the light node rejects the block header and tries again later. The retrial is necessary to deal with false negatives, i.e., block headers being rejected although the block data is available. This may happen due to network congestion for example.

    Alternatively, light nodes may accept a block header although the data is not available, i.e., a false positive. This is possible since the soundness property (i.e., if an honest light node accepts a block as available, then at least one honest full node will eventually have the entire block data) is probabilistically guaranteed (for more details, take a look at the original paper).

    By fine tuning Celestia's parameters (e.g., the number of data shares sampled by each light node) the likelihood of false positives can be sufficiently reduced such that block producers have no incentive to withhold the block data.

    + \ No newline at end of file diff --git a/pr-1815/learn/how-to-stake-tia.html b/pr-1815/learn/how-to-stake-tia.html index b55d263cc..c483e5a73 100644 --- a/pr-1815/learn/how-to-stake-tia.html +++ b/pr-1815/learn/how-to-stake-tia.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    How to stake TIA

    Celestia is a proof-of-stake blockchain based on the Cosmos SDK.

    Staking TIA as a delegator allows you to secure the Celestia network. This means that you can stake the native token TIA and vote on governance proposals.

    In this tutorial, you will learn how to stake TIA tokens via Keplr, Leap, and Gem wallets.

    Select your preferred wallet

    Keplr
    Leap
    Gem Wallet

    Stake TIA with Keplr wallet

    1️⃣ Open your Keplr browser extension

    Navigate to Staked and select Stake with Keplr Dashboard.

    This will open the Keplr dashboard in a new browser page.

    Keplr1

    2️⃣ Select Celestia network and search for a validator

    In the Keplr dashboard, select the Celestia network and pick a validator of your choice.

    Keplr1

    3️⃣ Stake your TIA tokens

    On the following screen enter amount of TIA tokens and select Stake.

    A Keplr popup will appear, requesting your approval for the transaction. Select Approve.

    Keplr1

    4️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Leap wallet

    1️⃣ Open your Leap browser extension

    In top right select Celestia network and navigate to Stake.

    Similarly to previous step, select the +Stake button.

    Keplr1

    2️⃣ Select a validator and stake TIA

    On the following screen choose a validator of your choice, enter the desired amount, and click Review.

    Following that, review the transaction details and select Stake, then wait for the transaction to finalize.

    Keplr1

    3️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Gem wallet

    1️⃣ Open your Gem Wallet app

    Navigate to Celestia and select Stake.

    Gem1

    2️⃣ Choose the amount of Celestia and search for a validator.

    Select the amount of Celestia tokens and choose a validator from the list.

    Gem2

    3️⃣ Stake your TIA tokens

    Review the network terms and commission, then press Confirm to proceed.

    Gem3

    4️⃣ Manage your TIA

    After your transaction is confirmed, you will have access to a control panel where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Gem4

    - +

    How to stake TIA

    Celestia is a proof-of-stake blockchain based on the Cosmos SDK.

    Staking TIA as a delegator allows you to secure the Celestia network. This means that you can stake the native token TIA and vote on governance proposals.

    In this tutorial, you will learn how to stake TIA tokens via Keplr, Leap, and Gem wallets.

    Select your preferred wallet

    Keplr
    Leap
    Gem Wallet

    Stake TIA with Keplr wallet

    1️⃣ Open your Keplr browser extension

    Navigate to Staked and select Stake with Keplr Dashboard.

    This will open the Keplr dashboard in a new browser page.

    Keplr1

    2️⃣ Select Celestia network and search for a validator

    In the Keplr dashboard, select the Celestia network and pick a validator of your choice.

    Keplr1

    3️⃣ Stake your TIA tokens

    On the following screen enter amount of TIA tokens and select Stake.

    A Keplr popup will appear, requesting your approval for the transaction. Select Approve.

    Keplr1

    4️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Leap wallet

    1️⃣ Open your Leap browser extension

    In top right select Celestia network and navigate to Stake.

    Similarly to previous step, select the +Stake button.

    Keplr1

    2️⃣ Select a validator and stake TIA

    On the following screen choose a validator of your choice, enter the desired amount, and click Review.

    Following that, review the transaction details and select Stake, then wait for the transaction to finalize.

    Keplr1

    3️⃣ Confirm and manage your TIA

    After the transaction is confirmed, you will see the following overview dashboard where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Keplr1

    Stake TIA with Gem wallet

    1️⃣ Open your Gem Wallet app

    Navigate to Celestia and select Stake.

    Gem1

    2️⃣ Choose the amount of Celestia and search for a validator.

    Select the amount of Celestia tokens and choose a validator from the list.

    Gem2

    3️⃣ Stake your TIA tokens

    Review the network terms and commission, then press Confirm to proceed.

    Gem3

    4️⃣ Manage your TIA

    After your transaction is confirmed, you will have access to a control panel where you can claim rewards, unstake, redelegate, or stake additional tokens.

    Gem4

    + \ No newline at end of file diff --git a/pr-1815/learn/paying-for-blobspace.html b/pr-1815/learn/paying-for-blobspace.html index 2d420a213..360c899ae 100644 --- a/pr-1815/learn/paying-for-blobspace.html +++ b/pr-1815/learn/paying-for-blobspace.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,8 +48,8 @@

    Paying for blobspace

    PayForBlobs transactions

    To publish data on Celestia, developers can submit PayForBlobs transactions. A PayForBlobs transaction consists of the identity of the sender, the data to be made available, the data size, the namespace, and a signature.

    Each PayForBlobs transaction is split into two parts: the blob or blobs which include the data to be made available along with the namespace, and the executable payment transaction which includes a commitment to the data.

    Both the blobs and executable payment transactions are put into the block within the appropriate namespace. The block data is extended using erasure coding and then Merkelized into a data root commitment included in the block header.

    Lifecycle of a celestia-app Transaction

    See the detailed life cycle of a Celestia transaction.

    Learn how to submit data to Celestia’s data availability layer.

    Fee market overview

    Celestia uses a standard gas-price prioritised mempool. This means that transactions with higher fees will be prioritised by validators. Fees are comprised of a flat fee per transaction and then a variable fee based on the size of each blob in the transaction.

    Understand how fees are calculated on Celestia in the overview on submitting PFB transactions.

    - +

    Paying for blobspace

    PayForBlobs transactions

    To publish data on Celestia, developers can submit PayForBlobs transactions. A PayForBlobs transaction consists of the identity of the sender, the data to be made available, the data size, the namespace, and a signature.

    Each PayForBlobs transaction is split into two parts: the blob or blobs which include the data to be made available along with the namespace, and the executable payment transaction which includes a commitment to the data.

    Both the blobs and executable payment transactions are put into the block within the appropriate namespace. The block data is extended using erasure coding and then Merkelized into a data root commitment included in the block header.

    Lifecycle of a celestia-app Transaction

    See the detailed life cycle of a Celestia transaction.

    Learn how to submit data to Celestia’s data availability layer.

    Fee market overview

    Celestia uses a standard gas-price prioritised mempool. This means that transactions with higher fees will be prioritised by validators. Fees are comprised of a flat fee per transaction and then a variable fee based on the size of each blob in the transaction.

    Understand how fees are calculated on Celestia in the overview on submitting PFB transactions.

    + \ No newline at end of file diff --git a/pr-1815/learn/retrievability.html b/pr-1815/learn/retrievability.html index 34b7b8c32..83bad8217 100644 --- a/pr-1815/learn/retrievability.html +++ b/pr-1815/learn/retrievability.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Data retrievability and pruning

    The purpose of data availability layers such as Celestia is to ensure that block data is provably published, so that applications and rollups can know what the state of their chain is, and store that data. Once the data is published, data availability layers do not inherently guarantee that historical data will be permanently stored and remain retrievable.

    In this document, we discuss the state of data retrievability and pruning in Celestia, as well as some tips for rollup developers in order to ensure that syncing new rollup nodes is possible.

    Data retrievability and pruning in celestia-node

    As of version v0.13.0, celestia-node has implemented a light node sampling window of 30 days, as specified in CIP-4. This means that once pruning is implemented, light nodes will now only sample blocks within a 30-day window instead of sampling all blocks from genesis. This change introduces the concept of pruning to celestia-node, where data outside of the 30-day window may not be stored by light nodes, marking a significant update in how data retrievability and storage are managed within the network (v0.13.0 release notes).

    Data blobs older than the recency window will be pruned by default on light nodes, after pruning is fully implemented, but will continue to be stored by archival nodes that do not prune data. Light nodes will be able to query historic blob data in namespaces from archival nodes, as long as archival nodes exist on the public network.

    Once pruning is fully implemented, light nodes will only perform data availability sampling for blocks within the data recency window of 30 days.

    Suggested practices for rollups

    Rollups may need to access historic data in order to allow new rollup nodes to reconstruct the latest state by replaying historical blocks. Once data has been published on Celestia and guaranteed to have been made available, rollups and applications are responsible for storing their historical data.

    While it is possible to continue to do this by using the GetAll API method in celestia-node on historic blocks as long as archival nodes exist on the public Celestia network, rollup developers should not rely on this as the only method to access historical data, as archival nodes serving requests for historical data for free is not guaranteed. Below are some other suggested methods to access historical data.

    • Use professional archival node or data providers. It is expected that professional infrastructure providers will provide paid access to archival nodes, where historical data can be retrieved, for example using the GetAll API method. This provides better guarantees than solely relying on free archival nodes on the public Celestia network.
    • Share snapshots of rollup nodes. Rollups could share snapshots of their data directories which can be downloaded manually by users bootstrapping new nodes. These snapshots could contain the latest state of the rollup, and/or all the historical blocks.
    • Add peer-to-peer support for historical block sync. A less manual version of sharing snapshots, where rollup nodes could implement built-in support for block sync, where rollup nodes download historical block data from each other over a peer-to-peer network.
      • Namespace pinning. In the future, celestia-node is expected to allow nodes to choose to "pin" data from selected namespaces that they wish to store and make available for other nodes. This will allow rollup nodes to be responsible for storing their data, without needing to implement their own peer-to-peer historical block sync mechanism.
    - +

    Data retrievability and pruning

    The purpose of data availability layers such as Celestia is to ensure that block data is provably published, so that applications and rollups can know what the state of their chain is, and store that data. Once the data is published, data availability layers do not inherently guarantee that historical data will be permanently stored and remain retrievable.

    In this document, we discuss the state of data retrievability and pruning in Celestia, as well as some tips for rollup developers in order to ensure that syncing new rollup nodes is possible.

    Data retrievability and pruning in celestia-node

    As of version v0.13.0, celestia-node has implemented a light node sampling window of 30 days, as specified in CIP-4. This means that once pruning is implemented, light nodes will now only sample blocks within a 30-day window instead of sampling all blocks from genesis. This change introduces the concept of pruning to celestia-node, where data outside of the 30-day window may not be stored by light nodes, marking a significant update in how data retrievability and storage are managed within the network (v0.13.0 release notes).

    Data blobs older than the recency window will be pruned by default on light nodes, after pruning is fully implemented, but will continue to be stored by archival nodes that do not prune data. Light nodes will be able to query historic blob data in namespaces from archival nodes, as long as archival nodes exist on the public network.

    Once pruning is fully implemented, light nodes will only perform data availability sampling for blocks within the data recency window of 30 days.

    Suggested practices for rollups

    Rollups may need to access historic data in order to allow new rollup nodes to reconstruct the latest state by replaying historical blocks. Once data has been published on Celestia and guaranteed to have been made available, rollups and applications are responsible for storing their historical data.

    While it is possible to continue to do this by using the GetAll API method in celestia-node on historic blocks as long as archival nodes exist on the public Celestia network, rollup developers should not rely on this as the only method to access historical data, as archival nodes serving requests for historical data for free is not guaranteed. Below are some other suggested methods to access historical data.

    • Use professional archival node or data providers. It is expected that professional infrastructure providers will provide paid access to archival nodes, where historical data can be retrieved, for example using the GetAll API method. This provides better guarantees than solely relying on free archival nodes on the public Celestia network.
    • Share snapshots of rollup nodes. Rollups could share snapshots of their data directories which can be downloaded manually by users bootstrapping new nodes. These snapshots could contain the latest state of the rollup, and/or all the historical blocks.
    • Add peer-to-peer support for historical block sync. A less manual version of sharing snapshots, where rollup nodes could implement built-in support for block sync, where rollup nodes download historical block data from each other over a peer-to-peer network.
      • Namespace pinning. In the future, celestia-node is expected to allow nodes to choose to "pin" data from selected namespaces that they wish to store and make available for other nodes. This will allow rollup nodes to be responsible for storing their data, without needing to implement their own peer-to-peer historical block sync mechanism.
    + \ No newline at end of file diff --git a/pr-1815/learn/staking-governance-supply.html b/pr-1815/learn/staking-governance-supply.html index 49803b3a7..97213ce5a 100644 --- a/pr-1815/learn/staking-governance-supply.html +++ b/pr-1815/learn/staking-governance-supply.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Staking, governance, & supply

    Proof-of-stake on Celestia

    Celestia is a proof-of-stake blockchain based on CometBFT and the Cosmos SDK. Celestia supports in-protocol delegation and will start with an initial validator set of 100.

    Staking TIA as a validator or delegator enables you to earn staking rewards from the network. Validators charge a fee to delegators which gives them a percentage of staking rewards.

    Learn how proof of stake works on Cosmos SDK chains like Celestia.

    Consensus mechanismProof-of-stake
    Blockchain frameworkCosmos SDK
    Validator set size100
    Delegation supportYes

    Learn how to stake on your own at the community dashboards.

    Inflation

    TIA inflation starts at 8% annually and decreases by 10% every year until it reaches the long term issuance rate of 1.5%. Exact annual inflation rates can be found in the diagram below.

    inflation diagram

    The annual provisions for inflation are calculated based on the total supply of TIA at the beginning of each year. To calculate how many TIA to issue per block, Celestia uses the block timestamp rather than the block height since the time between blocks can vary and cause actual issuance to be higher than the target.

    For an in-depth understanding, refer to ADR019.

    Decentralised governance

    Network parameters

    TIA holders (not just stakers) can propose and vote on governance proposals to change a subset of network parameters. To learn more, see a complete list of both the changeable and non-changeable parameters and their values. Additionally, learn how to submit and vote on governance proposals.

    Community pool

    Starting at genesis, Celestia’s community pool receives 2% of all Celestia block rewards. TIA stakers may vote to fund ecosystem initiatives as in many other Cosmos SDK chains.

    Learn how to submit a governance proposal to spend community pool funds.

    TIA allocation at genesis

    Celestia will have a total supply of 1,000,000,000 TIA at genesis, split across five categories described in the chart and table below.

    allocation diagram

    CategoryDescription%
    Public AllocationGenesis Drop and Incentivized Testnet: 7.41%
    Future initiatives: 12.59%
    20.00%
    R&D & EcosystemTokens allocated to the Celestia Foundation and core devs for research, development, and ecosystem initiatives including:
    - Protocol maintenance and development
    - Programs for rollup developers, infrastructure, and node operators
    26.79%
    Early Backers: Series A&BEarly supporters of Celestia19.67%
    Early Backers: SeedEarly supporters of Celestia15.90%
    Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.64%

    Unlocks

    Celestia’s 1 billion TIA supply at genesis will be subject to several different unlock schedules. All tokens, locked or unlocked, may be staked, but staking rewards are unlocked upon receipt and will add to the circulating supply.

    Circulating supply is defined as the amount of TIA tokens in general circulation without onchain transfer restrictions.

    Available supply is defined as the amount of TIA tokens that are either part of the circulating supply or are unlocked but subject to some form of governance to determine when the tokens are allocated. This includes the unlocked portion of the R&D & Ecosystem tokens and the tokens set aside for future initiatives.

    The definitions for circulating and available supply were adapted from Optimism’s definitions.

    supply diagram

    Unlock schedule by category is described in the table below.

    Note: Due to 2024 being a leap year, the yearly unlock intervals will occur on October 30th of each year. For example, unlocks at year 1 will occur on October 30, 2024.

    CategoryUnlock Schedule
    Public AllocationFully unlocked at launch.
    R&D & Ecosystem25.00% unlocked at launch.
    Remaining 75.00% unlocks continuously from year 1 to year 4.
    Initial Core Contributors33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 3.
    Early Backers: Seed33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    Early Backers: Series A&B33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    - +

    Staking, governance, & supply

    Proof-of-stake on Celestia

    Celestia is a proof-of-stake blockchain based on CometBFT and the Cosmos SDK. Celestia supports in-protocol delegation and will start with an initial validator set of 100.

    Staking TIA as a validator or delegator enables you to earn staking rewards from the network. Validators charge a fee to delegators which gives them a percentage of staking rewards.

    Learn how proof of stake works on Cosmos SDK chains like Celestia.

    Consensus mechanismProof-of-stake
    Blockchain frameworkCosmos SDK
    Validator set size100
    Delegation supportYes

    Learn how to stake on your own at the community dashboards.

    Inflation

    TIA inflation starts at 8% annually and decreases by 10% every year until it reaches the long term issuance rate of 1.5%. Exact annual inflation rates can be found in the diagram below.

    inflation diagram

    The annual provisions for inflation are calculated based on the total supply of TIA at the beginning of each year. To calculate how many TIA to issue per block, Celestia uses the block timestamp rather than the block height since the time between blocks can vary and cause actual issuance to be higher than the target.

    For an in-depth understanding, refer to ADR019.

    Decentralised governance

    Network parameters

    TIA holders (not just stakers) can propose and vote on governance proposals to change a subset of network parameters. To learn more, see a complete list of both the changeable and non-changeable parameters and their values. Additionally, learn how to submit and vote on governance proposals.

    Community pool

    Starting at genesis, Celestia’s community pool receives 2% of all Celestia block rewards. TIA stakers may vote to fund ecosystem initiatives as in many other Cosmos SDK chains.

    Learn how to submit a governance proposal to spend community pool funds.

    TIA allocation at genesis

    Celestia will have a total supply of 1,000,000,000 TIA at genesis, split across five categories described in the chart and table below.

    allocation diagram

    CategoryDescription%
    Public AllocationGenesis Drop and Incentivized Testnet: 7.41%
    Future initiatives: 12.59%
    20.00%
    R&D & EcosystemTokens allocated to the Celestia Foundation and core devs for research, development, and ecosystem initiatives including:
    - Protocol maintenance and development
    - Programs for rollup developers, infrastructure, and node operators
    26.79%
    Early Backers: Series A&BEarly supporters of Celestia19.67%
    Early Backers: SeedEarly supporters of Celestia15.90%
    Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.64%

    Unlocks

    Celestia’s 1 billion TIA supply at genesis will be subject to several different unlock schedules. All tokens, locked or unlocked, may be staked, but staking rewards are unlocked upon receipt and will add to the circulating supply.

    Circulating supply is defined as the amount of TIA tokens in general circulation without onchain transfer restrictions.

    Available supply is defined as the amount of TIA tokens that are either part of the circulating supply or are unlocked but subject to some form of governance to determine when the tokens are allocated. This includes the unlocked portion of the R&D & Ecosystem tokens and the tokens set aside for future initiatives.

    The definitions for circulating and available supply were adapted from Optimism’s definitions.

    supply diagram

    Unlock schedule by category is described in the table below.

    Note: Due to 2024 being a leap year, the yearly unlock intervals will occur on October 30th of each year. For example, unlocks at year 1 will occur on October 30, 2024.

    CategoryUnlock Schedule
    Public AllocationFully unlocked at launch.
    R&D & Ecosystem25.00% unlocked at launch.
    Remaining 75.00% unlocks continuously from year 1 to year 4.
    Initial Core Contributors33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 3.
    Early Backers: Seed33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    Early Backers: Series A&B33.33% unlocked at year 1.
    Remaining 66.67% unlocks continuously from year 1 to year 2.
    + \ No newline at end of file diff --git a/pr-1815/learn/staking.html b/pr-1815/learn/staking.html index 80a113f0e..722ae6d80 100644 --- a/pr-1815/learn/staking.html +++ b/pr-1815/learn/staking.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Staking on Celestia

    Engage with the Celestia network at a deeper level through staking. An essential mechanism to a proof-of-stake network, users can secure the network by delegating to a validator and receive a share of its staking rewards.

    Mainnet Beta

    Currently, the following staking interfaces exist for the Mainnet Beta.

    Just connect your wallet to get started!

    Mocha testnet

    Currently, the following staking interfaces exist for the Mocha testnet.

    Just connect your wallet to get started!

    - +

    Staking on Celestia

    Engage with the Celestia network at a deeper level through staking. An essential mechanism to a proof-of-stake network, users can secure the network by delegating to a validator and receive a share of its staking rewards.

    Mainnet Beta

    Currently, the following staking interfaces exist for the Mainnet Beta.

    Just connect your wallet to get started!

    Mocha testnet

    Currently, the following staking interfaces exist for the Mocha testnet.

    Just connect your wallet to get started!

    + \ No newline at end of file diff --git a/pr-1815/learn/tia.html b/pr-1815/learn/tia.html index 163ce5f45..6933c94df 100644 --- a/pr-1815/learn/tia.html +++ b/pr-1815/learn/tia.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Overview of TIA

    TIA at a glance

    PropertyDetails
    AbbreviationTIA
    Total supply at genesis1,000,000,000 TIA
    Inflation schedule8% in the first year, decreasing 10% per year until reaching an inflation floor of 1.5% annually
    Decimals6
    Conversion1 uTIA=TIA×106

    Role of TIA

    Paying for blobspace

    Celestia’s native asset, TIA, is an essential part of how developers build on the first modular blockchain network. To use Celestia for data availability, rollup developers submit PayForBlobs transactions on the network for a fee, denominated in TIA.

    Bootstrapping new rollups

    A core part of the Celestia vision is that deploying a blockchain should be as easy as deploying a smart contract. In the modular era, developers no longer need to issue a token to launch their own blockchain.

    Similarly to ETH on Ethereum-based rollups, developers may opt to bootstrap their chain quickly by using TIA as a gas token and currency, in addition to paying for data availability. In this mode, developers can focus on creating their application or execution layer, instead of issuing a token right away.

    Proof-of-stake

    As a permissionless network built with Cosmos SDK, Celestia uses proof-of-stake to secure its own consensus. Like in other Cosmos networks, any user can help secure the network by delegating their TIA to a Celestia validator for a portion of their validator’s staking rewards.

    Learn how proof-of-stake works in Cosmos.

    Decentralised governance

    TIA staking also allows the community to play a critical role in decentralised governance over key parts of Celestia, such as voting on network parameters through governance proposals, and governing the community pool, which receives 2% of block rewards.

    Learn more about Celestia’s decentralised governance model.

    Denominations

    TIA: display token

    TIA is the DisplayDenom that you will typically see in wallets and user interfaces.

    utia: staking denomination

    utia is the BondDenom and stands for "micro TIA", with 1 TIA = 1,000,000 utia. This is the native staking denomination.

    In staking operations or transactions, if no denomination is specified, utia is assumed.

    microtia: staking denomination alias

    microtia is the BondDenomAlias, an alias for utia.

    - +

    Overview of TIA

    TIA at a glance

    PropertyDetails
    AbbreviationTIA
    Total supply at genesis1,000,000,000 TIA
    Inflation schedule8% in the first year, decreasing 10% per year until reaching an inflation floor of 1.5% annually
    Decimals6
    Conversion1 uTIA=TIA×106

    Role of TIA

    Paying for blobspace

    Celestia’s native asset, TIA, is an essential part of how developers build on the first modular blockchain network. To use Celestia for data availability, rollup developers submit PayForBlobs transactions on the network for a fee, denominated in TIA.

    Bootstrapping new rollups

    A core part of the Celestia vision is that deploying a blockchain should be as easy as deploying a smart contract. In the modular era, developers no longer need to issue a token to launch their own blockchain.

    Similarly to ETH on Ethereum-based rollups, developers may opt to bootstrap their chain quickly by using TIA as a gas token and currency, in addition to paying for data availability. In this mode, developers can focus on creating their application or execution layer, instead of issuing a token right away.

    Proof-of-stake

    As a permissionless network built with Cosmos SDK, Celestia uses proof-of-stake to secure its own consensus. Like in other Cosmos networks, any user can help secure the network by delegating their TIA to a Celestia validator for a portion of their validator’s staking rewards.

    Learn how proof-of-stake works in Cosmos.

    Decentralised governance

    TIA staking also allows the community to play a critical role in decentralised governance over key parts of Celestia, such as voting on network parameters through governance proposals, and governing the community pool, which receives 2% of block rewards.

    Learn more about Celestia’s decentralised governance model.

    Denominations

    TIA: display token

    TIA is the DisplayDenom that you will typically see in wallets and user interfaces.

    utia: staking denomination

    utia is the BondDenom and stands for "micro TIA", with 1 TIA = 1,000,000 utia. This is the native staking denomination.

    In staking operations or transactions, if no denomination is specified, utia is assumed.

    microtia: staking denomination alias

    microtia is the BondDenomAlias, an alias for utia.

    + \ No newline at end of file diff --git a/pr-1815/sitemap.xml b/pr-1815/sitemap.xml index 007eb01a5..c125e50f5 100644 --- a/pr-1815/sitemap.xml +++ b/pr-1815/sitemap.xml @@ -1 +1 @@ -https://docs.celestia.org/README2024-11-28T06:46:34.000Zhttps://docs.celestia.org/community/coc2024-11-28T06:46:34.000Zhttps://docs.celestia.org/community/foundation-delegation-program2024-11-28T06:46:34.000Zhttps://docs.celestia.org/community/modular-meetup-guide2024-11-28T06:46:34.000Zhttps://docs.celestia.org/community/modular-meetup-intro2024-11-28T06:46:34.000Zhttps://docs.celestia.org/community/modular-meetup-toolkit2024-11-28T06:46:34.000Zhttps://docs.celestia.org/community/speaker-list2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/arabica-devnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-bridge2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-deploy2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-full-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-integration2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream-contracts2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream-offchain2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream-proof-queries2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream-rollups2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream-x-deploy2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream-x-requesting-data-commitment-ranges2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstream2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/blobstreamx2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/bridge-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/bubs-testnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-commands2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-metrics2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-multisig2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-slashing2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-upgrade-monitor2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-vesting2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-wallet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-app2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-custom-networks2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-metrics2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-store-structure2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-troubleshooting2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-trusted-hash2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/celestia-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/config-toml2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/consensus-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/decide-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/docker-images2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/environment2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/ethereum-fallback2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/feegrant-for-blobs2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/full-storage-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/ibc-relayer2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/instantiate-testnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/intro-to-op-stack2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/light-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/local-testnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/mainnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/mocha-testnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/multiaccounts2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/network-upgrade-process2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/nodes-overview2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/optimism-devnet2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/optimism2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/participate2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/quick-start2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/rollup-stacks2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/sp1-blobstream-deploy2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/submit-data2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/systemd2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/transaction-resubmission2024-11-28T06:46:34.000Zhttps://docs.celestia.org/how-to-guides/validator-node2024-11-28T06:46:34.000Zhttps://docs.celestia.org/2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-faq2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-layer2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/how-celestia-works/monolithic-vs-modular2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/how-celestia-works/overview2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/how-celestia-works/transaction-lifecycle2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/how-to-stake-tia2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/paying-for-blobspace2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/retrievability2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/staking-governance-supply2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/staking2024-11-28T06:46:34.000Zhttps://docs.celestia.org/learn/tia2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/celestia-node-key2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/golang-client-tutorial2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/integrate-celestia2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/node-api2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/node-tutorial2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/prompt-scavenger2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/rust-client-tutorial2024-11-28T06:46:34.000Zhttps://docs.celestia.org/tutorials/wallets2024-11-28T06:46:34.000Z \ No newline at end of file +https://docs.celestia.org/README2024-11-28T07:04:39.000Zhttps://docs.celestia.org/community/coc2024-11-28T07:04:39.000Zhttps://docs.celestia.org/community/foundation-delegation-program2024-11-28T07:04:39.000Zhttps://docs.celestia.org/community/modular-meetup-guide2024-11-28T07:04:39.000Zhttps://docs.celestia.org/community/modular-meetup-intro2024-11-28T07:04:39.000Zhttps://docs.celestia.org/community/modular-meetup-toolkit2024-11-28T07:04:39.000Zhttps://docs.celestia.org/community/speaker-list2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/arabica-devnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-bridge2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-deploy2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-full-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/arbitrum-integration2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream-contracts2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream-offchain2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream-proof-queries2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream-rollups2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream-x-deploy2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream-x-requesting-data-commitment-ranges2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstream2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/blobstreamx2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/bridge-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/bubs-testnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-commands2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-metrics2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-multisig2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-slashing2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-upgrade-monitor2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-vesting2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app-wallet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-app2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-custom-networks2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-metrics2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-store-structure2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-troubleshooting2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-node-trusted-hash2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/celestia-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/config-toml2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/consensus-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/decide-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/docker-images2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/environment2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/ethereum-fallback2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/feegrant-for-blobs2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/full-storage-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/ibc-relayer2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/instantiate-testnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/intro-to-op-stack2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/light-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/local-testnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/mainnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/mocha-testnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/multiaccounts2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/network-upgrade-process2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/nodes-overview2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/optimism-devnet2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/optimism2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/participate2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/quick-start2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/rollup-stacks2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/sp1-blobstream-deploy2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/submit-data2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/systemd2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/transaction-resubmission2024-11-28T07:04:39.000Zhttps://docs.celestia.org/how-to-guides/validator-node2024-11-28T07:04:39.000Zhttps://docs.celestia.org/2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-faq2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-layer2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/how-celestia-works/monolithic-vs-modular2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/how-celestia-works/overview2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/how-celestia-works/transaction-lifecycle2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/how-to-stake-tia2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/paying-for-blobspace2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/retrievability2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/staking-governance-supply2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/staking2024-11-28T07:04:39.000Zhttps://docs.celestia.org/learn/tia2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/celestia-node-key2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/golang-client-tutorial2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/integrate-celestia2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/node-api2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/node-tutorial2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/prompt-scavenger2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/rust-client-tutorial2024-11-28T07:04:39.000Zhttps://docs.celestia.org/tutorials/wallets2024-11-28T07:04:39.000Z \ No newline at end of file diff --git a/pr-1815/start-local.sh b/pr-1815/start-local.sh index d8722065f..0e2a53643 100644 --- a/pr-1815/start-local.sh +++ b/pr-1815/start-local.sh @@ -85,9 +85,6 @@ celestia bridge start \ --p2p.network test & wait_for_service 2121 "bridge node" -echo "Waiting for bridge node to sync..." -sleep 10 - # Get bridge node info echo "Getting bridge node peer info..." BRIDGE_INFO=$(celestia p2p info --node.store "$HOME/.celestia-custom-bridge") diff --git a/pr-1815/tutorials/celestia-node-key.html b/pr-1815/tutorials/celestia-node-key.html index 97ff4febe..b74f31b26 100644 --- a/pr-1815/tutorials/celestia-node-key.html +++ b/pr-1815/tutorials/celestia-node-key.html @@ -7,12 +7,12 @@ - + - + - + @@ -54,19 +54,19 @@ make cel-key
    # dumps binary in current working directory, accessible via `./cel-key`
     make cel-key

    or

    sh
    # installs binary in GOBIN path, accessible via `cel-key`
     make install-key
    # installs binary in GOBIN path, accessible via `cel-key`
    -make install-key

    For the purpose of this guide, we will use the make cel-key command.

    Steps for generating node keys

    To generate a key for a Celestia node, select the tab for your node type:

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    bash
    ./cel-key add <key-name> --keyring-backend test --node.type bridge \
    +make install-key

    For the purpose of this guide, we will use the make cel-key command.

    Steps for generating node keys

    To generate a key for a Celestia node, select the tab for your node type:

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    bash
    ./cel-key add <key-name> --keyring-backend test --node.type bridge \
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type bridge \
       --p2p.network <network>
    bash
    ./cel-key add <key-name> --keyring-backend test --node.type full \
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type full \
       --p2p.network <network>
    bash
    ./cel-key add <key-name> --keyring-backend test --node.type light \
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type light \
    -  --p2p.network <network>

    This will load the key <key-name> into the directory of the node.

    Further flags you can use to customize your key are the following:

    • --p2p.network: Specifies which network you want the key for. Values are arabica and mocha. Please note the default network will be mocha.

    Keep in mind that your celestia-node will only pick up keys that are inside the default directory under /keys so you should make sure to point cel-key utility to the correct directory via the p2p.network or home flags if you have specified a custom directory or network other than Arabica, Mocha, or Mainnet Beta.

    Also keep in mind that if you do not specify a network with --p2p.network, the default one will always be celestia (Mainnet Beta).

    Steps for exporting node keys

    You can export a private key from the local keyring in encrypted and ASCII-armored format.

    bash
    ./cel-key export <key-name> --keyring-backend test --node.type bridge \
    +  --p2p.network <network>

    This will load the key <key-name> into the directory of the node.

    Further flags you can use to customize your key are the following:

    • --p2p.network: Specifies which network you want the key for. Values are arabica and mocha. Please note the default network will be mocha.

    Keep in mind that your celestia-node will only pick up keys that are inside the default directory under /keys so you should make sure to point cel-key utility to the correct directory via the p2p.network or home flags if you have specified a custom directory or network other than Arabica, Mocha, or Mainnet Beta.

    Also keep in mind that if you do not specify a network with --p2p.network, the default one will always be celestia (Mainnet Beta).

    Steps for exporting node keys

    You can export a private key from the local keyring in encrypted and ASCII-armored format.

    bash
    ./cel-key export <key-name> --keyring-backend test --node.type bridge \
       --p2p.network <network>
    ./cel-key export <key-name> --keyring-backend test --node.type bridge \
       --p2p.network <network>
    bash
    ./cel-key export <key-name> --keyring-backend test --node.type full \
       --p2p.network <network>
    ./cel-key export <key-name> --keyring-backend test --node.type full \
       --p2p.network <network>
    bash
    ./cel-key export <key-name> --keyring-backend test --node.type light \
       --p2p.network <network>
    ./cel-key export <key-name> --keyring-backend test --node.type light \
    -  --p2p.network <network>

    Steps for importing node keys

    To import from a mnemonic, use the following command, then enter your bip39 mnemonic:

    bash
    ./cel-key add <key-name> --recover --keyring-backend test \
    +  --p2p.network <network>

    Steps for importing node keys

    To import from a mnemonic, use the following command, then enter your bip39 mnemonic:

    bash
    ./cel-key add <key-name> --recover --keyring-backend test \
       --node.type bridge --p2p.network <network>
    ./cel-key add <key-name> --recover --keyring-backend test \
       --node.type bridge --p2p.network <network>
    bash
    ./cel-key add <key-name> --recover --keyring-backend test \
       --node.type full --p2p.network <network>
    ./cel-key add <key-name> --recover --keyring-backend test \
    @@ -110,8 +110,8 @@
     - address: celestia1wkhyhr7ngf0ayqlpnsnxg4d72hfs5453dvunm9
       name: my_celes_key
       pubkey: '{"@type":"/cosmos.crypto.secp256k1.PubKey","key":"A1/NsoY0RGL7Hqt4VWLg441GQKJsZ2fBUnZXipgns8oV"}'
    -  type: local
    - + type: local + \ No newline at end of file diff --git a/pr-1815/tutorials/golang-client-tutorial.html b/pr-1815/tutorials/golang-client-tutorial.html index 310683194..f3c6025f9 100644 --- a/pr-1815/tutorials/golang-client-tutorial.html +++ b/pr-1815/tutorials/golang-client-tutorial.html @@ -7,11 +7,11 @@ - + - - + + @@ -285,8 +285,8 @@ // Fetch the EDS return client.Share.GetEDS(ctx, header) -}

    API documentation

    To see the full list of available methods, see the API documentation.

    - +}

    API documentation

    To see the full list of available methods, see the API documentation.

    + \ No newline at end of file diff --git a/pr-1815/tutorials/integrate-celestia.html b/pr-1815/tutorials/integrate-celestia.html index ad302f6ef..7dbd2ca38 100644 --- a/pr-1815/tutorials/integrate-celestia.html +++ b/pr-1815/tutorials/integrate-celestia.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Integrate Celestia for service providers

    This document is for third-party service providers, such as custodians and explorers, integrating the Celestia network.

    Getting started

    When getting started with Celestia, we recommend checking out these resources first:

    Celestia service provider notes

    Celestia is a fairly standard Cosmos-SDK based chain. We use the latest version of Tendermint and the Cosmos-SDK, with only minor modifications to each. This means that we are:

    • Using the default Cosmos-SDK modules: auth, bank, distribution, staking, slashing, mint, crisis, ibchost, genutil, evidence, ibctransfer, params, gov (limited in some TBD capacities), upgrade, vesting, feegrant, capability, and payment.
    • Use the standard digital keys schemes provided by the Cosmos-SDK and Tendermint, those being secp256k1 for user transactions, and tm-ed25519 for signing and verifying consensus messages.

    While exactly which modules used is subject to change, Celestia aims to be as minimal as possible.

    Custody and key management

    Celestia supports many already existing key management systems, as we rely on the Cosmos-SDK and Tendermint libraries for signing and verifying transactions. Learn more in the Cosmos-SDK documentation

    RPC and querying

    In celestia-app, only the standard RPC endpoints for Tendermint and the Cosmos-SDK are exposed. We do not currently add or subtract any core functionality, but this could change in the future. The same goes for querying data from the chain.

    In celestia-node, the Data Availability node client, there is a JSON-RPC API that allows you to interact directly with Celestia's Data Availability layer. Learn how to use the API in this tutorial.

    Compatibility

    Linux, particularly Ubuntu 20.04 LTS, is the most well tested. Potentially compatible with other OSs, but they are currently untested. Some of the cryptography libraries used for erasure data are not guaranteed to work on other platforms.

    Syncing

    Since we utilize Tendermint and the Cosmos-SDK, syncing the chain can be performed by any method that is supported by those libraries. This includes fast-sync, state sync, and quick sync.

    Notable exceptions relative to other blockchains

    Relative to other Tendermint based chains, Celestia will have significantly longer blocktimes of roughly 12* seconds. The reason behind this block time is to optimize the bandwidth used by light clients that are sampling the chain, and is not because we have modified Tendermint consensus in any meaningful way. Validators will likely download/upload relatively large blocks. It should be noted that while these blocks are large, very little typical blockchain state execution is actually occurring on Celestia. Meaning that the bandwidth requirements will likely be larger than that of a typical Cosmos-SDK based blockchain full node, the computing requirements should be similar in magnitude.

    *Subject to Change

    - +

    Integrate Celestia for service providers

    This document is for third-party service providers, such as custodians and explorers, integrating the Celestia network.

    Getting started

    When getting started with Celestia, we recommend checking out these resources first:

    Celestia service provider notes

    Celestia is a fairly standard Cosmos-SDK based chain. We use the latest version of Tendermint and the Cosmos-SDK, with only minor modifications to each. This means that we are:

    • Using the default Cosmos-SDK modules: auth, bank, distribution, staking, slashing, mint, crisis, ibchost, genutil, evidence, ibctransfer, params, gov (limited in some TBD capacities), upgrade, vesting, feegrant, capability, and payment.
    • Use the standard digital keys schemes provided by the Cosmos-SDK and Tendermint, those being secp256k1 for user transactions, and tm-ed25519 for signing and verifying consensus messages.

    While exactly which modules used is subject to change, Celestia aims to be as minimal as possible.

    Custody and key management

    Celestia supports many already existing key management systems, as we rely on the Cosmos-SDK and Tendermint libraries for signing and verifying transactions. Learn more in the Cosmos-SDK documentation

    RPC and querying

    In celestia-app, only the standard RPC endpoints for Tendermint and the Cosmos-SDK are exposed. We do not currently add or subtract any core functionality, but this could change in the future. The same goes for querying data from the chain.

    In celestia-node, the Data Availability node client, there is a JSON-RPC API that allows you to interact directly with Celestia's Data Availability layer. Learn how to use the API in this tutorial.

    Compatibility

    Linux, particularly Ubuntu 20.04 LTS, is the most well tested. Potentially compatible with other OSs, but they are currently untested. Some of the cryptography libraries used for erasure data are not guaranteed to work on other platforms.

    Syncing

    Since we utilize Tendermint and the Cosmos-SDK, syncing the chain can be performed by any method that is supported by those libraries. This includes fast-sync, state sync, and quick sync.

    Notable exceptions relative to other blockchains

    Relative to other Tendermint based chains, Celestia will have significantly longer blocktimes of roughly 12* seconds. The reason behind this block time is to optimize the bandwidth used by light clients that are sampling the chain, and is not because we have modified Tendermint consensus in any meaningful way. Validators will likely download/upload relatively large blocks. It should be noted that while these blocks are large, very little typical blockchain state execution is actually occurring on Celestia. Meaning that the bandwidth requirements will likely be larger than that of a typical Cosmos-SDK based blockchain full node, the computing requirements should be similar in magnitude.

    *Subject to Change

    + \ No newline at end of file diff --git a/pr-1815/tutorials/node-api.html b/pr-1815/tutorials/node-api.html index ee1585a2d..6549e4652 100644 --- a/pr-1815/tutorials/node-api.html +++ b/pr-1815/tutorials/node-api.html @@ -7,11 +7,11 @@ - + - - + + @@ -47,8 +47,8 @@

    Node API

    The celestia-node API is made for interacting with celestia-node. There are two ways in which a user and developer can interact with the API, the RPC API and the Gateway API. View the API's documentation.

    RPC API

    The RPC API primarily focuses on developers and projects building on top of Celestia, who are willing to run their own DA nodes. The RPC API provides a richer set of features and a superior user experience. Unlike the Gateway API, the RPC API allows access to the internal wallet and keyring of the DA node, as well as other sensitive and administrative capabilities.

    Library

    The node can be used as a Golang library and designed for programmatic API access.

    RPC

    The RPC API is also exposed to OpenRPC(JSON-RPC 2.0) for users wanting to run their DA node as a separate DA service. It provides the same set of features as the library with an additional authentication system with different permissions levels to protect the wallet and signing + providing RPC-level DOS protection.

    RPC API tutorial

    The quick start guide is the easiest way to get started.

    The node tutorial, which uses the RPC CLI, is the recommended way to learn more about interacting with your Celestia node.

    Other ways to get started are with the Rust and Golang tutorials.

    Gateway API

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    The gateway API is a REST API which is meant to be deployed by infra providers to enable the public read-only gateway to the DA network for external users who don't want or can't run light nodes (like browsers currently) over HTTP. It has no wallet or signing functionality.

    Gateway API tutorial

    Check out the Prompt scavenger gateway API tutorial for more details.

    - +

    Node API

    The celestia-node API is made for interacting with celestia-node. There are two ways in which a user and developer can interact with the API, the RPC API and the Gateway API. View the API's documentation.

    RPC API

    The RPC API primarily focuses on developers and projects building on top of Celestia, who are willing to run their own DA nodes. The RPC API provides a richer set of features and a superior user experience. Unlike the Gateway API, the RPC API allows access to the internal wallet and keyring of the DA node, as well as other sensitive and administrative capabilities.

    Library

    The node can be used as a Golang library and designed for programmatic API access.

    RPC

    The RPC API is also exposed to OpenRPC(JSON-RPC 2.0) for users wanting to run their DA node as a separate DA service. It provides the same set of features as the library with an additional authentication system with different permissions levels to protect the wallet and signing + providing RPC-level DOS protection.

    RPC API tutorial

    The quick start guide is the easiest way to get started.

    The node tutorial, which uses the RPC CLI, is the recommended way to learn more about interacting with your Celestia node.

    Other ways to get started are with the Rust and Golang tutorials.

    Gateway API

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    The gateway API is a REST API which is meant to be deployed by infra providers to enable the public read-only gateway to the DA network for external users who don't want or can't run light nodes (like browsers currently) over HTTP. It has no wallet or signing functionality.

    Gateway API tutorial

    Check out the Prompt scavenger gateway API tutorial for more details.

    + \ No newline at end of file diff --git a/pr-1815/tutorials/node-tutorial.html b/pr-1815/tutorials/node-tutorial.html index 17a7788f0..a815992c6 100644 --- a/pr-1815/tutorials/node-tutorial.html +++ b/pr-1815/tutorials/node-tutorial.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,11 +48,11 @@

    Celestia-node RPC CLI tutorial

    In this tutorial, we will cover how to use the celestia-node RPC API to submit and retrieve data (blobs) from the data availability layer by their namespace.

    Introduction

    Blobs

    Data is posted to Celestia's DA layer by using MsgPayForBlobs transactions to the core network. Read more about MsgPayForBlobs.

    Namespaces

    Celestia partitions the block data into multiple namespaces, one for every application. This allows applications to only download their data, and not the data of other applications. Read more about Namespaced Merkle trees (NMTs).

    TIP

    If you already have a running and funded node, you can skip to the RPC CLI guide section.

    If you would like to skip syncing, you can use this guide to sync from trusted hash and height.

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 50 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Setting up dependencies

    Install dependencies and celestia-node if you have not already.

    Instantiate a Celestia light node

    Now, let's instantiate a Celestia Light node:

    TIP

    RPC endpoints are exposed in all celestia-node types such as light, bridge and full nodes.

    bash
    celestia light init
    celestia light init
    bash
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    bash
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    Instantiating (or initializing) the node means setting up a node store on your machine. This is where the data and your keys will be stored.

    Connect to a core endpoint

    Let's now run the Celestia Light node with a gRPC connection to an example core endpoint. Connecting to a core endpoint provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Note: You are also encouraged to find an RPC endpoint for Mainnet Beta, Mocha testnet, or Arabica devnet. If you are running a production application, use a production endpoint.

    bash
    celestia light start --core.ip <URI>
    celestia light start --core.ip <URI>
    bash
    celestia light start --core.ip <URI> --p2p.network mocha
    celestia light start --core.ip <URI> --p2p.network mocha
    bash
    celestia light start --core.ip <URI> --p2p.network arabica
    celestia light start --core.ip <URI> --p2p.network arabica

    TIP

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    For example, your command along with an RPC endpoint might look like this:

    bash
    celestia light start --core.ip consensus.lunaroasis.net
    celestia light start --core.ip consensus.lunaroasis.net
    bash
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    bash
    celestia light start --core.ip validator-1.celestia-arabica-11.com \
    +

    Celestia-node RPC CLI tutorial

    In this tutorial, we will cover how to use the celestia-node RPC API to submit and retrieve data (blobs) from the data availability layer by their namespace.

    Introduction

    Blobs

    Data is posted to Celestia's DA layer by using MsgPayForBlobs transactions to the core network. Read more about MsgPayForBlobs.

    Namespaces

    Celestia partitions the block data into multiple namespaces, one for every application. This allows applications to only download their data, and not the data of other applications. Read more about Namespaced Merkle trees (NMTs).

    TIP

    If you already have a running and funded node, you can skip to the RPC CLI guide section.

    If you would like to skip syncing, you can use this guide to sync from trusted hash and height.

    WARNING

    The gateway endpoints have been deprecated and will be removed in the future. If you would like to use them anyway, you can find more details on GitHub.

    Hardware requirements

    The following minimum hardware requirements are recommended for running a light node:

    • Memory: 500 MB RAM (minimum)
    • CPU: Single Core
    • Disk: 50 GB SSD Storage
    • Bandwidth: 56 Kbps for Download/56 Kbps for Upload

    Setting up dependencies

    Install dependencies and celestia-node if you have not already.

    Instantiate a Celestia light node

    Now, let's instantiate a Celestia Light node:

    TIP

    RPC endpoints are exposed in all celestia-node types such as light, bridge and full nodes.

    bash
    celestia light init
    celestia light init
    bash
    celestia light init --p2p.network mocha
    celestia light init --p2p.network mocha
    bash
    celestia light init --p2p.network arabica
    celestia light init --p2p.network arabica

    Instantiating (or initializing) the node means setting up a node store on your machine. This is where the data and your keys will be stored.

    Connect to a core endpoint

    Let's now run the Celestia Light node with a gRPC connection to an example core endpoint. Connecting to a core endpoint provides the light node with access to state queries (reading balances, submitting transactions, and other state-related queries).

    Note: You are also encouraged to find an RPC endpoint for Mainnet Beta, Mocha testnet, or Arabica devnet. If you are running a production application, use a production endpoint.

    bash
    celestia light start --core.ip <URI>
    celestia light start --core.ip <URI>
    bash
    celestia light start --core.ip <URI> --p2p.network mocha
    celestia light start --core.ip <URI> --p2p.network mocha
    bash
    celestia light start --core.ip <URI> --p2p.network arabica
    celestia light start --core.ip <URI> --p2p.network arabica

    TIP

    The --core.ip gRPC port defaults to 9090, so if you do not specify it in the command line, it will default to that port. You can add the port after the IP address or use the --core.grpc.port flag to specify another port if you prefer.

    Refer to the ports section of the celestia-node troubleshooting page for information on which ports are required to be open on your machine.

    For example, your command along with an RPC endpoint might look like this:

    bash
    celestia light start --core.ip consensus.lunaroasis.net
    celestia light start --core.ip consensus.lunaroasis.net
    bash
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    celestia light start --core.ip rpc-mocha.pops.one --p2p.network mocha
    bash
    celestia light start --core.ip validator-1.celestia-arabica-11.com \
       --p2p.network arabica
    celestia light start --core.ip validator-1.celestia-arabica-11.com \
       --p2p.network arabica

    Keys and wallets

    You can create your key for your node by running the following command from the celestia-node directory:

    TIP

    You do not need to declare a network for Mainnet Beta. Refer to the chain ID section on the troubleshooting page for more information

    bash
    ./cel-key add <key-name> --keyring-backend test --node.type light \
       --p2p.network <network>
    ./cel-key add <key-name> --keyring-backend test --node.type light \
    -  --p2p.network <network>

    You can start your light node with the key created by running the following command:

    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \
    +  --p2p.network <network>

    You can start your light node with the key created by running the following command:

    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    celestia light start --core.ip <URI> --keyring.keyname <key-name>
    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \
       --p2p.network mocha
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \
       --p2p.network mocha
    bash
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \
       --p2p.network arabica
    celestia light start --core.ip <URI> --keyring.keyname <key-name> \
    @@ -444,8 +444,8 @@
         ],
         0.002
       ]
    -}' 127.0.0.1:26658
    1. Upon successful blob submission, the result will show the block height:
    bash
    {"jsonrpc":"2.0","result":362101,"id":1}
    {"jsonrpc":"2.0","result":362101,"id":1}

    The example transaction can be found on Celenium.

    Post an SVG as a PFB

    If you'd like to create your own SVG, post it to Celestia, and retrieve it, you can check out the Base64 SVG Tutorial.

    Troubleshooting

    If you encounter an error like:

    sh
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"

    It is possible that the account you are trying to submit a PayForBlobs from doesn't have testnet tokens yet. Ensure the testnet faucet has funded your account with tokens and then try again.

    - +}' 127.0.0.1:26658
    1. Upon successful blob submission, the result will show the block height:
    bash
    {"jsonrpc":"2.0","result":362101,"id":1}
    {"jsonrpc":"2.0","result":362101,"id":1}

    The example transaction can be found on Celenium.

    Post an SVG as a PFB

    If you'd like to create your own SVG, post it to Celestia, and retrieve it, you can check out the Base64 SVG Tutorial.

    Troubleshooting

    If you encounter an error like:

    sh
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"
    "rpc error: code = NotFound desc = account celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86 not found"

    It is possible that the account you are trying to submit a PayForBlobs from doesn't have testnet tokens yet. Ensure the testnet faucet has funded your account with tokens and then try again.

    + \ No newline at end of file diff --git a/pr-1815/tutorials/prompt-scavenger.html b/pr-1815/tutorials/prompt-scavenger.html index 3edb51516..75e6427df 100644 --- a/pr-1815/tutorials/prompt-scavenger.html +++ b/pr-1815/tutorials/prompt-scavenger.html @@ -7,11 +7,11 @@ - + - - + + @@ -465,8 +465,8 @@ } log.Printf("GPT-3 response: %s\n", promptAnswer) -}

    And now you have the final version of the prompt scavenger!

    Run the golang script with the following command:

    sh
    go run main.go <nodeIP> <namespace> <prompt>
    go run main.go <nodeIP> <namespace> <prompt>

    For example, you could run:

    sh
    go run main.go ws://localhost:26658 ce1e5714 'What is a modular blockchain?'
    go run main.go ws://localhost:26658 ce1e5714 'What is a modular blockchain?'

    After some time, it’ll post the output of the prompt you submitted to OpenAI that you pulled from Celestia’s blockchain.

    Next steps

    With this tutorial, you were able to construct a blob, submit it to Celestia, get it back from Celestia, decode its contents, then for added bonus, submit the message to GPT-3.5.

    If you're up for a challenge, you can refer to the Node API client guide and try to implement more advanced features, such as:

    • Subscribing to new prompts inside the ce1e5714 namespace, submitting each one to GPT-3.5
    • Posting the responses back to Celestia under a different namespace.
    - +}

    And now you have the final version of the prompt scavenger!

    Run the golang script with the following command:

    sh
    go run main.go <nodeIP> <namespace> <prompt>
    go run main.go <nodeIP> <namespace> <prompt>

    For example, you could run:

    sh
    go run main.go ws://localhost:26658 ce1e5714 'What is a modular blockchain?'
    go run main.go ws://localhost:26658 ce1e5714 'What is a modular blockchain?'

    After some time, it’ll post the output of the prompt you submitted to OpenAI that you pulled from Celestia’s blockchain.

    Next steps

    With this tutorial, you were able to construct a blob, submit it to Celestia, get it back from Celestia, decode its contents, then for added bonus, submit the message to GPT-3.5.

    If you're up for a challenge, you can refer to the Node API client guide and try to implement more advanced features, such as:

    • Subscribing to new prompts inside the ce1e5714 namespace, submitting each one to GPT-3.5
    • Posting the responses back to Celestia under a different namespace.
    + \ No newline at end of file diff --git a/pr-1815/tutorials/rust-client-tutorial.html b/pr-1815/tutorials/rust-client-tutorial.html index 827ddaa03..901612999 100644 --- a/pr-1815/tutorials/rust-client-tutorial.html +++ b/pr-1815/tutorials/rust-client-tutorial.html @@ -7,11 +7,11 @@ - + - - + + @@ -215,8 +215,8 @@ .share_get_eds(&latest_header) .await .expect("Failed to get EDS from latest header") -}

    API documentation

    To see the full list of available methods, see the API documentation.

    - +}

    API documentation

    To see the full list of available methods, see the API documentation.

    + \ No newline at end of file diff --git a/pr-1815/tutorials/wallets.html b/pr-1815/tutorials/wallets.html index 0bf2ae4db..c8209f8d0 100644 --- a/pr-1815/tutorials/wallets.html +++ b/pr-1815/tutorials/wallets.html @@ -7,12 +7,12 @@ - + - + - + @@ -48,7 +48,7 @@

    Wallet integrations with Celestia

    This page covers how developers can use Keplr and React to add Celestia network parameters to wallets, and how to add custom networks to Leap and Cosmostation.

    Add Celestia network parameters to Keplr with React

    Before we demonstrate how to export the specific parameters for Celestia's testnets, we need to create a ReactJS component that allows us to connect directly to Keplr and pass it the network parameters.

    In the following code, we show how you can export a component that detects whether Keplr is installed and sets the network params for it:

    jsx
    // @site/src/components/AddNetworkKeplr.js
    +

    Wallet integrations with Celestia

    This page covers how developers can use Keplr and React to add Celestia network parameters to wallets, and how to add custom networks to Leap and Cosmostation.

    Add Celestia network parameters to Keplr with React

    Before we demonstrate how to export the specific parameters for Celestia's testnets, we need to create a ReactJS component that allows us to connect directly to Keplr and pass it the network parameters.

    In the following code, we show how you can export a component that detects whether Keplr is installed and sets the network params for it:

    jsx
    // @site/src/components/AddNetworkKeplr.js
     import React from "react";
     import styles from "./Keplr.module.css";
     
    @@ -196,7 +196,7 @@
           </button>
         </div>
       );
    -}

    We still need to pass the Celestia network parameters to the AddNetworkKeplr function:

    js
    import '@site/src/components/AddNetworkKeplr'
    +}

    We still need to pass the Celestia network parameters to the AddNetworkKeplr function:

    js
    import '@site/src/components/AddNetworkKeplr'
     
     export const MAINNET_PARAMS = {`{
       chainId: 'celestia',
    @@ -250,8 +250,8 @@
       rest: 'https://api.celestia-arabica-11.com'
     }`}
     
    -{<AddNetworkKeplr params={ARABICA_PARAMS}/>}

    Now, we can connect to the network that you would like to use in Keplr wallet.

    Adding a custom chain to Leap

    If you want to add a custom chain to Leap, you can do so by:

    1. Clicking the Cosmos logo in the top corner of Leap wallet
    2. Scrolling down and clicking "Add new chain"

    You can then add the following parameters:

    • Chain Id: arabica-11
    • Chain Name: Arabica devnet
    • New RPC URL: https://rpc.celestia-arabica-11.com/
    • New REST URL: https://api.celestia-arabica-11.com
    • Address Prefix: celestia
    • Native Denom: utia
    • Coin Type: 118
    • Decimals: 6
    • Block explorer URL (optional): https://explorer.celestia-arabica-10.com

    Now, click Add chain and you will be able to view your Arabica account balance and transactions in Leap wallet.

    You'll see that you're connected to Arabica Devnet.

    Adding a custom chain to Cosmostation

    Click the hamburger menu icon in the top corner of Cosmostation wallet. Scroll down and click "Add Custom Chain"

    You can then add the following parameters:

    • Custom Chain name: Mocha testnet
    • Rest URL: https://api-mocha.pops.one
    • New RPC URL: https://rpc-mocha.pops.one
    • Currency symbol: TIA
    • Address prefix: celestia
    • Denom: utia
    • Symbol image URL (optional): https://raw.githubusercontent.com/cosmos/chain-registry/master/testnets/celestiatestnet/images/celestia.svg
    • Explorer URL (optional): https://testnet.mintscan.io/celestia-testnet
    • Coin Type: 118
    • Decimals: 6
    • Gas rate Tiny: 0.1
    • Gas rate Low: 0.25
    • Gas rate Average: 0.5

    Now, click Add a custom chain and you will be able to view your Celestia account balance and transactions in Cosmostation wallet.

    Switch chains to "Mocha testnet" and you'll see that you're connected to Celestia's Mocha testnet!

    - +{<AddNetworkKeplr params={ARABICA_PARAMS}/>}

    Now, we can connect to the network that you would like to use in Keplr wallet.

    Adding a custom chain to Leap

    If you want to add a custom chain to Leap, you can do so by:

    1. Clicking the Cosmos logo in the top corner of Leap wallet
    2. Scrolling down and clicking "Add new chain"

    You can then add the following parameters:

    • Chain Id: arabica-11
    • Chain Name: Arabica devnet
    • New RPC URL: https://rpc.celestia-arabica-11.com/
    • New REST URL: https://api.celestia-arabica-11.com
    • Address Prefix: celestia
    • Native Denom: utia
    • Coin Type: 118
    • Decimals: 6
    • Block explorer URL (optional): https://explorer.celestia-arabica-10.com

    Now, click Add chain and you will be able to view your Arabica account balance and transactions in Leap wallet.

    You'll see that you're connected to Arabica Devnet.

    Adding a custom chain to Cosmostation

    Click the hamburger menu icon in the top corner of Cosmostation wallet. Scroll down and click "Add Custom Chain"

    You can then add the following parameters:

    • Custom Chain name: Mocha testnet
    • Rest URL: https://api-mocha.pops.one
    • New RPC URL: https://rpc-mocha.pops.one
    • Currency symbol: TIA
    • Address prefix: celestia
    • Denom: utia
    • Symbol image URL (optional): https://raw.githubusercontent.com/cosmos/chain-registry/master/testnets/celestiatestnet/images/celestia.svg
    • Explorer URL (optional): https://testnet.mintscan.io/celestia-testnet
    • Coin Type: 118
    • Decimals: 6
    • Gas rate Tiny: 0.1
    • Gas rate Low: 0.25
    • Gas rate Average: 0.5

    Now, click Add a custom chain and you will be able to view your Celestia account balance and transactions in Cosmostation wallet.

    Switch chains to "Mocha testnet" and you'll see that you're connected to Celestia's Mocha testnet!

    + \ No newline at end of file