From ff058a3ec7a58a3588e570d39d40d95fee23c019 Mon Sep 17 00:00:00 2001 From: jcstein Date: Tue, 10 Sep 2024 08:09:04 +0000 Subject: [PATCH] =?UTF-8?q?Deploy=20preview=20for=20PR=201680=20?= =?UTF-8?q?=F0=9F=9B=AB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pr-1680/404.html | 4 +- pr-1680/README.html | 10 +-- ...E.md.84351c9c.js => README.md.eba3dded.js} | 2 +- ...c9c.lean.js => README.md.eba3dded.lean.js} | 2 +- .../{app.2e777ca5.js => app.3a5d9d68.js} | 2 +- .../chunks/@localSearchIndexroot.a2a5e800.js | 1 - .../chunks/@localSearchIndexroot.f0900312.js | 1 + ...d824.js => ArabicaVersionTags.20a10f87.js} | 2 +- ...f3c9.js => MainnetVersionTags.8346f766.js} | 2 +- ...273d07.js => MochaVersionTags.78e5b38e.js} | 2 +- ...2a90f5.js => VPLocalSearchBox.640545fb.js} | 2 +- ...d4ea25.js => arabica_versions.1930378b.js} | 2 +- .../chunks/arabica_versions.6d89be6e.js | 1 - ...ants.0e6df566.js => constants.295fc0ab.js} | 2 +- .../assets/chunks/mocha_versions.7704b055.js | 1 + .../{theme.c177f54e.js => theme.cfd5f84b.js} | 2 +- ...a.js => community_calendar.md.97a43115.js} | 2 +- ...=> community_calendar.md.97a43115.lean.js} | 2 +- ...3f881c.js => community_coc.md.532aa249.js} | 2 +- ...n.js => community_coc.md.532aa249.lean.js} | 2 +- ...ndation-delegation-program.md.ef8a9b75.js} | 2 +- ...on-delegation-program.md.ef8a9b75.lean.js} | 2 +- ...cc.js => community_itn-tos.md.89c55442.js} | 2 +- ... => community_itn-tos.md.89c55442.lean.js} | 2 +- ...unity_modular-meetup-guide.md.3997fb81.js} | 2 +- ..._modular-meetup-guide.md.3997fb81.lean.js} | 2 +- ...unity_modular-meetup-intro.md.8430b9a3.js} | 2 +- ..._modular-meetup-intro.md.8430b9a3.lean.js} | 2 +- ...ity_modular-meetup-toolkit.md.676a0a2a.js} | 2 +- ...odular-meetup-toolkit.md.676a0a2a.lean.js} | 2 +- ...5.js => community_overview.md.237c0746.js} | 2 +- ...=> community_overview.md.237c0746.lean.js} | 2 +- ... => community_speaker-list.md.b66230db.js} | 2 +- ...ommunity_speaker-list.md.b66230db.lean.js} | 2 +- ...developers_arbitrum-bridge.md.96018be7.js} | 2 +- ...opers_arbitrum-bridge.md.96018be7.lean.js} | 2 +- ...opers_arbitrum-dapp-deploy.md.f7dfbfa7.js} | 2 +- ..._arbitrum-dapp-deploy.md.f7dfbfa7.lean.js} | 2 +- ...developers_arbitrum-deploy.md.70ab5228.js} | 2 +- ...opers_arbitrum-deploy.md.70ab5228.lean.js} | 2 +- ...elopers_arbitrum-full-node.md.3cfe6aa9.js} | 2 +- ...rs_arbitrum-full-node.md.3cfe6aa9.lean.js} | 2 +- ...opers_arbitrum-integration.md.8282c127.js} | 2 +- ..._arbitrum-integration.md.8282c127.lean.js} | 2 +- ...rs_arbitrum-smart-contract.md.cc5d7a73.js} | 2 +- ...bitrum-smart-contract.md.cc5d7a73.lean.js} | 2 +- ...opers_blobstream-contracts.md.94e59fda.js} | 26 +++--- ..._blobstream-contracts.md.94e59fda.lean.js} | 2 +- ...lopers_blobstream-offchain.md.628432c8.js} | 2 +- ...s_blobstream-offchain.md.628432c8.lean.js} | 2 +- ...s_blobstream-proof-queries.md.cf3a9152.js} | 76 ++++++++++++----- ...bstream-proof-queries.md.cf3a9152.lean.js} | 2 +- ...elopers_blobstream-rollups.md.41e4a8bc.js} | 2 +- ...rs_blobstream-rollups.md.41e4a8bc.lean.js} | 2 +- ...lopers_blobstream-x-deploy.md.3886b5a3.js} | 2 +- ...s_blobstream-x-deploy.md.3886b5a3.lean.js} | 2 +- ...ing-data-commitment-ranges.md.4aa3e66e.js} | 2 +- ...ata-commitment-ranges.md.4aa3e66e.lean.js} | 2 +- .../developers_blobstream.md.5a20f3f8.js | 1 - .../developers_blobstream.md.5a20f3f8.lean.js | 1 - .../developers_blobstream.md.7c6b29b0.js | 1 + .../developers_blobstream.md.7c6b29b0.lean.js | 1 + .../developers_blobstreamx.md.7d123eea.js | 1 + ...developers_blobstreamx.md.7d123eea.lean.js | 1 + ...=> developers_bubs-testnet.md.6fd541b2.js} | 2 +- ...velopers_bubs-testnet.md.6fd541b2.lean.js} | 2 +- ... developers_build-whatever.md.30271c51.js} | 2 +- ...lopers_build-whatever.md.30271c51.lean.js} | 2 +- ...velopers_celestia-node-key.md.88cf4b78.js} | 10 +-- ...ers_celestia-node-key.md.88cf4b78.lean.js} | 2 +- ... developers_deploy-on-bubs.md.1057b5ac.js} | 2 +- ...lopers_deploy-on-bubs.md.1057b5ac.lean.js} | 2 +- ...velopers_ethereum-fallback.md.cd2adaa4.js} | 2 +- ...ers_ethereum-fallback.md.cd2adaa4.lean.js} | 2 +- ...elopers_feegrant-for-blobs.md.77fb195e.js} | 18 ++-- ...rs_feegrant-for-blobs.md.77fb195e.lean.js} | 2 +- ...-modular-development-guide.md.0c71091e.js} | 2 +- ...lar-development-guide.md.0c71091e.lean.js} | 2 +- ... developers_gm-portal-bubs.md.df82ad53.js} | 2 +- ...lopers_gm-portal-bubs.md.df82ad53.lean.js} | 2 +- ...ers_golang-client-tutorial.md.3f31b896.js} | 2 +- ...olang-client-tutorial.md.3f31b896.lean.js} | 2 +- ...elopers_integrate-celestia.md.3f8ccd2c.js} | 2 +- ...rs_integrate-celestia.md.3f8ccd2c.lean.js} | 2 +- ...velopers_intro-to-op-stack.md.07bb6aa7.js} | 2 +- ...ers_intro-to-op-stack.md.07bb6aa7.lean.js} | 2 +- .../developers_multiaccounts.md.a7a3ebe9.js | 5 ++ ...velopers_multiaccounts.md.a7a3ebe9.lean.js | 1 + ....js => developers_node-api.md.793cfe04.js} | 2 +- ...> developers_node-api.md.793cfe04.lean.js} | 2 +- ...> developers_node-tutorial.md.797233e2.js} | 6 +- ...elopers_node-tutorial.md.797233e2.lean.js} | 2 +- ...developers_optimism-devnet.md.5de00bc6.js} | 2 +- ...opers_optimism-devnet.md.5de00bc6.lean.js} | 2 +- ....js => developers_optimism.md.f09e526a.js} | 4 +- ...> developers_optimism.md.f09e526a.lean.js} | 2 +- ...evelopers_prompt-scavenger.md.8af0d32d.js} | 2 +- ...pers_prompt-scavenger.md.8af0d32d.lean.js} | 2 +- ...opers_rust-client-tutorial.md.892b74cf.js} | 2 +- ..._rust-client-tutorial.md.892b74cf.lean.js} | 2 +- ...pers_sp1-blobstream-deploy.md.6a1de8c6.js} | 2 +- ...sp1-blobstream-deploy.md.6a1de8c6.lean.js} | 2 +- ... => developers_submit-data.md.84194c6f.js} | 2 +- ...evelopers_submit-data.md.84194c6f.lean.js} | 2 +- ...s_transaction-resubmission.md.a7ae5c83.js} | 2 +- ...nsaction-resubmission.md.a7ae5c83.lean.js} | 2 +- ...4.js => developers_wallets.md.91a1722d.js} | 30 +++---- ...=> developers_wallets.md.91a1722d.lean.js} | 28 +++---- ...ex.md.0f32fb36.js => index.md.c62fad43.js} | 2 +- ...fb36.lean.js => index.md.c62fad43.lean.js} | 2 +- ...orks_data-availability-faq.md.4f8ba756.js} | 2 +- ...data-availability-faq.md.4f8ba756.lean.js} | 2 +- ...ks_data-availability-layer.md.fe8c1e7c.js} | 2 +- ...ta-availability-layer.md.fe8c1e7c.lean.js} | 2 +- ...orks_monolithic-vs-modular.md.b9f1f45d.js} | 2 +- ...monolithic-vs-modular.md.b9f1f45d.lean.js} | 2 +- ...ow-celestia-works_overview.md.c1a281d5.js} | 2 +- ...lestia-works_overview.md.c1a281d5.lean.js} | 2 +- ...orks_transaction-lifecycle.md.2dbdde2f.js} | 2 +- ...transaction-lifecycle.md.2dbdde2f.lean.js} | 2 +- ... => learn_how-to-stake-tia.md.8cd56e12.js} | 2 +- ...earn_how-to-stake-tia.md.8cd56e12.lean.js} | 2 +- ...learn_paying-for-blobspace.md.bf3ce96f.js} | 2 +- ..._paying-for-blobspace.md.bf3ce96f.lean.js} | 2 +- ...js => learn_retrievability.md.502536f6.js} | 2 +- ... learn_retrievability.md.502536f6.lean.js} | 2 +- ..._staking-governance-supply.md.d4993c82.js} | 2 +- ...ing-governance-supply.md.d4993c82.lean.js} | 2 +- ...f598de.js => learn_staking.md.5f314f9c.js} | 2 +- ...n.js => learn_staking.md.5f314f9c.lean.js} | 2 +- ...d.4c7134d5.js => learn_tia.md.50908c0d.js} | 2 +- ....lean.js => learn_tia.md.50908c0d.lean.js} | 2 +- ...js => nodes_arabica-devnet.md.c4919f1d.js} | 4 +- ... nodes_arabica-devnet.md.c4919f1d.lean.js} | 2 +- ...48.js => nodes_bridge-node.md.74cb097b.js} | 6 +- ... => nodes_bridge-node.md.74cb097b.lean.js} | 2 +- ...odes_celestia-app-commands.md.c7ad4df8.js} | 2 +- ...celestia-app-commands.md.c7ad4df8.lean.js} | 2 +- ...nodes_celestia-app-metrics.md.29cc5cc2.js} | 2 +- ..._celestia-app-metrics.md.29cc5cc2.lean.js} | 2 +- ...odes_celestia-app-multisig.md.ddb08823.js} | 2 +- ...celestia-app-multisig.md.ddb08823.lean.js} | 2 +- ...odes_celestia-app-slashing.md.f566e698.js} | 2 +- ...celestia-app-slashing.md.f566e698.lean.js} | 2 +- ...lestia-app-upgrade-monitor.md.7f8357e1.js} | 2 +- ...a-app-upgrade-monitor.md.7f8357e1.lean.js} | 2 +- ...nodes_celestia-app-vesting.md.dd0ddeb3.js} | 2 +- ..._celestia-app-vesting.md.dd0ddeb3.lean.js} | 2 +- ... nodes_celestia-app-wallet.md.634f19b0.js} | 2 +- ...s_celestia-app-wallet.md.634f19b0.lean.js} | 2 +- .../assets/nodes_celestia-app.md.4ff1b2af.js | 7 -- .../nodes_celestia-app.md.4ff1b2af.lean.js | 1 - .../assets/nodes_celestia-app.md.e40766f7.js | 7 ++ .../nodes_celestia-app.md.e40766f7.lean.js | 1 + ...estia-node-custom-networks.md.18993406.js} | 2 +- ...-node-custom-networks.md.18993406.lean.js} | 2 +- ...odes_celestia-node-metrics.md.ebcb2743.js} | 2 +- ...celestia-node-metrics.md.ebcb2743.lean.js} | 2 +- ...estia-node-troubleshooting.md.f834eff5.js} | 4 +- ...-node-troubleshooting.md.f834eff5.lean.js} | 2 +- ...celestia-node-trusted-hash.md.09a35d4c.js} | 2 +- ...tia-node-trusted-hash.md.09a35d4c.lean.js} | 2 +- ....js => nodes_celestia-node.md.1aba6dda.js} | 4 +- ...> nodes_celestia-node.md.1aba6dda.lean.js} | 2 +- ...cd.js => nodes_config-toml.md.baac8bd9.js} | 2 +- ... => nodes_config-toml.md.baac8bd9.lean.js} | 2 +- ...js => nodes_consensus-node.md.21f5a1d7.js} | 46 +++++----- ... nodes_consensus-node.md.21f5a1d7.lean.js} | 42 +++++----- ...f2.js => nodes_decide-node.md.1303eb5d.js} | 2 +- ... => nodes_decide-node.md.1303eb5d.lean.js} | 2 +- ....js => nodes_docker-images.md.8cee5aaa.js} | 52 ++++++------ ...> nodes_docker-images.md.8cee5aaa.lean.js} | 46 +++++----- .../nodes_environment.md.327a8dbd.lean.js | 1 - ...bd.js => nodes_environment.md.3dbd31f9.js} | 8 +- .../nodes_environment.md.3dbd31f9.lean.js | 1 + ...=> nodes_full-storage-node.md.b0ec8a5f.js} | 4 +- ...des_full-storage-node.md.b0ec8a5f.lean.js} | 2 +- ... => nodes_hardfork-process.md.c86d1151.js} | 2 +- ...odes_hardfork-process.md.c86d1151.lean.js} | 2 +- ...4c.js => nodes_ibc-relayer.md.a8f27ce5.js} | 2 +- ... => nodes_ibc-relayer.md.a8f27ce5.lean.js} | 2 +- ... nodes_instantiate-testnet.md.4237987d.js} | 2 +- ...s_instantiate-testnet.md.4237987d.lean.js} | 2 +- ...f14.js => nodes_light-node.md.ebca7fc4.js} | 8 +- ...s => nodes_light-node.md.ebca7fc4.lean.js} | 2 +- ...c4e1fb.js => nodes_mainnet.md.91c04e4d.js} | 2 +- ...n.js => nodes_mainnet.md.91c04e4d.lean.js} | 2 +- ....js => nodes_mocha-testnet.md.aa2ae9c7.js} | 2 +- ...> nodes_mocha-testnet.md.aa2ae9c7.lean.js} | 2 +- ...f23da.js => nodes_overview.md.1b940623.js} | 2 +- ....js => nodes_overview.md.1b940623.lean.js} | 2 +- ...40.js => nodes_participate.md.44f9ae13.js} | 2 +- ... => nodes_participate.md.44f9ae13.lean.js} | 2 +- ...08.js => nodes_quick-start.md.4fe562f2.js} | 2 +- ... => nodes_quick-start.md.4fe562f2.lean.js} | 2 +- ...76c2e7.js => nodes_systemd.md.10732002.js} | 2 +- ...n.js => nodes_systemd.md.10732002.lean.js} | 2 +- ...js => nodes_validator-node.md.56905fa6.js} | 22 ++--- ... nodes_validator-node.md.56905fa6.lean.js} | 16 ++-- pr-1680/community/calendar.html | 10 +-- pr-1680/community/coc.html | 10 +-- .../foundation-delegation-program.html | 10 +-- pr-1680/community/itn-tos.html | 10 +-- pr-1680/community/modular-meetup-guide.html | 10 +-- pr-1680/community/modular-meetup-intro.html | 10 +-- pr-1680/community/modular-meetup-toolkit.html | 10 +-- pr-1680/community/overview.html | 10 +-- pr-1680/community/speaker-list.html | 10 +-- pr-1680/developers/arbitrum-bridge.html | 10 +-- pr-1680/developers/arbitrum-dapp-deploy.html | 12 +-- pr-1680/developers/arbitrum-deploy.html | 12 +-- pr-1680/developers/arbitrum-full-node.html | 12 +-- pr-1680/developers/arbitrum-integration.html | 10 +-- .../developers/arbitrum-smart-contract.html | 12 +-- pr-1680/developers/blobstream-contracts.html | 34 ++++---- pr-1680/developers/blobstream-offchain.html | 12 +-- .../developers/blobstream-proof-queries.html | 84 +++++++++++++------ pr-1680/developers/blobstream-rollups.html | 12 +-- pr-1680/developers/blobstream-x-deploy.html | 12 +-- ...m-x-requesting-data-commitment-ranges.html | 10 +-- pr-1680/developers/blobstream.html | 10 +-- pr-1680/developers/blobstreamx.html | 45 ++++++++++ pr-1680/developers/bubs-testnet.html | 10 +-- pr-1680/developers/build-whatever.html | 10 +-- pr-1680/developers/celestia-node-key.html | 24 +++--- pr-1680/developers/deploy-on-bubs.html | 12 +-- pr-1680/developers/ethereum-fallback.html | 10 +-- pr-1680/developers/feegrant-for-blobs.html | 26 +++--- .../full-stack-modular-development-guide.html | 12 +-- pr-1680/developers/gm-portal-bubs.html | 12 +-- .../developers/golang-client-tutorial.html | 12 +-- pr-1680/developers/integrate-celestia.html | 10 +-- pr-1680/developers/intro-to-op-stack.html | 10 +-- pr-1680/developers/multiaccounts.html | 49 +++++++++++ pr-1680/developers/node-api.html | 10 +-- pr-1680/developers/node-tutorial.html | 16 ++-- pr-1680/developers/optimism-devnet.html | 12 +-- pr-1680/developers/optimism.html | 14 ++-- pr-1680/developers/prompt-scavenger.html | 12 +-- pr-1680/developers/rust-client-tutorial.html | 12 +-- pr-1680/developers/sp1-blobstream-deploy.html | 12 +-- pr-1680/developers/submit-data.html | 12 +-- .../developers/transaction-resubmission.html | 10 +-- pr-1680/developers/wallets.html | 16 ++-- pr-1680/hashmap.json | 2 +- pr-1680/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-1680/learn/how-to-stake-tia.html | 10 +-- pr-1680/learn/paying-for-blobspace.html | 10 +-- pr-1680/learn/retrievability.html | 10 +-- pr-1680/learn/staking-governance-supply.html | 10 +-- pr-1680/learn/staking.html | 10 +-- pr-1680/learn/tia.html | 10 +-- pr-1680/nodes/arabica-devnet.html | 18 ++-- pr-1680/nodes/bridge-node.html | 14 ++-- pr-1680/nodes/celestia-app-commands.html | 12 +-- pr-1680/nodes/celestia-app-metrics.html | 12 +-- pr-1680/nodes/celestia-app-multisig.html | 12 +-- pr-1680/nodes/celestia-app-slashing.html | 10 +-- .../nodes/celestia-app-upgrade-monitor.html | 10 +-- pr-1680/nodes/celestia-app-vesting.html | 12 +-- pr-1680/nodes/celestia-app-wallet.html | 12 +-- pr-1680/nodes/celestia-app.html | 16 ++-- .../nodes/celestia-node-custom-networks.html | 12 +-- pr-1680/nodes/celestia-node-metrics.html | 12 +-- .../nodes/celestia-node-troubleshooting.html | 14 ++-- pr-1680/nodes/celestia-node-trusted-hash.html | 12 +-- pr-1680/nodes/celestia-node.html | 16 ++-- pr-1680/nodes/config-toml.html | 10 +-- pr-1680/nodes/consensus-node.html | 20 ++--- pr-1680/nodes/decide-node.html | 10 +-- pr-1680/nodes/docker-images.html | 46 +++++----- pr-1680/nodes/environment.html | 18 ++-- pr-1680/nodes/full-storage-node.html | 12 +-- pr-1680/nodes/hardfork-process.html | 10 +-- pr-1680/nodes/ibc-relayer.html | 12 +-- pr-1680/nodes/instantiate-testnet.html | 12 +-- pr-1680/nodes/light-node.html | 16 ++-- pr-1680/nodes/mainnet.html | 14 ++-- pr-1680/nodes/mocha-testnet.html | 16 ++-- pr-1680/nodes/overview.html | 10 +-- pr-1680/nodes/participate.html | 22 ++--- pr-1680/nodes/quick-start.html | 10 +-- pr-1680/nodes/systemd.html | 12 +-- pr-1680/nodes/validator-node.html | 16 ++-- pr-1680/sitemap.xml | 2 +- 290 files changed, 1132 insertions(+), 974 deletions(-) rename pr-1680/assets/{README.md.84351c9c.js => README.md.eba3dded.js} (96%) rename pr-1680/assets/{README.md.84351c9c.lean.js => README.md.eba3dded.lean.js} (76%) rename pr-1680/assets/{app.2e777ca5.js => app.3a5d9d68.js} (95%) delete mode 100644 pr-1680/assets/chunks/@localSearchIndexroot.a2a5e800.js create mode 100644 pr-1680/assets/chunks/@localSearchIndexroot.f0900312.js rename pr-1680/assets/chunks/{ArabicaVersionTags.e01dd824.js => ArabicaVersionTags.20a10f87.js} (86%) rename pr-1680/assets/chunks/{MainnetVersionTags.1cb0f3c9.js => MainnetVersionTags.8346f766.js} (93%) rename pr-1680/assets/chunks/{MochaVersionTags.83273d07.js => MochaVersionTags.78e5b38e.js} (86%) rename pr-1680/assets/chunks/{VPLocalSearchBox.c92a90f5.js => VPLocalSearchBox.640545fb.js} (99%) rename pr-1680/assets/chunks/{mocha_versions.ffd4ea25.js => arabica_versions.1930378b.js} (59%) delete mode 100644 pr-1680/assets/chunks/arabica_versions.6d89be6e.js rename pr-1680/assets/chunks/{constants.0e6df566.js => constants.295fc0ab.js} (82%) create mode 100644 pr-1680/assets/chunks/mocha_versions.7704b055.js rename pr-1680/assets/chunks/{theme.c177f54e.js => theme.cfd5f84b.js} (99%) rename pr-1680/assets/{community_calendar.md.cec7b00a.js => community_calendar.md.97a43115.js} (95%) rename pr-1680/assets/{community_calendar.md.cec7b00a.lean.js => community_calendar.md.97a43115.lean.js} (95%) rename pr-1680/assets/{community_coc.md.3b3f881c.js => community_coc.md.532aa249.js} (98%) rename pr-1680/assets/{community_coc.md.3b3f881c.lean.js => community_coc.md.532aa249.lean.js} (82%) rename pr-1680/assets/{community_foundation-delegation-program.md.d130506e.js => community_foundation-delegation-program.md.ef8a9b75.js} (99%) rename pr-1680/assets/{community_foundation-delegation-program.md.d130506e.lean.js => community_foundation-delegation-program.md.ef8a9b75.lean.js} (91%) rename pr-1680/assets/{community_itn-tos.md.c448efcc.js => community_itn-tos.md.89c55442.js} (99%) rename pr-1680/assets/{community_itn-tos.md.c448efcc.lean.js => community_itn-tos.md.89c55442.lean.js} (92%) rename pr-1680/assets/{community_modular-meetup-guide.md.83bd3c81.js => community_modular-meetup-guide.md.3997fb81.js} (99%) rename pr-1680/assets/{community_modular-meetup-guide.md.83bd3c81.lean.js => community_modular-meetup-guide.md.3997fb81.lean.js} (91%) rename pr-1680/assets/{community_modular-meetup-intro.md.15c20508.js => community_modular-meetup-intro.md.8430b9a3.js} (98%) rename pr-1680/assets/{community_modular-meetup-intro.md.15c20508.lean.js => community_modular-meetup-intro.md.8430b9a3.lean.js} (91%) rename pr-1680/assets/{community_modular-meetup-toolkit.md.c0a464fb.js => community_modular-meetup-toolkit.md.676a0a2a.js} (98%) rename pr-1680/assets/{community_modular-meetup-toolkit.md.c0a464fb.lean.js => community_modular-meetup-toolkit.md.676a0a2a.lean.js} (90%) rename pr-1680/assets/{community_overview.md.5d3cdb35.js => community_overview.md.237c0746.js} (94%) rename pr-1680/assets/{community_overview.md.5d3cdb35.lean.js => community_overview.md.237c0746.lean.js} (94%) rename pr-1680/assets/{community_speaker-list.md.dd7785cb.js => community_speaker-list.md.b66230db.js} (97%) rename pr-1680/assets/{community_speaker-list.md.dd7785cb.lean.js => community_speaker-list.md.b66230db.lean.js} (97%) rename pr-1680/assets/{developers_arbitrum-bridge.md.1305b088.js => developers_arbitrum-bridge.md.96018be7.js} (99%) rename pr-1680/assets/{developers_arbitrum-bridge.md.1305b088.lean.js => developers_arbitrum-bridge.md.96018be7.lean.js} (96%) rename pr-1680/assets/{developers_arbitrum-dapp-deploy.md.94c9ebd9.js => developers_arbitrum-dapp-deploy.md.f7dfbfa7.js} (99%) rename pr-1680/assets/{developers_arbitrum-dapp-deploy.md.94c9ebd9.lean.js => developers_arbitrum-dapp-deploy.md.f7dfbfa7.lean.js} (92%) rename pr-1680/assets/{developers_arbitrum-deploy.md.839b7894.js => developers_arbitrum-deploy.md.70ab5228.js} (99%) rename pr-1680/assets/{developers_arbitrum-deploy.md.839b7894.lean.js => developers_arbitrum-deploy.md.70ab5228.lean.js} (94%) rename pr-1680/assets/{developers_arbitrum-full-node.md.1806878f.js => developers_arbitrum-full-node.md.3cfe6aa9.js} (98%) rename pr-1680/assets/{developers_arbitrum-full-node.md.1806878f.lean.js => developers_arbitrum-full-node.md.3cfe6aa9.lean.js} (92%) rename pr-1680/assets/{developers_arbitrum-integration.md.9e0aee21.js => developers_arbitrum-integration.md.8282c127.js} (99%) rename pr-1680/assets/{developers_arbitrum-integration.md.9e0aee21.lean.js => developers_arbitrum-integration.md.8282c127.lean.js} (93%) rename pr-1680/assets/{developers_arbitrum-smart-contract.md.26545321.js => developers_arbitrum-smart-contract.md.cc5d7a73.js} (99%) rename pr-1680/assets/{developers_arbitrum-smart-contract.md.26545321.lean.js => developers_arbitrum-smart-contract.md.cc5d7a73.lean.js} (94%) rename pr-1680/assets/{developers_blobstream-contracts.md.a96f5b10.js => developers_blobstream-contracts.md.94e59fda.js} (84%) rename pr-1680/assets/{developers_blobstream-contracts.md.a96f5b10.lean.js => developers_blobstream-contracts.md.94e59fda.lean.js} (86%) rename pr-1680/assets/{developers_blobstream-offchain.md.714e874f.js => developers_blobstream-offchain.md.628432c8.js} (98%) rename pr-1680/assets/{developers_blobstream-offchain.md.714e874f.lean.js => developers_blobstream-offchain.md.628432c8.lean.js} (91%) rename pr-1680/assets/{developers_blobstream-proof-queries.md.8321ccb1.js => developers_blobstream-proof-queries.md.cf3a9152.js} (93%) rename pr-1680/assets/{developers_blobstream-proof-queries.md.8321ccb1.lean.js => developers_blobstream-proof-queries.md.cf3a9152.lean.js} (81%) rename pr-1680/assets/{developers_blobstream-rollups.md.67f5cc25.js => developers_blobstream-rollups.md.41e4a8bc.js} (99%) rename pr-1680/assets/{developers_blobstream-rollups.md.67f5cc25.lean.js => developers_blobstream-rollups.md.41e4a8bc.lean.js} (92%) rename pr-1680/assets/{developers_blobstream-x-deploy.md.16c5ae12.js => developers_blobstream-x-deploy.md.3886b5a3.js} (99%) rename pr-1680/assets/{developers_blobstream-x-deploy.md.16c5ae12.lean.js => developers_blobstream-x-deploy.md.3886b5a3.lean.js} (90%) rename pr-1680/assets/{developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.js => developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.js} (98%) rename pr-1680/assets/{developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.lean.js => developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.lean.js} (92%) delete mode 100644 pr-1680/assets/developers_blobstream.md.5a20f3f8.js delete mode 100644 pr-1680/assets/developers_blobstream.md.5a20f3f8.lean.js create mode 100644 pr-1680/assets/developers_blobstream.md.7c6b29b0.js create mode 100644 pr-1680/assets/developers_blobstream.md.7c6b29b0.lean.js create mode 100644 pr-1680/assets/developers_blobstreamx.md.7d123eea.js create mode 100644 pr-1680/assets/developers_blobstreamx.md.7d123eea.lean.js rename pr-1680/assets/{developers_bubs-testnet.md.e6fe9bf8.js => developers_bubs-testnet.md.6fd541b2.js} (98%) rename pr-1680/assets/{developers_bubs-testnet.md.e6fe9bf8.lean.js => developers_bubs-testnet.md.6fd541b2.lean.js} (92%) rename pr-1680/assets/{developers_build-whatever.md.a1d2e5ba.js => developers_build-whatever.md.30271c51.js} (99%) rename pr-1680/assets/{developers_build-whatever.md.a1d2e5ba.lean.js => developers_build-whatever.md.30271c51.lean.js} (98%) rename pr-1680/assets/{developers_celestia-node-key.md.b25623f9.js => developers_celestia-node-key.md.88cf4b78.js} (98%) rename pr-1680/assets/{developers_celestia-node-key.md.b25623f9.lean.js => developers_celestia-node-key.md.88cf4b78.lean.js} (88%) rename pr-1680/assets/{developers_deploy-on-bubs.md.d43095f8.js => developers_deploy-on-bubs.md.1057b5ac.js} (99%) rename pr-1680/assets/{developers_deploy-on-bubs.md.d43095f8.lean.js => developers_deploy-on-bubs.md.1057b5ac.lean.js} (81%) rename pr-1680/assets/{developers_ethereum-fallback.md.8387bd5e.js => developers_ethereum-fallback.md.cd2adaa4.js} (97%) rename pr-1680/assets/{developers_ethereum-fallback.md.8387bd5e.lean.js => developers_ethereum-fallback.md.cd2adaa4.lean.js} (97%) rename pr-1680/assets/{developers_feegrant-for-blobs.md.fb084a8d.js => developers_feegrant-for-blobs.md.77fb195e.js} (55%) rename pr-1680/assets/{developers_feegrant-for-blobs.md.fb084a8d.lean.js => developers_feegrant-for-blobs.md.77fb195e.lean.js} (50%) rename pr-1680/assets/{developers_full-stack-modular-development-guide.md.ca053aa5.js => developers_full-stack-modular-development-guide.md.0c71091e.js} (99%) rename pr-1680/assets/{developers_full-stack-modular-development-guide.md.ca053aa5.lean.js => developers_full-stack-modular-development-guide.md.0c71091e.lean.js} (92%) rename pr-1680/assets/{developers_gm-portal-bubs.md.69f6963b.js => developers_gm-portal-bubs.md.df82ad53.js} (99%) rename pr-1680/assets/{developers_gm-portal-bubs.md.69f6963b.lean.js => developers_gm-portal-bubs.md.df82ad53.lean.js} (92%) rename pr-1680/assets/{developers_golang-client-tutorial.md.1734d91e.js => developers_golang-client-tutorial.md.3f31b896.js} (99%) rename pr-1680/assets/{developers_golang-client-tutorial.md.1734d91e.lean.js => developers_golang-client-tutorial.md.3f31b896.lean.js} (89%) rename pr-1680/assets/{developers_integrate-celestia.md.a09ad5ff.js => developers_integrate-celestia.md.3f8ccd2c.js} (98%) rename pr-1680/assets/{developers_integrate-celestia.md.a09ad5ff.lean.js => developers_integrate-celestia.md.3f8ccd2c.lean.js} (92%) rename pr-1680/assets/{developers_intro-to-op-stack.md.fa5d636c.js => developers_intro-to-op-stack.md.07bb6aa7.js} (98%) rename pr-1680/assets/{developers_intro-to-op-stack.md.fa5d636c.lean.js => developers_intro-to-op-stack.md.07bb6aa7.lean.js} (92%) create mode 100644 pr-1680/assets/developers_multiaccounts.md.a7a3ebe9.js create mode 100644 pr-1680/assets/developers_multiaccounts.md.a7a3ebe9.lean.js rename pr-1680/assets/{developers_node-api.md.e5a7b4d3.js => developers_node-api.md.793cfe04.js} (98%) rename pr-1680/assets/{developers_node-api.md.e5a7b4d3.lean.js => developers_node-api.md.793cfe04.lean.js} (90%) rename pr-1680/assets/{developers_node-tutorial.md.185dc136.js => developers_node-tutorial.md.797233e2.js} (99%) rename pr-1680/assets/{developers_node-tutorial.md.185dc136.lean.js => developers_node-tutorial.md.797233e2.lean.js} (93%) rename pr-1680/assets/{developers_optimism-devnet.md.a9e0c5a6.js => developers_optimism-devnet.md.5de00bc6.js} (99%) rename pr-1680/assets/{developers_optimism-devnet.md.a9e0c5a6.lean.js => developers_optimism-devnet.md.5de00bc6.lean.js} (89%) rename pr-1680/assets/{developers_optimism.md.6b557910.js => developers_optimism.md.f09e526a.js} (93%) rename pr-1680/assets/{developers_optimism.md.6b557910.lean.js => developers_optimism.md.f09e526a.lean.js} (63%) rename pr-1680/assets/{developers_prompt-scavenger.md.70ab1baf.js => developers_prompt-scavenger.md.8af0d32d.js} (99%) rename pr-1680/assets/{developers_prompt-scavenger.md.70ab1baf.lean.js => developers_prompt-scavenger.md.8af0d32d.lean.js} (84%) rename pr-1680/assets/{developers_rust-client-tutorial.md.1649c175.js => developers_rust-client-tutorial.md.892b74cf.js} (99%) rename pr-1680/assets/{developers_rust-client-tutorial.md.1649c175.lean.js => developers_rust-client-tutorial.md.892b74cf.lean.js} (90%) rename pr-1680/assets/{developers_sp1-blobstream-deploy.md.2340bea7.js => developers_sp1-blobstream-deploy.md.6a1de8c6.js} (98%) rename pr-1680/assets/{developers_sp1-blobstream-deploy.md.2340bea7.lean.js => developers_sp1-blobstream-deploy.md.6a1de8c6.lean.js} (91%) rename pr-1680/assets/{developers_submit-data.md.c8780ba2.js => developers_submit-data.md.84194c6f.js} (99%) rename pr-1680/assets/{developers_submit-data.md.c8780ba2.lean.js => developers_submit-data.md.84194c6f.lean.js} (99%) rename pr-1680/assets/{developers_transaction-resubmission.md.2dfb34a4.js => developers_transaction-resubmission.md.a7ae5c83.js} (97%) rename pr-1680/assets/{developers_transaction-resubmission.md.2dfb34a4.lean.js => developers_transaction-resubmission.md.a7ae5c83.lean.js} (91%) rename pr-1680/assets/{developers_wallets.md.1fc181f4.js => developers_wallets.md.91a1722d.js} (95%) rename pr-1680/assets/{developers_wallets.md.1fc181f4.lean.js => developers_wallets.md.91a1722d.lean.js} (81%) rename pr-1680/assets/{index.md.0f32fb36.js => index.md.c62fad43.js} (96%) rename pr-1680/assets/{index.md.0f32fb36.lean.js => index.md.c62fad43.lean.js} (96%) rename pr-1680/assets/{learn_how-celestia-works_data-availability-faq.md.c77d8ed2.js => learn_how-celestia-works_data-availability-faq.md.4f8ba756.js} (99%) rename pr-1680/assets/{learn_how-celestia-works_data-availability-faq.md.c77d8ed2.lean.js => learn_how-celestia-works_data-availability-faq.md.4f8ba756.lean.js} (93%) rename pr-1680/assets/{learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.js => learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.js} (99%) rename pr-1680/assets/{learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.lean.js => learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.lean.js} (99%) rename pr-1680/assets/{learn_how-celestia-works_monolithic-vs-modular.md.494025b0.js => learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.js} (98%) rename pr-1680/assets/{learn_how-celestia-works_monolithic-vs-modular.md.494025b0.lean.js => learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.lean.js} (92%) rename pr-1680/assets/{learn_how-celestia-works_overview.md.d0862172.js => learn_how-celestia-works_overview.md.c1a281d5.js} (97%) rename pr-1680/assets/{learn_how-celestia-works_overview.md.d0862172.lean.js => learn_how-celestia-works_overview.md.c1a281d5.lean.js} (89%) rename pr-1680/assets/{learn_how-celestia-works_transaction-lifecycle.md.a039d39a.js => learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.js} (99%) rename pr-1680/assets/{learn_how-celestia-works_transaction-lifecycle.md.a039d39a.lean.js => learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.lean.js} (99%) rename pr-1680/assets/{learn_how-to-stake-tia.md.eca4d77a.js => learn_how-to-stake-tia.md.8cd56e12.js} (99%) rename pr-1680/assets/{learn_how-to-stake-tia.md.eca4d77a.lean.js => learn_how-to-stake-tia.md.8cd56e12.lean.js} (95%) rename pr-1680/assets/{learn_paying-for-blobspace.md.1a14801b.js => learn_paying-for-blobspace.md.bf3ce96f.js} (97%) rename pr-1680/assets/{learn_paying-for-blobspace.md.1a14801b.lean.js => learn_paying-for-blobspace.md.bf3ce96f.lean.js} (90%) rename pr-1680/assets/{learn_retrievability.md.624d5724.js => learn_retrievability.md.502536f6.js} (98%) rename pr-1680/assets/{learn_retrievability.md.624d5724.lean.js => learn_retrievability.md.502536f6.lean.js} (92%) rename pr-1680/assets/{learn_staking-governance-supply.md.f12d24a2.js => learn_staking-governance-supply.md.d4993c82.js} (99%) rename pr-1680/assets/{learn_staking-governance-supply.md.f12d24a2.lean.js => learn_staking-governance-supply.md.d4993c82.lean.js} (93%) rename pr-1680/assets/{learn_staking.md.41f598de.js => learn_staking.md.5f314f9c.js} (97%) rename pr-1680/assets/{learn_staking.md.41f598de.lean.js => learn_staking.md.5f314f9c.lean.js} (90%) rename pr-1680/assets/{learn_tia.md.4c7134d5.js => learn_tia.md.50908c0d.js} (99%) rename pr-1680/assets/{learn_tia.md.4c7134d5.lean.js => learn_tia.md.50908c0d.lean.js} (97%) rename pr-1680/assets/{nodes_arabica-devnet.md.1e272478.js => nodes_arabica-devnet.md.c4919f1d.js} (98%) rename pr-1680/assets/{nodes_arabica-devnet.md.1e272478.lean.js => nodes_arabica-devnet.md.c4919f1d.lean.js} (85%) rename pr-1680/assets/{nodes_bridge-node.md.a669cc48.js => nodes_bridge-node.md.74cb097b.js} (93%) rename pr-1680/assets/{nodes_bridge-node.md.a669cc48.lean.js => nodes_bridge-node.md.74cb097b.lean.js} (73%) rename pr-1680/assets/{nodes_celestia-app-commands.md.da9e2012.js => nodes_celestia-app-commands.md.c7ad4df8.js} (99%) rename pr-1680/assets/{nodes_celestia-app-commands.md.da9e2012.lean.js => nodes_celestia-app-commands.md.c7ad4df8.lean.js} (91%) rename pr-1680/assets/{nodes_celestia-app-metrics.md.1d5a64b1.js => nodes_celestia-app-metrics.md.29cc5cc2.js} (99%) rename pr-1680/assets/{nodes_celestia-app-metrics.md.1d5a64b1.lean.js => nodes_celestia-app-metrics.md.29cc5cc2.lean.js} (92%) rename pr-1680/assets/{nodes_celestia-app-multisig.md.9965f0f0.js => nodes_celestia-app-multisig.md.ddb08823.js} (99%) rename pr-1680/assets/{nodes_celestia-app-multisig.md.9965f0f0.lean.js => nodes_celestia-app-multisig.md.ddb08823.lean.js} (88%) rename pr-1680/assets/{nodes_celestia-app-slashing.md.90798e11.js => nodes_celestia-app-slashing.md.f566e698.js} (97%) rename pr-1680/assets/{nodes_celestia-app-slashing.md.90798e11.lean.js => nodes_celestia-app-slashing.md.f566e698.lean.js} (92%) rename pr-1680/assets/{nodes_celestia-app-upgrade-monitor.md.a7f594fd.js => nodes_celestia-app-upgrade-monitor.md.7f8357e1.js} (89%) rename pr-1680/assets/{nodes_celestia-app-upgrade-monitor.md.a7f594fd.lean.js => nodes_celestia-app-upgrade-monitor.md.7f8357e1.lean.js} (89%) rename pr-1680/assets/{nodes_celestia-app-vesting.md.f93598b1.js => nodes_celestia-app-vesting.md.dd0ddeb3.js} (99%) rename pr-1680/assets/{nodes_celestia-app-vesting.md.f93598b1.lean.js => nodes_celestia-app-vesting.md.dd0ddeb3.lean.js} (91%) rename pr-1680/assets/{nodes_celestia-app-wallet.md.3b09d1dc.js => nodes_celestia-app-wallet.md.634f19b0.js} (99%) rename pr-1680/assets/{nodes_celestia-app-wallet.md.3b09d1dc.lean.js => nodes_celestia-app-wallet.md.634f19b0.lean.js} (91%) delete mode 100644 pr-1680/assets/nodes_celestia-app.md.4ff1b2af.js delete mode 100644 pr-1680/assets/nodes_celestia-app.md.4ff1b2af.lean.js create mode 100644 pr-1680/assets/nodes_celestia-app.md.e40766f7.js create mode 100644 pr-1680/assets/nodes_celestia-app.md.e40766f7.lean.js rename pr-1680/assets/{nodes_celestia-node-custom-networks.md.20aba34e.js => nodes_celestia-node-custom-networks.md.18993406.js} (99%) rename pr-1680/assets/{nodes_celestia-node-custom-networks.md.20aba34e.lean.js => nodes_celestia-node-custom-networks.md.18993406.lean.js} (91%) rename pr-1680/assets/{nodes_celestia-node-metrics.md.216eb211.js => nodes_celestia-node-metrics.md.ebcb2743.js} (99%) rename pr-1680/assets/{nodes_celestia-node-metrics.md.216eb211.lean.js => nodes_celestia-node-metrics.md.ebcb2743.lean.js} (91%) rename pr-1680/assets/{nodes_celestia-node-troubleshooting.md.821659c6.js => nodes_celestia-node-troubleshooting.md.f834eff5.js} (99%) rename pr-1680/assets/{nodes_celestia-node-troubleshooting.md.821659c6.lean.js => nodes_celestia-node-troubleshooting.md.f834eff5.lean.js} (93%) rename pr-1680/assets/{nodes_celestia-node-trusted-hash.md.f83aaf6b.js => nodes_celestia-node-trusted-hash.md.09a35d4c.js} (99%) rename pr-1680/assets/{nodes_celestia-node-trusted-hash.md.f83aaf6b.lean.js => nodes_celestia-node-trusted-hash.md.09a35d4c.lean.js} (91%) rename pr-1680/assets/{nodes_celestia-node.md.a266ee0e.js => nodes_celestia-node.md.1aba6dda.js} (85%) rename pr-1680/assets/{nodes_celestia-node.md.a266ee0e.lean.js => nodes_celestia-node.md.1aba6dda.lean.js} (60%) rename pr-1680/assets/{nodes_config-toml.md.7c6ec5cd.js => nodes_config-toml.md.baac8bd9.js} (98%) rename pr-1680/assets/{nodes_config-toml.md.7c6ec5cd.lean.js => nodes_config-toml.md.baac8bd9.lean.js} (90%) rename pr-1680/assets/{nodes_consensus-node.md.01077dd8.js => nodes_consensus-node.md.21f5a1d7.js} (64%) rename pr-1680/assets/{nodes_consensus-node.md.01077dd8.lean.js => nodes_consensus-node.md.21f5a1d7.lean.js} (66%) rename pr-1680/assets/{nodes_decide-node.md.e2cf48f2.js => nodes_decide-node.md.1303eb5d.js} (96%) rename pr-1680/assets/{nodes_decide-node.md.e2cf48f2.lean.js => nodes_decide-node.md.1303eb5d.lean.js} (90%) rename pr-1680/assets/{nodes_docker-images.md.cd1555b9.js => nodes_docker-images.md.8cee5aaa.js} (88%) rename pr-1680/assets/{nodes_docker-images.md.cd1555b9.lean.js => nodes_docker-images.md.8cee5aaa.lean.js} (67%) delete mode 100644 pr-1680/assets/nodes_environment.md.327a8dbd.lean.js rename pr-1680/assets/{nodes_environment.md.327a8dbd.js => nodes_environment.md.3dbd31f9.js} (90%) create mode 100644 pr-1680/assets/nodes_environment.md.3dbd31f9.lean.js rename pr-1680/assets/{nodes_full-storage-node.md.07a0c9a4.js => nodes_full-storage-node.md.b0ec8a5f.js} (89%) rename pr-1680/assets/{nodes_full-storage-node.md.07a0c9a4.lean.js => nodes_full-storage-node.md.b0ec8a5f.lean.js} (83%) rename pr-1680/assets/{nodes_hardfork-process.md.9c089234.js => nodes_hardfork-process.md.c86d1151.js} (85%) rename pr-1680/assets/{nodes_hardfork-process.md.9c089234.lean.js => nodes_hardfork-process.md.c86d1151.lean.js} (81%) rename pr-1680/assets/{nodes_ibc-relayer.md.7a3c6a4c.js => nodes_ibc-relayer.md.a8f27ce5.js} (99%) rename pr-1680/assets/{nodes_ibc-relayer.md.7a3c6a4c.lean.js => nodes_ibc-relayer.md.a8f27ce5.lean.js} (91%) rename pr-1680/assets/{nodes_instantiate-testnet.md.564058ba.js => nodes_instantiate-testnet.md.4237987d.js} (99%) rename pr-1680/assets/{nodes_instantiate-testnet.md.564058ba.lean.js => nodes_instantiate-testnet.md.4237987d.lean.js} (91%) rename pr-1680/assets/{nodes_light-node.md.4d805f14.js => nodes_light-node.md.ebca7fc4.js} (90%) rename pr-1680/assets/{nodes_light-node.md.4d805f14.lean.js => nodes_light-node.md.ebca7fc4.lean.js} (59%) rename pr-1680/assets/{nodes_mainnet.md.71c4e1fb.js => nodes_mainnet.md.91c04e4d.js} (99%) rename pr-1680/assets/{nodes_mainnet.md.71c4e1fb.lean.js => nodes_mainnet.md.91c04e4d.lean.js} (99%) rename pr-1680/assets/{nodes_mocha-testnet.md.21cdb959.js => nodes_mocha-testnet.md.aa2ae9c7.js} (98%) rename pr-1680/assets/{nodes_mocha-testnet.md.21cdb959.lean.js => nodes_mocha-testnet.md.aa2ae9c7.lean.js} (88%) rename pr-1680/assets/{nodes_overview.md.4fff23da.js => nodes_overview.md.1b940623.js} (98%) rename pr-1680/assets/{nodes_overview.md.4fff23da.lean.js => nodes_overview.md.1b940623.lean.js} (91%) rename pr-1680/assets/{nodes_participate.md.be133e40.js => nodes_participate.md.44f9ae13.js} (92%) rename pr-1680/assets/{nodes_participate.md.be133e40.lean.js => nodes_participate.md.44f9ae13.lean.js} (61%) rename pr-1680/assets/{nodes_quick-start.md.87f87708.js => nodes_quick-start.md.4fe562f2.js} (97%) rename pr-1680/assets/{nodes_quick-start.md.87f87708.lean.js => nodes_quick-start.md.4fe562f2.lean.js} (90%) rename pr-1680/assets/{nodes_systemd.md.0a76c2e7.js => nodes_systemd.md.10732002.js} (99%) rename pr-1680/assets/{nodes_systemd.md.0a76c2e7.lean.js => nodes_systemd.md.10732002.lean.js} (91%) rename pr-1680/assets/{nodes_validator-node.md.6d429357.js => nodes_validator-node.md.56905fa6.js} (68%) rename pr-1680/assets/{nodes_validator-node.md.6d429357.lean.js => nodes_validator-node.md.56905fa6.lean.js} (78%) create mode 100644 pr-1680/developers/blobstreamx.html create mode 100644 pr-1680/developers/multiaccounts.html diff --git a/pr-1680/404.html b/pr-1680/404.html index 7ee79ed91b..cd67d24655 100644 --- a/pr-1680/404.html +++ b/pr-1680/404.html @@ -7,7 +7,7 @@ - + @@ -35,7 +35,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-1680/README.html b/pr-1680/README.html index 0617bab9bb..53825ecd0e 100644 --- a/pr-1680/README.html +++ b/pr-1680/README.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

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.
  • /developers: A category with tutorials and guides for deploying rollups and interacting with Celestia nodes.
  • /nodes: Technical reference materials for all node types.
  • /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.

- +

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.
  • /developers: A category with tutorials and guides for deploying rollups and interacting with Celestia nodes.
  • /nodes: Technical reference materials for all node types.
  • /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-1680/assets/README.md.84351c9c.js b/pr-1680/assets/README.md.eba3dded.js similarity index 96% rename from pr-1680/assets/README.md.84351c9c.js rename to pr-1680/assets/README.md.eba3dded.js index fa677ca92d..60e5c2b1dd 100644 --- a/pr-1680/assets/README.md.84351c9c.js +++ b/pr-1680/assets/README.md.eba3dded.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Celestia Documentation Site | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1724867275000}'),o={name:"README.md"},n=i('

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.

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

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.

',16),s=[n];function r(l,c,u,d,p,h){return t(),a("div",null,s)}const y=e(o,[["render",r]]);export{g as __pageData,y as default}; diff --git a/pr-1680/assets/README.md.84351c9c.lean.js b/pr-1680/assets/README.md.eba3dded.lean.js similarity index 76% rename from pr-1680/assets/README.md.84351c9c.lean.js rename to pr-1680/assets/README.md.eba3dded.lean.js index c501296d9a..b6e2a51786 100644 --- a/pr-1680/assets/README.md.84351c9c.lean.js +++ b/pr-1680/assets/README.md.eba3dded.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Celestia Documentation Site | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1724867275000}'),o={name:"README.md"},n=i("",16),s=[n];function r(l,c,u,d,p,h){return t(),a("div",null,s)}const y=e(o,[["render",r]]);export{g as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia Documentation Site","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Celestia Documentation Site | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"README.md","filePath":"README.md","lastUpdated":1725955670000}'),o={name:"README.md"},n=i("",16),s=[n];function r(l,c,u,d,p,h){return t(),a("div",null,s)}const y=e(o,[["render",r]]);export{g as __pageData,y as default}; diff --git a/pr-1680/assets/app.2e777ca5.js b/pr-1680/assets/app.3a5d9d68.js similarity index 95% rename from pr-1680/assets/app.2e777ca5.js rename to pr-1680/assets/app.3a5d9d68.js index c387b5fda3..442704628b 100644 --- a/pr-1680/assets/app.2e777ca5.js +++ b/pr-1680/assets/app.3a5d9d68.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.a504a440.js";import{t as p}from"./chunks/theme.c177f54e.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.a504a440.js";import{t as p}from"./chunks/theme.cfd5f84b.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-1680/assets/chunks/@localSearchIndexroot.a2a5e800.js b/pr-1680/assets/chunks/@localSearchIndexroot.a2a5e800.js deleted file mode 100644 index f166ad5562..0000000000 --- a/pr-1680/assets/chunks/@localSearchIndexroot.a2a5e800.js +++ /dev/null @@ -1 +0,0 @@ -const e='{"documentCount":795,"nextId":795,"documentIds":{"0":"/docs-preview/pr-1680/README#celestia-documentation-site","1":"/docs-preview/pr-1680/README#building-the-site","2":"/docs-preview/pr-1680/README#contribution-guidelines","3":"/docs-preview/pr-1680/README#directory-structure","4":"/docs-preview/pr-1680/README#feedback-suggestions","5":"/docs-preview/pr-1680/community/calendar#community-calendar","6":"/docs-preview/pr-1680/community/coc#celestia-org-code-of-conduct","7":"/docs-preview/pr-1680/community/coc#our-pledge","8":"/docs-preview/pr-1680/community/coc#our-standards","9":"/docs-preview/pr-1680/community/coc#enforcement-responsibilities","10":"/docs-preview/pr-1680/community/coc#scope","11":"/docs-preview/pr-1680/community/coc#enforcement","12":"/docs-preview/pr-1680/community/coc#enforcement-guidelines","13":"/docs-preview/pr-1680/community/coc#_1-correction","14":"/docs-preview/pr-1680/community/coc#_2-warning","15":"/docs-preview/pr-1680/community/coc#_3-temporary-ban","16":"/docs-preview/pr-1680/community/coc#_4-permanent-ban","17":"/docs-preview/pr-1680/community/coc#attribution","18":"/docs-preview/pr-1680/community/foundation-delegation-program#the-celestia-foundation-delegation-program","19":"/docs-preview/pr-1680/community/foundation-delegation-program#objectives-of-the-program","20":"/docs-preview/pr-1680/community/foundation-delegation-program#foundation-delegation-process","21":"/docs-preview/pr-1680/community/foundation-delegation-program#program-launch","22":"/docs-preview/pr-1680/community/foundation-delegation-program#cohort-process","23":"/docs-preview/pr-1680/community/foundation-delegation-program#key-points","24":"/docs-preview/pr-1680/community/foundation-delegation-program#eligibility-criteria","25":"/docs-preview/pr-1680/community/foundation-delegation-program#undelegation-criteria","26":"/docs-preview/pr-1680/community/foundation-delegation-program#application","27":"/docs-preview/pr-1680/community/foundation-delegation-program#application-details","28":"/docs-preview/pr-1680/community/foundation-delegation-program#cohort-information","29":"/docs-preview/pr-1680/community/foundation-delegation-program#feedback-process","30":"/docs-preview/pr-1680/community/itn-tos#supplemental-incentivized-testnet-terms","31":"/docs-preview/pr-1680/community/itn-tos#_1-general-terms","32":"/docs-preview/pr-1680/community/itn-tos#_2-taxes","33":"/docs-preview/pr-1680/community/itn-tos#_3-supplemental-privacy-information","34":"/docs-preview/pr-1680/community/itn-tos#_4-certain-additional-representations","35":"/docs-preview/pr-1680/community/modular-meetup-guide#modular-meetup-guide","36":"/docs-preview/pr-1680/community/modular-meetup-guide#before-the-meetup","37":"/docs-preview/pr-1680/community/modular-meetup-guide#during-the-meetup","38":"/docs-preview/pr-1680/community/modular-meetup-guide#after-the-meetup","39":"/docs-preview/pr-1680/community/modular-meetup-guide#logistics-and-guidance","40":"/docs-preview/pr-1680/community/modular-meetup-guide#venue","41":"/docs-preview/pr-1680/community/modular-meetup-guide#catering-and-refreshments","42":"/docs-preview/pr-1680/community/modular-meetup-guide#audience","43":"/docs-preview/pr-1680/community/modular-meetup-guide#speakers","44":"/docs-preview/pr-1680/community/modular-meetup-guide#sponsors","45":"/docs-preview/pr-1680/community/modular-meetup-guide#communications-and-marketing","46":"/docs-preview/pr-1680/community/modular-meetup-guide#recording","47":"/docs-preview/pr-1680/community/modular-meetup-guide#utilizing-meetup-com-platform","48":"/docs-preview/pr-1680/community/modular-meetup-guide#onboarding-questions-for-community-members-joining-a-modular-meetup","49":"/docs-preview/pr-1680/community/modular-meetup-intro#celestia-modular-meetup-program","50":"/docs-preview/pr-1680/community/modular-meetup-intro#program-description","51":"/docs-preview/pr-1680/community/modular-meetup-intro#important-info","52":"/docs-preview/pr-1680/community/modular-meetup-intro#celestia-org-community-code-of-conduct","53":"/docs-preview/pr-1680/community/modular-meetup-intro#signup-form","54":"/docs-preview/pr-1680/community/modular-meetup-intro#emails","55":"/docs-preview/pr-1680/community/modular-meetup-intro#discord","56":"/docs-preview/pr-1680/community/modular-meetup-intro#materials","57":"/docs-preview/pr-1680/community/modular-meetup-toolkit#modular-meetup-toolkit","58":"/docs-preview/pr-1680/community/modular-meetup-toolkit#celestia-branding-guidelines","59":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-introduction-to-modularity-workshop-presentation","60":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-run-a-celestia-light-node-workshop-presentation","61":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-deploy-a-sovereign-rollup-workshop-presentation","62":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-modular-meetup-introduction-workshop-presentation","63":"/docs-preview/pr-1680/community/modular-meetup-toolkit#swag-logistics","64":"/docs-preview/pr-1680/community/overview#community-overview","65":"/docs-preview/pr-1680/community/speaker-list#speaker-list","66":"/docs-preview/pr-1680/developers/arbitrum-bridge#bridging-in-and-out-of-your-orbit-rollup","67":"/docs-preview/pr-1680/developers/arbitrum-bridge#bridge-in-deposit-to-your-rollup","68":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-1-add-your-custom-chain-config","69":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-2-deposit-to-your-orbit-rollup","70":"/docs-preview/pr-1680/developers/arbitrum-bridge#bridge-out-withdrawal-from-your-rollup","71":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-1-choose-an-amount-to-withdraw-from-your-rollup","72":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-2-claim-your-withdrawal","73":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#deploy-a-dapp-on-your-arbitrum-rollup-devnet","74":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#dependencies","75":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#setup-and-contract-deployment","76":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#interact-with-the-contract","77":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#update-the-frontend","78":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#interact-with-the-frontend","79":"/docs-preview/pr-1680/developers/arbitrum-deploy#quickstart-deploy-an-arbitrum-orbit-rollup","80":"/docs-preview/pr-1680/developers/arbitrum-deploy#prerequisites","81":"/docs-preview/pr-1680/developers/arbitrum-deploy#setup","82":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-1-acquire-arbitrum-sepolia-eth","83":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-2-pick-your-deployment-type","84":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-3-configure-your-orbit-chain-s-deployment","85":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-3-review-deploy-your-orbit-chain","86":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-4-download-your-chain-s-configuration-files-and-launch-your-chain","87":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-5-clone-the-setup-script-repository-and-add-your-configuration-files","88":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-6-pick-an-l2-rpc-url-for-the-batch-poster","89":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-7-run-your-light-node-for-mocha-testnet","90":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-8-run-your-chain-s-node-and-block-explorer","91":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-9-finish-setting-up-your-chain","92":"/docs-preview/pr-1680/developers/arbitrum-deploy#congratulations-with-celestia-underneath","93":"/docs-preview/pr-1680/developers/arbitrum-deploy#appendix","94":"/docs-preview/pr-1680/developers/arbitrum-deploy#compatibility-matrix","95":"/docs-preview/pr-1680/developers/arbitrum-deploy#blobstream-x-contract-deployments","96":"/docs-preview/pr-1680/developers/arbitrum-deploy#arbitrum-sepolia","97":"/docs-preview/pr-1680/developers/arbitrum-deploy#base-sepolia","98":"/docs-preview/pr-1680/developers/arbitrum-deploy#arbitrum-sepolia-additional-deployments","99":"/docs-preview/pr-1680/developers/arbitrum-deploy#base-sepolia-additional-deployments","100":"/docs-preview/pr-1680/developers/arbitrum-full-node#running-a-full-node-and-or-validator","101":"/docs-preview/pr-1680/developers/arbitrum-full-node#prerequisites","102":"/docs-preview/pr-1680/developers/arbitrum-full-node#running-a-full-node","103":"/docs-preview/pr-1680/developers/arbitrum-full-node#running-a-full-node-with-validation","104":"/docs-preview/pr-1680/developers/arbitrum-integration#introduction-to-arbitrum-rollups-with-celestia-as-da","105":"/docs-preview/pr-1680/developers/arbitrum-integration#overview","106":"/docs-preview/pr-1680/developers/arbitrum-integration#key-components","107":"/docs-preview/pr-1680/developers/arbitrum-integration#da-provider-implementation","108":"/docs-preview/pr-1680/developers/arbitrum-integration#preimage-oracle-implementation","109":"/docs-preview/pr-1680/developers/arbitrum-integration#blobstream-x-implementation","110":"/docs-preview/pr-1680/developers/arbitrum-integration#ethereum-fallback-mechanism-in-nitro","111":"/docs-preview/pr-1680/developers/arbitrum-integration#next-steps","112":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#deploy-a-smart-contract-to-your-arbitrum-rollup","113":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#overview","114":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#prerequisites","115":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#setup","116":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#create-your-smart-contract","117":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#test-your-smart-contract","118":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#deploying-your-smart-contract","119":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#funded-accounts","120":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#using-our-arbitrum-devnet","121":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#interacting-with-your-smart-contract","122":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#next-steps","123":"/docs-preview/pr-1680/developers/blobstream-contracts#integrate-with-blobstream-contracts","124":"/docs-preview/pr-1680/developers/blobstream-contracts#getting-started","125":"/docs-preview/pr-1680/developers/blobstream-contracts#prerequisites","126":"/docs-preview/pr-1680/developers/blobstream-contracts#installing-blobstream-x-contracts","127":"/docs-preview/pr-1680/developers/blobstream-contracts#example-usage","128":"/docs-preview/pr-1680/developers/blobstream-contracts#data-structures","129":"/docs-preview/pr-1680/developers/blobstream-contracts#interface","130":"/docs-preview/pr-1680/developers/blobstream-contracts#querying-the-proof","131":"/docs-preview/pr-1680/developers/blobstream-contracts#verifying-data-inclusion-for-fraud-proofs","132":"/docs-preview/pr-1680/developers/blobstream-offchain#integrate-with-blobstream-client","133":"/docs-preview/pr-1680/developers/blobstream-offchain#blobstream-demo-rollup","134":"/docs-preview/pr-1680/developers/blobstream-offchain#defining-a-chain","135":"/docs-preview/pr-1680/developers/blobstream-offchain#rollup-sequencer","136":"/docs-preview/pr-1680/developers/blobstream-offchain#committing-to-data","137":"/docs-preview/pr-1680/developers/blobstream-offchain#creating-blocks","138":"/docs-preview/pr-1680/developers/blobstream-offchain#rollup-full-node","139":"/docs-preview/pr-1680/developers/blobstream-offchain#downloading-the-block","140":"/docs-preview/pr-1680/developers/blobstream-offchain#more-documentation","141":"/docs-preview/pr-1680/developers/blobstream-offchain#proving-inclusion-via-blobstream","142":"/docs-preview/pr-1680/developers/blobstream-offchain#submitting-block-data-to-celestia-via-light-node","143":"/docs-preview/pr-1680/developers/blobstream-offchain#posting-headers-to-ethereum","144":"/docs-preview/pr-1680/developers/blobstream-proof-queries#blobstream-proofs-queries","145":"/docs-preview/pr-1680/developers/blobstream-proof-queries#prerequisites","146":"/docs-preview/pr-1680/developers/blobstream-proof-queries#overview-of-the-proof-queries","147":"/docs-preview/pr-1680/developers/blobstream-proof-queries#the-celestia-square","148":"/docs-preview/pr-1680/developers/blobstream-proof-queries#the-commitment-scheme","149":"/docs-preview/pr-1680/developers/blobstream-proof-queries#hands-on-demonstration","150":"/docs-preview/pr-1680/developers/blobstream-proof-queries#_1-data-root-inclusion-proof","151":"/docs-preview/pr-1680/developers/blobstream-proof-queries#http-query","152":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client","153":"/docs-preview/pr-1680/developers/blobstream-proof-queries#full-example-of-proving-that-a-celestia-block-was-committed-to-by-blobstream-x-contract","154":"/docs-preview/pr-1680/developers/blobstream-proof-queries#_2-transaction-inclusion-proof","155":"/docs-preview/pr-1680/developers/blobstream-proof-queries#transaction-inclusion-proof-using-the-transaction-hash","156":"/docs-preview/pr-1680/developers/blobstream-proof-queries#http-request","157":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client-1","158":"/docs-preview/pr-1680/developers/blobstream-proof-queries#blob-inclusion-proof-using-the-corresponding-pfb-transaction-hash","159":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client-2","160":"/docs-preview/pr-1680/developers/blobstream-proof-queries#specific-share-range-inclusion-proof","161":"/docs-preview/pr-1680/developers/blobstream-proof-queries#http-request-1","162":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client-3","163":"/docs-preview/pr-1680/developers/blobstream-proof-queries#converting-the-proofs-to-be-usable-in-the-daverifier-library","164":"/docs-preview/pr-1680/developers/blobstream-proof-queries#data","165":"/docs-preview/pr-1680/developers/blobstream-proof-queries#shareproofs","166":"/docs-preview/pr-1680/developers/blobstream-proof-queries#namespace","167":"/docs-preview/pr-1680/developers/blobstream-proof-queries#rowroots","168":"/docs-preview/pr-1680/developers/blobstream-proof-queries#rowproofs","169":"/docs-preview/pr-1680/developers/blobstream-proof-queries#attestationproof","170":"/docs-preview/pr-1680/developers/blobstream-proof-queries#querying-the-proof-s-tuplerootnonce","171":"/docs-preview/pr-1680/developers/blobstream-proof-queries#listening-for-new-data-commitments","172":"/docs-preview/pr-1680/developers/blobstream-proof-queries#example-rollup-that-uses-the-daverifier","173":"/docs-preview/pr-1680/developers/blobstream-proof-queries#conclusion","174":"/docs-preview/pr-1680/developers/blobstream-rollups#introduction-to-blobstream-rollups","175":"/docs-preview/pr-1680/developers/blobstream-rollups#concepts","176":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment","177":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-proof-details","178":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-compact-proofs","179":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-pros","180":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-cons","181":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans","182":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-proof-details","183":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-proving-unavailable-data","184":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-proving-inclusion-of-some-data","185":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-pros","186":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-cons","187":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups","188":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans","189":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-pros","190":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-cons","191":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-example","192":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments","193":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-pros","194":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-cons","195":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups","196":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-sequence-of-spans","197":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-pros","198":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-cons","199":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-blob-share-commitments","200":"/docs-preview/pr-1680/developers/blobstream-rollups#protobuf-deserialization-inside-a-zk-circuit","201":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-pros","202":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-cons","203":"/docs-preview/pr-1680/developers/blobstream-rollups#heavy-merkle-proofs-usage","204":"/docs-preview/pr-1680/developers/blobstream-rollups#heavy-merkle-proofs-usage-pros","205":"/docs-preview/pr-1680/developers/blobstream-rollups#heavy-merkle-proofs-usage-cons","206":"/docs-preview/pr-1680/developers/blobstream-rollups#conclusion","207":"/docs-preview/pr-1680/developers/blobstream-rollups#faq","208":"/docs-preview/pr-1680/developers/blobstream-rollups#should-i-use-the-celestia-transaction-hash-to-reference-the-rollup-data","209":"/docs-preview/pr-1680/developers/blobstream-x-deploy#new-blobstream-x-deployments","210":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploying-the-contracts","211":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploy-a-new-succinctgateway","212":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploy-the-function-verifiers","213":"/docs-preview/pr-1680/developers/blobstream-x-deploy#register-the-function-verifier-in-the-deployed-succinctgateway","214":"/docs-preview/pr-1680/developers/blobstream-x-deploy#enable-prover-whitelisting","215":"/docs-preview/pr-1680/developers/blobstream-x-deploy#set-whitelist-status","216":"/docs-preview/pr-1680/developers/blobstream-x-deploy#add-custom-prover","217":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploy-the-blobstreamx-contract","218":"/docs-preview/pr-1680/developers/blobstream-x-deploy#querying-the-trusted-hash","219":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deployment-instructions","220":"/docs-preview/pr-1680/developers/blobstream-x-deploy#run-a-local-prover","221":"/docs-preview/pr-1680/developers/blobstream-x-deploy#run-a-proof-replayer-from-an-existing-deployment","222":"/docs-preview/pr-1680/developers/blobstream-x-deploy#optional-regenerating-the-downloaded-artifacts","223":"/docs-preview/pr-1680/developers/blobstream-x-deploy#regenerate-the-verifier-build","224":"/docs-preview/pr-1680/developers/blobstream-x-deploy#build-the-circuits-and-function-verifiers","225":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#requesting-data-commitment-ranges","226":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#local-proving","227":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#request-proofs-from-the-succinct-platform","228":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#request-proofs-onchain","229":"/docs-preview/pr-1680/developers/blobstream#blobstream-streaming-modular-da-to-ethereum","230":"/docs-preview/pr-1680/developers/blobstream#what-is-blobstream","231":"/docs-preview/pr-1680/developers/blobstream#implementations-of-blobstream","232":"/docs-preview/pr-1680/developers/blobstream#blobstream-vs-data-availability-committees-dacs","233":"/docs-preview/pr-1680/developers/blobstream#decentralization-and-security","234":"/docs-preview/pr-1680/developers/blobstream#mechanism-of-verification","235":"/docs-preview/pr-1680/developers/blobstream#flexibility-and-scalability","236":"/docs-preview/pr-1680/developers/blobstream#what-is-sp1-blobstream","237":"/docs-preview/pr-1680/developers/blobstream#what-is-blobstream-x","238":"/docs-preview/pr-1680/developers/blobstream#integrate-with-blobstream-x","239":"/docs-preview/pr-1680/developers/blobstream#how-blobstream-x-works","240":"/docs-preview/pr-1680/developers/blobstream#how-to-integrate-with-blobstream-x","241":"/docs-preview/pr-1680/developers/blobstream#blobstream-rollups","242":"/docs-preview/pr-1680/developers/blobstream#deployed-contracts","243":"/docs-preview/pr-1680/developers/blobstream#deploy-blobstream-x","244":"/docs-preview/pr-1680/developers/bubs-testnet#bubs-testnet","245":"/docs-preview/pr-1680/developers/bubs-testnet#built-with-the-op-stack-and-celestia","246":"/docs-preview/pr-1680/developers/bubs-testnet#building-on-bubs","247":"/docs-preview/pr-1680/developers/bubs-testnet#rpc-urls","248":"/docs-preview/pr-1680/developers/bubs-testnet#https","249":"/docs-preview/pr-1680/developers/bubs-testnet#wss","250":"/docs-preview/pr-1680/developers/bubs-testnet#bridge","251":"/docs-preview/pr-1680/developers/bubs-testnet#faucet","252":"/docs-preview/pr-1680/developers/bubs-testnet#explorer","253":"/docs-preview/pr-1680/developers/bubs-testnet#status","254":"/docs-preview/pr-1680/developers/bubs-testnet#next-steps","255":"/docs-preview/pr-1680/developers/build-whatever#build-whatever","256":"/docs-preview/pr-1680/developers/build-whatever#quickstart-building-on-celestia","257":"/docs-preview/pr-1680/developers/build-whatever#choose-a-framework","258":"/docs-preview/pr-1680/developers/build-whatever#rollups-as-a-service","259":"/docs-preview/pr-1680/developers/build-whatever#smart-contracts","260":"/docs-preview/pr-1680/developers/build-whatever#what-is-a-rollup","261":"/docs-preview/pr-1680/developers/build-whatever#what-is-a-modular-blockchain","262":"/docs-preview/pr-1680/developers/build-whatever#benefits-of-modular-blockchains","263":"/docs-preview/pr-1680/developers/build-whatever#ease-of-deploying-a-chain","264":"/docs-preview/pr-1680/developers/build-whatever#scaling","265":"/docs-preview/pr-1680/developers/build-whatever#customizability","266":"/docs-preview/pr-1680/developers/celestia-node-key#create-a-wallet-with-celestia-node","267":"/docs-preview/pr-1680/developers/celestia-node-key#using-the-cel-key-utility","268":"/docs-preview/pr-1680/developers/celestia-node-key#installation","269":"/docs-preview/pr-1680/developers/celestia-node-key#steps-for-generating-node-keys","270":"/docs-preview/pr-1680/developers/celestia-node-key#steps-for-exporting-node-keys","271":"/docs-preview/pr-1680/developers/celestia-node-key#steps-for-importing-node-keys","272":"/docs-preview/pr-1680/developers/celestia-node-key#view-all-options-for-cel-key","273":"/docs-preview/pr-1680/developers/celestia-node-key#docker-and-cel-key","274":"/docs-preview/pr-1680/developers/celestia-node-key#prerequisites","275":"/docs-preview/pr-1680/developers/celestia-node-key#running-your-node","276":"/docs-preview/pr-1680/developers/celestia-node-key#mounting-existing-keys-to-container","277":"/docs-preview/pr-1680/developers/deploy-on-bubs#deploy-a-smart-contract-on-bubs-testnet","278":"/docs-preview/pr-1680/developers/deploy-on-bubs#dependencies","279":"/docs-preview/pr-1680/developers/deploy-on-bubs#setup","280":"/docs-preview/pr-1680/developers/deploy-on-bubs#create-your-smart-contract","281":"/docs-preview/pr-1680/developers/deploy-on-bubs#test-your-smart-contract","282":"/docs-preview/pr-1680/developers/deploy-on-bubs#deploying-your-smart-contract","283":"/docs-preview/pr-1680/developers/deploy-on-bubs#using-anvil","284":"/docs-preview/pr-1680/developers/deploy-on-bubs#using-bubs","285":"/docs-preview/pr-1680/developers/deploy-on-bubs#interacting-with-your-smart-contract","286":"/docs-preview/pr-1680/developers/deploy-on-bubs#next-steps","287":"/docs-preview/pr-1680/developers/ethereum-fallback#ethereum-fallback","288":"/docs-preview/pr-1680/developers/feegrant-for-blobs#feegrant-module-for-blobs-submission","289":"/docs-preview/pr-1680/developers/feegrant-for-blobs#overview","290":"/docs-preview/pr-1680/developers/feegrant-for-blobs#pre-requisites","291":"/docs-preview/pr-1680/developers/feegrant-for-blobs#introduction","292":"/docs-preview/pr-1680/developers/feegrant-for-blobs#granting-fee-allowances-using-celestia-node","293":"/docs-preview/pr-1680/developers/feegrant-for-blobs#feegrant-module-implementation-in-celestia-node","294":"/docs-preview/pr-1680/developers/feegrant-for-blobs#grant-permission-for-an-allowance-as-a-granter","295":"/docs-preview/pr-1680/developers/feegrant-for-blobs#using-a-feegrant-allowance-as-a-grantee-in-celestia-node","296":"/docs-preview/pr-1680/developers/feegrant-for-blobs#checking-account-balances-after-submission","297":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-revoke-permission-for-a-feegrant-allowance-as-a-granter","298":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-submitting-a-blob-from-file-input","299":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-granting-fee-allowances-using-celestia-appd","300":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-checking-the-granter-s-account","301":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#full-stack-modular-blockchain-development-guide","302":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#getting-started","303":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#pre-requisites","304":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#project-setup","305":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#updating-the-contract-and-tests","306":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#running-the-test","307":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#updating-the-deployment-script","308":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#deploying-locally","309":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#deploying-to-the-ethermint-sovereign-rollup","310":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#building-the-frontend","311":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#configuring-environment-variables","312":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#configuring-the-entrypoint","313":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#creating-and-reading-posts","314":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#adding-ethermint-chain-to-metamask","315":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#testing-it-out-on-ethermint","316":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#now-give-it-a-spin-🌀","317":"/docs-preview/pr-1680/developers/gm-portal-bubs#deploying-a-dapp-on-bubs-testnet","318":"/docs-preview/pr-1680/developers/gm-portal-bubs#update-the-frontend","319":"/docs-preview/pr-1680/developers/gm-portal-bubs#interact-with-the-frontend","320":"/docs-preview/pr-1680/developers/gm-portal-bubs#next-steps","321":"/docs-preview/pr-1680/developers/golang-client-tutorial#golang-client-library","322":"/docs-preview/pr-1680/developers/golang-client-tutorial#project-setup","323":"/docs-preview/pr-1680/developers/golang-client-tutorial#submitting-and-retrieving-blobs","324":"/docs-preview/pr-1680/developers/golang-client-tutorial#subscribing-to-new-blobs","325":"/docs-preview/pr-1680/developers/golang-client-tutorial#subscribing-to-new-headers","326":"/docs-preview/pr-1680/developers/golang-client-tutorial#fetching-an-extended-data-square-eds","327":"/docs-preview/pr-1680/developers/golang-client-tutorial#api-documentation","328":"/docs-preview/pr-1680/developers/integrate-celestia#integrate-celestia-for-service-providers","329":"/docs-preview/pr-1680/developers/integrate-celestia#getting-started","330":"/docs-preview/pr-1680/developers/integrate-celestia#celestia-service-provider-notes","331":"/docs-preview/pr-1680/developers/integrate-celestia#custody-and-key-management","332":"/docs-preview/pr-1680/developers/integrate-celestia#rpc-and-querying","333":"/docs-preview/pr-1680/developers/integrate-celestia#compatibility","334":"/docs-preview/pr-1680/developers/integrate-celestia#syncing","335":"/docs-preview/pr-1680/developers/integrate-celestia#notable-exceptions-relative-to-other-blockchains","336":"/docs-preview/pr-1680/developers/intro-to-op-stack#introduction-to-op-stack-integration","337":"/docs-preview/pr-1680/developers/intro-to-op-stack#about-the-integration","338":"/docs-preview/pr-1680/developers/intro-to-op-stack#github-repository","339":"/docs-preview/pr-1680/developers/intro-to-op-stack#category-contents","340":"/docs-preview/pr-1680/developers/intro-to-op-stack#next-steps","341":"/docs-preview/pr-1680/developers/node-api#node-api","342":"/docs-preview/pr-1680/developers/node-api#rpc-api","343":"/docs-preview/pr-1680/developers/node-api#library","344":"/docs-preview/pr-1680/developers/node-api#rpc","345":"/docs-preview/pr-1680/developers/node-api#rpc-api-tutorial","346":"/docs-preview/pr-1680/developers/node-api#gateway-api","347":"/docs-preview/pr-1680/developers/node-api#gateway-api-tutorial","348":"/docs-preview/pr-1680/developers/node-tutorial#celestia-node-rpc-cli-tutorial","349":"/docs-preview/pr-1680/developers/node-tutorial#introduction","350":"/docs-preview/pr-1680/developers/node-tutorial#blobs","351":"/docs-preview/pr-1680/developers/node-tutorial#namespaces","352":"/docs-preview/pr-1680/developers/node-tutorial#hardware-requirements","353":"/docs-preview/pr-1680/developers/node-tutorial#setting-up-dependencies","354":"/docs-preview/pr-1680/developers/node-tutorial#instantiate-a-celestia-light-node","355":"/docs-preview/pr-1680/developers/node-tutorial#connect-to-a-core-endpoint","356":"/docs-preview/pr-1680/developers/node-tutorial#keys-and-wallets","357":"/docs-preview/pr-1680/developers/node-tutorial#rpc-cli-guide","358":"/docs-preview/pr-1680/developers/node-tutorial#command-formatting","359":"/docs-preview/pr-1680/developers/node-tutorial#basic-flags","360":"/docs-preview/pr-1680/developers/node-tutorial#auth-token","361":"/docs-preview/pr-1680/developers/node-tutorial#node-store","362":"/docs-preview/pr-1680/developers/node-tutorial#auth-token-on-custom-or-private-network","363":"/docs-preview/pr-1680/developers/node-tutorial#submitting-data","364":"/docs-preview/pr-1680/developers/node-tutorial#optional-submit-with-curl","365":"/docs-preview/pr-1680/developers/node-tutorial#retrieving-data","366":"/docs-preview/pr-1680/developers/node-tutorial#setting-the-gas-price","367":"/docs-preview/pr-1680/developers/node-tutorial#examples","368":"/docs-preview/pr-1680/developers/node-tutorial#check-your-balance","369":"/docs-preview/pr-1680/developers/node-tutorial#check-the-balance-of-another-address","370":"/docs-preview/pr-1680/developers/node-tutorial#get-your-node-id","371":"/docs-preview/pr-1680/developers/node-tutorial#get-your-account-address","372":"/docs-preview/pr-1680/developers/node-tutorial#get-block-header-by-height","373":"/docs-preview/pr-1680/developers/node-tutorial#combined-commands","374":"/docs-preview/pr-1680/developers/node-tutorial#get-data-availability-sampler-stats","375":"/docs-preview/pr-1680/developers/node-tutorial#transfer-balance-of-utia-to-another-account","376":"/docs-preview/pr-1680/developers/node-tutorial#api-version","377":"/docs-preview/pr-1680/developers/node-tutorial#help","378":"/docs-preview/pr-1680/developers/node-tutorial#advanced-example","379":"/docs-preview/pr-1680/developers/node-tutorial#additional-resources","380":"/docs-preview/pr-1680/developers/node-tutorial#submitting-a-blob-using-curl","381":"/docs-preview/pr-1680/developers/node-tutorial#post-an-svg-as-a-pfb","382":"/docs-preview/pr-1680/developers/node-tutorial#troubleshooting","383":"/docs-preview/pr-1680/developers/optimism-devnet#optimism-devnet-deep-dive","384":"/docs-preview/pr-1680/developers/optimism-devnet#find-a-transaction","385":"/docs-preview/pr-1680/developers/optimism-devnet#read-the-transaction-call-data","386":"/docs-preview/pr-1680/developers/optimism-devnet#find-the-data-on-celestia","387":"/docs-preview/pr-1680/developers/optimism-devnet#span-batches","388":"/docs-preview/pr-1680/developers/optimism#run-an-op-stack-rollup-with-celestia-underneath","389":"/docs-preview/pr-1680/developers/optimism#dependency-setup","390":"/docs-preview/pr-1680/developers/optimism#setting-up-your-light-node","391":"/docs-preview/pr-1680/developers/optimism#deploying-a-devnet-to-mocha","392":"/docs-preview/pr-1680/developers/optimism#deploying-a-testnet-to-an-l1-or-l2-and-mocha","393":"/docs-preview/pr-1680/developers/optimism#congratulations","394":"/docs-preview/pr-1680/developers/prompt-scavenger#prompt-scavenger","395":"/docs-preview/pr-1680/developers/prompt-scavenger#dependencies","396":"/docs-preview/pr-1680/developers/prompt-scavenger#install-celestia-node-and-run-a-light-node","397":"/docs-preview/pr-1680/developers/prompt-scavenger#openai-key","398":"/docs-preview/pr-1680/developers/prompt-scavenger#building-the-prompt-scavenger","399":"/docs-preview/pr-1680/developers/prompt-scavenger#initialize-your-go-project","400":"/docs-preview/pr-1680/developers/prompt-scavenger#build-your-import-statements","401":"/docs-preview/pr-1680/developers/prompt-scavenger#main-function","402":"/docs-preview/pr-1680/developers/prompt-scavenger#utility-functions","403":"/docs-preview/pr-1680/developers/prompt-scavenger#prompting-chatgpt","404":"/docs-preview/pr-1680/developers/prompt-scavenger#wrapping-things-up","405":"/docs-preview/pr-1680/developers/prompt-scavenger#next-steps","406":"/docs-preview/pr-1680/developers/rust-client-tutorial#rust-client-library","407":"/docs-preview/pr-1680/developers/rust-client-tutorial#project-setup","408":"/docs-preview/pr-1680/developers/rust-client-tutorial#submitting-and-retrieving-blobs","409":"/docs-preview/pr-1680/developers/rust-client-tutorial#subscribing-to-new-headers","410":"/docs-preview/pr-1680/developers/rust-client-tutorial#fetching-an-extended-data-square-eds","411":"/docs-preview/pr-1680/developers/rust-client-tutorial#api-documentation","412":"/docs-preview/pr-1680/developers/sp1-blobstream-deploy#new-sp1-blobstream-deployments","413":"/docs-preview/pr-1680/developers/sp1-blobstream-deploy#deploying-the-contracts","414":"/docs-preview/pr-1680/developers/submit-data#submitting-data-blobs-to-celestia","415":"/docs-preview/pr-1680/developers/submit-data#maximum-blob-size","416":"/docs-preview/pr-1680/developers/submit-data#fee-market-and-mempool","417":"/docs-preview/pr-1680/developers/submit-data#fees-and-gas-limits","418":"/docs-preview/pr-1680/developers/submit-data#estimating-pfb-gas","419":"/docs-preview/pr-1680/developers/submit-data#gas-fee-calculation","420":"/docs-preview/pr-1680/developers/submit-data#estimating-gas-programmatically","421":"/docs-preview/pr-1680/developers/submit-data#submitting-multiple-transactions-in-one-block-from-the-same-account","422":"/docs-preview/pr-1680/developers/submit-data#api","423":"/docs-preview/pr-1680/developers/submit-data#the-celestia-app-consensus-node-cli","424":"/docs-preview/pr-1680/developers/submit-data#the-celestia-node-light-node-cli","425":"/docs-preview/pr-1680/developers/submit-data#the-celestia-node-api-golang-client","426":"/docs-preview/pr-1680/developers/submit-data#grpc-to-a-consensus-node-via-the-user-package","427":"/docs-preview/pr-1680/developers/submit-data#rpc-to-a-celestia-node","428":"/docs-preview/pr-1680/developers/transaction-resubmission#transaction-resubmission","429":"/docs-preview/pr-1680/developers/transaction-resubmission#monitoring-and-resubmission","430":"/docs-preview/pr-1680/developers/transaction-resubmission#notes","431":"/docs-preview/pr-1680/developers/wallets#wallet-integrations-with-celestia","432":"/docs-preview/pr-1680/developers/wallets#add-celestia-network-parameters-to-keplr-with-react","433":"/docs-preview/pr-1680/developers/wallets#adding-a-custom-chain-to-leap","434":"/docs-preview/pr-1680/developers/wallets#adding-a-custom-chain-to-cosmostation","435":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#data-availability-faq","436":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-data-availability","437":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-the-data-availability-problem","438":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#how-do-nodes-verify-data-availability-in-celestia","439":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-data-availability-sampling","440":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-are-some-of-the-security-assumptions-that-celestia-makes-for-data-availability-sampling","441":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#why-is-block-reconstruction-necessary-for-security","442":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-data-storage","443":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-the-problem-around-data-storage","444":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-the-difference-between-data-availability-and-data-storage","445":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#where-does-blockchain-state-fit-into-this","446":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#why-doesn-t-celestia-incentivize-storage-of-historical-data","447":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#who-may-store-historical-data-if-there-is-no-reward","448":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-are-some-things-blockchains-can-do-to-provide-stronger-assurances-of-data-retrievability","449":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#celestia-s-data-availability-layer","450":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#data-availability-sampling-das","451":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#scalability","452":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#fraud-proofs-of-incorrectly-extended-data","453":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#namespaced-merkle-trees-nmts","454":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#building-a-pos-blockchain-for-da","455":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#providing-data-availability","456":"/docs-preview/pr-1680/learn/how-celestia-works/monolithic-vs-modular#monolithic-vs-modular-blockchains","457":"/docs-preview/pr-1680/learn/how-celestia-works/overview#introduction","458":"/docs-preview/pr-1680/learn/how-celestia-works/transaction-lifecycle#the-lifecycle-of-a-celestia-app-transaction","459":"/docs-preview/pr-1680/learn/how-celestia-works/transaction-lifecycle#checking-data-availability","460":"/docs-preview/pr-1680/learn/how-to-stake-tia#how-to-stake-tia","461":"/docs-preview/pr-1680/learn/how-to-stake-tia#select-your-preferred-wallet","462":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-tia-with-keplr-wallet","463":"/docs-preview/pr-1680/learn/how-to-stake-tia#open-your-keplr-browser-extension","464":"/docs-preview/pr-1680/learn/how-to-stake-tia#select-celestia-network-and-search-for-a-validator","465":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-your-tia-tokens","466":"/docs-preview/pr-1680/learn/how-to-stake-tia#confirm-and-manage-your-tia","467":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-tia-with-leap-wallet","468":"/docs-preview/pr-1680/learn/how-to-stake-tia#open-your-leap-browser-extension","469":"/docs-preview/pr-1680/learn/how-to-stake-tia#select-a-validator-and-stake-tia","470":"/docs-preview/pr-1680/learn/how-to-stake-tia#confirm-and-manage-your-tia-1","471":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-tia-with-gem-wallet","472":"/docs-preview/pr-1680/learn/how-to-stake-tia#open-your-gem-wallet-app","473":"/docs-preview/pr-1680/learn/how-to-stake-tia#choose-the-amount-of-celestia-and-search-for-a-validator","474":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-your-tia-tokens-1","475":"/docs-preview/pr-1680/learn/how-to-stake-tia#manage-your-tia","476":"/docs-preview/pr-1680/learn/paying-for-blobspace#paying-for-blobspace","477":"/docs-preview/pr-1680/learn/paying-for-blobspace#payforblobs-transactions","478":"/docs-preview/pr-1680/learn/paying-for-blobspace#fee-market-overview","479":"/docs-preview/pr-1680/learn/retrievability#data-retrievability-and-pruning","480":"/docs-preview/pr-1680/learn/retrievability#data-retrievability-and-pruning-in-celestia-node","481":"/docs-preview/pr-1680/learn/retrievability#suggested-practices-for-rollups","482":"/docs-preview/pr-1680/learn/staking-governance-supply#staking-governance-supply","483":"/docs-preview/pr-1680/learn/staking-governance-supply#proof-of-stake-on-celestia","484":"/docs-preview/pr-1680/learn/staking-governance-supply#inflation","485":"/docs-preview/pr-1680/learn/staking-governance-supply#decentralised-governance","486":"/docs-preview/pr-1680/learn/staking-governance-supply#network-parameters","487":"/docs-preview/pr-1680/learn/staking-governance-supply#community-pool","488":"/docs-preview/pr-1680/learn/staking-governance-supply#tia-allocation-at-genesis","489":"/docs-preview/pr-1680/learn/staking-governance-supply#unlocks","490":"/docs-preview/pr-1680/learn/staking#staking-on-celestia","491":"/docs-preview/pr-1680/learn/staking#mainnet-beta","492":"/docs-preview/pr-1680/learn/staking#mocha-testnet","493":"/docs-preview/pr-1680/learn/tia#overview-of-tia","494":"/docs-preview/pr-1680/learn/tia#tia-at-a-glance","495":"/docs-preview/pr-1680/learn/tia#role-of-tia","496":"/docs-preview/pr-1680/learn/tia#paying-for-blobspace","497":"/docs-preview/pr-1680/learn/tia#bootstrapping-new-rollups","498":"/docs-preview/pr-1680/learn/tia#proof-of-stake","499":"/docs-preview/pr-1680/learn/tia#decentralised-governance","500":"/docs-preview/pr-1680/learn/tia#denominations","501":"/docs-preview/pr-1680/learn/tia#tia-display-token","502":"/docs-preview/pr-1680/learn/tia#utia-staking-denomination","503":"/docs-preview/pr-1680/learn/tia#microtia-staking-denomination-alias","504":"/docs-preview/pr-1680/nodes/arabica-devnet#arabica-devnet","505":"/docs-preview/pr-1680/nodes/arabica-devnet#network-stability-and-upgrades","506":"/docs-preview/pr-1680/nodes/arabica-devnet#network-details","507":"/docs-preview/pr-1680/nodes/arabica-devnet#software-version-numbers","508":"/docs-preview/pr-1680/nodes/arabica-devnet#integrations","509":"/docs-preview/pr-1680/nodes/arabica-devnet#production-rpc-endpoints","510":"/docs-preview/pr-1680/nodes/arabica-devnet#community-rpc-endpoints","511":"/docs-preview/pr-1680/nodes/arabica-devnet#using-consensus-endpoints-with-da-nodes","512":"/docs-preview/pr-1680/nodes/arabica-devnet#data-availability-da-rpc-endpoints-for-bridge-node-sync","513":"/docs-preview/pr-1680/nodes/arabica-devnet#data-availability-da-grpc-endpoints-for-state-access","514":"/docs-preview/pr-1680/nodes/arabica-devnet#arabica-devnet-faucet","515":"/docs-preview/pr-1680/nodes/arabica-devnet#discord","516":"/docs-preview/pr-1680/nodes/arabica-devnet#web","517":"/docs-preview/pr-1680/nodes/arabica-devnet#explorers","518":"/docs-preview/pr-1680/nodes/arabica-devnet#network-upgrades","519":"/docs-preview/pr-1680/nodes/bridge-node#setting-up-a-celestia-bridge-node","520":"/docs-preview/pr-1680/nodes/bridge-node#overview-of-bridge-nodes","521":"/docs-preview/pr-1680/nodes/bridge-node#hardware-requirements","522":"/docs-preview/pr-1680/nodes/bridge-node#setting-up-your-bridge-node","523":"/docs-preview/pr-1680/nodes/bridge-node#setup-the-dependencies","524":"/docs-preview/pr-1680/nodes/bridge-node#deploy-the-celestia-bridge-node","525":"/docs-preview/pr-1680/nodes/bridge-node#install-celestia-node","526":"/docs-preview/pr-1680/nodes/bridge-node#initialize-the-bridge-node","527":"/docs-preview/pr-1680/nodes/bridge-node#run-the-bridge-node","528":"/docs-preview/pr-1680/nodes/bridge-node#optional-run-the-bridge-node-with-a-custom-key","529":"/docs-preview/pr-1680/nodes/bridge-node#optional-start-the-bridge-node-with-systemd","530":"/docs-preview/pr-1680/nodes/celestia-app-commands#helpful-cli-commands","531":"/docs-preview/pr-1680/nodes/celestia-app-commands#creating-a-wallet","532":"/docs-preview/pr-1680/nodes/celestia-app-commands#key-management","533":"/docs-preview/pr-1680/nodes/celestia-app-commands#importing-and-exporting-keys","534":"/docs-preview/pr-1680/nodes/celestia-app-commands#querying-subcommands","535":"/docs-preview/pr-1680/nodes/celestia-app-commands#token-management","536":"/docs-preview/pr-1680/nodes/celestia-app-commands#governance","537":"/docs-preview/pr-1680/nodes/celestia-app-commands#community-pool","538":"/docs-preview/pr-1680/nodes/celestia-app-commands#claim-validator-rewards","539":"/docs-preview/pr-1680/nodes/celestia-app-commands#delegate-undelegate-tokens","540":"/docs-preview/pr-1680/nodes/celestia-app-commands#unjailing-the-validator","541":"/docs-preview/pr-1680/nodes/celestia-app-commands#how-to-export-logs-with-systemd","542":"/docs-preview/pr-1680/nodes/celestia-app-commands#signing-genesis-for-a-new-network","543":"/docs-preview/pr-1680/nodes/celestia-app-metrics#metrics","544":"/docs-preview/pr-1680/nodes/celestia-app-metrics#setup","545":"/docs-preview/pr-1680/nodes/celestia-app-metrics#visualization","546":"/docs-preview/pr-1680/nodes/celestia-app-metrics#node-exporter","547":"/docs-preview/pr-1680/nodes/celestia-app-metrics#alerts","548":"/docs-preview/pr-1680/nodes/celestia-app-multisig#multisig","549":"/docs-preview/pr-1680/nodes/celestia-app-multisig#command-line","550":"/docs-preview/pr-1680/nodes/celestia-app-multisig#resources","551":"/docs-preview/pr-1680/nodes/celestia-app-slashing#jailing-and-slashing-on-celestia","552":"/docs-preview/pr-1680/nodes/celestia-app-upgrade-monitor#upgrade-monitor","553":"/docs-preview/pr-1680/nodes/celestia-app-vesting#how-to-create-a-vesting-account-with-celestia-app","554":"/docs-preview/pr-1680/nodes/celestia-app-vesting#local-devnet","555":"/docs-preview/pr-1680/nodes/celestia-app-vesting#setting-up-the-local-devnet","556":"/docs-preview/pr-1680/nodes/celestia-app-vesting#run-the-devnet","557":"/docs-preview/pr-1680/nodes/celestia-app-vesting#save-the-home-directory-path","558":"/docs-preview/pr-1680/nodes/celestia-app-vesting#check-the-version-of-the-devnet","559":"/docs-preview/pr-1680/nodes/celestia-app-vesting#next-steps","560":"/docs-preview/pr-1680/nodes/celestia-app-vesting#setting-up-vesting-account-on-devnet","561":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-a-new-key","562":"/docs-preview/pr-1680/nodes/celestia-app-vesting#list-your-keys","563":"/docs-preview/pr-1680/nodes/celestia-app-vesting#set-variables","564":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-your-devnet-vesting-account","565":"/docs-preview/pr-1680/nodes/celestia-app-vesting#query-the-devnet-vesting-account-details","566":"/docs-preview/pr-1680/nodes/celestia-app-vesting#query-the-devnet-base-account-details","567":"/docs-preview/pr-1680/nodes/celestia-app-vesting#query-the-balances-of-the-devnet-accounts","568":"/docs-preview/pr-1680/nodes/celestia-app-vesting#mocha","569":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-a-wallet","570":"/docs-preview/pr-1680/nodes/celestia-app-vesting#fund-your-account","571":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-a-vesting-account-on-mocha","572":"/docs-preview/pr-1680/nodes/celestia-app-vesting#optional-set-up-a-consensus-node-or-validator","573":"/docs-preview/pr-1680/nodes/celestia-app-vesting#optional-change-your-client-toml","574":"/docs-preview/pr-1680/nodes/celestia-app-vesting#notes","575":"/docs-preview/pr-1680/nodes/celestia-app-vesting#conclusion","576":"/docs-preview/pr-1680/nodes/celestia-app-wallet#create-a-wallet-with-celestia-app","577":"/docs-preview/pr-1680/nodes/celestia-app-wallet#prerequisites","578":"/docs-preview/pr-1680/nodes/celestia-app-wallet#create-a-wallet","579":"/docs-preview/pr-1680/nodes/celestia-app-wallet#fund-a-wallet","580":"/docs-preview/pr-1680/nodes/celestia-app#install-celestia-app","581":"/docs-preview/pr-1680/nodes/celestia-app#building-binary-from-source","582":"/docs-preview/pr-1680/nodes/celestia-app#installing-a-pre-built-binary","583":"/docs-preview/pr-1680/nodes/celestia-app#ports","584":"/docs-preview/pr-1680/nodes/celestia-node-custom-networks#custom-networks-and-values","585":"/docs-preview/pr-1680/nodes/celestia-node-metrics#celestia-node-metrics","586":"/docs-preview/pr-1680/nodes/celestia-node-metrics#running-metrics-flags","587":"/docs-preview/pr-1680/nodes/celestia-node-metrics#mainnet-beta","588":"/docs-preview/pr-1680/nodes/celestia-node-metrics#mocha-testnet","589":"/docs-preview/pr-1680/nodes/celestia-node-metrics#tls-connections","590":"/docs-preview/pr-1680/nodes/celestia-node-metrics#metrics-endpoint-design-considerations","591":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#troubleshooting","592":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#network-selection","593":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#chain-id","594":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#ports","595":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#changing-the-location-of-your-node-store","596":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#background","597":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#demonstration","598":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#examples","599":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#mainnet-beta-full-and-mocha-light","600":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#mocha-full-and-arabica-light","601":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#using-a-custom-rpc-config-address","602":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#resetting-your-config","603":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#clearing-the-data-store","604":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#fatal-headers-given-to-the-heightsub-are-in-the-wrong-order","605":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#error-too-many-open-files","606":"/docs-preview/pr-1680/nodes/celestia-node-trusted-hash#syncing-a-light-node-from-a-trusted-hash","607":"/docs-preview/pr-1680/nodes/celestia-node-trusted-hash#for-service-operators","608":"/docs-preview/pr-1680/nodes/celestia-node#install-celestia-node","609":"/docs-preview/pr-1680/nodes/celestia-node#installing-from-source","610":"/docs-preview/pr-1680/nodes/celestia-node#installing-a-pre-built-binary","611":"/docs-preview/pr-1680/nodes/celestia-node#next-steps","612":"/docs-preview/pr-1680/nodes/celestia-node#upgrading-your-binary","613":"/docs-preview/pr-1680/nodes/config-toml#config-toml-guide","614":"/docs-preview/pr-1680/nodes/config-toml#pre-requisites","615":"/docs-preview/pr-1680/nodes/config-toml#understanding-config-toml","616":"/docs-preview/pr-1680/nodes/config-toml#core","617":"/docs-preview/pr-1680/nodes/config-toml#p2p","618":"/docs-preview/pr-1680/nodes/config-toml#bootstrap","619":"/docs-preview/pr-1680/nodes/config-toml#mutual-peers","620":"/docs-preview/pr-1680/nodes/config-toml#services","621":"/docs-preview/pr-1680/nodes/config-toml#trustedhash-and-trustedpeer","622":"/docs-preview/pr-1680/nodes/consensus-node#consensus-node","623":"/docs-preview/pr-1680/nodes/consensus-node#minimum-hardware-requirements","624":"/docs-preview/pr-1680/nodes/consensus-node#set-up-a-consensus-node","625":"/docs-preview/pr-1680/nodes/consensus-node#set-up-the-dependencies","626":"/docs-preview/pr-1680/nodes/consensus-node#install-celestia-app","627":"/docs-preview/pr-1680/nodes/consensus-node#set-up-the-p2p-networks","628":"/docs-preview/pr-1680/nodes/consensus-node#storage-and-pruning-configurations","629":"/docs-preview/pr-1680/nodes/consensus-node#optional-connect-a-consensus-node-to-a-bridge-node","630":"/docs-preview/pr-1680/nodes/consensus-node#enable-transaction-indexing","631":"/docs-preview/pr-1680/nodes/consensus-node#retain-all-block-data","632":"/docs-preview/pr-1680/nodes/consensus-node#query-transactions-by-hash","633":"/docs-preview/pr-1680/nodes/consensus-node#optional-access-historical-state","634":"/docs-preview/pr-1680/nodes/consensus-node#save-on-storage-requirements","635":"/docs-preview/pr-1680/nodes/consensus-node#sync-types","636":"/docs-preview/pr-1680/nodes/consensus-node#option-1-block-sync","637":"/docs-preview/pr-1680/nodes/consensus-node#option-2-state-sync","638":"/docs-preview/pr-1680/nodes/consensus-node#option-3-quick-sync","639":"/docs-preview/pr-1680/nodes/consensus-node#start-the-consensus-node","640":"/docs-preview/pr-1680/nodes/consensus-node#extra-resources-for-consensus-nodes","641":"/docs-preview/pr-1680/nodes/consensus-node#optional-reset-network","642":"/docs-preview/pr-1680/nodes/consensus-node#optional-configure-an-rpc-endpoint","643":"/docs-preview/pr-1680/nodes/consensus-node#expose-rpc","644":"/docs-preview/pr-1680/nodes/consensus-node#note-on-external-address","645":"/docs-preview/pr-1680/nodes/consensus-node#restart-the-node","646":"/docs-preview/pr-1680/nodes/consensus-node#optional-transaction-indexer-configuration-options","647":"/docs-preview/pr-1680/nodes/consensus-node#optional-discard-abci-responses-configuration","648":"/docs-preview/pr-1680/nodes/consensus-node#faq","649":"/docs-preview/pr-1680/nodes/consensus-node#_2-3-committed-an-invalid-block-wrong-block-header-version","650":"/docs-preview/pr-1680/nodes/decide-node#deciding-which-node-to-run","651":"/docs-preview/pr-1680/nodes/decide-node#beginner","652":"/docs-preview/pr-1680/nodes/decide-node#advanced","653":"/docs-preview/pr-1680/nodes/docker-images#🐳-docker-setup","654":"/docs-preview/pr-1680/nodes/docker-images#prerequisites","655":"/docs-preview/pr-1680/nodes/docker-images#quick-start","656":"/docs-preview/pr-1680/nodes/docker-images#light-node-setup-with-persistent-storage","657":"/docs-preview/pr-1680/nodes/docker-images#initialize-the-node-store-and-key","658":"/docs-preview/pr-1680/nodes/docker-images#start-the-node","659":"/docs-preview/pr-1680/nodes/docker-images#video-walkthrough","660":"/docs-preview/pr-1680/nodes/docker-images#_2-5-minute-version","661":"/docs-preview/pr-1680/nodes/docker-images#troubleshooting","662":"/docs-preview/pr-1680/nodes/environment#development-environment","663":"/docs-preview/pr-1680/nodes/environment#install-dependencies","664":"/docs-preview/pr-1680/nodes/environment#install-golang","665":"/docs-preview/pr-1680/nodes/full-storage-node#setting-up-a-celestia-full-storage-node","666":"/docs-preview/pr-1680/nodes/full-storage-node#overview-of-full-storage-nodes","667":"/docs-preview/pr-1680/nodes/full-storage-node#hardware-requirements","668":"/docs-preview/pr-1680/nodes/full-storage-node#setting-up-your-full-storage-node","669":"/docs-preview/pr-1680/nodes/full-storage-node#setup-the-dependencies","670":"/docs-preview/pr-1680/nodes/full-storage-node#install-celestia-node","671":"/docs-preview/pr-1680/nodes/full-storage-node#run-the-full-storage-node","672":"/docs-preview/pr-1680/nodes/full-storage-node#initialize-the-full-storage-node","673":"/docs-preview/pr-1680/nodes/full-storage-node#start-the-full-storage-node","674":"/docs-preview/pr-1680/nodes/full-storage-node#optional-run-the-full-storage-node-with-a-custom-key","675":"/docs-preview/pr-1680/nodes/full-storage-node#optional-start-the-full-storage-node-with-systemd","676":"/docs-preview/pr-1680/nodes/full-storage-node#stop-the-full-storage-node","677":"/docs-preview/pr-1680/nodes/hardfork-process#celestia-hardfork-process","678":"/docs-preview/pr-1680/nodes/hardfork-process#general-process","679":"/docs-preview/pr-1680/nodes/hardfork-process#lemongrass-hardfork","680":"/docs-preview/pr-1680/nodes/ibc-relayer#ibc-relaying-guide","681":"/docs-preview/pr-1680/nodes/ibc-relayer#hermes","682":"/docs-preview/pr-1680/nodes/ibc-relayer#configuration","683":"/docs-preview/pr-1680/nodes/ibc-relayer#add-relayer-wallets","684":"/docs-preview/pr-1680/nodes/ibc-relayer#verify-configuration-files","685":"/docs-preview/pr-1680/nodes/ibc-relayer#create-a-connection-between-2-chains","686":"/docs-preview/pr-1680/nodes/ibc-relayer#create-clients","687":"/docs-preview/pr-1680/nodes/ibc-relayer#open-connection-over-new-clients","688":"/docs-preview/pr-1680/nodes/ibc-relayer#configure-channels-in-hermes","689":"/docs-preview/pr-1680/nodes/ibc-relayer#start-the-relayer","690":"/docs-preview/pr-1680/nodes/ibc-relayer#transfer","691":"/docs-preview/pr-1680/nodes/ibc-relayer#token-filter","692":"/docs-preview/pr-1680/nodes/instantiate-testnet#celestia-app-network-instantiation-guide","693":"/docs-preview/pr-1680/nodes/instantiate-testnet#hardware-requirements","694":"/docs-preview/pr-1680/nodes/instantiate-testnet#setup-dependencies","695":"/docs-preview/pr-1680/nodes/instantiate-testnet#celestia-app-installation","696":"/docs-preview/pr-1680/nodes/instantiate-testnet#spin-up-a-celestia-testnet","697":"/docs-preview/pr-1680/nodes/instantiate-testnet#optional-reset-working-directory","698":"/docs-preview/pr-1680/nodes/instantiate-testnet#initialize-a-working-directory","699":"/docs-preview/pr-1680/nodes/instantiate-testnet#create-a-new-key","700":"/docs-preview/pr-1680/nodes/instantiate-testnet#add-genesis-account-keyname","701":"/docs-preview/pr-1680/nodes/instantiate-testnet#optional-adding-other-validators","702":"/docs-preview/pr-1680/nodes/instantiate-testnet#create-the-genesis-transaction-for-new-chain","703":"/docs-preview/pr-1680/nodes/instantiate-testnet#creating-the-genesis-json-file","704":"/docs-preview/pr-1680/nodes/instantiate-testnet#modify-your-config-file","705":"/docs-preview/pr-1680/nodes/instantiate-testnet#add-your-node-as-a-persistent-peer","706":"/docs-preview/pr-1680/nodes/instantiate-testnet#instantiate-the-network","707":"/docs-preview/pr-1680/nodes/light-node#setting-up-a-celestia-light-node","708":"/docs-preview/pr-1680/nodes/light-node#overview-of-light-nodes","709":"/docs-preview/pr-1680/nodes/light-node#hardware-requirements","710":"/docs-preview/pr-1680/nodes/light-node#setting-up-your-light-node","711":"/docs-preview/pr-1680/nodes/light-node#install-celestia-node","712":"/docs-preview/pr-1680/nodes/light-node#initialize-the-light-node","713":"/docs-preview/pr-1680/nodes/light-node#start-the-light-node","714":"/docs-preview/pr-1680/nodes/light-node#keys-and-wallets","715":"/docs-preview/pr-1680/nodes/light-node#testnet-tokens","716":"/docs-preview/pr-1680/nodes/light-node#optional-run-the-light-node-with-a-custom-key","717":"/docs-preview/pr-1680/nodes/light-node#optional-start-light-node-with-systemd","718":"/docs-preview/pr-1680/nodes/light-node#data-availability-sampling","719":"/docs-preview/pr-1680/nodes/mainnet#mainnet-beta","720":"/docs-preview/pr-1680/nodes/mainnet#network-stability-and-upgrades","721":"/docs-preview/pr-1680/nodes/mainnet#network-details","722":"/docs-preview/pr-1680/nodes/mainnet#software-version-numbers","723":"/docs-preview/pr-1680/nodes/mainnet#network-parameters","724":"/docs-preview/pr-1680/nodes/mainnet#maximum-bytes","725":"/docs-preview/pr-1680/nodes/mainnet#integrations","726":"/docs-preview/pr-1680/nodes/mainnet#production-rpc-endpoints","727":"/docs-preview/pr-1680/nodes/mainnet#consensus-nodes","728":"/docs-preview/pr-1680/nodes/mainnet#community-consensus-rpc-endpoints","729":"/docs-preview/pr-1680/nodes/mainnet#community-api-endpoints","730":"/docs-preview/pr-1680/nodes/mainnet#community-grpc-endpoints","731":"/docs-preview/pr-1680/nodes/mainnet#community-websocket-endpoints","732":"/docs-preview/pr-1680/nodes/mainnet#data-availability-nodes","733":"/docs-preview/pr-1680/nodes/mainnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","734":"/docs-preview/pr-1680/nodes/mainnet#community-data-availability-da-grpc-endpoints-for-state-access","735":"/docs-preview/pr-1680/nodes/mainnet#archival-da-rpc-endpoints","736":"/docs-preview/pr-1680/nodes/mainnet#grove-archival-endpoints","737":"/docs-preview/pr-1680/nodes/mainnet#explorers","738":"/docs-preview/pr-1680/nodes/mainnet#analytics","739":"/docs-preview/pr-1680/nodes/mainnet#network-upgrades","740":"/docs-preview/pr-1680/nodes/mocha-testnet#mocha-testnet","741":"/docs-preview/pr-1680/nodes/mocha-testnet#network-details","742":"/docs-preview/pr-1680/nodes/mocha-testnet#software-version-numbers","743":"/docs-preview/pr-1680/nodes/mocha-testnet#rpc-for-da-bridge-full-and-light-nodes","744":"/docs-preview/pr-1680/nodes/mocha-testnet#production-rpc-endpoints","745":"/docs-preview/pr-1680/nodes/mocha-testnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","746":"/docs-preview/pr-1680/nodes/mocha-testnet#community-data-availability-da-grpc-endpoints-for-state-access","747":"/docs-preview/pr-1680/nodes/mocha-testnet#community-rpc-endpoints","748":"/docs-preview/pr-1680/nodes/mocha-testnet#community-api-endpoints","749":"/docs-preview/pr-1680/nodes/mocha-testnet#community-grpc-endpoints","750":"/docs-preview/pr-1680/nodes/mocha-testnet#community-bridge-and-full-node-endpoints","751":"/docs-preview/pr-1680/nodes/mocha-testnet#mocha-testnet-faucet","752":"/docs-preview/pr-1680/nodes/mocha-testnet#analytics","753":"/docs-preview/pr-1680/nodes/mocha-testnet#explorers","754":"/docs-preview/pr-1680/nodes/mocha-testnet#network-upgrades","755":"/docs-preview/pr-1680/nodes/overview#overview-to-running-nodes-on-celestia","756":"/docs-preview/pr-1680/nodes/overview#recommended-celestia-node-requirements","757":"/docs-preview/pr-1680/nodes/overview#data-availability-nodes","758":"/docs-preview/pr-1680/nodes/overview#consensus-nodes","759":"/docs-preview/pr-1680/nodes/participate#participate-in-the-celestia-networks","760":"/docs-preview/pr-1680/nodes/participate#mainnet-beta","761":"/docs-preview/pr-1680/nodes/participate#compatible-software-versions-for-mainnet-beta","762":"/docs-preview/pr-1680/nodes/participate#testnets","763":"/docs-preview/pr-1680/nodes/participate#arabica-devnet","764":"/docs-preview/pr-1680/nodes/participate#compatible-software-versions-for-arabica-devnet","765":"/docs-preview/pr-1680/nodes/participate#mocha-testnet","766":"/docs-preview/pr-1680/nodes/participate#compatible-software-versions-for-mocha-testnet","767":"/docs-preview/pr-1680/nodes/participate#network-upgrades","768":"/docs-preview/pr-1680/nodes/quick-start#quick-start-guide","769":"/docs-preview/pr-1680/nodes/quick-start#celestia-node","770":"/docs-preview/pr-1680/nodes/quick-start#celestia-app","771":"/docs-preview/pr-1680/nodes/quick-start#getting-started","772":"/docs-preview/pr-1680/nodes/systemd#setting-up-your-node-as-a-background-process-with-systemd","773":"/docs-preview/pr-1680/nodes/systemd#consensus-nodes","774":"/docs-preview/pr-1680/nodes/systemd#start-the-celestia-app-with-systemd","775":"/docs-preview/pr-1680/nodes/systemd#data-availability-nodes","776":"/docs-preview/pr-1680/nodes/systemd#celestia-full-storage-node","777":"/docs-preview/pr-1680/nodes/systemd#celestia-bridge-node","778":"/docs-preview/pr-1680/nodes/systemd#celestia-light-node","779":"/docs-preview/pr-1680/nodes/validator-node#setting-up-a-celestia-validator-node","780":"/docs-preview/pr-1680/nodes/validator-node#hardware-requirements","781":"/docs-preview/pr-1680/nodes/validator-node#setting-up-a-validator-node","782":"/docs-preview/pr-1680/nodes/validator-node#wallet","783":"/docs-preview/pr-1680/nodes/validator-node#delegate-stake-to-a-validator","784":"/docs-preview/pr-1680/nodes/validator-node#optional-deploy-the-celestia-node","785":"/docs-preview/pr-1680/nodes/validator-node#install-celestia-node","786":"/docs-preview/pr-1680/nodes/validator-node#initialize-the-bridge-node","787":"/docs-preview/pr-1680/nodes/validator-node#run-the-bridge-node","788":"/docs-preview/pr-1680/nodes/validator-node#optional-start-the-bridge-node-with-systemd","789":"/docs-preview/pr-1680/nodes/validator-node#run-the-validator-node","790":"/docs-preview/pr-1680/nodes/validator-node#submit-your-validator-information","791":"/docs-preview/pr-1680/nodes/validator-node#optional-transaction-indexer-configuration-options","792":"/docs-preview/pr-1680/nodes/validator-node#additional-resources","793":"/docs-preview/pr-1680/nodes/validator-node#faq","794":"/docs-preview/pr-1680/nodes/validator-node#_2-3-committed-an-invalid-block-wrong-block-header-version"},"fieldIds":{"title":0,"titles":1,"text":2},"fieldLength":{"0":[3,1,24],"1":[3,3,22],"2":[2,3,69],"3":[2,3,34],"4":[3,3,25],"5":[2,1,32],"6":[5,1,1],"7":[2,5,62],"8":[2,5,114],"9":[2,5,57],"10":[1,5,43],"11":[1,5,39],"12":[2,5,22],"13":[2,7,38],"14":[2,7,57],"15":[3,7,50],"16":[3,7,34],"17":[1,5,47],"18":[5,1,1],"19":[4,5,57],"20":[3,5,1],"21":[2,7,53],"22":[2,7,41],"23":[2,7,110],"24":[2,7,174],"25":[2,7,62],"26":[1,5,45],"27":[2,6,147],"28":[2,5,53],"29":[2,5,17],"30":[4,1,150],"31":[3,4,229],"32":[2,4,69],"33":[4,4,137],"34":[4,4,460],"35":[3,1,31],"36":[3,3,129],"37":[3,3,69],"38":[3,3,72],"39":[3,3,39],"40":[1,6,164],"41":[3,6,124],"42":[1,6,150],"43":[1,6,190],"44":[1,6,170],"45":[3,6,159],"46":[1,6,132],"47":[4,6,145],"48":[9,6,167],"49":[4,1,28],"50":[2,4,64],"51":[2,4,1],"52":[6,6,71],"53":[2,6,70],"54":[1,6,35],"55":[1,6,28],"56":[1,6,48],"57":[3,1,37],"58":[3,3,12],"59":[6,3,44],"60":[8,3,58],"61":[7,3,48],"62":[6,3,23],"63":[2,3,37],"64":[2,1,26],"65":[2,1,143],"66":[8,1,29],"67":[6,8,1],"68":[7,11,47],"69":[7,11,68],"70":[6,8,1],"71":[10,11,81],"72":[5,11,40],"73":[8,1,18],"74":[1,8,14],"75":[4,8,85],"76":[4,12,94],"77":[3,8,51],"78":[4,8,15],"79":[6,1,77],"80":[1,6,52],"81":[1,6,10],"82":[6,7,63],"83":[6,7,58],"84":[8,7,238],"85":[8,7,115],"86":[10,7,74],"87":[12,7,39],"88":[11,7,129],"89":[9,7,238],"90":[10,7,56],"91":[7,7,231],"92":[4,7,49],"93":[1,6,17],"94":[2,7,75],"95":[4,7,32],"96":[2,11,13],"97":[2,11,13],"98":[4,7,48],"99":[4,7,48],"100":[7,1,1],"101":[1,7,20],"102":[4,7,71],"103":[6,7,34],"104":[8,1,1],"105":[1,8,51],"106":[2,8,33],"107":[3,10,174],"108":[3,10,128],"109":[3,10,77],"110":[5,10,86],"111":[2,8,17],"112":[8,1,1],"113":[1,8,33],"114":[1,8,18],"115":[1,8,35],"116":[4,8,103],"117":[4,8,139],"118":[4,8,1],"119":[2,9,51],"120":[4,9,87],"121":[5,8,91],"122":[2,8,28],"123":[4,1,1],"124":[2,4,1],"125":[1,6,9],"126":[4,6,58],"127":[2,6,95],"128":[2,4,43],"129":[1,4,50],"130":[3,4,31],"131":[6,4,124],"132":[4,1,1],"133":[3,4,75],"134":[3,4,149],"135":[2,4,168],"136":[3,6,101],"137":[2,6,115],"138":[3,4,1],"139":[3,7,164],"140":[2,7,1],"141":[4,9,10],"142":[8,9,13],"143":[4,9,39],"144":[3,1,1],"145":[1,3,106],"146":[5,3,101],"147":[3,7,1],"148":[3,7,134],"149":[3,3,72],"150":[5,6,51],"151":[2,11,78],"152":[2,11,56],"153":[15,6,228],"154":[4,6,44],"155":[7,6,13],"156":[2,13,163],"157":[2,13,31],"158":[9,6,35],"159":[2,15,89],"160":[5,6,60],"161":[2,11,108],"162":[2,11,50],"163":[9,3,85],"164":[1,11,54],"165":[1,11,198],"166":[1,11,94],"167":[1,11,47],"168":[1,11,113],"169":[1,11,187],"170":[5,11,119],"171":[5,11,72],"172":[6,11,365],"173":[1,3,58],"174":[4,1,47],"175":[1,4,53],"176":[3,5,23],"177":[5,8,92],"178":[5,8,83],"179":[4,8,41],"180":[4,8,63],"181":[3,5,85],"182":[5,8,31],"183":[6,8,119],"184":[7,8,119],"185":[4,8,15],"186":[4,8,2],"187":[2,4,57],"188":[8,5,70],"189":[9,11,50],"190":[9,11,2],"191":[9,11,42],"192":[7,5,107],"193":[8,10,18],"194":[8,10,27],"195":[2,4,66],"196":[7,5,88],"197":[8,10,36],"198":[8,10,2],"199":[7,5,30],"200":[6,10,82],"201":[8,10,2],"202":[8,10,26],"203":[4,5,79],"204":[5,9,2],"205":[5,9,13],"206":[1,4,48],"207":[1,4,1],"208":[12,5,104],"209":[4,1,14],"210":[3,4,34],"211":[4,7,232],"212":[4,7,104],"213":[7,7,113],"214":[3,13,59],"215":[3,13,61],"216":[3,13,22],"217":[4,7,116],"218":[4,10,40],"219":[2,10,180],"220":[4,7,186],"221":[8,7,36],"222":[5,4,34],"223":[4,9,175],"224":[6,9,176],"225":[4,1,89],"226":[2,4,75],"227":[6,4,92],"228":[3,4,63],"229":[6,1,1],"230":[4,6,119],"231":[3,9,7],"232":[7,6,1],"233":[3,12,40],"234":[3,12,42],"235":[3,12,69],"236":[5,6,30],"237":[5,6,111],"238":[4,6,106],"239":[4,9,58],"240":[6,9,31],"241":[2,9,17],"242":[2,9,52],"243":[3,6,63],"244":[2,1,32],"245":[7,2,56],"246":[3,2,49],"247":[2,4,34],"248":[1,6,8],"249":[1,6,40],"250":[1,4,22],"251":[1,4,20],"252":[1,4,12],"253":[1,4,12],"254":[2,2,22],"255":[2,1,43],"256":[4,2,1],"257":[3,6,23],"258":[4,6,9],"259":[2,6,10],"260":[5,2,41],"261":[6,2,100],"262":[4,2,1],"263":[5,6,81],"264":[1,6,123],"265":[1,6,107],"266":[6,1,42],"267":[5,6,42],"268":[1,11,56],"269":[5,11,106],"270":[5,11,32],"271":[5,11,33],"272":[6,11,5],"273":[4,6,1],"274":[1,10,16],"275":[3,10,144],"276":[5,10,147],"277":[7,1,14],"278":[1,7,26],"279":[1,7,35],"280":[4,7,103],"281":[4,7,139],"282":[4,7,1],"283":[2,9,62],"284":[2,9,90],"285":[5,7,90],"286":[2,7,27],"287":[2,1,95],"288":[5,1,1],"289":[1,5,37],"290":[2,5,31],"291":[1,5,60],"292":[6,5,52],"293":[6,11,83],"294":[8,11,72],"295":[9,5,75],"296":[5,5,37],"297":[9,5,53],"298":[7,12,11],"299":[7,5,87],"300":[6,12,48],"301":[6,1,88],"302":[2,6,34],"303":[2,8,34],"304":[2,8,26],"305":[5,10,193],"306":[3,10,18],"307":[4,10,70],"308":[2,10,120],"309":[6,8,142],"310":[3,8,97],"311":[3,11,75],"312":[3,8,121],"313":[4,8,270],"314":[5,8,60],"315":[5,8,98],"316":[6,8,32],"317":[6,1,156],"318":[3,6,51],"319":[4,6,15],"320":[2,6,34],"321":[4,1,27],"322":[2,4,66],"323":[4,4,132],"324":[4,4,86],"325":[4,4,101],"326":[7,4,59],"327":[2,4,11],"328":[5,1,18],"329":[2,5,28],"330":[4,5,84],"331":[4,7,27],"332":[3,7,62],"333":[1,7,36],"334":[1,7,28],"335":[6,7,81],"336":[5,1,43],"337":[3,5,109],"338":[2,7,26],"339":[2,5,50],"340":[2,5,35],"341":[2,1,28],"342":[2,2,46],"343":[1,3,16],"344":[1,3,48],"345":[3,3,19],"346":[2,2,66],"347":[3,3,12],"348":[5,1,26],"349":[1,5,1],"350":[1,6,19],"351":[1,6,66],"352":[2,5,30],"353":[3,5,11],"354":[5,8,55],"355":[5,8,130],"356":[3,8,107],"357":[3,5,39],"358":[2,6,124],"359":[2,6,77],"360":[3,8,67],"361":[2,8,65],"362":[7,10,70],"363":[2,6,118],"364":[4,8,10],"365":[2,6,113],"366":[4,6,74],"367":[1,6,1],"368":[3,7,46],"369":[6,7,43],"370":[4,7,49],"371":[4,7,28],"372":[5,7,107],"373":[2,7,20],"374":[5,7,6],"375":[7,7,72],"376":[2,7,17],"377":[1,7,21],"378":[2,6,35],"379":[2,5,1],"380":[5,7,124],"381":[6,7,21],"382":[1,7,46],"383":[4,1,21],"384":[3,4,83],"385":[5,4,84],"386":[5,4,51],"387":[2,4,57],"388":[8,1,47],"389":[2,8,5],"390":[5,10,73],"391":[5,8,48],"392":[10,8,115],"393":[1,8,22],"394":[2,1,80],"395":[1,2,28],"396":[8,3,145],"397":[2,3,42],"398":[4,2,1],"399":[4,5,38],"400":[4,5,100],"401":[2,5,110],"402":[2,5,232],"403":[2,5,84],"404":[3,5,160],"405":[2,2,60],"406":[4,1,29],"407":[2,4,63],"408":[4,4,107],"409":[4,4,87],"410":[7,4,57],"411":[2,4,11],"412":[4,1,22],"413":[3,4,106],"414":[5,1,27],"415":[3,5,94],"416":[4,5,26],"417":[4,9,103],"418":[3,12,141],"419":[3,12,152],"420":[3,12,78],"421":[10,9,118],"422":[1,5,11],"423":[6,6,14],"424":[5,6,19],"425":[6,6,100],"426":[9,6,199],"427":[5,6,21],"428":[2,1,53],"429":[3,2,42],"430":[1,2,37],"431":[4,1,21],"432":[8,4,181],"433":[6,4,82],"434":[6,4,100],"435":[3,1,1],"436":[5,3,82],"437":[7,3,73],"438":[9,3,41],"439":[6,3,62],"440":[15,3,80],"441":[8,3,65],"442":[5,3,33],"443":[8,3,70],"444":[10,3,26],"445":[8,3,51],"446":[10,3,73],"447":[11,3,42],"448":[15,3,34],"449":[5,1,69],"450":[5,5,122],"451":[1,9,86],"452":[6,9,122],"453":[5,5,130],"454":[6,5,1],"455":[3,11,120],"456":[4,1,172],"457":[1,1,90],"458":[7,1,158],"459":[3,7,163],"460":[4,1,44],"461":[4,4,1],"462":[5,4,1],"463":[6,8,20],"464":[9,8,15],"465":[5,8,25],"466":[6,8,22],"467":[5,4,1],"468":[6,8,17],"469":[7,8,29],"470":[6,8,22],"471":[5,4,1],"472":[6,8,7],"473":[12,8,13],"474":[5,8,12],"475":[4,8,24],"476":[3,1,1],"477":[2,3,70],"478":[3,3,44],"479":[4,1,60],"480":[7,4,93],"481":[4,4,143],"482":[4,1,1],"483":[5,4,68],"484":[1,4,73],"485":[2,4,1],"486":[2,5,35],"487":[2,5,37],"488":[4,4,82],"489":[1,8,109],"490":[3,1,30],"491":[2,3,34],"492":[2,3,31],"493":[3,1,1],"494":[4,3,33],"495":[3,3,1],"496":[3,4,33],"497":[3,4,68],"498":[3,4,41],"499":[2,4,41],"500":[1,4,1],"501":[3,5,15],"502":[3,5,27],"503":[4,5,9],"504":[2,1,45],"505":[4,2,64],"506":[2,2,1],"507":[3,4,1],"508":[1,2,49],"509":[3,3,37],"510":[3,3,95],"511":[6,3,1],"512":[9,9,39],"513":[8,9,111],"514":[3,2,24],"515":[1,3,41],"516":[1,3,12],"517":[1,2,19],"518":[2,2,22],"519":[6,1,23],"520":[4,6,108],"521":[2,6,30],"522":[5,6,16],"523":[3,7,7],"524":[5,6,1],"525":[3,8,17],"526":[4,8,102],"527":[4,8,112],"528":[9,9,49],"529":[7,8,23],"530":[3,1,102],"531":[3,3,27],"532":[2,3,19],"533":[4,5,52],"534":[2,3,19],"535":[2,3,47],"536":[1,3,175],"537":[2,4,89],"538":[3,3,28],"539":[4,3,28],"540":[3,3,24],"541":[6,3,38],"542":[6,3,93],"543":[1,1,41],"544":[1,1,80],"545":[1,1,243],"546":[2,1,52],"547":[1,1,63],"548":[1,1,40],"549":[2,1,97],"550":[1,1,29],"551":[5,1,135],"552":[2,1,24],"553":[9,1,42],"554":[2,9,18],"555":[5,11,1],"556":[3,15,20],"557":[5,15,79],"558":[5,15,22],"559":[2,15,53],"560":[6,11,17],"561":[4,14,89],"562":[3,14,32],"563":[2,14,20],"564":[5,14,144],"565":[6,14,62],"566":[6,14,42],"567":[6,14,62],"568":[1,9,41],"569":[3,10,50],"570":[3,10,10],"571":[6,10,91],"572":[8,10,39],"573":[5,10,88],"574":[1,9,25],"575":[1,9,20],"576":[6,1,18],"577":[1,6,20],"578":[3,6,57],"579":[3,6,75],"580":[3,1,19],"581":[4,3,111],"582":[5,3,108],"583":[1,3,90],"584":[4,1,82],"585":[3,1,28],"586":[3,3,58],"587":[2,5,23],"588":[2,5,27],"589":[2,5,78],"590":[4,3,80],"591":[1,1,1],"592":[2,1,64],"593":[2,3,48],"594":[1,1,106],"595":[7,1,1],"596":[1,8,99],"597":[1,8,81],"598":[1,8,1],"599":[6,9,58],"600":[5,9,42],"601":[6,9,47],"602":[3,1,81],"603":[4,1,26],"604":[10,1,71],"605":[7,1,109],"606":[7,1,92],"607":[3,7,27],"608":[3,1,1],"609":[3,3,126],"610":[5,3,102],"611":[2,3,39],"612":[3,3,26],"613":[3,1,1],"614":[2,3,12],"615":[3,3,34],"616":[1,4,35],"617":[1,4,1],"618":[1,5,45],"619":[2,5,31],"620":[1,4,1],"621":[3,5,61],"622":[2,1,24],"623":[3,2,30],"624":[5,2,16],"625":[4,6,7],"626":[3,6,8],"627":[5,6,140],"628":[4,2,1],"629":[7,6,34],"630":[3,12,6],"631":[4,12,25],"632":[4,6,25],"633":[4,6,49],"634":[4,6,54],"635":[2,2,50],"636":[4,4,41],"637":[4,4,113],"638":[4,4,72],"639":[4,2,77],"640":[5,2,1],"641":[3,7,22],"642":[5,7,28],"643":[2,12,65],"644":[4,12,56],"645":[3,12,13],"646":[5,7,94],"647":[5,7,90],"648":[1,2,1],"649":[10,3,165],"650":[5,1,16],"651":[1,5,38],"652":[1,5,29],"653":[3,1,71],"654":[1,3,14],"655":[2,3,105],"656":[6,3,77],"657":[6,8,79],"658":[3,8,64],"659":[2,3,1],"660":[4,5,1],"661":[1,3,54],"662":[2,1,24],"663":[2,2,80],"664":[2,2,108],"665":[7,1,31],"666":[5,7,26],"667":[2,7,31],"668":[6,7,16],"669":[3,9,11],"670":[3,7,10],"671":[5,10,1],"672":[5,12,17],"673":[5,12,141],"674":[10,10,50],"675":[8,10,24],"676":[5,10,32],"677":[3,1,65],"678":[2,3,84],"679":[2,4,112],"680":[3,1,93],"681":[1,3,85],"682":[1,4,180],"683":[3,4,84],"684":[3,4,49],"685":[6,3,52],"686":[2,3,31],"687":[5,5,85],"688":[4,5,44],"689":[3,3,7],"690":[1,3,41],"691":[2,4,37],"692":[5,1,42],"693":[2,5,8],"694":[2,5,11],"695":[3,5,12],"696":[5,5,32],"697":[4,9,38],"698":[4,9,44],"699":[4,9,49],"700":[4,9,29],"701":[4,9,48],"702":[7,9,76],"703":[5,9,74],"704":[4,9,38],"705":[7,9,66],"706":[3,9,42],"707":[6,1,25],"708":[4,6,42],"709":[2,6,30],"710":[5,6,22],"711":[3,7,10],"712":[4,6,37],"713":[4,6,83],"714":[3,8,80],"715":[2,11,38],"716":[9,8,49],"717":[6,8,15],"718":[3,6,16],"719":[2,1,49],"720":[4,2,66],"721":[2,2,1],"722":[3,2,1],"723":[2,2,31],"724":[2,4,109],"725":[1,2,56],"726":[3,3,59],"727":[2,3,4],"728":[4,5,74],"729":[3,5,55],"730":[3,5,57],"731":[3,5,14],"732":[3,3,6],"733":[10,6,39],"734":[9,6,129],"735":[4,6,37],"736":[3,10,31],"737":[1,2,30],"738":[1,2,26],"739":[2,2,31],"740":[2,1,106],"741":[2,2,1],"742":[3,2,1],"743":[8,2,1],"744":[3,10,59],"745":[10,10,39],"746":[9,10,99],"747":[3,2,67],"748":[3,2,81],"749":[3,2,85],"750":[6,2,33],"751":[3,2,63],"752":[1,2,14],"753":[1,2,32],"754":[2,2,31],"755":[6,1,71],"756":[4,6,1],"757":[3,6,30],"758":[2,6,47],"759":[5,1,1],"760":[2,5,40],"761":[6,7,1],"762":[1,5,12],"763":[2,6,45],"764":[6,8,1],"765":[2,6,48],"766":[6,6,1],"767":[2,5,31],"768":[3,1,25],"769":[2,3,48],"770":[2,3,29],"771":[2,3,76],"772":[10,1,13],"773":[2,10,21],"774":[6,12,113],"775":[3,10,1],"776":[4,13,72],"777":[3,13,106],"778":[3,13,93],"779":[6,1,23],"780":[2,6,30],"781":[5,6,25],"782":[1,6,8],"783":[5,6,113],"784":[5,6,48],"785":[3,10,10],"786":[4,10,47],"787":[4,10,8],"788":[7,12,23],"789":[4,6,190],"790":[4,6,16],"791":[5,6,19],"792":[2,6,14],"793":[1,6,1],"794":[10,7,165]},"averageFieldLength":[3.8553459119496867,5.67547169811321,57.58364779874213],"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":"Community calendar","titles":[]},"6":{"title":"Celestia.org Code of Conduct","titles":[]},"7":{"title":"Our Pledge","titles":["Celestia.org Code of Conduct"]},"8":{"title":"Our Standards","titles":["Celestia.org Code of Conduct"]},"9":{"title":"Enforcement Responsibilities","titles":["Celestia.org Code of Conduct"]},"10":{"title":"Scope","titles":["Celestia.org Code of Conduct"]},"11":{"title":"Enforcement","titles":["Celestia.org Code of Conduct"]},"12":{"title":"Enforcement Guidelines","titles":["Celestia.org Code of Conduct"]},"13":{"title":"1. Correction","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"14":{"title":"2. Warning","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"15":{"title":"3. Temporary Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"16":{"title":"4. Permanent Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"17":{"title":"Attribution","titles":["Celestia.org Code of Conduct"]},"18":{"title":"The Celestia Foundation Delegation Program","titles":[]},"19":{"title":"Objectives of the program","titles":["The Celestia Foundation Delegation Program"]},"20":{"title":"Foundation delegation process","titles":["The Celestia Foundation Delegation Program"]},"21":{"title":"Program launch","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"22":{"title":"Cohort process","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"23":{"title":"Key Points","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"24":{"title":"Eligibility criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"25":{"title":"Undelegation criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"26":{"title":"Application","titles":["The Celestia Foundation Delegation Program"]},"27":{"title":"Application details","titles":["The Celestia Foundation Delegation Program","Application"]},"28":{"title":"Cohort information","titles":["The Celestia Foundation Delegation Program"]},"29":{"title":"Feedback process","titles":["The Celestia Foundation Delegation Program"]},"30":{"title":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS","titles":[]},"31":{"title":"1. General Terms","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"32":{"title":"2. Taxes","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"33":{"title":"3. Supplemental Privacy Information","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"34":{"title":"4. Certain Additional Representations","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"35":{"title":"Modular Meetup guide","titles":[]},"36":{"title":"Before the Meetup","titles":["Modular Meetup guide"]},"37":{"title":"During the Meetup","titles":["Modular Meetup guide"]},"38":{"title":"After the Meetup","titles":["Modular Meetup guide"]},"39":{"title":"Logistics and guidance","titles":["Modular Meetup guide"]},"40":{"title":"Venue","titles":["Modular Meetup guide","Logistics and guidance"]},"41":{"title":"Catering and refreshments","titles":["Modular Meetup guide","Logistics and guidance"]},"42":{"title":"Audience","titles":["Modular Meetup guide","Logistics and guidance"]},"43":{"title":"Speakers","titles":["Modular Meetup guide","Logistics and guidance"]},"44":{"title":"Sponsors","titles":["Modular Meetup guide","Logistics and guidance"]},"45":{"title":"Communications and marketing","titles":["Modular Meetup guide","Logistics and guidance"]},"46":{"title":"Recording","titles":["Modular Meetup guide","Logistics and guidance"]},"47":{"title":"Utilizing Meetup.com platform","titles":["Modular Meetup guide","Logistics and guidance"]},"48":{"title":"Onboarding questions for community members joining a Modular Meetup","titles":["Modular Meetup guide","Logistics and guidance"]},"49":{"title":"Celestia Modular Meetup program","titles":[]},"50":{"title":"Program description","titles":["Celestia Modular Meetup program"]},"51":{"title":"Important info","titles":["Celestia Modular Meetup program"]},"52":{"title":"Celestia.org Community Code of Conduct","titles":["Celestia Modular Meetup program","Important info"]},"53":{"title":"Signup form","titles":["Celestia Modular Meetup program","Important info"]},"54":{"title":"Emails","titles":["Celestia Modular Meetup program","Important info"]},"55":{"title":"Discord","titles":["Celestia Modular Meetup program","Important info"]},"56":{"title":"Materials","titles":["Celestia Modular Meetup program","Important info"]},"57":{"title":"Modular Meetup Toolkit","titles":[]},"58":{"title":"Celestia branding guidelines","titles":["Modular Meetup Toolkit"]},"59":{"title":"Sample “Introduction to Modularity” workshop presentation","titles":["Modular Meetup Toolkit"]},"60":{"title":"Sample “Run a Celestia light node” workshop presentation","titles":["Modular Meetup Toolkit"]},"61":{"title":"Sample “Deploy a Sovereign Rollup” workshop presentation","titles":["Modular Meetup Toolkit"]},"62":{"title":"Sample “Modular Meetup Introduction” workshop presentation","titles":["Modular Meetup Toolkit"]},"63":{"title":"Swag logistics","titles":["Modular Meetup Toolkit"]},"64":{"title":"Community overview","titles":[]},"65":{"title":"Speaker list","titles":[]},"66":{"title":"Bridging in and out of your Orbit rollup","titles":[]},"67":{"title":"Bridge in (deposit) to your rollup","titles":["Bridging in and out of your Orbit rollup"]},"68":{"title":"Step 1: Add your custom chain config","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"69":{"title":"Step 2: Deposit to your Orbit rollup","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"70":{"title":"Bridge out (withdrawal) from your rollup","titles":["Bridging in and out of your Orbit rollup"]},"71":{"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"]},"72":{"title":"Step 2: Claim your withdrawal","titles":["Bridging in and out of your Orbit rollup","Bridge out (withdrawal) from your rollup"]},"73":{"title":"Deploy a dapp on your Arbitrum rollup devnet","titles":[]},"74":{"title":"Dependencies","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"75":{"title":"Setup and contract deployment","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"76":{"title":"Interact with the contract","titles":["Deploy a dapp on your Arbitrum rollup devnet","Setup and contract deployment"]},"77":{"title":"Update the frontend","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"78":{"title":"Interact with the frontend","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"79":{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","titles":[]},"80":{"title":"Prerequisites","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"81":{"title":"Setup","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"82":{"title":"Step 1: Acquire Arbitrum Sepolia ETH","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"83":{"title":"Step 2: Pick your deployment type","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"84":{"title":"Step 3: Configure your Orbit chain\'s deployment","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"85":{"title":"Step 3: Review & Deploy your Orbit chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"86":{"title":"Step 4: Download your chain\'s configuration files and launch your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"87":{"title":"Step 5: Clone the setup script repository and add your configuration files","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"88":{"title":"Step 6: Pick an L2 RPC URL for the Batch Poster","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"89":{"title":"Step 7: Run your light node for Mocha testnet","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"90":{"title":"Step 8: Run your chain\'s node and block explorer","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"91":{"title":"Step 9: Finish setting up your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"92":{"title":"Congratulations with Celestia underneath","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"93":{"title":"Appendix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"94":{"title":"Compatibility matrix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"95":{"title":"Blobstream X contract deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"96":{"title":"Arbitrum Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"97":{"title":"Base Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"98":{"title":"Arbitrum Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"99":{"title":"Base Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"100":{"title":"Running a full node and/or validator","titles":[]},"101":{"title":"Prerequisites","titles":["Running a full node and/or validator"]},"102":{"title":"Running a full node","titles":["Running a full node and/or validator"]},"103":{"title":"Running a full node with validation","titles":["Running a full node and/or validator"]},"104":{"title":"Introduction to Arbitrum rollups with Celestia as DA","titles":[]},"105":{"title":"Overview","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"106":{"title":"Key components","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"107":{"title":"DA provider implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"108":{"title":"Preimage Oracle Implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"109":{"title":"Blobstream X implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"110":{"title":"Ethereum fallback mechanism in Nitro","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"111":{"title":"Next steps","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"112":{"title":"Deploy a smart contract to your Arbitrum rollup","titles":[]},"113":{"title":"Overview","titles":["Deploy a smart contract to your Arbitrum rollup"]},"114":{"title":"Prerequisites","titles":["Deploy a smart contract to your Arbitrum rollup"]},"115":{"title":"Setup","titles":["Deploy a smart contract to your Arbitrum rollup"]},"116":{"title":"Create your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"117":{"title":"Test your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"118":{"title":"Deploying your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"119":{"title":"Funded accounts","titles":["Deploy a smart contract to your Arbitrum rollup","Deploying your smart contract"]},"120":{"title":"Using our Arbitrum devnet","titles":["Deploy a smart contract to your Arbitrum rollup","Deploying your smart contract"]},"121":{"title":"Interacting with your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"122":{"title":"Next steps","titles":["Deploy a smart contract to your Arbitrum rollup"]},"123":{"title":"Integrate with Blobstream contracts","titles":[]},"124":{"title":"Getting started","titles":["Integrate with Blobstream contracts"]},"125":{"title":"Prerequisites","titles":["Integrate with Blobstream contracts","Getting started"]},"126":{"title":"Installing Blobstream X contracts","titles":["Integrate with Blobstream contracts","Getting started"]},"127":{"title":"Example usage","titles":["Integrate with Blobstream contracts","Getting started"]},"128":{"title":"Data structures","titles":["Integrate with Blobstream contracts"]},"129":{"title":"Interface","titles":["Integrate with Blobstream contracts"]},"130":{"title":"Querying the proof","titles":["Integrate with Blobstream contracts"]},"131":{"title":"Verifying data inclusion for fraud proofs","titles":["Integrate with Blobstream contracts"]},"132":{"title":"Integrate with Blobstream client","titles":[]},"133":{"title":"Blobstream demo rollup","titles":["Integrate with Blobstream client"]},"134":{"title":"Defining a chain","titles":["Integrate with Blobstream client"]},"135":{"title":"Rollup sequencer","titles":["Integrate with Blobstream client"]},"136":{"title":"Committing to data","titles":["Integrate with Blobstream client","Rollup sequencer"]},"137":{"title":"Creating blocks","titles":["Integrate with Blobstream client","Rollup sequencer"]},"138":{"title":"Rollup full node","titles":["Integrate with Blobstream client"]},"139":{"title":"Downloading the block","titles":["Integrate with Blobstream client","Rollup full node"]},"140":{"title":"More documentation","titles":["Integrate with Blobstream client","Rollup full node"]},"141":{"title":"Proving inclusion via Blobstream","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"142":{"title":"Submitting block data to Celestia via light node","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"143":{"title":"Posting headers to Ethereum","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"144":{"title":"Blobstream proofs queries","titles":[]},"145":{"title":"Prerequisites","titles":["Blobstream proofs queries"]},"146":{"title":"Overview of the proof queries","titles":["Blobstream proofs queries"]},"147":{"title":"The Celestia square","titles":["Blobstream proofs queries","Overview of the proof queries"]},"148":{"title":"The commitment scheme","titles":["Blobstream proofs queries","Overview of the proof queries"]},"149":{"title":"Hands-on demonstration","titles":["Blobstream proofs queries"]},"150":{"title":"1. Data root inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"151":{"title":"HTTP query","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"152":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"153":{"title":"Full example of proving that a Celestia block was committed to by Blobstream X contract","titles":["Blobstream proofs queries","Hands-on demonstration"]},"154":{"title":"2. Transaction inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"155":{"title":"Transaction inclusion proof using the transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"156":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"157":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"158":{"title":"Blob inclusion proof using the corresponding PFB transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"159":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Blob inclusion proof using the corresponding PFB transaction hash"]},"160":{"title":"Specific share range inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"161":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"162":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"163":{"title":"Converting the proofs to be usable in the DAVerifier library","titles":["Blobstream proofs queries"]},"164":{"title":"data","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"165":{"title":"shareProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"166":{"title":"namespace","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"167":{"title":"rowRoots","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"168":{"title":"rowProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"169":{"title":"attestationProof","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"170":{"title":"Querying the proof\'s tupleRootNonce","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"171":{"title":"Listening for new data commitments","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"172":{"title":"Example rollup that uses the DAVerifier","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"173":{"title":"Conclusion","titles":["Blobstream proofs queries"]},"174":{"title":"Introduction to Blobstream rollups","titles":[]},"175":{"title":"Concepts","titles":["Introduction to Blobstream rollups"]},"176":{"title":"Blob share commitment","titles":["Introduction to Blobstream rollups","Concepts"]},"177":{"title":"Blob share commitment: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"178":{"title":"Blob share commitment: Compact proofs","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"179":{"title":"Blob share commitment: Pros","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"180":{"title":"Blob share commitment: Cons","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"181":{"title":"Sequence of spans","titles":["Introduction to Blobstream rollups","Concepts"]},"182":{"title":"Sequence of spans: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"183":{"title":"Sequence of spans: Proving unavailable data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"184":{"title":"Sequence of spans: Proving inclusion of some data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"185":{"title":"Sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"186":{"title":"Sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"187":{"title":"Optimistic rollups","titles":["Introduction to Blobstream rollups"]},"188":{"title":"Optimistic rollups that use a sequence of spans","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"189":{"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"]},"190":{"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"]},"191":{"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"]},"192":{"title":"Optimistic rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"193":{"title":"Optimistic rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"194":{"title":"Optimistic rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"195":{"title":"Zk-rollups","titles":["Introduction to Blobstream rollups"]},"196":{"title":"Zk-rollups that use sequence of spans","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"197":{"title":"Zk-rollups that use sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"198":{"title":"Zk-rollups that use sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"199":{"title":"Zk-rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"200":{"title":"Protobuf deserialization inside a zk-circuit","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"201":{"title":"Zk-rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"202":{"title":"Zk-rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"203":{"title":"Heavy merkle proofs usage","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"204":{"title":"heavy merkle proofs usage: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"205":{"title":"heavy merkle proofs usage: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"206":{"title":"Conclusion","titles":["Introduction to Blobstream rollups"]},"207":{"title":"FAQ","titles":["Introduction to Blobstream rollups"]},"208":{"title":"Should I use the Celestia transaction hash to reference the rollup data?","titles":["Introduction to Blobstream rollups","FAQ"]},"209":{"title":"New Blobstream X deployments","titles":[]},"210":{"title":"Deploying the contracts","titles":["New Blobstream X deployments"]},"211":{"title":"Deploy a new SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"212":{"title":"Deploy the function verifiers","titles":["New Blobstream X deployments","Deploying the contracts"]},"213":{"title":"Register the function verifier in the deployed SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"214":{"title":"Enable prover whitelisting","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"215":{"title":"Set Whitelist Status","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"216":{"title":"Add Custom Prover","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"217":{"title":"Deploy the BlobstreamX contract","titles":["New Blobstream X deployments","Deploying the contracts"]},"218":{"title":"Querying the trusted hash","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"219":{"title":"Deployment instructions","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"220":{"title":"Run a local prover","titles":["New Blobstream X deployments","Deploying the contracts"]},"221":{"title":"Run a proof replayer from an existing deployment","titles":["New Blobstream X deployments","Deploying the contracts"]},"222":{"title":"Optional: Regenerating the downloaded artifacts","titles":["New Blobstream X deployments"]},"223":{"title":"Regenerate the verifier-build","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"224":{"title":"Build the circuits and function verifiers","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"225":{"title":"Requesting data commitment ranges","titles":[]},"226":{"title":"Local proving","titles":["Requesting data commitment ranges"]},"227":{"title":"Request proofs from the Succinct platform","titles":["Requesting data commitment ranges"]},"228":{"title":"Request proofs onchain","titles":["Requesting data commitment ranges"]},"229":{"title":"Blobstream: Streaming modular DA to Ethereum","titles":[]},"230":{"title":"What is Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"231":{"title":"Implementations of Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","What is Blobstream?"]},"232":{"title":"Blobstream vs. data availability committees (DACs)","titles":["Blobstream: Streaming modular DA to Ethereum"]},"233":{"title":"Decentralization and security","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"234":{"title":"Mechanism of verification","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"235":{"title":"Flexibility and scalability","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"236":{"title":"What is SP1 Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"237":{"title":"What is Blobstream X?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"238":{"title":"Integrate with Blobstream X","titles":["Blobstream: Streaming modular DA to Ethereum"]},"239":{"title":"How Blobstream X works","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with Blobstream X"]},"240":{"title":"How to integrate with Blobstream X","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with Blobstream X"]},"241":{"title":"Blobstream rollups","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with Blobstream X"]},"242":{"title":"Deployed contracts","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with Blobstream X"]},"243":{"title":"Deploy Blobstream X","titles":["Blobstream: Streaming modular DA to Ethereum"]},"244":{"title":"Bubs testnet","titles":[]},"245":{"title":"Built with the OP Stack and Celestia","titles":["Bubs testnet"]},"246":{"title":"Building on Bubs","titles":["Bubs testnet"]},"247":{"title":"RPC URLs","titles":["Bubs testnet","Building on Bubs"]},"248":{"title":"HTTPS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"249":{"title":"WSS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"250":{"title":"Bridge","titles":["Bubs testnet","Building on Bubs"]},"251":{"title":"Faucet","titles":["Bubs testnet","Building on Bubs"]},"252":{"title":"Explorer","titles":["Bubs testnet","Building on Bubs"]},"253":{"title":"Status","titles":["Bubs testnet","Building on Bubs"]},"254":{"title":"Next steps","titles":["Bubs testnet"]},"255":{"title":"Build whatever","titles":[]},"256":{"title":"Quickstart - Building on Celestia","titles":["Build whatever"]},"257":{"title":"Choose a framework","titles":["Build whatever","Quickstart - Building on Celestia"]},"258":{"title":"Rollups as a Service","titles":["Build whatever","Quickstart - Building on Celestia"]},"259":{"title":"Smart contracts","titles":["Build whatever","Quickstart - Building on Celestia"]},"260":{"title":"What is a rollup?","titles":["Build whatever"]},"261":{"title":"What is a modular blockchain?","titles":["Build whatever"]},"262":{"title":"Benefits of modular blockchains","titles":["Build whatever"]},"263":{"title":"Ease of deploying a chain","titles":["Build whatever","Benefits of modular blockchains"]},"264":{"title":"Scaling","titles":["Build whatever","Benefits of modular blockchains"]},"265":{"title":"Customizability","titles":["Build whatever","Benefits of modular blockchains"]},"266":{"title":"Create a wallet with celestia-node","titles":[]},"267":{"title":"Using the cel-key utility","titles":["Create a wallet with celestia-node"]},"268":{"title":"Installation","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"269":{"title":"Steps for generating node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"270":{"title":"Steps for exporting node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"271":{"title":"Steps for importing node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"272":{"title":"View all options for cel-key","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"273":{"title":"Docker and cel-key","titles":["Create a wallet with celestia-node"]},"274":{"title":"Prerequisites","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"275":{"title":"Running your node","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"276":{"title":"Mounting existing keys to container","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"277":{"title":"Deploy a smart contract on Bubs testnet","titles":[]},"278":{"title":"Dependencies","titles":["Deploy a smart contract on Bubs testnet"]},"279":{"title":"Setup","titles":["Deploy a smart contract on Bubs testnet"]},"280":{"title":"Create your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"281":{"title":"Test your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"282":{"title":"Deploying your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"283":{"title":"Using Anvil","titles":["Deploy a smart contract on Bubs testnet","Deploying your smart contract"]},"284":{"title":"Using Bubs","titles":["Deploy a smart contract on Bubs testnet","Deploying your smart contract"]},"285":{"title":"Interacting with your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"286":{"title":"Next steps","titles":["Deploy a smart contract on Bubs testnet"]},"287":{"title":"Ethereum fallback","titles":[]},"288":{"title":"FeeGrant module for blobs submission","titles":[]},"289":{"title":"Overview","titles":["FeeGrant module for blobs submission"]},"290":{"title":"Pre-requisites","titles":["FeeGrant module for blobs submission"]},"291":{"title":"Introduction","titles":["FeeGrant module for blobs submission"]},"292":{"title":"Granting fee allowances using celestia-node","titles":["FeeGrant module for blobs submission"]},"293":{"title":"FeeGrant module implementation in celestia-node","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"294":{"title":"Grant permission for an allowance as a granter","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"295":{"title":"Using a FeeGrant allowance as a grantee in celestia-node","titles":["FeeGrant module for blobs submission"]},"296":{"title":"Checking account balances after submission","titles":["FeeGrant module for blobs submission"]},"297":{"title":"Optional: Revoke permission for a FeeGrant allowance as a granter","titles":["FeeGrant module for blobs submission"]},"298":{"title":"Optional: Submitting a blob from file input","titles":["FeeGrant module for blobs submission","Optional: Revoke permission for a FeeGrant allowance as a granter"]},"299":{"title":"Optional: Granting fee allowances using celestia-appd","titles":["FeeGrant module for blobs submission"]},"300":{"title":"Optional: Checking the granter\'s account","titles":["FeeGrant module for blobs submission","Optional: Granting fee allowances using celestia-appd"]},"301":{"title":"Full stack modular blockchain development guide","titles":[]},"302":{"title":"Getting started","titles":["Full stack modular blockchain development guide"]},"303":{"title":"Pre-requisites","titles":["Full stack modular blockchain development guide","Getting started"]},"304":{"title":"Project setup","titles":["Full stack modular blockchain development guide","Getting started"]},"305":{"title":"Updating the contract and tests","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"306":{"title":"Running the test","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"307":{"title":"Updating the deployment script","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"308":{"title":"Deploying locally","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"309":{"title":"Deploying to the Ethermint Sovereign Rollup","titles":["Full stack modular blockchain development guide","Getting started"]},"310":{"title":"Building the frontend","titles":["Full stack modular blockchain development guide","Getting started"]},"311":{"title":"Configuring environment variables","titles":["Full stack modular blockchain development guide","Getting started","Building the frontend"]},"312":{"title":"Configuring the entrypoint","titles":["Full stack modular blockchain development guide","Getting started"]},"313":{"title":"Creating and reading posts","titles":["Full stack modular blockchain development guide","Getting started"]},"314":{"title":"Adding Ethermint Chain to MetaMask","titles":["Full stack modular blockchain development guide","Getting started"]},"315":{"title":"Testing it out on Ethermint","titles":["Full stack modular blockchain development guide","Getting started"]},"316":{"title":"Now give it a spin 🌀","titles":["Full stack modular blockchain development guide","Getting started"]},"317":{"title":"Deploying a dapp on Bubs testnet","titles":[]},"318":{"title":"Update the frontend","titles":["Deploying a dapp on Bubs testnet"]},"319":{"title":"Interact with the frontend","titles":["Deploying a dapp on Bubs testnet"]},"320":{"title":"Next steps","titles":["Deploying a dapp on Bubs testnet"]},"321":{"title":"Golang client library tutorial","titles":[]},"322":{"title":"Project setup","titles":["Golang client library tutorial"]},"323":{"title":"Submitting and retrieving blobs","titles":["Golang client library tutorial"]},"324":{"title":"Subscribing to new blobs","titles":["Golang client library tutorial"]},"325":{"title":"Subscribing to new headers","titles":["Golang client library tutorial"]},"326":{"title":"Fetching an Extended Data Square (EDS)","titles":["Golang client library tutorial"]},"327":{"title":"API documentation","titles":["Golang client library tutorial"]},"328":{"title":"Integrate Celestia for service providers","titles":[]},"329":{"title":"Getting started","titles":["Integrate Celestia for service providers"]},"330":{"title":"Celestia service provider notes","titles":["Integrate Celestia for service providers"]},"331":{"title":"Custody and key management","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"332":{"title":"RPC and querying","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"333":{"title":"Compatibility","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"334":{"title":"Syncing","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"335":{"title":"Notable exceptions relative to other blockchains","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"336":{"title":"Introduction to OP Stack integration","titles":[]},"337":{"title":"About the integration","titles":["Introduction to OP Stack integration"]},"338":{"title":"GitHub repository","titles":["Introduction to OP Stack integration","About the integration"]},"339":{"title":"Category contents","titles":["Introduction to OP Stack integration"]},"340":{"title":"Next steps","titles":["Introduction to OP Stack integration"]},"341":{"title":"Node API","titles":[]},"342":{"title":"RPC API","titles":["Node API"]},"343":{"title":"Library","titles":["Node API","RPC API"]},"344":{"title":"RPC","titles":["Node API","RPC API"]},"345":{"title":"RPC API tutorial","titles":["Node API","RPC API"]},"346":{"title":"Gateway API","titles":["Node API"]},"347":{"title":"Gateway API tutorial","titles":["Node API","Gateway API"]},"348":{"title":"Celestia-node RPC CLI tutorial","titles":[]},"349":{"title":"Introduction","titles":["Celestia-node RPC CLI tutorial"]},"350":{"title":"Blobs","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"351":{"title":"Namespaces","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"352":{"title":"Hardware requirements","titles":["Celestia-node RPC CLI tutorial"]},"353":{"title":"Setting up dependencies","titles":["Celestia-node RPC CLI tutorial"]},"354":{"title":"Instantiate a Celestia light node","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"355":{"title":"Connect to a core endpoint","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"356":{"title":"Keys and wallets","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"357":{"title":"RPC CLI guide","titles":["Celestia-node RPC CLI tutorial"]},"358":{"title":"Command formatting","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"359":{"title":"Basic flags","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"360":{"title":"Auth token 🔐","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"361":{"title":"Node store","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"362":{"title":"Auth token on custom or private network","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags","Node store"]},"363":{"title":"Submitting data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"364":{"title":"Optional: Submit with curl","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Submitting data"]},"365":{"title":"Retrieving data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"366":{"title":"Setting the gas price","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"367":{"title":"Examples","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"368":{"title":"Check your balance","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"369":{"title":"Check the balance of another address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"370":{"title":"Get your node ID","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"371":{"title":"Get your account address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"372":{"title":"Get block header by height","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"373":{"title":"Combined commands","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"374":{"title":"Get data availability sampler stats","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"375":{"title":"Transfer balance of utia to another account","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"376":{"title":"API version","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"377":{"title":"Help","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"378":{"title":"Advanced example","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"379":{"title":"Additional resources","titles":["Celestia-node RPC CLI tutorial"]},"380":{"title":"Submitting a blob using curl","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"381":{"title":"Post an SVG as a PFB","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"382":{"title":"Troubleshooting","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"383":{"title":"Optimism devnet deep dive","titles":[]},"384":{"title":"Find a transaction","titles":["Optimism devnet deep dive"]},"385":{"title":"Read the transaction call data","titles":["Optimism devnet deep dive"]},"386":{"title":"Find the data on Celestia","titles":["Optimism devnet deep dive"]},"387":{"title":"Span batches","titles":["Optimism devnet deep dive"]},"388":{"title":"Run an OP Stack rollup with Celestia underneath","titles":[]},"389":{"title":"Dependency setup","titles":["Run an OP Stack rollup with Celestia underneath"]},"390":{"title":"Setting up your light node","titles":["Run an OP Stack rollup with Celestia underneath","Dependency setup"]},"391":{"title":"Deploying a devnet to Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"392":{"title":"Deploying a testnet to an L1 (or L2) and Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"393":{"title":"Congratulations","titles":["Run an OP Stack rollup with Celestia underneath"]},"394":{"title":"Prompt scavenger","titles":[]},"395":{"title":"Dependencies","titles":["Prompt scavenger"]},"396":{"title":"Install Celestia Node and run a light node","titles":["Prompt scavenger","Dependencies"]},"397":{"title":"OpenAI key","titles":["Prompt scavenger","Dependencies"]},"398":{"title":"Building the Prompt Scavenger","titles":["Prompt scavenger"]},"399":{"title":"Initialize your Go project","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"400":{"title":"Build your import statements","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"401":{"title":"Main function","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"402":{"title":"Utility functions","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"403":{"title":"Prompting ChatGPT","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"404":{"title":"Wrapping things up","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"405":{"title":"Next steps","titles":["Prompt scavenger"]},"406":{"title":"Rust client library tutorial","titles":[]},"407":{"title":"Project setup","titles":["Rust client library tutorial"]},"408":{"title":"Submitting and retrieving blobs","titles":["Rust client library tutorial"]},"409":{"title":"Subscribing to new headers","titles":["Rust client library tutorial"]},"410":{"title":"Fetching an Extended Data Square (EDS)","titles":["Rust client library tutorial"]},"411":{"title":"API documentation","titles":["Rust client library tutorial"]},"412":{"title":"New SP1 Blobstream deployments","titles":[]},"413":{"title":"Deploying the contracts","titles":["New SP1 Blobstream deployments"]},"414":{"title":"Submitting data blobs to Celestia","titles":[]},"415":{"title":"Maximum blob size","titles":["Submitting data blobs to Celestia"]},"416":{"title":"Fee market and mempool","titles":["Submitting data blobs to Celestia"]},"417":{"title":"Fees and gas limits","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"418":{"title":"Estimating PFB gas","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"419":{"title":"Gas fee calculation","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"420":{"title":"Estimating gas programmatically","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"421":{"title":"Submitting multiple transactions in one block from the same account","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"422":{"title":"API","titles":["Submitting data blobs to Celestia"]},"423":{"title":"The celestia-app consensus node CLI","titles":["Submitting data blobs to Celestia","API"]},"424":{"title":"The celestia-node light node CLI","titles":["Submitting data blobs to Celestia","API"]},"425":{"title":"The celestia-node API golang client","titles":["Submitting data blobs to Celestia","API"]},"426":{"title":"GRPC to a consensus node via the user package","titles":["Submitting data blobs to Celestia","API"]},"427":{"title":"RPC to a celestia-node","titles":["Submitting data blobs to Celestia","API"]},"428":{"title":"Transaction resubmission","titles":[]},"429":{"title":"Monitoring and resubmission","titles":["Transaction resubmission"]},"430":{"title":"Notes","titles":["Transaction resubmission"]},"431":{"title":"Wallet integrations with Celestia","titles":[]},"432":{"title":"Add Celestia network parameters to Keplr with React","titles":["Wallet integrations with Celestia"]},"433":{"title":"Adding a custom chain to Leap","titles":["Wallet integrations with Celestia"]},"434":{"title":"Adding a custom chain to Cosmostation","titles":["Wallet integrations with Celestia"]},"435":{"title":"Data availability FAQ","titles":[]},"436":{"title":"What is data availability?","titles":["Data availability FAQ"]},"437":{"title":"What is the data availability problem?","titles":["Data availability FAQ"]},"438":{"title":"How do nodes verify data availability in Celestia?","titles":["Data availability FAQ"]},"439":{"title":"What is data availability sampling?","titles":["Data availability FAQ"]},"440":{"title":"What are some of the security assumptions that Celestia makes for data availability sampling?","titles":["Data availability FAQ"]},"441":{"title":"Why is block reconstruction necessary for security?","titles":["Data availability FAQ"]},"442":{"title":"What is data storage?","titles":["Data availability FAQ"]},"443":{"title":"What is the problem around data storage?","titles":["Data availability FAQ"]},"444":{"title":"What is the difference between data availability and data storage?","titles":["Data availability FAQ"]},"445":{"title":"Where does blockchain state fit into this?","titles":["Data availability FAQ"]},"446":{"title":"Why doesn’t Celestia incentivize storage of historical data?","titles":["Data availability FAQ"]},"447":{"title":"Who may store historical data if there is no reward?","titles":["Data availability FAQ"]},"448":{"title":"What are some things blockchains can do to provide stronger assurances of data retrievability?","titles":["Data availability FAQ"]},"449":{"title":"Celestia\'s data availability layer","titles":[]},"450":{"title":"Data availability sampling (DAS)","titles":["Celestia\'s data availability layer"]},"451":{"title":"Scalability","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"452":{"title":"Fraud proofs of incorrectly extended data","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"453":{"title":"Namespaced Merkle trees (NMTs)","titles":["Celestia\'s data availability layer"]},"454":{"title":"Building a PoS blockchain for DA","titles":["Celestia\'s data availability layer"]},"455":{"title":"Providing data availability","titles":["Celestia\'s data availability layer","Building a PoS blockchain for DA"]},"456":{"title":"Monolithic vs. modular blockchains","titles":[]},"457":{"title":"Introduction","titles":[]},"458":{"title":"The lifecycle of a celestia-app transaction","titles":[]},"459":{"title":"Checking data availability","titles":["The lifecycle of a celestia-app transaction"]},"460":{"title":"How to stake TIA","titles":[]},"461":{"title":"Select your preferred wallet","titles":["How to stake TIA"]},"462":{"title":"Stake TIA with Keplr wallet","titles":["How to stake TIA"]},"463":{"title":"1️⃣ Open your Keplr browser extension","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"464":{"title":"2️⃣ Select Celestia network and search for a validator","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"465":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"466":{"title":"4️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"467":{"title":"Stake TIA with Leap wallet","titles":["How to stake TIA"]},"468":{"title":"1️⃣ Open your Leap browser extension","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"469":{"title":"2️⃣ Select a validator and stake TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"470":{"title":"3️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"471":{"title":"Stake TIA with Gem wallet","titles":["How to stake TIA"]},"472":{"title":"1️⃣ Open your Gem Wallet app","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"473":{"title":"2️⃣ Choose the amount of Celestia and search for a validator.","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"474":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"475":{"title":"4️⃣ Manage your TIA","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"476":{"title":"Paying for blobspace","titles":[]},"477":{"title":"PayForBlobs transactions","titles":["Paying for blobspace"]},"478":{"title":"Fee market overview","titles":["Paying for blobspace"]},"479":{"title":"Data retrievability and pruning","titles":[]},"480":{"title":"Data retrievability and pruning in celestia-node","titles":["Data retrievability and pruning"]},"481":{"title":"Suggested practices for rollups","titles":["Data retrievability and pruning"]},"482":{"title":"Staking, governance, & supply","titles":[]},"483":{"title":"Proof-of-stake on Celestia","titles":["Staking, governance, & supply"]},"484":{"title":"Inflation","titles":["Staking, governance, & supply"]},"485":{"title":"Decentralised governance","titles":["Staking, governance, & supply"]},"486":{"title":"Network parameters","titles":["Staking, governance, & supply","Decentralised governance"]},"487":{"title":"Community pool","titles":["Staking, governance, & supply","Decentralised governance"]},"488":{"title":"TIA allocation at genesis","titles":["Staking, governance, & supply"]},"489":{"title":"Unlocks","titles":["Staking, governance, & supply","TIA allocation at genesis"]},"490":{"title":"Staking on Celestia","titles":[]},"491":{"title":"Mainnet Beta","titles":["Staking on Celestia"]},"492":{"title":"Mocha testnet","titles":["Staking on Celestia"]},"493":{"title":"Overview of TIA","titles":[]},"494":{"title":"TIA at a glance","titles":["Overview of TIA"]},"495":{"title":"Role of TIA","titles":["Overview of TIA"]},"496":{"title":"Paying for blobspace","titles":["Overview of TIA","Role of TIA"]},"497":{"title":"Bootstrapping new rollups","titles":["Overview of TIA","Role of TIA"]},"498":{"title":"Proof-of-stake","titles":["Overview of TIA","Role of TIA"]},"499":{"title":"Decentralised governance","titles":["Overview of TIA","Role of TIA"]},"500":{"title":"Denominations","titles":["Overview of TIA","Role of TIA"]},"501":{"title":"TIA: display token","titles":["Overview of TIA","Role of TIA","Denominations"]},"502":{"title":"utia: staking denomination","titles":["Overview of TIA","Role of TIA","Denominations"]},"503":{"title":"microtia: staking denomination alias","titles":["Overview of TIA","Role of TIA","Denominations"]},"504":{"title":"Arabica devnet","titles":[]},"505":{"title":"Network stability and upgrades","titles":["Arabica devnet"]},"506":{"title":"Network details","titles":["Arabica devnet"]},"507":{"title":"Software version numbers","titles":["Arabica devnet","Network details"]},"508":{"title":"Integrations","titles":["Arabica devnet"]},"509":{"title":"Production RPC endpoints","titles":["Arabica devnet","Integrations"]},"510":{"title":"Community RPC endpoints","titles":["Arabica devnet","Integrations"]},"511":{"title":"Using consensus endpoints with DA nodes","titles":["Arabica devnet","Integrations"]},"512":{"title":"Data availability (DA) RPC endpoints for bridge node sync","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"513":{"title":"Data availability (DA) gRPC endpoints for state access","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"514":{"title":"Arabica devnet faucet","titles":["Arabica devnet"]},"515":{"title":"Discord","titles":["Arabica devnet","Arabica devnet faucet"]},"516":{"title":"Web","titles":["Arabica devnet","Arabica devnet faucet"]},"517":{"title":"Explorers","titles":["Arabica devnet"]},"518":{"title":"Network upgrades","titles":["Arabica devnet"]},"519":{"title":"Setting up a Celestia bridge node","titles":[]},"520":{"title":"Overview of bridge nodes","titles":["Setting up a Celestia bridge node"]},"521":{"title":"Hardware requirements","titles":["Setting up a Celestia bridge node"]},"522":{"title":"Setting up your bridge node","titles":["Setting up a Celestia bridge node"]},"523":{"title":"Setup the dependencies","titles":["Setting up a Celestia bridge node","Setting up your bridge node"]},"524":{"title":"Deploy the Celestia bridge node","titles":["Setting up a Celestia bridge node"]},"525":{"title":"Install Celestia Node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"526":{"title":"Initialize the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"527":{"title":"Run the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"528":{"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"]},"529":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"530":{"title":"Helpful CLI commands","titles":[]},"531":{"title":"Creating a wallet","titles":["Helpful CLI commands"]},"532":{"title":"Key management","titles":["Helpful CLI commands"]},"533":{"title":"Importing and exporting keys","titles":["Helpful CLI commands","Key management"]},"534":{"title":"Querying subcommands","titles":["Helpful CLI commands"]},"535":{"title":"Token management","titles":["Helpful CLI commands"]},"536":{"title":"Governance","titles":["Helpful CLI commands"]},"537":{"title":"Community Pool","titles":["Helpful CLI commands","Governance"]},"538":{"title":"Claim validator rewards","titles":["Helpful CLI commands"]},"539":{"title":"Delegate & undelegate tokens","titles":["Helpful CLI commands"]},"540":{"title":"Unjailing the validator","titles":["Helpful CLI commands"]},"541":{"title":"How to export logs with SystemD","titles":["Helpful CLI commands"]},"542":{"title":"Signing genesis for a new network","titles":["Helpful CLI commands"]},"543":{"title":"Metrics","titles":[]},"544":{"title":"Setup","titles":["Metrics"]},"545":{"title":"Visualization","titles":["Metrics"]},"546":{"title":"Node exporter","titles":["Metrics"]},"547":{"title":"Alerts","titles":["Metrics"]},"548":{"title":"Multisig","titles":[]},"549":{"title":"Command line","titles":["Multisig"]},"550":{"title":"Resources","titles":["Multisig"]},"551":{"title":"Jailing and Slashing on Celestia","titles":[]},"552":{"title":"Upgrade Monitor","titles":[]},"553":{"title":"How to create a vesting account with celestia-app","titles":[]},"554":{"title":"Local devnet","titles":["How to create a vesting account with celestia-app"]},"555":{"title":"Setting up the local devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"556":{"title":"Run the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"557":{"title":"Save the home directory path","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"558":{"title":"Check the version of the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"559":{"title":"Next steps","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"560":{"title":"Setting up vesting account on devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"561":{"title":"Create a new key","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"562":{"title":"List your keys","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"563":{"title":"Set variables","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"564":{"title":"Create your devnet vesting account","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"565":{"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"]},"566":{"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"]},"567":{"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"]},"568":{"title":"Mocha","titles":["How to create a vesting account with celestia-app"]},"569":{"title":"Create a wallet","titles":["How to create a vesting account with celestia-app","Mocha"]},"570":{"title":"Fund your account","titles":["How to create a vesting account with celestia-app","Mocha"]},"571":{"title":"Create a vesting account on Mocha","titles":["How to create a vesting account with celestia-app","Mocha"]},"572":{"title":"Optional: Set up a consensus node or validator","titles":["How to create a vesting account with celestia-app","Mocha"]},"573":{"title":"Optional: Change your client.toml","titles":["How to create a vesting account with celestia-app","Mocha"]},"574":{"title":"Notes","titles":["How to create a vesting account with celestia-app"]},"575":{"title":"Conclusion","titles":["How to create a vesting account with celestia-app"]},"576":{"title":"Create a wallet with celestia-app","titles":[]},"577":{"title":"Prerequisites","titles":["Create a wallet with celestia-app"]},"578":{"title":"Create a wallet","titles":["Create a wallet with celestia-app"]},"579":{"title":"Fund a wallet","titles":["Create a wallet with celestia-app"]},"580":{"title":"Install celestia-app","titles":[]},"581":{"title":"Building binary from source","titles":["Install celestia-app"]},"582":{"title":"Installing a pre-built binary","titles":["Install celestia-app"]},"583":{"title":"Ports","titles":["Install celestia-app"]},"584":{"title":"Custom networks and values","titles":[]},"585":{"title":"celestia-node metrics","titles":[]},"586":{"title":"Running metrics flags","titles":["celestia-node metrics"]},"587":{"title":"Mainnet Beta","titles":["celestia-node metrics","Running metrics flags"]},"588":{"title":"Mocha testnet","titles":["celestia-node metrics","Running metrics flags"]},"589":{"title":"TLS connections","titles":["celestia-node metrics","Running metrics flags"]},"590":{"title":"Metrics endpoint design considerations","titles":["celestia-node metrics"]},"591":{"title":"Troubleshooting","titles":[]},"592":{"title":"Network selection","titles":["Troubleshooting"]},"593":{"title":"Chain ID","titles":["Troubleshooting","Network selection"]},"594":{"title":"Ports","titles":["Troubleshooting"]},"595":{"title":"Changing the location of your node store","titles":["Troubleshooting"]},"596":{"title":"Background","titles":["Troubleshooting","Changing the location of your node store"]},"597":{"title":"Demonstration","titles":["Troubleshooting","Changing the location of your node store"]},"598":{"title":"Examples","titles":["Troubleshooting","Changing the location of your node store"]},"599":{"title":"Mainnet Beta full and Mocha light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"600":{"title":"Mocha full and Arabica light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"601":{"title":"Using a custom rpc.config address","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"602":{"title":"Resetting your config","titles":["Troubleshooting"]},"603":{"title":"Clearing the data store","titles":["Troubleshooting"]},"604":{"title":"FATAL headers given to the heightSub are in the wrong order","titles":["Troubleshooting"]},"605":{"title":"Error: "too many open files"","titles":["Troubleshooting"]},"606":{"title":"Syncing a light node from a trusted hash","titles":[]},"607":{"title":"For service operators","titles":["Syncing a light node from a trusted hash"]},"608":{"title":"Install celestia-node","titles":[]},"609":{"title":"Installing from source","titles":["Install celestia-node"]},"610":{"title":"Installing a pre-built binary","titles":["Install celestia-node"]},"611":{"title":"Next steps","titles":["Install celestia-node"]},"612":{"title":"Upgrading your binary","titles":["Install celestia-node"]},"613":{"title":"config.toml guide","titles":[]},"614":{"title":"Pre-requisites","titles":["config.toml guide"]},"615":{"title":"Understanding config.toml","titles":["config.toml guide"]},"616":{"title":"Core","titles":["config.toml guide","Understanding config.toml"]},"617":{"title":"P2P","titles":["config.toml guide","Understanding config.toml"]},"618":{"title":"Bootstrap","titles":["config.toml guide","Understanding config.toml","P2P"]},"619":{"title":"Mutual peers","titles":["config.toml guide","Understanding config.toml","P2P"]},"620":{"title":"Services","titles":["config.toml guide","Understanding config.toml"]},"621":{"title":"TrustedHash and TrustedPeer","titles":["config.toml guide","Understanding config.toml","Services"]},"622":{"title":"Consensus node","titles":[]},"623":{"title":"Minimum hardware requirements","titles":["Consensus node"]},"624":{"title":"Set up a consensus node","titles":["Consensus node"]},"625":{"title":"Set up the dependencies","titles":["Consensus node","Set up a consensus node"]},"626":{"title":"Install celestia-app","titles":["Consensus node","Set up a consensus node"]},"627":{"title":"Set up the P2P networks","titles":["Consensus node","Set up a consensus node"]},"628":{"title":"Storage and pruning configurations","titles":["Consensus node"]},"629":{"title":"Optional: Connect a consensus node to a bridge node","titles":["Consensus node","Storage and pruning configurations"]},"630":{"title":"Enable transaction indexing","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"631":{"title":"Retain all block data","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"632":{"title":"Query transactions by hash","titles":["Consensus node","Storage and pruning configurations"]},"633":{"title":"Optional: Access historical state","titles":["Consensus node","Storage and pruning configurations"]},"634":{"title":"Save on storage requirements","titles":["Consensus node","Storage and pruning configurations"]},"635":{"title":"Sync types","titles":["Consensus node"]},"636":{"title":"Option 1: Block sync","titles":["Consensus node","Sync types"]},"637":{"title":"Option 2: State sync","titles":["Consensus node","Sync types"]},"638":{"title":"Option 3: Quick sync","titles":["Consensus node","Sync types"]},"639":{"title":"Start the consensus node","titles":["Consensus node"]},"640":{"title":"Extra resources for consensus nodes","titles":["Consensus node"]},"641":{"title":"Optional: Reset network","titles":["Consensus node","Extra resources for consensus nodes"]},"642":{"title":"Optional: Configure an RPC endpoint","titles":["Consensus node","Extra resources for consensus nodes"]},"643":{"title":"Expose RPC","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"644":{"title":"Note on external-address","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"645":{"title":"Restart the node","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"646":{"title":"Optional: Transaction indexer configuration options","titles":["Consensus node","Extra resources for consensus nodes"]},"647":{"title":"Optional: Discard ABCI responses configuration","titles":["Consensus node","Extra resources for consensus nodes"]},"648":{"title":"FAQ","titles":["Consensus node"]},"649":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Consensus node","FAQ"]},"650":{"title":"Deciding which node to run","titles":[]},"651":{"title":"Beginner","titles":["Deciding which node to run"]},"652":{"title":"Advanced","titles":["Deciding which node to run"]},"653":{"title":"🐳 Docker setup","titles":[]},"654":{"title":"Prerequisites","titles":["🐳 Docker setup"]},"655":{"title":"Quick start","titles":["🐳 Docker setup"]},"656":{"title":"Light node setup with persistent storage","titles":["🐳 Docker setup"]},"657":{"title":"Initialize the node store and key","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"658":{"title":"Start the node","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"659":{"title":"Video walkthrough","titles":["🐳 Docker setup"]},"660":{"title":"2.5 minute version","titles":["🐳 Docker setup","Video walkthrough"]},"661":{"title":"Troubleshooting","titles":["🐳 Docker setup"]},"662":{"title":"Development environment","titles":[]},"663":{"title":"Install dependencies","titles":["Development environment"]},"664":{"title":"Install Golang","titles":["Development environment"]},"665":{"title":"Setting up a Celestia full storage Node","titles":[]},"666":{"title":"Overview of full storage nodes","titles":["Setting up a Celestia full storage Node"]},"667":{"title":"Hardware requirements","titles":["Setting up a Celestia full storage Node"]},"668":{"title":"Setting up your full storage node","titles":["Setting up a Celestia full storage Node"]},"669":{"title":"Setup the dependencies","titles":["Setting up a Celestia full storage Node","Setting up your full storage node"]},"670":{"title":"Install celestia-node","titles":["Setting up a Celestia full storage Node"]},"671":{"title":"Run the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"672":{"title":"Initialize the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"673":{"title":"Start the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"674":{"title":"Optional: run the full storage node with a custom key","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"675":{"title":"Optional: start the full storage node with SystemD","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"676":{"title":"Stop the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"677":{"title":"Celestia hardfork process","titles":[]},"678":{"title":"General process","titles":["Celestia hardfork process"]},"679":{"title":"Lemongrass hardfork","titles":["Celestia hardfork process","General process"]},"680":{"title":"IBC relaying guide","titles":[]},"681":{"title":"Hermes","titles":["IBC relaying guide"]},"682":{"title":"Configuration","titles":["IBC relaying guide","Hermes"]},"683":{"title":"Add relayer wallets","titles":["IBC relaying guide","Hermes"]},"684":{"title":"Verify configuration files","titles":["IBC relaying guide","Hermes"]},"685":{"title":"Create a connection between 2 chains","titles":["IBC relaying guide"]},"686":{"title":"Create clients","titles":["IBC relaying guide"]},"687":{"title":"Open connection over new clients","titles":["IBC relaying guide","Create clients"]},"688":{"title":"Configure channels in Hermes","titles":["IBC relaying guide","Create clients"]},"689":{"title":"Start the relayer","titles":["IBC relaying guide"]},"690":{"title":"Transfer","titles":["IBC relaying guide"]},"691":{"title":"Token filter","titles":["IBC relaying guide","Transfer"]},"692":{"title":"Celestia App network instantiation guide","titles":[]},"693":{"title":"Hardware requirements","titles":["Celestia App network instantiation guide"]},"694":{"title":"Setup dependencies","titles":["Celestia App network instantiation guide"]},"695":{"title":"celestia-app installation","titles":["Celestia App network instantiation guide"]},"696":{"title":"Spin up a Celestia testnet","titles":["Celestia App network instantiation guide"]},"697":{"title":"Optional: Reset working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"698":{"title":"Initialize a working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"699":{"title":"Create a new key","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"700":{"title":"Add genesis account KeyName","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"701":{"title":"Optional: Adding other validators","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"702":{"title":"Create the genesis transaction for new chain","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"703":{"title":"Creating the genesis JSON file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"704":{"title":"Modify your config file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"705":{"title":"Add your node as a persistent peer","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"706":{"title":"Instantiate the network","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"707":{"title":"Setting up a Celestia light node","titles":[]},"708":{"title":"Overview of light nodes","titles":["Setting up a Celestia light node"]},"709":{"title":"Hardware requirements","titles":["Setting up a Celestia light node"]},"710":{"title":"Setting up your light node","titles":["Setting up a Celestia light node"]},"711":{"title":"Install celestia-node","titles":["Setting up a Celestia light node","Setting up your light node"]},"712":{"title":"Initialize the light node","titles":["Setting up a Celestia light node"]},"713":{"title":"Start the light node","titles":["Setting up a Celestia light node"]},"714":{"title":"Keys and wallets","titles":["Setting up a Celestia light node","Start the light node"]},"715":{"title":"Testnet tokens","titles":["Setting up a Celestia light node","Start the light node","Keys and wallets"]},"716":{"title":"Optional: run the light node with a custom key","titles":["Setting up a Celestia light node","Start the light node"]},"717":{"title":"Optional: start light node with SystemD","titles":["Setting up a Celestia light node","Start the light node"]},"718":{"title":"Data availability sampling","titles":["Setting up a Celestia light node"]},"719":{"title":"Mainnet Beta","titles":[]},"720":{"title":"Network stability and upgrades","titles":["Mainnet Beta"]},"721":{"title":"Network details","titles":["Mainnet Beta"]},"722":{"title":"Software version numbers","titles":["Mainnet Beta"]},"723":{"title":"Network parameters","titles":["Mainnet Beta"]},"724":{"title":"Maximum bytes","titles":["Mainnet Beta","Network parameters"]},"725":{"title":"Integrations","titles":["Mainnet Beta"]},"726":{"title":"Production RPC endpoints","titles":["Mainnet Beta","Integrations"]},"727":{"title":"Consensus nodes","titles":["Mainnet Beta","Integrations"]},"728":{"title":"Community consensus RPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"729":{"title":"Community API endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"730":{"title":"Community gRPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"731":{"title":"Community WebSocket endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"732":{"title":"Data availability nodes","titles":["Mainnet Beta","Integrations"]},"733":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"734":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"735":{"title":"Archival DA RPC endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"736":{"title":"Grove archival endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes","Archival DA RPC endpoints"]},"737":{"title":"Explorers","titles":["Mainnet Beta"]},"738":{"title":"Analytics","titles":["Mainnet Beta"]},"739":{"title":"Network upgrades","titles":["Mainnet Beta"]},"740":{"title":"Mocha testnet","titles":[]},"741":{"title":"Network details","titles":["Mocha testnet"]},"742":{"title":"Software version numbers","titles":["Mocha testnet"]},"743":{"title":"RPC for DA bridge, full, and light nodes","titles":["Mocha testnet"]},"744":{"title":"Production RPC endpoints","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"745":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"746":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"747":{"title":"Community RPC endpoints","titles":["Mocha testnet"]},"748":{"title":"Community API endpoints","titles":["Mocha testnet"]},"749":{"title":"Community gRPC endpoints","titles":["Mocha testnet"]},"750":{"title":"Community bridge and full node endpoints","titles":["Mocha testnet"]},"751":{"title":"Mocha testnet faucet","titles":["Mocha testnet"]},"752":{"title":"Analytics","titles":["Mocha testnet"]},"753":{"title":"Explorers","titles":["Mocha testnet"]},"754":{"title":"Network upgrades","titles":["Mocha testnet"]},"755":{"title":"Overview to running nodes on Celestia","titles":[]},"756":{"title":"Recommended Celestia node requirements","titles":["Overview to running nodes on Celestia"]},"757":{"title":"Data availability nodes","titles":["Overview to running nodes on Celestia"]},"758":{"title":"Consensus nodes","titles":["Overview to running nodes on Celestia"]},"759":{"title":"Participate in the Celestia networks","titles":[]},"760":{"title":"Mainnet Beta","titles":["Participate in the Celestia networks"]},"761":{"title":"Compatible software versions for Mainnet Beta","titles":["Participate in the Celestia networks","Mainnet Beta"]},"762":{"title":"Testnets","titles":["Participate in the Celestia networks"]},"763":{"title":"Arabica Devnet","titles":["Participate in the Celestia networks","Testnets"]},"764":{"title":"Compatible software versions for Arabica devnet","titles":["Participate in the Celestia networks","Testnets","Arabica Devnet"]},"765":{"title":"Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"766":{"title":"Compatible software versions for Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"767":{"title":"Network upgrades","titles":["Participate in the Celestia networks"]},"768":{"title":"Quick start guide","titles":[]},"769":{"title":"Celestia Node","titles":["Quick start guide"]},"770":{"title":"Celestia App","titles":["Quick start guide"]},"771":{"title":"Getting started","titles":["Quick start guide"]},"772":{"title":"Setting up your node as a background process with SystemD","titles":[]},"773":{"title":"Consensus nodes","titles":["Setting up your node as a background process with SystemD"]},"774":{"title":"Start the celestia-app with SystemD","titles":["Setting up your node as a background process with SystemD","Consensus nodes"]},"775":{"title":"Data availability nodes","titles":["Setting up your node as a background process with SystemD"]},"776":{"title":"Celestia full storage node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"777":{"title":"Celestia bridge node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"778":{"title":"Celestia light node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"779":{"title":"Setting up a Celestia validator node","titles":[]},"780":{"title":"Hardware requirements","titles":["Setting up a Celestia validator node"]},"781":{"title":"Setting up a validator node","titles":["Setting up a Celestia validator node"]},"782":{"title":"Wallet","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"783":{"title":"Delegate stake to a validator","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"784":{"title":"Optional: Deploy the celestia-node","titles":["Setting up a Celestia validator node"]},"785":{"title":"Install celestia-node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"786":{"title":"Initialize the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"787":{"title":"Run the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"788":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node","Run the bridge node"]},"789":{"title":"Run the validator node","titles":["Setting up a Celestia validator node"]},"790":{"title":"Submit your validator information","titles":["Setting up a Celestia validator node"]},"791":{"title":"Optional: Transaction indexer configuration options","titles":["Setting up a Celestia validator node"]},"792":{"title":"Additional resources","titles":["Setting up a Celestia validator node"]},"793":{"title":"FAQ","titles":["Setting up a Celestia validator node"]},"794":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Setting up a Celestia validator node","FAQ"]}},"dirtCount":0,"index":[["∑i=1nssn",{"2":{"419":1}}],["×ss×gcpbb",{"2":{"419":1}}],["🌀",{"0":{"316":1}}],["🌉🌉🌉🌉🌉",{"2":{"91":2}}],["|",{"2":{"315":2,"363":4,"365":2,"373":2,"375":2,"378":2,"385":4,"387":1,"534":4,"627":14,"638":12,"774":4}}],["||",{"2":{"267":2}}],[">",{"2":{"257":1,"258":3}}],["^external",{"2":{"644":2}}],["^persistent",{"2":{"627":6}}],["^seeds",{"2":{"627":4}}],["^",{"2":{"212":2,"223":4,"224":4}}],["^0",{"2":{"116":2,"117":2,"127":2,"172":2,"280":2,"281":2,"305":4,"307":2}}],["\\tlog",{"2":{"402":6,"404":4}}],["\\tlatestblocknumber",{"2":{"153":2,"170":2}}],["\\tpromptanswer",{"2":{"404":2}}],["\\tproof",{"2":{"153":2}}],["\\tpayload",{"2":{"402":2}}],["\\theader",{"2":{"326":2}}],["\\theaderchan",{"2":{"325":2}}],["\\thelloworldblob",{"2":{"323":2,"425":2}}],["\\theight",{"2":{"153":2,"169":2,"172":4,"323":2,"402":2,"425":2}}],["\\tns",{"2":{"402":2}}],["\\tnodeip",{"2":{"401":2,"402":2,"404":2}}],["\\tnodeclient",{"2":{"400":2}}],["\\tnonce",{"2":{"153":2,"169":2,"172":4}}],["\\tnamespaceid",{"2":{"402":2,"404":2}}],["\\tnamespacebytes",{"2":{"402":2}}],["\\tnamespace",{"2":{"323":2,"324":2,"325":2,"425":2}}],["\\tretrievedblobs",{"2":{"323":2,"425":2}}],["\\treturn",{"2":{"153":2,"165":8,"166":2,"167":2,"168":2,"169":2,"172":18,"323":2,"326":2,"402":4,"403":4,"425":2}}],["\\trowproofs",{"2":{"168":2,"172":2}}],["\\trowroots",{"2":{"167":2,"172":2}}],["\\tmaxns",{"2":{"165":2,"172":2}}],["\\tmaxsquaresize",{"2":{"159":2}}],["\\tminns",{"2":{"165":2,"172":2}}],["\\tsimplerollup",{"2":{"172":2}}],["\\tsimplerollupwrapper",{"2":{"172":2}}],["\\tsidenodes",{"2":{"153":2,"169":2,"172":2}}],["\\tshareproofs",{"2":{"165":2,"172":2}}],["\\tsharesproof",{"2":{"162":1,"172":4}}],["\\tsubtreerootthreshold",{"2":{"159":2}}],["\\tversion",{"2":{"159":2,"165":4,"172":6}}],["\\tvalid",{"2":{"153":2}}],["\\tvar",{"2":{"153":2,"165":6,"166":2,"170":2,"172":10}}],["\\twrappedproof",{"2":{"153":2}}],["\\twrapper",{"2":{"153":2,"170":2}}],["\\tcreatedblob",{"2":{"402":4,"404":2}}],["\\tclient",{"2":{"323":4,"324":2,"325":2,"326":2,"401":2,"402":4,"404":2,"425":4}}],["\\tcopy",{"2":{"165":6,"166":2,"172":2}}],["\\tcommitted",{"2":{"153":2}}],["\\tctx",{"2":{"152":2,"153":2,"172":4,"401":2,"402":4,"404":2}}],["\\tfetchedblob",{"2":{"402":2,"404":2}}],["\\tfor",{"2":{"153":4,"165":2,"167":2,"168":2,"169":2,"170":2,"172":16,"324":2,"325":2}}],["\\tfmt",{"2":{"152":2,"323":4,"425":4}}],["\\tblobchan",{"2":{"324":2}}],["\\tblobsharerange",{"2":{"159":2}}],["\\tblobstreamxwrapper",{"2":{"153":4,"172":2}}],["\\tblockdataroot",{"2":{"169":2,"172":2}}],["\\tblockres",{"2":{"153":2,"159":2}}],["\\ttmproto",{"2":{"172":2}}],["\\ttuple",{"2":{"153":2}}],["\\ttxhash",{"2":{"159":2}}],["\\ttx",{"2":{"153":2,"159":2,"172":2}}],["\\ttrpc",{"2":{"152":2,"153":2}}],["\\teventsiterator",{"2":{"153":2,"170":2}}],["\\tethclient",{"2":{"153":2,"170":2,"172":2}}],["\\tethcmn",{"2":{"153":2,"172":2}}],["\\terr",{"2":{"145":2,"152":2,"153":6,"170":2,"172":4}}],["\\tdatarootinclusionproof",{"2":{"169":2,"172":4}}],["\\tdataroot",{"2":{"153":2,"172":2}}],["\\tdcproof",{"2":{"152":2,"153":2}}],["\\tdefer",{"2":{"145":2,"153":2,"170":2,"172":2,"401":4,"402":4,"404":4}}],["\\t",{"2":{"145":6,"152":14,"153":90,"157":2,"159":22,"162":2,"165":8,"166":2,"167":2,"168":2,"169":4,"170":27,"171":24,"172":98,"323":28,"324":12,"325":12,"326":8,"400":28,"401":24,"402":54,"404":26,"425":28}}],["\\t\\tlog",{"2":{"401":4,"402":10,"404":12}}],["\\t\\tuint64",{"2":{"172":2}}],["\\t\\tclient",{"2":{"172":2}}],["\\t\\tctx",{"2":{"172":2,"403":2}}],["\\t\\tcase",{"2":{"171":4,"324":4,"325":4}}],["\\t\\tcopy",{"2":{"169":2}}],["\\t\\tproof",{"2":{"169":2,"172":2}}],["\\t\\tvar",{"2":{"169":2,"172":2}}],["\\t\\tversion",{"2":{"165":4,"166":2,"172":6}}],["\\t\\trowproofs",{"2":{"168":2,"172":2}}],["\\t\\trowroots",{"2":{"167":2,"172":2}}],["\\t\\treturn",{"2":{"145":2,"153":30,"159":8,"170":14,"172":8,"323":10,"324":6,"325":6,"326":4,"402":6,"425":10}}],["\\t\\tdcproof",{"2":{"172":2}}],["\\t\\tdigest",{"2":{"165":2,"172":4}}],["\\t\\tdataroot",{"2":{"153":2}}],["\\t\\tmax",{"2":{"165":2,"172":2}}],["\\t\\tmaxsquaresize",{"2":{"159":2}}],["\\t\\tmin",{"2":{"165":2,"172":2}}],["\\t\\tfor",{"2":{"165":2,"168":2,"172":6}}],["\\t\\tfmt",{"2":{"152":6,"153":6,"172":2}}],["\\t\\tselect",{"2":{"324":2,"325":2}}],["\\t\\tsharesproof",{"2":{"172":2}}],["\\t\\tshareproofs",{"2":{"165":2,"172":2}}],["\\t\\tsimplerollupwrapper",{"2":{"172":2}}],["\\t\\tsidenodes",{"2":{"153":4,"165":2,"168":2,"169":2,"172":6}}],["\\t\\tsubtreerootthreshold",{"2":{"159":2}}],["\\t\\tid",{"2":{"165":4,"166":2,"172":12}}],["\\t\\tint",{"2":{"159":2}}],["\\t\\tif",{"2":{"145":2,"153":2,"170":2}}],["\\t\\tblockdataroot",{"2":{"172":2}}],["\\t\\tblockres",{"2":{"159":2,"172":2}}],["\\t\\tbig",{"2":{"153":2}}],["\\t\\twrappedproof",{"2":{"153":2}}],["\\t\\ttuplerootnonce",{"2":{"169":2,"172":2}}],["\\t\\ttuple",{"2":{"153":2,"169":2,"172":2}}],["\\t\\tnumleaves",{"2":{"153":2}}],["\\t\\tnil",{"2":{"153":6,"170":6}}],["\\t\\tkey",{"2":{"153":2}}],["\\t\\theight",{"2":{"153":2}}],["\\t\\tevent",{"2":{"172":2}}],["\\t\\te",{"2":{"153":2,"170":2}}],["\\t\\terr",{"2":{"145":2}}],["\\t\\tos",{"2":{"152":6,"153":2,"172":2}}],["\\t\\t\\tif",{"2":{"325":2}}],["\\t\\t\\tfmt",{"2":{"324":2,"325":2}}],["\\t\\t\\tfor",{"2":{"172":2}}],["\\t\\t\\tattestationproof",{"2":{"172":2}}],["\\t\\t\\trowproofs",{"2":{"172":2}}],["\\t\\t\\trowroots",{"2":{"172":2}}],["\\t\\t\\treturn",{"2":{"171":2,"324":2,"325":2}}],["\\t\\t\\tnamespace",{"2":{"172":2}}],["\\t\\t\\tnumleaves",{"2":{"168":2,"169":2,"172":4}}],["\\t\\t\\tdata",{"2":{"172":2}}],["\\t\\t\\tdataroot",{"2":{"169":2,"172":2}}],["\\t\\t\\theight",{"2":{"169":2,"172":2}}],["\\t\\t\\tkey",{"2":{"168":2,"169":2,"172":4}}],["\\t\\t\\tcopy",{"2":{"168":2}}],["\\t\\t\\tcontext",{"2":{"153":2,"170":2,"171":2,"172":2}}],["\\t\\t\\tvar",{"2":{"168":2,"172":2}}],["\\t\\t\\tblobs",{"2":{"325":2}}],["\\t\\t\\tbzsidenode",{"2":{"172":2}}],["\\t\\t\\tbeginkey",{"2":{"165":2,"172":2}}],["\\t\\t\\tbreak",{"2":{"153":2,"170":2}}],["\\t\\t\\tshareproofs",{"2":{"172":2}}],["\\t\\t\\tsidenodes",{"2":{"165":4,"168":4,"169":2,"172":10}}],["\\t\\t\\tstart",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tfmt",{"2":{"325":2}}],["\\t\\t\\t\\tbzsidenode",{"2":{"172":2}}],["\\t\\t\\t\\tdatacommitment",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tendblock",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tstartblock",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tproofnonce",{"2":{"153":2,"170":2}}],["\\t\\t\\tevent",{"2":{"153":2,"170":2}}],["\\t\\t\\tendkey",{"2":{"165":2,"172":2}}],["\\t\\t\\tend",{"2":{"153":2,"170":2}}],["\\t\\t\\t",{"2":{"145":2,"153":2,"170":2,"171":2,"172":2,"325":4}}],["\\t\\t",{"2":{"145":4,"153":8,"157":4,"159":2,"162":2,"165":4,"168":4,"169":4,"170":6,"171":4,"172":20,"324":2,"325":2}}],["\\tif",{"2":{"145":4,"152":6,"153":32,"159":8,"162":2,"170":14,"172":10,"323":10,"324":6,"325":6,"326":4,"401":4,"402":16,"403":2,"404":12,"425":10}}],["🤪",{"2":{"135":1}}],["`$home",{"2":{"627":2}}],["`job=",{"2":{"545":2}}],["`json",{"2":{"134":22}}],["```json",{"2":{"372":2}}],["```",{"2":{"372":2}}],["`https",{"2":{"313":4}}],["`celestia",{"2":{"426":4}}],["`cel",{"2":{"268":2}}],["`private",{"2":{"211":2}}],["`mnemonic",{"2":{"211":2}}],["`wallet",{"2":{"211":4}}],["`trpc",{"2":{"172":4}}],["`availabledataroot`",{"2":{"169":2}}],["`",{"2":{"134":22,"268":2,"313":4,"432":12,"545":2}}],["zshrcecho",{"2":{"664":1}}],["zshrc",{"2":{"664":3}}],["z20=",{"2":{"365":2}}],["zxrxj96",{"2":{"156":2}}],["zhsjrh",{"2":{"151":2}}],["zero",{"2":{"127":2,"133":1,"230":1}}],["zkvm",{"2":{"230":1,"236":1,"412":1}}],["zkp",{"2":{"127":2}}],["zk",{"0":{"195":1,"196":1,"197":1,"198":1,"199":1,"200":1,"201":1,"202":1},"1":{"196":1,"197":2,"198":2,"199":1,"200":2,"201":2,"202":2,"203":1,"204":1,"205":1},"2":{"127":7,"136":2,"148":1,"174":1,"178":1,"195":1,"196":2,"197":1,"199":2,"200":4,"202":1,"203":5,"205":1,"206":1,"230":1,"237":4}}],["zip",{"2":{"86":2}}],["~2",{"2":{"724":1}}],["~20",{"2":{"223":1}}],["~5",{"2":{"635":1}}],["~1",{"2":{"635":1}}],["~10",{"2":{"224":1}}],["~1hr",{"2":{"224":1}}],["~30",{"2":{"226":1}}],["~3",{"2":{"224":1,"635":1}}],["~",{"2":{"117":2,"276":2,"281":2,"396":2,"528":1,"604":4,"638":18,"643":2,"674":1,"716":1}}],["μ",{"2":{"117":2,"281":2}}],["⠆",{"2":{"117":2,"120":2,"281":2,"284":2}}],["⠑",{"2":{"116":2,"280":2}}],["⠔",{"2":{"116":2,"280":2}}],["⠢",{"2":{"116":2,"280":2}}],["=1",{"2":{"724":1}}],["===",{"2":{"313":6}}],["==",{"2":{"153":2,"165":6,"168":3,"170":2,"305":2,"403":2,"418":1,"657":2,"658":2}}],["=",{"2":{"116":2,"117":2,"127":2,"137":28,"139":14,"145":12,"149":8,"152":14,"153":74,"157":8,"159":22,"162":4,"165":20,"167":6,"168":12,"169":10,"170":30,"171":18,"172":96,"184":4,"224":2,"225":1,"227":1,"238":1,"280":2,"281":2,"305":62,"312":10,"313":80,"315":2,"323":20,"324":14,"325":18,"326":8,"382":4,"392":29,"401":10,"402":34,"403":8,"404":26,"408":10,"409":20,"410":4,"417":1,"419":4,"420":2,"425":20,"426":44,"432":8,"502":1,"544":8,"573":10,"606":1,"616":1,"618":2,"627":22,"630":2,"631":2,"632":2,"633":3,"634":6,"637":8,"639":1,"644":4,"646":2,"647":2,"679":2,"682":170,"688":8,"704":2,"789":1}}],["⏰⏰⏰⏰⏰⏰",{"2":{"91":2}}],["🐳",{"0":{"653":1},"1":{"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1}}],["😎",{"2":{"390":1,"656":2}}],["🔐",{"0":{"360":1}}],["🙂",{"2":{"133":1}}],["🔃🔃🔃",{"2":{"91":2}}],["🚀🚀🚀🚀",{"2":{"91":2}}],["📝📝📝📝📝",{"2":{"91":2}}],["💰💰💰💰💰💰",{"2":{"91":2}}],["😁",{"2":{"89":1}}],["xzf",{"2":{"664":8}}],["xf",{"2":{"638":6}}],["x86",{"2":{"582":1,"610":1}}],["xv92a3qxexport",{"2":{"557":1}}],["xv92a3qx",{"2":{"557":3}}],["x64",{"2":{"522":1,"624":1,"668":1,"710":1,"781":1}}],["xxxxxxxxxxxxx",{"2":{"557":4}}],["xxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"397":1}}],["xxxxxxxxxxxxxxxxxxxxxxxxexport",{"2":{"397":1}}],["xxd",{"2":{"385":2}}],["xyz",{"2":{"227":1,"246":1,"248":1,"249":1,"251":1,"252":1,"284":2,"317":2,"509":3,"682":6,"726":3,"728":3,"729":3,"730":3,"734":2,"744":3,"746":2,"747":2,"749":2}}],["xthp6xws=",{"2":{"161":2}}],["xiijl+gqm0fqxiw0z0o",{"2":{"161":2}}],["x",{"0":{"95":1,"109":1,"126":1,"153":1,"209":1,"237":1,"238":1,"239":1,"240":1,"243":1},"1":{"96":1,"97":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"239":1,"240":1,"241":1,"242":1},"2":{"89":4,"94":1,"95":1,"106":1,"117":9,"126":2,"130":1,"131":7,"133":1,"145":1,"148":6,"150":2,"169":2,"172":4,"173":1,"210":1,"212":2,"225":3,"226":1,"227":4,"228":2,"230":3,"231":2,"237":5,"238":9,"239":3,"240":1,"242":9,"243":3,"281":9,"323":1,"380":2,"386":2,"391":1,"392":1,"401":4,"402":10,"420":2,"426":2,"536":1,"551":1,"638":6,"639":2,"789":2}}],["✨",{"2":{"83":1,"91":2,"313":2}}],["07",{"2":{"687":8}}],["0ns",{"2":{"687":4}}],["09",{"2":{"679":1}}],["010",{"2":{"590":1}}],["01",{"2":{"432":2,"542":2,"682":6,"728":1,"729":1,"730":1,"747":1,"748":1,"749":1,"789":2}}],["011",{"2":{"178":1}}],["0blockhash",{"2":{"385":1}}],["08",{"2":{"375":1,"679":2}}],["025",{"2":{"682":2}}],["02",{"2":{"372":2,"432":2}}],["06",{"2":{"372":4}}],["0mfhykqui2bu+u1jxpzg7qy2bvv1lb3kiu+zak7nuiy=",{"2":{"363":2,"599":2,"600":4,"601":2}}],["0+",{"2":{"358":1,"596":1,"681":1}}],["0px",{"2":{"313":2}}],["03",{"2":{"223":2}}],["05",{"2":{"223":2,"396":4}}],["001hermes",{"2":{"686":2,"687":1}}],["001",{"2":{"682":3,"683":2,"685":1,"686":4,"687":7,"688":3}}],["003442",{"2":{"605":4}}],["008",{"2":{"375":1}}],["004celestia",{"2":{"366":1}}],["004",{"2":{"366":3}}],["002",{"2":{"366":1,"380":2}}],["000",{"2":{"418":2,"419":1,"488":3,"494":3,"502":2,"551":1}}],["00016",{"2":{"293":1}}],["000176",{"2":{"293":1}}],["000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000121312324243243288993946154604701154f739f3d1b5475786ddd960f06d8708d4e870da6501c51750",{"2":{"161":2}}],["00000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000584cb53884b394593052df4039e58c7d51f0e45cace7dd584125f62f9261b7900ac1eeef5e82349",{"2":{"156":2}}],["00",{"2":{"223":2,"679":3}}],["048091bc7ddc283f77bfbf91d73c44da58c3df8a9cbc867405d8b7f3daada22f",{"2":{"372":2}}],["04",{"2":{"223":16,"333":1,"522":1,"624":1,"649":2,"668":1,"710":1,"781":1,"794":2}}],["0xbe",{"2":{"323":2,"324":2,"325":2,"408":2,"409":2,"425":2}}],["0xb6b15c8cb491557369f3c7d2c287b053eb229daa9c22138887752191c9520659",{"2":{"119":1}}],["0xb6052122545aacd2bdda0ca9fa56416bd968cdbc",{"2":{"99":1}}],["0x",{"2":{"219":1,"363":2}}],["0x0",{"2":{"387":1,"649":2,"794":2}}],["0x0000000000000000",{"2":{"384":2}}],["0x0000000000000000000000000000000000000000",{"2":{"384":2}}],["0x0000000000000000000000000000000000000000000000000000000000000000",{"2":{"384":2}}],["0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",{"2":{"121":2,"285":2,"384":2}}],["0x0000000000000000000000000000000000000000000000000000000000000001",{"2":{"211":2}}],["0x000000000000000000000000000000000000000000000000000000000000000a",{"2":{"121":2,"285":2}}],["0x0000000000000000000000000000000000000001",{"2":{"211":2}}],["0x007d0b2a2e2b013612e8",{"2":{"224":2}}],["0x0c",{"2":{"107":1}}],["0x04cae899fc0b7ef45c529f8bf075d54f6fb70ed9",{"2":{"99":1}}],["0x03b43f7b61fa100611191f481ef48aa1fc98f434",{"2":{"99":1}}],["0x01b5905b154f21a393f5b5a0c6d15b53a493c05e",{"2":{"98":1}}],["0x019850732270d8c436585c7921219252422228b5d0f559da0da219f0fa2b7216",{"2":{"91":2}}],["0x8e1ede4ce0865b41d714",{"2":{"224":2}}],["0x8f15d6004598f0662dd673a9898dceef77be8cc28408cecc284b28d7be32307d",{"2":{"121":2,"285":2}}],["0x8f97cb7c643acd7f79f3b13841b24a243da51242",{"2":{"99":1}}],["0x89b7c7970c13bb587893a70697ad6d2a335b6a15",{"2":{"99":1}}],["0x8dee6e88d3b62b258c1574cbb7005e1c3cf193b60a99b5c2fcfae00819b7ed82",{"2":{"91":2}}],["0xd4b998a35d20d98ed3488221f0c161a0a9572d3de66399482553c8e3d2fae751",{"2":{"384":2}}],["0xd883010d04846765746888676f312e32312e33856c696e7578000000000000006b3afa42dce1f87f1f07a1ef569c4d43e41738ef93c865098bfa1458645f384e2e4498bcfe4ad9353ff1913a2e16162f496fafe5b0939a6c78fb5b503248d6da01",{"2":{"384":2}}],["0xde",{"2":{"323":2,"324":2,"325":2,"408":2,"409":2,"425":2}}],["0xdeadbeef",{"2":{"323":4,"324":3,"325":5,"409":3,"425":4}}],["0xd2d353916b34a877793628049c99858f04123ee1",{"2":{"98":1}}],["0xd0a6699fc7519966685181c80bf98d35afa1fc95",{"2":{"98":1}}],["0xef",{"2":{"323":2,"324":2,"325":2,"408":2,"409":2,"425":2}}],["0xe2662ff9b41f39e63a850e50e013ea66e60a4f37",{"2":{"98":1}}],["0xe24a60b758b51b0a3da5e8f4f6ddf1cd0aff646c",{"2":{"98":1}}],["0xe371afcb8437bf61bd831ef57be7a2496d88488b",{"2":{"98":1}}],["0x3",{"2":{"649":6,"794":6}}],["0x383ed2debf9f9055920cd7340418dda7e2bca6b989eb6992d83d123d4e322f2a",{"2":{"385":2}}],["0x3c44cdddb6a900fa2b585dd299e03d12fa4293bc",{"2":{"385":2}}],["0x3f1eae7d46d88f08fc2f8ed27fcb2ab183eb2d0e",{"2":{"119":1}}],["0x3b6e845fb9f0c8ee4e9f6d44781f6547d9c6359a",{"2":{"99":1}}],["0x3bc040eaca40b91fa06cf55ea91842fac88b1af4",{"2":{"98":1}}],["0x3681cbb0e95ab50b63f2fc524fbbcc78adefbd33",{"2":{"98":1}}],["0xaf5c1505c7dfcebca94d9a6a8c0caf99b6c87a8ed6d6c0b3161c9026f270a84f",{"2":{"385":2}}],["0xaf8ff6af1180c8be9e4e8f3a5f882b3b227233f4abbefa479836d3721682a389",{"2":{"384":2}}],["0xaddress",{"2":{"392":11}}],["0xadd3a5dc0b8c605aeac891098e87cbaff43bb642896ebbf74f964c0690e46df2",{"2":{"385":2}}],["0xad",{"2":{"323":2,"324":2,"325":2,"408":2,"409":2,"425":2}}],["0xa83ca7775bc2889825bcdedffa5b758cf69e8794",{"2":{"242":2}}],["0xa2140c9bde000dc5e21e",{"2":{"224":2}}],["0xac3427e621c6f10dc2abdab00188d92690503914",{"2":{"98":1}}],["0xa773e19dc9e822933a7e72df9c87ed1578701d29",{"2":{"98":1}}],["0xaa",{"2":{"219":1}}],["0xaa3b8b63ccca3c98b948fd1d6ed875d378de2c6c",{"2":{"97":1}}],["0xaae3a04931345df5ac6e784bb6bdeb29b1ff0286",{"2":{"96":1}}],["0x28",{"2":{"649":2,"794":2}}],["0x2b30a00",{"2":{"649":2,"794":2}}],["0x20d8153aacc4e6d29558fa3916bff422bede9b5e",{"2":{"99":1}}],["0x2588867f19e2de51f90f0ab852c7ad11228e3d83",{"2":{"98":1}}],["0x22a6580faeca49cf86cbb2f18f2b7f98031fc6ad",{"2":{"96":1}}],["0x5fbdb2315678afecb367f032d93f642f64180aa3",{"2":{"120":2,"284":2}}],["0x55527d53fda37dbf1924482b40acf8625e1caa5b",{"2":{"99":1}}],["0x5a48adf22f526ebd06e3e8856cfea2490923cc55",{"2":{"99":1}}],["0x51d196e07a27dba0f4461dd6cc26108424f196f7",{"2":{"99":1}}],["0x5187a92539bb4a2befe1fc078745c84ab6d37171",{"2":{"98":1}}],["0x53dea3a90fd6c82840a1f7224f799d622f142df4",{"2":{"98":1}}],["0x5810f0916bae1067ca1efcc00aaaf30301af001c",{"2":{"98":1}}],["0x59d2db6c5095b9e329c80211b7a761d20064379e3382d156b69e5cf3b5fe2fc7",{"2":{"91":2}}],["0x664bf4bb4a57dd5768a0a98991d77c58fb7a4e164c2581c79fb33ce9c3d4c250",{"2":{"384":2}}],["0x6665656772616e74",{"2":{"295":1}}],["0x6665656772616e74celestia",{"2":{"295":1}}],["0x676d",{"2":{"363":3,"600":2}}],["0x61254e43e5c1e9e801f9c56b47a9ac3eadf6d1e9",{"2":{"99":1}}],["0x61e154128b6a1400ea8090b4431b4aa1dbb80cc4",{"2":{"98":1}}],["0x630093954cbf19fe4532a2edd0bd3b10deca7a4d",{"2":{"98":1}}],["0x6cb49605f10831749c6090ad09918bc61439bace",{"2":{"98":1}}],["0x6c7360a96165c570dcb7ce609d748d612c5fa5b76e229cd81ba5f5c93c00f805",{"2":{"91":2}}],["0x9f4dfae061b5ddd86f95a81be5daa0d7fe32e7f7f770f86dc375e0007d249bd2",{"2":{"385":2}}],["0x9039e58b2089e5f9abbb",{"2":{"224":2}}],["0x9c3f372a2aacc0d7272f56a4664311b7647b0031",{"2":{"223":32}}],["0x99e9d2f04352b42c18f1da5dd93a970f82c08afe",{"2":{"99":1}}],["0x9abc41fefae7e7543a01fa837aec909f96147280",{"2":{"99":1}}],["0x95cbda89325db5529eaf1813e181f66b83a7d65a",{"2":{"98":1}}],["0x95fea00e689e8d1cba909836e1ef1b941d5f21b1",{"2":{"98":1}}],["0x97b50f60b60d0e658fdbf185969db0a0327bd0ae9e57cd65af2a7f9be0eeb5b0",{"2":{"91":2}}],["0x40002a61b0",{"2":{"649":2,"794":2}}],["0x400065ea88",{"2":{"649":10,"794":10}}],["0x400143e048",{"2":{"649":2,"794":2}}],["0x400153b240",{"2":{"649":2,"794":2}}],["0x40f8c63e0a20b399bcd9631a22e57bb988a9400e",{"2":{"99":1}}],["0x42690c204d39600fddd3celestia",{"2":{"365":1,"373":1,"378":1}}],["0x42690c204d39600fddd3",{"2":{"295":2,"358":4,"363":5,"365":7,"366":2,"373":1,"378":1,"599":2,"600":2,"601":2}}],["0x4270889adcb82338c5ff5e64b45c0a3d31cfd08c",{"2":{"97":1}}],["0x44b412b291fef00398501b2ca353ea912ad0fe13",{"2":{"99":1}}],["0x4888fdf44251d456bbfca92bfc6e180cfe0b096ffbea2f6da2a203a16902214f",{"2":{"91":2}}],["0x1b91180",{"2":{"649":2,"794":2}}],["0x1bb8add5e878b12fa37756392642eb94c53a1cf4",{"2":{"97":1,"99":1}}],["0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",{"2":{"384":2}}],["0x1cb54d2369752ef73511c202ff9cdfd0eadf3a77b7aef0092bea63f2b5d57659",{"2":{"384":2}}],["0x1cc4551922c069a9ade06756bf14bf0410ea44ff",{"2":{"99":1}}],["0x1",{"2":{"305":2}}],["0x131822bef6eb59656d7e1387c19b75be667e587006710365ec5cf58030786c42",{"2":{"121":2,"285":2}}],["0x1ae3a8dc1e7efd37f418b2987d3df74c5a917a8b",{"2":{"99":1}}],["0x10c65b27d5031ce2351c719072e58f3153228887f027f9f6d65300d2b5b30152",{"2":{"94":1}}],["0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"384":2}}],["0x7973d0b475e898082df25c1617cbce1917cfed17",{"2":{"98":1}}],["0x79751b011bcc20f413a2c4e3af019b6e2a9738b9",{"2":{"96":1,"98":1}}],["0x7cf3876f681dbb6eda8f6ffc45d66b996df08fae",{"2":{"242":1}}],["0x78f8b2941dde5a8a312814ebd29c2e2a36f25e91",{"2":{"99":1}}],["0x7fc4d9a24949680fad666feee7cd6a100e39c4f0",{"2":{"98":1}}],["0x7fbeb5bc73a11b438891022786feb2c624f275f0",{"2":{"91":2}}],["0xff00000000000000000000000000000000000901",{"2":{"385":3}}],["0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1e",{"2":{"242":1}}],["0xf6759ff933786ddacb92",{"2":{"224":2}}],["0xfill",{"2":{"220":4}}],["0xf1a793a793cd9fc588f5132d99008565ea361eb3535d66499575e9e1908200b2",{"2":{"120":2,"284":2}}],["0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266",{"2":{"120":2,"284":2}}],["0xf31fd34f8a9d9057198d8b13e755e583766bd528459733d948d9ffbc980c9506",{"2":{"91":2}}],["0xf889a3174fddd9f78e6cd250ebf4c16f1bdd1b6a",{"2":{"99":1}}],["0xfb612fb83959b8acd3e49540b29c93c5a67e05f1",{"2":{"98":1}}],["0xf47dc66514fd78e4666e35abd12df7d1ae2c79f69f7dfedb8d98e4106142ab7c",{"2":{"91":2}}],["0xf2ddc2dad90e7e2b20a772bf89f989224165659d50824b98d7340e12265abf01",{"2":{"91":2}}],["0xcryptovestor",{"2":{"728":1}}],["0xce",{"2":{"385":2}}],["0xce3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"385":2}}],["0xce1636cfaf2bd5497c11",{"2":{"224":2}}],["0xc7535f078cb3880a0fd5e54fa7a3b4eaf09b3924",{"2":{"99":1}}],["0xc99eea0b8e67d5b2226ab6d37882daaf6dd7593b",{"2":{"99":1}}],["0xcd9fca5015b5ce2b06a2266e4a5dd54d9ca39f1a",{"2":{"99":1}}],["0xc61382d5609ab0ece36b2776349c8bdceeafdd13dde9624cdf3d746fb4cf7d79",{"2":{"91":2}}],["0xc3e209eb245fd59c8586777b499d6a665df3abd2",{"2":{"89":2,"95":1,"242":2}}],["0",{"2":{"80":2,"82":2,"89":6,"91":6,"94":1,"116":4,"117":5,"121":2,"126":1,"127":2,"137":2,"148":1,"149":6,"151":2,"156":16,"161":12,"162":3,"165":2,"169":2,"172":6,"183":1,"184":6,"215":1,"280":4,"281":5,"283":2,"285":2,"293":2,"294":1,"295":3,"296":2,"305":4,"311":6,"312":2,"313":4,"323":2,"344":1,"365":8,"366":5,"368":2,"369":2,"370":10,"371":2,"372":10,"375":3,"380":14,"385":7,"386":8,"396":1,"402":4,"403":2,"408":4,"417":4,"418":1,"421":2,"425":2,"426":8,"432":6,"434":3,"480":2,"544":2,"545":4,"564":10,"565":2,"566":2,"567":4,"582":1,"583":4,"600":2,"601":15,"631":3,"634":4,"637":2,"639":2,"643":20,"649":14,"679":3,"682":14,"687":14,"688":2,"783":8,"789":10,"794":14}}],["$ip",{"2":{"705":2}}],["$input",{"2":{"385":2}}],["$network",{"2":{"655":3,"657":3}}],["$networkdocker",{"2":{"655":3,"657":3}}],["$node",{"2":{"361":3,"655":6,"657":2,"705":2,"777":2}}],["$peer",{"2":{"705":1}}],["$peerpeer=",{"2":{"705":1}}],["$persistent",{"2":{"627":12}}],["$port",{"2":{"705":2}}],["$path",{"2":{"664":1}}],["$private",{"2":{"75":2,"76":4,"219":2,"283":2,"308":4,"309":4,"315":2,"317":6}}],["$shell",{"2":{"664":1}}],["$seeds",{"2":{"627":8}}],["$staking",{"2":{"542":2,"702":3}}],["$from",{"2":{"564":6,"566":2,"567":2,"571":2}}],["$tia",{"2":{"700":2}}],["$to",{"2":{"564":6,"565":2,"567":2,"571":2}}],["$tx",{"2":{"385":2}}],["$broadcast",{"2":{"549":2}}],["$bubs",{"2":{"284":4,"285":6,"317":10}}],["$multisig",{"2":{"549":10}}],["$keyring",{"2":{"549":4}}],["$key",{"2":{"542":6,"699":3,"700":3,"702":3}}],["$validator",{"2":{"542":2,"549":6,"698":3,"783":2}}],["$external",{"2":{"644":2}}],["$encoded",{"2":{"386":2}}],["$etherscan",{"2":{"219":2}}],["$celes",{"2":{"542":2}}],["$celestia",{"2":{"380":2,"386":2,"561":2,"562":2,"564":6,"565":2,"566":2,"567":4}}],["$chain",{"2":{"542":4,"549":10,"698":4,"702":2}}],["$contract",{"2":{"76":6,"121":4,"285":4,"308":4,"309":4,"317":6}}],["$granter",{"2":{"299":2,"300":2}}],["$grantee",{"2":{"294":4,"297":2,"299":2}}],["$address",{"2":{"375":6}}],["$auth",{"2":{"358":2}}],["$anvil",{"2":{"283":2}}],["$arb",{"2":{"75":2,"76":8,"120":2,"121":4}}],["$request",{"2":{"356":1,"515":1,"715":1,"751":1}}],["$receiver",{"2":{"76":2,"317":2}}],["$rpc",{"2":{"219":2,"294":2,"295":2,"299":2,"571":2,"655":6,"658":6}}],["$",{"2":{"121":2,"276":2,"285":2,"313":4,"373":2,"378":2,"582":2,"584":12,"610":2,"627":2,"638":6,"663":2}}],["$l2",{"2":{"120":2,"121":2}}],["$home",{"2":{"75":4,"77":2,"102":2,"115":3,"116":1,"212":2,"217":2,"220":2,"223":2,"224":2,"279":3,"280":1,"317":4,"318":2,"362":4,"390":2,"391":2,"545":3,"556":3,"557":1,"558":2,"561":2,"581":3,"582":1,"609":2,"610":1,"615":3,"627":11,"637":1,"638":6,"641":2,"644":2,"656":4,"657":8,"658":8,"664":20,"682":2,"697":2,"701":1,"702":1,"703":4,"704":1}}],["qo",{"2":{"644":2}}],["qgb",{"2":{"172":2,"230":1}}],["qmaezrnbtgexcryc8pcvgrbs+umukniborae4qye7osgwcrwbvys",{"2":{"372":2}}],["qm",{"2":{"156":2}}],["q5",{"2":{"48":1}}],["q4",{"2":{"48":1}}],["q3",{"2":{"48":1}}],["q2",{"2":{"48":1}}],["q1",{"2":{"48":1}}],["q",{"2":{"44":1,"59":1,"60":1,"61":1,"65":1,"534":6,"535":4,"536":4,"537":2}}],["qubelabs",{"2":{"638":12}}],["quorum",{"2":{"536":1}}],["quot",{"0":{"605":2},"2":{"30":18,"31":6,"34":6,"47":2,"53":2,"76":20,"85":2,"88":2,"89":72,"91":12,"102":4,"108":4,"116":6,"117":40,"121":8,"127":12,"134":44,"139":8,"145":8,"151":64,"152":24,"153":76,"156":356,"157":4,"159":24,"161":120,"170":12,"171":8,"172":80,"211":8,"213":12,"215":4,"216":4,"223":4,"251":2,"275":4,"276":24,"280":6,"281":40,"283":2,"285":8,"290":4,"295":36,"296":20,"299":4,"305":68,"307":12,"308":16,"309":16,"312":76,"313":232,"314":6,"315":4,"317":20,"323":40,"324":4,"325":8,"363":36,"365":128,"366":16,"368":32,"369":32,"370":52,"371":20,"372":364,"373":4,"378":4,"380":76,"382":4,"385":4,"386":60,"387":4,"392":44,"396":2,"400":36,"401":12,"402":44,"403":24,"404":32,"408":32,"409":24,"410":12,"415":2,"420":4,"425":40,"426":64,"432":96,"433":2,"434":4,"458":2,"481":2,"502":2,"510":2,"513":2,"536":156,"537":40,"542":4,"544":8,"545":36,"549":16,"557":2,"561":16,"562":32,"564":66,"565":20,"566":8,"567":16,"573":20,"578":2,"582":4,"584":16,"599":8,"600":36,"601":12,"604":2,"610":4,"627":58,"630":4,"632":6,"633":6,"634":10,"637":8,"638":36,"643":8,"644":12,"646":4,"649":8,"663":4,"664":68,"679":2,"682":188,"684":4,"687":64,"700":4,"704":4,"705":4,"774":2,"783":28,"789":36,"794":8}}],["quic",{"2":{"370":6}}],["quicker",{"2":{"636":1}}],["quickly",{"2":{"415":1,"497":1}}],["quick",{"0":{"638":1,"655":1,"768":1},"1":{"769":1,"770":1,"771":1},"2":{"334":1,"577":1,"635":1,"638":2,"657":1,"681":1,"696":1,"771":1}}],["quickstart",{"0":{"79":1,"256":1},"1":{"80":1,"81":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,"257":1,"258":1,"259":1},"2":{"73":1,"81":1,"101":1}}],["quite",{"2":{"315":1}}],["queried",{"2":{"145":1,"152":1,"155":1,"162":1,"163":1,"169":2,"181":1,"219":2,"369":1}}],["queries",{"0":{"144":1,"146":1},"1":{"145":1,"146":1,"147":2,"148":2,"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,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1},"2":{"130":1,"145":1,"149":1,"151":1,"156":1,"161":2,"162":1,"172":1,"191":1,"355":2,"447":1,"450":1,"459":3,"526":2,"646":2,"647":3,"673":2,"749":1}}],["queryable",{"2":{"169":2}}],["querysharerange",{"2":{"159":2}}],["querying",{"0":{"130":1,"170":1,"218":1,"332":1,"534":1},"2":{"135":2,"150":1,"158":1,"160":1,"169":1,"191":1,"217":1,"218":1,"219":2,"240":1,"247":1,"332":1,"513":1,"530":2,"565":1,"637":1,"734":1,"746":1,"747":1}}],["query",{"0":{"151":1,"565":1,"566":1,"567":1,"632":1},"2":{"76":1,"129":1,"130":1,"146":1,"148":1,"150":1,"153":2,"155":1,"160":2,"164":1,"165":4,"166":1,"168":4,"169":1,"170":2,"172":2,"181":1,"184":2,"192":1,"218":1,"300":2,"317":1,"368":1,"369":1,"376":1,"426":2,"450":1,"480":1,"530":6,"534":2,"536":1,"565":2,"566":2,"567":4,"579":2,"584":1,"632":1,"633":1,"646":1,"673":1,"686":2,"713":1}}],["question",{"2":{"48":3,"436":1,"685":1,"783":1}}],["questions",{"0":{"48":1},"2":{"17":1,"47":2}}],["quad",{"2":{"623":1,"757":1,"758":1}}],["quadratic",{"2":{"451":1}}],["quantum",{"2":{"230":1}}],["qualify",{"2":{"34":1}}],["qualification",{"2":{"34":3}}],["qualified",{"2":{"34":1}}],["quality",{"2":{"24":1,"46":1,"47":1,"65":1}}],["quarterly",{"2":{"42":1}}],["quarter",{"2":{"29":1}}],["9390",{"2":{"730":1,"749":1}}],["96112",{"2":{"564":4}}],["96ms",{"2":{"117":2,"281":2}}],["999994999800000",{"2":{"567":2}}],["99",{"2":{"439":1}}],["973",{"2":{"415":1,"724":2}}],["9anbaxno1b4x5lr2qy5qwqwrmnozejkctxwzq9bexsg=",{"2":{"372":4}}],["91e04695cf9cf531bc0891e7b1d602b3e8022c86",{"2":{"372":8}}],["9545",{"2":{"308":4}}],["9545anvil",{"2":{"308":1}}],["9070",{"2":{"746":1}}],["9080",{"2":{"734":1}}],["9099",{"2":{"749":1}}],["9095",{"2":{"730":1}}],["9090",{"2":{"355":1,"380":1,"510":1,"513":1,"526":1,"527":1,"545":2,"583":2,"594":1,"673":1,"713":1,"730":3,"734":7,"746":2,"749":5}}],["90",{"2":{"313":2}}],["90vw",{"2":{"313":2}}],["900px",{"2":{"312":2}}],["9000",{"2":{"312":2,"314":1}}],["9000000utia",{"2":{"702":1}}],["90000",{"2":{"153":2,"170":4}}],["902",{"2":{"31":1,"34":5}}],["9",{"0":{"91":1},"2":{"33":1,"34":1,"488":1}}],["782",{"2":{"649":2,"794":2}}],["786bytes",{"2":{"724":1}}],["786",{"2":{"415":1,"724":1}}],["770",{"2":{"649":2,"794":2}}],["746",{"2":{"649":2,"794":2}}],["741743z",{"2":{"372":2}}],["75",{"2":{"428":1,"429":1,"430":1,"489":1}}],["767",{"2":{"384":2}}],["76au8rj4vsyvasph5lgqq2kg",{"2":{"156":2}}],["7a5fabb19713d732d967b1da84fa0df5e87a7b62302d783f78743e216c1a3550",{"2":{"372":2}}],["71",{"2":{"370":4}}],["7",{"0":{"89":1},"2":{"31":1,"34":1,"156":2,"372":4,"384":2,"488":2,"565":2,"681":1}}],["5s",{"2":{"545":2,"682":4}}],["554+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"396":2}}],["5iieerohbmff+ser3jpvroieejzjby+tre0ntadqll3",{"2":{"372":4}}],["564+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"396":2}}],["56",{"2":{"352":2,"709":2,"757":1}}],["512gb",{"2":{"226":1}}],["5158076079",{"2":{"91":2}}],["53",{"2":{"223":2}}],["57",{"2":{"172":2}}],["58",{"2":{"91":2,"165":4,"172":2,"223":2}}],["5",{"0":{"87":1,"660":1},"2":{"31":1,"34":1,"151":2,"156":2,"172":2,"313":4,"394":2,"395":1,"403":1,"405":2,"421":2,"434":1,"484":1,"494":1,"545":2,"551":1,"682":4}}],["500ms",{"2":{"682":4}}],["5000100000000utia",{"2":{"542":2}}],["500000000",{"2":{"372":4}}],["500",{"2":{"352":1,"415":1,"682":2,"709":1,"757":1}}],["5001",{"2":{"313":2}}],["50px",{"2":{"313":2}}],["504g",{"2":{"223":1,"224":1}}],["50",{"2":{"21":1,"23":2,"28":1,"352":1}}],["+0x110",{"2":{"649":2,"794":2}}],["+0x1c8",{"2":{"649":2,"794":2}}],["+0x124",{"2":{"649":2,"794":2}}],["+0x2c4",{"2":{"649":2,"794":2}}],["+0x2d8",{"2":{"649":2,"794":2}}],["+0x26c",{"2":{"649":2,"794":2}}],["+0xd30",{"2":{"649":2,"794":2}}],["+0x44",{"2":{"649":2,"794":2}}],["+0x64",{"2":{"649":2,"794":2}}],["+2",{"0":{"649":1,"794":1},"2":{"649":2,"794":2}}],["+stake",{"2":{"468":1}}],["+sgf6mfzmmtdkz5mllh+y7mpv9moo2x5rljle3gbfqo=",{"2":{"151":2}}],["+mhkrh9borgjn3oqt",{"2":{"156":2}}],["+1",{"2":{"137":2,"139":4}}],["+",{"2":{"27":2,"102":1,"137":2,"139":2,"183":1,"184":2,"305":4,"313":6,"344":1,"432":10,"597":1,"676":1,"724":1}}],["856",{"2":{"649":2,"794":2}}],["8548",{"2":{"119":1}}],["8545cast",{"2":{"309":1,"384":1,"385":1}}],["8545export",{"2":{"283":1}}],["8545",{"2":{"119":1,"283":2,"308":1,"309":5,"312":2,"314":1,"315":1,"384":1,"385":1}}],["8547",{"2":{"75":1,"119":1,"120":2}}],["8547export",{"2":{"75":1,"120":1}}],["87",{"2":{"604":2}}],["80000",{"2":{"375":3}}],["80000celestia",{"2":{"375":1}}],["8000",{"2":{"375":4,"545":1}}],["800px",{"2":{"313":4}}],["8dxemrbwrpwj6hi+3uesz+0p5vrf3v8ssaqeabelorfgaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"161":2}}],["8woyobnjs3mt1dkfrqid8vc75oja2jnf3wn",{"2":{"156":2}}],["8449",{"2":{"91":3}}],["8",{"0":{"90":1},"2":{"23":2,"34":1,"94":2,"116":6,"117":4,"126":1,"127":2,"161":2,"172":2,"276":2,"280":6,"281":4,"305":4,"307":2,"311":4,"415":2,"484":1,"488":1,"494":1,"557":4,"758":1,"780":1}}],["kv",{"2":{"630":2,"632":3,"646":5}}],["kjnodes",{"2":{"492":1,"728":1,"729":1,"730":1,"738":1}}],["k×k",{"2":{"450":3,"452":1,"458":1}}],["kr",{"2":{"426":6}}],["kbps",{"2":{"352":2,"709":2,"757":1}}],["kqkhkpjxmiby",{"2":{"156":2}}],["known",{"2":{"160":1,"230":1,"237":1}}],["knowing",{"2":{"48":1}}],["know",{"2":{"44":1,"45":1,"47":2,"107":1,"228":1,"255":1,"261":1,"479":1,"633":1}}],["knowledgeable",{"2":{"42":1,"43":1}}],["knowledge",{"2":{"34":1,"43":1,"46":1,"65":1,"127":2,"133":1,"230":1,"289":1}}],["kept",{"2":{"437":1}}],["keplrbutton",{"2":{"432":2}}],["keplr",{"0":{"432":1,"462":1,"463":1},"1":{"463":1,"464":1,"465":1,"466":1},"2":{"431":1,"432":18,"460":1,"463":2,"464":1,"465":1,"491":1,"492":1,"548":1}}],["keeping",{"2":{"451":1}}],["keeps",{"2":{"108":1,"148":1}}],["keep",{"2":{"41":1,"42":1,"136":1,"221":1,"269":2,"392":1,"505":1,"546":1,"627":1,"634":3,"704":2,"789":1}}],["keymake",{"2":{"609":1}}],["keyfile",{"2":{"533":2}}],["keyforge",{"2":{"219":1}}],["keybase",{"2":{"533":1}}],["keycelestia",{"2":{"294":1}}],["keycast",{"2":{"121":1,"285":1,"308":1,"309":1}}],["keyname",{"0":{"700":1},"2":{"276":2,"294":2,"356":6,"528":6,"674":6,"714":6,"716":6}}],["keyring",{"2":{"269":6,"270":7,"271":6,"275":2,"276":4,"294":2,"299":2,"309":2,"315":2,"342":1,"356":10,"426":10,"527":2,"528":7,"531":4,"533":1,"549":6,"569":3,"573":4,"578":2,"597":3,"673":2,"674":7,"699":2,"700":2,"702":2,"714":10,"716":7,"783":2,"789":2}}],["key`",{"2":{"211":4,"268":4}}],["key=sk",{"2":{"397":2}}],["key=ac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80",{"2":{"317":2}}],["key=$",{"2":{"309":2,"315":2}}],["key=0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80",{"2":{"283":2,"284":2}}],["key=0xe887f7d17d07cc7b8004053fb8826f6657084e88904bb61590e498ca04704cf2",{"2":{"120":2}}],["key=0xb6b15c8cb491557369f3c7d2c287b053eb229daa9c22138887752191c9520659",{"2":{"75":2}}],["key=",{"2":{"91":2,"211":2,"313":2}}],["keys`",{"2":{"426":4}}],["keys",{"0":{"269":1,"270":1,"271":1,"276":1,"356":1,"533":1,"562":1,"714":1},"1":{"715":1},"2":{"27":1,"31":1,"86":1,"113":1,"211":2,"267":2,"269":2,"275":1,"276":8,"292":1,"308":2,"309":2,"315":2,"330":1,"354":1,"392":2,"528":1,"530":4,"531":1,"532":16,"533":6,"542":2,"549":10,"561":2,"562":2,"563":1,"569":8,"573":2,"578":4,"597":3,"661":1,"674":1,"683":6,"684":1,"699":2,"701":1,"716":1,"783":2}}],["key",{"0":{"23":1,"106":1,"267":1,"272":1,"273":1,"331":1,"397":1,"528":1,"532":1,"561":1,"657":1,"674":1,"699":1,"716":1},"1":{"107":1,"108":1,"109":1,"110":1,"268":1,"269":1,"270":1,"271":1,"272":1,"274":1,"275":1,"276":1,"533":1},"2":{"38":2,"43":1,"55":1,"75":5,"76":9,"84":3,"88":1,"91":2,"106":1,"119":3,"120":5,"121":3,"137":2,"156":8,"165":4,"168":5,"184":3,"211":14,"212":8,"213":8,"219":10,"220":2,"227":2,"266":2,"267":2,"268":5,"269":18,"270":13,"271":12,"272":2,"275":5,"276":11,"283":5,"284":5,"285":3,"291":1,"294":1,"308":7,"309":12,"311":4,"315":6,"317":14,"331":1,"356":15,"368":1,"372":4,"390":1,"392":11,"395":1,"396":8,"397":5,"403":5,"426":2,"449":1,"499":1,"527":5,"528":9,"532":8,"533":13,"536":4,"549":2,"559":1,"560":1,"561":8,"562":6,"563":1,"565":2,"566":4,"567":4,"569":1,"596":2,"597":3,"609":2,"646":1,"653":2,"657":1,"673":5,"674":9,"682":12,"699":2,"700":1,"714":16,"716":9}}],["kib",{"2":{"415":1}}],["kit",{"2":{"57":2,"58":1,"63":1}}],["kickstarting",{"2":{"39":1}}],["kinds",{"2":{"191":1}}],["kindly",{"2":{"52":1}}],["kind",{"2":{"8":1,"34":1}}],["kindness",{"2":{"8":1}}],["k",{"2":{"31":1,"34":3,"156":2,"172":8,"452":3}}],["67",{"2":{"489":3}}],["64x64",{"2":{"415":1,"724":1}}],["64",{"2":{"413":1,"582":1,"610":1,"724":1}}],["64cpu",{"2":{"223":1,"224":1,"226":1}}],["6363c68770c200fd794445668f9b18f5b1dd1125180d6e8d5ab004f7dd7a0f48",{"2":{"372":4}}],["65",{"2":{"370":4,"418":1,"419":1}}],["62562",{"2":{"366":2}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2",{"2":{"564":1}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2gas",{"2":{"564":1}}],["60",{"2":{"220":1}}],["6962",{"2":{"128":1}}],["6",{"0":{"88":1},"2":{"21":1,"24":1,"27":1,"31":1,"34":1,"80":1,"82":1,"432":6,"433":1,"434":1,"488":2,"494":1,"521":1,"649":2,"667":1,"757":1,"794":2}}],["jemalloc",{"2":{"609":2}}],["jemallocmake",{"2":{"609":1}}],["jwt",{"2":{"401":2,"402":2,"404":2}}],["jq",{"2":{"373":2,"375":3,"378":3,"627":2,"663":10,"774":4}}],["jail",{"2":{"551":1}}],["jailing",{"0":{"551":1},"2":{"551":1}}],["jailed",{"2":{"24":2,"25":1,"27":1,"551":2}}],["javascriptyarn",{"2":{"310":1}}],["javascript",{"2":{"310":2}}],["j",{"2":{"165":4,"168":4,"172":8}}],["j2pyclt4khpiqvh7b6wp9kcdmghlct9edfydr7zaq9o=",{"2":{"156":2}}],["jh0tyrmtrdtha",{"2":{"156":2}}],["jsimport",{"2":{"432":3}}],["jsximport",{"2":{"312":1,"313":1}}],["jsx",{"2":{"312":1,"313":1,"315":3,"432":1}}],["jsxnpm",{"2":{"311":1}}],["jsxyarn",{"2":{"310":1}}],["js",{"2":{"114":2,"278":2,"303":1,"310":1,"432":2}}],["jsoncelestia",{"2":{"298":1}}],["jsonrpc",{"2":{"151":2,"156":2,"161":2,"368":2,"369":2,"370":2,"371":2,"372":2,"380":4,"386":4}}],["jsondocker",{"2":{"102":2}}],["json",{"0":{"703":1},"2":{"68":1,"77":4,"84":2,"86":2,"87":2,"88":1,"89":1,"91":2,"92":1,"102":6,"134":2,"137":2,"151":1,"156":1,"161":1,"295":2,"296":1,"298":1,"310":3,"313":2,"318":4,"332":1,"344":1,"363":2,"365":4,"366":1,"368":1,"369":1,"370":1,"371":1,"380":2,"386":2,"387":1,"427":1,"530":6,"536":9,"537":5,"542":1,"549":18,"627":3,"701":3,"702":3,"703":6}}],["jcstein",{"2":{"75":2,"317":2}}],["journalctl",{"2":{"541":6,"774":2,"776":2,"777":2,"778":2}}],["journey",{"2":{"35":1,"50":1}}],["jotzla2v3g2q7y+18ih5j0uxk",{"2":{"161":2}}],["job",{"2":{"48":1,"260":1,"446":1,"545":8}}],["joining",{"0":{"48":1},"2":{"42":1,"47":1,"53":1,"65":1}}],["join",{"2":{"19":1,"50":1,"518":1}}],["june",{"2":{"28":1}}],["jurisdiction",{"2":{"24":1,"34":5}}],["justifycontent",{"2":{"313":6}}],["just",{"2":{"8":1,"85":1,"91":2,"102":1,"126":1,"135":1,"267":1,"308":1,"375":1,"415":1,"459":1,"486":1,"491":1,"492":1,"505":1,"545":1,"553":1,"673":1,"765":1,"771":1}}],["4hermes",{"2":{"686":1}}],["4hr",{"2":{"224":1}}],["48pm",{"2":{"649":2,"794":2}}],["48",{"2":{"649":2,"794":2}}],["482",{"2":{"415":1,"724":1}}],["4️⃣",{"0":{"466":1,"475":1}}],["4k",{"2":{"450":1,"451":1,"452":1,"458":1,"459":1}}],["42069celestia",{"2":{"294":1}}],["42069",{"2":{"294":2}}],["443celestia",{"2":{"535":1}}],["443export",{"2":{"299":1,"571":1}}],["443",{"2":{"290":1,"299":1,"300":2,"510":1,"535":3,"571":1,"573":2,"682":2,"728":2,"729":2,"730":7,"731":2,"746":2,"747":3,"749":4}}],["478",{"2":{"415":1,"724":1}}],["47",{"2":{"223":2}}],["41",{"2":{"223":2}}],["46",{"2":{"149":2}}],["43494",{"2":{"121":4,"285":4}}],["49",{"2":{"396":4}}],["49s",{"2":{"91":2}}],["4989526079",{"2":{"91":2}}],["400000",{"2":{"682":4}}],["400px",{"2":{"313":2}}],["401",{"2":{"599":4}}],["4094×482bytes",{"2":{"724":1}}],["4094",{"2":{"415":1}}],["4095",{"2":{"415":1,"724":1}}],["4096",{"2":{"415":1,"724":1}}],["40px",{"2":{"313":2}}],["40",{"2":{"43":1,"372":2}}],["4",{"0":{"16":1,"34":1,"86":1},"2":{"22":1,"23":3,"26":1,"27":1,"28":1,"31":1,"34":13,"80":1,"82":1,"85":1,"89":2,"91":2,"95":1,"156":2,"172":2,"183":1,"225":1,"238":1,"276":4,"299":2,"385":2,"401":2,"402":2,"404":2,"480":1,"488":1,"489":1,"492":1,"510":2,"679":1,"682":3,"683":2,"685":1,"686":5,"687":10,"688":3,"746":3,"747":2,"748":1,"749":4,"750":8}}],["3152",{"2":{"687":2}}],["3108",{"2":{"682":2,"688":2}}],["33373",{"2":{"728":1,"731":1}}],["33554432",{"2":{"682":4}}],["33",{"2":{"489":3,"584":2}}],["3️⃣",{"0":{"465":1,"470":1,"474":1}}],["3d96b7d238e7e0456f6af8e7cdf0a67bd6cf9c2089ecb559c659dcaa1f880353",{"2":{"372":2}}],["3dmfzfawzmtzvxhphf5txlcj+ct3evmmfopixfh+id4=",{"2":{"161":2}}],["3+fuhlzufkjnzd8yg",{"2":{"161":2}}],["3wl9cwxs8rqbddgupu9p8jcfj+jc77zsswdcf6pm=",{"2":{"156":2}}],["34",{"2":{"149":2,"649":14,"681":1,"794":14}}],["32cpu",{"2":{"220":1}}],["32",{"2":{"149":2,"153":6,"165":3,"168":4,"169":6,"172":14,"211":2,"213":4}}],["391",{"2":{"649":2,"794":2}}],["39",{"2":{"139":2,"153":2,"170":2,"172":2,"211":10,"276":4,"323":2,"358":8,"363":8,"366":4,"372":2,"373":4,"378":4,"380":4,"386":4,"402":2,"404":4,"408":2,"425":2,"426":8,"432":62,"530":2,"545":2,"561":4,"562":8,"564":8,"565":4,"566":8,"573":2,"627":48,"643":4,"656":2,"688":24,"783":4,"789":4}}],["3767182372",{"2":{"121":2,"285":2}}],["30s",{"2":{"682":4}}],["3001",{"2":{"682":2}}],["30000",{"2":{"682":2}}],["30000000",{"2":{"384":2}}],["3000",{"2":{"545":1,"682":2}}],["300xzo8tilwpnurey6ojcrkzthq4y6yy6qh0waummrc=",{"2":{"161":2}}],["30t08",{"2":{"372":2}}],["30",{"2":{"91":2,"165":2,"172":2,"480":4,"682":4}}],["3663",{"2":{"681":1}}],["3623",{"2":{"681":1}}],["362101",{"2":{"380":2}}],["36",{"2":{"23":1,"223":2}}],["35",{"2":{"23":1,"223":14,"649":14,"794":14}}],["3",{"0":{"15":1,"33":1,"84":1,"85":1,"638":1,"649":1,"794":1},"2":{"23":1,"28":1,"30":1,"31":1,"34":1,"43":1,"89":2,"91":4,"94":1,"102":2,"106":1,"121":2,"148":1,"149":6,"172":2,"276":2,"285":2,"394":2,"395":1,"401":2,"402":2,"403":4,"404":6,"405":2,"489":1,"510":2,"536":1,"544":2,"549":4,"582":1,"610":1,"649":2,"682":4,"794":2}}],["2382",{"2":{"687":4}}],["23",{"2":{"600":2}}],["26357",{"2":{"746":1}}],["26557",{"2":{"734":1}}],["26660",{"2":{"544":4,"545":2}}],["26656",{"2":{"510":1,"644":2,"705":1}}],["26659version",{"2":{"276":1}}],["26659",{"2":{"275":4,"276":3,"594":1}}],["26657",{"2":{"89":2,"152":2,"153":2,"380":1,"510":1,"512":1,"527":2,"583":2,"594":1,"643":4,"682":4,"733":1,"734":6,"745":1,"746":1,"747":3,"774":2}}],["26658curl",{"2":{"380":1,"386":1}}],["26658",{"2":{"89":3,"322":2,"359":1,"380":1,"386":1,"404":2,"407":2,"594":1}}],["26",{"2":{"488":1}}],["2️⃣",{"0":{"464":1,"469":1,"473":1}}],["2k",{"2":{"452":1}}],["2k×2k",{"2":{"450":2,"458":1}}],["27090",{"2":{"746":1,"749":1}}],["2727",{"2":{"687":6}}],["27t13",{"2":{"372":2}}],["27709",{"2":{"117":2,"281":2}}],["2585031",{"2":{"639":1,"679":1,"789":1}}],["2585031celestia",{"2":{"639":1,"789":1}}],["25231",{"2":{"601":5}}],["252614",{"2":{"363":3,"365":9,"378":2}}],["252607",{"2":{"363":2}}],["25",{"2":{"434":1,"489":1,"551":1,"649":2,"794":2}}],["255",{"2":{"313":6}}],["25630",{"2":{"370":4}}],["256gb",{"2":{"220":1}}],["256",{"2":{"117":2,"281":2}}],["2s",{"2":{"261":1}}],["22t14",{"2":{"396":4}}],["2283",{"2":{"384":2}}],["22",{"2":{"172":2,"275":2,"276":2,"362":4}}],["2zdir",{"2":{"156":2}}],["299137127z",{"2":{"372":2}}],["29",{"2":{"149":2,"165":7,"166":1,"172":2,"649":14,"794":14}}],["28657",{"2":{"734":1}}],["28090",{"2":{"730":1,"734":1}}],["28",{"2":{"165":5,"166":3,"172":8,"679":1}}],["28409",{"2":{"117":2,"281":2}}],["28334",{"2":{"117":2,"281":2}}],["28217653",{"2":{"91":2}}],["28217647",{"2":{"91":2}}],["2f",{"2":{"69":1}}],["2e",{"2":{"69":1}}],["2d",{"2":{"69":1}}],["2c",{"2":{"69":1,"72":1}}],["2blockhash",{"2":{"121":1,"285":1}}],["2b",{"2":{"69":1,"72":1}}],["2ae1ddf74ef7",{"2":{"149":2}}],["2a",{"2":{"69":1,"72":1}}],["24s",{"2":{"116":2,"280":2}}],["24",{"2":{"25":1,"385":2,"649":4,"794":4}}],["21090",{"2":{"749":1}}],["214",{"2":{"649":2,"794":2}}],["216\\tnew",{"2":{"396":2}}],["211\\tno",{"2":{"396":2}}],["21572",{"2":{"385":2}}],["21568",{"2":{"384":2}}],["2121",{"2":{"275":2,"276":2,"370":8,"510":4,"583":2,"584":4,"594":2,"777":2}}],["21",{"2":{"23":1,"116":2,"275":2,"276":2,"280":2,"551":1}}],["2019",{"2":{"719":1}}],["2001",{"2":{"649":2,"794":2}}],["200",{"2":{"370":4}}],["20000",{"2":{"682":2}}],["20000utia",{"2":{"299":2}}],["2000",{"2":{"294":4,"297":2}}],["20+",{"2":{"310":1}}],["2048",{"2":{"224":4}}],["20ignition",{"2":{"223":16}}],["20210819022825",{"2":{"149":2}}],["2023",{"2":{"30":1,"372":4}}],["2025",{"2":{"28":1}}],["2024",{"2":{"21":1,"28":2,"223":14,"396":4,"649":1,"679":3,"794":1}}],["20",{"2":{"23":1,"28":1,"43":1,"151":1,"152":2,"333":1,"488":1,"522":1,"624":1,"668":1,"710":1,"781":1}}],["2",{"0":{"14":1,"32":1,"69":1,"72":1,"83":1,"154":1,"637":1,"660":1,"685":1},"2":{"17":2,"23":2,"24":1,"27":1,"28":1,"31":1,"32":1,"34":1,"41":1,"43":1,"48":1,"71":1,"72":1,"80":1,"91":2,"94":4,"117":4,"121":1,"127":2,"148":1,"151":2,"154":1,"156":2,"161":2,"172":3,"184":1,"196":1,"215":1,"281":4,"285":1,"293":1,"313":2,"344":1,"368":2,"369":2,"370":2,"371":2,"372":4,"380":4,"384":2,"386":4,"401":2,"402":2,"404":2,"415":1,"450":1,"452":3,"453":3,"455":1,"458":1,"487":1,"489":2,"499":1,"510":2,"542":2,"549":4,"551":1,"566":2,"623":1,"639":1,"649":2,"747":1,"748":1,"749":1,"750":6,"758":2,"780":1,"784":1,"789":3,"794":2}}],["1×478bytes",{"2":{"724":1}}],["1️⃣",{"0":{"463":1,"468":1,"472":1}}],["1utia",{"2":{"426":2,"549":2}}],["1usgft4=",{"2":{"156":2}}],["1751707",{"2":{"639":1,"679":1,"789":1}}],["1751707celestia",{"2":{"639":1,"789":1}}],["17",{"2":{"488":1,"679":1}}],["171",{"2":{"370":4}}],["172118057",{"2":{"368":2}}],["1px",{"2":{"313":2}}],["1s",{"2":{"260":1,"261":1}}],["1hr",{"2":{"220":2}}],["19000000utia",{"2":{"535":2}}],["19l",{"2":{"295":2}}],["196",{"2":{"223":32}}],["19",{"2":{"116":4,"126":1,"127":2,"223":16,"280":4,"372":2,"488":1,"679":1}}],["1933",{"2":{"31":2,"34":3}}],["1443",{"2":{"749":1}}],["1400000",{"2":{"605":1}}],["147105",{"2":{"373":2}}],["14",{"2":{"91":2,"149":2,"358":1,"584":2,"596":1,"649":2,"679":3,"794":2}}],["1318129",{"2":{"599":2,"600":2,"601":2}}],["1317",{"2":{"510":1,"748":1}}],["1350632",{"2":{"156":2}}],["13",{"2":{"80":1,"91":2,"94":2,"116":2,"117":2,"280":2,"281":2,"305":4,"307":2,"480":2,"610":1,"723":1}}],["1g",{"2":{"71":1}}],["1f",{"2":{"71":1}}],["1em",{"2":{"313":2}}],["1ether",{"2":{"76":2,"317":2}}],["1e",{"2":{"71":1}}],["1d",{"2":{"71":1}}],["1container",{"2":{"275":1,"276":1}}],["1c",{"2":{"68":1,"71":1}}],["1b",{"2":{"68":1,"71":1}}],["1a",{"2":{"68":1,"71":1}}],["11090",{"2":{"730":1}}],["11036",{"2":{"545":1}}],["115",{"2":{"584":2}}],["118",{"2":{"432":2,"433":1,"434":1}}],["11celestia",{"2":{"396":1}}],["11155111",{"2":{"392":2}}],["1117733",{"2":{"392":2}}],["1141",{"2":{"384":2}}],["11",{"2":{"34":1,"223":2,"355":2,"372":4,"396":3,"433":2,"510":11,"513":2,"516":1,"517":1,"527":2,"649":4,"679":1,"713":2,"714":2,"794":4}}],["180000",{"2":{"682":4}}],["18",{"2":{"31":1,"84":1,"149":2,"312":2,"679":1}}],["16002",{"2":{"749":1}}],["1606",{"2":{"649":2,"794":2}}],["169",{"2":{"649":2,"794":2}}],["1699638350",{"2":{"384":2}}],["1637",{"2":{"649":2,"794":2}}],["1639397",{"2":{"295":2}}],["1687908352",{"2":{"565":2}}],["1686748051",{"2":{"564":8,"565":2,"571":2}}],["16px",{"2":{"313":2}}],["16xlarge",{"2":{"226":1}}],["16",{"2":{"30":1,"91":2,"172":2,"521":1,"623":1,"638":12,"667":1,"679":1,"757":2,"758":2,"780":1}}],["151",{"2":{"584":2}}],["15s",{"2":{"545":2}}],["1559",{"2":{"417":1}}],["15",{"2":{"28":2,"91":2,"151":1,"152":2,"161":1,"162":2,"169":1,"223":16,"313":4,"396":4,"488":1,"545":2}}],["15002",{"2":{"730":1}}],["1500",{"2":{"27":1}}],["10790",{"2":{"749":2}}],["10s",{"2":{"682":4}}],["103",{"2":{"536":2}}],["105",{"2":{"536":3}}],["1089",{"2":{"429":1}}],["1080694",{"2":{"156":2}}],["1040676758",{"2":{"385":2}}],["106",{"2":{"370":4}}],["10px",{"2":{"313":6}}],["1024cd",{"2":{"224":1}}],["1024",{"2":{"224":14}}],["1095604",{"2":{"156":2}}],["10+",{"2":{"40":1}}],["10",{"2":{"24":3,"34":1,"89":4,"121":3,"151":3,"152":2,"161":1,"162":1,"172":2,"285":3,"311":2,"363":1,"370":4,"392":1,"418":1,"433":1,"484":1,"494":1,"515":1,"521":1,"667":1,"682":4,"751":1,"757":2}}],["1000",{"2":{"682":2}}],["10001",{"2":{"656":4}}],["1000utia",{"2":{"549":4}}],["100000utia",{"2":{"549":2,"564":12,"571":4}}],["100000",{"2":{"375":4,"564":4,"565":2,"567":2,"571":2,"682":4}}],["10000000utia",{"2":{"700":2}}],["100000000000utia",{"2":{"537":2}}],["1000000000",{"2":{"536":2}}],["1000000000utia",{"2":{"536":2,"537":2}}],["1000000utia",{"2":{"299":2,"783":2}}],["1000000",{"2":{"294":3,"297":1,"369":2,"541":2}}],["1000000celestia",{"2":{"294":1,"297":1}}],["100vh",{"2":{"313":2}}],["100",{"2":{"21":1,"89":2,"171":2,"313":2,"483":2,"682":2,"709":1,"757":1}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22",{"2":{"777":1}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22node",{"2":{"777":1}}],["12d3koowkeertzvmpudxyszo2edqps6ms67n6lt5mpdulskpsxbq",{"2":{"584":2}}],["12d3koowlt1yssrd7xwsbjh7tu1hqanf5m64dhv6aum6cyejxmpk",{"2":{"510":1}}],["12d3koowewuqrjulanpukdfgvohw3roeuu53ec9t9v5cww3mkvdq",{"2":{"510":1}}],["12d3koowcmgm5ezwvfcn9zlavigfluwafxp5pcm78nfkb9jpbtua",{"2":{"510":1}}],["12d3koowgqwzdeqm54dce6lxzffr97bnhvm6rn7km7mfwdomfm4s",{"2":{"510":1}}],["12d3koowffhcaaqy56oeqy3plzudlsv4ryafvwkatzrepupdoslp",{"2":{"370":2}}],["127",{"2":{"283":1,"380":3,"386":2,"643":2,"682":4}}],["1234",{"2":{"211":3}}],["123456",{"2":{"606":1}}],["1234567890",{"2":{"426":2}}],["12345=",{"2":{"211":6}}],["12345",{"2":{"211":9,"305":14,"308":2,"309":2}}],["128gb",{"2":{"413":1}}],["128",{"2":{"156":2}}],["120000",{"2":{"156":2}}],["12",{"2":{"23":2,"335":1,"488":1}}],["1",{"0":{"13":1,"31":1,"68":1,"71":1,"82":1,"150":1,"636":1},"1":{"151":1,"152":1},"2":{"17":2,"22":1,"23":7,"24":1,"25":1,"26":1,"28":4,"30":1,"31":8,"32":1,"34":2,"41":1,"48":1,"80":1,"82":1,"83":1,"91":4,"94":6,"102":4,"116":2,"117":3,"121":2,"137":4,"139":2,"148":1,"149":4,"151":2,"152":6,"153":2,"154":1,"156":2,"161":5,"162":2,"165":6,"166":2,"169":2,"172":14,"215":1,"225":1,"238":2,"260":2,"261":1,"275":1,"276":1,"280":2,"281":3,"283":1,"285":2,"293":1,"305":12,"355":2,"368":2,"369":2,"370":6,"371":2,"372":13,"375":1,"380":7,"386":6,"387":1,"396":2,"401":2,"402":2,"404":2,"408":2,"415":4,"421":1,"426":2,"432":2,"434":1,"443":1,"452":1,"484":1,"488":1,"489":8,"494":3,"502":2,"510":2,"513":2,"521":2,"527":2,"536":1,"541":2,"542":2,"551":1,"601":5,"623":2,"635":1,"639":1,"643":2,"649":2,"667":2,"682":14,"713":2,"714":2,"724":1,"747":1,"748":1,"749":1,"750":4,"757":2,"758":2,"780":2,"789":3,"794":2}}],["ua",{"2":{"746":2,"747":1,"748":1,"749":1,"753":1}}],["uatom",{"2":{"682":2}}],["udp",{"2":{"370":6,"583":1,"594":1}}],["uri",{"2":{"355":6,"356":6,"526":8,"527":2,"528":6,"535":4,"586":4,"587":2,"588":2,"589":8,"592":2,"673":2,"674":6,"716":6,"777":2,"778":2,"786":2}}],["urldocker",{"2":{"658":3}}],["url=this",{"2":{"655":2}}],["url=rpc",{"2":{"292":2}}],["url=",{"2":{"91":4,"218":2}}],["url=https",{"2":{"284":2,"299":2,"317":2,"571":2}}],["url=http",{"2":{"75":2,"120":2,"283":2}}],["urlexport",{"2":{"76":1,"317":1}}],["urlcast",{"2":{"76":3,"121":1,"285":1,"317":3}}],["url",{"0":{"88":1},"2":{"47":2,"75":5,"76":12,"88":5,"89":4,"91":1,"120":4,"121":7,"212":4,"213":12,"219":5,"220":2,"227":2,"249":1,"278":1,"283":4,"284":5,"285":7,"294":2,"295":2,"299":3,"308":2,"309":6,"314":1,"317":17,"322":2,"323":4,"324":4,"325":4,"326":4,"358":1,"359":1,"384":2,"385":2,"392":2,"407":2,"408":4,"409":4,"410":4,"425":4,"433":3,"434":4,"509":1,"512":1,"513":3,"545":2,"571":5,"573":1,"655":9,"658":3,"682":4,"726":1,"733":1,"734":3,"744":1,"745":1,"746":1}}],["urls",{"0":{"247":1},"1":{"248":1,"249":1},"2":{"47":2,"88":1,"211":2,"220":1,"247":2}}],["ubuntu",{"2":{"333":1,"522":1,"624":1,"653":1,"663":1,"664":2,"668":1,"710":1,"781":1}}],["ugp0sv9ynei5poiyr7rdodswwlfbh2o3xirsmmnmbks=",{"2":{"161":2}}],["uhlbgdgo=",{"2":{"156":2}}],["uhhb3u6dpayj1pjnefrwq5he=",{"2":{"151":2}}],["utc",{"2":{"679":3}}],["ut8sjtguh+akimnqtkuuu",{"2":{"156":2}}],["utility",{"0":{"267":1,"402":1},"1":{"268":1,"269":1,"270":1,"271":1,"272":1},"2":{"266":1,"267":3,"269":1,"401":1,"402":2,"403":1,"609":1,"714":1}}],["utilizing",{"0":{"47":1}}],["utilizes",{"2":{"237":1}}],["utilize",{"2":{"43":1,"45":2,"46":1,"334":1}}],["utia=tia×10−6",{"2":{"494":1}}],["utiacelestia",{"2":{"300":1}}],["utia",{"0":{"375":1,"502":1},"2":{"89":1,"294":2,"295":3,"296":2,"300":1,"366":1,"368":2,"369":2,"375":6,"432":6,"433":1,"434":1,"502":3,"503":1,"536":2,"564":4,"565":2,"567":4,"682":2}}],["uint32",{"2":{"420":4,"426":4}}],["uint",{"2":{"294":1,"305":18}}],["uint8",{"2":{"166":2,"215":2}}],["uint64",{"2":{"134":8,"135":4,"137":4,"139":4,"153":10,"169":4,"172":14,"228":3,"326":2,"402":2}}],["uint256",{"2":{"116":4,"117":4,"121":2,"127":2,"163":2,"165":4,"168":4,"169":4,"184":3,"228":1,"280":4,"281":4,"285":2}}],["ui",{"2":{"68":1,"71":1,"72":2,"84":1}}],["ultimate",{"2":{"49":1}}],["u",{"2":{"31":2,"34":5,"541":6,"774":2,"776":2,"777":2,"778":2}}],["upper",{"2":{"724":1}}],["upload",{"2":{"313":1,"335":1,"352":1,"521":1,"623":1,"667":1,"683":1,"709":1,"780":1}}],["uploaded",{"2":{"309":1}}],["uploading",{"2":{"303":1}}],["updocker",{"2":{"276":1}}],["updating",{"0":{"305":1,"307":1},"2":{"180":1,"219":3,"225":1,"557":2}}],["updatepost",{"2":{"305":6}}],["updatename",{"2":{"305":2}}],["updateheaders",{"2":{"137":2}}],["updatesudo",{"2":{"663":1}}],["updates",{"2":{"117":1,"219":1,"239":1,"281":1,"305":4,"505":1,"720":1,"760":1,"763":1}}],["update",{"0":{"77":1,"318":1},"2":{"77":2,"84":1,"149":1,"180":1,"211":2,"219":5,"225":1,"237":3,"238":1,"239":1,"261":1,"305":2,"307":1,"312":1,"313":1,"315":1,"318":2,"404":1,"421":1,"437":1,"456":1,"480":1,"536":2,"602":4,"649":1,"663":4,"703":1,"794":1}}],["updatedpost",{"2":{"305":4}}],["updated",{"2":{"5":1,"91":2,"137":1,"211":1,"225":2,"238":1,"301":1,"402":1,"505":1,"763":1}}],["upgrading",{"0":{"612":1},"2":{"219":2}}],["upgraded",{"2":{"639":1,"649":1,"789":1,"794":1}}],["upgradeexecutor",{"2":{"91":2}}],["upgrade",{"0":{"552":1},"2":{"25":1,"91":4,"94":1,"219":2,"330":1,"552":1,"612":1,"639":10,"649":2,"663":3,"677":3,"678":4,"679":8,"789":10,"794":2}}],["upgrades",{"0":{"505":1,"518":1,"720":1,"739":1,"754":1,"767":1},"2":{"24":1,"504":1,"505":1,"518":2,"536":1,"552":1,"677":2,"678":1,"679":1,"719":1,"720":1,"739":2,"754":2,"765":1,"767":2}}],["upcoming",{"2":{"53":1,"161":1,"162":1,"175":1,"177":1,"230":1,"677":1}}],["ups",{"2":{"39":1}}],["upon",{"2":{"34":3,"56":1,"137":1,"143":1,"365":1,"380":1,"489":1,"528":1,"674":1,"716":1}}],["up",{"0":{"91":1,"353":1,"390":1,"404":1,"519":1,"522":1,"555":1,"560":1,"572":1,"624":1,"625":1,"627":1,"665":1,"668":1,"696":1,"707":1,"710":1,"772":1,"779":1,"781":1},"1":{"354":1,"355":1,"356":1,"520":1,"521":1,"522":1,"523":2,"524":1,"525":1,"526":1,"527":1,"528":1,"529":1,"556":1,"557":1,"558":1,"559":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"625":1,"626":1,"627":1,"666":1,"667":1,"668":1,"669":2,"670":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"708":1,"709":1,"710":1,"711":2,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1,"780":1,"781":1,"782":2,"783":2,"784":1,"785":1,"786":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"793":1,"794":1},"2":{"21":1,"23":1,"26":1,"36":1,"37":1,"38":1,"47":3,"48":1,"54":1,"60":1,"61":1,"88":2,"90":1,"115":1,"177":2,"208":1,"261":1,"266":1,"269":1,"275":2,"276":3,"279":1,"313":1,"337":3,"354":1,"362":1,"395":1,"397":2,"399":1,"400":2,"405":1,"428":1,"445":1,"446":1,"519":1,"529":2,"543":1,"545":1,"546":1,"559":1,"568":2,"571":1,"572":1,"581":1,"589":1,"606":1,"609":1,"619":1,"622":1,"636":2,"662":1,"665":1,"669":1,"684":1,"696":1,"697":1,"707":1,"710":2,"717":1,"755":1,"758":1,"773":1,"774":1,"779":1,"781":1,"788":2,"789":1}}],["uptime",{"2":{"21":1,"23":1,"27":2,"33":1,"253":1,"586":1,"734":1}}],["unexplored",{"2":{"720":1}}],["unexpectedly",{"2":{"505":1}}],["unordered",{"2":{"687":2}}],["unmarshaling",{"2":{"599":2}}],["unjail",{"2":{"540":3,"551":2}}],["unjailing",{"0":{"540":1}}],["unbonded",{"2":{"551":1}}],["unbond",{"2":{"539":3}}],["unbonding",{"2":{"217":1,"551":1}}],["unused",{"2":{"400":1,"417":1,"419":1}}],["untested",{"2":{"333":1}}],["until",{"2":{"107":1,"139":1,"293":1,"421":1,"426":2,"445":1,"484":1,"494":1,"505":1,"681":1,"774":1}}],["unknown",{"2":{"169":1}}],["unstable",{"2":{"763":1}}],["unstake",{"2":{"466":1,"470":1,"475":1}}],["unsafe",{"2":{"309":2,"315":2,"603":4,"641":2,"649":1,"697":2,"794":1}}],["unsubscribe",{"2":{"171":2}}],["unsignedtx",{"2":{"549":8}}],["unsigned",{"2":{"116":1,"117":1,"280":1,"281":1}}],["unsolicited",{"2":{"14":1,"15":1}}],["unpacked",{"2":{"109":1}}],["unpealed",{"2":{"108":2}}],["unprofessional",{"2":{"13":1}}],["unlocked",{"2":{"489":9}}],["unlocks",{"0":{"489":1},"2":{"489":4}}],["unlock",{"2":{"432":2,"489":3}}],["unlocking",{"2":{"55":1}}],["unlimited",{"2":{"544":2}}],["unlike",{"2":{"136":1,"178":1,"228":1,"342":1}}],["unlicensed",{"2":{"116":2,"117":2,"280":2,"281":2}}],["unless",{"2":{"24":1,"31":2,"34":4,"208":1,"380":1,"390":1,"696":1}}],["unix",{"2":{"596":1}}],["unify",{"2":{"291":1}}],["unified",{"2":{"148":1}}],["universal",{"2":{"223":1}}],["university",{"2":{"40":1}}],["universities",{"2":{"40":2,"44":1}}],["unit",{"2":{"117":1,"281":1,"426":2,"774":2,"776":2,"777":2,"778":2}}],["united",{"2":{"34":9}}],["unique",{"2":{"33":1,"47":1,"84":2,"263":1,"450":2,"452":1,"557":1}}],["unauthorized",{"2":{"599":2}}],["unavailability",{"2":{"287":1}}],["unavailable",{"0":{"183":1},"2":{"139":1,"188":1}}],["unaffected",{"2":{"264":1}}],["unaffiliated",{"2":{"31":1}}],["unable",{"2":{"31":3,"421":1,"443":1,"551":1}}],["unacceptable",{"2":{"8":1,"11":1}}],["undelegate",{"0":{"539":1},"2":{"539":1}}],["undelegation",{"0":{"25":1}}],["undergoes",{"2":{"505":1}}],["underneath",{"0":{"92":1,"388":1},"1":{"389":1,"390":1,"391":1,"392":1,"393":1},"2":{"107":2,"108":1,"244":1,"337":1,"339":2,"393":1}}],["underlying",{"2":{"84":1,"91":1,"107":1,"110":1}}],["underwriter",{"2":{"34":1}}],["undertake",{"2":{"34":1}}],["undertaking",{"2":{"34":1}}],["understanding",{"0":{"615":1},"1":{"616":1,"617":1,"618":1,"619":1,"620":1,"621":1},"2":{"42":1,"65":1,"114":2,"254":1,"261":1,"274":1,"278":2,"484":1,"654":2}}],["understand",{"2":{"30":1,"33":1,"34":4,"47":1,"48":3,"65":1,"89":1,"130":1,"340":1,"478":1,"571":1}}],["under",{"2":{"24":1,"27":1,"30":1,"31":1,"34":10,"68":2,"72":1,"88":1,"94":1,"129":1,"157":1,"203":1,"217":1,"219":1,"223":2,"224":1,"267":1,"269":1,"405":1,"415":2,"417":1,"544":2,"605":1,"637":1,"791":1}}],["unwelcome",{"2":{"13":1}}],["usr",{"2":{"582":1,"610":1,"649":4,"664":21,"794":4}}],["usual",{"2":{"184":1}}],["usually",{"2":{"84":1,"527":1,"619":1,"673":1,"713":1}}],["usable",{"0":{"163":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1},"2":{"130":1,"151":1,"156":1,"161":1}}],["usage",{"0":{"127":1,"203":1,"204":1,"205":1},"1":{"204":1,"205":1},"2":{"205":1,"401":2,"402":2,"404":2,"530":2,"533":1,"534":1,"535":2,"546":1,"609":1}}],["using",{"0":{"120":1,"155":1,"158":1,"267":1,"283":1,"284":1,"292":1,"295":1,"299":1,"380":1,"511":1,"601":1},"1":{"156":1,"157":1,"159":1,"268":1,"269":1,"270":1,"271":1,"272":1,"293":1,"294":1,"300":1,"512":1,"513":1},"2":{"10":1,"33":1,"36":1,"37":1,"48":1,"75":2,"79":1,"82":1,"84":1,"88":1,"89":6,"91":1,"108":1,"110":1,"111":1,"113":1,"119":1,"121":1,"126":3,"131":3,"135":1,"136":2,"139":1,"145":1,"146":1,"148":3,"150":1,"152":1,"154":1,"157":1,"158":2,"159":1,"162":1,"164":2,"169":2,"171":1,"172":3,"177":1,"178":1,"179":2,"181":3,"182":2,"184":6,"185":1,"187":1,"188":2,"193":1,"195":1,"197":1,"200":3,"203":1,"206":1,"208":4,"211":7,"213":1,"217":1,"218":1,"223":1,"224":1,"227":2,"230":2,"236":1,"238":1,"265":1,"266":1,"268":1,"275":1,"276":3,"285":1,"287":1,"293":1,"305":1,"307":1,"308":1,"310":2,"311":1,"313":1,"315":3,"317":2,"321":1,"324":3,"325":3,"326":1,"330":1,"337":2,"350":1,"356":1,"357":1,"359":1,"360":1,"361":2,"362":2,"364":1,"378":1,"380":2,"388":1,"392":1,"394":3,"396":1,"402":8,"403":2,"404":2,"406":1,"409":1,"410":1,"412":1,"413":1,"420":2,"424":1,"426":4,"427":2,"432":2,"452":1,"453":2,"455":3,"458":2,"477":1,"481":2,"497":1,"513":1,"514":1,"526":1,"528":1,"536":1,"537":1,"547":1,"548":1,"553":1,"563":1,"571":1,"576":1,"581":1,"584":1,"597":3,"601":1,"602":1,"607":2,"632":1,"634":1,"636":1,"653":3,"655":1,"657":2,"661":1,"664":1,"673":1,"674":1,"680":1,"682":1,"714":1,"715":1,"716":1,"748":2,"749":1,"751":1,"783":1}}],["useaccount",{"2":{"313":4}}],["useeffect",{"2":{"313":6}}],["useful",{"2":{"48":1,"57":1,"90":1,"505":1,"627":1,"748":1,"772":1,"774":1}}],["user=$user",{"2":{"774":2,"776":2,"777":2,"778":2}}],["user",{"0":{"426":1},"2":{"42":1,"47":2,"48":1,"131":2,"133":1,"260":1,"287":1,"305":2,"310":1,"312":1,"330":1,"341":1,"342":1,"359":2,"363":1,"417":2,"419":3,"421":1,"426":8,"430":1,"432":4,"498":1,"501":1,"545":1,"550":1,"597":8,"621":1,"656":1,"691":2,"774":2,"776":2,"777":2,"778":2}}],["users",{"2":{"19":1,"30":1,"84":1,"174":1,"192":1,"230":2,"264":1,"287":1,"313":3,"344":1,"346":1,"362":1,"391":1,"414":1,"417":3,"419":3,"420":1,"421":2,"422":1,"436":2,"443":2,"446":2,"447":1,"457":1,"458":1,"481":1,"490":1,"512":1,"513":1,"653":1,"661":1,"720":1,"733":1,"734":1,"745":1,"746":1,"747":1,"748":1,"749":1,"760":1}}],["usestate",{"2":{"313":10}}],["uses",{"0":{"172":1},"2":{"40":1,"94":1,"105":1,"110":1,"121":1,"135":4,"139":1,"172":4,"187":1,"191":1,"197":1,"206":1,"233":1,"234":1,"245":1,"267":1,"285":1,"305":1,"323":2,"337":1,"339":1,"345":1,"403":2,"417":1,"419":1,"420":1,"421":1,"425":2,"441":1,"450":1,"478":1,"484":1,"498":1,"544":1,"551":1,"599":1,"600":1,"637":1,"680":1,"691":1}}],["use",{"0":{"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"196":1,"197":1,"198":1,"199":1,"201":1,"202":1,"208":1},"1":{"189":1,"190":1,"191":1,"193":1,"194":1,"197":1,"198":1,"200":1,"201":1,"202":1},"2":{"8":1,"13":1,"19":1,"31":3,"33":3,"34":1,"45":1,"47":1,"48":2,"82":1,"88":2,"89":3,"102":2,"107":1,"119":1,"120":1,"121":1,"133":1,"134":2,"136":2,"137":1,"142":1,"146":1,"148":1,"153":2,"161":1,"162":1,"163":1,"165":2,"170":2,"171":1,"172":2,"174":1,"183":2,"184":2,"195":1,"199":1,"206":1,"208":1,"211":4,"213":3,"219":1,"220":1,"222":1,"224":1,"230":1,"237":2,"249":1,"264":1,"268":1,"269":1,"271":1,"285":1,"289":1,"292":1,"293":1,"294":1,"295":1,"299":1,"305":2,"307":1,"308":4,"309":1,"315":1,"322":4,"323":2,"330":2,"332":1,"346":1,"348":1,"351":1,"355":1,"358":4,"359":1,"360":1,"361":2,"363":4,"365":5,"366":2,"375":1,"376":1,"377":2,"380":1,"388":1,"400":3,"402":3,"407":4,"408":7,"413":1,"416":1,"417":1,"418":1,"426":6,"431":1,"432":1,"455":1,"456":1,"481":1,"496":1,"517":1,"526":1,"536":2,"537":1,"545":2,"552":1,"554":1,"557":1,"558":1,"564":1,"569":1,"571":2,"572":1,"573":1,"581":1,"589":1,"594":1,"596":1,"607":1,"609":1,"616":1,"653":1,"664":1,"673":1,"676":1,"679":1,"681":1,"683":1,"685":1,"686":2,"687":1,"688":1,"698":2,"703":1,"737":1,"753":1,"771":1}}],["used",{"2":{"3":1,"30":1,"84":2,"88":1,"89":4,"91":1,"107":3,"108":1,"134":2,"136":1,"137":2,"139":1,"145":2,"156":2,"158":1,"160":1,"165":1,"166":1,"175":2,"183":1,"196":2,"208":2,"211":5,"222":2,"223":3,"224":3,"225":1,"230":1,"237":1,"239":1,"267":1,"291":1,"330":1,"333":1,"335":1,"343":1,"355":1,"359":2,"366":1,"378":1,"402":1,"417":1,"418":2,"419":1,"420":2,"450":1,"455":1,"458":1,"504":1,"509":1,"525":1,"527":1,"536":1,"543":1,"551":1,"564":2,"578":1,"581":1,"583":1,"594":1,"615":1,"644":1,"647":1,"656":1,"662":1,"673":2,"678":1,"680":1,"683":1,"726":1,"744":1,"749":1,"750":1,"783":2,"789":2}}],["us",{"2":{"8":1,"24":1,"27":1,"30":1,"31":3,"33":2,"34":1,"48":6,"109":3,"264":1,"378":1,"401":1,"403":1,"432":1,"724":2}}],["huzwottdmd36n1f75a9bshxnlrascnnpqiwqihdvhcu",{"2":{"372":4}}],["hub",{"2":{"246":1,"251":1,"680":1,"682":1,"683":1}}],["h2",{"2":{"313":8}}],["h3",{"2":{"313":8}}],["h1",{"2":{"313":8}}],["hzfy",{"2":{"156":2}}],["historic",{"2":{"480":1,"481":3}}],["historical",{"0":{"446":1,"447":1,"633":1},"2":{"443":2,"446":2,"447":2,"448":1,"479":1,"481":9,"633":1}}],["history",{"2":{"443":1,"447":1,"513":1,"606":1,"622":1,"734":1,"735":1,"755":1}}],["hidden",{"2":{"135":1,"394":1}}],["hiring",{"2":{"44":1}}],["highly",{"2":{"527":1,"651":1,"673":1}}],["highlighted",{"2":{"146":1}}],["highlight",{"2":{"44":1,"64":1}}],["highlights",{"2":{"38":1}}],["higher",{"2":{"84":1,"264":1,"366":1,"415":1,"416":1,"421":1,"478":1,"484":1}}],["high",{"2":{"23":1,"46":1,"65":1,"84":1,"108":1,"109":2,"131":1,"133":1,"230":1,"235":1,"237":1,"392":1,"432":2,"450":1,"605":1,"749":1}}],["h",{"2":{"34":1,"380":4,"386":4}}],["hollow",{"2":{"561":2}}],["holds",{"2":{"86":1}}],["holders",{"2":{"486":1,"537":1}}],["holder",{"2":{"34":1}}],["hold",{"2":{"34":1,"42":1}}],["holding",{"2":{"34":2}}],["hooks",{"2":{"310":1}}],["hood",{"2":{"94":1,"267":1,"417":1}}],["homebrew",{"2":{"663":4}}],["homecd",{"2":{"561":1}}],["home=",{"2":{"557":2}}],["home",{"0":{"557":1},"2":{"269":1,"359":1,"557":4,"561":3,"562":4,"564":12,"565":4,"566":4,"567":8,"583":1,"594":1,"597":8,"641":2,"657":8,"658":8,"697":2}}],["hosted",{"2":{"227":1,"244":1,"245":1,"589":1}}],["hosts",{"2":{"89":2}}],["host",{"2":{"89":8,"102":2,"260":1,"261":1,"313":2,"573":2,"601":2,"656":3,"682":4,"686":6}}],["hosting",{"2":{"27":1,"43":1,"46":1,"48":2,"79":1}}],["honesty",{"2":{"443":1}}],["honest",{"2":{"84":1,"440":2,"450":1,"452":1,"459":2}}],["hour",{"2":{"48":1,"225":1,"238":2,"635":1}}],["hours",{"2":{"25":1,"71":1,"72":1,"180":1,"225":1,"238":1,"635":1}}],["hope",{"2":{"48":2}}],["however",{"2":{"44":1,"47":1,"135":1,"139":1,"184":1,"195":1,"206":1,"208":1,"359":1,"417":1,"418":1,"441":1,"451":1,"453":1,"455":1,"536":1,"589":1,"621":1,"647":1}}],["how",{"0":{"239":1,"240":1,"438":1,"460":1,"541":1,"553":1},"1":{"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"472":1,"473":1,"474":1,"475":1,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1},"2":{"22":1,"41":1,"42":1,"44":2,"47":1,"48":1,"60":1,"66":1,"84":1,"89":1,"92":1,"109":1,"111":1,"113":1,"122":2,"130":1,"131":1,"133":1,"135":1,"136":1,"143":2,"146":1,"148":2,"181":1,"191":1,"225":1,"238":1,"243":1,"265":1,"274":1,"275":1,"286":1,"301":2,"332":1,"339":1,"348":1,"357":1,"358":2,"360":1,"388":1,"391":1,"392":1,"394":1,"418":2,"419":1,"420":2,"426":2,"431":2,"432":2,"439":1,"460":1,"477":1,"478":1,"480":1,"483":2,"484":1,"486":1,"487":1,"496":1,"498":1,"508":2,"543":2,"550":1,"552":1,"553":1,"567":1,"568":2,"572":1,"575":2,"576":1,"589":1,"606":1,"622":1,"646":1,"647":1,"680":2,"725":2,"740":3,"755":1,"768":1}}],["http2",{"2":{"748":1}}],["httpexport",{"2":{"284":1,"317":1}}],["http",{"0":{"151":1,"156":1,"161":1},"2":{"88":1,"89":4,"90":1,"91":3,"119":2,"120":1,"145":6,"151":1,"152":4,"153":4,"159":2,"164":1,"165":1,"172":2,"248":1,"284":1,"308":2,"309":6,"311":2,"312":4,"313":2,"314":1,"317":1,"322":2,"346":1,"359":1,"386":2,"407":2,"583":1,"594":2,"599":2,"601":2,"655":1,"748":1}}],["https",{"0":{"248":1},"2":{"17":3,"75":2,"87":2,"91":2,"165":2,"166":2,"169":2,"211":2,"212":2,"217":2,"220":2,"223":18,"224":2,"227":1,"246":1,"248":1,"251":1,"252":1,"268":2,"290":1,"300":2,"313":2,"314":1,"317":2,"338":1,"392":2,"402":2,"413":2,"433":3,"434":4,"491":3,"492":3,"509":4,"510":2,"516":1,"517":3,"535":4,"550":4,"573":2,"581":2,"582":2,"609":2,"610":2,"627":10,"638":12,"655":1,"663":2,"664":8,"682":8,"683":2,"726":4,"737":9,"738":5,"744":4,"748":16,"752":1,"753":9}}],["html",{"2":{"17":1,"165":2,"166":2}}],["halo",{"2":{"520":1}}],["halting",{"2":{"437":1}}],["hamburger",{"2":{"434":1}}],["handpicking",{"2":{"545":1}}],["handful",{"2":{"308":1}}],["hand",{"2":{"235":1}}],["hands",{"0":{"149":1},"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}}],["handling",{"2":{"110":1,"337":1}}],["handlemsg",{"2":{"649":2,"794":2}}],["handlecompleteproposal",{"2":{"649":2,"794":2}}],["handled",{"2":{"417":1}}],["handles",{"2":{"91":1,"228":1,"337":1,"359":1}}],["handle",{"2":{"31":1,"426":4,"457":1}}],["happen",{"2":{"459":1,"678":1}}],["happens",{"2":{"107":1,"678":1}}],["happened",{"2":{"85":1}}],["happening",{"2":{"5":1}}],["happy",{"2":{"47":1,"63":1}}],["having",{"2":{"40":2,"41":1,"84":1,"179":1,"180":1,"192":1,"202":1,"220":1,"227":1,"439":2,"653":1}}],["haven",{"2":{"432":2,"611":1}}],["have",{"2":{"4":1,"9":1,"24":3,"27":1,"30":1,"31":5,"32":3,"34":8,"40":4,"41":1,"42":1,"43":1,"45":1,"46":2,"47":1,"63":1,"72":1,"76":1,"79":1,"85":1,"89":1,"90":1,"91":2,"108":2,"119":1,"125":1,"133":1,"135":1,"149":1,"163":4,"178":1,"192":2,"202":1,"211":4,"217":1,"218":1,"219":1,"220":1,"223":2,"224":1,"225":1,"237":1,"243":1,"254":1,"265":1,"269":1,"293":1,"294":1,"295":1,"296":1,"297":1,"300":2,"301":1,"310":1,"312":2,"316":1,"317":1,"321":1,"335":2,"346":1,"351":2,"353":1,"357":1,"359":1,"382":1,"388":1,"390":2,"392":1,"393":1,"396":1,"397":1,"404":1,"406":1,"408":1,"421":1,"437":1,"438":2,"441":1,"447":1,"453":1,"459":2,"475":1,"481":1,"488":1,"520":1,"529":1,"551":3,"559":1,"560":1,"568":1,"579":2,"582":1,"584":1,"585":1,"594":1,"610":1,"614":1,"650":1,"655":1,"658":1,"664":1,"682":2,"683":1,"685":1,"687":1,"688":1,"697":1,"702":1,"703":1,"706":1,"708":1,"715":1,"724":1,"734":1,"740":1,"774":1,"788":1,"789":1}}],["had",{"2":{"32":1,"172":2,"302":1,"358":1}}],["hash=580b3dff8a7c716968161d91116a1e171f486298d582874e93714e489c9e6e88",{"2":{"584":2}}],["hash=",{"2":{"584":2}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"384":1}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7export",{"2":{"384":1}}],["hash=0xef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"156":1}}],["hashtopost",{"2":{"305":8}}],["hashtags",{"2":{"45":1}}],["hashing",{"2":{"108":1}}],["hashes",{"2":{"108":2,"127":4,"237":1}}],["hash",{"0":{"155":1,"158":1,"208":1,"218":1,"606":1,"632":1},"1":{"156":1,"157":1,"159":1,"607":1},"2":{"91":6,"108":2,"120":2,"127":10,"134":2,"137":2,"151":2,"153":2,"155":1,"156":5,"157":2,"158":1,"159":4,"161":2,"169":1,"181":1,"208":8,"218":3,"219":5,"284":2,"305":30,"313":1,"372":24,"375":1,"384":4,"385":4,"453":1,"584":6,"606":10,"607":1,"609":1,"621":2,"632":1,"637":3,"646":2,"783":3,"789":2}}],["has",{"2":{"28":1,"32":1,"34":2,"47":1,"50":1,"84":1,"89":1,"91":3,"94":1,"107":2,"108":1,"110":2,"127":3,"177":1,"178":1,"179":1,"206":1,"208":1,"228":1,"287":1,"293":1,"297":1,"304":1,"308":1,"309":1,"323":1,"346":1,"358":1,"382":1,"396":2,"415":1,"418":2,"436":1,"446":1,"451":1,"453":1,"480":1,"481":1,"505":1,"515":1,"520":1,"545":1,"547":1,"565":1,"596":2,"638":1,"639":1,"649":1,"653":1,"673":1,"687":1,"712":1,"723":1,"724":1,"751":1,"762":1,"774":1,"778":1,"789":1,"794":1}}],["hard",{"2":{"724":2}}],["hardforks",{"2":{"677":1,"678":1,"765":1}}],["hardfork",{"0":{"677":1,"679":1},"1":{"678":1,"679":1},"2":{"505":1,"518":2,"677":2,"678":2,"679":4,"739":2,"754":2,"767":2}}],["hardhat",{"2":{"91":1}}],["hardware",{"0":{"352":1,"521":1,"623":1,"667":1,"693":1,"709":1,"780":1},"2":{"27":1,"60":1,"61":1,"352":1,"521":1,"623":1,"667":1,"693":1,"709":1,"780":1}}],["harassing",{"2":{"11":1}}],["harassment",{"2":{"7":1,"8":1,"16":1}}],["harmfully",{"2":{"551":1}}],["harmful",{"2":{"9":1,"25":1}}],["hermes",{"0":{"681":1,"688":1},"1":{"682":1,"683":1,"684":1},"2":{"680":2,"681":9,"682":4,"683":4,"684":2,"685":1,"689":1}}],["hereby",{"2":{"32":1,"34":4}}],["herein",{"2":{"30":1}}],["here",{"2":{"0":1,"22":1,"52":1,"60":1,"61":1,"64":1,"108":1,"109":1,"117":1,"134":1,"135":1,"137":1,"139":1,"227":1,"257":1,"281":1,"305":3,"309":1,"312":1,"360":1,"363":2,"365":3,"369":1,"372":2,"375":1,"392":1,"400":1,"402":2,"426":4,"526":1,"527":1,"536":1,"545":2,"571":1,"587":1,"588":1,"589":1,"590":1,"637":1,"699":2,"700":1,"702":1,"725":1,"773":1,"789":1}}],["hence",{"2":{"418":1,"665":1}}],["helloworldblob",{"2":{"323":4,"425":4}}],["hello",{"2":{"323":4,"363":1,"408":4,"425":4}}],["helpful",{"0":{"530":1},"1":{"531":1,"532":1,"533":1,"534":1,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"542":1},"2":{"581":1,"582":1}}],["helpcelestia",{"2":{"377":2,"534":1,"535":1,"571":1,"581":1,"690":1}}],["helper",{"2":{"141":1,"165":1,"168":1,"169":1}}],["helping",{"2":{"47":1,"287":1,"530":2,"692":1}}],["helps",{"2":{"2":1,"43":1,"46":1,"48":4,"84":1}}],["help",{"0":{"377":1},"2":{"0":1,"33":1,"35":2,"36":1,"39":1,"40":1,"41":1,"42":3,"43":2,"44":1,"45":2,"46":2,"47":3,"48":2,"57":2,"131":1,"264":1,"272":2,"377":4,"401":1,"403":1,"498":1,"530":6,"534":1,"535":1,"571":2,"581":2,"590":1,"618":1,"690":2,"740":1,"768":1}}],["height=",{"2":{"218":1}}],["height=15",{"2":{"151":1,"161":1,"169":1}}],["heightsub",{"0":{"604":1},"2":{"604":4}}],["heights",{"2":{"217":1,"226":1,"679":1}}],["height",{"0":{"372":1},"2":{"107":2,"128":1,"134":8,"135":4,"137":2,"139":6,"148":3,"150":2,"151":1,"153":16,"156":2,"159":2,"160":1,"169":17,"170":8,"172":8,"177":1,"181":2,"192":2,"196":1,"217":1,"218":4,"219":2,"221":1,"238":1,"295":3,"313":4,"323":8,"324":4,"325":11,"326":7,"363":5,"365":6,"366":3,"372":10,"373":2,"378":3,"380":1,"402":17,"404":4,"408":10,"409":13,"410":1,"425":6,"453":1,"484":1,"530":4,"564":4,"606":3,"607":2,"633":1,"636":1,"637":3,"639":11,"646":2,"649":1,"679":6,"783":2,"789":13,"794":1}}],["hexbytes",{"2":{"167":2,"172":2}}],["hextoaddress",{"2":{"153":2,"170":2,"171":2,"172":2}}],["hexadecimal",{"2":{"121":1,"285":1,"363":1,"402":1}}],["hex",{"2":{"76":1,"89":1,"157":2,"159":4,"164":1,"165":1,"166":1,"211":2,"219":1,"317":1,"363":8,"365":2,"400":2,"402":11,"404":2,"423":4,"424":4}}],["health",{"2":{"543":1,"684":4,"734":1}}],["healthy",{"2":{"7":1,"684":1}}],["heavy",{"0":{"203":1,"204":1,"205":1},"1":{"204":1,"205":1},"2":{"205":1}}],["headerclient",{"2":{"408":2}}],["headerchan",{"2":{"325":2}}],["headerrangefunctionid",{"2":{"227":1}}],["header",{"0":{"372":1,"649":1,"794":1},"2":{"89":1,"107":2,"108":1,"127":2,"128":1,"129":1,"134":11,"135":9,"136":1,"137":18,"139":19,"159":2,"169":2,"183":1,"213":2,"217":5,"219":8,"220":10,"224":16,"226":1,"227":2,"237":2,"325":16,"326":7,"372":8,"373":2,"378":4,"403":2,"409":22,"410":13,"450":1,"453":1,"458":1,"459":4,"477":1,"604":2,"637":1,"649":2,"794":2}}],["headers",{"0":{"143":1,"325":1,"409":1,"604":1},"2":{"89":1,"95":1,"107":1,"133":1,"137":1,"139":5,"143":1,"148":1,"230":1,"313":2,"325":6,"409":6,"450":1,"451":1,"452":1,"459":5,"520":2,"604":3,"606":2,"666":2,"708":3,"777":1,"778":1}}],["head",{"2":{"72":1,"131":1,"135":1,"261":1,"356":1,"410":2,"547":1,"570":1,"636":1,"663":2}}],["heard",{"2":{"261":1}}],["hear",{"2":{"48":2}}],["hesitate",{"2":{"40":1,"45":1}}],["hedging",{"2":{"34":1}}],["hetzner",{"2":{"24":1}}],["vlog",{"2":{"605":4}}],["vcpu",{"2":{"413":1}}],["vghpcybpcybhbiblegftcgxlig9mihnvbwugymxvyibkyxrh",{"2":{"380":2}}],["vv",{"2":{"306":1}}],["vvforge",{"2":{"306":1}}],["vms",{"2":{"265":1}}],["vm",{"2":{"264":1,"265":4,"305":4,"307":4}}],["vs",{"0":{"232":1,"456":1},"1":{"233":1,"234":1,"235":1},"2":{"735":1}}],["vk",{"2":{"223":2}}],["vkrarg7fgtz",{"2":{"151":2}}],["v",{"2":{"102":2,"323":2,"325":2,"329":1,"385":2,"401":2,"402":8,"404":8,"425":2,"657":11,"658":10}}],["v1beta1",{"2":{"299":2,"536":4,"564":2,"565":2,"566":2}}],["v1",{"2":{"94":2,"149":8,"156":4,"161":1,"162":1,"172":2,"299":2,"370":6,"417":2,"421":1,"582":1,"639":1,"649":14,"681":1,"789":1,"794":14}}],["v2",{"2":{"94":1,"102":2,"159":2,"161":1,"639":10,"649":1,"679":3,"789":10,"794":1}}],["vulnerability",{"2":{"84":1}}],["v0",{"2":{"80":1,"94":3,"149":4,"358":1,"408":3,"409":2,"480":2,"596":1,"610":1,"649":14,"679":1,"681":1,"794":14}}],["void",{"2":{"561":2}}],["voice",{"2":{"40":1}}],["vote",{"2":{"460":1,"486":2,"487":1,"536":5,"537":1}}],["voting",{"2":{"372":4,"499":1,"536":1,"755":1}}],["volume",{"2":{"656":2,"657":6,"658":2,"661":1}}],["volumes",{"2":{"276":2}}],["volunteer",{"2":{"36":1}}],["volunteers",{"2":{"36":1,"38":1,"52":1}}],["vouch",{"2":{"233":1}}],["vest",{"2":{"564":1}}],["vestingcelestia",{"2":{"569":1}}],["vesting",{"0":{"553":1,"560":1,"564":1,"565":1,"571":1},"1":{"554":1,"555":1,"556":1,"557":1,"558":1,"559":1,"560":1,"561":2,"562":2,"563":2,"564":2,"565":2,"566":2,"567":2,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1},"2":{"330":1,"418":1,"553":4,"559":1,"560":1,"561":5,"562":2,"563":1,"564":19,"565":8,"567":3,"568":2,"569":4,"571":10,"574":1,"575":2}}],["veto",{"2":{"536":2}}],["vec",{"2":{"408":2}}],["ve",{"2":{"45":1,"65":1,"76":1,"120":1,"122":1,"255":1,"261":1,"284":1,"286":1,"302":1,"307":1,"309":1,"317":1,"394":1,"402":2,"567":1,"575":1,"611":1}}],["venv",{"2":{"391":7}}],["venue",{"0":{"40":1},"2":{"36":2,"37":1,"40":4,"44":2,"45":2}}],["vendors",{"2":{"31":1}}],["ver=",{"2":{"664":3}}],["very",{"2":{"133":1,"226":2,"335":1}}],["verifiable",{"2":{"237":1}}],["verified",{"2":{"146":1,"172":2,"177":1,"189":1,"192":1,"195":1,"199":1,"203":1,"211":1,"215":1,"436":1,"437":1,"438":1,"446":1}}],["verifiercd",{"2":{"212":1}}],["verifiers",{"0":{"212":1,"224":1},"2":{"211":2,"212":5,"213":4,"223":1}}],["verifier",{"0":{"213":1,"223":1},"1":{"214":1,"215":1,"216":1},"2":{"130":1,"131":1,"141":1,"172":2,"200":1,"203":1,"211":2,"212":7,"213":10,"214":4,"215":1,"219":6,"220":5,"222":1,"223":22,"224":13,"239":1,"413":4}}],["verifies",{"2":{"117":2,"129":2,"131":3,"237":2,"239":1,"281":2}}],["verification",{"0":{"234":1},"2":{"31":1,"89":1,"107":1,"131":1,"148":1,"169":1,"196":2,"200":1,"203":1,"208":3,"211":1,"223":1,"418":1,"637":1}}],["verifydatarootinclusion",{"2":{"153":4}}],["verifymultirowrootstodataroottupleroot",{"2":{"131":1}}],["verifyrowroottodataroottupleroot",{"2":{"131":2}}],["verifysharestodataroottupleroot",{"2":{"131":2,"172":2}}],["verifying",{"0":{"131":1},"2":{"128":2,"135":2,"136":1,"148":1,"173":1,"177":2,"188":1,"330":1,"331":1,"438":1,"444":1,"452":1}}],["verifyzkp",{"2":{"127":4}}],["verifyattestation",{"2":{"110":1,"127":2,"129":1,"153":2}}],["verify",{"0":{"438":1,"684":1},"2":{"89":2,"127":4,"131":4,"136":1,"145":1,"153":6,"163":2,"165":6,"168":4,"169":2,"172":10,"173":1,"181":1,"184":1,"187":1,"188":1,"189":1,"191":1,"192":1,"195":1,"196":2,"200":2,"203":3,"208":2,"211":1,"212":4,"213":2,"219":2,"222":1,"264":2,"296":1,"436":5,"438":2,"439":1,"440":1,"441":1,"446":1,"449":1,"450":1,"452":1,"453":1,"456":1,"457":2,"561":2,"564":1,"609":1,"637":1,"664":1,"681":1,"685":1}}],["versed",{"2":{"65":1}}],["versioned",{"2":{"724":1}}],["versiongo",{"2":{"664":1}}],["versioncelestia",{"2":{"609":1}}],["versioncd",{"2":{"558":1}}],["versions",{"0":{"761":1,"764":1,"766":1},"2":{"89":1,"94":1,"149":2,"677":1}}],["version",{"0":{"376":1,"507":1,"558":1,"649":1,"660":1,"722":1,"742":1,"794":1},"2":{"17":2,"94":2,"126":1,"156":2,"159":6,"161":2,"165":11,"166":11,"172":6,"224":2,"245":1,"330":1,"339":1,"363":1,"365":8,"372":2,"376":1,"380":2,"404":1,"413":1,"417":2,"455":1,"480":1,"481":1,"530":6,"554":1,"558":2,"568":1,"571":1,"581":1,"600":2,"609":6,"612":1,"639":1,"649":4,"664":4,"680":1,"681":1,"687":12,"789":1,"794":4}}],["vpn",{"2":{"31":1}}],["vanilla",{"2":{"455":1}}],["vastly",{"2":{"264":1}}],["vault",{"2":{"211":6}}],["var",{"2":{"137":2,"557":4}}],["vary",{"2":{"41":1,"418":1,"484":1,"724":1}}],["variant",{"2":{"310":2}}],["variablescd",{"2":{"219":1}}],["variables",{"0":{"311":1,"563":1},"2":{"89":1,"211":1,"219":3,"220":1,"227":1,"292":1,"311":1,"419":1,"563":1,"569":1,"657":1}}],["variable",{"2":{"75":2,"91":1,"116":2,"117":2,"120":1,"121":1,"164":1,"211":2,"220":3,"280":2,"281":2,"284":2,"285":1,"308":1,"309":1,"315":1,"317":2,"361":1,"375":1,"384":1,"385":1,"397":1,"403":3,"419":1,"478":1,"557":1,"783":1}}],["variety",{"2":{"41":1,"265":1}}],["varies",{"2":{"23":1}}],["various",{"2":{"34":1,"36":1,"47":1,"65":1,"255":1}}],["val",{"2":{"783":2}}],["valconspub",{"2":{"432":2}}],["valcons",{"2":{"432":2}}],["valoperpub",{"2":{"432":2}}],["valoper",{"2":{"432":2,"538":2,"539":4}}],["validao",{"2":{"728":1,"729":1,"730":1}}],["validating",{"2":{"92":1,"103":1,"145":1,"677":1}}],["validation",{"0":{"103":1},"2":{"84":2,"139":2}}],["validatehermes",{"2":{"684":1}}],["validates",{"2":{"455":1,"530":2}}],["validated",{"2":{"27":1}}],["validate",{"2":{"27":1,"192":1,"451":1,"452":1,"520":1,"530":2,"636":1,"684":1,"763":1}}],["validator1",{"2":{"698":1}}],["validatorwalletcreator",{"2":{"98":1,"99":1}}],["validatorutils",{"2":{"98":1,"99":1}}],["validators",{"0":{"701":1},"2":{"19":1,"21":1,"22":1,"24":1,"26":1,"27":1,"29":1,"84":9,"85":1,"108":1,"133":1,"134":1,"217":1,"237":2,"263":1,"335":1,"372":6,"416":1,"441":1,"478":1,"483":1,"505":1,"536":3,"677":3,"678":2,"701":3,"702":1,"705":1,"740":1,"763":2,"765":1}}],["validator",{"0":{"100":1,"464":1,"469":1,"473":1,"538":1,"540":1,"572":1,"779":1,"781":1,"783":1,"789":1,"790":1},"1":{"101":1,"102":1,"103":1,"780":1,"781":1,"782":2,"783":2,"784":1,"785":1,"786":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"793":1,"794":1},"2":{"19":2,"21":2,"23":2,"24":4,"27":7,"28":5,"84":2,"86":1,"91":1,"103":1,"108":1,"137":1,"263":1,"355":2,"372":4,"396":2,"445":1,"464":1,"469":1,"473":1,"483":3,"490":1,"498":2,"504":3,"510":4,"513":2,"520":1,"527":5,"530":2,"538":5,"539":6,"540":3,"542":2,"549":6,"551":15,"559":2,"562":2,"563":1,"567":1,"571":1,"572":2,"578":4,"583":1,"594":1,"652":1,"673":3,"679":1,"699":1,"704":4,"705":2,"713":4,"714":2,"727":1,"740":1,"755":1,"758":1,"765":1,"770":1,"771":1,"773":1,"779":2,"780":1,"783":7,"784":2,"789":16}}],["validiums",{"2":{"437":1}}],["validity",{"2":{"195":1,"230":1,"264":3}}],["valid",{"2":{"131":2,"153":2,"177":2,"187":1,"188":1,"192":1,"196":2,"200":2,"203":2,"211":1,"219":1,"264":1,"450":1,"456":2,"459":1,"684":2}}],["valuable",{"2":{"40":1,"43":2,"48":1,"65":1}}],["valuelog",{"2":{"605":2}}],["values",{"0":{"584":1},"2":{"24":1,"85":1,"151":1,"156":1,"161":1,"165":1,"227":1,"269":1,"363":1,"486":1,"584":2,"602":3}}],["value",{"2":{"4":1,"44":1,"76":3,"89":2,"116":2,"121":1,"156":8,"165":6,"166":1,"196":1,"213":1,"219":3,"280":2,"285":1,"294":1,"313":15,"317":3,"363":2,"366":1,"370":1,"372":4,"385":2,"409":2,"417":1,"418":1,"419":1,"536":4,"589":1,"605":3,"634":2,"646":2,"647":1,"698":2,"699":1}}],["visualize",{"2":{"545":1}}],["visualizer",{"2":{"545":1}}],["visualization",{"0":{"545":1}}],["vision",{"2":{"497":1}}],["visited",{"2":{"432":2}}],["visit",{"2":{"79":1,"83":1,"84":1,"88":1,"90":1,"250":1,"251":1,"252":1,"253":1,"397":1,"653":1}}],["visibility",{"2":{"45":1}}],["visible",{"2":{"7":1}}],["vite",{"2":{"301":1,"310":4,"311":2,"313":4}}],["vitepress",{"2":{"1":1}}],["virtual",{"2":{"246":1}}],["virtually",{"2":{"65":1}}],["vim",{"2":{"219":2,"220":2}}],["vibrant",{"2":{"55":1}}],["video",{"0":{"659":1},"1":{"660":1},"2":{"40":1,"46":1,"60":1,"61":1}}],["videos",{"2":{"37":1,"46":1}}],["viewed",{"2":{"590":1}}],["viewing",{"2":{"536":1}}],["viewstate",{"2":{"313":6}}],["view",{"0":{"272":1},"2":{"34":2,"69":1,"71":1,"90":1,"121":1,"245":1,"285":1,"305":5,"313":15,"341":1,"377":2,"433":1,"434":1,"530":1,"537":1,"571":1,"582":1,"610":1}}],["viewpoints",{"2":{"8":1}}],["violate",{"2":{"23":1,"34":1}}],["violating",{"2":{"14":1,"15":1,"24":1,"25":1}}],["violation",{"2":{"12":1,"13":1,"14":1,"15":1,"16":1,"31":1}}],["via",{"0":{"141":1,"142":1,"426":1},"2":{"10":1,"45":2,"134":1,"136":1,"139":1,"146":1,"148":1,"154":1,"165":1,"166":1,"169":1,"183":1,"184":1,"200":1,"212":1,"217":1,"218":1,"228":1,"268":4,"269":1,"426":2,"458":1,"460":1,"536":1,"579":1,"592":1,"683":1,"689":1,"690":1,"765":1}}],["egrep",{"2":{"638":6}}],["egg",{"2":{"561":2}}],["egeiggrjtkryaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"156":2}}],["eye",{"2":{"546":1}}],["eprintln",{"2":{"409":4}}],["ephemeral",{"2":{"264":1}}],["eq",{"2":{"408":6}}],["equally",{"2":{"457":1}}],["equality",{"2":{"305":1}}],["equal",{"2":{"117":1,"281":1,"323":4,"425":4}}],["equipments",{"2":{"40":1}}],["equipment",{"2":{"36":2,"37":1,"40":2,"46":1}}],["equivalent",{"2":{"34":2}}],["e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",{"2":{"372":8}}],["eofsudo",{"2":{"774":1,"776":1,"777":1,"778":1}}],["eof",{"2":{"599":2,"774":3,"776":3,"777":3,"778":3}}],["eoa",{"2":{"211":2}}],["eoujy0=",{"2":{"156":2}}],["ef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"156":3}}],["efficient",{"2":{"264":1,"420":1,"457":1}}],["efficiently",{"2":{"176":1,"436":1}}],["efficiency",{"2":{"230":1}}],["effect",{"2":{"451":1}}],["effects",{"2":{"172":2}}],["effectivegasprice",{"2":{"121":2,"285":2}}],["effectively",{"2":{"45":1,"57":1,"638":1}}],["effective",{"2":{"44":1,"48":1,"724":1}}],["effected",{"2":{"34":1}}],["efforts",{"2":{"34":2,"47":1}}],["eclipse",{"2":{"440":1}}],["ecfg",{"2":{"426":4}}],["ec2",{"2":{"226":1}}],["echo",{"2":{"121":1,"285":1,"315":2,"385":2,"627":10,"664":1,"705":2}}],["ecosystem",{"2":{"8":1,"21":1,"27":3,"43":3,"48":1,"50":1,"53":1,"60":1,"61":1,"65":3,"230":1,"301":1,"487":1,"488":2,"489":2,"545":1,"719":1}}],["economic",{"2":{"7":1,"24":1}}],["era",{"2":{"497":1}}],["erasure",{"2":{"146":1,"333":1,"440":1,"441":3,"455":1,"458":1,"477":1,"520":2}}],["err=",{"2":{"649":2,"794":2}}],["err",{"2":{"137":18,"139":12,"145":10,"152":16,"153":78,"157":8,"159":24,"162":4,"170":34,"171":26,"172":30,"323":30,"324":18,"325":24,"326":12,"401":6,"402":42,"403":6,"404":30,"409":4,"425":30,"426":50,"649":2,"794":2}}],["errorcodes",{"2":{"172":2}}],["errorf",{"2":{"139":4,"153":2,"170":2,"402":6,"403":4}}],["error",{"0":{"605":1},"2":{"93":1,"135":10,"137":4,"139":4,"153":6,"159":2,"170":2,"172":4,"287":3,"297":2,"323":2,"324":2,"325":4,"326":2,"382":3,"402":8,"403":4,"409":4,"425":2,"426":2,"596":1,"599":2,"601":2,"602":3,"605":6,"649":1,"702":1,"794":1}}],["errors",{"2":{"89":1,"390":1,"683":1}}],["erc20outbox",{"2":{"98":1,"99":1}}],["erc20rollupeventinbox",{"2":{"98":1,"99":1}}],["erc20inbox",{"2":{"98":1,"99":1}}],["erc20bridge",{"2":{"98":1,"99":1}}],["erc20tokenbridge",{"2":{"91":2}}],["erc20",{"2":{"91":2}}],["eight",{"2":{"453":1}}],["eighteen",{"2":{"31":1}}],["eip",{"2":{"417":1}}],["eip4844",{"2":{"107":1}}],["eiokkc9jzwxlc3rpys5ibg9ilnyxlk1zz1bheuzvckjsb2jzumvzcg9uc2u=",{"2":{"156":2}}],["either",{"2":{"65":1,"102":1,"178":1,"195":1,"212":2,"213":1,"220":2,"224":1,"268":1,"307":1,"311":1,"356":1,"359":1,"380":1,"417":1,"459":1,"489":1,"545":3,"579":1,"582":1,"610":1,"655":1}}],["es",{"2":{"728":1,"729":1,"730":1}}],["estimates",{"2":{"419":1}}],["estimategas",{"2":{"419":2}}],["estimated",{"2":{"419":1,"426":2}}],["estimate",{"2":{"42":1,"91":8,"419":1,"420":1,"564":2}}],["estimating",{"0":{"418":1,"420":1},"2":{"42":2,"419":1,"426":2}}],["established",{"2":{"687":1}}],["establish",{"2":{"42":1,"88":2,"680":1}}],["especially",{"2":{"40":1,"50":1,"428":1}}],["essentially",{"2":{"590":1}}],["essential",{"2":{"40":1,"45":1,"47":1,"53":1,"86":1,"88":1,"247":1,"490":1,"496":1,"583":1,"594":1,"663":5}}],["eu",{"2":{"34":2}}],["eth0",{"2":{"644":2}}],["ethers",{"2":{"311":2,"313":12}}],["etherscan",{"2":{"211":6,"212":6,"217":1,"219":6}}],["ethermintd",{"2":{"309":2,"315":2}}],["ethermint",{"0":{"309":1,"314":1,"315":1},"2":{"302":1,"308":1,"309":4,"312":15,"313":4,"314":1,"315":7,"316":1}}],["ethereumclient",{"2":{"135":6,"137":4,"139":2}}],["ethereum",{"0":{"110":1,"143":1,"229":1,"287":1},"1":{"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1},"2":{"39":1,"76":1,"80":3,"82":1,"83":1,"89":1,"101":2,"105":1,"106":1,"109":2,"110":4,"114":1,"121":1,"129":1,"133":2,"134":4,"135":12,"137":3,"139":4,"143":3,"153":12,"172":12,"225":1,"230":3,"234":1,"235":2,"237":8,"238":2,"242":1,"246":1,"250":1,"278":1,"284":1,"285":1,"287":6,"301":1,"313":8,"314":1,"317":1,"336":2,"337":7,"392":4,"417":1,"497":1}}],["ethcmn",{"2":{"153":2,"170":2,"171":2,"172":2}}],["ethclient",{"2":{"153":10,"170":8,"171":8,"172":8}}],["eths",{"2":{"91":2}}],["eth",{"0":{"82":1},"2":{"69":1,"76":2,"80":2,"82":5,"84":1,"85":2,"88":1,"89":6,"91":7,"93":1,"278":1,"309":2,"315":2,"317":2,"392":1,"497":1}}],["ethnicity",{"2":{"7":1}}],["etc",{"2":{"33":1,"36":2,"38":1,"48":1,"146":1,"183":1,"310":1,"358":2,"513":1,"605":2,"734":1,"746":1,"774":4,"776":4,"777":4,"778":4}}],["eliminating",{"2":{"596":1}}],["eligible",{"2":{"30":1,"31":1}}],["eligibility",{"0":{"24":1},"2":{"21":1,"23":1,"31":1,"33":1,"34":2}}],["else",{"2":{"153":2,"432":2,"683":1}}],["elastic",{"2":{"39":1}}],["electronic",{"2":{"34":1}}],["element",{"2":{"30":1}}],["early",{"2":{"230":1,"488":4,"489":2,"561":2}}],["earn",{"2":{"30":1,"31":1,"483":1,"551":1}}],["easiest",{"2":{"653":2}}],["easier",{"2":{"48":1}}],["easily",{"2":{"293":1,"336":1}}],["ease",{"0":{"263":1}}],["easy2stake",{"2":{"728":1,"729":1}}],["easy",{"2":{"47":1,"245":1,"263":1,"310":1,"457":1,"497":1}}],["eager",{"2":{"48":1}}],["each",{"2":{"26":1,"28":2,"42":1,"52":1,"65":1,"89":1,"108":1,"116":1,"128":1,"134":1,"136":1,"139":1,"169":2,"175":1,"180":1,"211":4,"223":1,"280":1,"291":1,"330":1,"358":1,"405":1,"415":1,"417":1,"418":3,"419":2,"420":2,"421":2,"450":1,"451":1,"457":1,"458":2,"459":1,"477":1,"478":1,"481":1,"484":1,"508":1,"551":1,"573":1,"596":2,"597":1,"683":2,"724":1,"725":1,"740":2,"755":2}}],["evolution",{"2":{"455":1,"719":1}}],["evolved",{"2":{"301":1}}],["evidence",{"2":{"330":1,"372":2}}],["evm",{"2":{"79":1,"105":1,"153":4,"170":6,"171":2,"172":4,"174":1,"211":1,"219":1,"220":2,"230":1,"242":1,"244":2,"246":2,"259":1,"265":1,"302":1,"303":2,"309":3,"391":1,"392":3,"542":6}}],["evaluated",{"2":{"26":1}}],["evaluate",{"2":{"24":1,"34":1,"38":1}}],["ever",{"2":{"34":1,"561":2}}],["everything",{"2":{"63":1,"127":2,"195":1,"634":5,"684":1}}],["everyone",{"2":{"7":1,"41":1,"52":2,"696":1,"698":1,"701":1,"703":1,"740":1}}],["every",{"2":{"2":1,"22":1,"26":1,"29":1,"107":1,"220":1,"225":2,"238":2,"264":2,"351":1,"400":1,"415":1,"450":3,"451":1,"453":3,"456":1,"458":5,"459":1,"484":1,"545":4,"557":1,"569":1,"573":1,"636":1,"696":1}}],["even",{"2":{"31":1,"34":1,"40":2,"214":1,"428":1,"452":1,"456":1,"656":1,"678":1}}],["eventually",{"2":{"421":1,"459":1}}],["eventpayforblobs",{"2":{"156":2}}],["event",{"2":{"10":1,"24":1,"31":1,"36":5,"37":2,"38":3,"40":2,"41":2,"42":1,"43":5,"44":11,"45":9,"46":5,"52":2,"56":1,"89":3,"110":1,"153":12,"170":6,"171":6,"217":1,"228":1,"287":2,"305":4,"647":1,"682":4}}],["eventschan",{"2":{"171":6}}],["eventsiterator",{"2":{"153":8,"170":8}}],["events",{"2":{"5":2,"42":6,"52":1,"54":1,"56":1,"65":1,"88":3,"89":2,"153":4,"156":4,"169":2,"170":6,"171":2,"172":4,"217":2,"305":4,"564":2,"647":2,"677":1}}],["e",{"2":{"10":1,"23":1,"31":1,"33":1,"38":1,"48":2,"128":1,"153":12,"169":1,"170":12,"183":2,"184":1,"196":1,"215":1,"226":1,"275":4,"290":1,"305":2,"313":8,"337":1,"358":1,"409":8,"413":1,"415":1,"421":1,"439":1,"450":3,"451":1,"452":4,"453":4,"455":2,"456":6,"458":4,"459":9,"545":1,"593":1,"606":1,"627":10,"639":1,"644":2,"655":12,"657":12,"658":12,"708":1,"789":1}}],["ed25519",{"2":{"330":1}}],["eds",{"0":{"326":1,"410":1},"2":{"326":8,"410":10}}],["editing",{"2":{"605":1,"643":1,"684":1}}],["edits",{"2":{"9":1}}],["edit",{"2":{"9":1,"220":2,"573":1,"605":1,"682":2,"688":1}}],["education",{"2":{"7":1,"50":1}}],["embedded",{"2":{"520":1}}],["embark",{"2":{"394":1}}],["emvpw0p8nijmvnocp4bv6k+v6gjmwdxuku=",{"2":{"380":2}}],["emit",{"2":{"305":4}}],["emitted",{"2":{"228":1}}],["emits",{"2":{"153":2,"170":2,"172":2}}],["employed",{"2":{"551":1}}],["employees",{"2":{"47":1}}],["employ",{"2":{"436":1}}],["empty",{"2":{"219":1,"322":1,"401":2,"402":3,"404":2,"407":1,"618":1}}],["empowering",{"2":{"52":1}}],["empower",{"2":{"50":1}}],["emphasizing",{"2":{"40":1}}],["empathy",{"2":{"8":1}}],["emergency",{"2":{"24":1}}],["emails",{"0":{"54":1},"2":{"54":2}}],["email",{"2":{"8":1,"24":1,"27":1,"36":1,"45":2,"47":2,"53":1,"54":1,"63":1}}],["engine",{"2":{"654":1,"656":1}}],["engages",{"2":{"551":1}}],["engaged",{"2":{"42":1}}],["engagement",{"2":{"38":1,"43":1}}],["engage",{"2":{"34":1,"44":1,"45":1,"46":1,"50":1,"490":1}}],["engaging",{"2":{"25":1,"41":1,"43":1,"47":1,"55":1,"63":1,"65":1}}],["ens",{"2":{"310":1}}],["ensuring",{"2":{"19":1,"45":1,"65":1}}],["ensures",{"2":{"287":1,"436":1,"440":1,"456":1,"647":1}}],["ensure",{"2":{"2":1,"37":1,"42":1,"43":1,"45":1,"46":2,"47":1,"84":1,"86":1,"88":1,"235":1,"287":1,"382":1,"456":1,"479":2,"605":1,"678":1,"684":1,"703":1,"708":1,"720":1}}],["enabling",{"2":{"289":1,"432":2,"457":1,"589":1,"765":1}}],["enabled=0",{"2":{"223":2}}],["enabled",{"2":{"211":2,"242":1,"387":1,"544":1,"583":1,"594":1,"682":12,"690":1}}],["enables",{"2":{"110":1,"230":1,"250":1,"264":1,"265":1,"287":1,"449":1,"451":1,"455":2,"456":1,"457":1,"483":1,"586":1,"589":1,"609":1,"784":1}}],["enablement",{"2":{"31":1}}],["enable",{"0":{"214":1,"630":1},"2":{"19":1,"89":4,"220":2,"336":1,"346":1,"387":1,"392":1,"432":2,"449":1,"452":1,"455":1,"586":1,"589":2,"629":1,"637":2,"680":1,"774":3,"776":3,"777":3,"778":3}}],["envcd",{"2":{"220":1}}],["env",{"2":{"211":4,"219":11,"220":7,"227":1,"311":1,"313":4,"413":1}}],["environments",{"2":{"509":1,"726":1,"744":1}}],["environment",{"0":{"311":1,"662":1},"1":{"663":1,"664":1},"2":{"8":1,"30":1,"52":1,"211":4,"219":3,"220":10,"246":1,"249":1,"266":1,"276":2,"302":1,"308":1,"311":1,"340":1,"395":1,"397":1,"403":3,"413":1,"456":1,"581":1,"589":1,"609":1,"653":1,"662":2,"710":1,"719":1,"783":1}}],["enough",{"2":{"145":1,"237":1,"450":1}}],["encrypt",{"2":{"533":2}}],["encrypted",{"2":{"270":1,"533":5}}],["encapsulating",{"2":{"86":1}}],["encounter",{"2":{"382":1,"602":1,"605":1,"649":1,"702":1,"720":1,"794":1}}],["encouraging",{"2":{"50":1}}],["encouraged",{"2":{"355":1,"602":1,"740":1}}],["encourages",{"2":{"41":1,"44":1,"47":1,"84":1}}],["encourage",{"2":{"37":1,"43":1,"44":1,"45":1}}],["encode",{"2":{"164":2,"385":1,"426":2,"450":1}}],["encoded",{"2":{"134":1,"136":1,"146":1,"151":1,"156":1,"161":1,"178":2,"192":1,"199":1,"200":1,"203":1,"363":9,"365":2,"385":2,"386":1,"423":4,"424":4,"536":1}}],["encoding",{"2":{"134":1,"159":2,"180":1,"400":2,"426":6,"441":2,"450":2,"452":8,"455":1,"458":1}}],["encompasses",{"2":{"520":1}}],["encompass",{"2":{"47":1}}],["enjoyed",{"2":{"316":1}}],["enjoy",{"2":{"52":1,"65":1,"91":2}}],["enjoyable",{"2":{"41":1}}],["enlightening",{"2":{"50":1}}],["endkey",{"2":{"165":3}}],["ending",{"2":{"165":2,"396":1,"456":1}}],["endshare=1",{"2":{"161":1}}],["endblock",{"2":{"153":6,"170":4}}],["end=20",{"2":{"151":1}}],["endpoint",{"0":{"355":1,"590":1,"642":1},"1":{"643":1,"644":1,"645":1},"2":{"89":3,"107":2,"120":1,"145":4,"150":1,"151":1,"152":1,"153":4,"156":1,"158":1,"160":1,"161":3,"162":1,"169":1,"170":4,"172":4,"211":1,"219":1,"220":2,"283":1,"308":1,"313":4,"355":4,"363":1,"380":1,"392":1,"508":1,"510":2,"513":1,"520":1,"526":1,"527":1,"545":4,"586":6,"587":2,"588":2,"589":4,"590":1,"606":2,"637":1,"642":1,"644":1,"655":1,"673":3,"713":3,"725":1,"734":1,"736":1,"747":1,"748":1,"749":1}}],["endpoints",{"0":{"509":1,"510":1,"511":1,"512":1,"513":1,"726":1,"728":1,"729":1,"730":1,"731":1,"733":1,"734":1,"735":1,"736":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1},"1":{"512":1,"513":1,"736":1},"2":{"33":1,"247":1,"321":1,"332":1,"346":1,"351":1,"354":1,"406":1,"510":7,"512":1,"513":3,"571":1,"594":1,"637":2,"726":1,"728":1,"733":1,"734":3,"744":1,"745":1,"746":2,"748":2,"750":1,"770":1,"786":1}}],["end",{"2":{"44":1,"134":2,"150":1,"156":6,"160":1,"161":4,"165":3,"172":4,"181":1,"184":1,"225":2,"228":1,"453":1,"458":1,"564":2,"565":2,"682":4}}],["enhancement",{"2":{"596":1}}],["enhanced",{"2":{"504":1}}],["enhances",{"2":{"41":1,"44":1}}],["enhance",{"2":{"38":1,"459":1}}],["entails",{"2":{"452":1,"456":4,"457":1}}],["entering",{"2":{"783":1}}],["enter",{"2":{"271":1,"314":1,"465":1,"469":1,"533":2,"545":1,"551":1,"561":2}}],["enters",{"2":{"24":1}}],["entrypoint",{"0":{"312":1},"2":{"211":1,"219":1,"239":2,"275":2,"276":2,"312":1}}],["entry",{"2":{"84":2,"249":1}}],["enthusiastic",{"2":{"49":1}}],["enthusiasts",{"2":{"43":1,"50":1}}],["entire",{"2":{"35":1,"108":1,"276":1,"440":1,"449":1,"459":1,"606":1,"622":1,"638":1,"735":1}}],["entirely",{"2":{"34":1,"143":1}}],["entitle",{"2":{"514":1,"751":1}}],["entitles",{"2":{"31":1}}],["entities",{"2":{"233":1,"446":1}}],["entity",{"2":{"27":2,"31":5,"33":1,"34":2,"589":1,"606":2}}],["enforced",{"2":{"417":1,"661":1}}],["enforce",{"2":{"52":1}}],["enforcement",{"0":{"9":1,"11":1,"12":1},"1":{"13":1,"14":1,"15":1,"16":1},"2":{"11":1,"17":1}}],["enforcing",{"2":{"9":1,"14":1,"15":1}}],["exit",{"2":{"152":6,"153":2,"172":2}}],["existent",{"2":{"136":1}}],["exist",{"2":{"34":1,"210":2,"295":1,"480":1,"481":1,"491":1,"492":1,"528":1,"599":1,"674":1,"716":1}}],["exists",{"2":{"34":1,"176":1,"179":1,"686":1}}],["existing",{"0":{"221":1,"276":1},"2":{"23":1,"26":1,"42":1,"47":1,"60":1,"61":1,"89":1,"193":1,"213":1,"217":4,"219":1,"221":2,"226":1,"265":2,"275":1,"276":2,"305":2,"331":1,"337":1,"339":1,"390":1,"421":1,"545":1,"581":1,"602":1,"604":1,"609":1,"685":1,"687":1,"688":1,"703":1,"762":1}}],["exhaustive",{"2":{"107":2}}],["extradata",{"2":{"384":2}}],["extra",{"0":{"640":1},"1":{"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"647":1},"2":{"89":2,"93":1,"184":1,"419":1,"792":1}}],["extends",{"2":{"458":1}}],["extendeddatasquare",{"2":{"326":2,"408":2,"410":2}}],["extendedheaders",{"2":{"708":1}}],["extendedheader",{"2":{"325":2}}],["extended",{"0":{"326":1,"410":1,"452":1},"2":{"183":1,"184":1,"326":1,"378":1,"409":4,"410":1,"450":4,"452":6,"458":4,"459":2,"477":1}}],["extension",{"0":{"463":1,"468":1},"2":{"432":2,"564":4}}],["extent",{"2":{"34":1}}],["external",{"0":{"644":1},"2":{"14":1,"76":1,"105":1,"263":1,"317":1,"346":1,"545":4,"644":3}}],["execstart=$",{"2":{"774":2,"776":2,"777":2,"778":2}}],["exec",{"2":{"275":2,"276":2}}],["executable",{"2":{"223":2,"458":4,"477":2}}],["execution",{"2":{"139":1,"213":1,"244":1,"246":1,"261":2,"264":3,"265":3,"302":1,"335":1,"337":1,"449":2,"455":1,"456":7,"457":1,"497":1}}],["executing",{"2":{"91":2,"456":1,"647":1}}],["executor",{"2":{"91":6}}],["executes",{"2":{"635":2}}],["executed",{"2":{"456":1,"458":1,"639":1,"679":1,"789":1}}],["execute",{"2":{"57":1,"63":1,"213":1,"261":1,"264":1,"455":1,"564":1,"597":1,"636":1,"663":1}}],["exercises",{"2":{"135":1}}],["exemptions",{"2":{"34":1}}],["exemption",{"2":{"34":8}}],["exact",{"2":{"420":1,"484":1,"724":1}}],["exactly",{"2":{"26":1,"330":1,"545":2}}],["example",{"0":{"127":1,"153":1,"172":1,"191":1,"378":1},"2":{"66":1,"88":1,"91":1,"127":1,"151":2,"156":2,"161":2,"164":1,"165":1,"166":1,"168":1,"169":4,"172":5,"181":1,"189":1,"191":1,"211":8,"219":5,"220":3,"227":1,"261":1,"275":1,"276":1,"294":1,"295":1,"296":1,"299":1,"304":1,"305":1,"316":1,"324":1,"325":1,"355":2,"358":1,"360":1,"362":2,"363":4,"365":3,"369":1,"372":1,"375":1,"378":1,"380":2,"392":1,"404":1,"409":1,"418":1,"453":2,"456":1,"459":1,"481":1,"513":2,"526":1,"527":1,"533":1,"535":2,"564":1,"571":1,"578":1,"583":1,"587":1,"588":1,"594":1,"597":1,"599":1,"600":1,"606":2,"627":1,"633":1,"646":1,"647":1,"656":1,"657":1,"685":1,"777":1,"783":1}}],["examples",{"0":{"367":1,"598":1},"1":{"368":1,"369":1,"370":1,"371":1,"372":1,"373":1,"374":1,"375":1,"376":1,"377":1,"599":1,"600":1,"601":1},"2":{"8":2,"10":1,"143":1,"366":1,"380":1,"425":1,"584":1,"589":1}}],["exceed",{"2":{"635":1}}],["except",{"2":{"428":1}}],["exceptions",{"0":{"335":1}}],["exceptional",{"2":{"19":1,"43":1}}],["exclusively",{"2":{"504":1}}],["exclusive",{"2":{"53":1,"65":1,"156":1}}],["exchange",{"2":{"24":1,"34":3,"85":1}}],["exposes",{"2":{"748":1}}],["expose",{"0":{"643":1}}],["exposed",{"2":{"135":1,"332":1,"344":1,"354":1,"527":1,"673":1,"713":1}}],["exporter",{"0":{"546":1},"2":{"546":1}}],["exported",{"2":{"533":2}}],["exporting",{"0":{"270":1,"533":1}}],["export",{"0":{"541":1},"2":{"75":3,"91":1,"120":2,"270":7,"275":1,"283":2,"284":2,"292":4,"299":4,"308":1,"309":4,"313":2,"315":2,"317":3,"360":2,"361":1,"362":2,"380":1,"385":3,"432":10,"530":4,"533":3,"541":1,"545":1,"563":2,"569":2,"584":15,"664":4}}],["expand",{"2":{"46":1,"52":1}}],["expiration",{"2":{"34":1}}],["express",{"2":{"44":1}}],["expressed",{"2":{"34":1}}],["expression",{"2":{"7":1}}],["expensive",{"2":{"180":1,"192":1,"194":1,"197":1,"208":2}}],["expenses",{"2":{"44":1}}],["experiment",{"2":{"692":1}}],["experimentation",{"2":{"265":1}}],["experimentalsuggestchain",{"2":{"432":4}}],["experimental",{"2":{"230":1,"609":2,"720":1,"760":1}}],["experimenting",{"2":{"257":1}}],["experiences",{"2":{"8":1}}],["experience",{"2":{"7":2,"8":1,"27":1,"34":1,"38":1,"41":1,"44":1,"52":1,"342":1,"388":1,"394":1,"760":1}}],["experts",{"2":{"43":2,"65":1}}],["expertise",{"2":{"43":1,"48":1,"65":1}}],["expects",{"2":{"586":1,"661":1}}],["expectrevert",{"2":{"305":2}}],["expect",{"2":{"54":1,"65":1,"133":1,"276":1,"408":10,"409":6,"410":6}}],["expectations",{"2":{"42":1}}],["expected",{"2":{"24":1,"36":1,"139":2,"213":1,"481":2,"565":1,"599":1,"600":1,"601":1,"649":2,"794":2}}],["exploring",{"2":{"254":1,"650":1}}],["exploreme",{"2":{"737":1}}],["explored",{"2":{"206":1}}],["explorers",{"0":{"517":1,"737":1,"753":1},"2":{"328":1,"447":1,"517":1,"737":2,"753":3,"789":1}}],["explorer",{"0":{"90":1,"252":1},"2":{"71":1,"90":2,"252":2,"402":2,"433":2,"434":1,"492":1,"517":1,"737":3,"753":2,"783":1,"789":1}}],["explore",{"2":{"5":1,"40":1,"56":1,"57":1,"340":1}}],["explains",{"2":{"680":1}}],["explain",{"2":{"301":1}}],["explained",{"2":{"192":1,"197":1,"206":1}}],["explanation",{"2":{"13":1,"439":1}}],["explicit",{"2":{"8":1}}],["python3",{"2":{"391":2}}],["pbcopy",{"2":{"315":1}}],["pbcopyprivate",{"2":{"315":1}}],["pnpm",{"2":{"311":1}}],["pwd",{"2":{"276":2}}],["psql",{"2":{"646":2}}],["ps",{"2":{"275":1,"276":1}}],["psdocker",{"2":{"275":1,"276":1}}],["p",{"2":{"224":2,"275":2,"313":12,"385":2,"638":6}}],["pk",{"2":{"223":2}}],["pkg",{"2":{"153":2,"159":2,"172":2,"426":6,"649":14,"663":4,"794":14}}],["pfbs",{"2":{"178":1,"192":1,"194":1,"303":1,"420":1}}],["pfb",{"0":{"158":1,"381":1,"418":1},"1":{"159":1},"2":{"91":1,"146":5,"148":1,"154":1,"158":1,"159":2,"178":4,"179":1,"180":1,"200":2,"365":3,"415":1,"418":4,"478":1,"724":2}}],["p2p",{"0":{"617":1,"627":1},"1":{"618":1,"619":1},"2":{"89":4,"135":1,"269":9,"270":6,"271":6,"275":4,"276":3,"294":2,"295":2,"354":4,"355":8,"356":8,"358":2,"360":4,"362":4,"370":2,"380":2,"392":4,"396":4,"455":1,"510":5,"513":2,"526":4,"527":6,"528":4,"530":2,"583":2,"584":4,"586":2,"588":2,"589":4,"592":4,"593":5,"594":2,"597":6,"602":4,"603":4,"604":4,"606":4,"655":12,"657":12,"658":6,"672":4,"673":2,"674":4,"712":4,"713":6,"714":8,"716":4,"750":1,"777":2}}],["pinnacle",{"2":{"719":1}}],["pinning",{"2":{"481":1}}],["pin",{"2":{"481":1}}],["pings",{"2":{"227":1}}],["pink",{"2":{"146":1}}],["pieces",{"2":{"134":1}}],["pick",{"0":{"83":1,"88":1},"2":{"269":1,"464":1,"578":1,"611":1,"627":1,"789":1}}],["pitches",{"2":{"44":1}}],["pitch",{"2":{"44":2}}],["pizza",{"2":{"41":1}}],["phase",{"2":{"621":1}}],["phrase",{"2":{"561":2,"683":1}}],["photos",{"2":{"37":1,"38":1}}],["physical",{"2":{"8":1}}],["plugin",{"2":{"547":1}}],["plus",{"2":{"82":1,"400":1}}],["plonky2x",{"2":{"223":7,"224":3}}],["plonk",{"2":{"211":1,"212":1,"222":1,"223":3,"224":1}}],["plw1gxabnavhwwurqswb0xh25zv9xhielqtvld0xqc4=",{"2":{"156":2}}],["plasma",{"2":{"383":1,"388":1}}],["plastic",{"2":{"41":1}}],["plain",{"2":{"363":1,"365":1,"491":1}}],["plaintext",{"2":{"363":1}}],["play",{"2":{"499":1,"651":1,"706":1}}],["playbook",{"2":{"50":1}}],["playlist",{"2":{"46":1}}],["platform",{"0":{"47":1,"227":1},"2":{"55":1,"212":1,"220":2,"227":3,"228":1,"246":1,"653":1,"719":1}}],["platforms",{"2":{"36":1,"45":1,"46":1,"301":2,"333":1}}],["planned",{"2":{"42":1,"45":1}}],["planning",{"2":{"38":1,"48":1,"611":1,"771":1}}],["plans",{"2":{"41":1}}],["plan",{"2":{"36":1,"41":1,"42":1,"45":1,"46":1,"47":1,"57":1,"63":1,"771":1}}],["placeholder=",{"2":{"313":4}}],["placement",{"2":{"23":2,"27":1}}],["place",{"2":{"23":10,"44":1,"255":1,"322":1,"407":1,"545":1,"561":2,"679":1,"685":1}}],["plethora",{"2":{"546":1}}],["pledge",{"0":{"7":1},"2":{"7":2,"34":1}}],["please",{"2":{"2":1,"4":1,"27":4,"30":3,"36":1,"53":2,"63":1,"89":1,"133":1,"143":1,"161":1,"162":1,"172":2,"230":1,"269":1,"432":2,"604":2,"614":1,"652":1,"653":1,"681":2,"683":1,"724":1,"758":1,"790":1}}],["polypore",{"2":{"682":6}}],["polyfills",{"2":{"312":2}}],["policies",{"2":{"31":1,"33":1}}],["policy",{"2":{"30":2,"33":3,"682":4,"688":4}}],["political",{"2":{"8":1}}],["popup",{"2":{"465":1}}],["populating",{"2":{"401":1,"644":1}}],["populates",{"2":{"512":1,"513":1,"733":1,"734":1,"745":1,"746":1}}],["populated",{"2":{"402":1}}],["populate",{"2":{"108":1}}],["popularity",{"2":{"42":1}}],["popular",{"2":{"42":1,"45":1}}],["pops",{"2":{"275":2,"276":2,"355":2,"434":2,"527":2,"535":4,"571":2,"573":2,"597":2,"682":2,"713":4,"714":2,"728":1,"729":1,"730":1,"734":1,"746":1,"748":1,"749":1}}],["point",{"2":{"249":1,"269":1,"421":1,"456":2,"545":2,"561":2,"606":1,"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["pointing",{"2":{"181":1}}],["pointer",{"2":{"107":1,"110":1,"134":2,"136":1,"181":1}}],["points",{"0":{"23":1},"2":{"596":1}}],["portid",{"2":{"687":4}}],["portions",{"2":{"439":1,"440":1,"441":1}}],["portion",{"2":{"22":1,"146":1,"451":1,"489":1,"498":1,"568":1,"572":1}}],["ports",{"0":{"583":1,"594":1},"2":{"275":4,"276":4,"355":2,"510":3,"513":2,"526":2,"579":2,"583":7,"592":2,"594":7,"655":2,"673":2,"706":2,"713":2,"786":2}}],["portrays",{"2":{"191":1}}],["port",{"2":{"89":1,"308":3,"313":2,"314":1,"355":5,"380":2,"512":1,"513":5,"526":5,"527":1,"545":3,"546":1,"573":2,"583":2,"594":4,"596":1,"601":2,"673":1,"682":4,"687":8,"704":4,"705":3,"713":1,"733":1,"734":20,"745":1,"746":5,"747":1,"748":1,"749":1}}],["portal",{"2":{"75":8,"77":8,"78":1,"79":1,"83":3,"84":1,"286":1,"317":8,"318":8,"319":1,"339":1}}],["poolcelestia",{"2":{"537":1}}],["pool",{"0":{"487":1,"537":1},"2":{"42":1,"487":2,"499":1,"537":9}}],["potentially",{"2":{"42":1,"46":1,"333":1,"418":1,"419":1}}],["potential",{"2":{"36":1,"42":1,"43":2,"44":2,"55":1,"89":1,"235":1}}],["powerful",{"2":{"543":1}}],["power",{"2":{"24":1,"372":4,"394":1,"458":1}}],["pos",{"0":{"454":1},"1":{"455":1},"2":{"455":2}}],["possibly",{"2":{"430":1}}],["possible",{"2":{"45":1,"79":1,"106":1,"139":2,"158":1,"191":1,"217":1,"243":1,"264":1,"293":1,"330":1,"382":1,"450":1,"452":1,"459":1,"479":1,"481":1,"604":1}}],["possibilities",{"2":{"320":1,"340":1,"456":1}}],["postgresql",{"2":{"646":1}}],["postcontainerstyle",{"2":{"313":4}}],["postcontent",{"2":{"313":4}}],["postcreated",{"2":{"305":4}}],["postupdated",{"2":{"305":4}}],["postid",{"2":{"305":20}}],["postings",{"2":{"86":1}}],["posting",{"0":{"143":1},"2":{"10":1,"84":3,"85":1,"88":2,"89":1,"107":1,"133":1,"137":1,"287":2,"337":4,"339":1,"405":1,"651":1}}],["poster",{"0":{"88":1},"2":{"84":4,"86":1,"88":2,"89":7,"91":3,"107":3}}],["posted",{"2":{"76":1,"83":3,"84":1,"89":1,"91":2,"107":2,"110":1,"127":1,"131":1,"133":1,"134":2,"135":1,"139":3,"143":1,"145":1,"146":1,"148":1,"163":4,"177":2,"189":1,"195":1,"196":1,"200":1,"203":1,"245":1,"317":1,"323":1,"337":1,"350":1,"402":1,"408":1,"599":1}}],["post",{"0":{"381":1},"2":{"40":1,"43":1,"45":1,"78":1,"79":1,"84":1,"89":1,"107":2,"133":1,"137":2,"174":2,"187":1,"188":1,"238":1,"291":1,"303":1,"305":72,"308":2,"309":3,"313":28,"316":1,"319":1,"323":2,"336":1,"380":4,"381":1,"386":2,"390":1,"392":1,"404":1,"425":2,"601":2}}],["posts",{"0":{"313":1},"2":{"36":1,"38":1,"83":1,"305":24,"313":25,"337":3,"388":1}}],["positions",{"2":{"184":1}}],["position",{"2":{"34":3,"107":1}}],["positiveerror",{"2":{"602":1}}],["positives",{"2":{"459":1}}],["positive",{"2":{"8":1,"52":1,"459":1,"602":3}}],["peerexchange",{"2":{"619":1}}],["peers=$",{"2":{"627":6}}],["peers",{"0":{"619":1},"2":{"618":2,"621":3,"627":38,"637":1,"644":1,"704":3,"750":1}}],["peer",{"0":{"705":1},"2":{"428":1,"481":6,"621":3,"705":3,"790":1}}],["peerid",{"2":{"370":1}}],["pending",{"2":{"69":1,"71":1}}],["percentage",{"2":{"483":1,"537":1,"551":2}}],["persist",{"2":{"656":1}}],["persisted",{"2":{"647":1,"661":1}}],["persistent",{"0":{"656":1,"705":1},"1":{"657":1,"658":1},"2":{"627":13,"658":1,"704":5,"705":1}}],["perspective",{"2":{"459":1,"520":1}}],["persons",{"2":{"34":1}}],["person",{"2":{"31":3,"34":7,"46":2,"65":1}}],["personal",{"2":{"5":1,"7":1,"8":1,"27":1,"43":1,"44":1}}],["per",{"2":{"43":1,"418":2,"419":2,"420":1,"426":2,"478":1,"484":1,"494":1,"515":2,"679":1,"751":2}}],["perfect",{"2":{"40":1}}],["perform",{"2":{"139":2,"308":1,"309":1,"456":2,"459":1,"480":1,"707":1,"708":1}}],["performing",{"2":{"121":1,"247":1,"285":1,"451":1,"459":2}}],["performs",{"2":{"117":1,"281":1,"358":1,"458":1}}],["performed",{"2":{"33":1,"334":1,"451":1,"684":2,"710":1}}],["performance",{"2":{"19":1,"21":1,"24":1,"33":1,"38":1,"230":1,"265":1,"504":1,"543":1,"605":1,"609":1,"720":1,"749":1,"760":1}}],["pertain",{"2":{"34":1}}],["permit",{"2":{"34":1}}],["permissions",{"2":{"344":1,"656":1,"661":2}}],["permissioned",{"2":{"234":1}}],["permissionless",{"2":{"215":1,"449":1,"456":1,"498":1}}],["permissionlss",{"2":{"214":1}}],["permission",{"0":{"294":1,"297":1},"1":{"298":1},"2":{"8":1,"293":2,"297":1}}],["permanently",{"2":{"31":1,"479":1,"551":1}}],["permanent",{"0":{"16":1},"2":{"14":1,"15":1,"16":1}}],["periods",{"2":{"24":1}}],["period",{"2":{"14":1,"15":2,"23":1,"25":1,"34":5,"84":2,"217":1,"551":3,"687":2}}],["people",{"2":{"8":1,"14":1,"15":1,"40":1,"42":1,"47":1,"48":1}}],["packet",{"2":{"682":8,"688":4}}],["packets",{"2":{"680":3,"681":1,"682":2}}],["packages",{"2":{"663":1,"768":1}}],["package",{"0":{"426":1},"2":{"102":1,"152":1,"153":1,"172":1,"400":1,"426":2,"531":1,"545":1}}],["panic",{"2":{"649":2,"794":2}}],["panel",{"2":{"475":1}}],["pagination",{"2":{"567":4}}],["pages",{"2":{"73":1}}],["page",{"2":{"27":1,"69":1,"85":1,"111":1,"169":1,"253":1,"255":1,"269":1,"275":2,"278":1,"301":1,"317":1,"355":3,"356":1,"383":1,"415":1,"431":1,"458":1,"463":1,"518":1,"526":3,"527":1,"545":2,"547":1,"551":1,"571":1,"579":1,"581":1,"582":1,"592":1,"653":2,"655":2,"662":1,"673":4,"706":1,"710":1,"713":1,"739":1,"740":2,"754":1,"767":1,"786":3,"792":1}}],["paired",{"2":{"545":1}}],["paid",{"2":{"85":1,"293":1,"392":1,"481":1}}],["padded",{"2":{"458":1}}],["padding",{"2":{"313":6}}],["path=$path",{"2":{"664":4}}],["path",{"0":{"557":1},"2":{"212":2,"220":3,"224":2,"268":2,"313":2,"359":1,"361":3,"362":5,"528":1,"536":4,"537":2,"557":1,"615":1,"657":6,"658":4,"661":1,"674":1,"716":1}}],["pattern",{"2":{"16":1}}],["payee",{"2":{"682":2}}],["payer",{"2":{"564":2}}],["paying",{"0":{"476":1,"496":1},"1":{"477":1,"478":1},"2":{"497":1}}],["payload",{"2":{"402":4}}],["payforblob",{"2":{"153":6,"159":1,"170":2,"172":2,"527":1,"673":2,"714":1,"718":1}}],["payforblobs",{"0":{"477":1},"2":{"146":1,"287":1,"293":1,"356":1,"382":1,"390":1,"419":1,"423":2,"458":3,"459":1,"477":3,"496":1,"713":1}}],["pay",{"2":{"85":1,"89":1,"291":2,"299":1,"356":1,"392":1,"419":1,"527":1,"673":1,"714":1}}],["payments",{"2":{"84":1}}],["payment",{"2":{"32":1,"291":1,"330":1,"477":2}}],["paradigm",{"2":{"456":2}}],["parallel",{"2":{"265":1}}],["param",{"2":{"536":2}}],["paramfilter",{"2":{"536":1}}],["params=",{"2":{"432":6}}],["params",{"2":{"89":1,"330":1,"380":2,"386":3,"432":27,"536":3,"621":1}}],["parameterchangeproposal",{"2":{"536":2}}],["parameters",{"0":{"432":1,"486":1,"723":1},"1":{"724":1},"2":{"91":1,"163":4,"169":2,"213":1,"358":1,"415":1,"418":2,"419":1,"431":1,"432":3,"433":1,"434":1,"459":1,"486":2,"499":1,"536":1,"551":1,"723":2}}],["parameter",{"2":{"84":2,"131":1,"156":1,"418":1,"419":1,"420":1,"536":3,"605":2,"724":2,"789":1}}],["parity",{"2":{"183":1,"450":1,"452":1}}],["parsing",{"2":{"178":1,"179":2,"188":1,"192":1,"203":1}}],["parsed",{"2":{"208":1,"219":1,"402":2}}],["parse",{"2":{"172":2,"178":2,"180":1,"192":1,"194":1,"208":1,"378":1,"402":2}}],["parenthash",{"2":{"384":2}}],["parent",{"2":{"84":1,"88":2,"91":18}}],["parts",{"2":{"372":4,"477":1,"499":1}}],["partnering",{"2":{"40":1,"44":1}}],["part",{"2":{"34":1,"53":1,"146":1,"148":2,"149":1,"154":1,"172":6,"183":1,"184":5,"188":1,"192":3,"196":1,"237":1,"263":1,"453":2,"456":1,"489":1,"496":1,"497":1,"681":1,"723":1,"771":1,"784":1}}],["partitioned",{"2":{"453":1,"458":1}}],["partitions",{"2":{"351":1,"453":1}}],["particularly",{"2":{"333":1,"436":1}}],["particular",{"2":{"237":1}}],["participating",{"2":{"30":1,"31":1,"34":1,"48":1,"52":1,"65":1,"508":1,"542":1,"698":1,"725":1,"740":1,"769":1}}],["participations",{"2":{"34":1}}],["participation",{"2":{"7":1,"19":1,"24":1,"30":2,"31":2,"32":4,"34":4,"38":1,"55":1,"84":1}}],["participates",{"2":{"755":1}}],["participate",{"0":{"759":1},"1":{"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1},"2":{"30":3,"31":5,"33":1,"34":2,"44":1,"53":1,"65":1,"84":1,"457":1,"510":1,"696":1,"725":1,"740":1,"755":1,"762":1,"763":1,"779":1,"789":1}}],["participant",{"2":{"24":1,"54":1}}],["participants",{"2":{"23":1,"31":1,"46":1,"48":3,"52":1,"65":1,"701":1,"703":4,"704":2,"705":1}}],["parties",{"2":{"33":1,"187":1,"446":1}}],["party",{"2":{"31":10,"33":4,"289":1,"291":1,"299":1,"328":1,"446":1,"638":1}}],["paper",{"2":{"34":1,"450":1,"453":1,"459":1}}],["passphrase",{"2":{"533":2,"783":3}}],["passport",{"2":{"33":1}}],["password",{"2":{"533":3,"545":1,"561":2}}],["passes",{"2":{"359":1,"458":1}}],["passed",{"2":{"117":2,"281":2,"366":1,"402":2,"528":1,"530":2,"673":1,"674":1,"713":1,"716":1}}],["pass",{"2":{"117":4,"131":1,"281":4,"322":1,"359":1,"401":3,"402":3,"404":2,"407":1,"432":2,"536":1}}],["passionate",{"2":{"65":1}}],["pasting",{"2":{"397":1}}],["paste",{"2":{"89":1,"133":1,"396":1}}],["past",{"2":{"5":1,"44":1,"442":1,"443":3,"444":1,"446":1,"447":2,"564":1,"633":1,"697":1}}],["punish",{"2":{"551":1}}],["put",{"2":{"477":1}}],["pub",{"2":{"372":4,"432":2,"565":2,"566":2}}],["pubkey=$",{"2":{"542":2,"789":2}}],["pubkeyed25519",{"2":{"372":4}}],["pubkey",{"2":{"276":4,"561":4,"562":8,"566":2}}],["pubs",{"2":{"42":1}}],["publish",{"2":{"448":1,"477":1,"544":1}}],["published",{"2":{"107":1,"130":1,"148":1,"153":2,"173":1,"234":1,"260":1,"261":1,"305":14,"313":4,"436":2,"479":2,"481":1}}],["publishing",{"2":{"8":1,"545":3}}],["publicnode",{"2":{"392":2}}],["publicprovider",{"2":{"312":4}}],["publicly",{"2":{"34":1,"65":1,"643":1}}],["public",{"2":{"3":1,"8":1,"10":1,"13":1,"15":2,"16":1,"33":1,"34":4,"43":1,"79":1,"85":1,"113":1,"116":8,"117":9,"119":2,"127":6,"172":2,"227":2,"280":8,"281":9,"305":26,"307":4,"312":2,"346":1,"392":3,"444":1,"480":1,"481":2,"488":1,"489":1,"514":1,"579":2,"642":1,"643":1,"644":1,"701":1,"728":1,"729":1,"730":1,"734":1,"746":1,"747":1,"749":1,"751":1,"789":1}}],["pure",{"2":{"127":2}}],["purchasers",{"2":{"34":1}}],["purchased",{"2":{"8":1}}],["purposes",{"2":{"113":1,"135":1,"355":1,"442":1,"661":1,"740":1}}],["purpose",{"2":{"34":1,"52":1,"268":1,"337":1,"446":1,"479":1,"619":1}}],["pursuant",{"2":{"30":1,"31":2,"34":3}}],["pulled",{"2":{"404":1}}],["pull",{"2":{"2":2,"268":1,"602":1,"703":1,"758":1}}],["push",{"2":{"2":2,"127":2,"682":4}}],["prune",{"2":{"480":1,"634":2,"735":1}}],["pruned",{"2":{"24":1,"28":1,"430":1,"480":1}}],["pruning",{"0":{"479":1,"480":1,"628":1},"1":{"480":1,"481":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1},"2":{"479":1,"480":4,"513":1,"633":2,"634":1,"734":1,"735":1}}],["pragma",{"2":{"116":2,"117":2,"127":2,"172":1,"280":2,"281":2,"305":4,"307":2}}],["practices",{"0":{"481":1},"2":{"31":1,"33":1,"60":1}}],["precise",{"2":{"724":1}}],["precedence",{"2":{"596":1}}],["precompiles",{"2":{"265":1}}],["preserved",{"2":{"602":1}}],["presence",{"2":{"428":1,"596":1}}],["presenters",{"2":{"43":1}}],["presented",{"2":{"34":1}}],["presenting",{"2":{"43":1}}],["presentation",{"0":{"59":1,"60":1,"61":1,"62":1},"2":{"36":1,"43":1,"44":1,"59":3,"60":3,"61":3,"62":2}}],["presentations",{"2":{"36":1,"37":1,"43":1,"60":1,"61":1,"65":1}}],["presently",{"2":{"34":1}}],["present",{"2":{"34":1,"234":1,"592":1,"602":1}}],["presumes",{"2":{"581":1}}],["press",{"2":{"474":1}}],["predetermined",{"2":{"439":1}}],["prefix",{"2":{"385":2,"433":1,"434":1,"682":12}}],["prefixed",{"2":{"363":1,"458":1}}],["preferences",{"2":{"582":1,"610":1}}],["preferred",{"0":{"461":1}}],["prefer",{"2":{"355":1,"526":1}}],["preimage",{"0":{"108":1},"2":{"106":1,"108":3}}],["pre",{"0":{"290":1,"303":1,"582":1,"610":1,"614":1},"2":{"84":1,"213":1,"309":1,"383":1,"580":1,"582":3,"610":3}}],["prerequisites",{"0":{"80":1,"101":1,"114":1,"125":1,"145":1,"274":1,"577":1,"654":1},"2":{"266":1}}],["prerequisite",{"2":{"53":1,"266":1,"549":2}}],["preparing",{"2":{"37":1}}],["prepared",{"2":{"649":1,"794":1}}],["prepare",{"2":{"36":2,"45":1}}],["previoushash",{"2":{"134":2,"137":2}}],["previous",{"2":{"38":1,"85":1,"110":1,"117":1,"134":2,"213":2,"222":1,"224":3,"225":1,"237":1,"281":1,"442":1,"468":1,"564":1,"568":1,"572":1,"596":1,"604":1,"702":1,"771":1}}],["previously",{"2":{"31":1,"337":1,"358":1,"579":1,"789":1}}],["preventing",{"2":{"287":1}}],["prevent",{"2":{"33":1,"572":1,"573":1,"691":1}}],["pro",{"2":{"737":1}}],["probabilistically",{"2":{"459":1}}],["probability",{"2":{"450":1}}],["probably",{"2":{"261":1}}],["problems",{"2":{"443":1,"445":1}}],["problem",{"0":{"437":1,"443":1},"2":{"437":2,"446":2,"449":1,"456":1,"457":1}}],["problematic",{"2":{"436":1}}],["proj",{"2":{"397":2}}],["project",{"0":{"304":1,"322":1,"399":1,"407":1},"1":{"305":1,"306":1,"307":1,"308":1},"2":{"115":7,"116":2,"172":2,"178":1,"279":7,"280":2,"304":1,"310":5,"311":7,"322":1,"399":2,"407":1,"537":2}}],["projector",{"2":{"40":1}}],["projectors",{"2":{"36":1,"40":1}}],["projects",{"2":{"24":1,"44":1,"310":1,"320":1,"342":1}}],["proposal",{"2":{"487":1,"536":14,"537":5}}],["proposalscelestia",{"2":{"536":1}}],["proposals",{"2":{"460":1,"486":2,"499":1,"536":6,"537":3}}],["proposing",{"2":{"458":1}}],["propose",{"2":{"486":1,"551":1}}],["proposer",{"2":{"337":1,"372":8,"392":4,"536":4}}],["proposed",{"2":{"34":1,"437":1}}],["property",{"2":{"459":1,"494":1}}],["properties",{"2":{"264":1,"520":1}}],["properly",{"2":{"306":1,"621":1}}],["proxy",{"2":{"227":1}}],["pros",{"0":{"179":1,"185":1,"189":1,"193":1,"197":1,"201":1,"204":1},"2":{"175":1,"179":1}}],["prospectus",{"2":{"34":1}}],["prospective",{"2":{"21":1}}],["producers",{"2":{"452":2,"459":1}}],["producer",{"2":{"437":2,"458":4}}],["produced",{"2":{"324":1,"325":1,"409":1}}],["produceblock",{"2":{"137":2}}],["producing",{"2":{"135":2,"547":1,"755":1}}],["product",{"2":{"418":1,"419":2}}],["production",{"0":{"509":1,"726":1,"744":1},"2":{"84":2,"263":1,"509":1,"510":2,"520":1,"627":1,"719":1,"726":3,"728":2,"744":3,"760":1}}],["products",{"2":{"31":2,"505":1}}],["provably",{"2":{"479":1}}],["provers",{"2":{"214":1,"215":1,"413":1}}],["prover=network",{"2":{"413":1}}],["prover=local",{"2":{"413":1}}],["prover=",{"2":{"211":2}}],["prover",{"0":{"214":1,"216":1,"220":1},"2":{"211":7,"214":1,"215":2,"216":3,"217":2,"220":7,"221":1,"238":1,"413":1}}],["proven",{"2":{"189":1,"196":1,"225":1,"238":1}}],["proveshars`",{"2":{"172":2}}],["provesharesv2`",{"2":{"172":2}}],["provesharesv2",{"2":{"162":1}}],["proveshares",{"2":{"158":1,"160":1,"162":3,"172":2,"184":1}}],["proves",{"2":{"165":2,"230":1}}],["prove=true",{"2":{"156":1}}],["proved",{"2":{"136":1}}],["prove",{"2":{"130":1,"134":3,"137":1,"139":1,"146":1,"148":5,"150":1,"154":1,"156":1,"161":3,"163":2,"166":1,"168":1,"173":1,"174":1,"177":5,"183":2,"184":6,"187":1,"192":1,"197":1,"200":1,"220":3,"237":1,"261":1,"453":1,"458":1}}],["provision",{"2":{"736":1}}],["provisions",{"2":{"34":2,"484":1}}],["proving",{"0":{"141":1,"153":1,"183":1,"184":1,"226":1},"2":{"133":1,"154":1,"173":1,"174":1,"176":1,"178":2,"184":2,"188":4,"220":1,"226":2,"227":1,"243":1,"413":4,"436":1}}],["provided",{"2":{"30":1,"32":1,"33":1,"34":2,"39":1,"43":1,"50":1,"79":1,"91":1,"113":1,"166":1,"183":1,"192":1,"200":2,"211":2,"267":1,"330":1,"453":3,"618":1,"621":1,"637":2,"678":1}}],["provides",{"2":{"30":1,"47":1,"131":1,"246":1,"255":1,"289":1,"342":1,"344":1,"355":1,"412":1,"449":1,"453":1,"455":1,"456":1,"457":1,"481":1,"526":1,"543":1,"673":1,"724":1}}],["providers",{"0":{"328":1},"1":{"329":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1},"2":{"31":1,"40":1,"263":1,"312":3,"313":4,"328":1,"346":1,"481":2,"509":1,"510":1,"726":2,"728":1,"744":2}}],["provider",{"0":{"107":1,"330":1},"1":{"331":1,"332":1,"333":1,"334":1,"335":1},"2":{"27":1,"31":1,"40":1,"88":1,"106":1,"107":1,"217":1,"258":1,"312":4,"313":8,"388":1,"509":1,"638":1,"726":1,"744":1}}],["provide",{"0":{"448":1},"2":{"19":1,"27":1,"30":2,"31":1,"32":1,"33":1,"37":1,"41":1,"46":1,"47":1,"102":1,"109":1,"148":1,"149":1,"150":1,"154":1,"183":1,"184":2,"305":1,"363":1,"441":1,"446":2,"447":2,"449":1,"453":2,"481":1,"512":1,"513":2,"543":1,"564":1,"618":1,"639":1,"702":1,"733":1,"734":2,"738":1,"745":1,"746":2,"752":1,"758":1,"770":1,"789":2}}],["providing",{"0":{"455":1},"2":{"13":1,"41":1,"50":1,"55":1,"110":1,"208":1,"244":1,"265":1,"344":1,"380":1,"504":1}}],["procedure",{"2":{"247":1,"357":1}}],["proceeding",{"2":{"85":1,"139":1,"681":1}}],["proceed",{"2":{"71":1,"84":2,"173":1,"200":1,"203":1,"266":1,"474":1,"651":1,"701":1,"771":1}}],["processing",{"2":{"265":1}}],["processed",{"2":{"260":1,"428":1}}],["processes",{"2":{"31":1,"403":2,"429":1,"447":1,"520":1,"680":1,"772":1,"774":1}}],["process",{"0":{"20":1,"22":1,"29":1,"677":1,"678":1,"772":1},"1":{"21":1,"22":1,"23":1,"24":1,"25":1,"678":1,"679":2,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1},"2":{"22":1,"31":1,"36":1,"47":1,"79":1,"84":1,"110":1,"136":1,"139":3,"171":2,"195":1,"196":1,"237":1,"250":1,"260":1,"266":1,"291":1,"337":1,"394":1,"404":2,"441":1,"456":1,"518":1,"520":3,"529":1,"590":1,"597":1,"639":1,"675":1,"677":1,"678":1,"717":1,"723":1,"739":1,"754":1,"767":1,"773":1,"778":1,"788":1}}],["proofnonce",{"2":{"153":4,"170":2,"172":2}}],["proofs",{"0":{"131":1,"144":1,"163":1,"178":1,"203":1,"204":1,"205":1,"227":1,"228":1,"452":1},"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":2,"165":2,"166":2,"167":2,"168":2,"169":2,"170":2,"171":2,"172":2,"173":1,"204":1,"205":1},"2":{"108":1,"130":1,"131":2,"136":1,"145":1,"146":1,"148":1,"149":1,"154":1,"156":6,"160":4,"161":4,"163":4,"165":8,"168":10,"171":1,"172":15,"173":1,"177":9,"178":5,"180":1,"183":1,"184":5,"185":1,"187":1,"188":3,"189":1,"191":2,"192":4,"194":1,"195":1,"199":1,"200":1,"203":3,"205":1,"211":1,"212":1,"214":1,"215":3,"217":1,"220":6,"221":1,"222":2,"224":3,"225":1,"226":2,"230":1,"237":2,"238":1,"239":1,"240":1,"243":1,"264":1,"440":1,"441":1,"450":1,"452":2,"453":1,"456":1,"459":1,"666":2,"680":1}}],["proof",{"0":{"130":1,"146":1,"150":1,"154":1,"155":1,"158":1,"160":1,"170":1,"177":1,"182":1,"221":1,"483":1,"498":1},"1":{"147":1,"148":1,"151":1,"152":1,"156":1,"157":1,"159":1,"161":1,"162":1},"2":{"33":1,"108":1,"127":12,"128":2,"129":1,"130":1,"131":5,"133":1,"136":5,"139":2,"141":1,"148":2,"149":1,"150":4,"151":4,"152":2,"153":14,"154":3,"155":1,"156":9,"157":2,"158":1,"160":5,"161":3,"163":9,"164":1,"165":12,"167":1,"168":14,"169":11,"172":40,"173":2,"177":6,"178":1,"179":1,"182":1,"183":6,"184":11,"188":1,"191":1,"192":3,"196":3,"197":2,"200":3,"203":5,"206":1,"208":3,"211":4,"214":1,"215":1,"217":2,"219":2,"220":1,"223":3,"225":1,"226":1,"227":2,"228":3,"233":1,"237":4,"264":3,"441":2,"450":1,"453":1,"459":1,"460":1,"483":3,"490":1,"498":2,"520":1,"551":1}}],["proto",{"2":{"172":2,"426":2}}],["protobuf",{"0":{"200":1},"2":{"149":4,"178":2,"179":1,"180":1,"192":2,"199":1,"200":2,"202":1,"203":2}}],["protocol",{"2":{"24":1,"30":2,"43":1,"105":1,"135":1,"237":2,"313":2,"322":1,"407":1,"417":1,"483":1,"488":1,"583":1,"589":1,"594":1,"680":1}}],["protection",{"2":{"344":1}}],["protect",{"2":{"25":1,"31":1,"89":1,"344":1}}],["prohibited",{"2":{"24":1,"31":1,"596":1}}],["prometheuslistenaddr",{"2":{"544":2}}],["prometheus",{"2":{"544":9,"545":17,"546":1,"590":1,"681":1}}],["prompts",{"2":{"405":1}}],["promptanswer",{"2":{"404":2}}],["prompting",{"0":{"403":1},"2":{"404":1}}],["prompt",{"0":{"394":1,"398":1},"1":{"395":1,"396":1,"397":1,"398":1,"399":2,"400":2,"401":2,"402":2,"403":2,"404":2,"405":1},"2":{"85":1,"347":1,"394":1,"399":2,"400":2,"401":8,"402":13,"403":2,"404":14}}],["prompted",{"2":{"83":1,"533":2,"789":1}}],["promptly",{"2":{"11":1,"107":1}}],["promise",{"2":{"313":2}}],["promised",{"2":{"31":1}}],["prominent",{"2":{"65":1}}],["promote",{"2":{"42":1,"45":2,"46":3,"65":1,"265":1}}],["promotions",{"2":{"37":1}}],["promotional",{"2":{"36":1,"37":1}}],["promoting",{"2":{"19":1}}],["profileecho",{"2":{"664":1}}],["profile",{"2":{"664":3}}],["proficient",{"2":{"19":1}}],["professionals",{"2":{"46":1}}],["professional",{"2":{"8":1,"34":1,"481":2}}],["programs",{"2":{"488":1}}],["programmatic",{"2":{"343":1}}],["programmatically",{"0":{"420":1},"2":{"143":1,"426":2}}],["programming",{"2":{"116":1,"173":1,"280":1}}],["program",{"0":{"18":1,"19":1,"21":1,"49":1,"50":1},"1":{"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"29":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1},"2":{"19":1,"21":2,"23":2,"24":4,"26":1,"27":3,"28":1,"29":2,"30":11,"31":9,"32":2,"33":4,"34":10,"39":1,"42":1,"43":1,"50":1,"53":2,"54":1,"56":1,"62":3,"65":3,"400":4,"401":5,"402":6,"404":2}}],["primitive",{"2":{"438":1,"457":1}}],["primitives",{"2":{"436":1}}],["primarily",{"2":{"84":2,"342":1}}],["primary",{"2":{"19":1,"55":1,"110":1}}],["pricing",{"2":{"235":1}}],["priced",{"2":{"416":1}}],["price",{"0":{"366":1},"2":{"89":3,"323":3,"366":10,"402":2,"408":3,"415":1,"417":4,"419":3,"426":2,"478":1,"682":8}}],["prices",{"2":{"8":1,"416":1}}],["printf",{"2":{"323":4,"324":2,"325":4,"402":6,"404":4,"425":4}}],["printed",{"2":{"211":1,"219":1}}],["println",{"2":{"152":8,"153":6,"171":2,"172":2,"408":2,"409":2,"426":6}}],["print",{"2":{"36":1,"530":2}}],["prioritised",{"2":{"478":2}}],["prioritized",{"2":{"416":2}}],["priority",{"2":{"372":4}}],["prior",{"2":{"26":1,"34":3,"36":1,"45":1,"549":2,"677":1,"678":1,"679":3}}],["privacy",{"0":{"33":1},"2":{"11":1,"30":2,"31":1,"33":3,"65":1}}],["privatekey",{"2":{"392":10}}],["privatecelestia",{"2":{"362":1}}],["private",{"0":{"362":1},"2":{"8":2,"13":1,"15":1,"27":1,"40":1,"75":5,"76":5,"84":2,"86":1,"91":2,"113":1,"119":2,"120":7,"121":4,"127":4,"211":10,"212":4,"213":8,"219":4,"220":2,"265":1,"270":1,"283":5,"284":7,"285":4,"305":6,"308":6,"309":6,"315":2,"317":10,"362":7,"530":2,"533":4,"549":2,"559":1,"564":6,"596":1,"604":4}}],["pr",{"2":{"2":1}}],["ncdu",{"2":{"663":4}}],["ncreated",{"2":{"649":2,"794":2}}],["ntfs",{"2":{"661":1}}],["ngithub",{"2":{"649":12,"794":12}}],["nruntime",{"2":{"649":2,"794":2}}],["nw",{"2":{"550":1}}],["n11",{"2":{"453":2}}],["n12",{"2":{"453":2}}],["n14",{"2":{"453":1}}],["n7",{"2":{"453":1}}],["n8",{"2":{"453":1}}],["n2",{"2":{"451":1,"452":1,"453":1}}],["ns",{"2":{"402":2,"426":6}}],["nsoy0rgl7hqt4vwlg441gqkjsz2fbunzxipgns8ov",{"2":{"276":2}}],["n",{"2":{"323":4,"324":2,"325":4,"402":6,"404":4,"425":4,"443":1,"451":1,"452":2,"541":2,"564":2,"583":1,"594":1,"606":2,"627":12,"649":20,"789":2,"794":20}}],["nft",{"2":{"320":1,"442":1}}],["nfts",{"2":{"43":1}}],["npanic",{"2":{"649":2,"794":2}}],["np5wre24w+e79",{"2":{"156":2}}],["npm",{"2":{"115":3,"279":3,"311":1}}],["nyzlbfjjnskofrzur8xvjijla+wbptwm0kbyglilxlg=",{"2":{"151":2}}],["nmbwwwhpiphwagai7maqm",{"2":{"151":2}}],["nmts",{"0":{"453":1},"2":{"351":1,"449":2,"453":2,"458":1}}],["nmtproof",{"2":{"165":2,"172":2}}],["nmt",{"2":{"148":2,"160":2,"163":2,"408":2,"453":2}}],["nidstring",{"2":{"402":4}}],["nil",{"2":{"137":10,"139":6,"145":6,"152":6,"153":36,"157":4,"159":8,"162":2,"170":14,"171":12,"172":12,"323":12,"324":8,"325":10,"326":8,"401":2,"402":22,"403":4,"404":10,"425":12,"426":16}}],["nitro",{"0":{"110":1},"2":{"90":1,"94":4,"102":4,"105":1,"106":1,"107":3,"108":2,"110":2,"113":1,"114":1,"119":2,"287":1}}],["nice",{"2":{"40":1,"312":1}}],["null",{"2":{"313":4,"564":4,"565":2,"567":4,"646":1,"774":2,"776":2,"777":2,"778":2,"783":2,"789":2}}],["numerator",{"2":{"682":4}}],["numerous",{"2":{"437":1,"456":1}}],["num",{"2":{"682":4}}],["numia",{"2":{"509":4,"726":4,"728":1,"729":1,"730":1,"734":1,"744":4,"746":1,"747":1,"749":1}}],["numleaves",{"2":{"168":3,"184":2}}],["number=26656",{"2":{"705":1}}],["number=26656ip",{"2":{"705":1}}],["numbers",{"0":{"507":1,"722":1,"742":1}}],["number++",{"2":{"116":2,"280":2}}],["number",{"2":{"36":1,"42":1,"76":1,"84":2,"91":8,"116":7,"117":9,"121":3,"168":2,"174":1,"181":1,"183":2,"219":1,"230":1,"264":1,"280":7,"281":9,"285":3,"317":1,"384":2,"418":3,"419":1,"421":1,"426":2,"440":1,"451":1,"457":2,"459":2,"544":4,"546":1,"565":2,"566":2,"605":1,"678":2,"705":2,"724":1}}],["nutshell",{"2":{"148":1}}],["nurturing",{"2":{"53":1}}],["necessitate",{"2":{"590":1}}],["necessity",{"2":{"589":1}}],["necessary",{"0":{"441":1},"2":{"25":1,"33":1,"36":1,"40":3,"86":1,"88":1,"107":2,"108":1,"163":4,"169":2,"183":1,"192":1,"219":3,"234":1,"264":1,"359":1,"428":1,"440":1,"455":1,"459":1,"644":1,"663":1,"682":1,"789":2}}],["net",{"2":{"355":1,"561":2,"714":1,"728":2,"729":2,"730":2,"731":1,"734":2,"737":1,"738":1,"746":1,"747":1,"748":1,"749":1,"753":1}}],["netcelestia",{"2":{"355":1,"714":1}}],["network=$network",{"2":{"655":6,"657":6,"658":6}}],["network=arabica",{"2":{"655":1}}],["network=arabicaexport",{"2":{"655":1}}],["network=celestia",{"2":{"655":1}}],["network=celestiaexport",{"2":{"655":1}}],["network=custom",{"2":{"584":2}}],["network=",{"2":{"584":2}}],["network=mochaexport",{"2":{"655":1}}],["network=mocha",{"2":{"275":2,"295":2,"655":1}}],["networking",{"2":{"37":1,"41":1,"48":2}}],["networks",{"0":{"584":1,"627":1,"759":1},"1":{"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1},"2":{"27":1,"84":1,"135":1,"301":1,"431":1,"449":1,"498":1,"542":1,"592":1,"593":1,"596":1,"627":9,"637":1,"677":1,"680":1,"685":1,"687":1,"705":1,"708":1,"715":1,"734":1,"740":1,"755":1,"771":1,"789":1,"790":1}}],["network",{"0":{"362":1,"432":1,"464":1,"486":1,"505":1,"506":1,"518":1,"542":1,"592":1,"641":1,"692":1,"706":1,"720":1,"721":1,"723":1,"739":1,"741":1,"754":1,"767":1},"1":{"507":1,"593":1,"693":1,"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"724":1},"2":{"19":2,"25":1,"31":1,"43":1,"44":1,"79":1,"83":2,"84":2,"88":3,"89":4,"91":6,"102":2,"135":1,"139":2,"149":2,"163":2,"237":1,"242":1,"261":1,"264":1,"269":20,"270":12,"271":12,"275":3,"276":3,"294":2,"307":1,"312":4,"313":2,"314":3,"323":4,"328":1,"336":1,"337":1,"346":1,"350":1,"354":4,"355":8,"356":13,"360":8,"362":8,"363":2,"380":3,"392":1,"396":4,"400":2,"401":2,"402":10,"404":2,"408":4,"413":1,"425":4,"428":2,"431":1,"432":4,"436":1,"445":1,"450":1,"451":1,"455":1,"456":3,"457":2,"459":4,"460":1,"464":1,"468":1,"474":1,"480":2,"481":3,"483":1,"486":1,"490":3,"496":2,"498":2,"499":1,"508":1,"512":1,"513":3,"518":1,"520":5,"526":4,"527":9,"528":4,"529":1,"542":1,"550":1,"551":1,"552":1,"554":1,"559":1,"573":2,"574":1,"581":2,"584":8,"586":4,"588":2,"589":8,"592":10,"593":6,"596":2,"597":6,"602":8,"603":6,"604":10,"606":10,"609":1,"618":1,"627":1,"637":1,"639":1,"643":2,"649":2,"655":7,"657":6,"664":1,"672":4,"673":5,"674":4,"677":4,"678":3,"679":3,"692":1,"698":1,"702":1,"707":1,"712":4,"713":6,"714":12,"716":4,"719":2,"720":2,"723":1,"725":1,"733":1,"734":2,"739":1,"740":2,"745":1,"746":1,"747":1,"750":1,"754":1,"755":4,"760":2,"765":1,"767":1,"779":1,"784":2,"788":1,"789":2,"794":2}}],["nearby",{"2":{"45":1}}],["negatives",{"2":{"459":1}}],["negatively",{"2":{"27":1,"44":1}}],["negotiate",{"2":{"40":1}}],["nextheaderfunctionid",{"2":{"227":1}}],["nextheight",{"2":{"139":4}}],["next",{"0":{"111":1,"122":1,"254":1,"286":1,"320":1,"340":1,"405":1,"559":1,"611":1},"2":{"38":1,"76":2,"77":1,"83":2,"84":1,"88":1,"92":1,"107":1,"111":1,"115":1,"122":2,"131":1,"139":2,"151":1,"153":2,"156":1,"161":1,"170":2,"180":1,"211":1,"213":2,"219":4,"220":5,"224":2,"227":1,"240":1,"275":1,"279":1,"286":1,"293":1,"305":1,"308":2,"310":1,"311":1,"312":1,"315":2,"317":3,"318":1,"356":1,"363":1,"372":2,"401":2,"402":7,"404":2,"409":2,"457":1,"458":2,"542":1,"545":1,"556":1,"567":6,"597":1,"699":1,"771":1}}],["needing",{"2":{"189":1,"308":1,"438":1,"449":1,"481":1,"564":1,"572":1,"573":1}}],["needs",{"2":{"44":1,"47":1,"48":1,"175":1,"177":1,"192":1,"208":1,"226":1,"239":1,"264":1,"301":1,"390":1,"443":1,"453":1}}],["needed",{"2":{"36":1,"37":1,"40":1,"43":1,"86":1,"89":1,"107":1,"134":1,"145":1,"163":2,"169":2,"184":2,"219":1,"224":2,"395":1,"397":1,"402":1,"418":1,"419":1,"440":1,"441":1,"442":1,"455":1,"545":1,"548":1,"616":1,"621":1,"639":1,"768":1,"777":1,"789":1}}],["need",{"2":{"34":1,"47":1,"63":1,"76":2,"77":1,"82":1,"84":1,"86":1,"89":2,"107":2,"108":1,"135":5,"136":1,"145":1,"150":1,"151":1,"154":1,"156":1,"161":1,"177":1,"179":1,"184":2,"189":1,"192":2,"194":1,"196":1,"199":2,"202":1,"203":1,"210":1,"211":1,"217":1,"243":2,"263":2,"264":1,"268":1,"269":1,"275":1,"291":1,"292":1,"294":1,"308":1,"309":2,"311":1,"313":4,"314":1,"315":2,"317":3,"318":1,"322":1,"356":2,"357":1,"358":1,"359":1,"360":1,"362":1,"380":1,"391":1,"392":1,"400":1,"401":2,"402":2,"403":1,"407":1,"413":2,"432":2,"441":1,"451":1,"452":1,"481":1,"497":1,"512":1,"513":1,"527":2,"545":4,"549":2,"560":1,"569":1,"571":2,"574":1,"577":1,"583":2,"586":1,"589":1,"593":1,"594":2,"596":1,"597":1,"605":1,"606":1,"618":1,"619":1,"629":1,"639":1,"643":1,"644":1,"646":1,"649":1,"656":2,"657":1,"673":2,"677":2,"679":3,"683":2,"687":1,"688":1,"693":1,"694":1,"695":1,"699":1,"701":1,"702":1,"714":1,"733":1,"734":1,"745":1,"746":1,"765":1,"771":1,"783":1,"786":1,"789":1,"794":1}}],["neither",{"2":{"31":2,"455":1,"599":1}}],["newmetric",{"2":{"509":2,"726":2,"728":1,"729":1,"730":1,"734":1,"744":2,"746":1,"747":1,"749":1}}],["newcredentials",{"2":{"426":2}}],["newclient",{"2":{"323":2,"324":2,"325":2,"326":2,"401":2,"402":2,"403":2,"404":2,"425":2}}],["newblob",{"2":{"426":2}}],["newblobv0",{"2":{"323":3,"402":2,"425":2}}],["newblobnamespacev0",{"2":{"323":3,"324":2,"325":2,"402":2,"425":2}}],["newblobstreamxfilterer",{"2":{"171":2}}],["newblobstreamx",{"2":{"153":2,"170":2}}],["newowner",{"2":{"305":4}}],["newer",{"2":{"301":1,"536":1}}],["newwrappers",{"2":{"172":2}}],["newint",{"2":{"153":8,"165":4,"168":4,"169":8,"172":16}}],["newnumber",{"2":{"116":4,"280":4}}],["newly",{"2":{"91":1,"437":1,"688":1}}],["newsubmitoptions",{"2":{"323":4}}],["newsletters",{"2":{"38":1}}],["newspaper",{"2":{"34":1}}],["new",{"0":{"171":1,"209":1,"211":1,"324":1,"325":1,"409":1,"412":1,"497":1,"542":1,"561":1,"687":1,"699":1,"702":1},"1":{"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"413":1},"2":{"2":2,"23":2,"24":2,"26":1,"42":1,"43":1,"47":3,"48":1,"75":1,"88":1,"115":1,"116":1,"117":3,"134":1,"145":2,"152":2,"153":4,"161":1,"162":1,"170":2,"171":3,"172":2,"209":1,"210":1,"217":1,"221":1,"236":2,"238":1,"263":2,"264":2,"265":1,"279":1,"280":1,"281":3,"301":1,"304":1,"305":7,"307":2,"309":2,"310":1,"311":1,"312":1,"313":8,"314":1,"316":1,"317":1,"324":4,"325":11,"394":1,"396":2,"399":1,"402":4,"403":1,"405":1,"408":8,"409":9,"410":2,"412":1,"413":1,"421":1,"428":1,"433":3,"434":1,"436":2,"437":1,"438":2,"444":1,"457":1,"463":1,"479":1,"481":2,"532":2,"545":1,"551":1,"559":1,"569":1,"597":1,"602":2,"618":1,"627":1,"645":1,"646":1,"647":1,"649":1,"677":1,"678":2,"680":1,"685":3,"686":1,"687":3,"688":1,"692":2,"697":1,"699":1,"702":1,"703":1,"706":1,"708":1,"763":1,"769":1,"794":1}}],["navigating",{"2":{"217":1}}],["navigate",{"2":{"88":1,"463":1,"468":1,"472":1}}],["name=$",{"2":{"638":6}}],["name=",{"2":{"549":2}}],["name=validator",{"2":{"542":2,"699":2}}],["name=validator1",{"2":{"542":2,"698":2}}],["namekey",{"2":{"542":1}}],["namevalidator",{"2":{"542":1}}],["names",{"2":{"224":1,"275":2,"276":2}}],["namespce",{"2":{"137":2}}],["namespacebytes",{"2":{"402":2}}],["namespacehex",{"2":{"401":2,"402":4,"404":4}}],["namespaced",{"0":{"453":1},"2":{"351":1,"449":1,"453":1,"455":1,"458":3}}],["namespaceid",{"2":{"166":5,"172":8,"402":14,"404":8}}],["namespacenode",{"2":{"163":2,"165":12,"167":4,"172":10}}],["namespacemerklemultiproof",{"2":{"163":2,"165":10,"172":6}}],["namespaces",{"0":{"351":1},"2":{"156":2,"183":1,"323":2,"351":1,"408":2,"453":3,"458":1,"480":1,"481":1}}],["namespace",{"0":{"166":1},"2":{"89":8,"91":1,"107":2,"134":8,"137":2,"148":2,"154":2,"156":4,"161":4,"163":6,"165":31,"166":21,"172":16,"184":2,"245":1,"323":11,"324":6,"325":11,"348":1,"363":7,"365":12,"373":2,"378":3,"380":2,"386":1,"400":2,"401":6,"402":23,"404":10,"405":2,"408":16,"409":13,"423":2,"424":2,"425":10,"426":6,"453":6,"458":5,"477":3,"481":1,"544":4,"599":1,"600":2}}],["named",{"2":{"116":1,"280":1,"305":1,"310":1,"311":1,"390":1,"581":1,"582":1,"610":1}}],["name",{"2":{"27":1,"36":1,"69":1,"84":2,"211":2,"220":2,"264":1,"269":7,"270":6,"271":6,"275":2,"276":2,"305":18,"309":2,"310":2,"312":4,"314":1,"356":8,"396":2,"433":1,"434":1,"528":7,"532":8,"533":4,"542":8,"545":6,"561":2,"562":4,"578":2,"584":2,"627":7,"638":6,"656":2,"674":7,"682":4,"698":4,"699":4,"700":4,"702":3,"714":2,"716":7,"783":2,"789":2}}],["naming",{"2":{"2":1,"47":3}}],["natural",{"2":{"446":1}}],["nature",{"2":{"13":1,"34":1,"235":1,"445":1,"449":1,"537":1}}],["nativecurrency",{"2":{"312":2}}],["natively",{"2":{"84":1}}],["native",{"2":{"80":1,"82":1,"91":6,"93":1,"106":1,"433":1,"460":1,"496":1,"502":1,"683":1,"690":1,"691":1}}],["nationality",{"2":{"7":1}}],["natnet",{"2":{"63":1}}],["nat",{"2":{"36":1,"644":1}}],["novel",{"2":{"449":1}}],["now",{"0":{"316":1},"2":{"34":1,"76":1,"78":1,"85":1,"89":2,"92":1,"107":1,"117":2,"120":2,"121":1,"172":2,"211":1,"213":1,"214":1,"220":1,"224":1,"254":1,"275":1,"276":1,"281":2,"283":2,"284":1,"285":1,"286":1,"293":1,"295":1,"302":1,"306":1,"307":2,"308":1,"309":2,"310":1,"311":1,"313":1,"315":4,"316":1,"317":2,"319":1,"337":1,"340":1,"354":1,"355":1,"372":1,"384":1,"385":2,"393":1,"396":2,"402":4,"404":4,"432":1,"433":1,"434":1,"445":1,"480":1,"545":1,"559":2,"567":1,"611":1,"650":1,"655":1,"656":1,"658":1,"675":1,"682":1,"683":1,"687":1,"688":1,"703":1,"705":1,"706":1,"734":1,"777":1,"778":1,"789":3}}],["nominee",{"2":{"34":1}}],["normal",{"2":{"139":3,"173":1,"418":1,"436":1,"637":1}}],["normally",{"2":{"40":1}}],["nor",{"2":{"31":2,"34":1,"455":1,"599":1}}],["none",{"2":{"186":1,"190":1,"198":1,"201":1,"204":1,"359":1,"687":4}}],["nonce",{"2":{"127":4,"129":1,"153":4,"163":4,"169":10,"170":2,"172":6,"287":1,"384":2,"385":2,"421":2,"426":2}}],["non",{"2":{"24":1,"28":1,"34":1,"107":2,"136":1,"361":1,"392":1,"486":1,"564":2,"596":1,"691":1}}],["no",{"0":{"447":1},"2":{"14":1,"15":1,"23":1,"30":1,"31":5,"34":8,"40":1,"117":2,"120":2,"126":2,"180":1,"195":1,"245":1,"263":1,"281":2,"284":2,"290":1,"313":2,"346":1,"366":1,"415":1,"417":1,"436":1,"452":1,"459":1,"497":1,"502":1,"513":1,"514":1,"536":5,"547":1,"593":2,"601":3,"621":1,"734":1,"751":1}}],["notably",{"2":{"418":1}}],["notable",{"0":{"335":1},"2":{"440":1}}],["notfound",{"2":{"382":2}}],["notify",{"2":{"708":1}}],["notification",{"2":{"72":1}}],["notice",{"2":{"163":4,"165":6,"166":2,"168":2,"169":4,"363":1,"455":1,"565":1,"566":1,"758":1}}],["nothing",{"2":{"34":1,"633":3}}],["noted",{"2":{"335":1,"696":1}}],["note",{"0":{"644":1},"2":{"27":1,"30":1,"53":1,"89":2,"102":1,"103":1,"108":1,"126":1,"134":1,"135":3,"137":1,"139":2,"149":1,"151":1,"156":1,"160":1,"161":1,"172":2,"173":1,"175":1,"177":1,"181":1,"183":1,"213":1,"223":1,"224":1,"225":1,"226":1,"227":1,"230":1,"238":1,"239":1,"269":1,"294":1,"301":1,"308":2,"309":2,"355":1,"358":1,"387":1,"413":1,"418":2,"426":2,"453":1,"456":1,"458":2,"459":1,"515":1,"527":1,"536":1,"545":1,"549":2,"553":1,"557":1,"564":1,"572":1,"577":1,"586":1,"592":2,"599":1,"605":1,"633":1,"652":1,"673":1,"683":1,"702":1,"705":1,"724":1,"751":1,"771":1,"777":1}}],["notes",{"0":{"330":1,"430":1,"574":1},"1":{"331":1,"332":1,"333":1,"334":1,"335":1},"2":{"5":1,"54":1,"480":1,"635":1}}],["not",{"2":{"8":1,"9":1,"23":1,"24":7,"27":1,"30":6,"31":11,"32":3,"33":3,"34":24,"40":1,"41":2,"65":1,"84":2,"88":2,"89":1,"91":2,"94":1,"108":1,"110":1,"126":1,"133":2,"136":1,"137":1,"153":2,"154":1,"172":2,"177":1,"182":1,"183":1,"187":1,"188":1,"189":1,"192":2,"202":1,"208":1,"210":1,"211":3,"217":1,"219":5,"220":2,"224":2,"237":1,"239":1,"242":1,"243":1,"269":2,"275":1,"287":1,"294":1,"295":2,"296":1,"301":1,"309":1,"321":1,"332":1,"333":1,"335":1,"351":1,"353":1,"355":1,"356":1,"357":1,"360":3,"366":1,"382":2,"403":2,"406":1,"417":3,"418":1,"419":1,"421":3,"426":2,"428":3,"429":1,"430":1,"440":1,"441":1,"446":1,"452":2,"458":1,"459":2,"479":1,"480":2,"481":2,"486":1,"504":1,"510":1,"513":2,"514":1,"526":1,"527":1,"536":1,"545":1,"551":1,"557":1,"574":1,"577":1,"584":1,"592":1,"593":1,"602":1,"606":1,"621":2,"634":1,"644":1,"647":2,"649":1,"661":1,"664":1,"665":1,"673":1,"676":1,"677":1,"678":1,"679":1,"683":1,"726":1,"728":1,"734":1,"744":1,"746":1,"748":1,"751":1,"755":1,"763":1,"784":2,"794":1}}],["noders",{"2":{"728":1,"729":1,"730":1,"734":1,"746":1,"747":1,"748":1,"749":1}}],["nodebuilder",{"2":{"602":6}}],["nodeclient",{"2":{"401":2,"402":4,"404":2}}],["nodeconfig",{"2":{"86":1,"87":1,"88":1,"89":1,"102":2}}],["nodeip",{"2":{"401":4,"402":4,"404":6}}],["node",{"0":{"60":1,"89":1,"90":1,"100":1,"102":1,"103":1,"138":1,"142":1,"266":1,"269":1,"270":1,"271":1,"275":1,"292":1,"293":1,"295":1,"341":1,"348":1,"354":1,"361":1,"370":1,"390":1,"396":2,"423":1,"424":2,"425":1,"426":1,"427":1,"480":1,"512":1,"519":1,"522":1,"524":1,"525":1,"526":1,"527":1,"528":1,"529":1,"546":1,"572":1,"585":1,"595":1,"606":1,"608":1,"622":1,"624":1,"629":2,"639":1,"645":1,"650":1,"656":1,"657":1,"658":1,"665":1,"668":1,"670":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"705":1,"707":1,"710":1,"711":1,"712":1,"713":1,"716":1,"717":1,"733":1,"745":1,"750":1,"756":1,"769":1,"772":1,"776":1,"777":1,"778":1,"779":1,"781":1,"784":1,"785":1,"786":1,"787":1,"788":1,"789":1},"1":{"101":1,"102":1,"103":1,"139":1,"140":1,"141":1,"142":1,"143":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"293":1,"294":1,"342":1,"343":1,"344":1,"345":1,"346":1,"347":1,"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"356":1,"357":1,"358":1,"359":1,"360":1,"361":1,"362":2,"363":1,"364":1,"365":1,"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,"520":1,"521":1,"522":1,"523":2,"524":1,"525":2,"526":2,"527":2,"528":3,"529":2,"586":1,"587":1,"588":1,"589":1,"590":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"607":1,"609":1,"610":1,"611":1,"612":1,"623":1,"624":1,"625":2,"626":2,"627":2,"628":1,"629":1,"630":3,"631":3,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"640":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"647":1,"648":1,"649":1,"651":1,"652":1,"657":1,"658":1,"666":1,"667":1,"668":1,"669":2,"670":1,"671":2,"672":3,"673":3,"674":2,"675":2,"676":2,"708":1,"709":1,"710":1,"711":2,"712":1,"713":1,"714":2,"715":2,"716":2,"717":2,"718":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1,"780":1,"781":1,"782":2,"783":2,"784":1,"785":2,"786":2,"787":2,"788":3,"789":1,"790":1,"791":1,"792":1,"793":1,"794":1},"2":{"3":1,"24":2,"25":1,"27":2,"28":1,"48":1,"60":6,"80":1,"85":1,"86":1,"88":4,"89":10,"90":1,"91":1,"92":1,"94":3,"102":3,"103":3,"107":6,"108":1,"110":1,"114":2,"135":13,"139":1,"142":1,"145":5,"146":1,"165":16,"172":12,"177":1,"264":1,"266":1,"267":2,"268":5,"269":10,"270":6,"271":6,"274":1,"275":15,"276":9,"278":2,"289":1,"290":3,"291":6,"292":1,"293":5,"294":1,"295":3,"296":2,"297":3,"299":3,"300":2,"303":2,"310":1,"321":1,"322":3,"323":3,"332":2,"335":1,"337":2,"341":2,"342":1,"343":1,"344":1,"345":2,"348":1,"351":1,"352":1,"353":1,"354":4,"355":3,"356":9,"357":2,"358":7,"359":6,"360":6,"361":10,"362":8,"363":7,"365":3,"368":2,"369":1,"370":2,"371":1,"376":3,"380":7,"386":2,"389":1,"390":4,"394":2,"395":1,"396":8,"400":2,"401":3,"402":2,"405":1,"406":1,"407":3,"408":1,"417":3,"420":1,"424":1,"425":3,"426":6,"427":1,"428":1,"436":3,"439":2,"440":4,"442":1,"450":1,"451":2,"453":1,"459":8,"480":3,"481":3,"488":1,"508":3,"510":3,"512":2,"513":7,"519":1,"520":4,"521":1,"525":3,"526":4,"527":8,"528":2,"529":2,"530":4,"535":12,"541":6,"544":1,"545":1,"546":1,"547":1,"549":4,"550":1,"556":3,"557":2,"568":1,"569":1,"571":3,"572":2,"573":3,"577":1,"579":1,"581":1,"582":1,"583":5,"584":6,"585":4,"586":6,"587":2,"588":2,"589":4,"590":3,"592":5,"593":1,"594":5,"596":7,"597":26,"599":4,"600":3,"601":1,"602":6,"603":2,"604":6,"605":1,"606":5,"609":17,"610":5,"611":6,"612":1,"614":1,"615":4,"616":1,"618":1,"621":7,"622":1,"623":1,"627":10,"629":3,"633":1,"635":1,"636":1,"637":1,"638":2,"639":2,"642":1,"644":1,"646":1,"649":4,"651":3,"652":3,"653":7,"655":30,"656":5,"657":27,"658":30,"661":1,"663":1,"664":2,"665":3,"667":1,"670":1,"673":12,"674":2,"675":2,"676":2,"679":4,"682":4,"698":1,"702":1,"705":7,"706":2,"707":1,"709":1,"711":1,"712":2,"713":6,"714":9,"716":2,"717":1,"718":1,"720":1,"724":1,"725":3,"726":1,"727":2,"732":3,"733":2,"734":5,"740":10,"744":1,"745":2,"746":4,"747":1,"748":1,"749":1,"750":4,"755":11,"757":4,"758":2,"768":1,"769":3,"770":2,"771":4,"773":1,"774":1,"776":2,"777":4,"778":6,"779":1,"780":1,"781":1,"784":5,"785":1,"786":1,"788":2,"789":2,"790":2,"792":1,"794":4}}],["nodessection",{"2":{"792":1}}],["nodestake",{"2":{"728":1,"729":1,"730":1,"737":1,"753":1}}],["nodes",{"0":{"438":1,"511":1,"520":1,"640":1,"666":1,"708":1,"727":1,"732":1,"743":1,"755":1,"757":1,"758":1,"773":1,"775":1},"1":{"512":1,"513":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"647":1,"728":1,"729":1,"730":1,"731":1,"733":1,"734":1,"735":1,"736":1,"744":1,"745":1,"746":1,"756":1,"757":1,"758":1,"774":1,"776":1,"777":1,"778":1},"2":{"3":2,"60":1,"85":1,"130":1,"134":2,"135":1,"156":2,"161":2,"165":8,"168":2,"172":4,"188":1,"192":1,"264":2,"293":1,"329":1,"342":1,"346":1,"354":1,"421":1,"436":1,"437":1,"438":2,"439":2,"440":5,"441":5,"443":1,"448":1,"449":1,"450":6,"451":6,"452":3,"453":3,"455":1,"456":3,"457":2,"459":5,"479":1,"480":8,"481":12,"510":3,"512":1,"513":2,"519":1,"520":4,"545":2,"583":3,"590":1,"594":3,"596":1,"603":1,"607":1,"618":1,"619":1,"621":2,"622":1,"627":3,"642":1,"650":1,"662":1,"666":5,"678":1,"704":2,"708":3,"725":1,"728":1,"729":1,"730":1,"733":1,"734":4,"735":3,"740":1,"745":1,"746":2,"747":3,"748":2,"749":2,"750":1,"765":1,"769":4,"770":1,"777":1,"779":1,"784":1}}],["ignore",{"2":{"453":1}}],["ignition",{"2":{"223":16}}],["icon",{"2":{"434":1}}],["icons",{"2":{"58":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=celestia",{"2":{"365":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=",{"2":{"363":2,"365":11,"366":2}}],["ibc",{"0":{"680":1},"1":{"681":1,"682":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1,"690":1,"691":1},"2":{"680":3,"681":2,"682":4,"687":1,"690":4}}],["ibctransfer",{"2":{"330":1}}],["ibchost",{"2":{"330":1}}],["i++",{"2":{"137":2,"305":2}}],["illustrate",{"2":{"133":1}}],["illustrations",{"2":{"58":1}}],["i",{"0":{"208":1},"2":{"128":1,"137":6,"153":4,"165":4,"167":4,"168":4,"169":5,"172":32,"183":2,"184":1,"196":1,"215":1,"226":1,"305":10,"337":1,"421":1,"450":3,"451":1,"452":4,"453":3,"455":2,"456":6,"458":3,"459":8,"593":1,"627":10,"643":2,"644":2,"708":1}}],["io",{"2":{"91":2,"165":2,"166":2,"275":2,"313":6,"402":2,"434":1,"491":1,"517":1,"550":1,"638":12,"655":6,"657":6,"658":6,"728":1,"729":1,"730":1,"737":3,"738":1,"747":1,"748":1,"749":1,"753":3}}],["ip=",{"2":{"777":2}}],["ip6",{"2":{"370":4}}],["ip4",{"2":{"370":8,"584":4,"777":2}}],["ipfs",{"2":{"303":1,"305":2,"309":1,"311":3,"313":22}}],["ip",{"2":{"89":2,"275":2,"276":2,"294":2,"295":2,"314":1,"355":14,"356":6,"380":2,"396":2,"401":2,"402":2,"404":2,"510":1,"512":2,"513":6,"526":11,"527":6,"528":6,"584":2,"586":2,"587":2,"588":2,"589":4,"592":2,"597":2,"602":2,"606":2,"643":2,"655":6,"658":6,"673":3,"674":6,"704":4,"713":7,"714":6,"716":6,"733":2,"734":4,"745":2,"746":2,"777":2,"778":2,"786":2}}],["irrevocably",{"2":{"31":1}}],["idvalidator",{"2":{"698":1}}],["id=$",{"2":{"705":2}}],["id=",{"2":{"549":2,"783":2,"789":2}}],["id=testnet",{"2":{"542":2,"698":2}}],["id=your",{"2":{"311":2}}],["idtopost",{"2":{"305":10}}],["ids",{"2":{"213":1,"219":2,"584":1,"593":1}}],["idaoracle",{"2":{"127":6,"129":1,"131":1,"172":6}}],["ide",{"2":{"400":1}}],["idea",{"2":{"261":1}}],["ideas",{"2":{"41":1}}],["ideally",{"2":{"43":1}}],["ideal",{"2":{"40":1,"246":1}}],["identically",{"2":{"133":1}}],["identify",{"2":{"41":1,"48":1,"107":1,"134":2,"453":1}}],["identifying",{"2":{"31":1,"38":1}}],["identification",{"2":{"33":2}}],["identifiers",{"2":{"243":2,"453":1}}],["identifier",{"2":{"33":1,"84":1,"116":2,"117":2,"127":2,"280":2,"281":2,"305":4,"307":2}}],["identity",{"2":{"7":2,"31":1,"458":1,"477":1}}],["id",{"0":{"370":1,"593":1},"2":{"27":3,"84":2,"89":4,"134":1,"151":2,"156":4,"161":4,"165":19,"166":13,"172":12,"211":4,"213":3,"215":2,"216":2,"218":1,"219":3,"220":10,"227":4,"269":1,"275":9,"276":10,"299":2,"305":12,"311":1,"312":2,"313":8,"314":1,"356":1,"365":1,"368":2,"369":2,"370":6,"371":2,"372":10,"380":4,"386":4,"392":6,"400":2,"401":2,"402":2,"433":1,"458":1,"515":1,"527":1,"535":6,"536":14,"538":4,"539":8,"540":4,"542":8,"545":1,"549":20,"564":6,"571":3,"573":5,"584":5,"593":2,"627":6,"673":1,"679":1,"682":4,"687":40,"698":5,"702":4,"705":4,"751":1,"783":1}}],["ifconfig",{"2":{"705":2}}],["if",{"0":{"447":1},"2":{"4":1,"24":3,"25":1,"26":1,"27":5,"30":1,"31":4,"33":1,"34":3,"36":2,"37":1,"40":3,"41":1,"42":2,"43":1,"44":2,"45":1,"46":2,"47":3,"48":3,"76":1,"77":1,"79":2,"89":4,"103":1,"107":3,"110":2,"117":2,"126":1,"134":1,"135":1,"136":1,"137":8,"139":10,"148":2,"157":4,"160":1,"163":4,"164":2,"165":1,"169":1,"171":6,"172":4,"177":1,"178":1,"179":1,"181":1,"183":3,"187":1,"188":2,"189":1,"192":1,"194":1,"200":1,"206":1,"208":1,"210":1,"211":12,"214":1,"217":1,"219":2,"224":6,"225":1,"226":1,"234":1,"236":1,"239":1,"243":1,"255":1,"261":1,"264":2,"269":2,"281":2,"301":1,"313":2,"314":1,"315":1,"316":1,"317":1,"318":1,"321":1,"322":1,"346":1,"351":2,"353":1,"355":2,"356":1,"357":1,"359":2,"360":2,"361":1,"362":1,"363":2,"366":2,"375":1,"381":1,"382":1,"388":1,"391":1,"392":2,"394":1,"396":2,"400":1,"402":1,"403":2,"405":1,"406":1,"407":1,"413":1,"415":2,"417":1,"418":2,"420":1,"421":4,"426":26,"429":1,"430":1,"432":8,"433":1,"436":1,"438":1,"440":1,"441":1,"450":1,"452":2,"453":1,"459":3,"502":1,"504":1,"505":1,"526":2,"527":1,"536":1,"541":1,"544":3,"545":3,"547":1,"551":3,"553":1,"558":1,"561":2,"564":2,"573":1,"579":2,"581":1,"583":2,"584":1,"589":1,"592":1,"594":3,"597":1,"602":1,"604":1,"607":1,"609":1,"611":2,"612":1,"618":2,"621":2,"627":3,"629":1,"633":1,"634":2,"639":3,"646":1,"649":2,"651":1,"652":1,"653":2,"655":1,"656":1,"663":1,"664":1,"673":1,"675":1,"678":1,"679":2,"684":1,"685":2,"686":1,"691":1,"692":2,"696":1,"697":1,"701":1,"702":2,"746":1,"748":1,"758":1,"769":1,"771":3,"773":1,"774":3,"776":1,"777":1,"778":2,"783":3,"784":1,"786":1,"789":3,"794":2}}],["ini",{"2":{"605":1}}],["initcelestia",{"2":{"354":1,"362":1,"672":1,"712":1}}],["initgit",{"2":{"126":1}}],["init",{"2":{"115":5,"126":1,"279":5,"304":2,"309":3,"354":5,"362":5,"396":6,"399":2,"526":8,"530":2,"542":2,"592":3,"597":3,"604":4,"606":2,"627":6,"657":9,"672":5,"698":2,"712":5,"786":2}}],["initiatives",{"2":{"487":1,"488":2,"489":1}}],["initiated",{"2":{"33":1}}],["initially",{"2":{"769":1}}],["initialisation",{"2":{"592":1,"618":1}}],["initialise",{"2":{"513":1,"734":1}}],["initialization",{"2":{"615":1,"621":1}}],["initializing",{"2":{"217":1,"354":1,"396":1,"526":1}}],["initializes",{"2":{"117":1,"281":1}}],["initialize",{"0":{"399":1,"526":1,"657":1,"672":1,"698":1,"712":1,"786":1},"2":{"115":1,"126":1,"263":1,"279":1,"291":1,"362":2,"399":1,"400":2,"401":3,"402":2,"530":2,"602":1,"604":1,"606":1,"621":1,"627":1,"657":1}}],["initialized",{"2":{"85":1,"126":1,"145":1,"614":1,"690":1,"697":1,"712":1}}],["initial",{"2":{"23":1,"84":1,"456":2,"483":1,"488":1,"489":1,"536":2}}],["inherently",{"2":{"479":1}}],["inherits",{"2":{"548":1}}],["inherit",{"2":{"263":1}}],["inheriting",{"2":{"230":1}}],["inability",{"2":{"443":1}}],["inappropriate",{"2":{"8":1,"9":1,"13":2,"15":1,"16":1}}],["injectedwallet",{"2":{"312":4}}],["innercontainerstyle",{"2":{"313":4}}],["innernode",{"2":{"165":12,"172":12}}],["innovative",{"2":{"264":1}}],["inputting",{"2":{"783":1,"789":1}}],["input=$",{"2":{"385":2}}],["input=3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"385":2}}],["inputstyle",{"2":{"313":6}}],["inputs",{"2":{"127":2}}],["input",{"0":{"298":1},"2":{"127":2,"196":3,"200":2,"203":2,"212":1,"298":3,"313":2,"385":4,"386":2,"586":1}}],["inbox",{"2":{"98":1,"99":1,"108":1}}],["indeed",{"2":{"449":1,"458":1,"459":1}}],["independently",{"2":{"235":1,"456":1}}],["indexing",{"0":{"630":1},"2":{"442":1,"629":1,"632":1,"646":1}}],["index`",{"2":{"211":2}}],["index",{"2":{"134":2,"151":2,"153":2,"156":6,"159":8,"160":2,"161":2,"168":3,"169":2,"172":4,"181":1,"183":1,"184":3,"312":2,"313":4,"561":2,"600":2,"646":2,"791":1}}],["indexer",{"0":{"646":1,"791":1},"2":{"630":1,"632":2,"646":3,"791":1}}],["indexers",{"2":{"447":1}}],["indexed",{"2":{"129":1,"646":2}}],["indexes",{"2":{"84":1}}],["induced",{"2":{"139":1}}],["industry",{"2":{"44":1}}],["indicates",{"2":{"295":1,"380":1,"605":1}}],["indicated",{"2":{"223":1}}],["indicators",{"2":{"38":1}}],["individual",{"2":{"10":1,"16":1,"27":1,"65":1,"131":1,"305":2}}],["individuals",{"2":{"8":1,"16":1,"233":1}}],["inflation",{"0":{"484":1},"2":{"484":3,"494":2}}],["infra",{"2":{"346":1}}],["infrastructure",{"2":{"24":2,"27":1,"48":1,"91":4,"481":1,"488":1,"590":1,"740":1,"765":1}}],["infura",{"2":{"303":1,"311":6,"313":12}}],["infocurl",{"2":{"774":1}}],["infocelestia",{"2":{"370":1,"376":1}}],["infos",{"2":{"564":2}}],["informed",{"2":{"739":1,"754":1,"767":1}}],["inform",{"2":{"107":1}}],["informative",{"2":{"48":1,"63":1,"65":1}}],["information$",{"2":{"530":1}}],["information",{"0":{"28":1,"33":1,"790":1},"2":{"8":1,"30":4,"31":1,"32":1,"33":18,"34":1,"42":1,"48":2,"79":2,"85":1,"86":1,"92":1,"103":1,"107":1,"109":1,"110":1,"134":2,"135":2,"136":2,"145":1,"148":2,"151":1,"156":1,"161":1,"172":1,"181":1,"183":1,"211":1,"219":1,"238":1,"239":1,"243":1,"253":1,"269":1,"275":2,"355":1,"356":1,"370":1,"372":1,"420":1,"426":2,"442":2,"443":1,"445":1,"526":1,"527":1,"530":1,"536":1,"545":2,"547":1,"573":2,"579":1,"592":1,"655":1,"673":3,"690":1,"706":1,"713":2,"786":1}}],["informalsystems",{"2":{"550":1}}],["informal",{"2":{"37":1}}],["info",{"0":{"51":1},"1":{"52":1,"53":1,"54":1,"55":1,"56":1},"2":{"27":1,"77":1,"156":2,"318":1,"358":1,"370":1,"376":1,"445":1,"564":4,"682":2,"774":1,"783":2,"789":2}}],["intuitive",{"2":{"208":1}}],["int64",{"2":{"153":8,"165":4,"169":4,"170":4,"172":8}}],["intake",{"2":{"47":2}}],["introducing",{"2":{"457":1}}],["introduction",{"0":{"59":1,"62":1,"104":1,"174":1,"291":1,"336":1,"349":1,"457":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":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,"200":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"337":1,"338":1,"339":1,"340":1,"350":1,"351":1},"2":{"43":1,"59":2,"61":1,"62":3,"79":1,"80":1,"101":1,"105":1,"245":1,"329":1}}],["introduces",{"2":{"480":1}}],["introduced",{"2":{"429":1}}],["introduce",{"2":{"37":1,"301":1}}],["intel",{"2":{"664":1}}],["integrating",{"2":{"240":1,"328":1}}],["integrations",{"0":{"431":1,"508":1,"725":1},"1":{"432":1,"433":1,"434":1,"509":1,"510":1,"511":1,"512":1,"513":1,"726":1,"727":1,"728":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1},"2":{"31":1,"287":1,"547":1}}],["integration",{"0":{"336":1,"337":1},"1":{"337":1,"338":2,"339":1,"340":1},"2":{"31":1,"73":1,"79":2,"80":1,"94":1,"101":1,"105":2,"106":2,"107":2,"108":1,"109":2,"110":1,"230":1,"245":2,"254":1,"337":1,"338":2,"340":2,"392":1,"547":1,"720":1}}],["integrate",{"0":{"123":1,"132":1,"238":1,"240":1,"328":1},"1":{"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"239":1,"240":1,"241":1,"242":1,"329":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1},"2":{"238":1,"240":2,"265":1,"394":1,"547":1}}],["integrated",{"2":{"109":1}}],["integrates",{"2":{"94":1}}],["integrity",{"2":{"84":2}}],["integer",{"2":{"84":1,"116":1,"117":1,"280":1,"281":1}}],["interruptions",{"2":{"720":1}}],["inter",{"2":{"680":1}}],["interval",{"2":{"545":4,"602":4,"682":2}}],["intermediate",{"2":{"451":1,"452":1,"458":1,"459":1}}],["interfaces",{"2":{"135":2,"305":2,"310":1,"491":1,"492":1,"501":1,"643":2}}],["interface",{"0":{"129":1},"2":{"107":2,"129":3,"131":1,"135":4,"228":1,"357":1,"455":1,"548":1,"573":2}}],["internally",{"2":{"520":1}}],["internal",{"2":{"89":5,"342":1}}],["interestingly",{"2":{"457":1}}],["interested",{"2":{"44":2,"45":3,"48":3,"301":1,"383":1}}],["interest",{"2":{"42":2,"43":1,"53":1}}],["interests",{"2":{"42":1,"47":1,"48":1}}],["interactivecelestia",{"2":{"578":1}}],["interactive",{"2":{"65":1,"578":1}}],["interactions",{"2":{"14":1,"135":1,"247":1}}],["interaction",{"2":{"14":2,"15":3,"16":1,"31":1,"37":1,"88":1,"520":1}}],["interacting",{"0":{"121":1,"285":1},"2":{"3":1,"143":1,"339":1,"341":1,"345":1,"358":2,"583":1,"593":1,"594":1}}],["interact",{"0":{"76":1,"78":1,"319":1},"2":{"7":1,"76":2,"77":1,"120":1,"131":1,"145":1,"242":1,"247":1,"249":1,"275":2,"276":2,"284":1,"317":2,"318":1,"332":1,"341":1,"357":1,"358":2,"359":1,"360":1,"361":2,"661":1,"708":1,"747":1,"748":1,"749":1}}],["intensive",{"2":{"633":1}}],["intended",{"2":{"300":1}}],["intend",{"2":{"34":1}}],["intent",{"2":{"34":1}}],["intention",{"2":{"34":1}}],["into",{"0":{"445":1},"2":{"23":1,"26":1,"59":1,"69":1,"75":1,"87":1,"91":1,"94":1,"107":1,"108":1,"109":1,"146":2,"148":1,"217":1,"223":1,"230":1,"269":1,"310":3,"313":2,"317":1,"351":1,"402":2,"417":1,"450":2,"452":1,"453":2,"456":1,"458":5,"477":3,"533":1,"543":1,"547":1,"556":1,"581":1,"586":1,"593":1,"602":1,"609":1,"612":1,"678":1,"683":1,"720":1}}],["inception",{"2":{"719":1}}],["incentive",{"2":{"459":1}}],["incentives",{"2":{"43":1,"446":1}}],["incentivizes",{"2":{"448":1}}],["incentivize",{"0":{"446":1},"2":{"446":1}}],["incentivized",{"0":{"30":1},"1":{"31":1,"32":1,"33":1,"34":1},"2":{"30":1,"488":1}}],["incurred",{"2":{"291":1,"299":1}}],["incubators",{"2":{"40":1}}],["increment",{"2":{"116":3,"117":4,"280":3,"281":4}}],["incredible",{"2":{"50":1}}],["increased",{"2":{"91":2}}],["increases",{"2":{"45":1,"84":1,"116":1,"117":1,"280":1,"281":1,"439":1,"457":1}}],["increase",{"2":{"44":1,"45":1,"456":1,"457":1,"544":2,"605":1}}],["increasing",{"2":{"42":1,"451":1,"457":1,"605":1}}],["incomplete",{"2":{"453":1}}],["incoming",{"2":{"409":2}}],["income",{"2":{"34":1}}],["incorrectly",{"0":{"452":1},"2":{"440":1,"441":1,"452":2}}],["incorrect",{"2":{"89":1,"287":1,"441":1}}],["incorporate",{"2":{"30":1}}],["incident",{"2":{"11":1,"14":1}}],["inclusion",{"0":{"131":1,"141":1,"150":1,"154":1,"155":1,"158":1,"160":1,"184":1},"1":{"151":1,"152":1,"156":1,"157":1,"159":1,"161":1,"162":1},"2":{"46":1,"128":2,"129":1,"131":4,"134":1,"136":3,"141":1,"146":1,"148":1,"150":1,"151":1,"153":2,"155":1,"156":2,"160":1,"164":1,"165":1,"169":1,"172":1,"173":1,"177":3,"178":2,"183":2,"184":7,"197":1,"200":1,"208":2,"237":2,"429":1}}],["inclusive",{"2":{"7":1,"52":1,"225":1}}],["including",{"2":{"14":1,"15":2,"16":1,"27":1,"31":1,"33":2,"34":4,"36":3,"37":1,"47":1,"52":1,"65":1,"84":1,"86":1,"92":1,"419":1,"488":1,"783":1}}],["included",{"2":{"129":2,"136":2,"137":3,"146":1,"169":2,"181":1,"183":1,"192":1,"237":1,"305":1,"323":2,"363":1,"365":1,"366":1,"408":2,"415":2,"421":3,"425":2,"428":1,"429":1,"430":1,"477":1,"724":1}}],["includes",{"2":{"14":1,"57":1,"58":1,"85":1,"94":1,"109":1,"117":1,"281":1,"334":1,"445":1,"453":1,"477":1,"489":1,"679":1,"681":1,"703":1}}],["include",{"2":{"8":2,"10":1,"30":3,"44":1,"181":1,"225":1,"238":1,"265":1,"305":1,"359":1,"387":1,"447":1,"477":1,"546":1,"704":1}}],["invocations",{"2":{"639":1,"789":1}}],["invoke",{"2":{"305":2}}],["involves",{"2":{"418":1,"444":1}}],["involve",{"2":{"135":2,"136":1}}],["involvement",{"2":{"43":1}}],["involved",{"2":{"14":1,"15":1,"199":1,"337":1,"418":1,"419":1}}],["involving",{"2":{"34":1}}],["investigations",{"2":{"194":1}}],["investigate",{"2":{"42":1,"44":1}}],["investigated",{"2":{"11":1,"179":1,"192":1,"202":1}}],["invalid",{"0":{"649":1,"794":1},"2":{"136":2,"139":2,"172":4,"183":1,"188":2,"192":2,"408":2,"409":2,"452":2,"459":1,"602":2,"649":2,"794":2}}],["invites",{"2":{"54":1}}],["invite",{"2":{"43":2,"45":2}}],["invitations",{"2":{"36":1}}],["invitation",{"2":{"34":2,"53":1}}],["invisible",{"2":{"7":1}}],["inspect",{"2":{"436":1}}],["inspired",{"2":{"17":1,"187":1,"211":1}}],["insecure",{"2":{"426":4}}],["inside",{"0":{"200":1},"2":{"181":2,"196":1,"197":1,"200":2,"202":1,"203":3,"205":1,"267":1,"269":1,"400":1,"405":1,"528":1,"581":1,"674":1,"702":1,"703":1,"704":1,"716":1}}],["insight",{"2":{"543":1}}],["insightful",{"2":{"50":1}}],["insights",{"2":{"5":1,"38":1,"43":1,"65":1,"550":1}}],["instrumentation",{"2":{"544":6}}],["instructions",{"0":{"219":1},"2":{"209":1,"220":2,"223":1,"226":1,"227":1,"391":1,"392":1,"412":1,"413":1,"527":1,"552":1,"553":1,"564":1,"582":1,"610":1,"612":1,"625":1,"653":3,"661":1,"663":2,"673":1,"740":2,"781":1,"789":1,"791":1}}],["instead",{"2":{"102":1,"108":1,"135":1,"139":3,"185":1,"203":1,"287":1,"337":1,"365":1,"417":3,"421":1,"480":1,"497":1}}],["instability",{"2":{"720":1,"760":1}}],["instantaneous",{"2":{"676":1}}],["instantiation",{"0":{"692":1},"1":{"693":1,"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1}}],["instantiating",{"2":{"103":1,"309":1,"354":1}}],["instantiate",{"0":{"354":1,"706":1},"2":{"354":1,"456":1,"692":1}}],["instance",{"2":{"69":1,"75":1,"90":2,"117":1,"223":1,"224":1,"243":1,"281":1,"317":1,"413":1,"522":1,"545":1,"585":1,"604":1,"624":1,"668":1,"710":1,"781":1}}],["instances",{"2":{"11":1}}],["installer",{"2":{"653":1}}],["installed",{"2":{"114":1,"125":1,"211":1,"217":1,"274":1,"278":1,"290":1,"395":1,"432":1,"557":1,"568":1,"577":1,"581":1,"611":1,"614":1,"650":1,"664":2,"681":1,"682":1}}],["installmake",{"2":{"581":1,"609":1}}],["installs",{"2":{"268":2,"609":1}}],["installation",{"0":{"268":1,"695":1},"2":{"266":1,"309":1,"582":2,"610":2}}],["installing",{"0":{"126":1,"582":1,"609":1,"610":1},"2":{"523":1,"525":1,"580":1,"582":1,"609":1,"610":1,"625":1,"626":1,"653":1,"661":1,"663":2,"670":1,"711":1,"768":1,"771":1,"785":1}}],["install",{"0":{"396":1,"525":1,"580":1,"608":1,"626":1,"663":1,"664":1,"670":1,"711":1,"785":1},"1":{"581":1,"582":1,"583":1,"609":1,"610":1,"611":1,"612":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1},"2":{"87":2,"126":4,"212":2,"219":2,"268":2,"310":1,"311":3,"315":1,"321":1,"353":1,"357":1,"396":1,"406":1,"432":2,"525":1,"545":1,"547":1,"552":1,"554":1,"577":1,"581":3,"582":1,"609":3,"610":1,"612":1,"653":1,"663":15,"664":2,"681":1,"695":1,"711":1,"769":1,"770":1,"771":1,"774":2,"776":2,"777":2,"778":2}}],["insulting",{"2":{"8":1}}],["in",{"0":{"66":1,"67":1,"110":1,"163":1,"213":1,"293":1,"295":1,"421":1,"438":1,"480":1,"604":1,"688":1,"759":1},"1":{"67":1,"68":2,"69":2,"70":1,"71":1,"72":1,"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"214":1,"215":1,"216":1,"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1},"2":{"3":1,"4":2,"5":1,"7":2,"8":1,"9":1,"10":1,"12":2,"13":1,"14":1,"19":1,"21":1,"23":6,"24":6,"25":3,"27":2,"29":1,"30":10,"31":17,"32":3,"33":3,"34":41,"35":1,"37":1,"38":1,"39":1,"40":2,"41":4,"42":3,"43":2,"44":6,"45":7,"46":4,"48":7,"50":2,"52":2,"53":2,"54":1,"56":1,"60":1,"61":1,"65":4,"66":2,"68":3,"69":4,"71":3,"72":3,"75":3,"76":4,"77":1,"82":1,"83":2,"84":12,"85":4,"86":1,"87":1,"88":5,"89":10,"91":10,"92":3,"93":1,"94":1,"95":1,"102":4,"105":1,"106":1,"107":7,"108":10,"109":1,"110":3,"111":1,"113":1,"115":1,"116":4,"117":8,"122":1,"128":2,"129":2,"130":1,"131":2,"134":13,"135":3,"136":12,"137":4,"139":1,"145":3,"146":8,"148":10,"149":1,"150":1,"159":2,"161":3,"162":2,"164":3,"165":13,"166":1,"167":1,"168":9,"169":8,"170":2,"171":1,"173":2,"174":1,"175":2,"176":1,"177":3,"178":4,"180":3,"181":4,"182":1,"183":9,"184":9,"188":2,"189":1,"191":2,"192":5,"193":1,"194":1,"195":1,"196":3,"197":1,"199":1,"200":2,"203":1,"206":2,"208":5,"210":1,"211":7,"212":3,"213":5,"214":1,"217":6,"219":6,"220":16,"222":2,"223":2,"224":7,"225":3,"226":2,"228":1,"230":2,"233":1,"235":1,"236":1,"237":4,"238":3,"239":1,"241":1,"242":1,"243":1,"245":2,"246":1,"249":1,"261":1,"263":1,"264":2,"265":2,"267":1,"268":4,"269":2,"270":1,"275":3,"276":3,"277":1,"279":1,"280":4,"281":8,"287":4,"291":2,"293":1,"294":1,"297":1,"301":2,"305":6,"308":2,"309":3,"310":2,"311":1,"316":1,"317":7,"318":1,"322":1,"323":1,"324":5,"325":6,"330":1,"331":1,"332":4,"335":2,"337":3,"340":1,"341":1,"346":1,"348":1,"351":1,"354":1,"355":2,"356":2,"358":3,"359":1,"360":1,"361":1,"362":1,"363":4,"365":4,"366":1,"370":2,"371":1,"375":6,"378":1,"380":3,"383":1,"387":2,"388":1,"390":2,"392":1,"393":1,"394":1,"396":5,"397":1,"399":1,"400":1,"402":3,"407":1,"408":1,"409":4,"412":1,"413":5,"415":5,"416":1,"417":3,"418":4,"419":4,"420":2,"421":2,"422":1,"424":1,"427":1,"428":2,"429":1,"430":1,"432":2,"433":2,"434":2,"438":2,"441":1,"443":1,"444":1,"445":1,"446":1,"449":1,"450":4,"451":3,"453":1,"456":9,"457":1,"458":3,"459":3,"460":1,"463":1,"464":1,"468":1,"477":1,"478":2,"479":3,"480":3,"481":4,"483":1,"484":2,"487":1,"488":1,"489":2,"494":1,"496":1,"497":3,"498":2,"499":1,"501":1,"502":1,"505":2,"508":2,"509":1,"510":2,"513":2,"520":3,"526":1,"528":1,"533":1,"536":4,"537":2,"542":2,"545":3,"546":1,"551":3,"553":1,"557":1,"559":1,"561":3,"564":1,"565":1,"566":1,"568":2,"571":1,"573":1,"574":1,"578":1,"581":1,"582":2,"584":1,"585":1,"586":1,"589":2,"590":3,"594":1,"596":4,"597":2,"599":1,"602":1,"604":2,"605":4,"606":1,"609":1,"610":2,"615":1,"618":1,"619":1,"621":1,"622":1,"627":7,"629":1,"631":1,"632":1,"633":2,"634":2,"637":3,"644":1,"646":2,"647":6,"649":2,"651":2,"652":1,"653":2,"657":3,"661":1,"664":1,"673":1,"674":1,"676":2,"677":2,"678":3,"679":2,"680":2,"681":1,"684":2,"685":5,"696":1,"697":1,"698":1,"701":3,"702":2,"703":2,"705":1,"712":1,"713":1,"714":2,"715":1,"716":1,"719":2,"723":1,"724":6,"725":4,"726":1,"736":1,"740":3,"744":1,"746":1,"748":1,"749":1,"750":1,"755":2,"762":1,"765":1,"768":2,"769":2,"771":4,"774":3,"778":2,"779":2,"783":2,"789":3,"794":2}}],["imagine",{"2":{"265":1}}],["image",{"2":{"102":1,"275":3,"276":6,"434":1,"655":1}}],["imagery",{"2":{"8":1}}],["images",{"2":{"3":1,"434":1}}],["immutable",{"2":{"84":2,"127":2}}],["improperly",{"2":{"440":1}}],["improve",{"2":{"47":1}}],["improvement",{"2":{"38":1,"451":1}}],["improvements",{"2":{"4":1,"720":1}}],["improved",{"2":{"29":1,"230":1,"543":1}}],["improves",{"2":{"24":1}}],["improving",{"2":{"2":1}}],["impractical",{"2":{"436":1}}],["imported",{"2":{"315":1}}],["importing",{"0":{"271":1,"533":1},"2":{"584":1}}],["import",{"0":{"400":1},"2":{"117":4,"127":6,"152":2,"153":2,"159":1,"172":6,"271":1,"281":4,"305":4,"307":4,"312":19,"313":17,"315":2,"323":1,"400":4,"420":1,"425":1,"426":1,"432":7,"520":1,"533":5,"545":2,"584":1,"683":1}}],["importance",{"2":{"65":1}}],["important",{"0":{"51":1},"1":{"52":1,"53":1,"54":1,"55":1,"56":1},"2":{"24":1,"28":1,"30":1,"108":1,"134":2,"419":1,"428":1,"455":1,"545":1,"546":1,"561":2,"593":1,"677":1}}],["impose",{"2":{"34":1}}],["implement",{"2":{"405":1,"456":1,"481":2}}],["implements",{"2":{"107":1}}],["implementations",{"0":{"231":1},"2":{"135":2,"680":1}}],["implementation",{"0":{"107":1,"108":1,"109":1,"293":1},"2":{"33":1,"106":3,"126":1,"131":1,"133":1,"148":1,"172":4,"230":3,"231":1,"235":1,"236":1,"237":1,"358":1,"412":1,"520":1,"678":1,"681":1}}],["implemented",{"2":{"31":1,"173":1,"413":1,"480":4,"748":1}}],["impactful",{"2":{"43":1,"65":1}}],["impact",{"2":{"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"27":1,"44":1}}],["itrocket",{"2":{"728":1,"729":1,"730":1,"731":1,"734":1,"737":1,"738":1,"746":1,"747":1,"748":1,"749":1,"753":1}}],["ith",{"2":{"419":2}}],["item",{"2":{"404":1}}],["items",{"2":{"401":1,"402":1}}],["itemcount",{"2":{"305":6}}],["itn",{"2":{"30":7,"31":11,"32":3,"33":1,"34":38}}],["itself",{"2":{"30":1,"94":1,"545":2}}],["its",{"2":{"19":2,"27":2,"30":3,"34":1,"84":4,"85":2,"108":1,"126":1,"148":1,"156":1,"158":1,"165":2,"166":2,"172":2,"175":1,"177":1,"181":1,"183":1,"187":1,"191":1,"192":1,"196":1,"208":1,"211":1,"218":1,"219":1,"234":1,"235":1,"254":2,"368":1,"405":1,"417":1,"418":1,"438":1,"439":1,"453":2,"456":1,"490":1,"498":1,"545":1,"605":1,"719":1,"774":1,"776":1,"777":1,"778":1}}],["it",{"0":{"315":1,"316":1},"2":{"2":2,"24":1,"30":1,"34":1,"35":1,"41":1,"42":1,"47":2,"48":1,"53":1,"69":1,"75":1,"76":1,"84":5,"86":2,"88":1,"89":3,"90":1,"102":1,"107":6,"108":1,"110":1,"116":1,"117":5,"120":2,"128":1,"129":1,"131":6,"133":1,"135":2,"139":2,"145":1,"146":2,"148":2,"150":2,"160":2,"164":2,"166":2,"169":1,"172":2,"174":1,"177":1,"179":1,"181":1,"183":2,"188":1,"191":1,"192":1,"196":2,"203":1,"208":1,"211":10,"212":4,"213":3,"217":1,"219":8,"220":2,"223":4,"224":5,"225":1,"226":1,"227":1,"228":1,"235":1,"237":2,"239":3,"243":1,"245":1,"246":2,"249":1,"260":1,"263":1,"266":1,"268":1,"280":1,"281":5,"284":2,"289":1,"293":1,"305":3,"307":1,"308":3,"309":2,"310":2,"313":4,"315":1,"317":2,"323":2,"335":1,"337":1,"344":1,"346":1,"355":2,"358":1,"363":1,"372":2,"381":2,"382":1,"384":1,"385":1,"392":1,"394":1,"396":3,"397":1,"402":7,"403":3,"404":1,"405":2,"415":2,"418":2,"419":4,"421":4,"425":2,"426":2,"429":1,"430":1,"432":4,"436":5,"439":2,"440":1,"445":1,"446":1,"452":1,"453":1,"456":1,"457":1,"458":5,"459":1,"481":2,"484":1,"505":5,"526":2,"527":1,"543":1,"544":2,"545":6,"546":1,"547":1,"551":1,"557":1,"561":2,"564":1,"575":1,"578":1,"582":1,"583":1,"586":1,"589":2,"592":1,"593":1,"594":1,"601":1,"602":2,"604":2,"605":1,"607":1,"610":1,"611":1,"634":1,"638":1,"642":1,"643":2,"647":1,"649":1,"651":1,"656":2,"673":2,"677":1,"680":1,"681":2,"683":1,"684":1,"691":1,"701":1,"703":2,"704":1,"712":1,"719":1,"720":1,"724":1,"740":1,"746":1,"760":1,"763":1,"765":1,"771":1,"774":2,"783":1,"784":2,"794":1}}],["issuing",{"2":{"497":1}}],["issuance",{"2":{"484":2}}],["issued",{"2":{"34":1}}],["issues",{"2":{"9":1,"60":1,"89":1,"338":1,"392":3,"612":1}}],["issue",{"2":{"4":1,"91":1,"421":1,"443":1,"484":1,"497":1,"681":1,"758":2}}],["isn",{"2":{"139":1,"413":1,"724":1}}],["isvalid",{"2":{"139":2}}],["isolated",{"2":{"653":1}}],["isolates",{"2":{"264":1}}],["isolate",{"2":{"135":1}}],["is",{"0":{"230":1,"236":1,"237":1,"260":1,"261":1,"436":1,"437":1,"439":1,"441":1,"442":1,"443":1,"444":1,"447":1},"1":{"231":1},"2":{"1":1,"5":1,"8":1,"10":1,"15":1,"17":1,"21":1,"22":1,"24":1,"26":1,"27":2,"30":5,"31":3,"33":1,"34":7,"35":1,"37":1,"40":1,"43":1,"44":1,"45":2,"47":3,"48":1,"49":1,"52":1,"53":2,"55":2,"56":1,"57":1,"59":1,"60":2,"61":2,"65":3,"71":1,"82":1,"83":3,"84":8,"85":1,"86":3,"88":3,"89":7,"91":10,"92":1,"94":2,"106":3,"107":7,"108":2,"109":1,"110":2,"117":7,"126":2,"127":2,"128":3,"129":2,"131":6,"133":3,"134":30,"135":5,"136":6,"137":6,"139":6,"143":1,"145":1,"146":3,"148":5,"150":2,"154":1,"156":2,"157":1,"158":2,"159":1,"160":1,"161":1,"162":1,"164":2,"165":5,"166":3,"168":2,"169":12,"172":6,"173":1,"174":1,"176":1,"177":1,"178":1,"181":3,"182":1,"183":9,"184":12,"187":3,"188":6,"189":1,"192":9,"194":1,"195":1,"196":6,"197":1,"200":6,"202":1,"203":4,"206":1,"208":6,"211":13,"213":2,"214":2,"217":3,"219":4,"220":6,"221":2,"222":1,"223":8,"224":7,"227":1,"228":1,"230":4,"233":1,"234":2,"235":2,"236":1,"237":3,"239":3,"242":2,"243":2,"244":2,"245":3,"249":1,"250":1,"260":1,"261":1,"263":2,"264":1,"266":1,"267":1,"281":7,"287":3,"291":1,"293":1,"294":1,"295":1,"297":1,"300":1,"302":2,"305":4,"306":1,"307":2,"308":1,"309":3,"311":1,"313":3,"315":1,"322":1,"328":1,"330":2,"332":1,"333":1,"334":1,"335":3,"336":2,"337":8,"338":1,"340":1,"341":1,"344":1,"345":1,"346":2,"350":1,"354":1,"355":1,"356":1,"358":5,"359":2,"360":2,"361":1,"362":3,"363":3,"365":3,"366":2,"368":1,"369":1,"370":2,"371":1,"372":1,"375":2,"382":1,"383":1,"390":2,"391":1,"392":1,"396":2,"400":1,"402":5,"404":2,"407":1,"412":1,"415":4,"417":4,"418":4,"419":14,"420":2,"421":2,"426":8,"428":2,"429":1,"430":1,"432":5,"436":2,"437":3,"438":1,"439":3,"440":6,"441":3,"442":2,"443":2,"444":2,"445":3,"446":3,"448":1,"449":2,"450":6,"452":7,"453":8,"455":7,"456":3,"457":3,"458":5,"459":9,"460":1,"466":1,"470":1,"475":1,"477":2,"479":5,"480":3,"481":4,"483":1,"489":3,"496":1,"497":1,"501":1,"502":4,"503":1,"504":4,"505":1,"508":1,"515":1,"516":1,"520":5,"522":1,"526":1,"527":4,"529":1,"536":3,"543":1,"545":5,"547":2,"548":1,"551":6,"552":1,"559":3,"561":2,"564":1,"565":1,"566":1,"573":2,"578":1,"582":2,"583":2,"584":1,"585":1,"587":1,"588":1,"589":2,"592":2,"593":4,"594":2,"596":1,"597":1,"599":1,"601":1,"602":3,"604":2,"605":2,"606":2,"607":1,"609":2,"610":2,"616":1,"618":1,"619":2,"621":4,"624":1,"627":3,"629":1,"631":2,"633":1,"634":2,"636":1,"639":2,"644":3,"646":7,"647":1,"649":1,"651":1,"652":1,"653":3,"655":2,"656":1,"661":2,"664":1,"665":1,"668":1,"673":3,"676":1,"677":3,"679":1,"680":1,"681":4,"684":3,"690":1,"691":1,"692":1,"698":2,"700":1,"701":1,"705":2,"708":1,"713":1,"715":1,"719":2,"720":2,"724":7,"725":2,"735":1,"736":1,"740":4,"747":2,"748":3,"749":3,"751":1,"760":2,"763":2,"765":1,"770":1,"771":2,"772":1,"774":3,"777":1,"778":1,"781":1,"784":3,"788":1,"789":3,"794":1}}],["lcd",{"2":{"729":2}}],["l5dhzjldczo",{"2":{"561":2,"562":2}}],["ljj6hspn0kn09qf9fy8kdyh40000gn",{"2":{"557":4}}],["luckily",{"2":{"443":1,"446":1}}],["lumina",{"2":{"406":1}}],["lunaroasis",{"2":{"355":2,"714":2,"728":1,"729":1,"730":1,"734":1}}],["ls",{"2":{"223":2,"224":2}}],["ldflags",{"2":{"223":2}}],["lfg",{"2":{"91":2}}],["l1",{"0":{"392":1},"2":{"82":2,"84":1,"91":8,"119":3,"384":1,"385":1,"392":4,"437":1}}],["l2genesisdeltatimeoffset",{"2":{"387":1}}],["l2s",{"2":{"110":1,"230":2,"235":1,"287":2,"337":1}}],["l2",{"0":{"88":1,"392":1},"2":{"77":1,"82":1,"84":2,"85":1,"86":1,"91":6,"109":1,"113":1,"119":4,"120":2,"129":1,"131":1,"230":1,"234":2,"240":1,"287":1,"318":1,"336":1,"392":2,"437":2}}],["lts",{"2":{"333":1,"522":1,"624":1,"668":1,"710":1,"781":1}}],["lt",{"2":{"69":1,"75":2,"76":2,"89":8,"137":2,"145":3,"151":1,"153":4,"156":1,"157":2,"159":7,"161":1,"170":4,"171":6,"212":8,"213":30,"215":4,"216":4,"218":6,"224":4,"225":1,"238":1,"269":13,"270":12,"271":12,"275":5,"276":8,"292":4,"299":4,"305":2,"308":2,"309":2,"312":14,"313":100,"317":4,"324":6,"325":6,"355":6,"356":21,"358":6,"360":6,"361":4,"363":8,"365":8,"369":2,"372":4,"375":6,"377":4,"384":1,"401":6,"402":6,"404":12,"423":4,"424":4,"432":14,"513":6,"515":3,"526":8,"527":4,"528":12,"532":8,"533":6,"534":8,"535":18,"536":20,"537":4,"538":6,"539":16,"540":4,"541":6,"542":2,"545":2,"573":4,"584":10,"586":10,"587":4,"588":4,"589":16,"592":10,"597":10,"602":8,"603":4,"604":8,"606":9,"639":2,"658":2,"673":4,"674":12,"683":4,"714":6,"715":3,"716":12,"734":6,"751":3,"774":4,"776":4,"777":6,"778":6,"783":4,"786":2,"789":4}}],["l3s",{"2":{"110":1,"230":1,"287":1}}],["l3configuration",{"2":{"91":2}}],["l3",{"2":{"66":1,"69":1,"71":1,"86":2,"91":6}}],["living",{"2":{"723":1}}],["lives",{"2":{"48":1,"108":1,"559":1}}],["live",{"2":{"46":4,"68":1,"307":1,"308":1,"340":1,"392":1,"559":1,"720":1}}],["life",{"2":{"477":1,"719":1}}],["lifecycle",{"0":{"458":1},"1":{"459":1}}],["libp2p",{"2":{"459":1,"520":1}}],["libssl",{"2":{"663":4}}],["libs",{"2":{"172":2}}],["library",{"0":{"163":1,"321":1,"343":1,"406":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"322":1,"323":1,"324":1,"325":1,"326":1,"327":1,"407":1,"408":1,"409":1,"410":1,"411":1},"2":{"131":3,"163":1,"172":2,"183":1,"192":1,"200":1,"305":1,"310":2,"321":1,"343":1,"344":1,"406":1}}],["libraries",{"2":{"40":2,"197":1,"310":1,"331":1,"333":1,"334":1,"400":1,"768":1}}],["lib",{"2":{"127":2,"131":1,"172":2}}],["lightdsudo",{"2":{"778":2}}],["lightd",{"2":{"778":13}}],["lightbridgefull",{"2":{"655":1}}],["light$home",{"2":{"390":1}}],["light",{"0":{"60":1,"89":1,"142":1,"354":1,"390":1,"396":1,"424":1,"599":1,"600":1,"606":1,"656":1,"707":1,"708":1,"710":1,"712":1,"713":1,"716":1,"717":1,"743":1,"778":1},"1":{"607":1,"657":1,"658":1,"708":1,"709":1,"710":1,"711":2,"712":1,"713":1,"714":2,"715":2,"716":2,"717":2,"718":1,"744":1,"745":1,"746":1},"2":{"60":7,"80":1,"89":7,"109":1,"135":9,"142":1,"143":1,"230":2,"237":2,"264":1,"267":1,"269":2,"270":2,"271":2,"275":5,"276":10,"290":1,"292":1,"294":2,"295":4,"296":2,"297":1,"303":1,"335":1,"346":1,"352":1,"354":8,"355":14,"356":12,"360":3,"361":3,"362":12,"363":1,"380":3,"390":7,"395":1,"396":10,"420":1,"438":1,"439":4,"440":6,"441":2,"449":1,"450":5,"451":8,"452":3,"457":2,"459":9,"480":6,"510":1,"513":3,"520":1,"526":1,"585":2,"590":1,"596":1,"599":1,"600":1,"603":3,"606":7,"607":1,"611":1,"615":2,"621":6,"637":2,"651":3,"657":6,"658":6,"666":2,"673":1,"707":1,"708":2,"709":1,"712":6,"713":7,"714":12,"716":9,"717":1,"718":1,"732":1,"734":1,"735":2,"740":1,"755":2,"757":1,"769":2,"771":2,"777":1,"778":7}}],["lightning",{"2":{"48":1,"336":1}}],["lisbon",{"2":{"50":1}}],["listcelestia",{"2":{"569":1,"578":1}}],["listing",{"2":{"532":2}}],["listed",{"2":{"413":1,"510":1,"679":1,"726":1,"728":1,"744":1}}],["listens",{"2":{"643":1}}],["listeners",{"2":{"305":2}}],["listen",{"2":{"228":1,"459":1,"544":4,"545":1,"643":1,"708":1}}],["listening",{"0":{"171":1},"2":{"171":1,"643":1}}],["list",{"0":{"65":1,"562":1},"2":{"27":2,"31":1,"36":1,"42":1,"43":2,"56":2,"65":6,"84":1,"107":3,"127":2,"165":2,"168":2,"212":1,"214":1,"215":2,"220":1,"227":1,"275":3,"276":3,"327":1,"356":2,"411":1,"450":1,"473":1,"486":1,"526":2,"527":2,"532":2,"536":1,"544":2,"562":2,"569":2,"578":1,"597":2,"627":2,"673":4,"682":4,"688":4,"704":2,"714":2,"725":1,"740":1,"786":3,"789":1}}],["lines",{"2":{"541":2}}],["linear",{"2":{"419":1}}],["line",{"0":{"549":1},"2":{"355":1,"357":1,"526":1,"548":1,"573":1,"604":1,"616":1,"647":1,"655":1,"704":1}}],["lineup",{"2":{"43":1}}],["linuxdocker",{"2":{"656":1}}],["linux",{"2":{"89":1,"333":1,"522":1,"582":1,"610":1,"624":1,"654":1,"661":1,"664":12,"668":1,"710":1,"781":1}}],["linked",{"2":{"142":1}}],["link",{"2":{"33":1,"242":1,"293":4,"402":2,"508":1,"545":2,"546":1,"725":1,"740":1}}],["links",{"2":{"27":2,"54":1,"64":1}}],["little",{"2":{"40":1,"85":1,"335":1,"702":1}}],["liechtenstein",{"2":{"34":3}}],["license",{"2":{"33":1,"116":2,"117":2,"127":2,"280":2,"281":2,"305":4,"307":2}}],["limitnofile=65535",{"2":{"774":2}}],["limitnofile=1400000",{"2":{"605":2,"776":2,"777":2}}],["limitnofile",{"2":{"605":2}}],["limit=fc+∑i=1nssn",{"2":{"419":1}}],["limit×gas",{"2":{"419":1}}],["limits",{"0":{"417":1},"1":{"418":1,"419":1,"420":1},"2":{"366":1,"456":1,"544":2,"605":1}}],["limit",{"2":{"294":3,"299":2,"363":1,"366":1,"375":1,"417":2,"419":4,"420":1,"426":2,"515":1,"564":2,"605":1,"724":1,"751":1}}],["limited",{"2":{"33":1,"34":2,"330":1,"451":2,"457":1,"536":1}}],["limitations",{"2":{"180":1}}],["limitation",{"2":{"31":1}}],["liable",{"2":{"31":2,"33":1}}],["liability",{"2":{"30":1,"31":2}}],["likely",{"2":{"135":5,"335":2,"447":1,"602":1,"649":1,"794":1}}],["likelihood",{"2":{"45":1,"459":1}}],["like",{"2":{"14":1,"36":1,"40":2,"41":1,"46":1,"47":2,"48":1,"80":1,"82":1,"84":2,"89":1,"90":1,"102":1,"133":1,"134":1,"139":1,"211":3,"224":2,"255":1,"260":1,"261":2,"264":2,"275":1,"276":1,"301":3,"322":1,"346":2,"351":1,"355":1,"356":1,"362":1,"365":1,"372":2,"375":3,"381":1,"382":1,"384":1,"388":1,"396":1,"407":1,"432":1,"436":1,"437":1,"439":1,"445":1,"448":1,"483":1,"498":1,"508":1,"518":1,"528":1,"545":1,"553":1,"554":1,"558":1,"564":3,"584":2,"589":1,"594":1,"597":1,"604":1,"605":1,"607":1,"639":1,"649":1,"653":1,"655":2,"663":1,"674":1,"675":1,"679":1,"684":1,"716":1,"720":1,"725":1,"739":1,"740":2,"754":1,"767":1,"769":1,"794":1}}],["laddr",{"2":{"583":1}}],["ladder",{"2":{"17":1}}],["lang",{"2":{"573":2}}],["languages",{"2":{"145":1,"173":1}}],["language",{"2":{"8":1,"13":1}}],["lag",{"2":{"505":1}}],["laid",{"2":{"200":1,"203":1}}],["latter",{"2":{"196":1,"457":1}}],["latency",{"2":{"682":4}}],["latestblock",{"2":{"238":6}}],["latestblocknumber",{"2":{"153":4,"170":4}}],["latestrollupheight",{"2":{"135":2,"137":6}}],["latest",{"2":{"93":1,"94":1,"102":1,"135":2,"149":1,"225":2,"230":1,"236":1,"237":3,"238":1,"275":2,"330":1,"384":2,"410":6,"412":1,"437":1,"481":2,"504":1,"505":2,"568":1,"581":12,"582":1,"609":6,"610":1,"612":1,"649":1,"655":6,"657":6,"658":6,"673":1,"680":1,"763":1,"794":1}}],["later",{"2":{"40":1,"224":1,"308":1,"310":1,"443":1,"458":1,"459":1,"581":1,"699":1,"769":1,"771":1}}],["large",{"2":{"180":1,"226":1,"315":1,"335":2}}],["larger",{"2":{"40":1,"42":1,"335":1,"451":1,"544":2}}],["layout",{"2":{"136":1,"146":2,"177":1}}],["layers",{"2":{"449":2,"455":1,"456":7,"479":2}}],["layer",{"0":{"449":1},"1":{"450":1,"451":1,"452":1,"453":1,"454":1,"455":1},"2":{"89":1,"105":2,"109":1,"187":2,"230":1,"237":1,"244":1,"245":1,"246":1,"260":3,"261":3,"287":1,"329":1,"332":1,"337":5,"339":1,"348":1,"350":1,"449":3,"451":2,"453":4,"455":4,"456":6,"458":1,"459":1,"477":1,"497":1,"519":2,"520":1,"622":1,"679":1,"770":2}}],["label",{"2":{"545":2,"690":1}}],["labels",{"2":{"545":4}}],["labeled",{"2":{"53":1}}],["labs",{"2":{"24":1,"30":1,"43":2,"44":2,"45":2,"46":5,"47":10,"65":1,"79":2,"91":1,"244":1,"488":1,"504":1,"677":1}}],["lastly",{"2":{"545":1}}],["lastblock",{"2":{"137":6}}],["last",{"2":{"27":1,"30":1,"41":1,"43":1,"217":1,"225":1,"372":6,"404":1,"541":2,"551":1}}],["laws",{"2":{"34":11}}],["law",{"2":{"25":1,"34":1}}],["launching",{"2":{"42":1}}],["launch",{"0":{"21":1,"86":1},"2":{"85":1,"86":1,"245":1,"457":1,"489":2,"497":1}}],["lemongrass",{"0":{"679":1},"2":{"518":1,"679":3,"739":1,"754":1,"767":1}}],["lemonade",{"2":{"41":1}}],["ledger",{"2":{"211":2,"436":1}}],["len",{"2":{"137":8,"139":6,"153":2,"165":4,"167":2,"168":4,"169":2,"172":12,"324":2,"325":2,"401":2,"402":2,"404":2,"408":2,"409":2,"426":4}}],["length",{"2":{"134":2,"305":6}}],["left",{"2":{"135":1,"188":2,"196":1,"200":1,"203":1,"446":1}}],["lets",{"2":{"264":1}}],["let",{"2":{"47":3,"85":1,"120":1,"131":1,"283":1,"302":1,"305":2,"307":1,"311":1,"313":2,"315":1,"323":2,"354":1,"355":1,"358":1,"368":1,"369":1,"372":1,"394":1,"396":1,"401":1,"408":12,"409":12,"410":4,"425":2,"615":1}}],["leveraging",{"2":{"302":1,"687":1}}],["leverages",{"2":{"127":1}}],["leverage",{"2":{"43":1,"44":1,"45":1,"736":1}}],["leveldb",{"2":{"646":1}}],["levels",{"2":{"344":1}}],["level",{"2":{"7":1,"131":1,"133":1,"146":1,"208":1,"224":1,"344":1,"439":1,"490":1,"504":1,"546":1,"682":2}}],["legacy",{"2":{"536":3,"537":2}}],["legal",{"2":{"30":1,"33":1,"34":1}}],["legended",{"2":{"34":1}}],["legend",{"2":{"34":3}}],["legends",{"2":{"34":2}}],["lessons",{"2":{"38":1}}],["less",{"2":{"24":1,"25":1,"178":1,"192":1,"261":1,"481":1,"724":1}}],["leave",{"2":{"774":1}}],["leaves",{"2":{"127":2,"165":6,"168":2,"458":1}}],["leaving",{"2":{"724":1}}],["leapwallet",{"2":{"491":1}}],["leap",{"0":{"433":1,"467":1,"468":1},"1":{"468":1,"469":1,"470":1},"2":{"431":1,"433":3,"460":1}}],["leafs",{"2":{"453":1}}],["leaf",{"2":{"151":2,"156":2,"161":2,"168":2}}],["least",{"2":{"24":1,"41":1,"45":1,"80":1,"82":1,"220":1,"392":1,"440":1,"450":1,"452":1,"459":2,"549":2,"637":1,"702":1}}],["lead",{"2":{"14":1,"15":1,"43":1}}],["leaders",{"2":{"7":1,"9":2,"11":2,"12":1,"13":1}}],["learned",{"2":{"38":1,"122":1,"286":1,"568":1,"575":1}}],["learning",{"2":{"3":1,"8":1,"46":1,"48":2,"301":1,"340":1}}],["learn",{"2":{"3":1,"46":1,"52":1,"56":1,"71":1,"79":2,"84":1,"92":1,"105":1,"111":1,"113":1,"116":1,"134":1,"146":1,"236":1,"245":1,"246":1,"261":1,"275":1,"280":1,"291":1,"329":1,"331":1,"332":1,"339":1,"358":1,"366":1,"393":1,"394":2,"415":1,"424":1,"427":1,"460":1,"477":1,"483":2,"486":2,"487":1,"498":1,"499":1,"508":1,"518":1,"531":1,"553":1,"567":1,"574":1,"581":1,"582":2,"609":1,"610":1,"653":1,"686":1,"725":1,"736":1,"739":1,"754":1,"755":1,"767":1}}],["locked",{"2":{"432":2,"489":1}}],["lock",{"2":{"265":1,"596":1}}],["located",{"2":{"136":1,"304":1}}],["locate",{"2":{"134":1}}],["location",{"0":{"595":1},"1":{"596":1,"597":1,"598":1,"599":1,"600":1,"601":1},"2":{"24":1,"27":1,"41":2,"65":1,"134":2,"136":1,"137":1,"181":1,"182":1,"183":3,"196":1,"362":1,"530":4,"557":1,"597":10,"615":1,"703":1,"712":1}}],["localroot",{"2":{"276":1}}],["localized",{"2":{"167":1}}],["locally",{"0":{"308":1},"2":{"79":1,"212":2,"221":1,"302":1,"307":1,"308":2,"309":1,"417":1,"559":1,"589":1}}],["localhost",{"2":{"75":2,"90":1,"91":3,"119":3,"120":3,"152":2,"153":2,"283":2,"308":2,"309":6,"312":6,"314":1,"315":1,"322":2,"359":1,"384":2,"385":2,"396":1,"404":2,"407":2,"544":2,"545":4,"583":3,"594":3,"643":2,"774":2}}],["local",{"0":{"220":1,"226":1,"554":1,"555":1},"1":{"555":1,"556":2,"557":2,"558":2,"559":2,"560":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1},"2":{"2":1,"40":1,"42":1,"43":2,"44":2,"45":3,"46":2,"53":1,"69":1,"71":1,"79":1,"85":1,"91":1,"92":1,"120":1,"217":2,"220":5,"226":2,"243":1,"270":1,"276":1,"283":3,"293":1,"308":4,"311":1,"410":2,"413":2,"533":2,"553":1,"558":1,"561":2,"562":4,"567":1,"568":1,"575":1,"582":1,"589":1,"610":1,"627":2,"649":4,"657":2,"658":2,"664":21,"746":1,"783":1,"794":4}}],["loads",{"2":{"313":2}}],["load",{"2":{"69":1,"269":1,"400":2,"401":3,"402":2,"426":2,"645":1,"646":1,"647":1}}],["lookups",{"2":{"305":2}}],["looks",{"2":{"84":1,"365":1}}],["looking",{"2":{"48":1,"79":2,"91":1,"169":1,"236":1,"246":1,"385":1,"396":1,"652":1,"653":1}}],["look",{"2":{"46":1,"90":1,"102":1,"116":2,"121":2,"131":1,"133":1,"153":2,"170":4,"172":2,"211":1,"275":1,"276":1,"280":2,"285":2,"355":1,"362":1,"365":1,"368":1,"375":1,"384":1,"385":1,"386":1,"450":1,"455":1,"459":1,"564":1,"584":2,"605":1,"657":1,"658":1,"703":1}}],["loop",{"2":{"30":1,"220":1}}],["log=debug",{"2":{"224":2}}],["log",{"2":{"156":2,"308":1,"396":1,"400":2,"545":1,"564":2,"604":1,"605":2,"639":1,"682":2,"783":2,"789":3}}],["logging",{"2":{"93":1,"305":1}}],["logged",{"2":{"88":1}}],["logsbloom",{"2":{"121":2,"285":2,"384":2}}],["logs",{"0":{"541":1},"2":{"71":1,"91":1,"121":2,"219":1,"220":1,"285":2,"387":1,"541":7,"564":2,"599":1,"605":1,"637":1,"774":1,"776":1,"777":1,"778":1,"783":2,"789":2}}],["logos",{"2":{"47":1}}],["logo",{"2":{"44":1,"47":1,"58":1,"433":1}}],["logic",{"2":{"107":2,"110":1,"135":1,"188":1,"223":1,"240":2,"265":1,"455":1,"520":1}}],["logical",{"2":{"43":1}}],["login",{"2":{"78":1,"319":1,"545":1}}],["logistics",{"0":{"39":1,"63":1},"1":{"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1},"2":{"36":1,"39":1,"43":1}}],["lost",{"2":{"602":1,"656":1}}],["lose",{"2":{"551":1,"578":1}}],["loses",{"2":{"24":1}}],["loss",{"2":{"31":2}}],["lowers",{"2":{"84":1}}],["lower",{"2":{"84":2}}],["low",{"2":{"27":1,"146":1,"287":1,"336":1,"428":1,"432":2,"434":1}}],["lot",{"2":{"27":1,"39":1,"40":1,"57":1,"208":1}}],["longer",{"2":{"84":1,"335":1,"392":1,"436":1,"452":1,"497":1,"547":1}}],["long",{"2":{"23":1,"34":1,"85":1,"450":1,"480":1,"481":1,"484":1}}],["love",{"2":{"2":1,"48":1}}],["ll",{"2":{"0":1,"41":1,"56":1,"63":1,"65":1,"68":1,"69":1,"71":1,"76":1,"82":1,"84":1,"85":1,"92":1,"107":1,"120":1,"121":1,"275":1,"276":1,"283":2,"284":1,"285":1,"295":1,"302":1,"308":2,"310":1,"312":1,"313":2,"314":1,"315":2,"317":1,"358":1,"384":1,"394":4,"404":1,"413":1,"433":1,"434":1,"436":1,"568":1,"597":1,"639":1,"649":1,"657":1,"699":1,"789":1,"794":1}}],["wget",{"2":{"644":2,"663":10,"664":8}}],["w",{"2":{"223":2,"402":4,"403":2}}],["wrong",{"0":{"604":1,"649":1,"794":1},"2":{"604":2,"649":2,"794":2}}],["wrapped",{"2":{"224":1,"708":1}}],["wrappers",{"2":{"172":2}}],["wrapper",{"2":{"153":4,"170":2,"220":2,"223":4,"224":2}}],["wrapping",{"0":{"404":1},"2":{"135":1}}],["wraps",{"2":{"135":2,"223":1}}],["writing",{"2":{"135":2,"143":1}}],["write",{"2":{"39":1,"121":1,"276":1,"285":1,"394":1,"561":2,"758":1}}],["written",{"2":{"13":1,"31":2,"230":1,"337":2,"664":1}}],["wsl",{"2":{"661":2}}],["ws",{"2":{"119":1,"249":1,"322":2,"404":2,"407":2,"682":4,"731":2}}],["wss",{"0":{"249":1},"2":{"88":6,"89":6,"249":1,"731":3}}],["won",{"2":{"88":1,"89":1,"192":1,"217":1,"390":1,"763":1}}],["wonderful",{"2":{"39":1}}],["worry",{"2":{"107":1,"653":1}}],["world",{"2":{"49":1,"323":4,"394":1,"408":4,"425":4,"719":1}}],["words",{"2":{"129":1,"183":1,"225":1,"443":1,"456":1}}],["word",{"2":{"42":1,"45":1}}],["workshop",{"0":{"59":1,"60":1,"61":1,"62":1}}],["workshops",{"2":{"40":1,"43":1}}],["works",{"0":{"239":1},"2":{"41":2,"94":1,"418":1,"420":1,"421":1,"439":1,"483":1,"498":1,"565":1,"590":1}}],["working",{"0":{"697":1,"698":1},"2":{"36":1,"40":2,"268":2,"300":1,"306":1,"310":1,"338":1,"544":1,"609":1,"697":1}}],["work",{"2":{"22":1,"24":1,"41":1,"131":1,"143":1,"178":1,"260":1,"333":1,"396":1,"453":1,"513":1,"677":1}}],["wouldn",{"2":{"441":1}}],["would",{"2":{"40":1,"45":1,"48":5,"102":1,"131":1,"133":1,"135":9,"136":1,"139":3,"192":2,"194":1,"200":2,"203":1,"212":1,"234":1,"235":1,"320":1,"322":1,"346":1,"351":1,"356":1,"362":1,"375":1,"388":1,"407":1,"413":1,"432":1,"508":1,"536":1,"554":1,"564":1,"584":1,"594":1,"627":1,"639":1,"653":1,"655":2,"675":1,"725":1,"740":2}}],["www",{"2":{"17":3,"509":1,"726":1,"744":1}}],["walkthrough",{"0":{"659":1},"1":{"660":1}}],["wallet=",{"2":{"783":2,"789":2}}],["wallets",{"0":{"356":1,"683":1,"714":1},"1":{"715":1},"2":{"310":1,"312":4,"431":1,"460":1,"501":1,"578":1,"683":3}}],["wallet",{"0":{"266":1,"431":1,"461":1,"462":1,"467":1,"471":1,"472":1,"531":1,"569":1,"576":1,"578":1,"579":1,"782":1},"1":{"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"432":1,"433":1,"434":1,"463":1,"464":1,"465":1,"466":1,"468":1,"469":1,"470":1,"472":1,"473":1,"474":1,"475":1,"577":1,"578":1,"579":1},"2":{"31":2,"33":4,"69":1,"71":1,"72":1,"76":1,"78":1,"80":1,"83":3,"85":2,"211":6,"266":1,"284":1,"291":1,"303":1,"310":1,"312":1,"313":4,"314":1,"317":1,"319":1,"342":1,"344":1,"346":1,"356":5,"432":5,"433":2,"434":2,"491":2,"492":1,"527":1,"535":1,"536":6,"537":2,"538":2,"539":4,"540":2,"542":1,"576":1,"578":3,"579":2,"633":1,"673":1,"684":1,"714":1,"715":2,"782":1,"783":8,"789":4}}],["wagmiclient",{"2":{"312":4}}],["wagmiconfig",{"2":{"312":6}}],["wagmi",{"2":{"310":1,"311":2,"312":4,"313":2}}],["wanting",{"2":{"344":1}}],["want",{"2":{"211":9,"212":1,"214":1,"217":1,"219":1,"222":1,"228":1,"255":1,"261":1,"264":1,"269":1,"309":1,"312":2,"326":2,"346":1,"358":2,"410":2,"421":1,"426":4,"433":1,"439":1,"447":1,"536":1,"544":2,"578":1,"590":1,"618":2,"627":1,"633":2,"634":2,"639":1,"682":1,"692":2,"696":1,"701":1,"740":1,"763":1,"771":1,"783":2,"789":2}}],["wantedby=multi",{"2":{"774":2,"776":2,"777":2,"778":2}}],["wanted",{"2":{"156":2,"564":2,"783":2,"789":2}}],["wants",{"2":{"145":1,"696":1}}],["waiting",{"2":{"91":6,"135":1,"137":1,"139":3,"180":2,"396":1,"426":2}}],["wait",{"2":{"89":1,"107":1,"139":1,"172":2,"220":1,"313":2,"396":1,"421":1,"426":2,"469":1,"579":1}}],["waive",{"2":{"31":1}}],["watchopts",{"2":{"171":2}}],["watchdatacommitmentstored",{"2":{"171":3}}],["watch",{"2":{"46":1}}],["watchlist",{"2":{"31":1}}],["water",{"2":{"41":2}}],["way",{"2":{"34":1,"44":1,"82":1,"108":1,"149":1,"175":1,"178":2,"179":1,"180":1,"181":1,"192":2,"200":1,"208":1,"212":2,"213":1,"312":1,"335":1,"340":1,"345":1,"394":1,"446":1,"449":1,"505":1,"536":1,"545":1,"561":2,"578":1,"582":1,"610":1,"653":2,"708":1}}],["ways",{"2":{"7":1,"174":1,"241":1,"263":1,"337":1,"341":1,"422":1,"739":1,"754":1,"755":1,"767":1}}],["warn",{"2":{"547":1}}],["warning",{"0":{"14":1},"2":{"13":1,"14":1,"89":1,"161":1,"162":1,"242":1,"338":1,"346":1,"351":1,"505":1,"510":1,"514":1,"594":1,"606":1,"726":1,"728":1,"744":1,"751":1}}],["warehouse",{"2":{"509":1,"726":1,"744":1}}],["warm",{"2":{"45":1}}],["warranties",{"2":{"34":1}}],["wasm",{"2":{"94":1}}],["was",{"0":{"153":1},"2":{"13":1,"34":1,"79":1,"81":1,"91":5,"109":1,"130":1,"131":5,"133":1,"137":1,"139":1,"145":1,"146":1,"148":2,"153":6,"163":6,"164":1,"169":7,"172":2,"173":1,"177":2,"183":1,"189":1,"195":1,"196":1,"200":1,"203":1,"213":2,"214":1,"217":1,"223":1,"224":2,"238":1,"261":1,"275":1,"310":1,"323":3,"337":1,"363":1,"365":2,"366":1,"402":1,"408":3,"425":2,"426":4,"436":1,"453":1,"458":1,"459":1,"557":1,"559":1,"581":1,"599":1,"638":1,"649":1,"664":1,"684":1,"710":1,"774":1,"776":1,"777":1,"778":1,"783":1,"794":1}}],["width",{"2":{"312":2,"313":8}}],["windows",{"2":{"654":1,"661":2}}],["window",{"2":{"275":1,"276":1,"313":6,"396":1,"428":1,"429":1,"430":1,"432":8,"480":5,"551":1,"676":1}}],["wise",{"2":{"458":1}}],["wish",{"2":{"225":1,"237":1,"417":1,"421":1,"481":1}}],["wisdom",{"2":{"56":1}}],["wiki",{"2":{"9":1}}],["willingness",{"2":{"421":1}}],["willing",{"2":{"342":1,"419":1}}],["will",{"2":{"9":2,"11":1,"12":1,"21":2,"22":2,"23":3,"24":2,"26":2,"27":1,"28":1,"29":1,"31":6,"33":1,"34":8,"40":1,"41":1,"42":2,"43":1,"44":1,"47":1,"48":3,"50":1,"52":1,"53":2,"64":2,"66":1,"71":1,"72":2,"76":1,"77":1,"79":2,"82":1,"83":2,"84":1,"85":2,"86":1,"88":3,"89":3,"90":3,"91":1,"102":1,"103":2,"107":5,"113":1,"119":3,"120":2,"121":2,"122":2,"126":1,"133":1,"134":1,"135":3,"139":1,"145":1,"148":2,"149":1,"150":1,"153":2,"154":1,"161":1,"162":1,"163":5,"165":1,"170":2,"172":4,"174":1,"175":2,"177":1,"178":4,"180":1,"181":1,"183":4,"184":2,"192":1,"195":1,"196":1,"197":1,"199":1,"200":2,"202":1,"203":3,"209":1,"211":2,"212":2,"213":5,"217":1,"219":3,"223":1,"224":3,"225":1,"228":2,"230":1,"238":4,"243":3,"255":1,"263":2,"266":2,"268":1,"269":4,"275":1,"276":2,"277":1,"284":2,"285":2,"286":1,"291":4,"292":1,"293":3,"294":1,"297":2,"300":1,"301":2,"302":1,"308":3,"309":3,"313":4,"315":1,"317":2,"318":1,"321":1,"322":1,"324":2,"325":2,"335":3,"339":1,"346":1,"348":1,"351":1,"354":1,"355":1,"356":2,"357":2,"358":1,"359":1,"360":3,"361":1,"362":1,"363":5,"365":6,"366":3,"368":1,"369":1,"372":3,"375":1,"380":3,"384":1,"385":1,"386":1,"387":1,"388":1,"390":1,"391":1,"392":1,"396":4,"397":1,"399":1,"400":2,"401":2,"402":3,"404":3,"406":1,"407":1,"409":4,"415":2,"416":1,"421":3,"426":4,"428":1,"432":4,"433":1,"434":1,"436":2,"437":1,"439":1,"440":1,"446":1,"447":1,"459":1,"460":1,"463":1,"465":1,"466":1,"470":1,"475":1,"478":1,"479":1,"480":5,"481":2,"483":1,"488":1,"489":2,"501":1,"505":2,"508":1,"512":1,"513":2,"519":1,"525":1,"526":1,"527":2,"533":3,"536":1,"545":6,"549":2,"551":8,"553":1,"557":3,"560":1,"561":1,"564":2,"565":1,"566":1,"567":2,"571":3,"572":1,"573":1,"576":1,"580":1,"581":4,"582":3,"584":3,"585":1,"586":3,"590":3,"592":2,"594":1,"597":1,"599":2,"600":1,"602":1,"605":1,"606":2,"609":2,"610":3,"615":1,"621":1,"627":1,"629":1,"633":1,"634":3,"636":2,"641":1,"646":2,"647":2,"656":4,"657":1,"658":1,"662":1,"664":1,"665":1,"673":2,"676":1,"677":1,"678":1,"679":6,"682":1,"683":1,"691":1,"693":1,"694":1,"695":1,"698":2,"699":1,"702":3,"703":3,"707":2,"712":2,"714":2,"720":2,"725":1,"733":1,"734":1,"740":1,"745":1,"746":1,"763":1,"765":1,"769":1,"771":2,"774":1,"776":1,"777":2,"778":3,"779":1,"783":1,"789":2}}],["withheld",{"2":{"437":1}}],["withhold",{"2":{"437":1,"459":1}}],["withholding",{"2":{"437":1}}],["withtransportcredentials",{"2":{"426":2}}],["withcancel",{"2":{"401":2,"402":2,"404":2}}],["withfeegranteraddress",{"2":{"323":1}}],["withsigneraddress",{"2":{"323":1}}],["withkeyname",{"2":{"323":1}}],["withgas",{"2":{"323":1}}],["withgasprice",{"2":{"323":2}}],["withdraw",{"0":{"71":1},"2":{"538":2}}],["withdrawalsroot",{"2":{"384":2}}],["withdrawals",{"2":{"84":1}}],["withdrawal",{"0":{"70":1,"72":1},"1":{"71":1,"72":1},"2":{"24":1,"66":2,"71":2,"72":2}}],["within",{"2":{"10":1,"16":1,"21":1,"24":4,"33":2,"34":1,"40":1,"43":1,"50":1,"65":1,"84":1,"358":1,"428":1,"429":1,"477":1,"480":3,"661":1}}],["without",{"2":{"8":1,"31":1,"34":1,"88":1,"107":1,"146":1,"179":1,"263":1,"289":1,"293":2,"297":1,"313":2,"322":1,"361":1,"390":1,"407":1,"438":1,"439":1,"449":1,"457":1,"481":1,"489":1,"564":1,"653":1,"655":1,"735":1}}],["with",{"0":{"76":1,"78":1,"92":1,"103":1,"104":1,"121":1,"123":1,"132":1,"238":1,"240":1,"245":1,"266":1,"285":1,"319":1,"364":1,"388":1,"431":1,"432":1,"462":1,"467":1,"471":1,"511":1,"528":1,"529":1,"541":1,"553":1,"576":1,"656":1,"674":1,"675":1,"716":1,"717":1,"772":1,"774":1,"788":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"239":1,"240":1,"241":1,"242":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"389":1,"390":1,"391":1,"392":1,"393":1,"432":1,"433":1,"434":1,"463":1,"464":1,"465":1,"466":1,"468":1,"469":1,"470":1,"472":1,"473":1,"474":1,"475":1,"512":1,"513":1,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1,"577":1,"578":1,"579":1,"657":1,"658":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1},"2":{"1":1,"2":1,"3":2,"5":1,"14":3,"15":3,"24":2,"25":1,"26":1,"27":2,"30":1,"31":5,"32":6,"33":4,"34":18,"36":2,"37":1,"38":2,"40":5,"42":5,"43":7,"44":2,"45":2,"46":5,"47":3,"48":1,"49":1,"50":1,"53":1,"54":2,"55":1,"61":1,"63":1,"65":1,"76":4,"77":3,"78":1,"79":1,"80":1,"82":1,"84":2,"85":1,"88":2,"89":2,"91":6,"94":5,"101":1,"102":2,"105":1,"106":1,"107":3,"108":2,"109":2,"110":1,"115":2,"116":2,"117":1,"120":2,"121":1,"131":3,"135":3,"139":1,"143":1,"145":1,"148":1,"151":1,"156":1,"159":1,"161":1,"165":2,"166":1,"167":1,"168":1,"169":6,"170":2,"172":2,"173":1,"174":1,"175":1,"181":1,"184":1,"187":1,"192":1,"211":1,"212":1,"217":1,"219":1,"223":1,"225":1,"226":1,"227":2,"228":1,"230":2,"234":1,"237":4,"238":2,"240":3,"242":1,"244":3,"245":1,"247":2,"249":1,"258":1,"261":1,"264":1,"265":2,"266":1,"269":1,"274":1,"275":3,"276":5,"279":2,"280":2,"281":1,"283":1,"284":2,"285":1,"287":2,"289":1,"290":2,"291":2,"292":1,"293":2,"294":1,"295":1,"297":1,"301":1,"305":2,"307":1,"308":3,"309":1,"310":1,"311":1,"312":1,"313":1,"315":2,"317":4,"318":3,"319":1,"320":1,"321":1,"323":2,"324":2,"325":2,"330":1,"332":1,"333":1,"336":2,"337":2,"339":5,"340":1,"341":2,"344":2,"345":1,"355":3,"356":4,"357":1,"358":5,"359":1,"360":3,"361":2,"362":2,"363":2,"365":1,"368":1,"375":1,"380":2,"382":1,"384":1,"390":1,"392":4,"393":1,"394":2,"396":2,"397":2,"400":2,"401":5,"402":6,"404":6,"405":1,"406":1,"408":2,"413":1,"415":1,"416":1,"419":1,"421":2,"428":1,"437":1,"441":1,"442":1,"443":1,"448":1,"450":2,"451":1,"452":6,"453":2,"455":1,"456":1,"457":1,"458":4,"459":3,"463":1,"477":1,"478":1,"483":1,"490":1,"498":1,"502":1,"504":1,"505":1,"510":3,"513":4,"515":1,"520":3,"526":2,"527":2,"529":2,"530":2,"536":6,"538":1,"539":2,"540":1,"541":1,"545":5,"547":1,"548":1,"549":2,"551":1,"557":1,"564":2,"574":1,"579":1,"580":1,"581":1,"582":2,"583":1,"584":2,"586":1,"593":1,"594":1,"597":3,"602":1,"603":1,"606":2,"609":2,"610":2,"621":1,"627":1,"629":1,"633":1,"639":1,"643":1,"649":1,"651":3,"655":1,"658":1,"661":1,"673":4,"675":1,"677":3,"678":1,"681":1,"683":1,"690":1,"692":2,"696":1,"699":1,"701":3,"702":2,"703":2,"705":4,"706":1,"708":1,"713":2,"714":3,"717":1,"718":1,"720":2,"724":1,"726":1,"728":1,"734":2,"744":1,"747":1,"748":2,"749":1,"751":1,"765":1,"768":1,"769":1,"784":1,"788":2,"789":1,"794":1}}],["whole",{"2":{"450":1}}],["whom",{"2":{"160":1}}],["whose",{"2":{"156":1,"211":2}}],["who",{"0":{"447":1},"2":{"22":1,"24":1,"31":1,"34":1,"43":1,"45":2,"46":3,"65":1,"245":1,"342":1,"346":1,"362":1,"696":1,"703":1,"763":1}}],["whitelist",{"0":{"215":1},"2":{"214":1,"215":3}}],["whitelisting",{"0":{"214":1},"2":{"211":1,"214":2,"413":1}}],["whitelisted",{"2":{"211":1}}],["whiteboard",{"2":{"40":1}}],["whiteboards",{"2":{"36":1,"40":1}}],["white",{"2":{"34":1}}],["while",{"2":{"19":1,"41":1,"91":1,"116":1,"165":1,"174":1,"230":1,"237":1,"266":1,"280":1,"330":1,"335":1,"337":2,"375":1,"396":1,"409":2,"451":1,"456":1,"459":1,"481":1,"605":4,"720":1,"760":1,"770":1}}],["which",{"0":{"650":1},"1":{"651":1,"652":1},"2":{"8":1,"27":1,"30":3,"31":1,"34":3,"41":1,"47":1,"48":1,"76":1,"83":1,"84":3,"86":1,"88":2,"89":1,"90":1,"95":1,"102":1,"106":1,"107":1,"108":3,"109":3,"110":2,"131":1,"134":1,"135":2,"137":1,"146":2,"148":4,"150":1,"151":1,"156":1,"158":1,"160":1,"161":1,"163":2,"165":2,"166":1,"167":1,"169":5,"175":1,"177":1,"183":1,"188":1,"189":1,"193":1,"196":1,"200":1,"202":1,"203":1,"208":1,"211":3,"213":3,"214":1,"215":3,"220":2,"222":2,"223":3,"224":2,"227":1,"228":1,"230":2,"233":1,"234":1,"239":1,"243":1,"269":1,"275":1,"294":1,"312":2,"317":1,"323":1,"330":1,"337":1,"341":1,"345":1,"346":1,"355":1,"363":4,"365":4,"366":1,"368":1,"387":1,"402":2,"403":1,"418":1,"437":1,"445":1,"446":1,"456":1,"477":2,"481":1,"483":1,"499":1,"508":1,"525":1,"526":1,"527":1,"536":1,"545":2,"579":1,"581":1,"584":1,"590":1,"592":1,"636":1,"643":2,"646":2,"650":1,"652":1,"655":1,"665":1,"673":2,"677":2,"680":1,"681":1,"691":1,"703":2,"705":1,"706":1,"707":1,"713":2,"724":4,"725":1,"740":1,"748":3,"769":1,"771":1,"774":2,"776":2,"777":2,"778":2,"786":1,"791":1}}],["why",{"0":{"441":1,"446":1},"2":{"13":1,"27":1,"48":5,"65":1,"223":1,"677":1}}],["whenever",{"2":{"45":1,"287":1,"740":1}}],["when",{"2":{"9":1,"10":1,"42":1,"48":1,"50":1,"65":1,"88":1,"89":2,"107":2,"146":1,"148":1,"153":2,"166":1,"170":2,"172":2,"178":1,"184":1,"188":1,"195":1,"196":2,"214":1,"223":1,"228":1,"275":1,"295":1,"297":1,"305":2,"308":1,"313":3,"315":1,"322":1,"329":1,"337":1,"356":1,"358":1,"359":1,"392":1,"407":1,"419":1,"420":1,"436":2,"437":1,"453":1,"489":1,"536":1,"544":2,"545":2,"583":1,"589":1,"593":1,"594":1,"597":1,"599":1,"600":1,"601":1,"605":2,"627":2,"644":1,"646":2,"657":1,"678":1,"702":1,"715":1}}],["whereas",{"2":{"84":1}}],["where",{"0":{"445":1},"2":{"8":1,"107":2,"108":1,"136":1,"156":1,"163":2,"167":1,"210":1,"219":1,"220":1,"354":1,"356":1,"358":1,"394":1,"396":1,"413":1,"415":1,"417":1,"418":1,"419":1,"428":1,"441":1,"452":1,"458":1,"466":1,"470":1,"475":1,"480":1,"481":3,"515":1,"520":1,"531":1,"573":2,"601":1,"606":1,"676":1,"678":1,"715":1,"719":1,"751":1}}],["whether",{"2":{"2":1,"34":1,"42":1,"428":1,"432":3,"437":1,"443":1,"449":1,"647":1}}],["whatever",{"0":{"255":1},"1":{"256":1,"257":1,"258":1,"259":1,"260":1,"261":1,"262":1,"263":1,"264":1,"265":1},"2":{"301":1,"329":1,"578":1}}],["what",{"0":{"230":1,"236":1,"237":1,"260":1,"261":1,"436":1,"437":1,"439":1,"440":1,"442":1,"443":1,"444":1,"448":1},"1":{"231":1},"2":{"8":1,"22":1,"48":4,"59":1,"60":1,"61":1,"71":1,"85":1,"117":1,"122":1,"133":1,"136":1,"139":1,"183":1,"220":2,"255":1,"281":1,"286":1,"302":1,"320":1,"362":1,"365":1,"375":1,"404":2,"479":1,"504":1,"582":1,"586":1,"610":1,"664":1,"677":1}}],["went",{"2":{"783":1}}],["we+s5gft6g944xbkvvygqb9oy+u",{"2":{"561":2,"562":2}}],["week",{"2":{"515":1,"751":1}}],["weeks",{"2":{"45":1,"217":1,"635":1,"636":1}}],["weak",{"2":{"443":1,"637":1}}],["weth",{"2":{"91":2}}],["webhook",{"2":{"547":1}}],["web",{"0":{"516":1},"2":{"310":1,"516":1,"545":1}}],["websocket",{"0":{"731":1},"2":{"88":5,"145":2,"152":2,"153":2,"682":4,"731":3}}],["websites",{"2":{"738":1,"752":1}}],["website",{"2":{"27":1,"46":1,"88":1,"432":2}}],["web3provider",{"2":{"313":4}}],["web3",{"2":{"48":1,"50":1,"301":1}}],["were",{"2":{"17":1,"31":1,"34":2,"131":5,"163":6,"164":1,"225":1,"237":1,"405":1,"489":1}}],["well",{"2":{"14":1,"30":1,"40":1,"41":2,"65":2,"107":1,"108":1,"211":1,"265":1,"308":1,"333":1,"342":1,"479":1,"673":1,"681":1}}],["welcoming",{"2":{"7":1,"40":1,"52":1}}],["welcome",{"2":{"0":1,"21":1,"30":1,"37":1,"47":2,"48":1,"49":1,"54":1,"57":1,"113":1,"394":1,"719":1}}],["we",{"2":{"2":1,"4":1,"7":2,"24":1,"30":2,"31":5,"33":9,"40":1,"48":8,"52":2,"65":2,"83":2,"84":1,"88":1,"103":1,"107":1,"117":1,"120":2,"121":2,"122":1,"126":2,"131":1,"134":4,"135":3,"136":1,"139":4,"146":1,"148":6,"150":1,"153":2,"154":1,"163":5,"164":2,"165":6,"168":1,"170":2,"172":4,"173":1,"178":1,"181":1,"182":1,"183":4,"184":5,"195":1,"211":4,"213":4,"214":1,"217":2,"218":2,"219":10,"220":1,"223":1,"224":1,"264":1,"268":1,"275":1,"276":2,"277":1,"281":1,"283":1,"284":3,"285":2,"301":1,"302":1,"305":5,"306":1,"307":2,"308":7,"309":7,"310":2,"311":1,"312":4,"313":8,"314":3,"315":2,"324":1,"325":1,"329":1,"330":2,"331":1,"332":1,"334":1,"335":1,"338":1,"348":1,"358":1,"363":6,"365":2,"368":1,"372":1,"380":1,"384":1,"392":2,"394":1,"396":3,"400":4,"401":8,"402":26,"403":1,"404":11,"409":3,"413":1,"421":1,"426":12,"432":5,"479":1,"504":1,"536":2,"545":1,"547":2,"553":1,"557":1,"567":1,"568":2,"571":4,"576":1,"578":1,"586":1,"590":1,"597":1,"611":2,"616":1,"641":1,"657":2,"664":1,"682":1,"683":2,"685":1,"687":1,"688":2,"698":2,"699":1,"720":1,"740":1,"746":1,"768":1,"771":1,"777":1}}],["dteam",{"2":{"728":1,"729":1,"730":1,"731":1,"734":1,"737":1,"746":2,"747":1,"748":1,"749":1,"753":1}}],["dl",{"2":{"664":8}}],["dbbackend",{"2":{"646":1}}],["d6",{"2":{"453":1}}],["d5",{"2":{"453":2}}],["d4",{"2":{"453":2}}],["d3",{"2":{"453":1}}],["dns4",{"2":{"510":4}}],["dns",{"2":{"380":1}}],["d85c907ce660878a8203ac74baa147ccc1f87114b45b568b72ad207b62afe45e",{"2":{"372":2}}],["dynamic",{"2":{"264":1,"418":1,"419":1}}],["d7wrs",{"2":{"156":2}}],["dcproof",{"2":{"152":2,"153":2}}],["dfcelestia",{"2":{"102":1}}],["drafted",{"2":{"723":1}}],["drawing",{"2":{"56":1}}],["drop",{"2":{"421":1,"488":1}}],["dropped",{"2":{"421":1}}],["dropdown",{"2":{"68":1,"314":1}}],["drift",{"2":{"682":4}}],["drinks",{"2":{"41":4}}],["driver",{"2":{"33":1}}],["d",{"2":{"31":1,"34":1,"47":2,"89":1,"90":1,"139":4,"313":18,"323":2,"324":4,"325":4,"375":1,"381":1,"386":2,"402":4,"425":2,"488":1,"489":2,"553":1,"558":1,"564":2,"638":6}}],["daemon",{"2":{"596":1,"605":3,"772":1,"774":6,"776":3,"777":3,"778":4,"784":1}}],["darwin",{"2":{"582":1,"610":1,"664":12}}],["daring",{"2":{"561":2}}],["dah",{"2":{"372":2,"373":2,"378":2}}],["dac",{"2":{"234":1,"235":1}}],["dacs",{"0":{"232":1},"1":{"233":1,"234":1,"235":1},"2":{"233":1,"235":2}}],["daverifier",{"0":{"163":1,"172":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1},"2":{"131":3,"163":1,"172":11,"183":1}}],["daser",{"2":{"606":1}}],["das",{"0":{"450":1},"1":{"451":1,"452":1},"2":{"108":1,"230":1,"374":2,"439":1,"449":2,"450":2,"451":4,"452":1,"459":4,"707":1,"708":1,"778":1}}],["dashboard",{"2":{"33":1,"463":2,"464":1,"466":1,"470":1,"513":1,"545":5,"590":1,"734":2}}],["dashboards",{"2":{"24":1,"483":1,"545":1,"789":1}}],["da",{"0":{"104":1,"107":1,"229":1,"454":1,"511":1,"512":1,"513":1,"733":1,"734":1,"735":1,"743":1,"745":1,"746":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1,"455":1,"512":1,"513":1,"736":1,"744":1,"745":1,"746":1},"2":{"89":3,"94":1,"103":1,"106":1,"107":1,"110":1,"111":1,"133":1,"135":4,"136":1,"139":1,"187":2,"195":1,"230":2,"237":3,"245":1,"267":1,"287":1,"290":1,"291":4,"329":1,"336":1,"337":8,"339":1,"342":2,"344":2,"346":1,"350":1,"386":2,"391":1,"392":1,"393":1,"449":3,"451":2,"453":4,"455":3,"456":6,"459":5,"510":5,"512":1,"513":5,"520":1,"606":1,"615":1,"679":1,"707":1,"708":1,"733":1,"734":7,"735":1,"745":1,"746":2,"750":8,"769":2,"770":1}}],["dao",{"2":{"84":1}}],["dappforge",{"2":{"304":1}}],["dappsys",{"2":{"305":1}}],["dapps",{"2":{"301":1}}],["dapp",{"0":{"73":1,"317":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"318":1,"319":1,"320":1},"2":{"122":1,"301":1,"304":3,"309":1,"314":1,"316":1,"339":1}}],["day",{"2":{"45":1,"480":2}}],["days",{"2":{"41":1,"480":2,"551":1}}],["damage",{"2":{"31":1}}],["dat2024",{"2":{"223":1}}],["dat",{"2":{"223":31}}],["datalen",{"2":{"181":2,"183":1}}],["datahash",{"2":{"153":2,"172":2}}],["datacommitmentstored",{"2":{"217":1,"228":1}}],["datacommitment",{"2":{"153":2,"170":2}}],["datasharelen",{"2":{"134":4}}],["datasharestart",{"2":{"134":4}}],["datarootinclusionproof",{"2":{"152":2,"153":2,"169":9,"172":10}}],["dataroot",{"2":{"127":4,"148":2,"153":2,"169":5,"172":2}}],["dataroottupleroot",{"2":{"150":1}}],["dataroottuples",{"2":{"128":5,"129":1}}],["dataroottuple",{"2":{"127":4,"128":2,"129":1,"131":1,"150":1,"153":2,"163":2,"169":7,"172":2}}],["dataavailabilityprovider",{"2":{"107":2}}],["data",{"0":{"128":1,"131":1,"136":1,"142":1,"150":1,"164":1,"171":1,"183":1,"184":1,"208":1,"225":1,"232":1,"326":1,"363":1,"365":1,"374":1,"385":1,"386":1,"410":1,"414":1,"435":1,"436":1,"437":1,"438":1,"439":1,"440":1,"442":1,"443":1,"444":2,"446":1,"447":1,"448":1,"449":1,"450":1,"452":1,"455":1,"459":1,"479":1,"480":1,"512":1,"513":1,"603":1,"631":1,"718":1,"732":1,"733":1,"734":1,"745":1,"746":1,"757":1,"775":1},"1":{"151":1,"152":1,"226":1,"227":1,"228":1,"233":1,"234":1,"235":1,"364":1,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"427":1,"436":1,"437":1,"438":1,"439":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"450":1,"451":2,"452":2,"453":1,"454":1,"455":1,"480":1,"481":1,"733":1,"734":1,"735":1,"736":1,"776":1,"777":1,"778":1},"2":{"27":1,"31":2,"43":1,"48":1,"59":1,"79":1,"83":5,"88":3,"89":1,"105":2,"107":10,"108":8,"109":5,"110":6,"127":5,"128":1,"129":1,"130":1,"131":8,"133":2,"134":31,"135":7,"136":7,"137":16,"139":10,"142":1,"145":1,"146":5,"148":9,"150":6,"151":2,"153":10,"154":3,"156":5,"158":1,"160":3,"161":2,"163":14,"164":2,"166":1,"167":1,"168":1,"169":30,"171":1,"172":14,"173":3,"174":4,"176":2,"177":8,"178":3,"179":2,"181":9,"182":1,"183":7,"184":19,"187":2,"188":7,"189":1,"191":2,"192":3,"195":2,"196":8,"199":1,"200":5,"203":5,"208":6,"223":9,"230":3,"233":2,"234":4,"235":2,"237":5,"238":2,"242":1,"245":2,"247":1,"261":3,"264":2,"287":2,"289":1,"299":1,"313":16,"326":1,"332":3,"333":1,"336":2,"337":14,"348":2,"350":1,"351":3,"354":1,"363":9,"365":10,"372":2,"380":4,"385":1,"388":1,"390":2,"394":3,"400":2,"401":2,"402":5,"404":5,"408":2,"410":1,"414":2,"423":2,"424":2,"426":8,"427":1,"436":11,"437":7,"438":7,"439":9,"440":2,"441":6,"442":4,"443":6,"444":4,"445":3,"446":9,"447":4,"448":6,"449":5,"450":11,"451":3,"452":11,"453":14,"455":5,"456":2,"457":6,"458":15,"459":9,"477":9,"479":7,"480":7,"481":12,"496":1,"497":1,"509":1,"510":1,"519":1,"520":3,"545":4,"564":2,"585":1,"586":1,"590":2,"600":2,"603":1,"604":1,"605":4,"610":1,"629":1,"631":2,"634":3,"635":2,"638":19,"641":1,"642":2,"651":3,"656":3,"665":1,"666":1,"707":2,"708":1,"720":1,"726":1,"735":5,"740":1,"744":1,"755":5,"769":2,"778":1,"783":2,"784":2,"789":2}}],["datetime",{"2":{"679":1}}],["date",{"2":{"26":1,"34":3,"36":1,"609":1}}],["duty",{"2":{"561":2}}],["dubbing",{"2":{"455":1}}],["dumps",{"2":{"268":2}}],["dummy",{"2":{"223":3}}],["dues",{"2":{"47":4}}],["due",{"2":{"24":1,"31":1,"65":1,"89":1,"287":1,"418":1,"421":1,"449":1,"456":1,"459":1,"592":1}}],["duration",{"2":{"23":3,"28":1}}],["during",{"0":{"37":1},"2":{"15":1,"23":1,"25":1,"34":1,"37":1,"41":1,"44":1,"169":1,"223":1,"237":1,"428":1,"440":1,"551":1,"582":1,"610":1,"618":1,"621":1,"639":1,"789":1}}],["double",{"2":{"551":2,"602":1}}],["dos",{"2":{"344":1}}],["domain",{"2":{"380":1}}],["dom",{"2":{"312":2}}],["doing",{"2":{"117":1,"139":1,"165":1,"261":1,"281":1,"312":1,"383":1,"582":1,"610":1}}],["downside",{"2":{"452":1}}],["down",{"2":{"268":1,"420":1,"433":1,"434":1,"615":1,"678":1}}],["downtime",{"2":{"110":1,"287":2,"551":1}}],["downloads",{"2":{"545":1,"609":1,"635":4,"638":1}}],["downloading",{"0":{"139":1},"2":{"139":1,"212":1,"438":1,"452":2,"663":1}}],["downloaded",{"0":{"222":1},"1":{"223":1,"224":1},"2":{"86":1,"87":1,"212":2,"220":1,"222":1,"223":1,"224":2,"437":1,"481":1,"635":1}}],["download",{"0":{"86":1},"2":{"85":1,"86":3,"135":1,"139":10,"212":2,"220":1,"223":16,"335":1,"351":1,"352":1,"399":1,"436":3,"438":2,"439":1,"449":2,"450":1,"451":3,"452":1,"453":1,"455":1,"481":1,"521":1,"554":1,"582":1,"610":1,"623":1,"627":7,"635":1,"664":1,"667":1,"679":3,"709":1,"746":2,"780":1}}],["do",{"0":{"438":1,"448":1},"2":{"30":3,"31":1,"32":1,"34":2,"48":1,"82":1,"133":1,"168":1,"208":1,"213":1,"219":1,"225":1,"261":1,"269":2,"275":1,"287":1,"307":1,"309":1,"312":1,"315":1,"332":1,"355":1,"356":1,"401":1,"417":1,"433":1,"438":1,"441":1,"479":1,"480":1,"481":1,"505":1,"510":1,"513":1,"526":1,"527":1,"545":2,"577":1,"590":1,"592":1,"634":1,"643":1,"661":1,"673":1,"676":1,"677":1,"679":1,"683":1,"685":1,"692":1,"697":1,"726":1,"728":1,"744":1,"746":1,"769":1,"778":1}}],["done",{"2":{"77":1,"91":10,"133":1,"136":1,"154":1,"164":1,"171":2,"184":2,"194":1,"318":1,"324":2,"325":2,"421":1,"429":1,"522":1,"536":1,"624":1,"668":1,"696":1,"765":1,"781":1}}],["don",{"2":{"27":1,"40":1,"45":1,"46":1,"71":1,"107":2,"211":2,"263":1,"264":1,"265":1,"346":1,"388":1,"426":2,"441":1,"446":1,"569":1,"639":1,"646":1,"685":1,"771":1,"789":1}}],["docker",{"0":{"273":1,"653":1},"1":{"274":1,"275":1,"276":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1},"2":{"80":2,"89":7,"90":2,"274":2,"275":3,"276":4,"387":2,"653":7,"654":4,"656":1,"657":2,"658":2}}],["docs",{"2":{"24":1,"88":1,"102":2,"141":1,"177":1,"238":1,"393":1,"427":1,"509":2,"547":1,"550":1,"582":2,"590":1,"610":2,"637":1,"726":2,"744":2}}],["documented",{"2":{"171":1,"217":2}}],["documents",{"2":{"102":2}}],["document",{"2":{"23":1,"38":1,"148":1,"174":1,"209":1,"312":2,"328":1,"412":1,"479":1,"549":6,"723":1}}],["documentation",{"0":{"0":1,"140":1,"327":1,"411":1},"1":{"1":1,"2":1,"3":1,"4":1,"141":1,"142":1,"143":1},"2":{"0":1,"1":1,"3":1,"4":1,"24":1,"31":3,"37":1,"79":1,"93":1,"130":1,"131":1,"135":2,"136":3,"172":1,"184":2,"191":1,"211":1,"212":1,"217":1,"221":1,"226":1,"239":1,"241":1,"243":2,"327":1,"331":1,"341":1,"411":1,"508":1,"531":2,"536":1,"544":2,"574":1,"725":1}}],["doesn",{"0":{"446":1},"2":{"145":1,"183":1,"208":1,"265":1,"359":1,"382":1,"665":1,"681":1}}],["does",{"0":{"445":1},"2":{"23":1,"27":1,"30":1,"34":3,"108":1,"210":1,"211":1,"294":1,"295":2,"417":1,"419":1,"421":1,"452":1,"458":1,"504":1,"514":1,"557":1,"661":1,"678":1,"748":1,"751":1,"755":1}}],["dir",{"2":{"597":3}}],["direct",{"2":{"510":2,"513":1,"547":1}}],["directories",{"2":{"481":1}}],["directory",{"0":{"3":1,"557":1,"697":1,"698":1},"2":{"68":1,"75":1,"87":1,"92":1,"115":1,"116":2,"126":1,"268":2,"269":4,"276":5,"279":1,"280":2,"305":1,"309":1,"310":3,"311":1,"317":1,"356":2,"359":1,"390":1,"399":1,"400":1,"528":1,"542":1,"556":1,"557":4,"559":1,"581":1,"604":1,"609":1,"635":1,"638":1,"656":4,"664":1,"674":1,"697":2,"703":3,"714":2,"716":1}}],["directly",{"2":{"135":1,"139":2,"228":1,"234":1,"332":1,"361":1,"417":1,"419":1,"426":2,"432":1}}],["directed",{"2":{"34":1,"673":1,"713":1}}],["dimensional",{"2":{"450":1,"452":4,"455":1,"458":1}}],["digest",{"2":{"165":9,"172":4,"223":2}}],["digital",{"2":{"8":1,"330":1}}],["dial",{"2":{"153":2,"170":2,"171":2,"172":2,"426":2,"601":2,"644":1}}],["diagram",{"2":{"148":1,"239":1,"484":1}}],["diagrams",{"2":{"3":1,"146":1}}],["did",{"2":{"48":2,"220":2}}],["difficulty",{"2":{"40":1,"42":1,"384":2}}],["difference",{"0":{"444":1},"2":{"102":1,"139":1,"184":1,"192":2,"203":1}}],["different",{"2":{"5":1,"39":1,"64":1,"76":1,"88":1,"89":1,"131":1,"139":1,"173":1,"182":2,"188":1,"191":1,"195":1,"206":1,"211":5,"225":3,"238":1,"241":1,"250":1,"255":1,"317":1,"344":1,"396":1,"405":1,"421":1,"445":2,"456":1,"489":1,"508":1,"536":1,"545":1,"571":1,"593":2,"597":2,"637":1,"644":1,"725":1,"755":1,"771":1}}],["differing",{"2":{"8":1}}],["dividing",{"2":{"417":1}}],["divided",{"2":{"23":1,"26":1}}],["div",{"2":{"312":4,"313":36,"432":4}}],["dive",{"0":{"383":1},"1":{"384":1,"385":1,"386":1,"387":1},"2":{"383":1}}],["dives",{"2":{"48":1,"59":1}}],["diverse",{"2":{"7":1}}],["disk",{"2":{"352":1,"521":1,"546":1,"623":1,"647":2,"667":1,"709":1,"757":1,"758":1,"780":1}}],["disruptions",{"2":{"287":1}}],["disruptive",{"2":{"19":1}}],["disables",{"2":{"589":1,"646":1}}],["disable",{"2":{"372":2,"589":2}}],["disabled",{"2":{"215":1,"401":2,"402":2,"404":2}}],["disability",{"2":{"7":1}}],["distinguish",{"2":{"84":1}}],["distributor",{"2":{"34":1}}],["distributors",{"2":{"34":1}}],["distributing",{"2":{"34":1}}],["distribution",{"2":{"34":2,"330":1,"514":1,"537":2,"538":2,"751":1}}],["distributed",{"2":{"456":1}}],["distribute",{"2":{"22":1}}],["disputes",{"2":{"84":1,"456":1}}],["dispute",{"2":{"84":1,"261":1}}],["displayed",{"2":{"533":1}}],["displaydenom",{"2":{"501":1}}],["displaying",{"2":{"37":1}}],["display",{"0":{"501":1},"2":{"33":1,"84":1,"313":8,"365":1}}],["disparagement",{"2":{"16":1}}],["disqualify",{"2":{"24":1,"31":1}}],["discard",{"0":{"647":1},"2":{"107":1,"109":1,"647":1}}],["disclaimer",{"2":{"71":1}}],["disclosure",{"2":{"34":1}}],["discussed",{"2":{"180":1}}],["discussion",{"2":{"43":2}}],["discussions",{"2":{"37":1,"50":1}}],["discuss",{"2":{"43":1,"46":1,"57":1,"195":1,"479":1}}],["discover",{"2":{"48":1}}],["discovering",{"2":{"43":1,"637":1}}],["discounts",{"2":{"40":1}}],["discord",{"0":{"55":1,"515":1},"2":{"11":1,"27":1,"45":2,"53":3,"54":1,"55":2,"316":1,"355":1,"356":2,"515":2,"579":1,"683":3,"715":1,"739":1,"751":2,"754":1,"767":2}}],["discretionary",{"2":{"30":1}}],["discretion",{"2":{"25":1,"30":1,"31":1,"34":1}}],["discrepancies",{"2":{"4":1}}],["debug",{"2":{"530":2,"649":4,"794":4}}],["debugging",{"2":{"90":1,"530":2}}],["denoted",{"2":{"458":2}}],["denominator",{"2":{"682":4}}],["denomination",{"0":{"502":1,"503":1},"2":{"502":2}}],["denominations",{"0":{"500":1},"1":{"501":1,"502":1,"503":1}}],["denominated",{"2":{"496":1}}],["denominate",{"2":{"85":1}}],["denom",{"2":{"295":2,"296":2,"300":2,"368":2,"369":2,"433":1,"434":1,"536":2,"564":4,"565":2,"567":4,"682":4}}],["deducting",{"2":{"417":1}}],["deducted",{"2":{"296":2,"300":2,"417":1}}],["dedicated",{"2":{"24":1,"37":1,"53":1,"244":1,"259":1}}],["demosubmitdata",{"2":{"426":2}}],["demo",{"0":{"133":1},"2":{"131":1,"133":1,"134":1,"135":4,"426":2}}],["demonstration",{"0":{"149":1,"597":1},"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},"2":{"355":1,"699":1}}],["demonstrating",{"2":{"8":1,"16":1}}],["demonstrate",{"2":{"44":1,"432":1}}],["degree",{"2":{"108":1,"109":1}}],["defer",{"2":{"171":4,"426":2}}],["defaultestimategas",{"2":{"419":1,"420":2,"426":2}}],["defaultgasprice",{"2":{"402":2,"425":2}}],["default",{"2":{"110":2,"211":3,"214":3,"215":2,"225":1,"264":1,"269":3,"294":1,"312":2,"313":2,"322":1,"323":2,"330":1,"355":1,"359":2,"361":1,"366":2,"368":1,"380":1,"390":2,"402":2,"407":1,"408":3,"416":1,"418":1,"421":1,"425":2,"432":2,"480":1,"512":1,"513":2,"526":1,"528":1,"530":2,"544":2,"545":6,"583":1,"584":1,"592":1,"593":1,"594":1,"596":1,"615":1,"616":1,"618":2,"621":1,"631":3,"634":4,"636":1,"643":1,"646":1,"647":1,"674":1,"682":4,"705":1,"716":1,"733":1,"734":1,"735":1,"745":1,"746":1,"747":1,"748":1,"749":1}}],["defaults",{"2":{"84":1,"355":1,"419":1,"526":1,"536":1,"646":1}}],["definitions",{"2":{"489":2}}],["defining",{"0":{"134":1},"2":{"135":1}}],["defines",{"2":{"789":1}}],["define",{"2":{"43":1,"134":2,"160":1,"184":1,"188":2,"196":1,"200":1,"203":1,"214":1,"264":1,"749":1}}],["defined",{"2":{"30":3,"31":1,"34":6,"84":1,"135":1,"151":1,"156":1,"165":1,"178":1,"180":1,"181":1,"203":1,"225":1,"489":2,"678":1,"789":1}}],["defi",{"2":{"43":1}}],["deeper",{"2":{"490":1}}],["deepen",{"2":{"65":1}}],["deep",{"0":{"383":1},"1":{"384":1,"385":1,"386":1,"387":1},"2":{"48":1,"59":1,"383":1}}],["deemed",{"2":{"13":1,"34":3}}],["deem",{"2":{"9":1,"12":1,"32":1}}],["decline",{"2":{"561":2}}],["declare",{"2":{"269":1,"275":1,"356":1,"527":1,"571":1,"593":1,"673":1}}],["decreasing",{"2":{"494":1}}],["decreases",{"2":{"484":1}}],["decentralised",{"0":{"485":1,"499":1},"1":{"486":1,"487":1},"2":{"499":2}}],["decentralized",{"2":{"235":1,"320":1}}],["decentralization",{"0":{"233":1},"2":{"738":1}}],["decouple",{"2":{"456":1}}],["decoupling",{"2":{"264":1,"265":1,"457":1}}],["decoding",{"2":{"166":1,"402":2,"682":4}}],["decode",{"2":{"208":1,"394":1,"402":2,"404":2,"405":1,"426":2}}],["decoder",{"2":{"202":1}}],["decoded",{"2":{"165":4,"365":1}}],["decodestring",{"2":{"157":2,"159":2,"402":2}}],["deciding",{"0":{"650":1},"1":{"651":1,"652":1}}],["decide",{"2":{"646":1}}],["decimal",{"2":{"219":1}}],["decimals",{"2":{"84":1,"312":2,"433":1,"434":1,"494":1}}],["decisions",{"2":{"9":1}}],["deck",{"2":{"44":2}}],["deal",{"2":{"459":1}}],["dealing",{"2":{"452":1}}],["dealer",{"2":{"34":1}}],["deadbeef",{"2":{"408":2}}],["deadline",{"2":{"24":2,"26":1}}],["derivation",{"2":{"682":4}}],["derivative",{"2":{"34":2}}],["derogatory",{"2":{"8":1}}],["descendants",{"2":{"453":2}}],["desc",{"2":{"382":2}}],["descriptor",{"2":{"605":1}}],["descriptors",{"2":{"605":1}}],["description=celestia",{"2":{"774":2,"776":2,"777":2,"778":2}}],["descriptions",{"2":{"84":2}}],["description",{"0":{"50":1},"2":{"42":1,"44":1,"47":3,"84":1,"418":1,"488":1,"536":6,"537":2,"583":1,"594":1,"678":1}}],["describing",{"2":{"455":1}}],["describes",{"2":{"134":2,"627":1,"680":1,"784":1}}],["described",{"2":{"21":1,"30":1,"31":1,"34":1,"166":1,"196":1,"458":3,"488":1,"489":1}}],["deserialization",{"0":{"200":1},"2":{"200":1,"203":1}}],["deserialize",{"2":{"199":1}}],["deserialized",{"2":{"107":1,"200":2}}],["desktop",{"2":{"89":1,"653":1,"654":1,"656":1}}],["destination",{"2":{"71":1,"579":1,"680":1}}],["desired",{"2":{"82":1,"239":1,"380":1,"469":1,"581":1,"609":1,"664":1}}],["desire",{"2":{"44":1}}],["designs",{"2":{"206":1}}],["design",{"0":{"590":1},"2":{"180":1,"235":1,"265":1,"545":1,"586":1,"590":1,"621":1}}],["designate",{"2":{"37":1}}],["designated",{"2":{"30":2}}],["designed",{"2":{"21":1,"49":1,"50":1,"57":1,"235":1,"343":1,"452":1,"740":2,"763":1}}],["delta",{"2":{"387":1}}],["deleting",{"2":{"532":2}}],["deleted",{"2":{"656":1}}],["delete",{"2":{"267":1,"532":2,"604":1,"641":1,"656":1}}],["delegate",{"0":{"539":1,"783":1},"2":{"539":3,"551":1,"783":5}}],["delegated",{"2":{"26":2,"263":1,"551":1,"565":4,"789":1}}],["delegating",{"2":{"490":1,"498":1}}],["delegation=1000000",{"2":{"789":3}}],["delegation=1",{"2":{"542":2}}],["delegations",{"2":{"21":1,"28":1}}],["delegation",{"0":{"18":1,"20":1},"1":{"19":1,"20":1,"21":2,"22":2,"23":2,"24":2,"25":2,"26":1,"27":1,"28":1,"29":1},"2":{"19":1,"23":4,"24":4,"25":1,"27":2,"483":2,"530":2}}],["delegators",{"2":{"483":1,"551":2}}],["delegator",{"2":{"460":1,"483":1}}],["delayedcelestia",{"2":{"571":1}}],["delayed",{"2":{"553":2,"564":7,"571":1}}],["delay",{"2":{"220":1,"682":4,"687":4}}],["delays",{"2":{"84":1}}],["delivering",{"2":{"65":1}}],["delivery",{"2":{"41":1}}],["delivers",{"2":{"19":1}}],["deprecated",{"2":{"161":1,"162":1,"172":2,"346":1,"351":1,"594":1}}],["depth",{"2":{"84":1,"484":1}}],["depositing",{"2":{"93":1}}],["deposited",{"2":{"91":2}}],["deposit",{"0":{"67":1,"69":1},"1":{"68":1,"69":1},"2":{"66":2,"69":2,"91":5,"536":5,"537":2}}],["dependent",{"2":{"143":1,"419":1,"639":1,"789":1}}],["dependency",{"0":{"389":1},"1":{"390":1},"2":{"126":2,"309":1,"322":1,"407":1}}],["dependencies",{"0":{"74":1,"278":1,"353":1,"395":1,"523":1,"625":1,"663":1,"669":1,"694":1},"1":{"354":1,"355":1,"356":1,"396":1,"397":1},"2":{"87":1,"311":1,"321":1,"353":1,"357":1,"395":1,"406":1,"523":1,"625":1,"650":1,"653":1,"669":1,"694":1,"710":1}}],["depend",{"2":{"89":1,"95":1,"235":1,"437":1,"440":1}}],["depending",{"2":{"40":1,"41":1,"65":1,"180":1,"224":1,"312":2,"400":1,"418":1,"508":1,"572":1,"582":1,"610":1,"636":1,"637":1,"646":1,"725":1,"740":1}}],["depends",{"2":{"34":1,"635":1,"724":1}}],["dependable",{"2":{"19":1}}],["deployer",{"2":{"120":2,"211":2,"284":2,"392":4}}],["deployed",{"0":{"213":1,"242":1},"1":{"214":1,"215":1,"216":1},"2":{"48":1,"84":2,"85":1,"89":1,"91":3,"120":3,"213":2,"214":1,"220":2,"227":1,"237":1,"239":3,"242":1,"243":1,"284":3,"305":2,"308":2,"309":2,"315":1,"346":1,"413":1,"505":1,"627":1,"678":1}}],["deployhelper",{"2":{"98":1,"99":1}}],["deploy",{"0":{"61":1,"73":1,"79":1,"85":1,"112":1,"211":1,"212":1,"217":1,"243":1,"277":1,"524":1,"784":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"80":1,"81":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,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"218":1,"219":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"525":1,"526":1,"527":1,"528":1,"529":1,"785":1,"786":1,"787":1,"788":1},"2":{"61":1,"73":2,"74":1,"75":1,"83":1,"84":2,"85":3,"91":4,"101":1,"105":1,"111":1,"113":1,"120":2,"122":2,"209":1,"210":1,"211":8,"212":2,"213":1,"217":1,"219":6,"221":1,"224":2,"226":2,"230":1,"236":1,"243":2,"244":1,"249":1,"258":1,"259":1,"263":2,"277":1,"283":2,"284":1,"286":1,"307":1,"308":1,"309":1,"317":3,"336":1,"339":2,"391":1,"392":4,"413":2,"505":1,"740":1,"763":1,"765":1}}],["deployments",{"0":{"95":1,"98":1,"99":1,"209":1,"412":1},"1":{"96":1,"97":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"413":1},"2":{"89":1,"95":2,"96":1,"97":1,"211":3,"224":1,"225":1,"230":1,"236":1,"238":1,"510":2,"726":2,"728":2,"744":2}}],["deployment",{"0":{"75":1,"83":1,"84":1,"219":1,"221":1,"307":1},"1":{"76":1},"2":{"30":2,"75":1,"79":2,"83":3,"84":4,"85":1,"120":1,"211":1,"217":4,"219":4,"221":1,"224":1,"226":1,"239":1,"242":6,"243":1,"284":1,"307":1,"317":1,"413":1}}],["deploying",{"0":{"118":1,"210":1,"263":1,"282":1,"308":1,"309":1,"317":1,"391":1,"392":1,"413":1},"1":{"119":1,"120":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"283":1,"284":1,"318":1,"319":1,"320":1},"2":{"3":1,"61":1,"79":1,"82":1,"113":1,"211":1,"213":1,"214":1,"217":1,"219":2,"255":1,"263":2,"303":1,"307":1,"309":1,"314":1,"392":1,"412":1,"413":1,"497":2,"719":1,"760":1}}],["deter",{"2":{"551":1}}],["deterministic",{"2":{"456":1}}],["determining",{"2":{"12":1,"418":1}}],["determined",{"2":{"137":1,"419":1,"724":3}}],["determines",{"2":{"84":1}}],["determine",{"2":{"33":1,"36":1,"41":2,"43":1,"48":1,"323":1,"408":1,"489":1,"508":1,"725":1,"740":1}}],["detecting",{"2":{"637":1}}],["detection",{"2":{"596":1}}],["detects",{"2":{"432":1}}],["detected",{"2":{"139":1}}],["detect",{"2":{"33":1,"135":1}}],["details",{"0":{"27":1,"177":1,"182":1,"506":1,"565":1,"566":1,"721":1,"741":1},"1":{"507":1},"2":{"21":1,"47":1,"69":2,"71":1,"72":2,"85":1,"94":1,"146":1,"148":1,"149":1,"177":1,"178":1,"184":1,"191":1,"192":1,"196":1,"200":1,"203":4,"206":1,"239":1,"314":1,"346":1,"347":1,"351":1,"419":1,"450":1,"453":1,"455":2,"459":1,"469":1,"494":1,"551":1,"561":1,"565":1,"566":1,"594":1,"596":1}}],["detailed",{"2":{"2":1,"22":1,"47":1,"79":1,"224":1,"477":1,"536":1}}],["devs",{"2":{"488":1}}],["devnpm",{"2":{"315":1}}],["devnetl1",{"2":{"387":1}}],["devnet",{"0":{"73":1,"120":1,"383":1,"391":1,"504":1,"514":1,"554":1,"555":1,"556":1,"558":1,"560":1,"564":1,"565":1,"566":1,"567":1,"763":1,"764":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"384":1,"385":1,"386":1,"387":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1,"514":1,"515":2,"516":2,"517":1,"518":1,"555":1,"556":2,"557":2,"558":2,"559":2,"560":1,"561":2,"562":2,"563":2,"564":2,"565":2,"566":2,"567":2,"764":1},"2":{"74":1,"111":1,"113":1,"114":1,"119":3,"122":1,"283":1,"339":2,"355":1,"356":1,"387":1,"388":1,"391":2,"432":2,"433":2,"504":1,"505":1,"508":1,"510":1,"513":1,"515":1,"526":1,"549":2,"553":1,"556":1,"557":1,"558":1,"559":4,"567":1,"568":1,"571":1,"575":1,"616":1,"627":2,"673":2,"678":1,"715":1,"740":1,"763":2,"771":1,"786":1}}],["devcd",{"2":{"75":1,"317":1}}],["devrel",{"2":{"41":1,"43":1}}],["developing",{"2":{"673":1}}],["development",{"0":{"301":1,"662":1},"1":{"302":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"663":1,"664":1},"2":{"79":1,"84":2,"263":1,"310":1,"488":2,"609":1,"662":2,"740":1,"760":1}}],["developer",{"2":{"24":1,"45":1,"68":1,"175":1,"255":1,"341":1,"430":1,"590":1,"692":1}}],["developers",{"2":{"3":1,"84":1,"105":2,"230":2,"238":1,"244":1,"246":2,"247":1,"255":1,"257":1,"264":1,"265":3,"289":1,"336":1,"342":1,"431":1,"477":1,"479":1,"481":1,"488":1,"496":2,"497":3,"504":1,"505":1,"740":1,"763":1,"765":1}}],["develop",{"2":{"24":1,"44":1}}],["devops",{"2":{"24":1,"388":1,"589":1}}],["dev",{"2":{"1":1,"75":1,"77":4,"102":1,"169":2,"315":1,"317":1,"318":4,"663":4,"774":2,"776":2,"777":2,"778":2}}],["devyarn",{"2":{"1":1}}],["yum",{"2":{"663":4}}],["ysudo",{"2":{"663":3}}],["yconfirm",{"2":{"789":1}}],["ycelestia",{"2":{"538":1,"540":1}}],["ycd",{"2":{"115":1,"279":1}}],["yparity",{"2":{"385":2}}],["yield",{"2":{"208":1}}],["y33zld2luvedelzzr9cf92+2etaimiwhn9pcaqaszwpqckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwoha36hewmw",{"2":{"161":2}}],["yh2zdyne9u",{"2":{"156":2}}],["yhcdb4cz7z4lrxmvrq5f8=",{"2":{"151":2}}],["y91da3zryfzmc7l",{"2":{"156":2}}],["y",{"2":{"115":1,"279":1,"538":1,"540":1,"564":9,"663":3,"789":4}}],["yamlversion",{"2":{"276":1}}],["yamlextra",{"2":{"89":1}}],["yarncd",{"2":{"310":1}}],["yarn",{"2":{"1":2,"75":4,"87":1,"91":2,"310":1,"311":1,"317":4}}],["ymlglobal",{"2":{"545":1}}],["yml",{"2":{"89":1,"276":2,"387":1,"545":3,"546":1}}],["yet",{"2":{"91":2,"137":1,"210":1,"242":1,"382":1,"611":1,"636":1}}],["yesterday",{"2":{"541":2}}],["yescelestia",{"2":{"299":1}}],["yes",{"2":{"48":1,"299":1,"483":1,"536":1,"549":2,"564":1}}],["years",{"2":{"31":1,"760":1}}],["year",{"2":{"25":1,"26":1,"34":4,"484":2,"489":11,"494":2}}],["youth",{"2":{"561":2}}],["youtube",{"2":{"40":1,"46":2}}],["yours",{"2":{"557":1}}],["yourself",{"2":{"34":1,"545":2}}],["yourprivatekey",{"2":{"91":3}}],["your",{"0":{"66":1,"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"73":1,"83":1,"84":1,"85":1,"86":2,"87":1,"89":1,"90":1,"91":1,"112":1,"116":1,"117":1,"118":1,"121":1,"275":1,"280":1,"281":1,"282":1,"285":1,"368":1,"370":1,"371":1,"390":1,"399":1,"400":1,"461":1,"463":1,"465":1,"466":1,"468":1,"470":1,"472":1,"474":1,"475":1,"522":1,"562":1,"564":1,"570":1,"573":1,"595":1,"602":1,"612":1,"668":1,"704":1,"705":1,"710":1,"772":1,"790":1},"1":{"67":1,"68":2,"69":2,"70":1,"71":2,"72":2,"74":1,"75":1,"76":1,"77":1,"78":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":2,"120":2,"121":1,"122":1,"283":1,"284":1,"523":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"669":1,"711":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1},"2":{"2":5,"5":1,"24":2,"25":1,"27":5,"30":5,"31":5,"32":7,"33":9,"34":15,"35":1,"40":4,"41":7,"42":6,"43":11,"44":14,"45":15,"46":7,"47":8,"48":1,"50":1,"53":1,"55":1,"56":2,"57":1,"63":1,"65":3,"66":2,"68":2,"69":7,"71":7,"72":4,"73":1,"74":1,"75":3,"76":2,"77":2,"78":2,"80":1,"82":2,"83":3,"84":11,"85":13,"86":8,"87":1,"88":6,"89":16,"90":3,"91":20,"92":5,"113":1,"114":1,"115":1,"116":2,"117":2,"119":1,"121":1,"122":2,"149":1,"212":1,"213":1,"214":1,"215":2,"224":2,"239":1,"240":4,"243":2,"249":1,"258":1,"259":1,"261":1,"266":1,"269":3,"271":1,"274":1,"275":2,"276":3,"278":1,"279":1,"280":2,"281":2,"284":2,"285":1,"292":5,"293":2,"294":1,"295":2,"297":3,"299":5,"303":4,"309":2,"311":1,"313":6,"314":2,"315":3,"316":3,"317":6,"318":2,"319":2,"322":6,"323":1,"339":1,"340":1,"345":1,"354":2,"355":2,"356":6,"358":3,"359":1,"360":3,"361":5,"362":5,"365":3,"370":1,"371":1,"375":1,"376":1,"380":2,"381":1,"382":1,"386":1,"387":2,"388":1,"390":2,"391":1,"392":6,"396":5,"397":1,"399":1,"400":1,"407":6,"413":5,"415":2,"429":1,"433":1,"434":1,"464":1,"465":1,"469":1,"475":1,"483":1,"491":1,"492":1,"504":1,"508":1,"510":1,"513":3,"519":1,"526":3,"527":3,"530":4,"533":1,"538":1,"539":1,"540":1,"541":7,"542":2,"543":1,"544":3,"545":3,"547":2,"553":1,"558":1,"559":2,"561":5,"564":1,"567":1,"569":1,"570":1,"571":1,"573":1,"578":2,"579":2,"581":1,"582":3,"583":3,"584":2,"585":2,"586":4,"590":1,"592":2,"594":3,"597":6,"602":5,"605":1,"606":1,"609":1,"610":3,"611":2,"612":2,"618":2,"627":4,"629":2,"631":1,"632":1,"633":1,"634":2,"635":1,"639":1,"642":1,"644":1,"646":1,"647":1,"649":5,"653":2,"655":2,"656":2,"657":1,"661":1,"662":1,"663":1,"664":3,"669":1,"673":7,"683":1,"692":1,"696":1,"698":1,"699":1,"701":2,"702":3,"705":3,"706":2,"712":2,"713":1,"714":3,"715":1,"718":1,"725":1,"726":1,"734":3,"736":2,"740":1,"744":1,"771":2,"774":1,"783":2,"786":1,"789":9,"790":2,"791":1,"794":5}}],["you",{"2":{"0":2,"2":1,"4":1,"24":3,"26":1,"27":6,"30":6,"31":23,"32":9,"33":4,"34":29,"35":4,"36":1,"39":1,"40":4,"41":7,"42":4,"43":3,"45":1,"46":3,"47":11,"48":8,"53":2,"54":1,"56":2,"57":2,"60":1,"61":1,"63":2,"64":1,"65":4,"68":1,"69":3,"71":3,"72":3,"75":1,"76":8,"77":3,"78":1,"79":4,"82":1,"83":1,"84":2,"85":5,"86":1,"87":1,"89":9,"90":2,"91":4,"92":1,"102":4,"103":1,"107":5,"108":2,"109":1,"113":1,"116":1,"119":1,"120":2,"122":2,"126":1,"134":1,"135":2,"148":2,"172":3,"177":1,"211":13,"212":3,"213":1,"214":2,"217":1,"219":1,"220":4,"222":1,"223":1,"224":6,"225":3,"228":1,"236":1,"238":1,"242":1,"243":2,"247":1,"249":2,"254":2,"255":5,"257":1,"261":3,"266":3,"268":1,"269":6,"270":1,"275":4,"276":2,"280":1,"283":1,"284":2,"286":3,"291":4,"292":1,"293":2,"295":1,"296":1,"297":2,"301":4,"302":2,"305":1,"308":2,"309":3,"312":2,"313":2,"315":6,"316":2,"317":10,"318":3,"319":1,"321":2,"322":5,"323":1,"324":1,"325":1,"326":3,"332":1,"339":1,"340":2,"346":2,"351":4,"353":1,"355":4,"356":11,"357":3,"358":7,"359":1,"360":3,"361":4,"362":2,"363":1,"365":3,"366":3,"369":1,"375":3,"376":1,"380":1,"381":2,"382":2,"385":1,"387":1,"388":2,"390":4,"391":2,"392":5,"393":2,"394":5,"396":4,"397":1,"400":1,"402":1,"404":4,"405":3,"406":2,"407":5,"408":1,"409":1,"410":3,"413":2,"420":1,"432":2,"433":6,"434":4,"436":1,"460":3,"466":2,"470":2,"475":2,"483":1,"501":1,"504":1,"508":3,"510":2,"514":1,"515":1,"517":1,"526":3,"527":8,"529":1,"531":1,"533":3,"536":2,"538":1,"539":2,"540":1,"541":2,"542":3,"544":6,"545":10,"547":3,"553":1,"554":1,"557":1,"558":2,"559":2,"560":2,"561":3,"564":4,"565":1,"566":1,"567":3,"568":1,"569":1,"571":2,"572":3,"573":4,"574":1,"575":1,"576":1,"577":1,"578":4,"579":2,"580":1,"581":4,"582":3,"583":3,"584":3,"585":1,"586":1,"589":1,"590":2,"592":1,"594":5,"597":5,"602":2,"604":2,"605":2,"606":5,"607":1,"609":4,"610":3,"611":3,"612":2,"614":1,"615":1,"618":3,"619":1,"622":1,"627":7,"629":1,"633":3,"634":3,"637":2,"639":7,"642":1,"643":2,"644":1,"646":3,"647":2,"649":3,"650":2,"651":3,"652":2,"653":5,"655":4,"656":10,"657":3,"658":1,"661":1,"663":1,"664":2,"665":1,"669":1,"670":1,"673":9,"675":2,"679":5,"682":3,"683":1,"684":1,"685":2,"686":1,"687":3,"692":3,"693":1,"694":1,"695":1,"696":2,"697":3,"698":1,"699":1,"701":2,"702":5,"703":4,"705":6,"706":2,"707":2,"713":1,"714":6,"715":3,"718":1,"725":4,"734":2,"735":1,"736":2,"737":1,"740":8,"746":3,"751":2,"753":1,"755":2,"758":1,"762":1,"768":2,"769":3,"770":2,"771":5,"773":1,"774":2,"776":2,"777":2,"778":1,"779":2,"783":8,"784":2,"785":1,"786":2,"788":1,"789":11,"794":3}}],["ahzu6yr9xmpixlquhgbhj9xl3wiaoz6pe3cvml",{"2":{"562":2,"566":2}}],["ahead",{"2":{"41":1,"139":1,"316":1}}],["a5jf",{"2":{"561":2,"562":2}}],["away",{"2":{"497":1,"678":1}}],["await",{"2":{"313":14,"408":6,"409":8,"410":6,"432":4}}],["awareness",{"2":{"36":1}}],["awards",{"2":{"30":1,"34":1}}],["award",{"2":{"30":4}}],["a1",{"2":{"276":2}}],["aztec",{"2":{"223":17}}],["aka",{"2":{"195":1,"217":1,"225":1,"421":1}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaecawqfbgcicra=",{"2":{"380":2,"386":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaba==",{"2":{"156":2,"161":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaap8aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaazz5aj1mijjrowjdcifyjkr0pcroiu2jigmd9bzuhzro",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqs98k+8wq2ix2bdctfohjtrqbqybtpdb1bufy",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaabxaaaacbaagroagqgaqqdaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseqovy2vszxn0awexdwc1zwt0mmnjn250dzrkdg1zzdlsn3n0ctbzn3z5ztd5btjyzhishqaaaaaaaaaaaaaaaaaaaaaaaaasexiyqkmkmoizggkxaiigrflow1m",{"2":{"161":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaacugaaacbaagrnagqfaqqcaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseaovy2vszxn0awexywxwngzwbhf5d21jnmn1adl5mzvly2xychf5cwf4mjn2z3zrczushqaaaaaaaaaaaaaaaaaaaaaaaaaaaagicagicagiggfeiiazloeqsgxg3row7sr1rkq7dvjygp3axkaqy4og6hyc0eibabjnclikrgofl2nvc21vcy5jcnlwdg8uc2vjcdi1nmsxllb1yktlerijcieca4ief8fzeabqlvc2wocefs+lhak0mdnmpnsxylkqv7qsbaoccaey5pebehekcwoedxrpyridmtyweltvbbpa7xbbsgyfrwtzcfhq3va1vhtbriczyd0elkajo6klsdooeqcwovaguwtdp55v8btf3wc7",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqaaaaaaeuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5rt0t52lwq3l0fnm6kqqka7nrxfnm8zc",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5ru6k2enim7thjqycl82hsxpinycelhed9qk+p9zbnide",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouu=",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaejpdcbnowap3dm=",{"2":{"365":8,"600":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaabitejjcqyqyijkaaaaaaaaaaaaaaaaaaaaaaaaaehmsmkjdjdkimbiwnpodwizbfr0uifhpkwgy",{"2":{"161":2}}],["axtrw6s+qsnuzfgfeg37da6igop2zqck+04egqkaggbgaisewoncgr1dglheguymtawmbdq6awaqclylqpnrfod6h8mgmwxjfenhwhru39ecrvkmfknq8+hhuodhdoqig",{"2":{"161":2}}],["airdrop",{"2":{"514":1,"751":1}}],["ai",{"2":{"394":1,"491":1,"492":1,"728":1,"729":1,"730":1,"734":1,"738":1}}],["aiming",{"2":{"235":1}}],["aims",{"2":{"50":1,"330":1}}],["aim",{"2":{"43":1,"235":1}}],["aid",{"2":{"35":1,"441":1}}],["aura",{"2":{"550":2}}],["augments",{"2":{"459":1,"520":1}}],["aunt",{"2":{"153":4}}],["aunts",{"2":{"151":2,"153":4,"156":2,"161":2,"168":5,"169":4,"172":8}}],["audible",{"2":{"40":1}}],["audience",{"0":{"42":1},"2":{"40":1,"42":3,"43":1,"44":1,"45":1,"46":1}}],["authcelestia",{"2":{"396":1}}],["authentication",{"2":{"344":1,"359":1,"360":5,"361":1,"403":2,"596":2}}],["authenticated",{"2":{"184":1,"208":1}}],["authorize",{"2":{"548":1}}],["authorization",{"2":{"313":4,"359":1,"380":2,"386":2}}],["authority",{"2":{"84":1,"313":2}}],["authorities",{"2":{"34":1}}],["auth",{"0":{"360":1,"362":1},"2":{"89":10,"313":4,"322":5,"330":1,"358":2,"359":5,"360":9,"361":2,"362":7,"363":4,"365":2,"368":1,"380":7,"386":2,"396":1,"401":4,"402":4,"404":4,"407":5,"418":1,"536":2,"564":2,"566":2}}],["automate",{"2":{"596":1}}],["automated",{"2":{"429":1}}],["automatically",{"2":{"24":1,"84":1,"323":1,"366":1,"408":1,"420":1,"426":2,"551":1}}],["autoconnect",{"2":{"312":2}}],["autogenerated",{"2":{"275":1}}],["auto",{"2":{"84":2,"312":2,"313":4,"538":2,"540":2,"564":6,"682":2}}],["amd",{"2":{"664":1}}],["amd64",{"2":{"582":1,"610":1,"664":12}}],["amanda",{"2":{"533":2}}],["amazonaws",{"2":{"223":16}}],["amountceles",{"2":{"542":1}}],["amount=1000000utia",{"2":{"789":2}}],["amount=9000000utia",{"2":{"702":2}}],["amount=5000000000000utia",{"2":{"542":2}}],["amount=",{"2":{"542":2,"700":2}}],["amount",{"0":{"71":1,"473":1},"2":{"41":1,"69":1,"84":1,"226":1,"294":3,"295":2,"296":2,"368":2,"369":2,"375":3,"418":1,"419":1,"440":1,"448":1,"457":1,"465":1,"469":1,"473":1,"489":2,"535":2,"536":2,"537":2,"539":4,"542":3,"564":8,"565":2,"567":4,"647":2,"700":2,"701":1,"702":3,"789":1}}],["amounts",{"2":{"34":1}}],["among",{"2":{"34":1,"37":1,"41":1,"455":1,"456":1,"520":1,"677":1}}],["amended",{"2":{"31":1}}],["ample",{"2":{"45":1}}],["amp",{"0":{"4":1,"85":1,"482":1,"539":1},"1":{"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1},"2":{"1":4,"2":2,"44":1,"59":1,"60":1,"61":1,"65":1,"75":12,"85":1,"115":8,"151":2,"153":14,"156":1,"159":2,"161":2,"165":6,"166":2,"170":10,"171":2,"172":10,"224":8,"227":1,"279":8,"303":1,"313":12,"315":4,"317":4,"408":10,"409":8,"410":6,"488":3,"489":5,"520":1,"545":1,"569":4,"606":2,"663":10,"776":4,"777":4}}],["affect",{"2":{"429":1,"605":1}}],["affected",{"2":{"8":1}}],["affordable",{"2":{"46":1}}],["affiliated",{"2":{"44":1}}],["affirm",{"2":{"34":1}}],["after=network",{"2":{"774":2,"776":2,"777":2,"778":2}}],["afterwards",{"2":{"25":1}}],["after",{"0":{"38":1,"296":1},"2":{"23":2,"24":2,"34":1,"40":1,"45":1,"46":1,"69":1,"71":2,"72":2,"79":1,"84":2,"86":1,"88":1,"90":1,"94":1,"117":1,"173":1,"181":1,"212":1,"213":1,"219":1,"220":1,"281":1,"295":1,"296":1,"300":1,"355":1,"365":1,"402":2,"404":1,"428":1,"466":1,"470":1,"475":1,"480":1,"526":1,"533":1,"551":2,"582":1,"602":1,"610":1,"615":1,"635":1,"639":1,"645":1,"646":1,"647":1,"649":1,"656":1,"663":2,"677":1,"682":1,"684":1,"703":1,"778":1,"783":1,"789":2,"790":1,"794":1}}],["agnostic",{"2":{"455":1}}],["ago",{"2":{"275":2,"276":2}}],["again",{"2":{"76":1,"317":1,"382":1,"396":1,"421":1,"459":1,"597":1,"602":1,"688":1}}],["against",{"2":{"31":3,"89":1,"128":1,"131":2,"237":1,"239":1,"604":1}}],["agreement",{"2":{"31":2,"34":3,"261":1}}],["agree",{"2":{"30":1,"31":5,"32":1,"33":1,"34":1,"456":1}}],["agreeing",{"2":{"30":1,"33":1,"34":2,"456":1}}],["ag",{"2":{"30":1}}],["aggression",{"2":{"16":1}}],["agenda",{"2":{"36":1}}],["agendas",{"2":{"5":1,"36":1}}],["agent",{"2":{"34":1}}],["age",{"2":{"7":1,"31":1}}],["avril14th",{"2":{"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["average",{"2":{"432":2,"434":1}}],["avoid",{"2":{"41":1,"44":1,"45":1,"89":1,"392":2,"419":1,"545":1,"656":1,"683":1}}],["avoiding",{"2":{"14":1,"19":1}}],["availability",{"0":{"232":1,"374":1,"435":1,"436":1,"437":1,"438":1,"439":1,"440":1,"444":1,"449":1,"450":1,"455":1,"459":1,"512":1,"513":1,"718":1,"732":1,"733":1,"734":1,"745":1,"746":1,"757":1,"775":1},"1":{"233":1,"234":1,"235":1,"436":1,"437":1,"438":1,"439":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"450":1,"451":2,"452":2,"453":1,"454":1,"455":1,"733":1,"734":1,"735":1,"736":1,"776":1,"777":1,"778":1},"2":{"34":1,"36":1,"42":1,"43":1,"59":1,"83":1,"105":2,"109":1,"110":2,"129":1,"131":1,"174":3,"188":1,"191":1,"203":1,"230":2,"233":2,"234":1,"235":2,"245":1,"261":1,"264":2,"287":2,"289":1,"299":1,"332":2,"336":1,"337":2,"348":1,"392":1,"436":7,"437":3,"438":5,"439":4,"440":1,"441":1,"444":1,"445":1,"446":1,"449":4,"452":1,"456":1,"457":5,"458":1,"477":1,"479":2,"480":1,"496":1,"497":1,"510":1,"519":1,"520":2,"585":1,"590":1,"610":1,"642":2,"651":2,"707":2,"708":1,"720":1,"735":1,"740":1,"755":4,"769":2,"778":1,"784":2}}],["available",{"2":{"5":1,"17":2,"22":1,"30":2,"33":1,"34":6,"35":1,"37":1,"46":2,"56":1,"109":1,"131":1,"183":1,"187":1,"188":1,"237":2,"257":1,"260":1,"305":1,"323":1,"327":1,"411":1,"439":2,"444":1,"446":1,"449":1,"450":2,"455":1,"456":1,"458":3,"459":4,"477":2,"481":2,"489":2,"516":1,"530":2,"536":1,"544":2,"582":3,"610":3,"643":3,"646":1,"647":2,"724":1,"735":1}}],["aria2",{"2":{"663":4}}],["aria2c",{"2":{"638":6}}],["arise",{"2":{"445":1}}],["arises",{"2":{"437":1}}],["arm",{"2":{"664":1}}],["arm64",{"2":{"582":1,"610":1,"664":12}}],["armored",{"2":{"270":1,"533":2}}],["arrived",{"2":{"579":1}}],["array",{"2":{"312":1,"408":3,"621":1}}],["arranging",{"2":{"37":1}}],["arranges",{"2":{"458":1}}],["arranged",{"2":{"450":1,"456":1}}],["arrange",{"2":{"36":2,"42":1,"43":1}}],["arrangement",{"2":{"34":1,"456":1}}],["arg",{"2":{"530":2}}],["args",{"2":{"358":3,"361":2,"401":8,"402":8,"404":8,"657":4,"658":4}}],["arguments",{"2":{"196":1,"358":1,"400":2,"401":5,"402":5,"404":2}}],["argument",{"2":{"117":1,"200":1,"203":1,"281":1}}],["architectnodes",{"2":{"682":2,"747":1,"748":1,"749":1}}],["architecture",{"2":{"590":1}}],["architectures",{"2":{"301":1,"457":1,"582":1,"610":1}}],["archives",{"2":{"728":1,"729":1,"730":1}}],["archive",{"2":{"513":1,"633":1,"728":1,"729":1,"730":1,"734":1}}],["archival",{"0":{"735":1,"736":1},"1":{"736":1},"2":{"24":1,"28":1,"480":3,"481":5,"735":2,"736":1}}],["arabicaversions",{"2":{"581":4,"609":2,"655":2,"657":2,"658":2}}],["arabicaresturl",{"2":{"432":2}}],["arabicarpcurl",{"2":{"432":2}}],["arabicachainid",{"2":{"365":1,"390":2,"432":2,"433":1,"593":1,"627":6,"638":2}}],["arabicacelestia",{"2":{"354":1,"355":2,"356":1,"396":1,"526":1,"527":1,"528":1,"672":1,"674":1,"712":1,"713":1,"714":1,"716":1}}],["arabica",{"0":{"504":1,"514":1,"600":1,"763":1,"764":1},"1":{"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1,"514":1,"515":2,"516":2,"517":1,"518":1,"764":1},"2":{"269":2,"354":1,"355":5,"356":3,"360":3,"372":2,"396":9,"402":3,"432":6,"433":6,"504":2,"505":3,"508":1,"510":12,"513":5,"515":2,"516":1,"517":3,"526":2,"527":5,"528":1,"579":1,"593":2,"596":1,"600":1,"606":1,"627":3,"655":1,"672":1,"673":4,"674":1,"678":1,"679":3,"712":1,"713":4,"714":3,"715":1,"716":1,"740":1,"763":3,"765":1,"771":2,"786":1}}],["artifacts",{"0":{"222":1},"1":{"223":1,"224":1},"2":{"212":1}}],["arfge6qnxuiz18vlglgewtw",{"2":{"156":4}}],["arbitrary",{"2":{"135":2,"537":1}}],["arbitrum",{"0":{"73":1,"79":1,"82":1,"96":1,"98":1,"104":1,"112":1,"120":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"80":1,"81":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,"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1},"2":{"66":1,"68":1,"69":3,"71":4,"73":3,"74":1,"75":2,"79":4,"80":3,"81":1,"82":3,"83":1,"85":5,"88":6,"89":1,"91":2,"93":1,"95":1,"96":1,"101":3,"102":2,"105":5,"106":1,"107":1,"109":1,"110":2,"111":1,"113":1,"122":2,"225":1,"238":1,"242":2,"287":1}}],["arb",{"2":{"75":2,"120":2}}],["around",{"0":{"443":1},"2":{"13":1,"49":1,"301":1,"437":1,"443":1,"445":1,"590":1,"651":1,"706":1}}],["areas",{"2":{"38":1,"43":1,"48":1}}],["area",{"2":{"37":1,"42":1,"43":1,"44":1,"45":1,"48":1}}],["aren",{"2":{"35":1,"571":1}}],["are",{"0":{"440":1,"448":1,"604":1},"2":{"9":2,"11":1,"17":1,"19":1,"21":2,"23":2,"24":3,"26":1,"30":2,"31":7,"32":2,"33":2,"34":8,"35":1,"36":1,"39":2,"41":1,"42":2,"48":3,"50":1,"52":1,"59":1,"65":1,"66":1,"76":1,"84":3,"85":1,"88":1,"89":4,"91":2,"107":1,"108":1,"116":1,"117":1,"127":2,"128":2,"134":1,"135":3,"136":1,"137":1,"139":3,"143":1,"145":1,"146":3,"148":3,"151":1,"153":2,"156":1,"160":1,"161":1,"165":1,"167":2,"168":2,"170":2,"172":2,"173":1,"177":2,"182":1,"183":1,"187":1,"188":1,"189":1,"194":1,"195":1,"196":2,"197":1,"200":1,"203":1,"206":1,"208":1,"211":5,"212":1,"213":1,"219":1,"220":2,"222":1,"224":5,"227":2,"233":1,"234":1,"238":1,"242":1,"247":2,"255":1,"257":2,"260":2,"261":1,"263":1,"264":1,"265":1,"269":3,"275":2,"280":1,"281":1,"296":1,"301":2,"305":1,"317":1,"320":1,"323":3,"324":1,"325":1,"330":1,"332":1,"333":2,"335":2,"337":2,"338":1,"341":1,"342":1,"352":1,"354":1,"355":3,"358":1,"359":1,"360":1,"361":1,"362":2,"382":1,"385":1,"386":1,"391":1,"392":2,"395":1,"409":1,"417":2,"418":3,"419":1,"421":1,"425":2,"428":1,"430":2,"438":1,"440":4,"443":1,"445":1,"446":1,"447":1,"449":3,"450":3,"451":1,"452":2,"455":1,"456":3,"458":4,"459":1,"477":1,"478":2,"480":1,"481":2,"484":1,"489":4,"504":1,"508":1,"509":1,"514":1,"517":1,"521":1,"526":1,"527":1,"531":2,"536":5,"537":2,"541":1,"542":1,"543":1,"544":2,"545":3,"551":1,"553":1,"559":1,"564":1,"571":1,"573":2,"579":1,"582":1,"583":3,"589":1,"592":1,"594":3,"596":4,"602":2,"604":3,"610":1,"616":1,"618":1,"623":1,"627":1,"636":1,"637":2,"639":2,"646":1,"647":6,"651":1,"652":1,"653":1,"655":1,"663":4,"664":1,"666":1,"667":1,"673":2,"675":1,"677":1,"678":2,"679":2,"680":1,"685":1,"701":1,"706":1,"709":1,"713":1,"725":1,"726":1,"737":1,"739":1,"740":3,"744":1,"746":1,"750":1,"751":1,"753":1,"754":1,"755":1,"765":1,"767":1,"769":2,"771":1,"773":2,"780":1,"784":1,"786":1,"789":6}}],["abstain",{"2":{"536":1}}],["abbreviation",{"2":{"494":1}}],["abci",{"0":{"647":1},"2":{"455":1,"647":8}}],["abci++",{"2":{"455":1,"458":1}}],["abigen",{"2":{"145":1}}],["abi",{"2":{"77":1,"153":2,"164":2,"172":2,"310":1,"313":4,"318":1}}],["ability",{"2":{"30":1,"110":1,"178":1,"437":1,"441":1,"442":1,"551":1,"673":2,"713":2}}],["able",{"2":{"34":3,"40":2,"41":1,"65":1,"71":2,"72":1,"88":1,"89":1,"134":2,"148":1,"178":1,"192":1,"194":1,"199":1,"213":1,"220":1,"263":1,"390":1,"402":1,"405":1,"421":1,"433":1,"434":1,"438":1,"441":1,"453":2,"480":1,"547":1,"590":1,"763":1,"774":1,"776":1,"777":1,"778":1,"789":1}}],["abusive",{"2":{"11":1}}],["about",{"0":{"337":1},"1":{"338":1},"2":{"3":1,"8":1,"17":1,"21":1,"30":2,"33":1,"36":1,"42":1,"43":1,"48":5,"49":1,"65":1,"71":1,"79":2,"84":1,"92":1,"105":1,"107":1,"108":1,"116":1,"134":2,"146":1,"220":2,"239":1,"245":1,"261":1,"280":1,"291":1,"301":1,"339":1,"340":1,"350":1,"351":1,"358":2,"365":1,"366":1,"393":1,"420":1,"443":1,"444":1,"445":2,"499":1,"508":1,"518":1,"530":2,"561":1,"582":1,"609":1,"610":1,"653":2,"725":1,"735":1,"736":1,"739":2,"754":2,"755":1,"767":2}}],["above",{"2":{"2":1,"24":1,"31":1,"34":1,"75":2,"83":1,"89":1,"103":1,"120":1,"139":1,"142":1,"148":3,"163":1,"164":1,"166":1,"171":1,"172":1,"173":1,"178":1,"181":1,"195":1,"200":1,"206":1,"211":1,"219":1,"317":2,"362":1,"363":1,"365":3,"368":1,"418":1,"426":2,"455":1,"458":2,"510":1,"513":1,"520":1,"537":1,"564":1,"612":1,"649":1,"656":1,"701":1,"702":1,"714":1,"794":1}}],["atomic",{"2":{"457":1}}],["atlas",{"2":{"94":1}}],["atmosphere",{"2":{"40":1,"41":1}}],["at",{"0":{"488":1,"494":1},"1":{"489":1},"2":{"10":1,"11":1,"17":3,"24":1,"27":1,"30":2,"33":1,"34":2,"40":2,"41":2,"42":2,"43":1,"44":3,"45":1,"46":1,"48":1,"80":1,"82":1,"91":1,"95":1,"116":1,"119":1,"131":2,"133":1,"163":2,"169":4,"189":1,"208":1,"220":1,"221":1,"224":3,"225":2,"226":1,"227":1,"230":1,"236":1,"246":1,"260":1,"280":1,"304":1,"307":1,"312":1,"323":3,"324":2,"325":7,"326":3,"338":1,"365":1,"392":1,"402":4,"408":3,"409":5,"410":1,"415":2,"421":1,"425":2,"440":1,"443":1,"450":3,"452":1,"455":1,"458":1,"459":3,"483":1,"484":2,"487":1,"488":1,"489":6,"490":1,"494":1,"512":1,"513":1,"516":1,"528":1,"530":4,"545":2,"547":1,"549":2,"557":1,"574":1,"582":1,"583":1,"590":1,"594":1,"606":1,"610":1,"633":1,"637":1,"674":1,"678":1,"679":2,"681":1,"683":1,"701":1,"702":1,"716":1,"720":1,"733":1,"734":1,"745":1,"746":1,"763":1,"777":1}}],["attach",{"2":{"545":2}}],["attack",{"2":{"437":3,"440":1}}],["attacks",{"2":{"8":1,"84":1}}],["attempting",{"2":{"685":1}}],["attempt",{"2":{"436":1}}],["attesting",{"2":{"169":1}}],["attestations",{"2":{"234":2,"287":1}}],["attestation",{"2":{"163":2,"169":4}}],["attestationproof",{"0":{"169":1},"2":{"163":6,"169":6,"172":4}}],["attests",{"2":{"148":1}}],["attested",{"2":{"127":2,"242":1}}],["attended",{"2":{"45":1}}],["attendees",{"2":{"36":3,"37":4,"38":3,"40":2,"41":2,"42":2,"43":2,"45":1,"46":1,"48":1,"52":1,"65":2}}],["attending",{"2":{"45":2}}],["attend",{"2":{"42":1,"46":3}}],["attendance",{"2":{"36":1,"38":1,"42":3,"45":2}}],["attention",{"2":{"8":1,"392":1}}],["attributes",{"2":{"156":4}}],["attribution",{"0":{"17":1}}],["attracting",{"2":{"45":1}}],["attract",{"2":{"42":1,"43":1}}],["ad5ezbg0",{"2":{"380":2}}],["adoption",{"2":{"301":1}}],["adopted",{"2":{"34":1}}],["adjusted",{"2":{"418":1,"419":1}}],["adjust",{"2":{"265":1,"606":1}}],["adr019",{"2":{"484":1}}],["adrs",{"2":{"455":1,"520":1}}],["adr",{"2":{"178":1,"590":2}}],["adapt",{"2":{"148":1,"163":1}}],["adapted",{"2":{"17":1,"81":1,"489":1}}],["admin",{"2":{"89":2,"360":4,"362":2,"380":2,"392":4,"545":1}}],["administrative",{"2":{"84":1,"342":1}}],["adhere",{"2":{"52":1}}],["adhering",{"2":{"24":1}}],["adventure",{"2":{"394":1}}],["advertise",{"2":{"644":1}}],["advertising",{"2":{"34":1}}],["adverse",{"2":{"32":1}}],["advantages",{"2":{"208":1}}],["advanced",{"0":{"378":1,"652":1},"2":{"405":1}}],["advance",{"2":{"41":1,"45":1,"679":1}}],["advances",{"2":{"8":1,"237":1}}],["advice",{"2":{"32":3}}],["advise",{"2":{"746":1}}],["advised",{"2":{"592":1,"627":1}}],["adviser",{"2":{"32":1}}],["advisable",{"2":{"32":1,"415":1}}],["addnetworkkeplr",{"2":{"432":17}}],["adds",{"2":{"418":1,"458":1,"606":1}}],["addcustomprover",{"2":{"215":1,"216":2}}],["addblock",{"2":{"137":2,"139":4}}],["addrs",{"2":{"370":2}}],["addr",{"2":{"89":1,"426":4,"544":2,"602":2,"682":8}}],["addressed",{"2":{"301":1}}],["addresses",{"2":{"84":2,"89":3,"92":1,"119":1,"299":1,"413":1}}],["addresscelestia",{"2":{"295":1,"371":1}}],["address=address",{"2":{"569":4}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"563":1}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5export",{"2":{"563":1}}],["address=celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"563":2}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0d",{"2":{"375":1}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0dexport",{"2":{"375":1}}],["address=$",{"2":{"644":2,"705":2}}],["address=$evm",{"2":{"542":2}}],["address=$granter",{"2":{"293":1,"295":2}}],["address=0x5fbdb2315678afecb367f032d93f642f64180aa3",{"2":{"120":1,"284":1}}],["address=0x5fbdb2315678afecb367f032d93f642f64180aa3export",{"2":{"120":1,"284":1}}],["address=",{"2":{"75":2,"292":4,"299":4,"308":2,"309":2,"317":2,"542":2,"545":1}}],["address",{"0":{"369":1,"371":1,"601":1,"644":1},"2":{"8":1,"10":1,"24":1,"27":3,"33":2,"44":1,"75":3,"76":8,"77":2,"84":8,"89":6,"91":4,"98":1,"99":1,"121":4,"134":1,"153":2,"170":2,"171":2,"172":2,"211":9,"212":2,"213":21,"215":1,"216":4,"218":2,"219":6,"220":4,"227":2,"242":1,"276":4,"285":4,"292":4,"293":2,"294":4,"295":1,"297":3,"299":8,"300":2,"305":10,"308":10,"309":8,"313":10,"314":1,"315":4,"317":11,"318":2,"355":1,"356":7,"359":1,"369":9,"371":2,"372":8,"375":2,"385":1,"396":4,"413":2,"426":2,"433":1,"434":1,"515":5,"526":1,"527":2,"535":10,"537":1,"542":5,"544":2,"561":3,"562":4,"563":3,"564":16,"565":5,"566":5,"567":4,"570":1,"571":4,"579":2,"583":2,"584":2,"594":1,"596":1,"601":2,"627":2,"643":1,"644":8,"673":2,"682":4,"699":1,"704":8,"705":4,"714":2,"715":5,"751":5,"783":2}}],["added",{"2":{"84":1,"91":2,"110":1,"313":4,"405":1,"436":1,"545":2,"548":1,"701":1,"703":1}}],["addition",{"2":{"34":1,"40":1,"446":1,"459":1,"497":1,"619":1}}],["additionally",{"2":{"33":1,"45":1,"89":1,"106":1,"107":2,"110":1,"135":1,"450":1,"486":1}}],["additional",{"0":{"34":1,"98":1,"99":1,"379":1,"792":1},"1":{"380":1,"381":1,"382":1},"2":{"32":1,"34":1,"38":1,"44":1,"46":1,"96":1,"97":1,"105":1,"134":1,"197":1,"311":1,"344":1,"358":1,"418":1,"452":1,"466":1,"470":1,"475":1,"792":1}}],["adding",{"0":{"314":1,"433":1,"434":1,"701":1},"2":{"2":1,"91":2,"265":1,"532":2,"546":1,"683":1,"684":1}}],["add",{"0":{"68":1,"87":1,"216":1,"432":1,"683":1,"700":1,"705":1},"2":{"5":1,"45":1,"47":1,"68":1,"83":1,"89":2,"135":2,"139":4,"214":1,"216":1,"267":1,"269":6,"271":6,"311":1,"313":4,"314":2,"322":1,"332":1,"355":1,"356":2,"400":1,"407":3,"431":2,"432":6,"433":4,"434":3,"481":1,"489":1,"526":1,"530":4,"532":2,"542":5,"545":1,"549":8,"553":1,"561":2,"569":5,"578":2,"586":1,"597":1,"618":1,"664":1,"678":1,"682":1,"683":6,"688":3,"699":2,"700":2,"703":1,"704":1,"714":2}}],["apt",{"2":{"663":6}}],["aptyummac",{"2":{"663":1}}],["aptyum",{"2":{"663":1}}],["apache",{"2":{"127":2}}],["api",{"0":{"327":1,"341":1,"342":1,"345":1,"346":1,"347":1,"376":1,"411":1,"422":1,"425":1,"729":1,"748":1},"1":{"342":1,"343":2,"344":2,"345":2,"346":1,"347":2,"423":1,"424":1,"425":1,"426":1,"427":1},"2":{"48":1,"88":1,"211":6,"212":4,"219":6,"227":3,"311":4,"327":1,"332":2,"341":5,"342":4,"343":1,"344":1,"346":2,"347":1,"348":1,"355":1,"357":1,"359":1,"360":1,"361":2,"376":1,"394":3,"395":1,"397":3,"400":2,"401":3,"402":2,"405":1,"411":1,"425":1,"427":2,"433":1,"434":1,"447":1,"481":2,"509":1,"510":3,"536":1,"585":1,"642":1,"651":1,"681":1,"726":1,"729":21,"744":1,"748":18}}],["apology",{"2":{"13":1}}],["apologizing",{"2":{"8":1}}],["appcelestia",{"2":{"641":1,"697":1}}],["appcd",{"2":{"581":1}}],["appconsts",{"2":{"159":6,"426":4}}],["appdsudo",{"2":{"774":2}}],["appd",{"0":{"299":1},"1":{"300":1},"2":{"299":2,"300":2,"423":2,"426":2,"530":4,"531":2,"532":8,"533":6,"534":6,"535":10,"536":10,"537":4,"538":2,"539":4,"540":2,"542":10,"549":18,"557":2,"558":2,"561":2,"562":2,"564":6,"565":2,"566":2,"567":4,"569":8,"571":4,"578":6,"579":4,"581":5,"582":5,"627":12,"639":9,"641":2,"645":1,"646":1,"647":1,"649":1,"690":3,"697":3,"698":2,"699":2,"700":2,"702":2,"703":3,"705":2,"706":2,"773":1,"774":15,"783":4,"789":13,"794":1}}],["append",{"2":{"127":2,"139":2}}],["appendix",{"0":{"93":1},"1":{"94":1,"95":1,"96":1,"97":1,"98":1,"99":1},"2":{"89":1}}],["appear",{"2":{"91":1,"465":1,"545":1}}],["appearance",{"2":{"7":1}}],["appeal",{"2":{"42":1}}],["app",{"0":{"423":1,"458":1,"472":1,"553":1,"576":1,"580":1,"626":1,"692":1,"695":1,"770":1,"774":1},"1":{"459":1,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1,"577":1,"578":1,"579":1,"581":1,"582":1,"583":1,"693":1,"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1},"2":{"77":1,"88":2,"153":2,"159":4,"161":1,"162":1,"165":4,"166":4,"172":6,"312":6,"313":5,"315":5,"318":1,"332":1,"372":4,"417":2,"420":2,"421":1,"426":20,"428":1,"455":6,"458":1,"459":2,"491":1,"492":1,"509":1,"520":3,"530":2,"545":4,"551":1,"553":1,"554":1,"556":3,"557":8,"558":2,"561":4,"562":2,"564":6,"565":2,"566":2,"567":4,"568":1,"576":1,"577":1,"580":1,"581":18,"582":4,"583":1,"626":1,"627":13,"631":1,"633":1,"634":2,"637":1,"638":18,"639":4,"641":1,"643":2,"644":2,"646":1,"647":1,"649":1,"665":1,"679":1,"680":1,"692":1,"695":1,"697":1,"701":1,"702":1,"703":3,"704":1,"723":1,"724":1,"726":1,"744":1,"755":1,"770":3,"771":2,"774":1,"777":1,"784":1,"789":3,"794":1}}],["appreciate",{"2":{"48":1,"52":1}}],["appreciation",{"2":{"43":2}}],["approximation",{"2":{"418":1,"724":1}}],["approximately",{"2":{"71":1,"72":1,"679":1}}],["approving",{"2":{"71":1}}],["approvedprovers",{"2":{"413":1}}],["approve",{"2":{"69":1,"72":1,"83":1,"465":1}}],["approval",{"2":{"53":1,"465":1}}],["approaching",{"2":{"415":1}}],["approaches",{"2":{"173":1}}],["approach",{"2":{"42":1,"43":1,"44":1,"195":1,"202":1,"208":1,"508":1,"725":1,"740":1}}],["appropriate",{"2":{"9":2,"135":2,"323":1,"408":1,"477":1,"605":1,"682":1}}],["apple",{"2":{"582":1,"610":1,"664":1}}],["applicable",{"2":{"25":2,"27":1,"31":1,"33":1,"34":9,"36":1}}],["applicant",{"2":{"23":1}}],["applicants",{"2":{"23":8,"24":2,"26":2}}],["applications",{"2":{"24":1,"26":1,"28":3,"244":1,"246":2,"249":1,"260":1,"264":2,"265":2,"340":1,"351":2,"447":1,"453":1,"479":1,"481":1,"504":1,"719":1,"760":1,"772":1,"774":1}}],["application",{"0":{"26":1,"27":1},"1":{"27":1},"2":{"21":3,"24":3,"27":1,"264":2,"265":1,"301":1,"308":1,"310":1,"315":1,"351":1,"380":2,"386":2,"413":1,"417":2,"421":1,"453":7,"455":3,"497":1,"520":1,"530":10,"546":1,"578":1,"605":1,"638":1,"646":1}}],["applies",{"2":{"10":2,"103":1}}],["applying",{"2":{"27":1,"38":1,"450":1}}],["apply",{"2":{"21":1,"25":1,"26":1,"34":1,"456":1,"586":1,"637":1}}],["appointed",{"2":{"10":1}}],["acelestia",{"2":{"783":1}}],["acquire",{"0":{"82":1},"2":{"82":1}}],["acquaintances",{"2":{"44":1,"45":1}}],["achieved",{"2":{"50":1,"546":1,"629":1}}],["across",{"2":{"47":2,"107":1,"165":1,"264":1,"488":1,"691":1}}],["acknowledging",{"2":{"44":1}}],["acknowledge",{"2":{"31":4,"34":4}}],["accurately",{"2":{"419":1,"601":1}}],["accurate",{"2":{"417":1}}],["accuracy",{"2":{"33":1,"34":1}}],["accomplish",{"2":{"276":1}}],["accommodate",{"2":{"36":1}}],["accordingly",{"2":{"48":1,"89":1,"606":1}}],["according",{"2":{"41":1,"237":1}}],["accordance",{"2":{"33":1,"34":3}}],["accountexport",{"2":{"569":1}}],["accounted",{"2":{"418":1}}],["accountname",{"2":{"426":2}}],["accountaddress",{"2":{"358":1}}],["accounts",{"0":{"119":1,"567":1},"2":{"91":5,"120":1,"153":2,"172":2,"283":1,"291":1,"292":1,"308":1,"418":1,"548":4,"549":2,"567":1,"574":1}}],["account",{"0":{"296":1,"300":1,"371":1,"375":1,"421":1,"553":1,"560":1,"564":1,"565":1,"566":1,"570":1,"571":1,"700":1},"1":{"554":1,"555":1,"556":1,"557":1,"558":1,"559":1,"560":1,"561":2,"562":2,"563":2,"564":2,"565":2,"566":2,"567":2,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1},"2":{"10":1,"34":4,"74":1,"76":2,"84":2,"88":3,"91":9,"211":5,"289":2,"290":2,"291":6,"292":4,"295":3,"296":2,"299":7,"300":1,"303":1,"311":1,"315":2,"317":3,"368":2,"371":3,"382":4,"390":2,"392":10,"396":4,"397":2,"418":3,"421":1,"426":6,"433":1,"434":1,"445":1,"530":4,"536":4,"542":3,"549":10,"553":3,"559":1,"560":1,"561":2,"564":12,"565":11,"566":6,"567":3,"568":2,"569":4,"571":4,"575":2,"593":1,"673":1,"682":4,"683":1,"700":2,"713":1}}],["accessed",{"2":{"643":1}}],["accessing",{"2":{"443":1,"444":1}}],["accessibility",{"2":{"301":1}}],["accessible",{"2":{"36":1,"65":1,"237":1,"268":4,"443":1,"583":2,"594":2}}],["access",{"0":{"513":1,"633":1,"734":1,"746":1},"2":{"31":4,"42":1,"43":1,"53":2,"56":1,"65":1,"90":1,"145":1,"179":1,"193":1,"202":1,"211":2,"230":1,"290":1,"342":1,"343":1,"355":1,"380":1,"418":1,"432":2,"438":1,"442":1,"443":2,"447":2,"475":1,"481":4,"509":4,"513":2,"526":1,"673":2,"713":1,"726":4,"734":1,"744":4,"746":1}}],["accepts",{"2":{"109":1,"220":1,"459":2}}],["accept",{"2":{"30":1,"196":1,"417":1,"421":1,"459":1,"544":2,"642":1}}],["accepted",{"2":{"23":1,"108":1}}],["acceptable",{"2":{"9":1}}],["accepting",{"2":{"8":2}}],["actors",{"2":{"447":1}}],["acts",{"2":{"211":1}}],["actually",{"2":{"335":1,"436":1}}],["actual",{"2":{"135":3,"137":1,"146":1,"182":1,"223":1,"418":1,"484":1}}],["activating",{"2":{"677":1,"678":1}}],["activation",{"2":{"387":1}}],["activate",{"2":{"391":1,"618":1}}],["activatecd",{"2":{"391":1}}],["activity",{"2":{"90":1}}],["activities",{"2":{"25":1,"33":3,"36":1,"37":1,"64":1}}],["active",{"2":{"21":1,"24":3,"27":2,"55":1,"275":1,"276":1,"520":1}}],["acting",{"2":{"10":1,"34":1}}],["actions",{"2":{"14":1,"31":2,"135":4}}],["action",{"2":{"9":1,"12":1,"31":1,"156":2,"358":1}}],["act",{"2":{"7":1,"31":3,"34":13,"551":1}}],["aside",{"2":{"489":1}}],["async",{"2":{"313":6,"408":2,"409":1,"410":1,"432":2}}],["ascii",{"2":{"270":1,"533":2}}],["asked",{"2":{"52":1,"208":1,"740":1}}],["ask",{"2":{"40":1,"43":1,"44":1,"432":2,"459":1}}],["aspects",{"2":{"47":1,"65":1}}],["aspect",{"2":{"31":1}}],["assumption",{"2":{"419":1,"440":2,"443":1,"606":1}}],["assumptions",{"0":{"440":1},"2":{"233":1,"443":1,"596":1}}],["assumed",{"2":{"440":1,"502":1}}],["assumes",{"2":{"224":2,"380":1,"419":1,"440":1,"585":1,"609":1}}],["assume",{"2":{"135":1,"211":1,"264":1,"396":1}}],["assurances",{"0":{"448":1},"2":{"34":2}}],["assign",{"2":{"84":1,"542":1}}],["assist",{"2":{"46":1,"47":1}}],["assistance",{"2":{"45":1,"47":1}}],["associated",{"2":{"24":1,"32":1,"45":1,"169":2,"337":1,"368":1,"458":2}}],["asset",{"2":{"496":1}}],["assets",{"2":{"8":1,"250":1}}],["assert",{"2":{"200":1,"305":1,"408":6}}],["asserted",{"2":{"196":2}}],["asserteq",{"2":{"117":4,"281":4,"305":9}}],["asserts",{"2":{"117":1,"281":1}}],["assertion",{"2":{"305":2}}],["assertions",{"2":{"84":3}}],["asserting",{"2":{"117":1,"281":1}}],["assessing",{"2":{"38":1}}],["assess",{"2":{"21":1,"42":1}}],["as",{"0":{"104":1,"258":1,"294":1,"295":1,"297":1,"381":1,"705":1,"772":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"298":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1},"2":{"7":1,"8":2,"10":1,"14":2,"23":1,"24":2,"30":5,"31":3,"32":1,"34":10,"36":1,"40":2,"42":1,"43":3,"44":2,"45":2,"47":1,"50":1,"54":1,"56":1,"57":1,"65":3,"71":1,"75":2,"76":1,"84":1,"85":2,"86":2,"89":1,"91":1,"107":2,"108":2,"111":1,"119":1,"120":1,"126":2,"128":1,"131":1,"134":5,"135":2,"136":2,"139":1,"142":1,"145":1,"148":1,"156":1,"161":2,"162":2,"163":1,"164":1,"165":2,"166":3,"167":1,"168":1,"171":2,"172":5,"178":1,"184":1,"187":1,"189":2,"192":1,"193":1,"195":1,"196":3,"197":1,"200":6,"203":2,"206":1,"208":1,"211":3,"212":2,"213":1,"217":1,"219":3,"220":2,"222":1,"224":2,"230":1,"233":1,"235":1,"237":2,"238":2,"239":1,"245":1,"249":1,"263":6,"284":1,"287":2,"292":2,"297":2,"300":1,"305":4,"308":5,"309":1,"317":3,"322":3,"324":1,"325":1,"328":1,"330":2,"331":1,"337":5,"339":1,"342":2,"343":1,"344":2,"354":1,"358":3,"362":1,"363":2,"375":1,"380":1,"384":1,"385":2,"388":1,"397":1,"400":1,"401":2,"402":2,"404":2,"405":1,"407":3,"408":1,"409":1,"417":2,"418":1,"419":2,"421":1,"426":2,"428":1,"436":2,"439":2,"440":1,"442":1,"443":1,"446":2,"450":4,"452":3,"453":4,"455":1,"456":5,"458":3,"459":3,"460":1,"479":3,"480":4,"481":4,"483":1,"487":1,"489":2,"497":3,"498":1,"499":1,"505":1,"513":1,"520":1,"527":1,"529":1,"530":2,"536":1,"537":1,"543":1,"545":5,"546":1,"548":1,"557":1,"563":3,"564":1,"565":1,"569":1,"571":1,"578":2,"583":1,"589":1,"590":1,"593":1,"594":1,"596":2,"600":1,"601":1,"621":1,"631":1,"637":1,"638":1,"639":1,"661":1,"673":4,"675":1,"676":1,"681":3,"690":1,"692":1,"700":1,"704":1,"705":1,"713":2,"717":1,"719":1,"720":1,"723":2,"724":1,"740":1,"748":1,"763":1,"765":1,"771":1,"772":1,"773":1,"774":1,"778":1,"783":2,"784":1,"788":1,"790":1}}],["anger",{"2":{"561":2}}],["anchoring",{"2":{"313":1}}],["analogously",{"2":{"129":1}}],["analogous",{"2":{"128":1}}],["analog",{"2":{"127":2}}],["analytics",{"0":{"738":1,"752":1},"2":{"738":2,"752":1}}],["analysis",{"2":{"192":1}}],["analyse",{"2":{"33":1}}],["analyze",{"2":{"38":1}}],["anvil",{"0":{"283":1},"2":{"120":1,"283":4,"308":3}}],["another",{"0":{"369":1,"375":1},"2":{"84":1,"91":2,"179":1,"192":1,"275":1,"276":1,"287":1,"291":1,"292":1,"305":2,"355":1,"369":1,"417":1,"458":1,"526":1,"535":1,"551":1,"621":1,"666":1,"691":1,"784":1}}],["answer",{"2":{"48":1,"403":1,"564":1}}],["answers",{"2":{"17":1,"47":1,"436":1}}],["annual",{"2":{"484":2}}],["annually",{"2":{"484":1,"494":1}}],["announced",{"2":{"45":1,"679":1}}],["announce",{"2":{"45":1}}],["announcements",{"2":{"739":1,"754":1,"767":2}}],["announcement",{"2":{"45":1,"518":1,"739":1,"740":1,"754":1,"767":1}}],["announcing",{"2":{"45":2}}],["anniversary",{"2":{"34":3}}],["anticipate",{"2":{"42":1}}],["anticipation",{"2":{"31":1}}],["an",{"0":{"71":1,"79":1,"88":1,"221":1,"294":1,"326":1,"381":1,"388":1,"392":1,"410":1,"642":1,"649":1,"794":1},"1":{"80":1,"81":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,"389":1,"390":1,"391":1,"392":1,"393":1,"643":1,"644":1,"645":1},"2":{"4":1,"7":1,"10":5,"13":1,"16":1,"22":1,"24":4,"27":1,"30":1,"31":3,"34":9,"37":1,"40":1,"42":1,"43":2,"44":1,"47":1,"52":1,"53":2,"55":1,"59":1,"60":1,"61":1,"65":1,"69":2,"71":1,"73":1,"74":1,"76":2,"82":1,"84":2,"85":1,"88":4,"91":1,"92":1,"101":1,"105":2,"107":1,"108":1,"109":1,"110":2,"111":1,"117":1,"126":1,"128":1,"131":2,"133":1,"135":4,"136":2,"145":1,"150":1,"153":2,"160":2,"164":1,"165":2,"166":1,"168":1,"169":4,"170":2,"172":4,"180":1,"181":2,"184":1,"187":2,"188":1,"191":1,"208":2,"211":6,"212":1,"217":3,"219":3,"221":1,"226":1,"227":1,"230":2,"231":1,"237":1,"238":1,"244":1,"246":3,"264":1,"276":2,"281":1,"284":1,"287":2,"302":2,"304":1,"305":4,"308":1,"311":1,"313":2,"317":2,"320":1,"322":2,"323":1,"326":1,"339":1,"344":1,"355":2,"360":1,"361":1,"362":2,"363":3,"365":2,"369":1,"370":1,"371":1,"372":1,"375":1,"382":1,"392":1,"393":1,"394":1,"395":1,"396":1,"397":6,"401":2,"402":3,"404":2,"407":2,"408":2,"410":1,"413":2,"417":1,"418":3,"420":1,"421":1,"426":2,"437":1,"440":3,"449":1,"453":4,"455":1,"456":6,"457":1,"458":1,"459":1,"483":1,"484":1,"490":1,"494":1,"496":1,"503":1,"513":2,"520":2,"522":1,"526":2,"527":1,"530":4,"533":1,"537":2,"542":1,"543":1,"545":1,"546":1,"551":1,"571":3,"572":1,"578":1,"581":1,"582":1,"586":1,"587":1,"588":1,"590":2,"592":1,"596":2,"600":1,"602":3,"605":1,"610":1,"621":1,"624":1,"633":1,"646":1,"647":1,"649":3,"653":1,"655":3,"657":1,"668":1,"673":1,"677":1,"679":1,"681":2,"687":1,"702":1,"710":1,"724":1,"734":1,"781":1,"783":2,"789":1,"794":3}}],["anyway",{"2":{"346":1,"351":1,"594":1}}],["anything",{"2":{"189":1,"390":1,"683":1}}],["anytrust",{"2":{"83":1,"84":1,"105":1,"107":1}}],["anyone",{"2":{"116":1,"280":1,"336":1,"436":1,"457":1,"680":1}}],["any",{"2":{"4":1,"8":1,"9":1,"11":1,"12":1,"15":1,"16":1,"24":4,"25":1,"27":1,"30":5,"31":19,"32":4,"33":2,"34":36,"36":3,"37":2,"45":2,"48":1,"89":1,"133":1,"183":1,"208":1,"210":1,"215":1,"217":1,"230":1,"261":1,"263":1,"265":2,"267":1,"295":1,"314":1,"332":1,"334":1,"335":1,"358":1,"390":1,"413":1,"415":1,"436":1,"451":1,"498":1,"514":2,"530":2,"545":4,"581":1,"602":1,"609":1,"612":1,"615":1,"621":1,"637":1,"690":1,"720":1,"735":1,"751":2,"758":1,"783":1}}],["and",{"0":{"39":1,"41":1,"45":1,"66":1,"75":1,"86":1,"87":1,"90":1,"100":1,"224":1,"233":1,"235":1,"245":1,"273":1,"305":1,"313":1,"323":1,"331":1,"332":1,"356":1,"392":1,"396":1,"408":1,"416":1,"417":1,"429":1,"444":1,"464":1,"466":1,"469":1,"470":1,"473":1,"479":1,"480":1,"505":1,"533":1,"551":1,"584":1,"599":1,"600":1,"621":1,"628":1,"657":1,"714":1,"720":1,"743":1,"750":1},"1":{"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"76":1,"101":1,"102":1,"103":1,"274":1,"275":1,"276":1,"417":1,"418":2,"419":2,"420":2,"421":1,"480":1,"481":1,"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"715":1,"744":1,"745":1,"746":1},"2":{"0":1,"1":1,"2":4,"3":3,"5":1,"7":5,"8":8,"9":6,"10":1,"11":3,"13":1,"19":3,"21":2,"22":1,"23":3,"24":11,"26":1,"27":10,"28":2,"30":7,"31":20,"32":3,"33":11,"34":37,"36":12,"37":7,"38":6,"39":1,"40":6,"41":9,"42":7,"43":6,"44":8,"45":11,"46":11,"47":4,"48":3,"50":4,"52":4,"53":2,"54":1,"56":2,"57":3,"58":1,"59":1,"60":1,"61":1,"62":1,"63":2,"64":2,"65":10,"66":3,"71":3,"72":1,"73":1,"75":4,"78":1,"79":5,"80":3,"83":2,"84":13,"85":4,"86":3,"87":1,"88":6,"89":1,"90":2,"91":5,"92":2,"94":2,"101":1,"103":1,"105":2,"107":9,"108":3,"109":1,"113":2,"114":1,"115":1,"116":1,"117":4,"119":5,"120":1,"128":1,"130":1,"131":9,"133":3,"134":3,"135":8,"136":3,"137":1,"139":10,"141":1,"145":1,"146":5,"148":4,"149":2,"150":1,"153":2,"154":2,"156":2,"159":1,"160":2,"165":5,"166":2,"168":3,"169":4,"170":2,"172":2,"173":3,"174":1,"175":2,"177":3,"178":1,"181":3,"182":2,"183":2,"184":5,"187":3,"188":3,"189":2,"191":1,"192":5,"194":1,"195":2,"196":3,"200":4,"203":2,"205":1,"206":2,"208":4,"211":8,"212":4,"213":3,"214":3,"217":3,"218":1,"219":6,"220":3,"223":2,"224":5,"225":3,"226":2,"227":1,"228":1,"230":4,"235":5,"237":5,"238":3,"239":1,"240":1,"242":1,"243":4,"246":1,"247":1,"249":1,"250":1,"251":1,"253":1,"254":2,"255":3,"257":1,"260":2,"261":4,"264":4,"265":2,"267":1,"269":1,"270":1,"278":1,"279":1,"280":1,"281":4,"283":1,"284":1,"287":3,"291":1,"292":1,"293":1,"295":1,"297":1,"299":2,"301":4,"305":8,"308":1,"309":3,"310":3,"311":3,"313":11,"314":1,"315":2,"316":1,"317":5,"319":1,"321":1,"322":1,"323":3,"325":2,"326":1,"328":1,"330":5,"331":2,"332":1,"334":2,"335":1,"336":3,"337":4,"338":1,"340":2,"341":2,"342":4,"343":1,"344":1,"346":1,"348":1,"351":3,"353":1,"354":2,"355":2,"357":1,"358":2,"359":1,"360":2,"362":1,"363":4,"365":1,"366":2,"375":2,"377":1,"380":1,"381":1,"382":1,"384":1,"385":1,"387":2,"388":3,"390":4,"391":1,"392":1,"394":3,"396":4,"397":2,"399":1,"400":4,"401":5,"402":19,"403":4,"404":7,"405":1,"406":1,"407":2,"408":2,"410":1,"413":1,"414":1,"415":1,"417":2,"418":3,"419":6,"420":3,"421":2,"422":1,"426":14,"429":1,"430":2,"431":3,"432":2,"433":3,"434":4,"436":2,"437":3,"440":1,"441":1,"442":3,"443":2,"444":2,"445":2,"446":4,"448":2,"449":3,"450":4,"451":1,"452":3,"453":8,"455":3,"456":9,"457":2,"458":7,"459":3,"460":2,"463":1,"464":1,"465":1,"468":1,"469":2,"472":1,"473":1,"474":1,"477":4,"478":1,"479":4,"480":1,"481":4,"483":2,"484":2,"486":4,"488":6,"489":3,"490":1,"497":1,"499":1,"501":1,"502":1,"504":2,"510":1,"513":1,"519":1,"520":5,"526":1,"527":1,"530":6,"533":2,"536":5,"537":2,"543":3,"545":9,"546":1,"549":2,"551":8,"552":1,"553":1,"554":2,"556":1,"557":2,"561":1,"563":1,"564":2,"565":1,"568":1,"569":1,"570":1,"573":1,"575":1,"577":1,"580":1,"581":2,"583":2,"584":1,"586":2,"590":1,"594":3,"596":7,"599":3,"600":2,"601":2,"602":1,"603":1,"604":1,"605":2,"606":2,"607":1,"609":7,"611":1,"612":1,"614":1,"616":1,"618":1,"627":1,"629":1,"631":1,"633":1,"635":2,"636":1,"637":3,"638":1,"642":1,"644":1,"646":2,"647":4,"649":2,"651":1,"653":2,"654":2,"656":1,"657":1,"662":1,"663":4,"664":2,"666":2,"673":1,"678":2,"679":3,"680":4,"681":1,"682":2,"683":1,"684":2,"685":5,"688":2,"691":1,"692":1,"703":1,"708":1,"711":1,"712":1,"713":1,"719":2,"720":4,"724":4,"734":2,"740":2,"746":1,"747":1,"749":2,"750":1,"755":2,"758":1,"760":4,"763":1,"768":1,"769":2,"770":1,"771":3,"774":1,"776":1,"777":3,"778":1,"784":1,"789":3,"790":1,"794":2}}],["alias",{"0":{"503":1},"2":{"503":1,"534":2}}],["alignitems",{"2":{"313":4}}],["align",{"2":{"44":1}}],["aligned",{"2":{"9":1,"24":1}}],["algorithm",{"2":{"455":1}}],["alertmanager",{"2":{"545":2}}],["alerts",{"0":{"547":1},"2":{"545":2,"547":1}}],["alert",{"2":{"432":4}}],["alerting",{"2":{"27":1}}],["although",{"2":{"459":3}}],["alt",{"2":{"391":1,"392":1,"393":1}}],["alternatives",{"2":{"636":1}}],["alternatively",{"2":{"119":1,"139":2,"192":1,"199":1,"212":1,"218":1,"226":1,"325":1,"358":1,"402":1,"452":1,"459":1}}],["alternative",{"2":{"110":1,"180":1,"181":1,"221":1}}],["along",{"2":{"135":1,"148":1,"169":1,"172":2,"212":1,"238":1,"308":1,"355":1,"394":1,"477":1}}],["alongside",{"2":{"48":1,"105":1,"680":1}}],["alphab",{"2":{"491":1,"492":1,"728":1,"729":1,"730":1,"734":1,"738":1}}],["alpha",{"2":{"94":1,"149":2,"227":1}}],["alchemy",{"2":{"88":3}}],["alcohol",{"2":{"41":1}}],["already",{"2":{"24":1,"46":1,"47":1,"50":1,"89":1,"160":1,"210":1,"217":1,"225":2,"321":1,"331":1,"351":1,"353":1,"357":1,"406":1,"421":1,"453":1,"547":1,"560":1,"585":1,"618":1,"621":1,"664":1,"685":1,"686":1,"688":1,"697":1}}],["also",{"2":{"10":1,"24":1,"41":3,"44":1,"45":1,"46":2,"48":1,"69":1,"84":2,"109":1,"136":1,"139":2,"149":1,"152":1,"156":2,"177":1,"191":1,"195":1,"202":1,"217":1,"220":2,"223":1,"224":1,"237":1,"243":1,"269":1,"275":1,"276":1,"287":1,"293":1,"297":1,"305":4,"308":1,"312":1,"344":1,"355":1,"358":1,"361":1,"363":1,"392":1,"394":1,"402":1,"432":2,"453":1,"458":1,"459":1,"499":1,"520":2,"543":1,"546":1,"551":1,"559":1,"571":1,"589":1,"616":1,"637":2,"651":1,"652":1,"701":1,"702":1,"712":1,"740":1,"746":1,"765":1,"769":1,"770":1}}],["allocation",{"0":{"488":1},"1":{"489":1},"2":{"488":1,"489":1}}],["allocating",{"2":{"46":1}}],["allocated",{"2":{"488":1,"489":1,"537":1}}],["allocate",{"2":{"41":1}}],["allotting",{"2":{"43":1}}],["allowance",{"0":{"294":1,"295":1,"297":1},"1":{"298":1},"2":{"292":1,"300":1}}],["allowances",{"0":{"292":1,"299":1},"1":{"293":1,"294":1,"300":1},"2":{"299":1}}],["allowing",{"2":{"47":1,"299":1,"690":1,"740":1}}],["allow",{"2":{"44":2,"84":1,"90":1,"178":1,"206":1,"214":1,"215":1,"230":2,"237":1,"247":1,"336":1,"361":1,"432":2,"436":1,"481":3,"512":1,"583":1,"584":1,"590":2,"594":1,"622":1,"656":1,"682":4,"688":4,"707":1,"733":1,"745":1,"747":1,"748":1,"749":1,"779":1}}],["allows",{"2":{"23":1,"46":2,"47":1,"84":1,"105":1,"109":2,"110":1,"116":1,"129":1,"131":1,"150":1,"160":1,"174":1,"176":1,"179":1,"181":1,"183":1,"185":1,"187":2,"215":2,"219":1,"226":1,"280":1,"291":1,"312":1,"313":3,"322":1,"332":1,"337":1,"342":1,"351":1,"366":1,"390":1,"407":1,"432":1,"451":1,"460":1,"499":1,"547":1,"583":2,"594":2,"596":1,"605":1,"642":1,"647":1,"653":1,"705":1,"748":1,"769":2,"770":2}}],["allowed",{"2":{"15":1,"299":2}}],["alleged",{"2":{"31":1}}],["all",{"0":{"272":1,"631":1},"2":{"3":1,"5":2,"10":1,"11":2,"27":2,"32":1,"33":1,"34":1,"47":1,"48":1,"52":3,"64":1,"76":1,"91":2,"134":2,"173":1,"177":1,"211":1,"224":1,"230":1,"237":2,"261":1,"263":3,"264":2,"265":1,"305":3,"313":2,"317":1,"324":1,"325":5,"354":1,"359":1,"365":6,"400":1,"402":1,"408":2,"409":5,"418":1,"419":1,"420":1,"426":2,"430":1,"436":3,"438":3,"439":1,"445":1,"453":3,"456":3,"459":1,"480":1,"481":1,"487":1,"489":1,"505":1,"513":1,"530":1,"534":1,"561":2,"574":1,"578":1,"583":1,"594":1,"607":1,"629":1,"631":2,"634":1,"635":2,"638":1,"641":3,"643":2,"649":1,"653":1,"656":1,"665":1,"666":1,"679":1,"684":2,"697":2,"701":2,"703":4,"719":1,"734":1,"735":1,"755":1,"789":1,"794":1}}],["always",{"2":{"2":1,"40":1,"107":1,"213":1,"269":1,"418":1,"505":1,"627":2,"646":2,"765":1}}],["a",{"0":{"48":1,"60":1,"61":1,"73":1,"100":1,"102":1,"103":1,"112":1,"134":1,"153":1,"188":1,"189":1,"190":1,"191":1,"200":1,"211":1,"220":1,"221":1,"257":1,"258":1,"260":1,"261":1,"263":1,"266":1,"277":1,"294":1,"295":2,"297":2,"298":1,"316":1,"317":1,"354":1,"355":1,"380":1,"381":1,"384":1,"391":1,"392":1,"396":1,"426":1,"427":1,"433":1,"434":1,"454":1,"458":1,"464":1,"469":1,"473":1,"494":1,"519":1,"528":1,"531":1,"542":1,"553":1,"561":1,"569":1,"571":1,"572":1,"576":1,"578":1,"579":1,"582":1,"601":1,"606":2,"610":1,"624":1,"629":2,"665":1,"674":1,"685":1,"696":1,"698":1,"699":1,"705":1,"707":1,"716":1,"772":1,"779":1,"781":1,"783":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"101":1,"102":1,"103":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"189":1,"190":1,"191":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"298":2,"318":1,"319":1,"320":1,"455":1,"459":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1,"526":1,"527":1,"528":1,"529":1,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1,"577":1,"578":1,"579":1,"607":2,"625":1,"626":1,"627":1,"630":2,"631":2,"666":1,"667":1,"668":1,"669":1,"670":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"708":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1,"780":1,"781":1,"782":2,"783":2,"784":1,"785":1,"786":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"793":1,"794":1},"2":{"2":4,"3":3,"7":1,"8":3,"13":2,"14":5,"15":4,"16":2,"19":3,"21":1,"22":2,"23":2,"24":6,"25":1,"26":1,"27":2,"28":1,"29":1,"30":5,"31":10,"32":3,"33":2,"34":15,"35":2,"36":6,"37":1,"39":3,"40":12,"41":3,"42":8,"43":7,"44":7,"45":3,"46":3,"47":8,"48":4,"50":1,"52":2,"53":2,"54":1,"56":1,"57":1,"59":1,"60":7,"61":5,"65":5,"66":2,"71":1,"72":1,"73":1,"74":1,"75":3,"76":3,"77":1,"78":1,"79":3,"80":3,"82":2,"83":2,"84":15,"85":3,"86":1,"88":7,"89":10,"90":1,"91":2,"92":1,"101":1,"102":2,"103":3,"105":1,"106":1,"107":21,"108":5,"109":3,"110":2,"113":2,"115":2,"116":3,"117":2,"119":2,"120":3,"121":3,"122":2,"126":2,"127":3,"128":8,"129":4,"131":13,"133":3,"134":15,"135":19,"136":3,"137":3,"139":6,"145":3,"146":10,"148":17,"150":5,"154":5,"155":1,"158":1,"160":7,"163":2,"165":4,"166":3,"168":2,"169":8,"172":2,"174":1,"176":1,"177":2,"178":5,"179":1,"180":1,"181":7,"182":1,"183":6,"184":12,"185":1,"187":3,"188":3,"189":3,"192":7,"195":1,"196":1,"197":1,"200":1,"202":2,"203":1,"206":1,"208":3,"209":1,"210":3,"211":17,"212":1,"213":6,"214":1,"215":2,"216":2,"217":11,"218":1,"219":4,"220":7,"221":2,"223":10,"224":10,"225":4,"226":5,"227":3,"228":3,"230":2,"233":2,"234":1,"235":3,"236":1,"237":7,"238":3,"239":3,"241":1,"243":3,"244":1,"245":3,"246":2,"249":1,"250":1,"254":1,"255":1,"257":1,"258":1,"260":3,"261":5,"263":7,"264":3,"265":2,"266":1,"267":1,"269":5,"270":1,"271":1,"275":2,"276":1,"277":1,"278":1,"279":2,"280":3,"281":2,"283":3,"284":3,"285":3,"286":1,"287":2,"289":2,"290":1,"291":4,"293":1,"294":3,"295":2,"296":1,"297":2,"298":1,"299":2,"301":1,"303":1,"304":1,"305":7,"307":1,"308":5,"310":7,"311":1,"312":3,"313":5,"315":1,"316":1,"317":8,"318":1,"319":1,"322":1,"323":7,"324":6,"325":5,"326":1,"330":1,"332":1,"335":1,"336":2,"337":4,"338":1,"339":4,"340":2,"341":1,"342":2,"343":1,"344":1,"346":1,"351":1,"352":1,"354":2,"355":3,"356":2,"357":1,"358":1,"360":2,"361":3,"362":4,"363":7,"364":1,"366":2,"375":3,"377":1,"380":3,"382":1,"383":1,"384":4,"385":1,"388":2,"390":2,"391":3,"392":4,"394":1,"396":3,"399":2,"400":5,"401":4,"402":21,"403":3,"404":4,"405":3,"407":1,"408":4,"409":1,"410":1,"412":1,"413":4,"414":1,"415":6,"416":1,"417":6,"418":10,"419":13,"420":4,"421":7,"425":4,"426":10,"428":2,"429":2,"430":1,"432":2,"433":1,"434":1,"436":2,"437":5,"438":3,"439":6,"440":5,"441":3,"442":2,"443":4,"444":1,"445":2,"446":4,"448":1,"449":5,"450":9,"451":3,"452":7,"453":4,"455":5,"456":10,"457":3,"458":13,"459":9,"460":2,"463":1,"464":1,"465":1,"469":1,"473":1,"475":1,"477":5,"478":3,"480":3,"481":2,"483":4,"486":2,"487":1,"488":2,"489":1,"490":4,"496":1,"497":6,"498":3,"499":1,"504":2,"505":2,"512":3,"513":4,"515":2,"520":6,"526":1,"527":5,"528":2,"529":2,"530":10,"533":4,"536":7,"537":4,"539":2,"541":1,"542":1,"543":2,"544":2,"545":16,"546":1,"547":3,"548":3,"549":2,"551":9,"552":2,"553":4,"557":1,"559":4,"560":1,"561":3,"564":3,"565":1,"567":2,"568":4,"569":3,"571":2,"572":2,"573":2,"574":1,"575":3,"576":1,"579":1,"580":1,"581":1,"582":2,"583":5,"584":2,"585":1,"589":6,"590":2,"592":1,"593":1,"594":5,"596":2,"597":3,"599":4,"600":1,"601":1,"604":4,"605":1,"606":7,"609":2,"610":2,"611":1,"615":2,"618":1,"619":1,"621":5,"622":1,"623":1,"627":4,"629":1,"633":2,"634":1,"635":2,"636":1,"637":3,"638":2,"639":2,"642":1,"643":1,"644":2,"646":1,"647":2,"649":2,"651":3,"652":4,"653":2,"654":2,"655":1,"656":6,"657":1,"658":2,"661":3,"665":3,"673":8,"674":2,"675":2,"677":2,"678":3,"679":7,"680":1,"681":2,"683":1,"685":1,"686":3,"687":17,"691":3,"692":2,"696":1,"697":2,"699":2,"705":1,"706":1,"707":1,"709":1,"713":5,"714":1,"716":2,"717":1,"719":1,"720":1,"723":2,"724":9,"725":1,"733":3,"734":3,"736":1,"739":1,"740":2,"745":3,"746":5,"749":2,"751":2,"754":1,"755":1,"758":3,"763":1,"765":1,"767":1,"768":1,"769":1,"770":1,"771":3,"772":1,"773":2,"774":1,"779":1,"780":1,"781":1,"782":1,"783":3,"784":4,"786":1,"788":2,"789":4,"790":1,"794":2}}],["bzsidenode",{"2":{"168":6,"169":6,"172":8}}],["blind",{"2":{"561":2}}],["blue",{"2":{"146":1}}],["blobtypes",{"2":{"420":4,"426":6}}],["blobtxs",{"2":{"422":1}}],["blobtx",{"2":{"414":1,"426":4}}],["blobclient",{"2":{"408":2}}],["blobchan",{"2":{"324":2}}],["blobresponse",{"2":{"324":2}}],["blobpointer",{"2":{"107":1}}],["blobspace",{"0":{"476":1,"496":1},"1":{"477":1,"478":1}}],["blobsharerange",{"2":{"159":2,"172":4}}],["blobs",{"0":{"288":1,"323":1,"324":1,"350":1,"408":1,"414":1},"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,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"427":1},"2":{"107":1,"146":1,"159":1,"289":1,"291":2,"323":5,"324":11,"325":13,"348":1,"365":1,"386":1,"402":1,"408":13,"409":17,"414":1,"415":1,"418":1,"419":3,"425":2,"477":2,"480":1,"513":1,"734":1,"746":1}}],["blobstreamgit",{"2":{"413":1}}],["blobstreamwrapper",{"2":{"171":4}}],["blobstreamxcd",{"2":{"217":1}}],["blobstreamxdatacommitmentstored",{"2":{"153":4,"169":1,"170":4,"171":3}}],["blobstreamxwrapper",{"2":{"153":14,"170":6,"171":4}}],["blobstreamx",{"0":{"217":1},"1":{"218":1,"219":1},"2":{"89":4,"107":3,"109":2,"126":2,"127":15,"129":1,"153":14,"163":6,"169":4,"170":4,"172":5,"209":1,"211":2,"212":5,"213":2,"217":5,"219":4,"220":9,"221":2,"224":7,"226":3,"238":3,"239":1}}],["blobstream",{"0":{"95":1,"109":1,"123":1,"126":1,"132":1,"133":1,"141":1,"144":1,"153":1,"174":1,"209":1,"229":1,"230":1,"231":1,"232":1,"236":1,"237":1,"238":1,"239":1,"240":1,"241":1,"243":1,"412":1},"1":{"96":1,"97":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":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,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":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,"200":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"230":1,"231":2,"232":1,"233":2,"234":2,"235":2,"236":1,"237":1,"238":1,"239":2,"240":2,"241":2,"242":2,"243":1,"413":1},"2":{"27":1,"88":3,"89":6,"94":1,"95":1,"106":1,"108":1,"109":1,"110":1,"126":4,"127":8,"130":1,"131":9,"133":3,"134":2,"135":4,"136":3,"137":1,"139":2,"141":1,"145":2,"146":2,"148":8,"150":2,"169":2,"172":8,"173":1,"174":2,"175":2,"177":2,"180":1,"183":1,"184":2,"187":2,"195":1,"210":1,"212":2,"221":1,"225":3,"226":1,"227":4,"228":2,"230":11,"231":3,"233":2,"234":2,"235":3,"236":5,"237":6,"238":9,"239":3,"240":4,"241":2,"242":9,"243":3,"287":1,"412":3,"413":6}}],["blob",{"0":{"158":1,"176":1,"177":1,"178":1,"179":1,"180":1,"192":1,"193":1,"194":1,"199":1,"201":1,"202":1,"298":1,"380":1,"415":1},"1":{"159":1,"177":1,"178":1,"179":1,"180":1,"193":1,"194":1,"200":1,"201":1,"202":1},"2":{"89":1,"91":1,"107":1,"108":2,"146":2,"148":1,"153":4,"154":1,"156":6,"158":1,"159":7,"164":1,"165":1,"169":2,"170":2,"172":4,"175":1,"176":1,"177":8,"178":2,"179":1,"182":1,"184":3,"185":1,"192":5,"193":1,"195":1,"197":1,"199":1,"200":5,"203":7,"208":2,"295":4,"296":1,"298":5,"299":2,"323":30,"324":5,"325":2,"358":8,"363":12,"364":1,"365":10,"366":3,"380":5,"400":8,"401":6,"402":51,"404":11,"405":1,"408":34,"409":2,"414":2,"415":2,"418":6,"419":6,"420":6,"423":2,"424":3,"425":24,"426":14,"427":1,"477":1,"478":1,"480":1,"599":4,"600":2,"601":2,"724":4}}],["blocktimes",{"2":{"335":1}}],["blockdataroot",{"2":{"169":3,"172":8}}],["blockres",{"2":{"153":2,"159":2}}],["blocknumber",{"2":{"121":2,"153":2,"170":2,"285":2,"385":2}}],["block",{"0":{"90":1,"139":1,"142":1,"153":1,"372":1,"421":1,"441":1,"631":1,"636":1,"649":2,"794":2},"2":{"89":1,"91":12,"127":16,"128":2,"129":1,"131":5,"133":1,"134":34,"135":2,"136":4,"137":17,"139":15,"146":4,"148":3,"150":3,"153":10,"158":1,"159":6,"160":1,"161":1,"169":16,"170":4,"172":6,"177":3,"180":1,"181":3,"183":1,"192":1,"196":1,"208":1,"218":4,"224":2,"225":6,"230":1,"237":2,"238":4,"299":2,"326":2,"335":1,"337":1,"351":1,"363":1,"365":6,"366":1,"372":10,"380":1,"384":3,"402":2,"410":2,"415":2,"421":2,"426":2,"433":1,"436":3,"437":4,"438":2,"439":4,"440":4,"441":2,"444":1,"447":1,"449":1,"450":8,"451":3,"452":4,"453":3,"455":2,"457":2,"458":10,"459":13,"477":3,"479":1,"481":4,"484":3,"487":1,"499":1,"513":1,"520":2,"537":1,"549":2,"606":2,"629":1,"631":2,"634":3,"635":1,"636":2,"637":1,"647":3,"649":5,"666":2,"678":2,"679":1,"682":4,"708":1,"724":3,"734":1,"783":1,"789":1,"794":5}}],["blocks",{"0":{"137":1},"2":{"84":2,"90":1,"134":3,"135":4,"136":1,"137":12,"139":13,"148":4,"154":1,"170":2,"181":2,"187":2,"217":1,"225":1,"335":2,"337":3,"421":2,"436":1,"440":2,"441":1,"444":1,"451":1,"452":1,"480":3,"481":3,"484":1,"512":1,"520":3,"551":2,"559":1,"631":3,"634":4,"635":2,"637":1,"733":1,"745":1,"746":2,"755":2,"777":1}}],["blockscout",{"2":{"69":1,"90":2}}],["blockchains",{"0":{"262":1,"335":1,"448":1,"456":1},"1":{"263":1,"264":1,"265":1},"2":{"59":3,"62":1,"65":1,"136":1,"250":1,"255":2,"261":3,"263":2,"264":2,"265":1,"301":4,"436":2,"438":1,"446":1,"448":1,"456":6,"457":1,"551":1}}],["blockchain",{"0":{"261":1,"301":1,"445":1,"454":1},"1":{"302":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"455":1},"2":{"19":1,"31":1,"40":1,"57":1,"59":1,"134":3,"135":3,"139":1,"143":1,"247":3,"260":1,"261":3,"263":3,"301":1,"313":2,"335":2,"336":2,"394":3,"404":3,"426":2,"436":1,"437":1,"443":1,"445":1,"446":1,"448":1,"449":2,"455":3,"456":1,"457":2,"460":1,"483":2,"496":1,"497":2,"622":1,"636":2,"638":1,"677":1,"680":1,"755":1}}],["blog",{"2":{"36":1,"38":1,"305":43,"307":6,"310":3,"313":12}}],["bidirectional",{"2":{"619":1}}],["bitszn",{"2":{"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["bitter",{"2":{"561":2}}],["bitcoin",{"2":{"301":1}}],["billion",{"2":{"489":1}}],["bip44",{"2":{"432":2}}],["bip39",{"2":{"271":1}}],["bi",{"2":{"419":2}}],["bigger",{"2":{"436":1,"440":1}}],["big",{"2":{"153":8,"165":4,"168":4,"169":8,"172":18}}],["bincd",{"2":{"223":1}}],["bin",{"2":{"218":2,"220":2,"223":5,"224":2,"275":2,"276":2,"391":2,"549":2,"581":1,"582":1,"610":1,"663":2,"664":9}}],["binaries",{"2":{"212":2,"220":1,"582":2,"610":2,"662":1}}],["binarymerkleproof",{"2":{"127":4,"128":1,"153":2,"163":4,"168":9,"169":5,"172":8}}],["binary",{"0":{"581":1,"582":1,"610":1,"612":1},"2":{"94":1,"102":1,"108":2,"127":2,"128":1,"131":1,"148":1,"150":1,"154":1,"160":2,"163":2,"169":2,"183":2,"184":1,"220":5,"223":1,"224":1,"268":4,"290":1,"396":1,"525":1,"530":2,"552":2,"557":1,"580":1,"581":5,"582":4,"609":4,"610":4,"612":1,"649":1,"653":1,"678":4,"679":4,"711":1,"794":1}}],["bind",{"2":{"153":6,"170":2,"171":2,"172":4,"643":1}}],["bindings",{"2":{"145":3,"153":2,"172":2,"238":1}}],["binding",{"2":{"31":1,"153":2,"170":2,"172":2}}],["biometric",{"2":{"33":3}}],["b",{"2":{"31":2,"32":1,"34":2,"139":10,"172":24,"408":4,"413":1,"488":1,"489":1,"581":6,"609":1,"687":8}}],["brew",{"2":{"545":1,"663":4}}],["brevity",{"2":{"456":1}}],["break",{"2":{"505":1,"615":1}}],["breaking",{"2":{"420":1,"679":1}}],["breaks",{"2":{"37":1,"43":1}}],["br",{"2":{"313":2}}],["brush",{"2":{"261":1}}],["broken",{"2":{"561":2,"678":1}}],["browsers",{"2":{"346":1}}],["browser",{"0":{"463":1,"468":1},"2":{"80":1,"463":1,"545":1,"736":1}}],["broadcasting",{"2":{"513":1,"564":2,"573":2,"734":1,"746":1,"747":1,"789":2}}],["broadcasttx",{"2":{"426":2}}],["broadcastforge",{"2":{"308":1,"309":1}}],["broadcast",{"2":{"75":1,"219":2,"299":2,"308":1,"309":1,"317":1,"457":1,"549":4,"573":2,"749":1}}],["broadcastcd",{"2":{"75":1,"317":1}}],["broader",{"2":{"30":1,"43":1,"46":1,"65":1,"720":1}}],["branding",{"0":{"58":1}}],["brand",{"2":{"47":1,"58":1}}],["branch",{"2":{"2":3}}],["brightlystake",{"2":{"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["brightest",{"2":{"65":1}}],["bridging",{"0":{"66":1},"1":{"67":1,"68":1,"69":1,"70":1,"71":1,"72":1},"2":{"66":1,"85":1,"237":2,"250":1}}],["bridge=",{"2":{"584":4}}],["bridgefulllight",{"2":{"269":1,"270":1,"271":1}}],["bridgesudo",{"2":{"605":1}}],["bridges",{"2":{"237":1,"755":1}}],["bridgecreator",{"2":{"98":1,"99":1}}],["bridge",{"0":{"67":1,"70":1,"250":1,"512":1,"519":1,"520":1,"522":1,"524":1,"526":1,"527":1,"528":1,"529":1,"629":1,"733":1,"743":1,"745":1,"750":1,"777":1,"786":1,"787":1,"788":1},"1":{"68":1,"69":1,"71":1,"72":1,"520":1,"521":1,"522":1,"523":2,"524":1,"525":2,"526":2,"527":2,"528":3,"529":2,"630":1,"631":1,"744":1,"745":1,"746":1,"788":1},"2":{"24":2,"27":3,"28":1,"66":2,"68":1,"69":1,"71":1,"72":2,"82":2,"86":1,"91":8,"92":1,"98":1,"99":1,"103":1,"135":2,"172":4,"230":1,"250":2,"267":1,"269":2,"270":2,"271":2,"278":1,"287":1,"354":1,"456":1,"510":6,"512":1,"513":2,"519":2,"520":4,"521":1,"525":1,"526":9,"527":12,"528":9,"529":2,"583":2,"584":4,"594":2,"596":1,"603":1,"604":4,"605":10,"615":2,"616":1,"619":1,"621":3,"629":1,"652":1,"732":1,"733":1,"734":2,"740":1,"745":1,"746":2,"750":7,"755":1,"757":1,"769":1,"777":20,"778":1,"784":3,"786":2,"787":2,"788":2}}],["briefly",{"2":{"44":1,"85":1}}],["bringing",{"2":{"545":1}}],["bring",{"2":{"41":1,"65":1}}],["bound",{"2":{"724":1}}],["bounds",{"2":{"183":2,"188":1}}],["bot",{"2":{"683":1}}],["both",{"2":{"23":1,"24":1,"28":1,"86":1,"91":1,"95":1,"119":1,"135":1,"195":1,"213":1,"235":1,"337":1,"419":1,"449":1,"453":1,"456":1,"477":1,"486":1,"545":1,"553":1,"573":1,"580":1,"683":1,"771":1}}],["bonded",{"2":{"551":2}}],["bonddenomalias",{"2":{"503":1}}],["bonddenom",{"2":{"502":1}}],["bonus",{"2":{"405":1,"425":2}}],["bona",{"2":{"34":1}}],["border",{"2":{"313":2}}],["borrowing",{"2":{"40":1}}],["bob",{"2":{"305":4}}],["box",{"2":{"265":1}}],["boxes",{"2":{"71":1}}],["bootstrappeers",{"2":{"618":2}}],["bootstrappers",{"2":{"618":1,"734":1}}],["bootstrapper",{"2":{"584":1,"618":3,"750":1}}],["bootstrapping",{"0":{"497":1},"2":{"481":1}}],["bootstrap",{"0":{"618":1},"2":{"497":1,"621":1}}],["boolean",{"2":{"586":2,"589":1}}],["bool",{"2":{"127":2,"153":2,"172":2,"305":6}}],["boost",{"2":{"46":1}}],["book",{"2":{"40":1,"143":1}}],["board",{"2":{"43":2}}],["body",{"2":{"7":1,"564":2}}],["bare",{"2":{"655":1}}],["barrier",{"2":{"84":2}}],["bak",{"2":{"627":10,"644":2}}],["bad",{"2":{"441":2}}],["balances",{"0":{"296":1,"567":1},"2":{"300":2,"355":1,"445":2,"513":1,"526":1,"535":5,"564":1,"567":6,"579":2,"673":1,"734":1,"746":1}}],["balancecelestia",{"2":{"295":1,"296":1,"368":1}}],["balance",{"0":{"368":1,"369":1,"375":1},"2":{"91":4,"235":1,"287":1,"295":4,"296":2,"300":1,"315":1,"368":2,"369":7,"396":3,"433":1,"434":1,"537":1,"567":3,"633":1,"673":1,"713":1}}],["batcher",{"2":{"337":5,"385":1,"387":1,"392":4}}],["batched",{"2":{"234":1}}],["batches",{"0":{"387":1},"2":{"84":2,"88":1,"107":1,"109":2,"128":1,"153":2,"170":2,"172":2,"180":1,"224":5,"238":2,"337":3,"387":2,"458":1}}],["batchposter",{"2":{"110":1}}],["batch",{"0":{"88":1},"2":{"84":4,"85":1,"86":2,"88":2,"89":5,"91":3,"93":1,"107":8,"129":2,"148":4,"169":1,"217":1,"225":1,"387":4,"682":8}}],["backward",{"2":{"677":1}}],["backed",{"2":{"646":2}}],["backers",{"2":{"488":2,"489":2}}],["backend=test",{"2":{"789":2}}],["backend=",{"2":{"549":2}}],["backend",{"2":{"269":6,"270":6,"271":6,"275":2,"276":2,"299":2,"309":2,"315":2,"356":4,"527":2,"531":4,"549":8,"569":3,"573":4,"578":2,"589":1,"673":2,"699":2,"700":2,"702":2,"714":4}}],["background",{"0":{"596":1,"772":1},"1":{"773":1,"774":1,"775":1,"776":1,"777":1,"778":1},"2":{"152":2,"153":4,"159":4,"172":2,"401":2,"402":2,"404":2,"529":1,"639":1,"675":1,"717":1,"772":1,"773":1,"774":1,"778":1,"788":1}}],["back",{"2":{"72":1,"88":1,"107":1,"110":1,"139":1,"188":3,"208":1,"211":1,"287":1,"323":2,"337":1,"400":1,"402":2,"404":2,"405":2,"408":2,"425":2,"681":1,"691":1}}],["basis",{"2":{"679":1}}],["basically",{"2":{"265":1}}],["basic",{"0":{"359":1},"1":{"360":1,"361":1,"362":1},"2":{"114":2,"278":2,"305":2,"313":2,"358":1,"359":1,"545":1,"646":1,"650":1,"654":2}}],["basechainhandle",{"2":{"687":8}}],["baseaccount",{"2":{"566":3}}],["basefeepergas",{"2":{"384":1}}],["base64=truecelestia",{"2":{"365":2}}],["base64=true",{"2":{"365":3}}],["base64",{"2":{"151":1,"156":1,"161":1,"165":1,"166":1,"313":2,"363":4,"365":4,"381":1,"385":3,"386":1}}],["base",{"0":{"97":1,"99":1,"566":1},"2":{"82":2,"84":13,"85":6,"86":1,"89":2,"91":12,"92":1,"95":1,"97":1,"121":1,"194":1,"225":1,"238":1,"242":2,"285":1,"313":1,"456":2,"565":4}}],["based",{"2":{"23":2,"24":1,"80":1,"131":1,"223":1,"233":1,"330":1,"335":2,"366":1,"394":1,"415":2,"418":2,"419":3,"430":1,"448":1,"460":1,"478":1,"483":1,"484":1,"497":1,"581":1,"609":1}}],["bashmoniker=",{"2":{"789":1}}],["bashmake",{"2":{"581":1,"609":4}}],["bashhermes",{"2":{"683":1,"684":1,"686":3,"687":2}}],["bashvalidator",{"2":{"783":1}}],["bashvim",{"2":{"682":1}}],["bashver=",{"2":{"664":3}}],["bashzsh",{"2":{"664":1}}],["bashpersistent",{"2":{"627":3}}],["bashprometheus",{"2":{"545":1}}],["bashprivate",{"2":{"91":1,"309":1,"315":1}}],["bashsuccess",{"2":{"684":1,"687":2}}],["bashsudo",{"2":{"605":2,"656":1,"663":4}}],["bashseeds=$",{"2":{"627":2}}],["bashnano",{"2":{"605":1}}],["bashnpm",{"2":{"315":1}}],["bashbash",{"2":{"582":1,"610":1}}],["bashbalances",{"2":{"567":2}}],["bashblockhash",{"2":{"121":1,"285":1}}],["bash$home",{"2":{"390":3}}],["bashgas",{"2":{"564":1}}],["bashgrafana",{"2":{"545":1}}],["bashgo",{"2":{"322":1,"664":1}}],["bashgit",{"2":{"87":1,"581":3,"609":3}}],["bashanvil",{"2":{"308":1}}],["bashanvilanvil",{"2":{"283":1}}],["bashroot",{"2":{"276":1}}],["bashdocker",{"2":{"275":4,"276":4,"655":3,"657":3,"658":3}}],["bash2024",{"2":{"223":1,"649":1,"794":1}}],["bashenter",{"2":{"783":1}}],["basherror",{"2":{"605":1}}],["bashecho",{"2":{"121":1,"285":1,"664":2}}],["bashexport",{"2":{"75":2,"76":1,"120":2,"283":1,"284":2,"292":1,"299":1,"308":1,"309":1,"317":3,"360":2,"361":1,"375":1,"380":1,"384":1,"385":1,"557":1,"563":1,"569":1,"571":1,"584":2,"655":7}}],["bash0x000000000000000000000000000000000000000000000000000000000000000a0x000000000000000000000000000000000000000000000000000000000000000a",{"2":{"121":1,"285":1}}],["bash",{"2":{"116":1,"117":1,"120":1,"269":3,"270":3,"271":3,"275":2,"276":1,"280":1,"281":1,"284":1,"356":2,"362":2,"380":1,"544":1,"549":1,"557":1,"561":1,"562":2,"564":3,"565":2,"566":2,"567":2,"582":1,"589":1,"597":2,"599":1,"600":1,"601":1,"610":1,"627":1,"656":1,"657":1,"658":1,"663":3,"664":4,"688":2}}],["bashfatal",{"2":{"604":1}}],["bashforge",{"2":{"115":1,"116":1,"117":1,"120":1,"279":1,"280":1,"281":1,"283":1,"284":1,"304":1,"306":1,"308":1,"309":1}}],["bashfunding",{"2":{"91":1}}],["bashcargo",{"2":{"407":1}}],["bashcast",{"2":{"76":3,"121":2,"285":2,"308":2,"309":2,"317":3,"384":1,"385":1}}],["bashcurl",{"2":{"380":1,"386":1,"544":1}}],["bashcp",{"2":{"310":1}}],["bashcontainer",{"2":{"275":1,"276":1}}],["bashcelestia",{"2":{"89":2,"294":3,"295":3,"296":1,"297":1,"298":1,"299":1,"300":1,"354":3,"355":6,"356":3,"358":3,"361":1,"362":2,"363":4,"365":5,"366":1,"368":1,"369":2,"370":1,"371":1,"372":2,"373":1,"374":1,"375":3,"376":1,"377":2,"378":1,"423":1,"424":1,"513":2,"569":3,"571":2,"584":1,"597":2,"602":2,"603":2,"609":1,"627":6,"690":1,"734":1,"783":2,"786":1,"787":1}}],["bashcd",{"2":{"75":2,"77":1,"115":1,"224":1,"279":1,"310":1,"317":2,"318":1,"556":1,"558":1,"561":1,"581":1,"609":1,"638":3,"656":1,"664":4}}],["bashyarn",{"2":{"1":1}}],["bandwidth",{"2":{"335":2,"352":1,"451":1,"521":1,"623":1,"667":1,"709":1,"757":1,"758":1,"780":1}}],["bank",{"2":{"299":2,"300":2,"330":1,"535":10,"549":4,"567":4,"579":2}}],["banner",{"2":{"44":1}}],["banners",{"2":{"44":1}}],["ban",{"0":{"15":1,"16":1},"2":{"14":1,"15":2,"16":1}}],["buckets",{"2":{"682":8}}],["bug",{"2":{"604":2,"758":1}}],["bugs",{"2":{"31":1}}],["burned",{"2":{"536":1}}],["buffer",{"2":{"313":6}}],["bubs",{"0":{"244":1,"246":1,"277":1,"284":1,"317":1},"1":{"245":1,"246":1,"247":2,"248":2,"249":2,"250":2,"251":2,"252":2,"253":2,"254":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"318":1,"319":1,"320":1},"2":{"244":2,"245":3,"246":2,"247":1,"248":1,"249":3,"250":2,"251":2,"252":1,"253":1,"254":1,"277":1,"278":5,"284":8,"286":1,"317":6,"339":3,"340":1}}],["budget",{"2":{"41":3,"46":1}}],["buy",{"2":{"34":1}}],["businesses",{"2":{"44":1}}],["business",{"2":{"34":1}}],["buttonstyle",{"2":{"313":6}}],["buttoncontainerstyle",{"2":{"313":6}}],["button",{"2":{"85":1,"86":1,"313":16,"432":4,"468":1,"545":1}}],["but",{"2":{"8":1,"24":1,"27":1,"30":1,"32":1,"33":1,"34":2,"35":1,"40":1,"41":3,"44":1,"47":1,"48":1,"65":1,"84":4,"107":2,"108":1,"134":1,"135":2,"179":1,"217":1,"219":1,"228":1,"235":1,"237":2,"261":1,"297":1,"309":1,"332":1,"333":1,"392":1,"421":1,"445":1,"458":1,"480":1,"489":2,"505":1,"546":1,"557":1,"560":1,"634":2,"647":1,"649":1,"665":1,"678":1,"683":1,"698":1,"720":1,"740":1,"755":1,"784":1,"794":1}}],["buildmake",{"2":{"609":1}}],["builds",{"2":{"557":1}}],["builders",{"2":{"263":1}}],["builder",{"2":{"223":1}}],["buildcd",{"2":{"211":1}}],["buildforge",{"2":{"116":1,"280":1}}],["build",{"0":{"223":1,"224":1,"255":1,"400":1},"1":{"256":1,"257":1,"258":1,"259":1,"260":1,"261":1,"262":1,"263":1,"264":1,"265":1},"2":{"43":1,"116":1,"122":1,"174":1,"175":1,"187":1,"192":1,"211":2,"212":2,"220":3,"222":2,"223":14,"224":22,"230":1,"241":1,"246":1,"263":1,"280":1,"286":1,"301":3,"320":1,"329":1,"496":1,"556":2,"557":3,"558":2,"561":2,"581":1,"609":10,"663":4,"664":1,"692":1}}],["building",{"0":{"1":1,"246":1,"256":1,"310":1,"398":1,"454":1,"581":1},"1":{"247":1,"248":1,"249":1,"250":1,"251":1,"252":1,"253":1,"257":1,"258":1,"259":1,"311":1,"399":1,"400":1,"401":1,"402":1,"403":1,"404":1,"455":1},"2":{"175":1,"224":1,"257":1,"302":1,"310":1,"342":1,"396":1,"609":1,"662":1,"711":1}}],["built",{"0":{"245":1,"582":1,"610":1},"2":{"1":1,"108":1,"175":1,"177":1,"187":1,"223":2,"233":1,"237":1,"268":1,"320":1,"336":2,"337":1,"340":1,"455":2,"481":1,"498":1,"520":2,"551":1,"580":1,"582":3,"610":3,"680":2,"690":1}}],["bypassing",{"2":{"596":1}}],["bytes=",{"2":{"724":1}}],["bytes28",{"2":{"165":2,"166":2}}],["bytes1",{"2":{"165":2,"166":2}}],["bytes",{"0":{"724":1},"2":{"127":4,"163":2,"164":2,"165":5,"166":1,"167":4,"172":6,"183":1,"213":4,"323":4,"363":1,"402":2,"415":4,"418":1,"425":4,"426":2,"451":2,"452":3,"458":1,"723":1,"724":4}}],["bytes32",{"2":{"127":8,"151":1,"156":1,"161":1,"165":2,"168":3,"169":2,"172":2,"213":11,"215":3,"216":2,"228":1}}],["byte",{"2":{"89":3,"134":8,"153":10,"165":17,"166":7,"168":4,"169":6,"172":36,"211":2,"235":1,"323":4,"324":2,"325":2,"402":4,"419":1,"420":1,"425":4,"426":4}}],["by",{"0":{"153":1,"372":1,"632":1},"2":{"8":1,"17":1,"19":1,"21":1,"23":2,"24":2,"30":6,"31":4,"33":3,"34":11,"38":1,"41":1,"42":1,"43":1,"46":1,"47":1,"48":1,"60":1,"65":2,"79":1,"83":1,"84":2,"85":1,"87":1,"88":1,"89":2,"91":3,"107":1,"110":1,"116":1,"117":2,"119":1,"127":2,"129":1,"131":7,"133":1,"134":1,"135":5,"137":2,"139":2,"148":3,"149":1,"150":1,"151":1,"153":6,"156":1,"163":4,"166":1,"169":2,"172":6,"173":1,"177":2,"180":1,"181":1,"183":2,"184":2,"187":1,"192":1,"196":1,"211":1,"213":2,"214":1,"215":2,"221":1,"223":2,"224":1,"225":3,"227":2,"228":1,"230":2,"238":1,"239":1,"244":1,"245":1,"263":1,"264":1,"265":1,"267":1,"275":1,"276":2,"280":1,"281":2,"287":1,"291":1,"293":1,"299":1,"305":6,"309":1,"310":1,"330":1,"334":2,"335":1,"337":2,"346":1,"348":1,"350":1,"356":3,"363":3,"372":4,"373":4,"378":6,"387":2,"390":1,"396":2,"400":1,"402":1,"409":2,"413":1,"416":2,"417":6,"418":5,"419":6,"420":2,"421":2,"433":1,"437":1,"438":1,"439":1,"440":1,"441":1,"450":2,"451":1,"453":2,"455":3,"457":2,"458":5,"459":3,"478":1,"480":3,"481":3,"484":1,"489":1,"490":1,"497":1,"498":1,"527":2,"530":4,"536":2,"544":1,"545":3,"546":1,"549":2,"550":1,"551":1,"565":1,"579":1,"583":3,"585":1,"594":3,"609":1,"616":2,"618":2,"621":2,"634":1,"636":1,"637":1,"643":2,"646":2,"649":2,"656":1,"673":2,"678":2,"680":2,"681":1,"687":1,"694":1,"695":1,"696":1,"697":1,"704":1,"706":1,"711":1,"714":3,"724":4,"735":1,"747":1,"755":2,"765":1,"783":1,"794":2}}],["beautiful",{"2":{"310":1}}],["bearer",{"2":{"380":2,"386":2}}],["bear",{"2":{"31":2,"34":2}}],["bedrock",{"2":{"245":1,"339":1}}],["belong",{"2":{"163":2,"177":2,"183":1}}],["below",{"2":{"21":1,"22":1,"34":1,"47":1,"66":1,"84":1,"89":1,"95":1,"96":1,"97":1,"120":1,"136":1,"146":1,"169":1,"180":1,"197":1,"239":1,"284":1,"322":1,"385":1,"386":1,"407":1,"455":1,"458":2,"481":1,"484":1,"488":1,"489":1,"510":1,"579":1,"581":1,"582":1,"610":1,"657":1,"658":1,"673":1,"713":1,"726":1,"728":1,"744":1,"746":1,"750":1,"783":1,"789":2}}],["bech",{"2":{"783":2}}],["bech32prefixconspub",{"2":{"432":2}}],["bech32prefixconsaddr",{"2":{"432":2}}],["bech32prefixvalpub",{"2":{"432":2}}],["bech32prefixvaladdr",{"2":{"432":2}}],["bech32prefixaccpub",{"2":{"432":2}}],["bech32prefixaccaddr",{"2":{"432":2}}],["bech32config",{"2":{"432":2}}],["because",{"2":{"108":1,"137":1,"182":1,"265":1,"308":1,"309":1,"335":1,"396":1,"402":1,"436":1,"446":1,"599":1,"635":1,"681":1}}],["becomes",{"2":{"436":2,"621":1}}],["become",{"2":{"31":1,"53":1,"56":1}}],["behind",{"2":{"107":1,"335":1,"505":1,"644":1,"765":1}}],["behave",{"2":{"548":1}}],["behavior",{"2":{"8":2,"9":2,"11":1,"13":2,"14":1,"15":1,"16":1,"358":1,"551":1,"596":1,"637":1,"708":1}}],["behalf",{"2":{"30":1,"34":2,"293":1}}],["beefy",{"2":{"220":1,"223":1,"224":1}}],["beer",{"2":{"41":1}}],["been",{"2":{"27":1,"31":1,"34":4,"91":2,"94":1,"107":1,"110":2,"127":3,"177":1,"228":1,"296":1,"300":2,"308":1,"309":1,"346":1,"351":1,"396":1,"436":1,"445":1,"446":1,"481":2,"551":1,"565":1,"579":1,"594":1,"596":1,"687":1,"712":1,"723":1,"774":1,"778":1}}],["beginner",{"0":{"651":1},"2":{"651":1}}],["beginning",{"2":{"44":2,"165":2,"169":1,"217":1,"484":1}}],["beginkey",{"2":{"165":3,"184":2}}],["begin",{"2":{"38":1,"139":1,"184":1,"292":1,"313":2,"401":1,"545":1}}],["benefits",{"0":{"262":1},"1":{"263":1,"264":1,"265":1},"2":{"40":1,"44":1,"59":1,"62":1,"65":2,"255":2,"301":1}}],["benefit",{"2":{"34":2,"44":2,"46":1,"109":1}}],["beneficial",{"2":{"34":1,"48":1}}],["better",{"2":{"47":1,"48":1,"135":1,"175":1,"206":1,"208":1,"254":1,"481":1}}],["between",{"0":{"444":1,"685":1},"2":{"31":1,"42":1,"43":1,"85":1,"139":1,"184":1,"192":1,"211":1,"235":1,"250":2,"305":2,"456":1,"484":1,"583":1,"594":1,"666":1,"680":2,"681":1,"682":1,"685":1,"687":1,"755":1,"777":1}}],["betaarabicamocha",{"2":{"716":1}}],["betaarabica",{"2":{"390":1}}],["betamochaarabica",{"2":{"354":1,"355":2,"356":1,"432":1,"526":1,"528":1,"581":1,"609":1,"627":4,"638":1,"639":1,"655":2,"657":1,"658":1,"664":1,"672":1,"674":1,"712":1,"713":1,"714":1,"789":1}}],["beta",{"0":{"491":1,"587":1,"599":1,"719":1,"760":1,"761":1},"1":{"720":1,"721":1,"722":1,"723":1,"724":1,"725":1,"726":1,"727":1,"728":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"761":1},"2":{"24":1,"25":1,"28":1,"110":1,"145":1,"242":4,"269":3,"275":1,"276":1,"287":1,"338":1,"356":1,"380":1,"415":1,"491":1,"527":1,"587":1,"592":1,"593":3,"599":2,"606":1,"627":1,"655":1,"673":1,"679":3,"719":2,"720":2,"725":2,"734":1,"737":1,"739":2,"760":1,"767":1}}],["be",{"0":{"163":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1},"2":{"8":2,"11":2,"13":1,"21":1,"23":3,"26":3,"27":1,"29":1,"31":2,"33":1,"34":14,"40":3,"41":3,"43":1,"44":3,"45":4,"48":4,"53":1,"65":1,"71":2,"72":1,"76":1,"77":1,"83":1,"84":5,"85":1,"88":1,"89":4,"90":2,"95":1,"103":1,"107":3,"108":2,"109":2,"110":1,"117":1,"119":2,"122":1,"126":1,"131":1,"134":4,"135":5,"136":2,"137":3,"139":3,"145":8,"146":2,"148":5,"149":1,"150":1,"151":2,"152":1,"154":1,"155":1,"156":2,"158":1,"160":1,"161":3,"162":2,"164":2,"165":2,"166":2,"167":1,"168":1,"169":4,"170":2,"171":1,"172":3,"173":1,"175":3,"177":3,"178":4,"179":1,"180":2,"181":4,"183":2,"184":6,"187":2,"189":3,"191":2,"192":5,"194":1,"195":1,"196":4,"197":2,"199":2,"200":2,"202":1,"203":2,"206":1,"210":1,"211":11,"212":2,"213":1,"215":2,"217":3,"218":1,"219":3,"220":2,"223":1,"224":4,"225":3,"226":1,"227":1,"228":2,"230":1,"238":6,"239":2,"241":1,"243":1,"245":1,"263":4,"265":2,"267":1,"268":1,"269":2,"275":1,"276":1,"281":1,"287":3,"291":1,"293":1,"294":1,"301":2,"302":1,"305":2,"308":2,"310":1,"313":1,"315":2,"316":1,"317":1,"318":1,"320":2,"323":2,"330":1,"334":1,"335":3,"343":1,"346":2,"351":1,"354":1,"355":1,"356":1,"358":1,"359":2,"360":2,"363":6,"366":2,"369":1,"380":1,"387":3,"390":3,"392":1,"394":2,"395":1,"396":4,"397":1,"400":1,"402":1,"408":2,"413":1,"415":2,"416":1,"417":1,"418":3,"419":1,"420":2,"421":3,"426":4,"428":2,"429":2,"433":1,"434":1,"437":1,"440":1,"441":3,"443":2,"446":2,"447":1,"450":1,"451":1,"452":3,"453":1,"456":3,"458":2,"459":1,"477":2,"478":1,"479":1,"480":4,"481":3,"484":2,"489":2,"497":1,"505":2,"509":1,"513":1,"525":1,"526":1,"527":1,"528":1,"533":3,"536":5,"537":1,"543":1,"544":1,"546":1,"547":1,"548":1,"549":2,"551":4,"557":1,"568":1,"574":2,"579":1,"581":2,"582":1,"583":1,"586":1,"590":2,"592":2,"594":2,"602":4,"605":1,"610":1,"616":1,"618":1,"621":2,"629":1,"632":1,"637":5,"642":1,"643":1,"646":2,"647":1,"655":1,"656":2,"662":1,"673":4,"674":1,"676":2,"677":2,"678":3,"679":3,"680":1,"682":1,"683":2,"687":2,"690":3,"691":1,"696":1,"701":1,"702":1,"703":1,"706":1,"713":2,"714":1,"716":1,"720":1,"723":1,"724":4,"726":1,"744":1,"748":1,"750":1,"763":3,"765":2,"769":1,"774":1,"776":2,"777":2,"778":1,"786":1,"789":3}}],["best",{"2":{"8":1,"60":1,"65":1,"264":1,"508":1,"546":1,"725":1,"740":1,"769":1}}],["being",{"2":{"8":1,"24":1,"26":1,"84":1,"89":2,"102":1,"108":1,"137":1,"159":2,"161":1,"162":1,"165":2,"166":1,"167":1,"168":1,"169":3,"196":1,"211":1,"223":1,"330":1,"366":1,"430":1,"443":1,"459":1,"520":1,"592":1,"629":1,"635":1,"691":1}}],["before",{"0":{"36":1},"2":{"2":1,"24":2,"27":1,"42":2,"43":1,"45":1,"77":1,"85":1,"89":2,"110":1,"136":1,"139":3,"164":1,"180":1,"220":1,"238":1,"239":1,"314":1,"318":1,"358":1,"391":1,"432":3,"458":1,"559":1,"564":2,"592":1,"637":1,"656":1,"681":1,"697":1,"700":1,"774":1,"789":2}}],["rf",{"2":{"581":2,"604":4,"609":2,"638":6,"664":8}}],["rfc",{"2":{"128":1}}],["rsmt2d",{"2":{"326":2}}],["rsvp",{"2":{"36":1}}],["rgba",{"2":{"313":2}}],["r6a",{"2":{"226":1}}],["r",{"2":{"224":2,"373":2,"378":2,"385":4,"488":1,"489":2,"627":2}}],["r1cs",{"2":{"223":2}}],["r1",{"2":{"146":1}}],["r0",{"2":{"146":1}}],["rm",{"2":{"102":2,"581":2,"604":4,"609":2,"638":6,"664":16}}],["rc0",{"2":{"679":1}}],["rc",{"2":{"94":1,"102":2}}],["rblocks",{"2":{"86":1}}],["rpcs",{"2":{"513":1,"734":1}}],["rpcurls",{"2":{"312":2}}],["rpc",{"0":{"88":1,"247":1,"332":1,"342":1,"344":1,"345":1,"348":1,"357":1,"427":1,"509":1,"510":1,"512":1,"601":1,"642":1,"643":1,"726":1,"728":1,"733":1,"735":1,"743":1,"744":1,"745":1,"747":1},"1":{"248":1,"249":1,"343":1,"344":1,"345":1,"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"356":1,"357":1,"358":2,"359":2,"360":2,"361":2,"362":2,"363":2,"364":2,"365":2,"366":2,"367":2,"368":2,"369":2,"370":2,"371":2,"372":2,"373":2,"374":2,"375":2,"376":2,"377":2,"378":2,"379":1,"380":1,"381":1,"382":1,"643":1,"644":1,"645":1,"736":1,"744":1,"745":1,"746":1},"2":{"75":7,"76":16,"88":3,"89":18,"91":7,"107":1,"120":7,"121":9,"135":4,"142":1,"145":5,"146":1,"151":1,"152":2,"153":8,"156":1,"159":2,"161":1,"170":4,"171":2,"172":6,"211":7,"212":4,"213":12,"217":1,"218":5,"219":4,"220":5,"227":2,"247":2,"248":1,"249":1,"275":2,"276":2,"278":1,"283":7,"284":10,"285":9,"290":1,"292":2,"299":5,"300":2,"308":2,"309":6,"314":1,"317":25,"321":1,"322":1,"332":2,"341":1,"342":3,"344":3,"345":1,"348":1,"351":1,"354":1,"355":3,"357":1,"358":2,"359":4,"360":1,"361":1,"370":1,"371":1,"380":1,"382":2,"384":2,"385":2,"392":7,"396":2,"401":2,"402":2,"404":2,"406":1,"407":4,"408":4,"409":2,"410":2,"427":1,"432":10,"433":2,"434":2,"509":3,"510":4,"512":2,"513":1,"520":1,"526":1,"527":2,"535":4,"571":8,"572":1,"573":5,"583":2,"584":1,"594":2,"596":1,"597":2,"599":2,"601":3,"606":2,"611":1,"637":4,"642":1,"643":3,"644":1,"647":3,"655":5,"673":1,"682":16,"713":5,"714":3,"726":3,"728":25,"729":1,"730":2,"731":1,"733":2,"734":12,"744":3,"745":2,"746":6,"747":16,"749":1,"770":1,"786":1}}],["rigorous",{"2":{"719":1}}],["rights",{"2":{"30":2}}],["right",{"2":{"9":1,"34":1,"68":1,"89":1,"255":1,"313":6,"315":1,"468":1,"497":1,"678":1}}],["richer",{"2":{"342":1}}],["risk",{"2":{"230":1}}],["risks",{"2":{"34":2}}],["rounds",{"2":{"439":2}}],["round",{"2":{"372":2}}],["roughly",{"2":{"335":1,"421":1}}],["route",{"2":{"601":2}}],["router",{"2":{"583":1,"594":1}}],["routes",{"2":{"219":1,"601":1}}],["routine",{"2":{"42":1}}],["robusta",{"2":{"362":2}}],["robust",{"2":{"246":1}}],["rowproof",{"2":{"167":1,"168":1,"172":4}}],["rowproofs",{"0":{"168":1},"2":{"163":2,"168":2,"169":1,"172":2,"184":4}}],["rowroots",{"0":{"167":1},"2":{"163":4,"167":3,"172":4}}],["row",{"2":{"108":3,"131":4,"146":1,"148":6,"154":3,"156":8,"160":6,"161":8,"163":2,"165":1,"168":1,"169":1,"177":2,"183":2,"184":7,"372":2,"452":1,"458":4}}],["rows",{"2":{"108":2,"131":3,"148":1,"160":1,"163":8,"165":1,"167":1,"168":1,"177":2,"183":2,"450":1}}],["ro",{"2":{"102":2}}],["room",{"2":{"415":1}}],["rooms",{"2":{"40":1}}],["roots",{"2":{"107":1,"108":5,"109":1,"131":2,"137":1,"146":1,"148":4,"156":2,"160":3,"161":2,"163":2,"165":1,"167":8,"169":1,"172":6,"177":6,"234":1,"237":2,"372":4,"450":3,"451":1,"452":1,"458":2,"459":1,"520":1}}],["root",{"0":{"150":1},"1":{"151":1,"152":1},"2":{"68":1,"87":2,"90":1,"91":1,"94":1,"108":2,"109":2,"110":1,"121":2,"127":4,"128":4,"131":10,"134":1,"136":5,"137":1,"148":9,"150":8,"151":1,"153":12,"154":5,"156":1,"160":6,"163":14,"167":4,"168":1,"169":26,"172":10,"173":2,"177":8,"178":2,"183":5,"184":15,"196":4,"200":3,"203":2,"208":2,"230":1,"237":4,"276":2,"285":2,"310":1,"312":2,"359":1,"450":1,"452":1,"453":1,"458":2,"477":1}}],["role",{"0":{"495":1},"1":{"496":1,"497":1,"498":1,"499":1,"500":1,"501":1,"502":1,"503":1},"2":{"60":1,"61":1,"84":1,"403":2,"499":1}}],["roles",{"2":{"36":1}}],["rolling",{"2":{"551":1}}],["rollback",{"2":{"530":8}}],["roll",{"2":{"388":1,"389":1,"391":3}}],["rollkit",{"2":{"48":1,"61":2,"309":1,"315":1}}],["rollupinclusionproofs",{"2":{"164":1,"165":1,"166":1,"168":1,"169":1,"191":1}}],["rollupuserlogic",{"2":{"98":1,"99":1}}],["rollupadminlogic",{"2":{"98":1,"99":1}}],["rollupeventinbox",{"2":{"98":1,"99":1}}],["rollupcreator",{"2":{"89":1,"96":1,"97":1,"98":1,"99":1}}],["rollup",{"0":{"61":1,"66":1,"67":1,"69":1,"70":1,"71":1,"73":1,"79":1,"112":1,"133":1,"135":1,"138":1,"172":1,"208":1,"260":1,"309":1,"388":1},"1":{"67":1,"68":2,"69":2,"70":1,"71":2,"72":2,"74":1,"75":1,"76":1,"77":1,"78":1,"80":1,"81":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,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"136":1,"137":1,"139":1,"140":1,"141":1,"142":1,"143":1,"389":1,"390":1,"391":1,"392":1,"393":1},"2":{"44":1,"61":4,"66":2,"69":4,"71":1,"73":2,"74":1,"79":3,"82":1,"83":3,"86":2,"88":1,"90":1,"91":8,"92":2,"101":1,"111":1,"113":1,"114":1,"122":2,"127":15,"131":1,"133":3,"134":11,"135":15,"139":4,"143":1,"146":2,"148":2,"149":1,"154":2,"158":1,"166":1,"167":1,"169":2,"172":4,"174":1,"175":1,"178":4,"179":2,"180":1,"181":7,"184":3,"187":3,"188":7,"189":2,"191":1,"192":7,"195":2,"196":5,"199":2,"200":4,"203":4,"206":1,"208":2,"237":1,"239":1,"240":1,"241":1,"245":1,"246":1,"258":1,"260":1,"261":1,"263":2,"264":1,"265":5,"303":2,"309":2,"313":2,"314":1,"315":3,"316":1,"320":1,"337":4,"390":1,"392":2,"393":1,"453":1,"479":2,"481":7,"488":1,"496":1,"607":1,"673":2}}],["rollups",{"0":{"104":1,"174":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,"241":1,"258":1,"481":1,"497":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":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":2,"189":3,"190":3,"191":3,"192":2,"193":3,"194":3,"195":1,"196":2,"197":3,"198":3,"199":2,"200":3,"201":3,"202":3,"203":2,"204":2,"205":2,"206":1,"207":1,"208":1},"2":{"3":1,"43":1,"48":1,"59":1,"61":1,"82":1,"103":1,"133":1,"136":3,"173":1,"174":2,"175":2,"180":1,"187":3,"188":1,"195":2,"200":1,"206":2,"237":4,"241":1,"245":1,"255":1,"259":1,"260":1,"261":1,"263":2,"264":6,"265":3,"336":1,"339":1,"383":1,"388":1,"437":1,"447":1,"456":1,"479":1,"481":3,"497":1,"504":1,"505":1,"719":1,"740":1,"760":1,"763":1,"765":1}}],["roster",{"2":{"27":1}}],["rustasync",{"2":{"409":1,"410":1}}],["rustuse",{"2":{"408":1}}],["rust",{"0":{"406":1},"1":{"407":1,"408":1,"409":1,"410":1,"411":1},"2":{"224":2,"230":1,"236":1,"406":1,"412":1,"680":1,"681":1}}],["rule",{"2":{"31":1,"34":5}}],["rules",{"2":{"23":1,"135":1,"214":1,"456":1}}],["runtime",{"2":{"649":4,"687":8,"794":4}}],["runners",{"2":{"513":1}}],["running",{"0":{"100":1,"102":1,"103":1,"275":1,"306":1,"586":1,"755":1},"1":{"101":1,"102":1,"103":1,"587":1,"588":1,"589":1,"756":1,"757":1,"758":1},"2":{"24":1,"60":1,"74":1,"80":1,"87":1,"88":1,"89":1,"91":6,"92":1,"103":1,"107":2,"114":1,"117":2,"119":1,"126":1,"135":1,"220":1,"221":1,"227":1,"237":1,"276":1,"281":2,"290":1,"294":1,"303":2,"315":1,"316":1,"323":2,"329":1,"351":1,"352":1,"356":3,"359":1,"360":1,"380":1,"391":1,"392":2,"393":1,"396":4,"417":1,"425":2,"440":1,"508":1,"521":1,"527":2,"541":1,"543":1,"544":1,"545":1,"546":1,"549":2,"559":1,"572":1,"585":2,"590":1,"596":3,"601":1,"605":1,"609":1,"621":1,"623":1,"627":2,"639":2,"649":3,"651":1,"652":2,"655":1,"656":1,"658":1,"662":1,"663":2,"667":1,"673":2,"675":1,"676":1,"681":1,"683":1,"697":1,"706":1,"709":1,"714":3,"718":1,"725":1,"740":1,"746":1,"765":1,"769":1,"770":1,"771":1,"772":1,"773":1,"774":2,"780":1,"784":3,"789":2,"794":3}}],["rundown",{"2":{"255":1}}],["runs",{"2":{"117":2,"281":2,"419":1,"545":2,"557":1}}],["run",{"0":{"60":1,"89":1,"90":1,"220":1,"221":1,"388":1,"396":1,"527":1,"528":1,"556":1,"650":1,"671":1,"674":1,"716":1,"787":1,"789":1},"1":{"389":1,"390":1,"391":1,"392":1,"393":1,"528":1,"651":1,"652":1,"672":1,"673":1,"788":1},"2":{"1":1,"24":2,"27":1,"57":1,"60":2,"89":1,"90":1,"91":3,"92":1,"102":4,"103":1,"116":3,"117":1,"135":1,"211":1,"213":1,"217":4,"218":2,"219":1,"220":6,"223":3,"224":3,"226":2,"227":2,"243":1,"265":2,"274":1,"275":3,"280":3,"281":1,"283":1,"284":1,"291":1,"292":1,"293":2,"297":3,"300":1,"302":1,"306":1,"307":2,"309":1,"315":7,"322":1,"339":1,"342":1,"344":1,"346":1,"355":2,"357":1,"363":1,"388":1,"390":1,"391":1,"396":1,"399":1,"401":2,"402":2,"404":8,"407":1,"413":1,"508":1,"510":1,"513":1,"520":3,"525":1,"526":1,"528":1,"530":2,"542":1,"545":4,"550":1,"556":3,"557":2,"559":1,"564":1,"573":1,"578":1,"579":1,"581":2,"582":1,"583":2,"590":1,"594":2,"602":1,"604":1,"606":1,"610":1,"611":2,"612":1,"633":1,"638":1,"639":1,"650":1,"652":2,"653":6,"655":9,"657":9,"658":9,"662":1,"664":2,"672":1,"674":1,"675":1,"679":2,"680":1,"684":1,"698":1,"699":1,"700":1,"702":2,"703":1,"705":2,"712":1,"716":1,"725":2,"734":1,"740":3,"746":1,"755":1,"768":1,"769":1,"770":1,"771":3,"783":2,"784":1,"786":1,"787":1,"789":1}}],["rate=0",{"2":{"542":6,"789":6}}],["rates",{"2":{"484":1}}],["rate",{"2":{"434":3,"484":1}}],["rather",{"2":{"235":1,"261":1,"484":1,"504":1}}],["rapid",{"2":{"310":1}}],["rapidly",{"2":{"50":1}}],["rainbow",{"2":{"311":2,"312":8,"313":2}}],["rainbowkitprovider",{"2":{"312":6}}],["rainbowkit",{"2":{"301":1,"310":1,"311":2,"312":10,"313":2}}],["raises",{"2":{"84":1}}],["raise",{"2":{"4":1,"36":1}}],["raas",{"2":{"258":1,"388":2}}],["ram",{"2":{"220":1,"223":1,"224":1,"226":1,"352":1,"413":1,"521":1,"609":1,"623":1,"667":1,"709":1,"757":3,"758":2,"780":1}}],["rawlog",{"2":{"426":4}}],["raw",{"2":{"164":1,"434":1,"520":2,"564":2,"627":10,"663":2,"708":1,"783":2,"789":2}}],["rawmessage",{"2":{"134":2,"137":2}}],["rand",{"2":{"89":1}}],["randomly",{"2":{"450":1}}],["randomness",{"2":{"223":1}}],["random",{"2":{"89":1,"192":1,"223":1,"439":1,"457":1,"459":2}}],["ranges",{"0":{"225":1},"1":{"226":1,"227":1,"228":1},"2":{"225":2,"238":3}}],["range",{"0":{"160":1},"1":{"161":1,"162":1},"2":{"89":1,"107":3,"151":1,"153":6,"156":2,"158":1,"160":3,"165":4,"167":2,"168":4,"169":2,"170":6,"172":26,"183":1,"213":1,"219":2,"220":5,"224":14,"225":1,"226":1,"227":1,"228":2,"237":1,"238":2,"453":2}}],["radio",{"2":{"34":1}}],["race",{"2":{"7":1}}],["reinitializing",{"2":{"697":1}}],["reinitialize",{"2":{"592":1}}],["reindexing",{"2":{"647":2}}],["reindex",{"2":{"647":1}}],["rejoin",{"2":{"551":1}}],["rejected",{"2":{"459":1,"691":1}}],["rejects",{"2":{"459":1}}],["reject",{"2":{"9":1,"452":1}}],["reed",{"2":{"450":2,"452":5,"455":1,"458":1}}],["redelegate",{"2":{"466":1,"470":1,"475":1}}],["redeploy",{"2":{"309":1}}],["reducing",{"2":{"457":1}}],["reduce",{"2":{"263":1,"337":1}}],["reduced",{"2":{"40":1,"189":1,"263":1,"459":1,"720":1,"760":1}}],["redundant",{"2":{"441":1}}],["revoked",{"2":{"297":1}}],["revokes",{"2":{"293":1,"297":1}}],["revoke",{"0":{"297":1},"1":{"298":1},"2":{"293":1,"297":3}}],["revert",{"2":{"172":2}}],["reveal",{"2":{"108":1}}],["revisit",{"2":{"46":1}}],["revised",{"2":{"30":1}}],["reviewing",{"2":{"38":1}}],["reviewed",{"2":{"11":1,"21":1,"24":1}}],["review",{"0":{"85":1},"2":{"2":1,"36":1,"53":1,"73":1,"84":1,"85":2,"317":1,"469":2,"474":1}}],["retain",{"0":{"631":1},"2":{"629":1,"631":5,"634":4}}],["retrial",{"2":{"459":1}}],["retried",{"2":{"169":1}}],["retrievable",{"2":{"446":1,"479":1,"735":1}}],["retrievability",{"0":{"448":1,"479":1,"480":1},"1":{"480":1,"481":1},"2":{"445":1,"479":1,"480":1}}],["retrieval",{"2":{"442":1}}],["retrieving",{"0":{"323":1,"365":1,"408":1},"2":{"107":1,"442":1,"446":1,"637":1,"651":1}}],["retrievedblobs",{"2":{"323":2,"425":2}}],["retrieved",{"2":{"145":1,"164":1,"169":1,"359":1,"400":2,"401":2,"402":2,"408":8,"443":1,"481":1}}],["retrieve",{"2":{"107":2,"160":1,"313":1,"348":1,"365":1,"381":1,"390":2,"400":2,"401":2,"402":2,"403":1,"408":2,"443":1}}],["retryable",{"2":{"91":6}}],["retryables",{"2":{"91":4}}],["returning",{"2":{"323":2,"408":2}}],["return",{"2":{"120":1,"127":2,"137":10,"139":12,"153":2,"171":8,"212":2,"213":3,"224":2,"284":1,"305":4,"313":4,"365":3,"375":1,"403":2,"426":18,"432":2}}],["returns",{"2":{"89":1,"127":2,"135":4,"181":1,"213":1,"305":4,"324":1,"325":1,"326":1,"363":1,"402":1,"403":2,"409":1,"410":1}}],["returned",{"2":{"76":1,"213":3,"313":2,"317":1,"365":1,"453":1,"551":1,"691":1,"783":1}}],["rebasing",{"2":{"84":1}}],["rename",{"2":{"532":2}}],["renaming",{"2":{"532":2}}],["render",{"2":{"312":2}}],["rentals",{"2":{"46":1}}],["renewals",{"2":{"23":1}}],["renewal",{"2":{"23":1,"26":1}}],["refresh",{"2":{"682":2}}],["refreshments",{"0":{"41":1},"2":{"36":1,"41":6,"44":1}}],["refund",{"2":{"417":1,"419":1}}],["refunded",{"2":{"417":1}}],["refers",{"2":{"183":2,"520":1}}],["referred",{"2":{"145":1,"456":1,"458":2}}],["referrals",{"2":{"43":2}}],["referencing",{"2":{"136":1,"179":2,"181":1,"182":1,"208":2}}],["references",{"2":{"196":1}}],["referenced",{"2":{"177":1,"181":1,"192":1,"196":1,"200":1,"203":1}}],["reference",{"0":{"208":1},"2":{"0":1,"3":1,"30":1,"42":1,"148":1,"188":1,"191":1,"195":1,"199":1,"200":1,"208":3,"686":6}}],["refer",{"2":{"84":1,"145":1,"211":1,"217":1,"269":1,"275":2,"355":1,"356":1,"364":1,"405":1,"419":2,"425":1,"453":1,"484":1,"510":1,"526":1,"527":1,"551":1,"579":1,"592":1,"612":1,"653":1,"655":2,"673":2,"706":1,"713":1,"740":1,"786":1,"792":1}}],["reward",{"0":{"447":1},"2":{"31":1,"34":1,"43":1,"448":1}}],["rewards",{"0":{"538":1},"2":{"30":5,"31":10,"32":3,"33":1,"34":37,"466":1,"470":1,"475":1,"483":2,"487":1,"489":1,"490":1,"498":1,"499":1,"537":1,"538":3,"551":1}}],["regenerate",{"0":{"223":1}}],["regenerated",{"2":{"212":1}}],["regeneration",{"2":{"220":1}}],["regenerating",{"0":{"222":1},"1":{"223":1,"224":1},"2":{"212":1}}],["regen",{"2":{"149":4}}],["regions",{"2":{"47":1}}],["registry",{"2":{"211":1,"434":1,"627":3,"637":1}}],["registration",{"2":{"34":8,"36":1,"37":1,"53":1,"213":1,"219":1}}],["registering",{"2":{"219":1}}],["registerfunction",{"2":{"213":4}}],["register",{"0":{"213":1},"1":{"214":1,"215":1,"216":1},"2":{"34":2,"213":3,"224":1,"682":2}}],["registered",{"2":{"34":5,"36":1,"211":1,"214":2,"220":2,"243":1}}],["regular",{"2":{"42":1,"48":1,"82":1,"293":1,"455":1,"548":1}}],["regulation",{"2":{"31":1,"34":6}}],["regardless",{"2":{"7":1,"178":1,"428":1,"430":1}}],["reaped",{"2":{"421":1}}],["reapplying",{"2":{"26":1}}],["reapply",{"2":{"24":1}}],["reactjs",{"2":{"432":1}}],["reactmarkdown",{"2":{"313":4}}],["reactdom",{"2":{"312":4}}],["react",{"0":{"432":1},"2":{"301":1,"310":4,"311":2,"312":2,"313":2,"315":1,"431":1,"432":4}}],["reaching",{"2":{"494":1}}],["reaches",{"2":{"439":1,"484":1}}],["reached",{"2":{"426":2}}],["reach",{"2":{"24":1,"36":1,"43":1,"44":1,"45":1,"46":3,"301":1}}],["real",{"2":{"88":1,"719":1,"774":1,"778":1}}],["readme",{"2":{"391":1,"392":1,"413":1,"552":1}}],["reads",{"2":{"337":2,"403":1}}],["readable",{"2":{"313":2}}],["reader",{"2":{"135":1,"145":1}}],["reading",{"0":{"313":1},"2":{"135":2,"337":4,"355":1,"442":1,"526":1,"611":1,"673":1}}],["read",{"0":{"385":1},"2":{"30":1,"71":1,"76":1,"79":2,"94":1,"107":1,"108":1,"121":1,"134":1,"135":1,"217":1,"285":1,"301":1,"308":1,"309":1,"313":3,"317":1,"346":1,"350":1,"351":1,"358":1,"365":1,"385":1,"418":1,"661":1,"735":1,"740":1}}],["ready",{"2":{"27":1,"76":1,"120":1,"149":1,"257":1,"263":1,"284":2,"286":1,"315":1,"317":1,"394":1,"559":1,"637":1,"677":1,"678":1,"789":1}}],["reasonable",{"2":{"226":1}}],["reasonably",{"2":{"8":1}}],["reason",{"2":{"25":1,"31":2,"335":1}}],["reasons",{"2":{"9":1,"208":1}}],["resubmission",{"0":{"428":1,"429":1},"1":{"429":1,"430":1},"2":{"428":1}}],["resubmitted",{"2":{"429":1}}],["resubmit",{"2":{"421":2,"430":1}}],["results",{"2":{"148":1,"149":1,"372":2,"551":1,"647":4}}],["resulting",{"2":{"148":1,"452":1,"456":1,"596":1}}],["result",{"2":{"24":2,"32":1,"117":2,"121":2,"151":2,"156":4,"161":2,"164":1,"165":1,"218":1,"281":2,"285":2,"295":4,"296":2,"363":6,"365":8,"366":2,"368":2,"369":2,"370":2,"371":2,"372":2,"373":2,"375":2,"378":2,"380":3,"386":3,"450":1,"453":2,"456":3,"599":2,"600":3,"601":2,"661":1,"774":2}}],["resolved",{"2":{"681":1}}],["resolve",{"2":{"456":1}}],["resolving",{"2":{"338":1}}],["resolution",{"2":{"261":1,"604":1}}],["resources",{"0":{"379":1,"550":1,"640":1,"792":1},"1":{"380":1,"381":1,"382":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"647":1},"2":{"45":1,"46":2,"49":1,"50":2,"56":1,"57":1,"64":2,"93":1,"143":1,"329":1,"792":2}}],["resource",{"2":{"43":1,"56":1,"65":1,"235":1,"451":2,"457":1,"633":1}}],["resides",{"2":{"108":1}}],["resilience",{"2":{"27":1}}],["resetting",{"0":{"602":1}}],["reset",{"0":{"641":1,"697":1},"2":{"592":1,"603":4,"641":2,"649":2,"697":2,"794":2}}],["reserved",{"2":{"183":1,"458":2,"724":1}}],["reserves",{"2":{"34":1}}],["research",{"2":{"42":1,"44":1,"488":1}}],["restartsec=3",{"2":{"774":2,"776":2,"777":2,"778":2}}],["restart=on",{"2":{"774":2,"776":2,"777":2,"778":2}}],["restart",{"0":{"645":1},"2":{"293":1,"297":1,"544":1,"586":1,"605":3,"612":1,"645":1,"646":1,"647":1,"649":1,"794":1}}],["restaurant",{"2":{"40":1}}],["restaurants",{"2":{"40":2}}],["rest",{"2":{"136":1,"223":1,"346":1,"396":1,"432":10,"433":1,"434":1,"594":1,"681":1,"682":2,"729":3,"748":4}}],["restrict",{"2":{"214":1,"265":1}}],["restricted",{"2":{"34":5}}],["restrictions",{"2":{"31":1,"34":4,"489":1}}],["resale",{"2":{"34":2}}],["resp",{"2":{"324":6,"403":4,"426":20}}],["respectively",{"2":{"227":1}}],["respective",{"2":{"28":1,"135":1,"139":1,"146":1,"512":1,"513":1,"542":1,"637":2,"733":1,"734":1,"740":1,"745":1,"746":1}}],["respect",{"2":{"11":1,"30":1,"31":1,"32":1,"34":3}}],["respectfully",{"2":{"52":1}}],["respectful",{"2":{"8":1}}],["responses",{"0":{"647":1},"2":{"48":1,"394":1,"405":1,"647":9}}],["response",{"2":{"9":1,"48":1,"151":1,"156":1,"161":1,"163":1,"165":4,"166":1,"168":4,"169":1,"275":1,"276":1,"295":1,"313":4,"365":3,"368":1,"369":1,"370":1,"371":1,"403":2,"404":2,"426":4,"450":1,"599":2}}],["responsible",{"2":{"9":1,"11":1,"31":1,"32":1,"33":2,"84":1,"85":1,"88":1,"135":2,"337":1,"457":1,"481":2}}],["responsibilities",{"0":{"9":1}}],["responsibility",{"2":{"8":1,"9":1,"131":2,"430":1,"446":1}}],["requiring",{"2":{"457":1}}],["requires",{"2":{"128":1,"175":1,"180":1,"202":1,"211":1,"217":1,"226":1,"227":1,"228":1,"237":1,"240":1,"387":1,"446":1}}],["requirement",{"2":{"41":1,"452":1,"548":1}}],["requirements",{"0":{"352":1,"521":1,"623":1,"634":1,"667":1,"693":1,"709":1,"756":1,"780":1},"2":{"24":1,"34":4,"36":1,"43":1,"60":1,"61":1,"84":1,"206":1,"335":2,"352":1,"521":1,"623":1,"634":1,"667":1,"693":1,"709":1,"780":1}}],["required",{"2":{"32":1,"34":1,"35":1,"36":1,"84":1,"158":1,"197":1,"211":1,"220":1,"245":1,"263":1,"275":1,"309":1,"355":1,"361":1,"399":1,"400":1,"419":1,"452":1,"526":1,"579":1,"583":1,"592":1,"593":2,"594":1,"637":1,"653":1,"655":1,"673":1,"706":1,"713":1,"784":1,"786":1}}],["require",{"2":{"31":1,"103":1,"127":4,"173":1,"178":1,"180":1,"237":1,"264":1,"305":2,"358":1,"446":1,"447":1,"452":2,"456":2,"596":1,"633":1,"677":1}}],["requisites",{"0":{"290":1,"303":1,"614":1},"2":{"309":1}}],["requestheaderrange",{"2":{"228":1,"238":1}}],["requesting",{"0":{"225":1},"1":{"226":1,"227":1,"228":1},"2":{"227":1,"228":1,"465":1}}],["requests",{"2":{"211":2,"227":1,"228":1,"359":1,"448":2,"453":1,"459":1,"481":1,"520":1,"642":1}}],["requested",{"2":{"13":1,"225":1,"227":1,"228":1,"238":1}}],["request",{"0":{"156":1,"161":1,"227":1,"228":1},"2":{"2":2,"44":1,"107":1,"151":1,"156":1,"161":1,"164":1,"165":1,"225":1,"227":1,"228":1,"356":1,"358":1,"360":1,"396":1,"432":2,"458":1,"515":1,"527":1,"551":1,"596":1,"599":2,"600":2,"636":1,"673":1,"715":1,"751":1,"758":1}}],["rec",{"2":{"426":4}}],["recipient",{"2":{"375":1,"537":2}}],["recipients",{"2":{"34":1}}],["recency",{"2":{"480":2}}],["recent",{"2":{"107":1,"384":1,"735":1}}],["receiptsroot",{"2":{"384":2}}],["receipt",{"2":{"32":3,"34":4,"489":1}}],["receiving",{"2":{"27":1,"31":2,"34":1,"409":2}}],["receiveroutine",{"2":{"649":4,"794":4}}],["receiver",{"2":{"76":2,"91":4,"317":2}}],["receiver=",{"2":{"76":2,"317":2}}],["received",{"2":{"24":1,"33":1,"171":1,"450":1,"459":2,"708":1}}],["receives",{"2":{"23":3,"293":1,"436":1,"487":1,"499":1}}],["receive",{"2":{"21":1,"23":1,"27":1,"29":1,"30":1,"31":4,"33":3,"34":3,"53":1,"54":1,"211":1,"324":1,"325":1,"366":1,"409":1,"440":1,"450":1,"490":1,"720":1,"760":1}}],["recap",{"2":{"54":1}}],["recruiting",{"2":{"48":2}}],["reconstructing",{"2":{"452":1}}],["reconstruction",{"0":{"441":1}}],["reconstruct",{"2":{"440":1,"441":1,"481":1}}],["recoverable",{"2":{"452":1}}],["recovered",{"2":{"450":1}}],["recover",{"2":{"271":6,"561":2,"578":1}}],["recompute",{"2":{"108":1}}],["recommend",{"2":{"84":1,"103":1,"301":1,"329":1,"392":2,"413":1,"504":1,"611":2,"740":1}}],["recommends",{"2":{"47":1}}],["recommendations",{"2":{"41":1}}],["recommended",{"0":{"756":1},"2":{"24":1,"35":1,"88":1,"208":1,"211":2,"220":1,"266":1,"312":2,"345":1,"352":1,"432":2,"459":1,"521":1,"527":1,"536":1,"607":1,"609":1,"623":1,"651":1,"661":1,"667":1,"673":1,"709":1,"771":1,"780":1,"784":1}}],["recognizable",{"2":{"84":1}}],["recognize",{"2":{"53":1}}],["recognition",{"2":{"43":1}}],["recorded",{"2":{"46":4}}],["record",{"2":{"40":1}}],["recording",{"0":{"46":1},"2":{"40":2,"46":6}}],["recordings",{"2":{"5":1,"40":1,"46":3}}],["recourse",{"2":{"31":2}}],["remainder",{"2":{"292":1,"309":1,"551":1,"557":1,"564":1}}],["remain",{"2":{"264":1,"415":1,"479":1,"543":1,"631":1,"679":1,"698":1}}],["remaining",{"2":{"165":2,"166":1,"261":1,"300":1,"489":4,"567":1,"724":1}}],["remains",{"2":{"19":1,"208":1,"230":1,"720":1,"760":1}}],["removing",{"2":{"551":1}}],["removed",{"2":{"91":2,"161":1,"162":1,"346":1,"351":1,"400":1,"551":2,"594":1}}],["removechainowner",{"2":{"91":2}}],["remove",{"2":{"9":1,"312":2,"385":2,"581":1,"603":1,"609":1}}],["remote",{"2":{"46":1,"247":1,"357":1,"413":1,"520":1,"530":2,"545":2,"616":3,"621":1}}],["remember",{"2":{"40":1,"44":1,"249":1,"265":1,"385":1,"646":1,"647":1,"720":1}}],["reminders",{"2":{"45":1}}],["reminder",{"2":{"36":1,"45":1,"71":1}}],["repeat",{"2":{"701":1}}],["replicated",{"2":{"456":1}}],["replace",{"2":{"192":1,"360":1,"421":1,"557":1,"703":1,"713":1}}],["replaced",{"2":{"170":2}}],["replaces",{"2":{"149":1,"223":1,"455":1,"643":1}}],["replacing",{"2":{"91":2,"275":1,"276":1,"579":1}}],["replaying",{"2":{"220":1,"221":1,"481":1}}],["replayer",{"0":{"221":1},"2":{"217":2}}],["replay",{"2":{"94":1,"108":1}}],["repo",{"2":{"126":3,"211":1,"212":1,"236":1,"520":2,"542":1,"627":1,"703":1,"705":1}}],["report",{"2":{"28":1,"604":2}}],["reporting",{"2":{"24":1}}],["reporter",{"2":{"11":1}}],["reported",{"2":{"11":1}}],["repository",{"0":{"87":1,"338":1},"2":{"0":1,"1":1,"2":2,"4":1,"87":3,"90":1,"91":1,"126":1,"145":1,"217":1,"220":2,"221":1,"238":1,"245":1,"267":1,"268":1,"338":1,"413":1,"581":1,"609":1,"627":2,"790":1}}],["represents",{"2":{"107":2,"358":1}}],["represented",{"2":{"34":1}}],["represent",{"2":{"32":1,"33":1,"34":2,"146":1}}],["representation",{"2":{"34":2,"135":1,"165":2,"166":2}}],["representations",{"0":{"34":1},"2":{"31":1,"34":2}}],["representative",{"2":{"10":1}}],["representing",{"2":{"10":2}}],["reloadsudo",{"2":{"605":1}}],["reload",{"2":{"605":2}}],["rely",{"2":{"224":1,"234":1,"331":1,"481":1,"510":2,"726":2,"728":2,"744":2}}],["relying",{"2":{"32":1,"233":1,"481":1}}],["relaying",{"0":{"680":1},"1":{"681":1,"682":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1,"690":1,"691":1},"2":{"287":1,"681":1,"683":3}}],["relayers",{"2":{"680":1}}],["relayer",{"0":{"683":1,"689":1},"2":{"215":1,"238":1,"243":1,"680":3,"681":2,"689":1}}],["relayed",{"2":{"107":2,"128":1,"129":1,"133":1,"136":1,"137":1,"228":1}}],["relay",{"2":{"107":1,"220":1,"243":1,"680":1,"682":1}}],["relays",{"2":{"95":1,"109":1,"230":1}}],["relatively",{"2":{"335":1,"428":1}}],["relative",{"0":{"335":1},"2":{"202":1,"335":1}}],["relations",{"2":{"45":1}}],["relationships",{"2":{"38":1,"42":1}}],["relating",{"2":{"32":1}}],["related",{"2":{"31":1,"33":1,"34":1,"44":1,"48":1,"64":1,"355":1,"445":1,"526":1,"673":2,"713":1}}],["release",{"2":{"220":1,"224":4,"480":1,"678":1,"680":1}}],["releasesource",{"2":{"220":1}}],["releases",{"2":{"161":1,"162":1,"582":1,"610":1}}],["released",{"2":{"31":1,"681":1}}],["relevant",{"2":{"30":1,"34":1,"43":2,"45":2,"48":1,"426":2,"449":1,"459":1,"508":2,"649":1,"708":1,"725":2,"740":2,"794":1}}],["relevantly",{"2":{"2":1}}],["relies",{"2":{"637":1,"680":1}}],["relied",{"2":{"34":1}}],["reliability",{"2":{"33":1}}],["reliance",{"2":{"31":3,"34":2}}],["religion",{"2":{"7":1}}],["re",{"2":{"2":1,"40":1,"41":1,"52":1,"75":1,"76":1,"79":2,"84":2,"89":1,"120":1,"126":1,"148":1,"172":2,"182":1,"187":1,"192":1,"211":3,"219":6,"224":2,"236":1,"255":1,"257":1,"264":1,"276":1,"284":2,"286":1,"301":1,"312":2,"314":1,"315":2,"317":2,"394":1,"405":1,"413":1,"426":4,"428":1,"433":1,"434":1,"547":1,"592":1,"602":1,"604":1,"607":1,"609":1,"611":1,"649":1,"656":2,"685":1,"794":1}}],["sql",{"2":{"509":1,"726":1,"744":1}}],["squaresizeupperbound",{"2":{"159":2}}],["square",{"0":{"147":1,"326":1,"410":1},"2":{"107":1,"108":2,"131":3,"136":1,"146":2,"153":2,"159":6,"172":2,"177":1,"181":2,"182":1,"183":9,"184":1,"326":1,"410":1,"458":3,"724":4}}],["snaps",{"2":{"638":12}}],["snapshots",{"2":{"481":4,"634":1,"637":3}}],["snapshot",{"2":{"445":1,"635":2,"638":1}}],["snap",{"2":{"638":24}}],["snippets",{"2":{"145":1,"149":1,"400":1}}],["ss",{"2":{"419":1}}],["ssd",{"2":{"352":1,"521":1,"623":1,"667":1,"709":1,"757":3,"758":2,"780":1}}],["sgvsbg8gd28ybgqh",{"2":{"386":2}}],["svg",{"0":{"381":1},"2":{"381":2,"434":1}}],["s3",{"2":{"223":16}}],["srl59gitsiwc9lqdyaszfc6tvusyy7njx8",{"2":{"161":2}}],["src",{"2":{"77":2,"116":1,"117":2,"120":2,"169":2,"212":2,"280":1,"281":2,"283":2,"284":2,"304":1,"305":3,"307":2,"312":1,"315":2,"318":2,"432":8,"649":4,"794":4}}],["skipauth",{"2":{"596":1}}],["skip",{"2":{"210":1,"224":2,"322":1,"351":1,"396":2,"401":2,"402":2,"404":2,"407":1,"685":1,"771":1,"784":1}}],["skipped",{"2":{"117":2,"120":2,"281":2,"284":2}}],["skillsets",{"2":{"52":1}}],["sdk",{"2":{"94":4,"149":7,"265":1,"267":1,"330":4,"331":2,"332":1,"334":1,"335":1,"413":1,"414":1,"418":1,"426":2,"455":1,"460":1,"483":3,"487":1,"498":1,"508":1,"520":1,"530":2,"536":2,"548":1,"551":1,"681":1,"725":1,"748":1,"749":1}}],["switching",{"2":{"592":1}}],["switch",{"2":{"83":1,"172":2,"315":1,"337":1,"432":2,"434":1,"545":1}}],["swag",{"0":{"63":1},"2":{"43":1}}],["symbol",{"2":{"312":2,"314":1,"434":2}}],["sync|async|block",{"2":{"573":2}}],["sync",{"0":{"512":1,"635":1,"636":1,"637":1,"638":1,"733":1,"745":1},"1":{"636":1,"637":1,"638":1},"2":{"334":3,"390":1,"443":1,"481":3,"512":1,"572":1,"573":2,"606":1,"622":1,"635":4,"636":2,"637":4,"638":2,"649":1,"733":1,"745":1,"755":1,"774":4,"778":1,"794":1}}],["syncing",{"0":{"334":1,"606":1},"1":{"607":1},"2":{"334":1,"442":1,"479":1,"529":1,"606":1,"636":1,"649":1,"776":1,"777":2,"778":1,"788":1,"794":1}}],["synced",{"2":{"80":1,"390":1}}],["syndtr",{"2":{"149":4}}],["systemctl",{"2":{"605":4,"774":6,"776":4,"777":4,"778":6}}],["systemd",{"0":{"529":1,"541":1,"675":1,"717":1,"772":1,"774":1,"788":1},"1":{"773":1,"774":1,"775":1,"776":1,"777":1,"778":1},"2":{"529":1,"541":7,"605":2,"639":1,"675":1,"717":1,"772":1,"774":6,"776":5,"777":5,"778":4,"788":1}}],["systems",{"2":{"331":1,"545":2,"582":1,"610":1}}],["system",{"2":{"23":1,"36":1,"233":1,"344":1,"418":1,"419":2,"456":2,"543":2,"546":1,"547":1,"605":5,"609":1,"653":1,"684":1,"774":4,"776":4,"777":4,"778":4}}],["smartstake",{"2":{"738":1}}],["smart",{"0":{"112":1,"116":1,"117":1,"118":1,"121":1,"259":1,"277":1,"280":1,"281":1,"282":1,"285":1},"1":{"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":2,"120":2,"121":1,"122":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":2,"284":2,"285":1,"286":1},"2":{"73":1,"74":1,"79":1,"85":2,"88":1,"113":2,"116":1,"122":1,"131":7,"133":1,"145":1,"148":1,"150":1,"151":1,"156":1,"161":1,"163":5,"169":2,"173":1,"178":1,"183":1,"184":2,"225":1,"237":2,"238":1,"239":1,"240":1,"242":1,"249":1,"259":1,"261":1,"263":1,"265":1,"277":1,"280":1,"284":1,"286":1,"301":1,"303":1,"304":1,"305":2,"307":1,"309":1,"313":2,"317":2,"339":1,"413":1,"445":1,"497":1}}],["smartphone",{"2":{"40":1}}],["smaller",{"2":{"415":1}}],["small",{"2":{"46":1,"107":1,"134":1,"206":1,"264":1,"439":1,"451":1,"457":1}}],["smooth",{"2":{"43":1}}],["sausage",{"2":{"561":2}}],["sandbox",{"2":{"736":1}}],["sanity",{"2":{"401":1}}],["sanctions",{"2":{"24":1,"31":1}}],["sashabaranov",{"2":{"399":2,"400":2}}],["salt=",{"2":{"211":2}}],["salt",{"2":{"211":5,"213":4,"219":2}}],["sales",{"2":{"34":1,"44":1,"514":1,"751":1}}],["sale",{"2":{"34":3}}],["save",{"0":{"557":1,"634":1},"2":{"211":1,"219":1,"396":2,"400":1,"536":1,"545":1,"578":1,"602":1,"634":1,"646":1,"647":1,"699":1,"735":1}}],["saved",{"2":{"146":1,"148":1,"178":1,"193":1,"196":1}}],["saving",{"2":{"43":1,"180":1,"536":1}}],["said",{"2":{"94":1}}],["sampling",{"0":{"439":1,"440":1,"450":1,"718":1},"1":{"451":1,"452":1},"2":{"59":1,"230":1,"264":1,"335":1,"374":2,"438":1,"439":5,"440":1,"441":1,"449":1,"450":3,"452":1,"457":2,"480":3,"520":1,"707":1,"720":1,"755":1,"769":1,"778":1}}],["samplefrom",{"2":{"606":2}}],["samples",{"2":{"451":1}}],["sampled",{"2":{"440":1,"459":1}}],["sampler",{"0":{"374":1}}],["sample",{"0":{"59":1,"60":1,"61":1,"62":1},"2":{"59":2,"60":2,"61":2,"62":2,"172":1,"457":1,"480":1,"606":1}}],["same",{"0":{"421":1},"2":{"34":1,"75":1,"110":1,"134":1,"148":1,"179":1,"184":1,"193":1,"196":1,"200":2,"211":2,"213":1,"233":1,"243":1,"317":1,"332":1,"344":1,"426":2,"456":2,"545":4,"551":1,"596":1,"607":3,"627":1,"698":1,"700":1,"789":1}}],["safely",{"2":{"109":1,"457":1,"597":1}}],["safe",{"2":{"52":1,"396":2,"550":1,"561":2}}],["satisfied",{"2":{"34":1}}],["satisfy",{"2":{"34":1}}],["shnode",{"2":{"777":1}}],["shpeer=",{"2":{"705":1}}],["ship",{"2":{"705":1}}],["shirts",{"2":{"43":1}}],["shtia",{"2":{"700":1}}],["shutdown",{"2":{"676":1}}],["shsed",{"2":{"643":1}}],["shstaking",{"2":{"542":1,"702":1}}],["shsudo",{"2":{"541":1,"774":4,"776":2,"777":2,"778":4}}],["shkey",{"2":{"542":1,"699":1}}],["shvalidator",{"2":{"542":1,"698":1}}],["shgo",{"2":{"404":2}}],["shgit",{"2":{"126":1,"268":1}}],["shmkdir",{"2":{"399":1}}],["shexternal",{"2":{"644":1}}],["shexport",{"2":{"397":1}}],["sherror",{"2":{"602":1}}],["shevm",{"2":{"542":1}}],["shellsource",{"2":{"220":1}}],["shellforge",{"2":{"219":1}}],["shelltendermint",{"2":{"218":1}}],["shellcast",{"2":{"213":3,"215":1,"216":1}}],["shellcd",{"2":{"211":1,"212":1,"217":1,"219":1,"220":1,"223":1}}],["shell",{"2":{"211":2,"664":1}}],["shellgit",{"2":{"211":1,"413":1}}],["shcurl",{"2":{"774":1}}],["shcat",{"2":{"774":1,"776":1,"777":1,"778":1}}],["shceles",{"2":{"542":1}}],["shcelestia",{"2":{"396":3,"526":4,"527":3,"528":3,"531":1,"533":3,"534":2,"535":5,"536":5,"537":2,"538":1,"539":2,"540":1,"578":3,"579":1,"581":1,"586":1,"587":1,"588":1,"592":1,"606":2,"639":4,"641":1,"672":3,"673":1,"674":3,"697":1,"703":1,"706":1,"712":3,"713":3,"714":3,"716":3,"789":4}}],["shcd",{"2":{"391":1,"556":1}}],["sha3uncles",{"2":{"384":2}}],["sharing",{"2":{"46":1,"65":1,"481":1}}],["shareversionzero",{"2":{"426":2}}],["shareclient",{"2":{"408":2}}],["shareindexinrowmajororder",{"2":{"184":2}}],["shareindexinrow",{"2":{"184":4}}],["shareproof",{"2":{"172":2,"184":6}}],["shareproofs",{"0":{"165":1},"2":{"163":2,"165":3,"172":4,"184":2}}],["sharesize",{"2":{"419":1}}],["sharesproof",{"2":{"163":3,"165":1,"166":1,"167":1,"168":1,"172":18}}],["shares",{"2":{"127":2,"131":5,"134":3,"136":1,"146":4,"148":3,"154":1,"160":3,"161":4,"163":14,"164":1,"165":2,"166":1,"167":1,"168":1,"172":4,"178":1,"181":1,"184":4,"189":1,"208":4,"233":1,"365":2,"415":2,"418":2,"419":2,"420":1,"450":5,"452":4,"453":3,"457":1,"458":4,"459":3,"520":1,"666":2,"724":4}}],["shared",{"2":{"65":1,"301":2,"702":1}}],["share",{"0":{"160":1,"176":1,"177":1,"178":1,"179":1,"180":1,"192":1,"193":1,"194":1,"199":1,"201":1,"202":1},"1":{"161":1,"162":1,"177":1,"178":1,"179":1,"180":1,"193":1,"194":1,"200":1,"201":1,"202":1},"2":{"27":1,"31":1,"36":1,"38":1,"40":1,"43":1,"45":4,"46":3,"48":1,"134":6,"146":2,"148":5,"156":5,"158":1,"160":6,"161":2,"172":2,"175":1,"176":1,"177":11,"178":2,"179":1,"181":2,"182":1,"183":2,"184":9,"185":1,"189":2,"192":7,"193":1,"195":1,"197":1,"199":1,"200":5,"203":7,"208":3,"313":2,"316":1,"323":7,"324":2,"325":4,"326":3,"363":1,"365":8,"373":2,"378":3,"380":2,"400":2,"402":7,"410":3,"415":2,"418":1,"419":2,"425":6,"450":1,"458":1,"459":1,"481":2,"490":1,"542":1,"600":2,"602":4,"701":1,"703":1,"705":3,"724":3}}],["sh",{"2":{"211":2,"268":2,"272":1,"275":2,"276":2,"309":3,"382":1,"527":1,"532":1,"549":4,"556":1,"557":2,"582":2,"604":1,"610":2,"663":2,"673":1,"714":2}}],["shforge",{"2":{"126":1}}],["shove",{"2":{"561":2}}],["shoutout",{"2":{"44":1}}],["shouldn",{"2":{"446":1}}],["should",{"0":{"208":1},"2":{"27":1,"40":1,"44":1,"56":1,"84":1,"85":1,"116":1,"117":1,"145":1,"164":1,"195":1,"196":1,"208":1,"211":3,"213":1,"217":1,"219":1,"220":1,"223":5,"224":2,"225":2,"230":1,"269":1,"280":1,"281":1,"315":1,"335":2,"363":1,"387":2,"392":1,"396":1,"417":1,"418":1,"429":1,"481":1,"497":1,"510":1,"545":1,"582":1,"597":1,"605":1,"610":1,"631":1,"633":1,"637":3,"684":1,"687":2,"692":1,"698":1,"702":1,"703":2,"726":1,"728":1,"744":1,"776":1,"777":1,"783":2,"789":2}}],["showing",{"2":{"296":1}}],["shown",{"2":{"239":1,"600":1,"789":1}}],["shows",{"2":{"148":1,"191":1,"378":1,"426":2,"453":1,"455":1}}],["showcase",{"2":{"44":1}}],["show",{"2":{"43":1,"44":1,"183":1,"300":1,"301":1,"380":1,"388":1,"432":1,"508":1,"542":2,"567":2,"597":1,"599":1,"609":1,"664":1,"705":2,"712":2,"725":1,"740":1,"768":1,"783":2,"789":3}}],["shortly",{"2":{"69":1}}],["short",{"2":{"34":1,"43":1,"657":1,"678":1}}],["scan",{"2":{"680":1}}],["scattered",{"2":{"394":1}}],["scavenger",{"0":{"394":1,"398":1},"1":{"395":1,"396":1,"397":1,"398":1,"399":2,"400":2,"401":2,"402":2,"403":2,"404":2,"405":1},"2":{"347":1,"394":1,"399":6,"404":1}}],["scaling",{"0":{"264":1},"2":{"264":2,"436":1,"437":1,"449":1}}],["scalable",{"2":{"235":1,"301":1,"337":1,"446":1,"449":1,"457":1}}],["scalability",{"0":{"235":1,"451":1},"2":{"109":1,"235":2}}],["scale",{"2":{"264":2,"451":1}}],["scaleway",{"2":{"223":1,"224":1}}],["scales",{"2":{"174":1,"230":1,"457":2}}],["scraped",{"2":{"545":2}}],["scrape",{"2":{"545":16}}],["scratches",{"2":{"265":1}}],["scratch",{"2":{"263":1}}],["scroll",{"2":{"434":1}}],["scrolling",{"2":{"433":1}}],["scripting",{"2":{"307":1}}],["scripts",{"2":{"119":1,"549":2,"556":2,"557":2}}],["script",{"0":{"87":1,"307":1},"2":{"68":1,"75":4,"87":5,"90":1,"91":7,"92":1,"211":2,"219":4,"227":2,"307":7,"308":4,"309":6,"317":4,"396":1,"404":1,"549":2,"556":1,"582":1,"610":1}}],["screening",{"2":{"31":1}}],["screen",{"2":{"24":1,"40":1,"465":1,"469":1}}],["scheme",{"0":{"148":1},"2":{"177":1,"450":1,"452":1,"455":1,"458":1}}],["schemes",{"2":{"58":1,"330":1}}],["schedules",{"2":{"489":1}}],["schedule",{"2":{"36":1,"37":1,"41":1,"43":1,"48":1,"489":2,"494":1}}],["schools",{"2":{"44":1}}],["scene",{"2":{"42":1}}],["scope",{"0":{"10":1},"2":{"62":1}}],["sl",{"2":{"582":2,"610":2,"627":8}}],["slack",{"2":{"547":1}}],["slas",{"2":{"510":1,"726":1,"728":1,"744":1}}],["slashboard",{"2":{"738":1}}],["slashing",{"0":{"551":1},"2":{"242":1,"330":1,"540":2,"551":3}}],["slashed",{"2":{"24":1,"25":1,"27":1,"217":1,"551":4}}],["slower",{"2":{"765":1}}],["slowest",{"2":{"636":1}}],["slowly",{"2":{"392":3}}],["slots",{"2":{"21":1,"23":1}}],["slightly",{"2":{"724":1}}],["slice",{"2":{"323":3,"402":2}}],["slides",{"2":{"43":1}}],["soundness",{"2":{"459":1}}],["sourcing",{"2":{"263":1}}],["source",{"0":{"581":1,"609":1},"2":{"89":1,"148":1,"219":2,"391":2,"537":2,"545":4,"580":1,"590":1,"664":4,"681":1,"682":4,"749":1}}],["sources",{"2":{"33":1,"545":1}}],["soon",{"2":{"303":1}}],["software",{"0":{"507":1,"722":1,"742":1,"761":1,"764":1,"766":1},"2":{"60":1,"61":1,"110":1,"230":1,"505":1,"662":1,"677":2,"740":1,"770":1,"771":1}}],["sovereign",{"0":{"61":1,"309":1},"2":{"59":1,"61":5,"316":1,"505":1,"673":2,"740":1,"763":1,"765":1}}],["soda",{"2":{"41":1}}],["sometimes",{"2":{"520":1,"666":1}}],["something",{"2":{"102":1,"108":1,"224":2,"372":2,"396":1,"545":1,"584":1}}],["somewhere",{"2":{"396":2,"699":1}}],["some",{"0":{"184":1,"440":1,"448":1},"2":{"40":1,"46":1,"82":1,"90":1,"134":3,"135":1,"137":1,"163":4,"169":2,"175":1,"260":1,"264":1,"265":1,"292":1,"330":1,"333":1,"363":1,"394":1,"396":1,"401":2,"404":1,"408":2,"409":4,"410":2,"426":2,"447":1,"448":1,"458":1,"479":1,"481":1,"489":1,"536":1,"537":1,"545":1,"549":4,"572":1,"574":1,"590":1,"615":1,"678":1,"687":8}}],["someone",{"2":{"37":1,"45":1}}],["solomon",{"2":{"450":2,"452":5,"455":1,"458":1}}],["solution",{"2":{"139":1,"174":1,"206":1,"230":1,"235":1,"449":1,"452":1,"456":1,"457":1}}],["solutions",{"2":{"109":1,"421":1,"437":1,"449":1}}],["solc",{"2":{"116":2,"280":2}}],["solid",{"2":{"313":2}}],["solidityuint256",{"2":{"184":1}}],["soliditypragma",{"2":{"172":1}}],["solidity",{"2":{"114":1,"116":4,"117":3,"126":1,"127":4,"151":1,"156":1,"161":1,"163":1,"165":6,"166":1,"168":4,"169":2,"172":2,"173":1,"177":1,"222":1,"242":1,"278":1,"280":4,"281":3,"305":6,"307":4}}],["soliciting",{"2":{"38":1}}],["solicits",{"2":{"34":1}}],["solicit",{"2":{"34":1}}],["solicited",{"2":{"34":1}}],["solicitation",{"2":{"34":3}}],["sol",{"2":{"75":2,"77":3,"109":1,"116":1,"117":7,"120":2,"127":7,"129":1,"131":1,"164":1,"165":1,"166":1,"168":1,"169":1,"172":4,"212":3,"219":2,"223":4,"224":4,"238":1,"239":1,"280":1,"281":7,"283":2,"284":2,"304":1,"305":6,"307":5,"308":2,"309":2,"310":2,"317":2,"318":3}}],["sold",{"2":{"34":1}}],["solely",{"2":{"31":1,"481":1}}],["sole",{"2":{"25":1,"30":1,"31":1,"34":1}}],["so",{"2":{"23":1,"24":2,"29":1,"32":1,"34":1,"41":2,"45":1,"71":1,"89":1,"126":1,"134":2,"148":2,"158":1,"159":1,"165":3,"182":1,"183":1,"196":1,"208":1,"219":1,"224":1,"257":1,"269":1,"293":1,"307":1,"309":1,"310":1,"312":2,"315":1,"355":1,"359":1,"394":1,"433":1,"438":1,"440":1,"441":2,"453":1,"459":1,"479":1,"505":1,"526":1,"528":1,"564":1,"569":1,"602":1,"634":1,"639":1,"641":1,"661":1,"664":1,"674":1,"692":1,"697":1,"705":2,"716":1,"734":1,"735":1,"789":1}}],["sorted",{"2":{"430":1}}],["sort",{"2":{"15":1,"16":1,"34":1}}],["social",{"2":{"10":1,"14":1,"36":1,"38":1,"45":4,"46":1,"320":1,"536":1}}],["socio",{"2":{"7":1}}],["spidey",{"2":{"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["spinning",{"2":{"589":1}}],["spin",{"0":{"316":1,"696":1},"1":{"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1},"2":{"696":1}}],["sp1",{"0":{"236":1,"412":1},"1":{"413":1},"2":{"230":3,"231":1,"236":5,"412":3,"413":14}}],["splits",{"2":{"458":1}}],["split",{"2":{"146":1,"450":1,"452":1,"458":1,"477":1,"488":1}}],["sparse",{"2":{"724":2}}],["sparsesharesneeded",{"2":{"419":1}}],["spans",{"0":{"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"188":1,"189":1,"190":1,"191":1,"196":1,"197":1,"198":1},"1":{"182":1,"183":1,"184":1,"185":1,"186":1,"189":1,"190":1,"191":1,"197":1,"198":1},"2":{"156":1,"160":1,"175":1,"181":3,"182":1,"183":3,"184":7,"185":1,"188":4,"191":1,"192":2,"195":1,"196":5,"206":3,"208":2}}],["span",{"0":{"387":1},"2":{"134":12,"135":4,"136":2,"137":8,"139":3,"163":4,"165":1,"183":1,"387":2}}],["space",{"2":{"52":1,"546":1,"646":1,"647":2,"728":1,"729":1,"730":1,"735":1}}],["spaces",{"2":{"10":2,"14":1,"40":5,"44":1}}],["spdx",{"2":{"116":2,"117":2,"127":2,"280":2,"281":2,"305":4,"307":2}}],["sponsoring",{"2":{"44":1}}],["sponsorship",{"2":{"44":5}}],["sponsors",{"0":{"44":1},"2":{"44":9,"45":1,"52":1}}],["spread",{"2":{"42":1,"45":1}}],["speed",{"2":{"429":1,"635":1}}],["spend",{"2":{"294":2,"299":2,"419":1,"487":1,"536":1,"537":7}}],["spec",{"2":{"736":1}}],["specialization",{"2":{"456":1}}],["specialized",{"2":{"456":3}}],["specialize",{"2":{"261":1}}],["specif",{"2":{"163":2,"169":2}}],["specifying",{"2":{"417":1,"545":1}}],["specify",{"2":{"84":1,"211":4,"269":1,"355":2,"366":1,"421":1,"526":2,"596":1,"657":2}}],["specifies",{"2":{"84":1,"269":1,"294":1}}],["specified",{"2":{"14":1,"15":1,"85":1,"211":1,"212":1,"220":2,"222":1,"224":2,"227":1,"269":1,"358":1,"366":1,"380":1,"417":2,"419":1,"480":1,"502":1,"530":2,"590":1}}],["specifications",{"2":{"134":1,"551":1,"678":1,"723":1}}],["specifically",{"2":{"65":1,"88":1,"436":1,"445":1,"637":1}}],["specific",{"0":{"160":1},"1":{"161":1,"162":1},"2":{"34":1,"41":1,"43":1,"48":1,"84":1,"107":1,"129":2,"134":2,"135":4,"137":1,"216":1,"223":2,"224":3,"226":2,"233":1,"235":1,"238":1,"297":1,"301":1,"358":2,"377":1,"432":1,"518":1,"546":1,"583":1,"594":1,"596":1,"678":1,"701":1,"739":1,"754":1,"767":1}}],["specs",{"2":{"146":2,"148":1,"165":2,"166":2,"169":4,"365":1,"420":1,"536":2}}],["speak",{"2":{"43":1}}],["speaking",{"2":{"42":1,"48":1}}],["speaker",{"0":{"65":1},"2":{"36":1,"40":1,"42":1,"43":3,"56":1,"65":5}}],["speakers",{"0":{"43":1},"2":{"36":3,"37":1,"38":1,"40":1,"42":5,"43":13,"44":2,"45":3,"48":2,"52":1,"62":1,"65":2}}],["sed",{"2":{"627":12,"644":2}}],["semantic",{"2":{"609":1}}],["semi",{"2":{"233":1}}],["severe",{"2":{"551":1}}],["severity",{"2":{"437":1}}],["several",{"2":{"107":1,"225":1,"355":1,"489":1,"678":1,"724":1,"753":1,"755":1}}],["sequential",{"2":{"265":1,"682":4}}],["sequence",{"0":{"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"188":1,"189":1,"190":1,"191":1,"196":1,"197":1,"198":1},"1":{"182":1,"183":1,"184":1,"185":1,"186":1,"189":1,"190":1,"191":1,"197":1,"198":1},"2":{"175":1,"181":3,"182":1,"183":3,"184":7,"185":1,"188":4,"191":1,"192":2,"195":1,"196":5,"206":3,"208":2,"287":1,"418":1,"421":1,"426":2,"456":2,"565":2,"566":2,"683":1}}],["sequencers",{"2":{"171":1,"192":1,"263":1}}],["sequencersignature",{"2":{"134":2,"137":2,"139":2}}],["sequenceraddress",{"2":{"134":2,"139":2}}],["sequencer",{"0":{"135":1},"1":{"136":1,"137":1},"2":{"108":1,"110":2,"134":3,"135":7,"136":2,"137":8,"139":8,"287":1,"392":4}}],["sequencerinbox",{"2":{"89":2,"98":2,"99":2,"109":1}}],["separation",{"2":{"456":1}}],["separating",{"2":{"264":1}}],["separately",{"2":{"192":1}}],["separated",{"2":{"146":1,"220":1,"627":2,"704":2}}],["separate",{"2":{"31":2,"165":1,"292":1,"344":1,"450":1,"459":1,"520":2,"589":1}}],["sepoliaeth",{"2":{"392":1}}],["sepoliafaucet",{"2":{"82":1}}],["sepolia",{"0":{"82":1,"96":1,"97":1,"98":1,"99":1},"2":{"69":2,"71":2,"79":1,"80":1,"82":3,"83":1,"85":1,"88":4,"91":2,"95":2,"96":1,"97":1,"242":3,"246":1,"248":1,"249":1,"250":1,"251":1,"252":1,"284":2,"317":2,"392":5}}],["session",{"2":{"59":1,"60":1,"61":1}}],["sessions",{"2":{"44":1,"65":1}}],["seamless",{"2":{"720":1}}],["seamlessly",{"2":{"287":1}}],["search",{"0":{"464":1,"473":1}}],["sealfields",{"2":{"384":2}}],["seasoned",{"2":{"56":1}}],["seating",{"2":{"37":1,"40":1}}],["seats",{"2":{"28":4}}],["sentry",{"2":{"627":1,"682":6}}],["sent",{"2":{"91":2,"148":1,"261":1,"418":1,"579":1}}],["sensitive",{"2":{"86":1,"342":1}}],["sense",{"2":{"42":1,"46":1}}],["sendrequest",{"2":{"599":2,"601":2}}],["sender",{"2":{"305":4,"458":1,"477":1,"687":16}}],["sending",{"2":{"220":1,"247":1,"287":1,"308":1,"309":1,"375":1,"458":1,"579":1}}],["sends",{"2":{"110":1}}],["send",{"2":{"36":2,"38":1,"45":3,"47":1,"76":5,"119":2,"121":3,"211":1,"213":2,"285":3,"299":1,"308":3,"309":3,"317":5,"535":6,"537":1,"549":8,"551":1,"571":1,"666":1,"691":1}}],["self",{"2":{"226":1,"530":2,"542":2,"789":4}}],["sell",{"2":{"34":5}}],["selling",{"2":{"34":3}}],["selecting",{"2":{"40":1,"88":1,"105":1,"554":1}}],["selection",{"0":{"592":1},"1":{"593":1},"2":{"27":1,"65":1}}],["select",{"0":{"461":1,"464":1,"469":1},"2":{"36":1,"68":2,"83":1,"171":2,"269":1,"310":4,"314":1,"463":1,"464":1,"465":2,"468":2,"469":1,"472":1,"473":1,"564":1,"581":1,"592":1,"634":1,"646":1,"740":3,"791":1}}],["selected",{"2":{"24":1,"28":1,"481":1}}],["serving",{"2":{"442":1,"448":1,"481":1}}],["servicecat",{"2":{"774":1,"776":1,"777":1,"778":1}}],["servicenano",{"2":{"605":1}}],["service",{"0":{"258":1,"328":1,"330":1,"607":1},"1":{"329":1,"330":1,"331":2,"332":2,"333":2,"334":2,"335":2},"2":{"30":5,"328":1,"344":1,"388":1,"510":1,"541":7,"605":9,"643":3,"720":1,"726":1,"728":1,"744":1,"772":1,"774":8,"776":7,"777":7,"778":7}}],["services",{"0":{"620":1},"1":{"621":1},"2":{"24":1,"30":4,"31":9,"33":3,"40":1,"276":2,"607":2,"728":2,"729":2,"730":2,"734":1,"738":2,"746":1,"747":2,"748":2,"749":2}}],["served",{"2":{"544":2}}],["serves",{"2":{"249":1,"459":1,"520":1,"691":1,"719":1}}],["servergrafana",{"2":{"545":1}}],["server",{"2":{"53":1,"283":1,"313":2,"426":2,"515":1,"545":6,"583":2,"590":1,"594":2,"683":1,"751":1}}],["servers",{"2":{"27":1,"637":2}}],["serve",{"2":{"50":1,"446":1,"448":1,"642":1}}],["serialized",{"2":{"107":1}}],["serious",{"2":{"15":1}}],["series",{"2":{"14":1,"488":1,"489":1,"545":2}}],["secretvite",{"2":{"311":1}}],["secret=your",{"2":{"311":2}}],["secret",{"2":{"311":2,"313":2}}],["secp256k1",{"2":{"276":2,"330":1,"561":2,"562":4,"566":2}}],["sections",{"2":{"206":1,"240":1,"508":1,"615":1,"725":1,"740":1,"769":1,"771":1}}],["section",{"2":{"30":1,"33":1,"34":1,"42":1,"64":1,"81":1,"84":2,"88":1,"107":1,"117":1,"131":1,"136":1,"151":1,"156":1,"161":1,"165":1,"169":1,"172":4,"175":1,"180":1,"183":1,"192":2,"195":1,"196":1,"200":1,"203":2,"208":1,"212":1,"213":2,"217":2,"219":4,"220":2,"222":2,"224":5,"255":1,"269":1,"275":3,"281":1,"321":1,"351":1,"355":1,"356":1,"357":1,"362":1,"364":1,"400":1,"406":1,"455":1,"513":1,"526":1,"527":1,"557":1,"568":1,"579":1,"581":1,"584":1,"586":1,"592":1,"597":1,"605":1,"609":1,"612":1,"616":1,"646":1,"647":1,"651":1,"652":1,"653":1,"655":1,"657":1,"673":2,"680":1,"685":1,"706":1,"713":1,"768":1,"771":2,"784":1,"786":1}}],["securing",{"2":{"42":1,"43":1,"44":2}}],["securities",{"2":{"31":1,"34":13}}],["security",{"0":{"233":1,"440":1,"441":1},"2":{"11":1,"27":2,"31":1,"34":1,"230":2,"233":1,"235":1,"243":1,"263":2,"436":1,"443":1,"661":1}}],["securely",{"2":{"86":1,"174":1,"230":1,"287":1,"313":2,"457":1,"678":1}}],["secure",{"2":{"25":1,"36":1,"235":1,"446":1,"460":1,"490":1,"498":2,"589":1,"636":1}}],["seconds",{"2":{"91":2,"275":4,"276":4,"335":1,"396":1,"545":4}}],["second",{"2":{"23":4,"165":1,"192":1,"238":1,"305":6,"421":1,"428":1,"429":1,"430":1,"440":1,"686":1}}],["setgaslimitandfee",{"2":{"426":2}}],["setcontent",{"2":{"313":4}}],["setposts",{"2":{"313":4}}],["setviewstate",{"2":{"313":6}}],["setwhiteliststatus",{"2":{"215":2}}],["sets",{"2":{"117":1,"156":1,"281":1,"360":1,"432":1}}],["setnumber",{"2":{"116":3,"117":7,"121":2,"280":3,"281":7,"285":2}}],["settitle",{"2":{"313":4}}],["settingpruning",{"2":{"634":1}}],["settingmin",{"2":{"631":1}}],["settings",{"2":{"68":1,"545":1,"596":1,"629":1,"646":1,"647":1}}],["setting",{"0":{"91":1,"353":1,"366":1,"390":1,"519":1,"522":1,"555":1,"560":1,"665":1,"668":1,"707":1,"710":1,"772":1,"779":1,"781":1},"1":{"354":1,"355":1,"356":1,"520":1,"521":1,"522":1,"523":2,"524":1,"525":1,"526":1,"527":1,"528":1,"529":1,"556":1,"557":1,"558":1,"559":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"666":1,"667":1,"668":1,"669":2,"670":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"708":1,"709":1,"710":1,"711":2,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"773":1,"774":1,"775":1,"776":1,"777":1,"778":1,"780":1,"781":1,"782":2,"783":2,"784":1,"785":1,"786":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"793":1,"794":1},"2":{"8":1,"47":2,"60":1,"61":1,"91":8,"220":1,"246":1,"266":1,"354":1,"361":1,"375":1,"387":1,"395":1,"426":4,"519":1,"529":1,"581":1,"605":1,"609":1,"621":1,"627":1,"631":2,"634":1,"662":1,"665":1,"669":1,"707":1,"710":1,"717":1,"773":1,"779":1,"781":1,"788":1}}],["settling",{"2":{"237":1}}],["settlement",{"2":{"146":1,"174":1,"180":1,"181":1,"188":1,"189":1,"192":2,"194":1,"195":2,"196":3,"199":1,"200":1,"203":1,"237":1,"261":1,"337":1,"449":2,"455":1,"456":4}}],["settles",{"2":{"105":1}}],["settle",{"2":{"79":1,"85":1,"109":1,"237":1,"336":1}}],["settled",{"2":{"69":1,"72":1}}],["setupprivate",{"2":{"91":1}}],["setup",{"0":{"75":1,"81":1,"87":1,"115":1,"279":1,"304":1,"322":1,"389":1,"407":1,"523":1,"544":1,"653":1,"656":1,"669":1,"694":1},"1":{"76":1,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"305":1,"306":1,"307":1,"308":1,"390":1,"654":1,"655":1,"656":1,"657":2,"658":2,"659":1,"660":1,"661":1},"2":{"27":2,"36":1,"68":1,"84":1,"87":5,"90":1,"91":2,"117":3,"211":2,"214":1,"215":1,"223":1,"245":1,"281":3,"305":2,"307":2,"309":2,"357":1,"400":1,"409":2,"426":2,"545":2,"547":1,"560":1,"582":1,"585":1,"610":1,"637":1,"680":1,"694":1,"784":1}}],["setupsigner",{"2":{"426":2}}],["setups",{"2":{"24":1,"596":1}}],["set",{"0":{"215":1,"563":1,"572":1,"624":1,"625":1,"627":1},"1":{"625":1,"626":1,"627":1},"2":{"19":2,"21":1,"23":1,"24":1,"27":1,"30":1,"36":1,"37":1,"42":1,"47":2,"71":1,"75":2,"76":2,"88":1,"89":4,"91":10,"115":1,"116":1,"120":2,"131":1,"134":4,"137":1,"160":1,"177":1,"187":1,"211":7,"214":2,"215":1,"219":6,"220":5,"233":1,"263":2,"265":1,"279":1,"280":1,"283":1,"284":3,"292":1,"294":1,"299":1,"305":2,"308":1,"309":1,"313":1,"317":4,"323":1,"342":1,"344":1,"358":4,"359":2,"360":5,"361":4,"362":4,"363":1,"365":1,"366":3,"372":2,"375":1,"380":1,"384":1,"385":1,"387":1,"397":1,"399":1,"400":1,"403":4,"408":1,"413":3,"419":4,"445":1,"450":1,"456":1,"483":2,"489":1,"529":1,"533":3,"545":1,"546":1,"551":3,"557":1,"563":1,"568":2,"569":2,"571":2,"572":1,"573":1,"574":1,"589":1,"605":1,"606":2,"616":1,"619":1,"622":1,"627":6,"632":1,"637":2,"646":1,"647":1,"655":3,"656":1,"657":1,"664":1,"684":1,"699":1,"710":1,"755":1,"788":1}}],["seeing",{"2":{"687":2,"776":1,"777":1}}],["seeds",{"2":{"627":13}}],["seed",{"2":{"488":1,"489":1,"627":2,"683":5,"790":1}}],["sees",{"2":{"437":1}}],["seen",{"2":{"305":2}}],["seeking",{"2":{"609":1}}],["seek",{"2":{"40":1,"43":1}}],["see",{"2":{"17":1,"33":1,"68":1,"69":4,"71":3,"72":1,"85":1,"89":1,"91":1,"92":1,"108":1,"109":1,"136":2,"143":1,"165":2,"166":2,"219":1,"220":1,"223":1,"236":1,"239":1,"253":1,"283":1,"291":1,"295":2,"315":1,"322":1,"327":2,"365":1,"388":1,"391":1,"392":1,"395":1,"396":1,"407":1,"411":2,"426":4,"433":1,"434":1,"436":1,"455":1,"466":1,"470":1,"477":1,"486":1,"501":1,"518":1,"520":3,"534":1,"535":1,"544":1,"545":1,"552":1,"557":1,"561":1,"573":2,"579":1,"581":1,"582":1,"610":1,"637":1,"639":1,"646":1,"679":1,"681":2,"684":1,"724":1,"734":1,"739":1,"754":1,"767":1,"774":1,"776":1,"777":2,"778":1,"783":2,"789":2}}],["sexualized",{"2":{"8":1}}],["sexual",{"2":{"7":1,"8":1}}],["sex",{"2":{"7":1}}],["sudo",{"2":{"541":4,"663":2,"664":16,"774":2,"776":4,"777":4,"778":2}}],["sudden",{"2":{"19":1}}],["superior",{"2":{"342":1}}],["supply",{"0":{"482":1},"1":{"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1},"2":{"484":1,"488":1,"489":6,"494":1,"520":1}}],["supplemented",{"2":{"30":1}}],["supplemental",{"0":{"30":1,"33":1},"1":{"31":1,"32":1,"33":1,"34":1},"2":{"30":2}}],["supporters",{"2":{"488":2}}],["supported",{"2":{"177":1,"243":1,"287":1,"334":1,"736":1}}],["supports",{"2":{"331":1,"483":1}}],["supportive",{"2":{"52":1}}],["supporting",{"2":{"44":1,"47":1,"62":1}}],["support",{"2":{"36":1,"39":1,"41":1,"44":4,"46":1,"49":1,"50":1,"63":2,"79":2,"88":1,"108":1,"244":1,"264":1,"265":2,"481":2,"483":1,"543":1,"548":1,"661":1,"680":1,"681":1,"748":1,"784":1}}],["suits",{"2":{"175":1}}],["suitable",{"2":{"36":1,"646":2}}],["summarize",{"2":{"146":1}}],["summarizes",{"2":{"135":4}}],["summary",{"2":{"59":1,"60":1,"61":1,"235":1}}],["surface",{"2":{"265":1}}],["sure",{"2":{"89":2,"125":1,"126":1,"148":2,"149":2,"173":1,"177":1,"184":1,"192":2,"196":2,"200":1,"203":1,"211":2,"213":1,"220":3,"223":1,"224":2,"269":1,"306":1,"316":1,"360":1,"396":1,"543":1,"544":2,"568":1,"581":1,"583":3,"594":3,"614":1,"676":1,"774":1}}],["surveys",{"2":{"37":1}}],["suggest",{"2":{"432":2}}],["suggested",{"0":{"481":1},"2":{"421":1,"481":1}}],["suggests",{"2":{"47":1}}],["suggestions",{"0":{"4":1},"2":{"4":1,"40":1}}],["sustainable",{"2":{"44":1}}],["sustained",{"2":{"15":1,"16":1}}],["sufficiently",{"2":{"459":1}}],["sufficient",{"2":{"34":1,"40":1,"183":1,"290":1,"452":2}}],["suffer",{"2":{"32":1}}],["succinct",{"0":{"227":1},"2":{"211":4,"212":2,"213":6,"214":1,"220":5,"227":7,"228":1,"230":1,"237":2,"243":1,"413":1}}],["succinctxgit",{"2":{"211":1}}],["succinctx",{"2":{"211":4,"223":4,"224":2}}],["succinctgateway",{"0":{"211":1,"213":1},"1":{"214":1,"215":1,"216":1},"2":{"211":7,"213":1,"214":1,"219":3,"224":1,"239":2}}],["succinctlabs",{"2":{"126":2,"153":2,"172":2,"211":2,"212":2,"217":2,"220":2,"223":2,"224":2,"413":2}}],["succeeds",{"2":{"107":1}}],["success",{"2":{"38":1,"50":1,"69":1,"365":1,"684":3,"687":2}}],["successful",{"2":{"30":1,"35":1,"42":1,"44":1,"45":1,"57":1,"63":1,"91":1,"116":2,"117":1,"120":1,"213":1,"280":2,"281":1,"284":1,"380":1,"402":1,"426":4,"459":1,"783":1}}],["successfully",{"2":{"24":1,"31":1,"88":1,"131":2,"177":1,"228":1,"308":1,"323":1,"396":1,"402":2,"408":1,"436":1,"439":1,"443":1,"529":1,"579":2,"581":1,"682":1,"683":1,"687":1,"774":1,"776":1,"777":1,"778":1,"788":1}}],["such",{"2":{"8":1,"30":3,"31":10,"33":1,"34":9,"36":1,"42":1,"43":2,"44":1,"84":1,"134":2,"135":1,"287":1,"322":1,"328":1,"354":1,"358":2,"405":1,"407":1,"418":1,"426":2,"437":1,"440":1,"442":1,"443":1,"446":1,"452":1,"456":1,"458":1,"459":2,"479":1,"499":1,"546":1,"548":1,"583":1,"594":1,"673":1,"713":1,"723":1}}],["subcommands",{"0":{"534":1},"2":{"530":6}}],["subdomain",{"2":{"380":1}}],["subtract",{"2":{"332":1}}],["subtrees",{"2":{"458":1}}],["subtree",{"2":{"177":6}}],["subtreerootthreshold",{"2":{"159":2}}],["subspace",{"2":{"536":4}}],["subset",{"2":{"486":1}}],["subsequently",{"2":{"133":1}}],["subsequent",{"2":{"23":1,"34":1}}],["subscribing",{"0":{"324":1,"325":1,"409":1},"2":{"405":1,"409":2}}],["subscribes",{"2":{"325":2}}],["subscribeblobs",{"2":{"324":2}}],["subscribeheaders",{"2":{"322":1,"325":4,"407":1}}],["subscribe",{"2":{"88":3,"89":1,"324":6,"325":6,"409":6}}],["subscription",{"2":{"171":6,"322":1,"407":1,"409":1}}],["subscriptions",{"2":{"88":1}}],["submitpayforblob",{"2":{"426":2,"427":1}}],["submitdata",{"2":{"426":2}}],["submitblob",{"2":{"323":4,"425":4}}],["submitblockdata",{"2":{"135":2,"137":2}}],["submitfraudproof",{"2":{"172":8}}],["submitter",{"2":{"536":1}}],["submitted",{"2":{"85":1,"134":8,"153":2,"164":2,"170":2,"172":2,"181":2,"217":1,"225":1,"365":1,"366":1,"402":2,"404":1,"421":3,"537":1,"682":2,"703":1}}],["submitting",{"0":{"142":1,"298":1,"323":1,"363":1,"380":1,"408":1,"414":1,"421":1},"1":{"364":1,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"427":1},"2":{"143":1,"166":1,"189":1,"192":1,"195":1,"196":1,"220":1,"226":1,"296":1,"355":1,"363":1,"364":1,"365":1,"405":1,"408":2,"418":1,"420":1,"478":1,"526":1,"536":1,"673":1,"718":1}}],["submits",{"2":{"135":2,"323":2,"402":3,"425":2,"680":1}}],["submitheader",{"2":{"135":4,"137":2}}],["submitrollupblock",{"2":{"127":2}}],["submit",{"0":{"364":1,"790":1},"2":{"85":1,"142":1,"172":5,"180":1,"211":1,"214":1,"215":3,"217":1,"220":1,"224":1,"226":1,"289":1,"293":1,"295":3,"298":3,"323":5,"348":1,"358":6,"363":12,"366":2,"380":2,"382":1,"390":1,"394":1,"400":2,"401":2,"402":11,"404":2,"405":2,"408":7,"414":2,"415":1,"419":1,"421":2,"422":1,"424":3,"425":4,"426":6,"427":2,"459":1,"477":2,"486":1,"487":1,"496":1,"536":10,"537":4,"673":2,"713":2,"790":1}}],["submission",{"0":{"288":1,"296":1},"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},"2":{"53":1,"195":1,"214":2,"215":1,"220":1,"337":1,"366":1,"380":1,"537":1}}],["submissions",{"2":{"21":1,"291":1}}],["sub",{"2":{"34":1,"409":4,"426":2}}],["subjectivity",{"2":{"637":1}}],["subject",{"2":{"24":1,"31":1,"43":1,"330":1,"335":1,"415":1,"430":1,"489":2,"505":1}}],["sig",{"2":{"550":1}}],["signal",{"2":{"187":1}}],["signatures",{"2":{"372":2,"548":1,"564":2}}],["signature",{"2":{"134":4,"137":4,"139":4,"372":2,"418":1,"458":1,"477":1}}],["signer",{"2":{"156":2,"211":2,"313":4,"323":2,"425":2,"426":12,"564":2}}],["signedtx",{"2":{"549":2}}],["signed",{"2":{"137":1,"549":4}}],["signbytes",{"2":{"137":2}}],["signs",{"2":{"136":1}}],["sign",{"2":{"88":1,"137":2,"211":2,"397":2,"426":6,"549":6}}],["signifies",{"2":{"596":1}}],["significant",{"2":{"480":1,"633":1,"647":1}}],["significantly",{"2":{"44":1,"263":1,"335":1,"415":1}}],["signing",{"0":{"542":1},"2":{"86":1,"310":1,"330":1,"331":1,"344":1,"346":1,"551":2,"564":2,"789":2}}],["signup",{"0":{"53":1}}],["situation",{"2":{"441":1}}],["site",{"0":{"0":1,"1":1},"1":{"1":1,"2":1,"3":1,"4":1},"2":{"1":1,"432":8}}],["sidebar",{"2":{"545":2}}],["sidenode",{"2":{"168":4,"169":4,"172":8}}],["sidenodes",{"2":{"153":2,"165":6,"168":6,"169":2,"172":6}}],["side",{"2":{"165":2,"168":2,"177":2,"687":8}}],["simultaneous",{"2":{"544":2}}],["simulated",{"2":{"287":1}}],["simulates",{"2":{"213":1}}],["simplicity",{"2":{"181":1}}],["simply",{"2":{"135":2,"337":1,"520":1,"545":1,"691":1}}],["simpler",{"2":{"185":1,"439":1}}],["simplerollup",{"2":{"172":8}}],["simple",{"2":{"133":1,"136":1,"172":1,"189":1,"197":1,"212":1,"213":1,"239":1,"263":1}}],["simplest",{"2":{"82":1,"139":1,"646":1}}],["similarly",{"2":{"196":1,"220":1,"234":1,"455":1,"468":1,"497":1,"548":1}}],["similar",{"2":{"89":1,"91":1,"116":1,"117":1,"120":1,"121":2,"169":1,"195":1,"203":1,"211":1,"219":1,"280":1,"281":1,"284":1,"285":2,"294":1,"335":1,"365":1,"368":1,"385":1,"386":1,"417":1,"457":1,"537":1,"605":1,"607":1,"657":1,"658":1,"687":2,"783":2,"789":1}}],["since",{"2":{"88":1,"89":1,"107":1,"128":1,"153":2,"170":2,"172":2,"178":1,"195":1,"208":1,"219":6,"334":1,"401":2,"402":2,"404":2,"417":1,"419":1,"437":1,"441":1,"451":1,"452":1,"459":1,"484":1,"547":1,"571":1,"679":1,"719":1}}],["single",{"2":{"14":1,"86":1,"129":1,"135":1,"146":1,"181":1,"189":3,"352":1,"443":1,"446":1,"456":1,"549":4,"556":3,"557":2,"709":1,"757":1}}],["sizeofdatainbytes",{"2":{"420":2}}],["sizes",{"2":{"156":2,"206":1,"419":1}}],["size",{"0":{"415":1},"2":{"7":1,"42":2,"89":4,"131":3,"166":1,"178":1,"180":1,"183":5,"358":1,"366":1,"384":2,"415":2,"418":4,"419":3,"420":1,"440":2,"445":1,"451":1,"457":1,"458":2,"477":1,"478":1,"483":1,"682":8,"724":9}}],["s",{"0":{"84":1,"86":1,"90":1,"170":1,"300":1,"449":1},"1":{"450":1,"451":1,"452":1,"453":1,"454":1,"455":1},"2":{"5":1,"8":1,"17":1,"19":1,"21":2,"22":1,"23":1,"24":2,"25":2,"27":1,"28":1,"31":3,"33":2,"34":12,"41":1,"42":3,"44":1,"46":1,"48":1,"53":1,"56":1,"65":1,"75":2,"79":1,"80":1,"81":1,"84":9,"85":9,"86":4,"88":4,"89":1,"90":1,"91":3,"92":1,"101":1,"105":1,"108":1,"109":2,"116":1,"117":1,"120":1,"131":4,"134":1,"137":28,"139":3,"146":1,"148":1,"174":1,"183":1,"188":1,"196":3,"208":1,"211":3,"214":1,"219":4,"220":1,"223":2,"225":1,"227":1,"230":2,"235":2,"237":5,"238":1,"245":1,"260":1,"261":1,"265":3,"280":1,"281":1,"283":1,"287":1,"289":2,"291":2,"296":1,"300":1,"302":1,"305":3,"307":2,"308":2,"309":2,"311":1,"315":1,"317":2,"323":2,"329":1,"332":1,"337":1,"341":1,"350":1,"354":1,"355":1,"357":1,"358":1,"360":1,"368":1,"369":1,"370":1,"371":1,"372":1,"375":1,"376":1,"385":2,"386":2,"388":1,"394":6,"396":1,"401":1,"402":2,"404":5,"406":1,"408":2,"413":1,"418":2,"419":2,"425":2,"426":2,"430":1,"432":1,"434":1,"443":1,"445":1,"446":1,"449":1,"450":1,"451":1,"458":1,"459":1,"477":1,"487":1,"489":2,"491":1,"492":1,"496":1,"498":1,"499":1,"505":1,"508":1,"512":1,"513":2,"515":1,"527":1,"530":2,"531":1,"536":1,"541":4,"544":3,"545":3,"546":2,"547":1,"551":1,"571":1,"573":2,"583":1,"586":1,"589":1,"594":1,"599":1,"602":1,"605":2,"611":1,"615":1,"627":14,"638":12,"643":2,"644":2,"646":1,"661":1,"673":2,"679":1,"680":1,"682":2,"684":1,"707":1,"713":2,"719":2,"720":1,"725":1,"733":1,"734":2,"738":1,"740":1,"745":1,"746":2,"747":2,"751":1,"760":1,"763":1,"774":2}}],["style",{"2":{"661":1}}],["style=",{"2":{"312":2,"313":26}}],["styles",{"2":{"312":2,"432":6}}],["stuck",{"2":{"287":1}}],["stub",{"2":{"127":1}}],["stick",{"2":{"181":1}}],["sticking",{"2":{"84":1}}],["still",{"2":{"175":1,"177":2,"220":2,"243":1,"295":1,"392":1,"396":1,"432":1,"451":1,"455":1,"505":1,"596":1,"616":1,"634":1,"649":1,"673":1,"720":1,"794":1}}],["stopbroadcast",{"2":{"307":2}}],["stops",{"2":{"287":1}}],["stop",{"0":{"676":1},"2":{"145":2,"536":1,"597":1,"676":1}}],["storing",{"2":{"110":1,"443":1,"444":1,"446":1,"448":1,"481":2,"777":1}}],["stories",{"2":{"48":1}}],["storecd",{"2":{"656":1}}],["storecelestia",{"2":{"361":1}}],["storesudo",{"2":{"656":1}}],["stores",{"2":{"455":1,"665":1,"755":1}}],["store=$home",{"2":{"361":2}}],["store",{"0":{"361":1,"447":1,"595":1,"603":1,"657":1},"1":{"362":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1},"2":{"86":1,"107":1,"110":1,"354":1,"358":4,"359":7,"361":9,"362":8,"363":4,"365":2,"390":1,"396":4,"418":1,"442":1,"446":2,"447":1,"448":1,"451":1,"455":1,"479":1,"481":1,"520":1,"596":3,"597":9,"603":5,"604":4,"606":1,"647":3,"656":4,"657":9,"658":8,"666":1,"682":8,"712":2,"735":1}}],["stored",{"2":{"84":3,"107":1,"148":1,"228":1,"237":1,"293":1,"354":1,"440":1,"441":1,"443":1,"479":1,"480":2,"531":1,"573":2,"647":2}}],["storage",{"0":{"442":1,"443":1,"444":1,"446":1,"628":1,"634":1,"656":1,"665":1,"666":1,"668":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"776":1},"1":{"629":1,"630":1,"631":1,"632":1,"633":1,"634":1,"657":1,"658":1,"666":1,"667":1,"668":1,"669":2,"670":1,"671":1,"672":2,"673":2,"674":1,"675":1,"676":1},"2":{"48":1,"110":1,"227":1,"305":6,"352":1,"442":2,"443":2,"444":1,"446":2,"448":2,"480":1,"521":1,"545":2,"623":1,"633":1,"634":1,"646":1,"647":1,"658":1,"665":1,"666":2,"667":2,"673":3,"674":2,"675":2,"676":1,"709":1,"732":1,"735":1,"740":1,"755":1,"757":1,"769":1,"776":2,"780":1}}],["std",{"2":{"117":2,"281":2,"305":2,"307":2}}],["steal",{"2":{"437":1}}],["steady",{"2":{"19":1,"23":1}}],["step",{"0":{"68":1,"69":1,"71":1,"72":1,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1},"2":{"60":2,"71":1,"83":1,"84":1,"85":2,"88":1,"134":1,"137":1,"139":1,"172":1,"184":1,"210":1,"213":1,"224":1,"356":1,"402":1,"468":1,"550":2,"685":1,"696":1,"701":1,"702":1,"720":1}}],["steps",{"0":{"111":1,"122":1,"254":1,"269":1,"270":1,"271":1,"286":1,"320":1,"340":1,"405":1,"559":1,"611":1},"2":{"35":1,"88":1,"102":1,"103":1,"208":1,"210":1,"224":1,"413":1,"519":1,"581":2,"582":1,"609":1,"610":1,"649":1,"681":1,"683":1,"692":1,"696":1,"773":1,"789":3,"794":1}}],["stronger",{"0":{"448":1}}],["strong",{"2":{"446":1}}],["str",{"2":{"408":4,"409":4,"410":4}}],["strike",{"2":{"235":1}}],["string",{"2":{"76":2,"152":2,"211":2,"223":1,"305":30,"308":4,"309":4,"317":2,"322":1,"323":4,"324":4,"325":4,"326":4,"359":3,"360":1,"363":2,"380":1,"401":2,"402":17,"403":4,"404":8,"407":1,"425":4,"426":2,"510":1,"512":1,"513":1,"526":1,"583":2,"593":2,"594":2,"673":1,"733":1,"734":1,"745":1,"746":1}}],["straight",{"2":{"736":1}}],["straightforward",{"2":{"202":1}}],["strategy",{"2":{"604":1}}],["strange",{"2":{"30":1}}],["struct",{"2":{"107":1,"134":10,"135":6,"163":4,"165":9,"166":2,"168":5,"169":4,"305":2}}],["structures",{"0":{"128":1},"2":{"108":1,"134":2,"146":1,"169":2,"426":2}}],["structure",{"0":{"3":1},"2":{"23":1,"134":2,"165":2,"168":2}}],["streaming",{"0":{"229":1},"1":{"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1},"2":{"46":4}}],["stress",{"2":{"41":1}}],["strengthen",{"2":{"38":1}}],["stands",{"2":{"502":1}}],["standard",{"2":{"47":1,"305":1,"330":2,"332":1,"414":1,"416":1,"452":4,"478":1,"609":1,"680":1}}],["standards",{"0":{"8":1},"2":{"9":1,"15":1,"16":1}}],["stage",{"2":{"230":1,"720":1}}],["stack=",{"2":{"649":2,"794":2}}],["stack",{"0":{"245":1,"301":1,"336":1,"388":1},"1":{"302":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"337":1,"338":1,"339":1,"340":1,"389":1,"390":1,"391":1,"392":1,"393":1},"2":{"105":1,"244":1,"246":1,"254":1,"263":2,"265":1,"301":1,"320":2,"336":1,"337":1,"339":3,"340":1,"388":1,"393":1,"456":2,"649":4,"794":4}}],["stakin",{"2":{"728":1,"729":1,"730":1}}],["staking",{"0":{"482":1,"490":1,"502":1,"503":1},"1":{"483":1,"484":1,"485":1,"486":1,"487":1,"488":1,"489":1,"491":1,"492":1},"2":{"84":1,"85":1,"330":1,"460":1,"483":3,"489":1,"490":2,"491":1,"492":1,"498":1,"499":1,"502":2,"536":6,"539":4,"542":1,"783":2,"789":2}}],["stakeflow",{"2":{"728":1,"729":1,"730":1,"737":1,"747":1,"748":1,"749":1,"753":1}}],["staked",{"2":{"463":1,"489":1}}],["stakecurrency",{"2":{"432":2}}],["stakers",{"2":{"486":1,"487":1}}],["staker",{"2":{"91":3,"728":1,"729":1,"730":1}}],["stakes",{"2":{"84":2}}],["stake",{"0":{"460":1,"462":1,"465":1,"467":1,"469":1,"471":1,"474":1,"483":1,"498":1,"783":1},"1":{"461":1,"462":1,"463":2,"464":2,"465":2,"466":2,"467":1,"468":2,"469":2,"470":2,"471":1,"472":2,"473":2,"474":2,"475":2},"2":{"19":1,"22":1,"24":1,"84":6,"233":1,"460":3,"463":1,"465":1,"466":1,"468":1,"469":1,"470":1,"472":1,"475":1,"483":4,"490":1,"491":1,"498":2,"520":1,"536":1,"551":4,"783":1}}],["static",{"2":{"418":4,"419":2,"545":2}}],["statscelestia",{"2":{"374":1}}],["stats",{"0":{"374":1},"2":{"374":1}}],["stateroot",{"2":{"384":2}}],["stated",{"2":{"219":1}}],["stateless",{"2":{"131":1}}],["state",{"0":{"445":1,"513":1,"633":1,"637":1,"734":1,"746":1},"2":{"34":6,"84":4,"121":1,"136":2,"139":1,"172":4,"188":3,"192":1,"196":1,"200":1,"203":1,"211":1,"219":3,"237":1,"261":1,"285":1,"294":4,"295":2,"296":2,"297":2,"334":1,"335":1,"337":1,"355":2,"358":2,"368":2,"369":4,"371":2,"375":6,"396":2,"417":1,"418":1,"419":1,"421":1,"427":1,"437":1,"445":4,"455":3,"456":8,"458":2,"479":2,"481":2,"513":3,"520":2,"526":2,"530":6,"572":1,"633":1,"634":1,"635":2,"637":5,"638":1,"647":3,"649":28,"673":3,"690":1,"713":1,"734":2,"746":2,"747":1,"749":1,"794":28}}],["statesync",{"2":{"637":3}}],["states",{"2":{"34":9}}],["statements",{"0":{"400":1},"2":{"400":2}}],["statement",{"2":{"27":1}}],["status",{"0":{"215":1,"253":1},"2":{"7":1,"69":1,"121":2,"214":2,"215":6,"253":2,"275":2,"276":2,"285":2,"429":1,"510":1,"530":4,"552":1,"599":2,"734":2,"774":4,"778":2}}],["stable",{"2":{"23":1,"720":1,"760":1}}],["stability",{"0":{"505":1,"720":1},"2":{"19":1}}],["startcelestia",{"2":{"639":1,"706":1,"787":1,"789":1}}],["startbroadcast",{"2":{"307":2}}],["startblock",{"2":{"153":6,"170":4,"217":1}}],["startprank",{"2":{"305":2}}],["starts",{"2":{"219":1,"226":1,"484":1}}],["startshare=0",{"2":{"161":1}}],["startindex",{"2":{"181":2,"183":2}}],["starting",{"2":{"21":1,"50":1,"134":1,"150":1,"160":1,"322":1,"391":1,"407":1,"456":1,"487":1,"527":1,"597":1,"607":1,"702":1,"790":1}}],["start=10",{"2":{"151":1}}],["start",{"0":{"529":1,"639":1,"655":1,"658":1,"673":1,"675":1,"689":1,"713":1,"717":1,"768":1,"774":1,"788":1},"1":{"714":1,"715":1,"716":1,"717":1,"769":1,"770":1,"771":1},"2":{"75":1,"89":3,"90":1,"134":2,"135":1,"145":2,"152":2,"153":4,"156":5,"161":2,"165":3,"172":4,"181":1,"225":1,"254":1,"257":1,"263":1,"275":2,"276":3,"283":1,"294":2,"295":3,"302":1,"308":1,"309":1,"313":4,"317":1,"322":1,"339":1,"340":1,"355":12,"356":8,"358":1,"396":4,"401":1,"407":1,"483":1,"509":1,"513":6,"526":1,"527":8,"528":7,"530":4,"549":2,"565":2,"577":1,"579":2,"584":3,"586":3,"587":2,"588":2,"589":4,"592":2,"597":3,"602":3,"606":2,"637":1,"639":9,"641":1,"649":1,"650":1,"655":6,"657":1,"658":10,"673":5,"674":7,"679":1,"681":1,"682":6,"689":2,"706":2,"713":7,"714":8,"716":7,"726":1,"734":3,"744":1,"771":1,"774":5,"776":5,"777":6,"778":7,"787":1,"789":9,"794":1}}],["startup",{"2":{"40":1,"777":1}}],["started",{"0":{"124":1,"302":1,"329":1,"771":1},"1":{"125":1,"126":1,"127":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1},"2":{"1":1,"27":1,"39":1,"47":1,"90":1,"275":1,"292":1,"304":1,"308":1,"313":2,"315":1,"329":1,"345":1,"392":1,"394":1,"491":1,"492":1,"582":1,"597":1,"610":1,"651":2,"656":1,"768":1,"769":1,"770":1,"771":1,"774":1,"778":1}}],["stay",{"2":{"5":1,"547":1,"739":1,"754":1,"767":1}}],["gprc",{"2":{"730":1}}],["gpt3dot5turbo",{"2":{"403":2}}],["gpt3",{"2":{"403":4,"404":2}}],["gpt",{"2":{"394":2,"395":1,"403":4,"404":4,"405":2}}],["gg",{"2":{"683":2}}],["gz",{"2":{"664":24}}],["global",{"2":{"545":3,"682":2}}],["glance",{"0":{"494":1}}],["gcpbb",{"2":{"419":1}}],["gbps",{"2":{"521":2,"623":2,"667":2,"757":2,"758":2,"780":2}}],["gb",{"2":{"352":1,"521":1,"623":1,"667":1,"709":1,"757":3,"758":2,"780":1}}],["ghcr",{"2":{"275":2,"655":6,"657":6,"658":6}}],["gnark",{"2":{"223":1}}],["gklcgflcsrm9caqasaapsckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwohaqdvbvupglandgtlocgsoherbafsfbb5l0wdvbjjesehegqkaggbgjjcariscgwkbhv0awesbdixotiqto9cgkcjrjcoyijj81bttfb2gudg7o8auawf0bscbhw9ppd99xpq1slpemfyq0y1joj",{"2":{"156":4}}],["gmid",{"2":{"313":2}}],["gms",{"2":{"76":3,"317":3}}],["gmportalscript",{"2":{"75":2,"317":2}}],["gmportal",{"2":{"75":2,"77":7,"317":2,"318":7}}],["gm",{"2":{"75":8,"76":5,"77":8,"78":2,"286":1,"317":13,"318":8,"319":2,"339":1,"358":4,"363":3,"365":6,"366":2}}],["gt",{"2":{"69":1,"75":2,"76":2,"89":8,"137":2,"145":3,"149":8,"151":1,"156":1,"157":2,"159":7,"161":1,"212":8,"213":30,"215":4,"216":4,"218":6,"224":2,"238":1,"269":13,"270":12,"271":12,"275":5,"276":8,"292":4,"293":1,"299":4,"305":4,"308":2,"309":2,"310":2,"312":14,"313":118,"317":4,"355":6,"356":21,"358":6,"360":6,"361":4,"363":8,"365":8,"369":2,"372":4,"375":6,"377":4,"384":1,"401":6,"402":6,"404":12,"409":8,"410":2,"423":4,"424":4,"432":14,"513":6,"515":3,"526":8,"527":4,"528":12,"532":8,"533":6,"534":8,"535":18,"536":20,"537":4,"538":6,"539":16,"540":4,"541":12,"542":2,"545":2,"549":2,"557":2,"573":4,"584":10,"586":10,"587":4,"588":4,"589":16,"592":10,"597":10,"602":8,"603":4,"604":8,"606":9,"638":12,"639":3,"658":2,"664":8,"673":4,"674":12,"679":2,"683":4,"714":6,"715":3,"716":12,"734":6,"751":3,"774":2,"776":2,"777":4,"778":4,"783":4,"786":2,"789":5}}],["go$ver",{"2":{"664":24}}],["goroutine",{"2":{"649":4,"794":4}}],["gone",{"2":{"577":1}}],["google",{"2":{"426":4}}],["good",{"2":{"320":1,"545":1,"656":2}}],["govcelestia",{"2":{"536":1}}],["gov",{"2":{"330":1,"536":12,"537":2}}],["governing",{"2":{"499":1}}],["governance",{"0":{"482":1,"485":1,"499":1,"536":1},"1":{"483":1,"484":1,"485":1,"486":2,"487":2,"488":1,"489":1,"537":1},"2":{"415":1,"418":1,"419":2,"455":1,"460":1,"486":2,"487":1,"489":1,"499":3,"536":3,"537":1,"724":3}}],["governs",{"2":{"243":1}}],["governmental",{"2":{"34":1}}],["government",{"2":{"33":1}}],["governed",{"2":{"31":1}}],["govern",{"2":{"30":1}}],["gobin",{"2":{"268":2}}],["go\\t",{"2":{"170":1}}],["go\\tsharesproof",{"2":{"162":1}}],["goimport",{"2":{"159":1,"323":1,"420":1,"425":1,"426":1}}],["going",{"2":{"71":1,"122":1,"559":1,"616":1,"755":1,"774":1}}],["gopackage",{"2":{"152":1,"153":1,"172":1,"400":1}}],["goleveldb",{"2":{"149":4}}],["golangnodearabica",{"2":{"664":2}}],["golangnodemocha",{"2":{"664":2}}],["golangnodemainnet",{"2":{"664":2}}],["golang",{"0":{"152":1,"157":1,"159":1,"162":1,"321":1,"425":1,"664":1},"1":{"322":1,"323":1,"324":1,"325":1,"326":1,"327":1},"2":{"145":2,"152":1,"157":1,"158":1,"159":1,"162":1,"165":1,"167":1,"168":1,"169":1,"172":1,"238":1,"321":1,"343":1,"394":2,"395":1,"404":1,"425":2,"426":4,"609":1,"664":11}}],["gogo",{"2":{"149":2}}],["gotten",{"2":{"164":1,"184":1}}],["got",{"2":{"139":2,"365":1,"649":2,"794":2}}],["gotype",{"2":{"134":2,"135":1}}],["gossiped",{"2":{"417":1,"428":1,"450":1}}],["gossiping",{"2":{"139":2,"429":1}}],["gossip",{"2":{"139":1,"666":1}}],["gofunc",{"2":{"137":2,"139":1,"165":1,"166":1,"167":1,"168":1,"169":1,"324":1,"402":1,"404":1}}],["goals",{"2":{"263":1}}],["goal",{"2":{"134":1}}],["goes",{"2":{"60":1,"72":1,"188":3,"208":1,"332":1,"606":1,"609":1}}],["go",{"0":{"399":1},"2":{"50":1,"107":1,"134":1,"135":1,"143":1,"145":1,"149":5,"153":6,"157":1,"159":2,"171":1,"172":6,"175":1,"209":1,"223":4,"238":1,"251":1,"252":1,"266":2,"316":1,"325":1,"326":1,"358":1,"396":4,"399":10,"400":3,"401":5,"402":6,"403":1,"404":10,"456":1,"519":1,"531":1,"545":1,"557":2,"576":1,"581":1,"586":1,"599":1,"600":1,"604":2,"649":36,"656":2,"662":1,"664":18,"680":4,"685":1,"771":1,"794":36}}],["gather",{"2":{"586":1}}],["gateways",{"2":{"211":1}}],["gateway",{"0":{"346":1,"347":1},"1":{"347":1},"2":{"89":2,"91":2,"210":1,"211":3,"213":7,"214":1,"219":3,"220":4,"243":1,"341":1,"342":1,"346":3,"347":1,"351":1,"594":3,"748":1}}],["game",{"2":{"394":2}}],["gaming",{"2":{"43":1,"264":1,"320":1}}],["gaining",{"2":{"437":1}}],["gain",{"2":{"48":1,"56":1,"65":1,"394":1,"443":1}}],["gained",{"2":{"38":1}}],["gap",{"2":{"42":1}}],["gauge",{"2":{"42":1}}],["gas=220000",{"2":{"789":1}}],["gas=220000moniker=",{"2":{"789":1}}],["gasperblobbyte",{"2":{"418":1}}],["gasperbyte",{"2":{"418":1,"419":2}}],["gaspricestep",{"2":{"432":2}}],["gasprice",{"2":{"385":2,"408":5,"417":1}}],["gastoconsume",{"2":{"418":2,"419":1}}],["gaslimit",{"2":{"363":4,"375":1,"384":2,"417":1,"420":2,"426":4}}],["gasused",{"2":{"121":2,"285":2,"384":2}}],["gas",{"0":{"366":1,"417":1,"418":1,"419":1,"420":1},"1":{"418":1,"419":1,"420":1},"2":{"31":1,"80":1,"82":1,"84":3,"85":2,"89":4,"117":2,"156":4,"228":1,"235":1,"281":2,"293":1,"323":3,"363":2,"366":12,"375":7,"385":2,"402":2,"408":3,"415":1,"416":2,"417":9,"418":9,"419":18,"420":5,"426":6,"434":3,"478":1,"497":1,"538":2,"540":2,"564":12,"571":2,"682":16,"783":4,"789":4}}],["grid",{"2":{"415":1}}],["grpcaddr",{"2":{"426":4}}],["grpc",{"0":{"426":1,"513":1,"730":1,"734":1,"746":1,"749":1},"2":{"355":3,"380":1,"426":10,"510":3,"513":4,"526":2,"527":1,"545":3,"583":2,"673":2,"682":12,"713":2,"730":21,"734":12,"746":8,"748":3,"749":19}}],["grzxooejihch93+g3mldibq6ff+nroakrbgupfu8muo=",{"2":{"156":2}}],["groundbreaking",{"2":{"720":1}}],["groupname",{"2":{"312":2}}],["group",{"2":{"42":2,"45":1,"46":1,"47":13,"48":7}}],["groups",{"2":{"40":1,"42":2,"45":5,"47":2}}],["grove",{"0":{"736":1},"2":{"509":2,"726":2,"736":2,"744":2}}],["growth",{"2":{"65":1}}],["grow",{"2":{"50":1}}],["growing",{"2":{"50":1}}],["grep",{"2":{"387":1}}],["grepping",{"2":{"387":1}}],["green",{"2":{"146":1}}],["greet",{"2":{"37":1}}],["greater",{"2":{"206":1,"637":1}}],["greatly",{"2":{"46":1}}],["great",{"2":{"41":1,"340":1}}],["grafana",{"2":{"545":3,"547":3,"590":1,"734":1}}],["graphical",{"2":{"548":1}}],["graphics",{"2":{"36":1}}],["graph",{"2":{"305":2}}],["gravity",{"2":{"230":1}}],["gradients",{"2":{"146":1}}],["grading",{"2":{"23":1}}],["grassroots",{"2":{"49":1}}],["gratitude",{"2":{"43":1,"44":1}}],["grantee",{"0":{"295":1},"2":{"290":1,"291":2,"292":5,"294":3,"295":1,"297":1,"299":6}}],["granter",{"0":{"294":1,"297":1,"300":1},"1":{"298":1},"2":{"290":1,"291":2,"292":5,"293":3,"294":2,"295":2,"297":4,"299":6,"300":1,"564":2}}],["granted",{"2":{"53":1,"300":1}}],["grant",{"0":{"294":1},"2":{"34":1,"293":2,"294":5,"297":3,"299":3}}],["granting",{"0":{"292":1,"299":1},"1":{"293":1,"294":1,"300":1},"2":{"34":1,"289":1,"292":1}}],["gracefully",{"2":{"8":1,"676":1}}],["guru",{"2":{"737":1,"747":2,"748":2,"749":2,"753":1}}],["guardian",{"2":{"211":1,"219":1}}],["guardian=",{"2":{"211":2}}],["guaranteeing",{"2":{"457":1}}],["guaranteed",{"2":{"333":1,"459":1,"481":2}}],["guarantees",{"2":{"230":2,"243":1,"481":1}}],["guarantee",{"2":{"27":1,"446":1,"447":1,"450":1,"452":1,"479":1,"513":1,"734":1,"746":1}}],["guidance",{"0":{"39":1},"1":{"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1}}],["guide",{"0":{"35":1,"301":1,"357":1,"613":1,"680":1,"692":1,"768":1},"1":{"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"302":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"358":1,"359":1,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"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,"614":1,"615":1,"616":1,"617":1,"618":1,"619":1,"620":1,"621":1,"681":1,"682":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1,"690":1,"691":1,"693":1,"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":1,"769":1,"770":1,"771":1},"2":{"49":1,"56":1,"60":1,"66":2,"79":3,"83":1,"91":1,"113":1,"226":1,"268":1,"274":1,"289":1,"292":1,"295":1,"301":2,"321":1,"322":1,"339":1,"351":1,"388":1,"405":1,"406":1,"407":1,"508":2,"546":1,"550":2,"553":1,"576":1,"580":1,"590":1,"597":1,"606":1,"622":1,"647":1,"665":1,"680":1,"692":2,"694":1,"695":1,"707":1,"719":1,"725":2,"740":2,"755":1,"771":1,"779":1}}],["guidelines",{"0":{"2":1,"12":1,"58":1},"1":{"13":1,"14":1,"15":1,"16":1},"2":{"2":1,"12":1,"17":1,"39":2}}],["guides",{"2":{"0":1,"3":1,"24":2,"39":1,"92":1,"255":1,"646":1,"740":1,"758":1}}],["gi",{"2":{"151":2}}],["gitgit",{"2":{"87":1}}],["git",{"2":{"75":6,"87":1,"126":1,"212":2,"217":2,"220":2,"223":2,"224":4,"268":3,"317":4,"581":7,"609":7,"663":4}}],["githubusercontent",{"2":{"434":1,"627":10,"663":2}}],["github",{"0":{"338":1},"2":{"27":2,"75":3,"87":2,"149":18,"152":2,"153":14,"159":6,"165":2,"166":2,"169":2,"172":22,"211":2,"212":2,"217":2,"220":2,"223":2,"224":2,"268":2,"317":3,"322":2,"323":6,"338":1,"346":1,"351":1,"399":4,"400":8,"413":2,"420":2,"425":6,"426":16,"550":2,"573":2,"581":2,"594":1,"609":2,"649":16,"758":1,"794":16}}],["given",{"0":{"604":1},"2":{"107":1,"155":1,"180":1,"206":1,"211":1,"218":1,"323":1,"326":3,"380":1,"402":1,"403":2,"408":1,"410":1,"440":1,"453":1,"505":1,"602":2,"604":2,"633":1,"724":1,"763":1,"765":1}}],["gives",{"2":{"45":1,"65":1,"109":1,"193":1,"483":1,"724":1}}],["give",{"0":{"316":1},"2":{"44":1,"255":1,"293":1,"305":2,"308":1,"656":1,"679":1}}],["giving",{"2":{"8":1,"40":1,"109":1}}],["gifts",{"2":{"43":1}}],["g",{"2":{"23":1,"31":1,"33":1,"38":1,"48":2,"290":1,"358":1,"413":1,"415":1,"439":1,"453":1,"459":1,"545":1,"606":1,"639":1,"643":2,"789":1}}],["gem",{"0":{"471":1,"472":1},"1":{"472":1,"473":1,"474":1,"475":1},"2":{"460":1}}],["geoblock",{"2":{"31":1}}],["geolocation",{"2":{"24":1}}],["gentx",{"2":{"530":2,"542":4,"702":5,"703":7}}],["gentxscelestia",{"2":{"703":1}}],["gentxs",{"2":{"530":2,"703":1}}],["gentle",{"2":{"79":1,"80":1,"101":1}}],["genutil",{"2":{"330":1}}],["genuine",{"2":{"53":1,"65":1}}],["genuinely",{"2":{"52":1}}],["genesis",{"0":{"488":1,"542":1,"700":1,"702":1,"703":1},"1":{"489":1},"2":{"169":2,"218":2,"219":4,"443":1,"480":1,"487":1,"488":2,"489":1,"494":1,"530":20,"542":3,"574":1,"584":10,"621":1,"627":7,"635":1,"649":1,"679":1,"700":2,"701":3,"702":2,"703":5,"794":1}}],["generic",{"2":{"117":1,"281":1}}],["generator",{"2":{"310":1}}],["generating",{"0":{"269":1},"2":{"177":1,"183":1,"212":1,"226":1,"396":2}}],["generation",{"2":{"149":1,"182":1,"457":1}}],["generate",{"2":{"177":1,"208":1,"211":1,"212":1,"220":2,"222":2,"223":4,"224":3,"226":1,"237":1,"243":1,"266":1,"269":1,"365":1,"394":1,"397":2,"441":2,"452":1,"530":2,"542":1,"549":4,"576":1}}],["generates",{"2":{"150":1}}],["generated",{"2":{"84":4,"133":1,"145":1,"160":1,"184":1,"208":1,"220":1,"223":1,"224":4,"228":2,"309":1,"323":2,"356":2,"363":1,"368":1,"396":2,"402":1,"408":2,"452":1,"515":1,"527":1,"673":1,"699":1,"702":1,"714":1,"715":1,"751":1}}],["generally",{"2":{"418":1}}],["generalized",{"2":{"181":1}}],["general",{"0":{"31":1,"678":1},"1":{"679":1},"2":{"27":1,"34":1,"206":1,"261":1,"267":1,"418":1,"450":1,"489":1,"678":1}}],["gender",{"2":{"7":1}}],["getaddress",{"2":{"426":2}}],["getall",{"2":{"323":3,"325":2,"402":1,"408":1,"425":2,"481":2}}],["getallgms",{"2":{"76":2,"317":2}}],["getbyheight",{"2":{"326":2,"372":1}}],["getblockdata",{"2":{"135":2,"139":2}}],["getenv",{"2":{"403":2}}],["geteds",{"2":{"326":7,"410":1}}],["getelementbyid",{"2":{"312":2}}],["getlatestblock",{"2":{"139":2}}],["getlatestrollupheight",{"2":{"135":2}}],["getheader",{"2":{"135":4,"139":2}}],["geth",{"2":{"119":1,"337":1}}],["getsigner",{"2":{"313":2}}],["gets",{"2":{"107":1,"108":1,"146":1,"148":2,"181":1,"223":1,"551":1}}],["gettotalgms",{"2":{"76":2,"317":2}}],["getting",{"0":{"124":1,"302":1,"329":1,"771":1},"1":{"125":1,"126":1,"127":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1},"2":{"25":2,"91":2,"93":1,"212":1,"218":1,"313":2,"329":1,"395":1,"436":1,"551":1}}],["get",{"0":{"370":1,"371":1,"372":1,"374":1},"2":{"1":1,"27":1,"39":1,"42":1,"47":1,"107":1,"108":2,"153":8,"156":1,"170":2,"172":4,"184":2,"213":2,"227":1,"260":1,"261":1,"264":1,"287":1,"292":1,"304":1,"322":3,"326":2,"345":1,"363":1,"365":15,"370":1,"371":1,"372":6,"373":4,"377":1,"378":7,"386":2,"392":1,"394":1,"399":4,"401":2,"402":5,"404":4,"405":1,"407":1,"408":2,"409":2,"410":8,"415":1,"419":1,"421":1,"426":2,"436":1,"491":1,"492":1,"527":1,"535":1,"536":1,"546":1,"551":1,"579":1,"582":1,"599":2,"600":2,"601":2,"606":2,"610":1,"627":1,"651":2,"673":2,"683":1,"713":1,"715":1,"768":1,"769":1,"770":1,"771":1,"783":1}}],["oil",{"2":{"561":2}}],["o",{"2":{"223":2,"451":1,"452":2,"638":12}}],["old",{"2":{"161":1,"162":1,"444":1,"592":1,"602":1}}],["older",{"2":{"31":1,"217":1,"480":1,"677":1}}],["ostrich",{"2":{"561":2}}],["os|file|kwallet|pass|test|memory",{"2":{"531":1,"573":2}}],["oss",{"2":{"333":1}}],["os",{"2":{"152":2,"153":2,"172":2,"400":2,"401":8,"402":8,"403":2,"404":8,"544":2,"663":1}}],["occupied",{"2":{"724":1}}],["occurs",{"2":{"437":1}}],["occurring",{"2":{"335":1}}],["occur",{"2":{"139":1,"536":1}}],["occasional",{"2":{"720":1,"760":1}}],["october",{"2":{"28":1}}],["omitempty",{"2":{"134":2}}],["okpajw+kyhnqkq5vch",{"2":{"156":2}}],["ok",{"2":{"117":2,"281":2,"409":4}}],["owners",{"2":{"91":6}}],["ownership",{"2":{"34":1,"91":2,"305":2}}],["owner",{"2":{"84":1,"91":5,"211":3,"213":4,"219":1,"305":12}}],["own",{"2":{"34":2,"84":1,"89":1,"226":1,"230":1,"263":1,"265":1,"303":1,"311":1,"323":1,"336":1,"339":1,"342":1,"381":1,"388":1,"397":1,"413":1,"453":1,"456":1,"457":1,"481":1,"483":1,"497":1,"498":1,"510":1,"513":1,"526":1,"567":1,"571":1,"579":1,"581":1,"618":1,"673":1,"692":1,"698":1,"726":1,"734":1,"736":1,"744":1,"783":1}}],["ovh",{"2":{"24":1}}],["override",{"2":{"545":2}}],["overpaying",{"2":{"419":1}}],["overpay",{"2":{"417":1}}],["overhead",{"2":{"336":1,"337":1}}],["over",{"0":{"687":1},"2":{"59":1,"60":1,"122":1,"134":4,"136":1,"137":1,"148":3,"175":1,"176":1,"208":1,"209":1,"220":1,"238":1,"261":1,"266":2,"301":1,"313":2,"346":1,"356":1,"358":1,"481":1,"499":1,"519":1,"576":1,"586":1,"606":1,"609":1,"662":1,"687":2,"771":1}}],["overview",{"0":{"64":1,"105":1,"113":1,"146":1,"289":1,"478":1,"493":1,"520":1,"666":1,"708":1,"755":1},"1":{"147":1,"148":1,"494":1,"495":1,"496":1,"497":1,"498":1,"499":1,"500":1,"501":1,"502":1,"503":1,"756":1,"757":1,"758":1},"2":{"22":1,"37":1,"47":1,"59":1,"60":1,"61":1,"69":1,"71":1,"79":1,"80":1,"94":1,"101":1,"131":2,"148":1,"302":1,"329":1,"466":1,"470":1,"478":1,"509":2,"590":1,"611":1,"726":2,"744":2}}],["overall",{"2":{"8":1,"41":1,"94":1}}],["otel",{"2":{"24":1,"587":2,"588":2,"590":3}}],["otherwise",{"2":{"11":1,"34":4,"89":1,"107":1,"109":1,"158":1,"192":1,"211":1,"217":1,"219":1,"222":1,"363":1,"380":1,"402":1,"536":1,"696":1,"774":1}}],["others",{"2":{"8":1,"219":1,"705":1}}],["other",{"0":{"335":1,"701":1},"2":{"3":1,"8":2,"9":1,"13":1,"24":2,"25":1,"27":1,"30":2,"31":10,"32":1,"34":12,"40":1,"42":5,"43":2,"45":2,"47":1,"48":3,"52":1,"64":1,"84":1,"105":1,"107":1,"119":1,"129":1,"134":2,"143":1,"145":1,"173":1,"187":1,"206":1,"224":1,"225":1,"235":1,"247":1,"264":1,"269":1,"293":1,"333":2,"335":1,"342":1,"351":1,"355":1,"415":2,"416":1,"419":1,"436":1,"443":1,"446":1,"453":1,"456":2,"481":3,"487":1,"498":1,"514":1,"520":1,"526":1,"596":1,"606":1,"643":1,"673":1,"690":1,"701":2,"702":1,"703":2,"704":2,"705":2,"751":1,"769":1}}],["observe",{"2":{"604":1}}],["observer",{"2":{"587":2}}],["observed",{"2":{"208":1}}],["observance",{"2":{"34":1}}],["objects",{"2":{"313":2}}],["object",{"2":{"88":2}}],["objective",{"2":{"27":1}}],["objectives",{"0":{"19":1},"2":{"19":1,"36":1}}],["obligation",{"2":{"34":1}}],["obligations",{"2":{"33":1}}],["obligated",{"2":{"11":1}}],["obtained",{"2":{"34":2,"218":1,"219":1,"395":1}}],["obtaining",{"2":{"34":2}}],["obtain",{"2":{"32":1,"33":1,"44":1,"88":1}}],["onstart",{"2":{"649":2,"794":2}}],["onto",{"2":{"284":1,"448":1}}],["oncall",{"2":{"547":2}}],["onchange=",{"2":{"313":4}}],["onchain",{"0":{"228":1},"2":{"109":1,"110":1,"211":1,"212":2,"220":1,"222":1,"224":2,"230":2,"239":1,"240":1,"264":1,"320":1,"337":1,"437":1,"489":1,"789":1}}],["onclick=",{"2":{"313":8,"432":2}}],["once",{"2":{"25":1,"85":1,"88":1,"107":1,"120":1,"137":1,"196":1,"203":1,"219":1,"260":1,"266":1,"284":1,"291":1,"308":3,"309":1,"313":2,"356":1,"358":1,"397":1,"439":1,"446":1,"458":1,"479":1,"480":2,"481":1,"527":1,"545":2,"564":1,"637":1,"673":1,"676":1,"701":1,"703":2,"714":1}}],["onboarding",{"0":{"48":1}}],["ones",{"2":{"178":1,"196":1,"222":1,"685":1,"688":1}}],["onestepproofentry",{"2":{"98":1,"99":1}}],["onestepproverhostio",{"2":{"98":1,"99":1}}],["onestepprovermath",{"2":{"98":1,"99":1}}],["onestepprovermemory",{"2":{"98":1,"99":1}}],["onestepprover0",{"2":{"98":1,"99":1}}],["one",{"0":{"421":1},"2":{"34":5,"45":1,"46":1,"47":1,"48":1,"66":2,"76":1,"88":1,"89":1,"102":1,"105":1,"107":1,"108":1,"116":1,"117":1,"143":1,"161":1,"162":1,"175":1,"178":1,"187":1,"193":1,"196":1,"200":3,"208":1,"217":1,"219":1,"221":1,"223":1,"225":2,"238":1,"242":1,"261":1,"263":1,"264":1,"265":1,"269":1,"275":2,"276":2,"280":1,"281":1,"290":2,"291":1,"292":1,"308":1,"317":1,"351":1,"355":3,"400":2,"403":1,"405":1,"414":1,"415":1,"418":1,"421":1,"434":2,"440":1,"452":2,"453":1,"456":2,"458":2,"459":2,"526":1,"527":2,"530":4,"535":5,"536":3,"545":3,"557":1,"559":1,"560":2,"569":1,"571":2,"573":2,"596":1,"597":2,"604":1,"621":2,"666":1,"673":1,"680":2,"682":2,"703":1,"713":4,"714":2,"724":2,"728":1,"729":1,"730":1,"734":1,"746":1,"748":1,"749":1,"784":1}}],["onlyowner",{"2":{"305":8}}],["only",{"2":{"34":2,"89":3,"94":2,"107":2,"108":3,"109":1,"139":2,"158":1,"175":1,"178":1,"181":1,"184":1,"189":1,"214":1,"215":2,"223":1,"237":1,"264":1,"265":1,"269":1,"305":2,"330":1,"332":1,"346":1,"351":1,"361":1,"402":1,"415":1,"419":1,"426":2,"441":1,"443":1,"446":1,"449":1,"450":1,"451":1,"452":2,"453":2,"455":1,"456":3,"457":2,"458":2,"480":2,"481":1,"537":1,"549":2,"561":2,"578":1,"583":1,"596":1,"627":1,"639":1,"661":1,"676":1,"692":1,"734":1,"750":1,"771":1,"789":2}}],["online",{"2":{"10":1,"37":1,"44":1,"45":1,"774":2,"776":2,"777":2,"778":2}}],["onwards",{"2":{"23":1,"172":2}}],["on",{"0":{"73":1,"149":1,"246":1,"256":1,"277":1,"315":1,"317":1,"362":1,"386":1,"483":1,"490":1,"551":1,"560":1,"571":1,"634":1,"644":1,"755":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":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,"247":1,"248":1,"249":1,"250":1,"251":1,"252":1,"253":1,"257":1,"258":1,"259":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"318":1,"319":1,"320":1,"491":1,"492":1,"561":1,"562":1,"563":1,"564":1,"565":1,"566":1,"567":1,"756":1,"757":1,"758":1},"2":{"8":2,"23":1,"24":5,"27":5,"30":3,"31":3,"32":1,"33":1,"34":5,"36":1,"39":1,"40":3,"41":2,"43":2,"44":1,"45":4,"46":5,"47":1,"48":1,"53":1,"59":1,"60":1,"61":2,"65":1,"68":1,"69":2,"71":3,"76":1,"77":3,"78":1,"79":1,"80":2,"82":1,"84":10,"85":2,"86":1,"88":1,"89":5,"90":1,"91":51,"95":1,"105":1,"107":3,"108":1,"109":4,"110":3,"113":1,"114":1,"117":1,"119":2,"129":1,"133":2,"135":6,"137":1,"145":1,"146":1,"148":3,"174":1,"176":1,"177":3,"178":1,"179":1,"180":2,"183":2,"184":2,"187":1,"189":1,"191":1,"211":2,"213":1,"223":3,"224":4,"225":2,"227":1,"228":1,"230":2,"233":2,"234":4,"235":2,"237":5,"238":2,"239":1,"241":1,"242":8,"244":1,"245":2,"246":1,"255":2,"257":1,"259":1,"261":2,"265":1,"266":1,"269":1,"274":2,"275":4,"276":1,"278":1,"281":1,"283":1,"287":4,"289":1,"290":1,"293":3,"294":1,"299":1,"301":1,"312":2,"313":5,"314":1,"315":1,"316":1,"317":1,"318":3,"319":1,"320":3,"323":2,"329":1,"331":1,"333":1,"335":1,"336":1,"337":6,"338":1,"339":2,"342":2,"346":1,"351":1,"354":1,"355":2,"356":3,"360":3,"361":1,"365":1,"366":1,"380":1,"383":1,"384":1,"385":1,"390":1,"391":3,"392":1,"394":2,"396":1,"400":1,"413":1,"415":3,"418":3,"419":6,"425":2,"426":2,"430":1,"437":1,"439":1,"440":1,"448":1,"449":1,"450":1,"451":1,"453":1,"455":2,"456":3,"459":1,"460":2,"465":1,"469":1,"477":1,"478":3,"480":2,"481":6,"483":3,"484":1,"486":2,"496":2,"497":2,"499":1,"504":3,"505":2,"508":1,"510":2,"513":1,"515":2,"520":2,"522":1,"526":4,"527":4,"529":1,"531":1,"536":3,"537":1,"542":1,"544":2,"545":9,"546":1,"547":2,"550":1,"551":1,"552":2,"553":1,"559":3,"567":2,"568":2,"571":2,"572":1,"575":2,"579":2,"581":2,"582":2,"583":4,"585":1,"590":3,"592":2,"594":5,"597":1,"599":1,"609":1,"610":1,"622":1,"624":1,"625":1,"626":1,"632":1,"634":1,"635":1,"636":1,"637":2,"639":1,"643":3,"646":4,"647":1,"649":1,"653":1,"655":3,"656":5,"661":1,"663":1,"668":1,"673":6,"677":2,"678":2,"679":3,"680":3,"682":2,"691":1,"706":2,"707":1,"708":1,"710":2,"713":3,"717":1,"718":1,"724":3,"725":1,"726":2,"728":2,"734":1,"735":1,"736":2,"739":1,"740":7,"744":2,"747":1,"751":2,"754":1,"755":3,"758":1,"763":3,"765":3,"768":1,"771":2,"779":1,"781":2,"782":1,"786":4,"788":1,"789":2,"794":1}}],["opqym",{"2":{"562":2,"566":2}}],["oprexqlg9er1oey1de4mkwvmjlfnqoocg==",{"2":{"372":2}}],["op",{"0":{"245":1,"336":1,"388":1},"1":{"337":1,"338":1,"339":1,"340":1,"389":1,"390":1,"391":1,"392":1,"393":1},"2":{"244":1,"246":1,"254":1,"320":1,"336":1,"337":10,"339":3,"340":1,"383":1,"387":1,"388":3,"389":1,"391":3,"393":1}}],["ops",{"2":{"221":1}}],["opt",{"2":{"220":1,"497":1,"605":4}}],["opted",{"2":{"211":2}}],["optimal",{"2":{"609":1}}],["optimally",{"2":{"456":1}}],["optimized",{"2":{"456":1}}],["optimize",{"2":{"335":1}}],["optimism",{"0":{"383":1},"1":{"384":1,"385":1,"386":1,"387":1},"2":{"245":2,"320":1,"336":1,"337":2,"338":1,"339":1,"383":1,"393":1,"489":1}}],["optimised",{"2":{"230":1}}],["optimistically",{"2":{"187":1,"188":1}}],["optimistic",{"0":{"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1},"1":{"188":1,"189":2,"190":2,"191":2,"192":1,"193":2,"194":2},"2":{"136":1,"139":1,"174":1,"180":1,"187":4,"188":1,"191":1,"195":1,"206":1,"237":1}}],["option",{"0":{"636":1,"637":1,"638":1},"2":{"105":1,"520":1,"536":2,"545":1,"609":2,"616":1,"646":4,"647":1,"771":1,"789":1}}],["options",{"0":{"272":1,"646":1,"791":1},"2":{"40":2,"41":1,"46":1,"83":1,"225":1,"255":1,"257":1,"263":1,"265":1,"313":4,"323":1,"426":6,"530":1,"531":1,"534":1,"535":1,"536":2,"544":2,"564":4,"637":2,"646":1,"725":1,"740":1,"755":1,"771":1,"791":1}}],["optionally",{"2":{"69":1,"71":2,"363":1,"627":1}}],["optional",{"0":{"222":1,"297":1,"298":1,"299":1,"300":1,"364":1,"528":1,"529":1,"572":1,"573":1,"629":1,"633":1,"641":1,"642":1,"646":1,"647":1,"674":1,"675":1,"697":1,"701":1,"716":1,"717":1,"784":1,"788":1,"791":1},"1":{"223":1,"224":1,"298":1,"300":1,"630":1,"631":1,"643":1,"644":1,"645":1,"785":1,"786":1,"787":1,"788":1},"2":{"24":1,"40":1,"45":1,"76":1,"363":10,"433":1,"434":2,"459":1,"564":1,"609":1,"627":1,"639":1}}],["opportunities",{"2":{"48":1,"65":1}}],["opportunity",{"2":{"19":1,"30":1,"32":1}}],["operating",{"2":{"582":1,"605":1,"610":1,"653":1}}],["operations",{"2":{"308":1,"309":1,"418":1,"458":1,"502":1,"504":1,"527":1,"673":1}}],["operation",{"2":{"30":1,"86":1,"117":1,"281":1}}],["operators",{"0":{"607":1},"2":{"337":1,"488":1,"590":1,"679":1,"720":1,"755":1}}],["operator",{"2":{"220":1,"224":1,"226":1,"227":3,"228":1,"543":1,"609":1,"646":1,"679":2}}],["operates",{"2":{"235":1}}],["operate",{"2":{"107":1,"456":1}}],["operated",{"2":{"24":1,"30":1}}],["opened",{"2":{"688":1}}],["opentelemetry",{"2":{"589":1,"590":1}}],["openaikey",{"2":{"403":6}}],["openaimkdir",{"2":{"399":1}}],["openai",{"0":{"397":1},"2":{"394":2,"395":1,"397":5,"399":1,"400":4,"403":15,"404":1}}],["openrpcgo",{"2":{"322":1}}],["openrpc",{"2":{"94":1,"322":2,"323":6,"344":1,"399":2,"400":6,"425":6}}],["openssl",{"2":{"89":1}}],["opening",{"2":{"34":1,"605":2}}],["open",{"0":{"463":1,"468":1,"472":1,"605":1,"687":1},"2":{"7":1,"23":1,"26":1,"28":3,"117":1,"275":1,"281":1,"305":1,"313":2,"314":2,"338":1,"355":1,"463":1,"510":3,"513":1,"526":1,"537":2,"544":2,"545":2,"579":1,"583":3,"590":1,"592":1,"594":2,"605":9,"606":1,"655":1,"673":1,"681":1,"704":1,"706":1,"713":1,"749":1,"786":1}}],["opinions",{"2":{"8":1}}],["our",{"0":{"7":1,"8":1,"120":1},"2":{"7":1,"8":2,"9":1,"10":1,"30":1,"31":1,"33":3,"48":1,"52":2,"53":2,"55":1,"64":1,"65":2,"122":1,"283":1,"306":2,"307":1,"309":2,"314":2,"316":1,"363":1,"368":1,"369":1,"396":4,"400":2,"401":2,"402":5,"404":4,"518":1,"559":1,"571":2,"578":1,"611":1,"657":1,"664":1,"683":1,"699":1}}],["outbound",{"2":{"680":1}}],["outbox",{"2":{"98":1,"99":1}}],["outcome",{"2":{"458":1}}],["outercontainerstyle",{"2":{"313":4}}],["outsource",{"2":{"263":1}}],["outsourcing",{"2":{"263":1}}],["outside",{"2":{"34":2,"205":1,"418":1,"446":1,"480":1}}],["outline",{"2":{"133":2,"139":1,"174":1}}],["outlined",{"2":{"23":1,"102":1,"103":1,"139":1,"192":1,"208":1}}],["outputs",{"2":{"223":1,"541":2}}],["output",{"2":{"75":3,"116":1,"117":1,"120":1,"121":1,"280":1,"281":1,"284":1,"285":1,"296":1,"300":1,"309":1,"317":3,"363":3,"365":4,"372":2,"378":1,"384":1,"385":1,"396":1,"404":1,"530":2,"549":6,"557":2,"561":1,"562":1,"564":1,"565":1,"566":1,"567":2,"573":4,"578":1,"581":1,"582":2,"609":1,"610":2,"663":2,"664":1,"684":1,"687":2,"699":1,"705":2,"712":1,"783":2,"789":1}}],["outputinfo",{"2":{"68":1,"92":1}}],["out",{"0":{"66":1,"70":1,"315":1},"1":{"67":1,"68":1,"69":1,"70":1,"71":2,"72":2},"2":{"0":1,"36":3,"43":1,"44":1,"45":1,"46":1,"66":2,"77":3,"92":1,"107":1,"127":2,"130":1,"135":1,"178":1,"183":2,"188":1,"200":1,"203":1,"230":1,"261":1,"265":1,"283":1,"286":1,"308":1,"310":2,"314":1,"316":1,"318":3,"329":1,"347":1,"355":1,"358":1,"381":1,"421":1,"439":1,"527":1,"544":2,"545":1,"581":1,"590":1,"609":1,"664":1,"692":1,"718":1,"734":1,"740":2,"765":1,"769":1}}],["oracle",{"0":{"108":1},"2":{"106":1,"108":3,"129":1}}],["oral",{"2":{"34":1}}],["originate",{"2":{"428":1}}],["originally",{"2":{"417":1,"597":1}}],["original",{"2":{"79":1,"183":1,"230":1,"421":1,"450":1,"452":3,"453":1,"458":2,"459":1,"565":2}}],["origin",{"2":{"71":1,"430":1,"569":4,"570":1}}],["orientation",{"2":{"7":1}}],["orbitsetupscriptconfig",{"2":{"86":1,"87":1}}],["orbit",{"0":{"66":1,"69":1,"79":1,"84":1,"85":1},"1":{"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"80":1,"81":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},"2":{"66":2,"68":2,"73":1,"79":5,"80":2,"81":1,"82":2,"83":1,"84":8,"85":7,"87":5,"89":1,"90":1,"91":28,"92":1,"94":4,"95":1,"101":3,"105":4,"106":1,"108":1}}],["ordered",{"2":{"453":1,"456":2,"596":2}}],["ordering",{"2":{"41":1,"261":1,"457":1,"687":2}}],["order",{"0":{"604":1},"2":{"30":1,"31":1,"41":1,"43":1,"76":1,"88":1,"107":1,"108":2,"145":1,"148":1,"183":1,"184":1,"260":1,"301":1,"317":1,"359":1,"360":1,"361":1,"370":1,"371":1,"380":1,"390":1,"397":1,"415":1,"417":1,"451":1,"456":1,"479":1,"481":1,"508":1,"510":1,"528":1,"604":2,"651":1,"657":1,"673":1,"674":1,"676":1,"677":1,"678":2,"701":1,"713":1,"716":1,"725":2,"746":1,"771":1,"789":1}}],["organizing",{"2":{"39":1,"42":2,"47":2,"52":1,"56":1,"63":1}}],["organizers",{"2":{"40":1,"43":1,"44":1,"48":2,"49":1,"50":2,"52":1,"53":1,"55":1,"56":2,"65":1}}],["organizer",{"2":{"39":1,"43":1,"47":4,"56":1,"63":1,"65":1}}],["organize",{"2":{"35":2,"42":1,"43":1}}],["organization",{"2":{"27":1}}],["org",{"0":{"6":1,"52":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1},"2":{"7":1,"11":1,"17":3,"25":1,"46":1,"47":2,"52":1,"63":1,"84":1,"426":4,"582":2,"610":2,"664":8,"728":2,"729":2,"730":2,"747":1,"748":1,"749":1}}],["or",{"0":{"100":1,"362":1,"392":1,"572":1},"1":{"101":1,"102":1,"103":1},"2":{"2":1,"4":1,"7":2,"8":8,"9":2,"10":2,"11":1,"13":2,"14":2,"15":2,"16":2,"23":1,"24":7,"25":4,"27":3,"30":9,"31":33,"32":3,"33":6,"34":50,"36":3,"37":4,"38":1,"40":4,"41":3,"42":3,"43":5,"44":4,"45":3,"46":2,"47":1,"48":2,"65":1,"82":1,"83":1,"84":3,"89":2,"91":5,"92":1,"94":1,"102":1,"105":1,"110":2,"131":1,"133":1,"135":1,"136":1,"139":2,"143":2,"145":1,"146":2,"148":1,"169":1,"174":1,"178":1,"183":1,"195":1,"212":2,"213":1,"214":1,"217":1,"220":3,"222":1,"224":1,"233":2,"234":1,"237":1,"261":2,"263":1,"264":1,"265":3,"267":1,"268":1,"269":3,"276":1,"278":1,"287":5,"301":1,"307":1,"310":1,"311":1,"312":2,"313":2,"314":1,"332":1,"346":2,"354":1,"355":2,"356":2,"358":1,"359":1,"362":2,"363":1,"380":2,"395":1,"414":1,"417":1,"418":1,"421":1,"426":4,"428":1,"429":1,"430":1,"437":2,"443":1,"447":1,"452":1,"456":1,"459":1,"466":1,"470":1,"475":1,"477":1,"481":2,"483":1,"489":2,"497":1,"502":1,"504":1,"510":1,"512":1,"513":3,"514":1,"520":1,"526":3,"530":4,"531":1,"542":1,"545":6,"547":3,"548":1,"551":2,"571":1,"572":2,"579":1,"589":2,"602":2,"606":4,"627":1,"634":1,"637":1,"643":1,"653":1,"654":1,"655":2,"657":1,"673":3,"677":1,"679":1,"688":1,"692":1,"702":1,"705":1,"713":2,"714":1,"720":2,"724":1,"726":1,"733":1,"734":3,"736":1,"744":1,"745":1,"746":1,"748":1,"751":1,"758":2,"760":1,"773":1,"786":1}}],["often",{"2":{"40":1,"42":1,"43":1,"45":1,"417":1,"419":1,"677":1}}],["offloads",{"2":{"260":1}}],["offline",{"2":{"10":1,"551":1,"679":1}}],["off",{"2":{"228":1,"402":1,"545":1}}],["offchain",{"2":{"79":2,"91":1,"235":1,"240":1,"437":1}}],["offshore",{"2":{"34":1}}],["offense",{"2":{"551":1}}],["offensive",{"2":{"9":1}}],["offers",{"2":{"57":1,"83":1,"230":1,"235":1,"246":1,"771":1}}],["offered",{"2":{"34":1,"42":1}}],["offer",{"2":{"34":5,"40":4,"41":1,"43":1,"44":2,"235":1}}],["offering",{"2":{"34":1,"41":1,"105":1}}],["officially",{"2":{"10":1}}],["official",{"2":{"0":1,"10":2,"89":1}}],["of",{"0":{"6":1,"19":1,"52":1,"66":1,"146":1,"153":1,"181":1,"182":1,"183":1,"184":2,"185":1,"186":1,"188":1,"189":1,"190":1,"191":1,"196":1,"197":1,"198":1,"231":1,"234":1,"262":1,"263":1,"369":1,"375":1,"440":1,"446":1,"448":1,"452":1,"458":1,"473":1,"483":1,"493":1,"495":1,"498":1,"520":1,"558":1,"567":1,"595":1,"666":1,"708":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"147":1,"148":1,"182":1,"183":1,"184":1,"185":1,"186":1,"189":1,"190":1,"191":1,"197":1,"198":1,"263":1,"264":1,"265":1,"459":1,"494":1,"495":1,"496":2,"497":2,"498":2,"499":2,"500":2,"501":2,"502":2,"503":2,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1},"2":{"0":1,"2":1,"7":2,"8":6,"9":2,"10":2,"11":3,"12":2,"13":3,"14":3,"15":4,"16":6,"17":4,"19":3,"21":1,"22":3,"23":5,"24":7,"25":1,"26":2,"27":3,"28":1,"30":9,"31":14,"32":5,"33":10,"34":47,"36":2,"37":1,"38":1,"39":3,"40":3,"41":1,"42":8,"43":5,"44":6,"45":1,"46":2,"47":5,"48":4,"49":1,"50":1,"52":5,"53":2,"55":1,"56":2,"59":2,"60":1,"61":1,"62":1,"64":1,"65":7,"66":3,"68":1,"69":3,"71":1,"72":1,"75":1,"76":1,"77":1,"79":3,"82":2,"84":6,"85":3,"87":2,"88":1,"89":3,"90":1,"91":5,"92":3,"94":1,"102":1,"105":1,"106":2,"107":8,"108":2,"109":2,"110":2,"114":2,"116":1,"117":3,"121":1,"126":1,"128":3,"131":5,"134":28,"135":10,"136":3,"137":2,"139":8,"143":2,"145":1,"146":4,"148":12,"149":2,"150":2,"151":1,"154":3,"158":1,"159":3,"160":4,"161":3,"162":2,"163":8,"164":1,"165":12,"166":2,"167":1,"168":10,"169":10,"170":2,"172":8,"173":1,"174":1,"175":1,"177":2,"178":4,"179":2,"180":1,"181":9,"182":1,"183":10,"184":20,"185":2,"187":2,"188":6,"189":1,"191":2,"192":10,"194":2,"195":1,"196":9,"197":1,"200":4,"203":4,"205":1,"206":3,"208":6,"210":1,"211":12,"212":2,"213":13,"214":2,"215":2,"217":3,"219":6,"220":8,"223":2,"224":2,"225":1,"226":1,"227":1,"228":1,"230":6,"231":1,"233":2,"234":1,"235":3,"236":1,"237":4,"238":1,"245":2,"250":1,"254":2,"255":1,"260":1,"261":6,"263":7,"264":6,"265":3,"266":1,"268":2,"269":1,"274":1,"275":1,"278":2,"280":1,"281":3,"284":1,"285":1,"287":3,"292":1,"293":1,"294":1,"295":2,"302":1,"305":5,"308":4,"309":2,"310":1,"312":2,"313":2,"317":2,"318":1,"320":1,"322":1,"323":3,"325":5,"326":2,"327":1,"330":1,"333":1,"335":2,"337":2,"339":1,"340":1,"342":3,"344":1,"351":1,"355":1,"357":1,"358":1,"359":2,"360":2,"362":1,"363":8,"365":3,"366":3,"368":1,"369":4,"372":2,"375":3,"378":1,"384":1,"392":2,"394":2,"396":1,"404":2,"407":1,"408":3,"409":3,"410":2,"411":1,"412":1,"413":2,"414":1,"416":2,"417":5,"418":10,"419":8,"420":3,"421":3,"426":4,"428":2,"429":1,"430":1,"433":1,"434":1,"436":2,"437":4,"439":3,"440":3,"441":1,"442":1,"443":2,"445":2,"446":4,"447":2,"448":1,"449":2,"450":5,"451":5,"452":8,"453":7,"455":7,"456":11,"457":4,"458":15,"459":4,"460":1,"464":1,"465":1,"469":1,"473":1,"477":3,"478":2,"479":3,"480":6,"481":4,"483":5,"484":3,"486":2,"487":1,"488":4,"489":5,"490":2,"494":1,"496":1,"497":2,"498":3,"499":2,"508":1,"510":2,"513":1,"514":2,"515":1,"520":3,"526":3,"527":1,"528":7,"536":3,"537":1,"543":1,"544":4,"545":2,"546":1,"547":1,"548":1,"549":2,"551":7,"552":1,"557":2,"558":1,"559":1,"564":1,"567":3,"568":2,"569":4,"572":2,"579":1,"581":2,"589":1,"590":2,"592":1,"596":3,"597":1,"604":1,"605":1,"606":3,"609":2,"611":1,"615":2,"618":1,"619":1,"621":1,"627":2,"631":1,"633":1,"634":3,"635":1,"636":2,"637":1,"647":4,"649":1,"653":1,"654":2,"655":1,"661":1,"664":2,"673":3,"674":7,"677":1,"678":3,"679":1,"680":2,"681":2,"683":1,"699":3,"703":2,"704":2,"706":1,"708":1,"712":1,"713":2,"716":7,"719":3,"723":1,"724":2,"725":4,"734":2,"735":1,"740":5,"746":1,"751":3,"755":1,"760":2,"769":1,"771":1,"776":1,"777":1,"783":2,"784":1,"786":2,"789":5,"792":1,"794":1}}],["mzonder",{"2":{"728":1,"729":1,"730":1}}],["m",{"2":{"391":2,"491":1,"738":1}}],["mb",{"2":{"352":1,"709":1,"757":1}}],["mbidstyle",{"2":{"313":4}}],["mykey",{"2":{"309":3,"315":2}}],["my",{"2":{"276":4,"305":14,"308":2,"309":2,"390":1,"396":2,"656":5,"657":8,"658":8,"714":6}}],["myrollup",{"2":{"127":2}}],["mnemonic",{"2":{"271":2,"396":2,"561":3,"578":1,"683":4}}],["mv",{"2":{"224":2}}],["md013",{"2":{"372":2}}],["md",{"2":{"169":2}}],["mtgbzqhrqol61okkzmhrfyq5bk6goklgwrvparpyxve=",{"2":{"156":2}}],["msgcreatevestingaccount",{"2":{"564":2}}],["msgsubmitproposal",{"2":{"536":2}}],["msgsend",{"2":{"299":2}}],["msgpayforblobs",{"2":{"156":2,"176":1,"299":2,"350":2,"414":1,"419":2}}],["msg",{"2":{"156":2,"305":4,"403":4,"458":1,"536":1,"682":4}}],["mkdir",{"2":{"115":2,"223":2,"224":2,"279":2,"638":6,"656":2}}],["mutual",{"0":{"619":1}}],["mutually",{"2":{"42":1}}],["mut",{"2":{"409":2}}],["multiaddress",{"2":{"777":1}}],["multiaddresses",{"2":{"618":1}}],["multi",{"2":{"550":1}}],["multiplier",{"2":{"682":4}}],["multiplies",{"2":{"419":1}}],["multiple",{"0":{"421":1},"2":{"43":1,"103":1,"131":1,"148":1,"159":1,"160":3,"163":8,"165":4,"181":2,"264":1,"351":1,"439":1,"442":1,"447":1,"450":1,"453":1,"456":2,"458":1,"517":1,"545":1,"596":1,"607":1,"737":1}}],["multiproof",{"2":{"165":2}}],["multisign",{"2":{"549":2}}],["multisig",{"0":{"548":1},"1":{"549":1,"550":1},"2":{"84":1,"243":1,"548":3,"549":18,"550":3}}],["much",{"2":{"41":1,"89":1,"261":1,"263":1,"264":1,"702":1}}],["mustnewv0",{"2":{"426":2}}],["must",{"2":{"30":1,"31":2,"84":2,"89":1,"301":1,"322":1,"390":2,"392":1,"407":1,"417":1,"421":3,"449":1,"451":1,"453":3,"456":2,"528":2,"536":1,"602":4,"632":1,"637":1,"652":1,"664":1,"673":1,"674":2,"696":1,"697":1,"698":1,"703":2,"713":1,"716":2,"724":1,"789":1}}],["milestone",{"2":{"740":1}}],["million",{"2":{"541":2}}],["middleware",{"2":{"691":1}}],["migrate",{"2":{"530":4}}],["might",{"2":{"40":3,"180":1,"261":1,"355":1,"358":1,"452":1,"536":1,"605":1,"627":1,"633":1,"734":1,"763":1}}],["microtia",{"0":{"503":1},"2":{"503":1}}],["micro",{"2":{"502":1}}],["microphone",{"2":{"40":2}}],["microphones",{"2":{"36":1,"40":1}}],["mib",{"2":{"415":3,"724":1}}],["mixhash",{"2":{"384":2}}],["mit",{"2":{"305":4,"307":2}}],["mirrors",{"2":{"246":1}}],["miner",{"2":{"384":2}}],["mined",{"2":{"91":4}}],["mintscan",{"2":{"434":1,"737":1,"753":1}}],["mint",{"2":{"330":1}}],["minority",{"2":{"536":1}}],["minor",{"2":{"330":1}}],["mins",{"2":{"220":1}}],["minns",{"2":{"165":2,"172":2}}],["minnamespace",{"2":{"165":4,"172":4}}],["min",{"2":{"165":4,"542":2,"631":1,"634":4,"682":4,"789":3}}],["minimized",{"2":{"449":1}}],["minimal",{"2":{"127":1,"189":1,"330":1,"336":1,"609":1,"720":1}}],["minimum",{"0":{"623":1},"2":{"24":1,"84":1,"91":4,"126":1,"165":2,"260":1,"352":2,"417":1,"440":1,"521":2,"623":1,"667":2,"709":2,"780":1}}],["minutes",{"2":{"43":1,"107":1,"220":1,"223":1,"224":1,"226":1,"637":1}}],["minute",{"0":{"660":1},"2":{"41":1,"48":1,"421":1,"551":1}}],["mind",{"2":{"41":1,"269":2,"627":1,"789":1}}],["mindful",{"2":{"41":1}}],["misbehaviour",{"2":{"682":2}}],["mismatch",{"2":{"452":1}}],["misuse",{"2":{"89":1}}],["mission",{"2":{"19":1}}],["mistakes",{"2":{"8":1}}],["moonli",{"2":{"728":1,"729":1}}],["mock",{"2":{"391":1}}],["mocha4",{"2":{"746":1,"747":1,"749":1}}],["mocharesturl",{"2":{"432":2}}],["mocharpcurl",{"2":{"432":2}}],["mochamainnet",{"2":{"390":1}}],["mochachainid",{"2":{"361":3,"390":2,"432":2,"593":1,"627":8,"638":2,"783":2,"789":2}}],["mochacelestia",{"2":{"89":1,"354":1,"355":2,"356":1,"526":1,"527":1,"528":1,"535":1,"588":1,"597":1,"603":1,"672":1,"674":1,"712":1,"713":1,"714":1,"716":1}}],["mochadocker",{"2":{"275":1}}],["mochaversions",{"2":{"275":2,"581":4,"609":2,"655":2,"657":2,"658":2}}],["mocha",{"0":{"89":1,"391":1,"392":1,"492":1,"568":1,"571":1,"588":1,"599":1,"600":1,"740":1,"751":1,"765":1,"766":1},"1":{"569":1,"570":1,"571":1,"572":1,"573":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},"2":{"24":3,"27":1,"28":1,"79":1,"80":2,"89":7,"95":1,"107":1,"145":2,"242":3,"245":2,"269":3,"275":4,"276":8,"289":1,"290":3,"292":2,"293":2,"294":2,"299":5,"300":2,"354":1,"355":5,"356":3,"388":1,"390":2,"391":1,"432":6,"434":5,"492":3,"504":2,"505":2,"526":2,"527":6,"528":1,"535":5,"553":1,"559":1,"567":1,"568":2,"571":7,"573":4,"575":1,"579":1,"588":4,"593":2,"596":1,"597":7,"599":2,"600":2,"603":1,"606":1,"627":1,"655":1,"672":1,"673":3,"674":1,"678":1,"679":3,"680":1,"682":9,"683":2,"685":1,"686":6,"687":6,"688":3,"712":1,"713":4,"714":3,"715":1,"716":1,"740":7,"746":6,"747":8,"748":8,"749":13,"750":16,"751":2,"752":1,"753":2,"754":2,"765":4,"767":1,"771":2,"786":1,"789":1}}],["mounted",{"2":{"276":1}}],["mounting",{"0":{"276":1},"2":{"276":1,"656":1}}],["mount",{"2":{"275":1,"276":1,"390":1,"656":2,"657":1,"661":1}}],["moment",{"2":{"189":1,"192":1,"308":1,"590":1}}],["moved",{"2":{"456":1,"703":1}}],["move",{"2":{"69":2,"71":1,"87":1,"356":1}}],["moniker",{"2":{"789":3}}],["moniker=$moniker",{"2":{"542":2,"789":2}}],["moniker=validator",{"2":{"542":2}}],["monitors",{"2":{"552":1}}],["monitor",{"0":{"552":1},"2":{"429":1,"430":1,"545":4,"552":1,"590":1}}],["monitoring",{"0":{"429":1},"2":{"24":1,"27":1,"543":1,"547":1,"663":1}}],["monolithic",{"0":{"456":1},"2":{"59":1,"261":2,"329":1,"337":1,"456":3}}],["monthly",{"2":{"42":1,"54":1}}],["month",{"2":{"24":1,"26":1}}],["months",{"2":{"22":1,"23":6,"24":1,"26":1,"27":1,"175":1,"177":1}}],["modifiable",{"2":{"536":1}}],["modifications",{"2":{"330":1}}],["modifier",{"2":{"305":4}}],["modified",{"2":{"245":1,"335":1,"339":1,"453":1,"455":1,"520":1}}],["modifying",{"2":{"704":1}}],["modify",{"0":{"704":1},"2":{"309":1,"358":1,"392":1,"605":1,"704":1}}],["module=consensus",{"2":{"649":2,"794":2}}],["moduleencodingregisters",{"2":{"426":2}}],["modules",{"2":{"310":1,"330":2,"399":1,"418":1}}],["module",{"0":{"288":1,"293":1},"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},"2":{"289":1,"291":1,"293":1,"300":1,"358":5,"361":2,"377":2,"420":1,"432":2,"536":4,"551":1,"690":1,"691":1}}],["modularity",{"0":{"59":1},"2":{"48":1,"59":1}}],["modular",{"0":{"35":1,"48":1,"49":1,"57":1,"62":1,"229":1,"261":1,"262":1,"301":1,"456":1},"1":{"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1,"58":1,"59":1,"60":1,"61":1,"62":1,"63":1,"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1,"263":1,"264":1,"265":1,"302":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1},"2":{"19":1,"35":2,"39":1,"40":1,"41":2,"42":3,"43":4,"45":1,"46":1,"47":2,"48":2,"49":2,"50":2,"53":3,"54":1,"56":2,"57":2,"59":4,"62":3,"63":1,"65":9,"237":1,"255":2,"261":4,"263":2,"264":2,"265":1,"301":3,"313":2,"329":2,"336":1,"404":2,"436":1,"456":3,"457":2,"496":1,"497":1,"737":1}}],["mod",{"2":{"149":3,"399":2,"557":2,"649":14,"680":1,"794":14}}],["mode=",{"2":{"549":2}}],["model",{"2":{"403":2,"419":1,"499":1}}],["modern",{"2":{"310":1,"749":1}}],["moderation",{"2":{"9":1}}],["mode",{"2":{"68":2,"220":2,"299":2,"313":2,"497":1,"549":4,"573":4,"635":1,"682":12}}],["mozilla",{"2":{"17":1}}],["more",{"0":{"140":1},"1":{"141":1,"142":1,"143":1},"2":{"5":1,"21":1,"25":1,"33":1,"40":1,"41":1,"42":1,"44":1,"71":1,"79":3,"84":3,"85":1,"90":1,"92":1,"105":1,"108":1,"110":1,"116":1,"117":1,"134":2,"135":2,"136":2,"145":1,"146":2,"148":2,"151":1,"156":1,"161":1,"172":1,"177":1,"178":1,"183":1,"184":2,"191":1,"199":1,"203":1,"205":1,"208":2,"219":1,"221":1,"235":2,"236":1,"238":1,"239":2,"241":1,"243":1,"245":1,"246":1,"261":1,"264":3,"265":1,"269":1,"275":1,"280":1,"281":1,"291":1,"293":1,"301":1,"313":2,"331":1,"337":1,"346":1,"347":1,"350":1,"351":2,"356":1,"358":2,"365":1,"366":1,"392":1,"393":1,"403":1,"405":1,"414":1,"415":1,"419":1,"420":1,"424":1,"425":1,"427":1,"436":1,"439":1,"440":1,"450":1,"451":3,"453":1,"455":3,"457":1,"459":1,"486":1,"499":1,"518":1,"527":1,"531":1,"536":1,"547":1,"551":3,"560":1,"561":1,"571":1,"573":2,"574":1,"581":1,"582":2,"594":1,"605":1,"609":1,"610":1,"637":1,"653":1,"673":1,"735":1,"736":1,"739":1,"754":1,"755":1,"767":1,"783":2}}],["mostly",{"2":{"673":1}}],["most",{"2":{"0":1,"43":1,"48":5,"50":1,"88":1,"208":1,"321":1,"333":1,"406":1,"438":1,"446":1,"615":1,"636":1,"653":1,"708":1}}],["mesa",{"2":{"728":1,"729":1,"730":1,"734":1,"746":1,"747":1,"749":1}}],["messages",{"2":{"36":1,"38":1,"199":1,"299":2,"330":1,"394":1,"403":2,"536":2,"564":2}}],["message",{"2":{"2":1,"47":3,"107":1,"110":1,"156":2,"365":1,"403":4,"404":2,"405":1,"419":1,"458":2,"574":1,"579":1}}],["me",{"2":{"311":2,"312":8,"313":2,"644":2,"705":2,"728":1,"729":1,"747":1,"748":1,"749":1}}],["mechanisms",{"2":{"85":1,"110":1,"139":1,"418":1,"419":1}}],["mechanism",{"0":{"110":1,"234":1},"2":{"85":1,"106":1,"110":4,"173":1,"208":1,"237":1,"287":2,"438":1,"439":1,"449":1,"481":1,"483":1,"490":1,"547":1,"551":1,"636":1}}],["measured",{"2":{"84":1}}],["meant",{"2":{"346":1,"509":1,"726":1,"744":1}}],["mean",{"2":{"135":2,"297":1}}],["meaningful",{"2":{"335":1}}],["meaning",{"2":{"30":1,"177":2,"335":1,"520":1,"638":1}}],["means",{"2":{"22":1,"148":1,"208":1,"214":1,"264":2,"294":1,"305":2,"330":1,"354":1,"415":1,"417":1,"421":1,"451":2,"456":2,"460":1,"478":1,"480":1,"606":1,"643":2,"652":1,"653":1}}],["metric",{"2":{"586":1}}],["metricscurl",{"2":{"544":1}}],["metrics",{"0":{"543":1,"585":1,"586":1,"590":1},"1":{"544":1,"545":1,"546":1,"547":1,"586":1,"587":2,"588":2,"589":2,"590":1},"2":{"33":1,"543":3,"544":8,"545":3,"546":2,"585":2,"586":12,"587":6,"588":6,"589":15,"590":2,"681":1}}],["met",{"2":{"417":1}}],["meta",{"2":{"313":4}}],["metadata",{"2":{"169":2,"264":1,"459":1,"708":1}}],["metamaskwallet",{"2":{"312":4}}],["metamask",{"0":{"314":1},"2":{"80":1,"303":1,"314":2,"315":3}}],["methods",{"2":{"322":2,"327":1,"358":1,"407":2,"411":1,"427":1,"481":1}}],["method",{"2":{"129":1,"131":2,"162":2,"166":1,"175":1,"183":1,"219":1,"238":1,"323":2,"324":2,"325":2,"326":2,"334":1,"337":1,"358":5,"361":2,"377":3,"378":1,"380":2,"386":2,"408":2,"409":2,"410":2,"432":2,"481":3}}],["menu",{"2":{"68":1,"377":2,"388":1,"434":1,"571":1,"581":1,"582":1,"610":1}}],["mentioned",{"2":{"102":1,"746":1}}],["mention",{"2":{"44":2}}],["memo",{"2":{"564":2,"682":4}}],["memory",{"2":{"136":1,"172":2,"305":26,"352":1,"521":1,"546":1,"623":1,"667":1,"709":1,"757":1,"758":1,"780":1}}],["memorable",{"2":{"65":1,"84":1}}],["mempool",{"0":{"416":1},"1":{"417":1,"418":1,"419":1,"420":1,"421":1},"2":{"287":1,"415":1,"416":2,"417":2,"421":2,"426":2,"478":1}}],["member",{"2":{"47":1}}],["members",{"0":{"48":1},"2":{"7":1,"23":1,"36":1,"45":3,"47":2,"48":2,"234":1,"421":1,"488":1,"537":1}}],["mev",{"2":{"48":1}}],["merge",{"2":{"602":1}}],["merkelized",{"2":{"477":1}}],["merkelizes",{"2":{"237":1}}],["merkleized",{"2":{"128":1,"148":1}}],["merkle",{"0":{"203":1,"204":1,"205":1,"453":1},"1":{"204":1,"205":1},"2":{"108":1,"128":4,"129":1,"131":1,"136":1,"148":3,"150":2,"153":4,"154":3,"160":1,"163":2,"165":4,"168":4,"169":4,"172":8,"177":6,"183":2,"184":5,"197":1,"199":1,"205":1,"234":1,"237":2,"351":1,"449":1,"450":6,"451":1,"452":2,"453":2,"455":2,"458":4,"459":3}}],["merchandise",{"2":{"63":2}}],["merits",{"2":{"34":1}}],["merely",{"2":{"27":1}}],["meetups",{"2":{"38":1,"40":4,"42":5,"43":1,"44":1,"45":1,"46":4,"47":6,"48":2,"49":1,"57":3,"63":2,"65":1}}],["meetup",{"0":{"35":1,"36":1,"37":1,"38":1,"47":1,"48":1,"49":1,"57":1,"62":1},"1":{"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1,"58":1,"59":1,"60":1,"61":1,"62":1,"63":1},"2":{"35":2,"36":2,"38":1,"39":3,"40":4,"41":2,"42":7,"43":9,"44":5,"45":8,"46":4,"47":10,"48":5,"49":1,"50":4,"52":1,"53":2,"54":1,"56":4,"62":2,"63":1,"65":6}}],["meet",{"2":{"22":1}}],["media",{"2":{"3":1,"10":1,"14":1,"36":1,"38":1,"45":4,"46":1,"320":1}}],["mac",{"2":{"654":1,"656":1,"664":2}}],["macos",{"2":{"391":2}}],["machines",{"2":{"456":1,"545":1,"643":1}}],["machine",{"2":{"2":1,"80":1,"114":1,"220":2,"223":1,"224":1,"226":1,"246":1,"274":1,"275":1,"278":1,"354":1,"355":1,"396":1,"417":1,"419":1,"455":3,"456":1,"458":2,"520":1,"522":1,"526":1,"545":1,"559":2,"579":1,"583":1,"592":1,"594":1,"624":1,"653":1,"655":1,"656":3,"668":1,"673":1,"690":1,"706":1,"710":1,"713":1,"781":1,"786":1}}],["magnitude",{"2":{"335":1}}],["map",{"2":{"313":8}}],["mappings",{"2":{"305":2}}],["mapping",{"2":{"108":1,"165":2,"168":1,"305":4,"413":1}}],["marginright",{"2":{"313":4}}],["margintop",{"2":{"313":4}}],["marginbottom",{"2":{"313":2}}],["margin",{"2":{"312":2,"313":4}}],["marking",{"2":{"480":1}}],["markdownlint",{"2":{"372":2}}],["markdown",{"2":{"311":1}}],["markdownnpm",{"2":{"311":1}}],["marks",{"2":{"105":1,"719":1,"760":1}}],["marketing",{"0":{"45":1},"2":{"45":1}}],["market",{"0":{"416":1,"478":1},"1":{"417":1,"418":1,"419":1,"420":1,"421":1},"2":{"34":3}}],["mark",{"2":{"27":1}}],["mass",{"2":{"301":1}}],["master",{"2":{"169":2,"434":1,"627":10}}],["majority",{"2":{"452":1}}],["major",{"2":{"184":1,"455":1}}],["malicious",{"2":{"139":1,"217":2,"452":1,"551":1}}],["math",{"2":{"153":2,"172":2}}],["matrix",{"0":{"94":1},"2":{"89":1,"450":4,"452":1,"458":5,"459":1}}],["matching",{"2":{"413":1}}],["matches",{"2":{"89":1,"208":1,"276":1}}],["match",{"2":{"77":1,"134":1,"149":1,"318":1,"409":4}}],["matters",{"2":{"34":1,"183":1}}],["materials",{"0":{"56":1},"2":{"0":1,"3":1,"36":2,"37":1,"57":1}}],["made",{"2":{"34":6,"79":1,"109":1,"237":1,"265":1,"295":1,"339":1,"341":1,"440":1,"455":1,"458":2,"459":1,"477":2,"481":1,"559":1,"567":1,"596":1}}],["manual",{"2":{"481":1}}],["manually",{"2":{"310":1,"314":1,"358":1,"421":1,"426":2,"429":1,"481":1,"596":1,"618":1,"621":1,"627":2}}],["managing",{"2":{"291":1}}],["manager",{"2":{"545":1}}],["management",{"0":{"331":1,"532":1,"535":1},"1":{"533":1},"2":{"331":1,"653":1}}],["manages",{"2":{"211":1}}],["managed",{"2":{"177":1,"337":1,"480":1}}],["manage",{"0":{"466":1,"470":1,"475":1},"2":{"31":1,"36":1,"42":1,"267":1,"426":2,"530":2,"647":1}}],["many",{"0":{"605":1},"2":{"45":1,"134":1,"143":1,"264":1,"320":1,"331":1,"418":1,"420":1,"456":1,"484":1,"487":1,"505":1,"545":1,"605":2,"663":1,"755":1}}],["manner",{"2":{"25":1,"31":1,"34":1,"661":1}}],["maxvalidators",{"2":{"536":4}}],["maxwidth",{"2":{"313":4}}],["maximize",{"2":{"265":1}}],["maximum",{"0":{"415":1,"724":1},"2":{"165":2,"358":1,"415":2,"419":1,"544":2,"724":8}}],["maxns",{"2":{"165":2,"172":2}}],["maxnamespace",{"2":{"165":4,"172":4}}],["max",{"2":{"27":1,"165":4,"238":1,"536":3,"542":4,"544":2,"682":20,"723":1,"789":4}}],["may",{"0":{"447":1},"2":{"11":1,"13":1,"14":1,"15":1,"23":1,"24":1,"30":3,"31":6,"32":1,"33":4,"34":11,"40":2,"44":2,"45":3,"76":1,"83":1,"85":1,"89":1,"173":1,"317":1,"400":1,"418":1,"428":1,"429":1,"447":1,"459":2,"480":1,"481":1,"487":1,"489":1,"497":1,"572":1,"583":1,"594":1,"605":1,"637":1,"646":1,"656":1,"720":1,"760":1}}],["mail",{"2":{"10":1,"34":1}}],["maintenance",{"2":{"488":1}}],["maintained",{"2":{"238":1}}],["maintaining",{"2":{"52":1,"60":1,"84":1,"230":1,"421":1}}],["maintains",{"2":{"23":1}}],["maintain",{"2":{"19":1,"23":1,"24":2,"28":1,"34":2,"38":1,"42":1,"43":1,"45":1,"243":1,"596":1}}],["mainly",{"2":{"224":2}}],["mainnetversions",{"2":{"581":4,"609":2,"655":2,"657":2,"658":2}}],["mainnetresturl",{"2":{"432":2}}],["mainnetrpcurl",{"2":{"432":2}}],["mainnetchainid",{"2":{"432":2,"593":2,"627":8,"638":2}}],["mainnet",{"0":{"491":1,"587":1,"599":1,"719":1,"760":1,"761":1},"1":{"720":1,"721":1,"722":1,"723":1,"724":1,"725":1,"726":1,"727":1,"728":1,"729":1,"730":1,"731":1,"732":1,"733":1,"734":1,"735":1,"736":1,"737":1,"738":1,"739":1,"761":1},"2":{"24":4,"25":1,"27":4,"28":1,"30":2,"110":1,"145":2,"238":2,"242":4,"269":3,"275":1,"276":1,"287":1,"314":1,"354":1,"355":2,"356":2,"380":1,"415":1,"432":5,"491":1,"514":2,"526":1,"527":1,"528":1,"581":1,"587":1,"592":1,"593":3,"596":1,"599":3,"606":1,"609":1,"627":5,"635":1,"638":1,"639":1,"655":3,"657":1,"658":1,"664":1,"672":1,"673":1,"674":1,"678":1,"679":3,"712":1,"713":2,"714":1,"716":1,"719":3,"720":2,"725":2,"728":3,"729":3,"730":3,"731":2,"734":4,"737":4,"738":3,"739":2,"751":2,"760":2,"767":1,"789":1}}],["main",{"0":{"401":1},"2":{"2":1,"77":1,"92":1,"152":4,"153":4,"172":4,"223":16,"224":2,"312":2,"318":1,"358":1,"400":6,"401":5,"402":5,"404":9,"455":1,"550":1}}],["making",{"2":{"2":1,"47":1,"48":1,"91":1,"237":1,"246":1,"295":1,"359":1,"456":1,"457":1,"599":1,"600":1,"643":1,"644":1,"645":1,"646":1,"647":1}}],["makeconfig",{"2":{"426":2}}],["makes",{"0":{"440":1},"2":{"34":1,"196":1,"245":1,"416":1}}],["make",{"2":{"0":1,"2":1,"7":1,"31":1,"50":1,"88":1,"89":1,"107":1,"121":1,"125":1,"126":1,"130":1,"149":3,"153":2,"165":5,"167":2,"168":4,"169":2,"171":2,"172":12,"177":1,"192":1,"211":3,"213":1,"220":3,"223":1,"224":2,"237":1,"263":1,"264":2,"268":5,"269":1,"285":1,"306":1,"313":2,"396":1,"450":1,"458":1,"481":1,"543":1,"544":2,"553":1,"564":1,"575":1,"583":3,"594":3,"614":1,"643":1,"663":4,"758":1,"774":1}}],["ccv",{"2":{"682":4}}],["cycle",{"2":{"477":1}}],["cte",{"2":{"312":2,"314":1}}],["ctx",{"2":{"152":2,"153":10,"162":2,"170":4,"171":6,"172":4,"323":8,"324":8,"325":8,"326":8,"401":2,"402":9,"403":2,"404":8,"425":8}}],["css",{"2":{"312":4,"432":2}}],["c4ibesqxgzc5zxj3vtugbiadqamienbyjkegcac=",{"2":{"295":2}}],["cgo",{"2":{"223":2,"609":1}}],["cmd",{"2":{"157":2}}],["cqebcp4bciavy2vszxn0aweuymxvyi52ms5nc2dqyxlgb3jcbg9icxj6ci9jzwxlc3rpytf2ogvzy3u3znu5bhy4nzlrenu1dwvndwv1cnrxnxn3nmhzbtnuzridaaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"156":2}}],["cfg",{"2":{"88":1,"89":2,"102":1}}],["cpu",{"2":{"352":1,"521":1,"623":1,"667":1,"709":1,"757":1,"758":1,"780":1}}],["cp",{"2":{"77":2,"212":2,"219":2,"220":2,"224":2,"310":1,"318":2}}],["cd",{"2":{"75":4,"115":2,"211":2,"212":2,"217":2,"220":2,"223":4,"224":2,"268":2,"279":2,"304":2,"317":2,"399":2,"413":2,"581":2,"609":3,"638":3,"664":4}}],["cips",{"2":{"679":1}}],["cip",{"2":{"480":1,"679":1,"723":2}}],["ciruit",{"2":{"212":1}}],["circulation",{"2":{"489":1}}],["circulating",{"2":{"489":4}}],["circulated",{"2":{"34":1}}],["circuits",{"0":{"224":1},"2":{"199":1,"212":2,"213":3,"220":2,"222":1,"223":2,"224":5,"238":1}}],["circuit",{"0":{"200":1},"2":{"178":1,"196":1,"197":1,"200":3,"202":1,"203":4,"205":1,"211":1,"213":1,"219":3,"220":2,"223":13,"224":23,"239":1}}],["circumvention",{"2":{"31":1}}],["circumvent",{"2":{"31":1}}],["city",{"2":{"42":1,"44":1,"45":1,"509":1,"726":1,"744":1}}],["cherry",{"2":{"547":1}}],["cheap",{"2":{"223":1}}],["cheaper",{"2":{"221":1}}],["checking",{"0":{"296":1,"300":1,"459":1},"2":{"329":1,"453":1}}],["checks",{"2":{"127":2,"131":3,"401":1}}],["checkout",{"2":{"75":2,"172":1,"224":2,"581":6,"609":6}}],["check",{"0":{"368":1,"369":1,"558":1},"2":{"37":1,"71":1,"110":1,"127":1,"130":1,"131":1,"135":1,"139":2,"148":1,"151":1,"156":1,"161":1,"169":1,"172":5,"183":2,"203":1,"212":1,"221":1,"224":1,"234":1,"243":2,"260":1,"275":1,"276":1,"286":1,"295":1,"296":1,"347":1,"355":1,"359":1,"381":1,"384":1,"396":1,"402":1,"426":4,"439":1,"449":1,"453":1,"544":3,"558":1,"564":1,"565":1,"566":1,"567":1,"578":1,"579":1,"581":2,"589":1,"590":1,"602":1,"609":2,"680":1,"684":4,"718":1,"734":1,"774":3,"778":2,"783":1}}],["checklist",{"2":{"35":1}}],["chown",{"2":{"656":2}}],["chose",{"2":{"505":1}}],["chosen",{"2":{"32":1,"43":1,"85":1,"646":2}}],["choice",{"2":{"464":1,"469":1,"789":2}}],["choices",{"2":{"403":2}}],["choosing",{"2":{"217":1,"284":1,"699":1}}],["chooses",{"2":{"450":1}}],["choose",{"0":{"71":1,"257":1,"473":1},"2":{"69":1,"71":1,"84":1,"175":1,"212":1,"469":1,"473":1,"481":1,"545":1,"564":1,"572":1,"582":2,"589":1,"597":1,"610":2,"646":1,"698":1}}],["chart",{"2":{"488":1}}],["charge",{"2":{"483":1}}],["charged",{"2":{"419":1}}],["characters",{"2":{"27":1}}],["characteristics",{"2":{"7":1}}],["chatmessageroleuser",{"2":{"403":2}}],["chatcompletion",{"2":{"403":2}}],["chatcompletionmessage",{"2":{"403":2}}],["chatcompletionrequest",{"2":{"403":2}}],["chatgpt",{"0":{"403":1},"2":{"400":2,"401":2,"402":3,"404":1}}],["chainode",{"2":{"728":1,"729":1,"730":1,"731":1}}],["chain=celestia",{"2":{"491":1}}],["chainname",{"2":{"432":12}}],["chainid",{"2":{"211":2,"432":16,"687":8}}],["chainlist",{"2":{"84":1}}],["chain",{"0":{"68":1,"84":1,"85":1,"86":2,"90":1,"91":1,"134":1,"263":1,"314":1,"433":1,"434":1,"593":1,"702":1},"2":{"68":2,"71":2,"77":2,"79":1,"82":1,"83":1,"84":26,"85":12,"86":7,"88":2,"89":3,"90":1,"91":56,"92":2,"105":1,"107":6,"108":1,"110":1,"129":1,"134":3,"135":1,"145":1,"180":1,"181":1,"189":1,"209":1,"210":2,"211":12,"213":1,"219":2,"220":5,"223":1,"224":1,"227":2,"228":2,"230":1,"236":1,"237":1,"239":1,"243":1,"261":1,"269":1,"275":1,"289":1,"299":2,"309":2,"312":6,"313":1,"314":1,"315":1,"318":2,"330":1,"332":1,"334":1,"335":1,"356":1,"372":2,"391":1,"392":8,"412":1,"413":2,"432":2,"433":5,"434":4,"436":2,"437":1,"457":1,"479":1,"497":1,"513":1,"527":1,"535":6,"536":12,"538":4,"539":8,"540":4,"542":6,"547":1,"549":12,"564":6,"571":3,"572":1,"573":7,"584":2,"593":3,"606":2,"627":11,"637":1,"649":1,"673":1,"679":2,"680":3,"681":1,"682":4,"683":6,"686":12,"687":22,"690":1,"691":1,"698":4,"702":3,"734":1,"735":1,"746":1,"783":2,"789":2,"794":1}}],["chains=",{"2":{"312":2}}],["chains",{"0":{"685":1},"2":{"27":1,"68":1,"79":1,"80":2,"84":3,"91":1,"95":2,"101":1,"105":1,"139":1,"174":1,"211":1,"238":1,"242":1,"312":8,"314":1,"335":1,"337":1,"392":1,"434":1,"483":1,"487":1,"491":1,"492":1,"509":1,"680":1,"681":1,"682":30,"683":1,"684":2,"685":1,"688":4,"726":1,"744":1}}],["challengemanager",{"2":{"98":1,"99":1}}],["challenge",{"2":{"84":1,"85":1,"109":1,"405":1}}],["challenges",{"2":{"48":1,"301":2}}],["challenging",{"2":{"44":1}}],["changing",{"0":{"595":1},"1":{"596":1,"597":1,"598":1,"599":1,"600":1,"601":1},"2":{"265":1,"634":1}}],["changeable",{"2":{"486":2}}],["changed",{"2":{"77":1,"91":2,"117":2,"120":2,"281":2,"284":2,"318":1,"358":1,"390":1}}],["change",{"0":{"573":1},"2":{"75":1,"77":1,"211":2,"220":2,"309":1,"310":1,"317":1,"318":1,"330":1,"332":1,"335":1,"390":1,"415":1,"418":1,"480":1,"486":1,"536":6,"542":2,"545":1,"556":1,"581":1,"597":1,"609":1,"619":1,"627":1,"679":1,"789":2}}],["changes",{"2":{"2":4,"19":1,"43":1,"45":1,"94":2,"421":1,"429":1,"455":2,"505":2,"520":1,"536":4,"645":1,"646":1,"647":1,"673":1,"720":1,"763":1}}],["chan",{"2":{"171":2,"324":2,"325":2}}],["channelid",{"2":{"687":4}}],["channel",{"2":{"40":1,"53":2,"54":1,"89":4,"324":3,"325":3,"515":1,"518":1,"579":1,"682":4,"687":13,"688":4,"739":1,"751":1,"754":1,"767":1}}],["channelside",{"2":{"687":4}}],["channels",{"0":{"688":1},"2":{"14":1,"36":1,"46":2,"48":1,"356":1,"682":2,"685":1,"688":2}}],["chances",{"2":{"44":1}}],["chance",{"2":{"27":1,"637":1}}],["c",{"2":{"31":2,"32":1,"34":2,"582":2,"597":1,"610":2,"638":6,"663":2,"664":8,"676":1}}],["cumulo",{"2":{"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["cumulativegasused",{"2":{"121":2,"285":2}}],["culmination",{"2":{"719":1,"760":1}}],["custody",{"0":{"331":1}}],["custodians",{"2":{"328":1}}],["custodian",{"2":{"24":1}}],["custom=",{"2":{"584":4}}],["custom=robusta",{"2":{"362":2}}],["custom=private",{"2":{"362":2}}],["customtargetblock",{"2":{"238":3}}],["customizable",{"2":{"312":1}}],["customizability",{"0":{"265":1},"2":{"265":1}}],["customizations",{"2":{"265":1}}],["customization",{"2":{"265":1}}],["customizing",{"2":{"84":1}}],["customized",{"2":{"265":1}}],["customize",{"2":{"47":2,"84":1,"269":1}}],["custom",{"0":{"68":1,"216":1,"362":1,"433":1,"434":1,"528":1,"584":1,"601":1,"674":1,"716":1},"2":{"47":3,"68":1,"80":1,"82":1,"84":1,"89":1,"214":1,"215":3,"216":3,"238":1,"265":1,"269":1,"314":1,"361":3,"362":9,"413":1,"431":1,"433":1,"434":3,"528":9,"584":3,"596":1,"601":2,"602":2,"606":1,"655":1,"674":9,"716":9}}],["curl",{"0":{"364":1,"380":1},"2":{"364":1,"380":1,"582":2,"610":2,"627":10,"638":6,"663":6,"705":2}}],["currencies",{"2":{"432":2}}],["currency",{"2":{"314":1,"434":1,"497":1}}],["currentitem",{"2":{"305":4}}],["currentid",{"2":{"305":4}}],["current",{"2":{"43":1,"95":1,"224":1,"237":1,"268":2,"301":1,"418":1,"445":1,"532":2,"724":1}}],["currently",{"2":{"23":1,"48":1,"148":1,"158":1,"175":1,"224":1,"242":1,"257":1,"287":1,"295":1,"332":1,"333":1,"337":1,"346":1,"417":1,"422":1,"491":1,"492":1,"604":1,"680":1,"681":1,"762":1}}],["curated",{"2":{"43":1,"65":1}}],["cups",{"2":{"41":1}}],["ce1e5714",{"2":{"404":2,"405":1}}],["celopstia",{"2":{"320":1}}],["cel",{"0":{"267":1,"272":1,"273":1},"1":{"268":1,"269":1,"270":1,"271":1,"272":1,"274":1,"275":1,"276":1},"2":{"266":2,"267":1,"268":5,"269":7,"270":6,"271":6,"272":2,"275":3,"276":3,"291":1,"356":4,"527":3,"596":1,"597":3,"609":3,"653":1,"673":3,"714":5}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hd",{"2":{"783":1}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hdenter",{"2":{"783":1}}],["celesvaloper",{"2":{"783":2}}],["celes",{"2":{"276":4,"390":1,"396":2,"714":6}}],["celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p",{"2":{"783":2}}],["celestiavaloper",{"2":{"783":1}}],["celestiacelestia",{"2":{"713":1}}],["celestiacommunity",{"2":{"683":1}}],["celestiascan",{"2":{"517":1,"753":1}}],["celestiatestnet",{"2":{"434":1}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxcelestia",{"2":{"579":1}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"579":2}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx$request",{"2":{"579":1}}],["celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"562":2,"564":2,"566":2}}],["celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"561":2,"562":2,"564":2,"565":2}}],["celestia17adsjkuecgjheugrdrwdqv9uh3qkrfmj9xzawx",{"2":{"537":2}}],["celestia10d07y265gmmuvt4z0w9aw880jnsr700jtgz4v7",{"2":{"536":2}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umard",{"2":{"369":1}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umardcelestia",{"2":{"369":1}}],["celestia1czpgn3hdh9sodm06d5qk23xzgpq2uyc8ggdqgw",{"2":{"535":2}}],["celestia1hn25k7gkfq0fy5a0vmphs6mjma2de74gsn36ef",{"2":{"396":2}}],["celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86",{"2":{"382":2}}],["celestia1znk24rh52pgcd9z5x2x42jztjh6raaaphuvrt3",{"2":{"371":2}}],["celestia1",{"2":{"356":1,"515":1,"715":1,"751":1}}],["celestia1wkhyhr7ngf0ayqlpnsnxg4d72hfs5453dvunm9",{"2":{"276":2}}],["celestia1vdjkcetnw35kzvtk8pjhxcm4xan82wtvwcurwwtt0f6n2at9va6k2atjw3cn2umhxe58xmfndejs40vqs9",{"2":{"156":2}}],["celestialightnodeclient",{"2":{"135":6,"137":2,"139":2}}],["celestiaheight",{"2":{"134":4}}],["celestiaorg",{"2":{"87":2,"110":1,"149":6,"153":2,"159":4,"165":2,"166":2,"169":2,"172":4,"245":1,"268":2,"275":2,"322":2,"323":6,"338":1,"383":1,"399":2,"400":6,"420":2,"425":6,"426":12,"429":1,"581":2,"609":2,"627":9,"649":14,"655":6,"657":6,"658":6,"794":14}}],["celestia",{"0":{"0":1,"6":1,"18":1,"49":1,"52":1,"58":1,"60":1,"92":1,"104":1,"142":1,"147":1,"153":1,"208":1,"245":1,"256":1,"266":1,"292":1,"293":1,"295":1,"299":1,"328":1,"330":1,"348":1,"354":1,"386":1,"388":1,"396":1,"414":1,"423":1,"424":1,"425":1,"427":1,"431":1,"432":1,"438":1,"440":1,"446":1,"449":1,"458":1,"464":1,"473":1,"480":1,"483":1,"490":1,"519":1,"524":1,"525":1,"551":1,"553":1,"576":1,"580":1,"585":1,"608":1,"626":1,"665":1,"670":1,"677":1,"692":1,"695":1,"696":1,"707":1,"711":1,"755":1,"756":1,"759":1,"769":1,"770":1,"774":1,"776":1,"777":1,"778":1,"779":1,"784":1,"785":1},"1":{"1":1,"2":1,"3":1,"4":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"29":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1,"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"257":1,"258":1,"259":1,"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"293":1,"294":1,"300":1,"329":1,"330":1,"331":2,"332":2,"333":2,"334":2,"335":2,"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"356":1,"357":1,"358":1,"359":1,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"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,"389":1,"390":1,"391":1,"392":1,"393":1,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"427":1,"432":1,"433":1,"434":1,"450":1,"451":1,"452":1,"453":1,"454":1,"455":1,"459":1,"491":1,"492":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":2,"526":2,"527":2,"528":2,"529":2,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1,"577":1,"578":1,"579":1,"581":1,"582":1,"583":1,"586":1,"587":1,"588":1,"589":1,"590":1,"609":1,"610":1,"611":1,"612":1,"666":1,"667":1,"668":1,"669":1,"670":1,"671":2,"672":2,"673":2,"674":2,"675":2,"676":2,"678":1,"679":1,"693":1,"694":1,"695":1,"696":1,"697":2,"698":2,"699":2,"700":2,"701":2,"702":2,"703":2,"704":2,"705":2,"706":2,"708":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"756":1,"757":1,"758":1,"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1,"780":1,"781":1,"782":1,"783":1,"784":1,"785":2,"786":2,"787":2,"788":2,"789":1,"790":1,"791":1,"792":1,"793":1,"794":1},"2":{"0":2,"3":3,"5":2,"7":1,"8":1,"11":1,"19":3,"21":3,"22":1,"24":3,"25":2,"27":5,"30":8,"33":3,"40":2,"41":2,"42":1,"43":4,"44":2,"45":2,"46":6,"47":15,"48":5,"49":1,"50":1,"52":2,"54":1,"56":1,"57":2,"59":2,"60":4,"61":2,"62":1,"63":2,"64":1,"65":4,"79":3,"80":1,"83":5,"88":1,"89":12,"94":5,"101":1,"102":4,"105":2,"106":1,"107":12,"108":6,"109":4,"110":3,"111":1,"127":1,"128":1,"129":1,"130":2,"131":6,"133":4,"134":20,"135":11,"136":4,"137":3,"139":4,"142":2,"145":3,"146":4,"148":4,"149":3,"153":2,"156":4,"159":2,"161":1,"162":1,"163":2,"164":1,"165":4,"166":5,"169":8,"172":6,"173":2,"174":2,"176":1,"177":5,"180":1,"181":4,"183":3,"184":2,"187":2,"188":1,"189":1,"192":2,"193":1,"195":1,"196":2,"200":1,"203":1,"208":3,"218":3,"220":1,"225":2,"227":1,"230":5,"233":2,"234":2,"235":1,"237":12,"238":1,"242":1,"244":2,"245":3,"246":1,"254":1,"255":1,"257":1,"260":1,"264":1,"265":1,"266":1,"267":1,"268":5,"269":3,"274":1,"275":11,"276":17,"287":5,"289":1,"290":3,"291":2,"292":2,"293":1,"299":5,"300":2,"301":3,"302":1,"303":1,"304":4,"305":2,"307":2,"309":1,"320":1,"321":1,"322":3,"323":7,"328":1,"329":4,"330":2,"331":1,"332":3,"335":2,"336":2,"337":7,"339":4,"340":1,"341":2,"342":1,"345":1,"348":1,"350":1,"351":1,"353":1,"354":2,"355":5,"356":7,"357":2,"358":5,"359":1,"360":4,"361":2,"362":13,"363":4,"365":2,"368":1,"369":1,"372":2,"373":2,"375":1,"378":4,"380":6,"381":1,"383":1,"388":2,"389":1,"390":7,"391":2,"392":1,"393":1,"394":3,"395":1,"396":5,"399":2,"400":6,"404":1,"405":3,"406":1,"407":6,"408":7,"414":1,"416":1,"417":2,"420":3,"421":2,"423":1,"424":1,"425":7,"426":16,"427":1,"428":2,"429":1,"431":1,"432":22,"433":4,"434":5,"436":1,"438":1,"440":1,"441":2,"446":1,"449":3,"450":3,"451":4,"452":1,"453":2,"455":12,"457":4,"458":3,"459":7,"460":2,"464":1,"468":1,"472":1,"473":1,"477":3,"478":2,"479":2,"480":2,"481":5,"483":3,"484":1,"487":2,"488":6,"489":1,"490":1,"491":2,"492":3,"496":2,"497":1,"498":2,"499":2,"504":1,"505":1,"509":1,"510":11,"512":1,"513":5,"514":2,"515":4,"516":1,"517":1,"519":1,"520":11,"525":2,"526":3,"527":3,"528":3,"530":6,"532":8,"533":2,"534":3,"535":2,"536":4,"537":1,"539":2,"542":10,"543":2,"544":3,"545":5,"546":1,"548":1,"549":18,"551":2,"552":1,"553":1,"554":1,"556":3,"557":10,"558":4,"559":1,"561":4,"562":2,"564":6,"565":2,"566":2,"567":4,"568":1,"569":2,"576":2,"577":2,"579":4,"580":1,"581":10,"582":12,"583":1,"584":6,"585":2,"586":2,"587":3,"588":2,"589":4,"590":2,"592":3,"593":2,"594":2,"597":9,"599":2,"600":2,"601":2,"602":2,"603":1,"604":10,"605":15,"606":4,"609":11,"610":12,"611":1,"614":1,"615":3,"616":1,"619":1,"621":6,"622":2,"626":1,"627":19,"629":1,"633":1,"637":1,"638":42,"639":5,"641":2,"643":2,"644":2,"645":1,"646":2,"647":2,"649":15,"653":6,"655":15,"657":22,"658":22,"661":1,"662":1,"664":1,"665":3,"666":1,"670":1,"673":2,"674":3,"675":1,"677":1,"678":1,"679":4,"680":2,"681":1,"682":9,"683":1,"690":3,"691":2,"692":2,"695":1,"697":3,"698":2,"699":2,"700":2,"701":1,"702":3,"703":4,"704":1,"705":2,"706":2,"707":2,"708":2,"711":2,"713":6,"714":4,"715":3,"716":3,"719":3,"720":1,"723":1,"724":2,"726":1,"728":26,"729":25,"730":23,"731":3,"733":1,"734":11,"736":2,"737":8,"738":6,"740":1,"744":1,"745":1,"746":10,"747":16,"748":12,"749":16,"750":8,"751":6,"752":1,"753":7,"755":3,"760":1,"762":1,"763":1,"768":2,"769":3,"770":4,"771":4,"773":1,"774":16,"776":14,"777":18,"778":16,"779":2,"784":4,"785":1,"786":2,"789":8,"794":15}}],["cele",{"2":{"275":2,"276":2}}],["celenium",{"2":{"91":1,"242":7,"294":1,"380":1,"402":2,"517":1,"606":2,"737":1,"753":1}}],["centric",{"2":{"235":1}}],["centralized",{"2":{"135":1,"233":2,"235":1,"313":2}}],["center",{"2":{"27":1,"313":4,"432":2}}],["certificate",{"2":{"34":1}}],["certainty",{"2":{"108":1,"109":1}}],["certain",{"0":{"34":1},"2":{"22":1,"30":2,"31":1,"33":1,"183":1,"217":1,"447":1,"536":1}}],["cryptech",{"2":{"746":2,"747":1,"748":1,"749":1,"753":1}}],["cryptography",{"2":{"333":1}}],["crypto",{"2":{"153":2,"172":2,"276":2,"426":2,"561":2,"562":4,"566":2}}],["cross",{"2":{"680":1}}],["crate",{"2":{"681":1}}],["crashed",{"2":{"547":1}}],["craft",{"2":{"320":1}}],["crisis",{"2":{"330":1}}],["critical",{"2":{"45":1,"436":1,"499":1,"543":1,"564":2,"784":1}}],["criteria",{"0":{"24":1,"25":1},"2":{"21":1,"22":1,"23":1,"24":3}}],["crs",{"2":{"223":1}}],["crucial",{"2":{"42":1,"44":1,"84":2,"86":2,"89":1,"720":1}}],["credibility",{"2":{"44":1}}],["credentials",{"2":{"31":1,"311":1,"426":2}}],["creation",{"2":{"402":1,"408":2}}],["creating",{"0":{"137":1,"313":1,"531":1,"703":1},"2":{"40":1,"88":1,"91":2,"135":1,"136":2,"137":1,"173":1,"177":1,"312":1,"408":2,"409":2,"410":2,"497":1,"559":2,"605":2,"685":1,"782":1}}],["creator",{"2":{"305":2}}],["creators",{"2":{"79":1}}],["createpayforblob",{"2":{"426":2}}],["createpost",{"2":{"305":10,"308":2,"309":2,"313":6}}],["createchatcompletion",{"2":{"403":2}}],["createclient",{"2":{"312":4}}],["createandsubmitblob",{"2":{"402":6,"404":2}}],["createnamespaceid",{"2":{"402":7,"404":2}}],["createroot",{"2":{"312":2}}],["creates",{"2":{"305":2,"402":2}}],["create2",{"2":{"211":5,"219":2}}],["createdblob",{"2":{"402":6,"404":2}}],["created",{"2":{"65":1,"117":1,"150":1,"171":1,"184":1,"275":2,"276":2,"281":1,"304":1,"310":1,"311":1,"356":2,"397":1,"402":3,"548":1,"559":1,"565":1,"574":1,"579":1,"682":1,"687":1,"688":2,"701":1,"703":1,"714":1,"715":1,"774":1,"776":1,"777":1,"778":1}}],["create",{"0":{"116":1,"266":1,"280":1,"553":1,"561":1,"564":1,"569":1,"571":1,"576":1,"578":1,"685":1,"686":1,"699":1,"702":1},"1":{"267":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1,"577":1,"578":1,"579":1,"687":1,"688":1},"2":{"2":3,"34":2,"36":1,"44":2,"46":2,"47":2,"65":2,"88":1,"120":2,"135":1,"137":1,"148":1,"169":1,"172":2,"178":1,"183":1,"187":1,"192":1,"212":2,"219":1,"220":2,"223":1,"238":1,"243":1,"283":2,"284":3,"291":1,"304":1,"305":6,"310":3,"311":2,"312":2,"313":20,"323":2,"324":2,"325":2,"336":1,"356":1,"359":1,"381":1,"400":5,"401":7,"402":15,"403":1,"404":4,"408":2,"422":1,"425":2,"426":4,"432":1,"527":1,"530":2,"537":1,"542":2,"545":2,"549":4,"553":1,"560":1,"561":1,"564":9,"567":1,"568":1,"571":3,"575":2,"578":1,"581":1,"656":2,"657":1,"673":1,"680":1,"685":1,"686":7,"687":6,"699":1,"702":1,"703":1,"714":1,"723":1,"774":1,"776":1,"777":1,"783":1,"789":3}}],["cake",{"2":{"547":1}}],["cautious",{"2":{"605":1}}],["caution",{"2":{"308":1}}],["cause",{"2":{"443":1,"484":1,"724":1}}],["caused",{"2":{"31":2}}],["cadence",{"2":{"225":2,"226":1,"227":1}}],["car",{"2":{"561":2}}],["carrying",{"2":{"530":2}}],["carry",{"2":{"261":1}}],["carries",{"2":{"146":1}}],["cargo",{"2":{"218":2,"220":2,"223":2,"224":2}}],["care",{"2":{"107":1}}],["carefully",{"2":{"30":1}}],["catching",{"2":{"774":1}}],["catch",{"2":{"54":1,"432":2}}],["categories",{"2":{"488":1}}],["category",{"0":{"339":1},"2":{"3":3,"339":1,"388":1,"488":1,"489":2}}],["cater",{"2":{"48":1}}],["catering",{"0":{"41":1},"2":{"41":1,"44":1}}],["cafes",{"2":{"42":1}}],["capacities",{"2":{"330":1}}],["capacity",{"2":{"264":3,"451":1}}],["capability",{"2":{"330":1,"680":1}}],["capabilities",{"2":{"254":1,"342":1,"605":1}}],["capable",{"2":{"31":1,"79":1}}],["capture",{"2":{"37":1}}],["cast",{"2":{"76":2,"121":3,"213":5,"215":1,"216":1,"285":3,"308":3,"309":2,"317":2}}],["caste",{"2":{"7":1}}],["casual",{"2":{"42":2,"48":1}}],["cases",{"2":{"188":1,"428":1,"455":1}}],["case",{"2":{"34":1,"69":1,"82":1,"109":1,"145":1,"165":1,"171":2,"180":1,"184":1,"192":1,"194":1,"195":1,"197":1,"206":1,"217":3,"220":2,"222":1,"287":1,"293":1,"297":2,"337":1,"400":1,"418":3,"448":1,"578":1,"619":1,"685":1,"783":1}}],["cancel",{"2":{"401":4,"402":4,"404":4}}],["canceling",{"2":{"45":1}}],["canonical",{"2":{"108":1,"413":1,"421":1,"679":1}}],["cannot",{"2":{"25":1,"34":1,"46":1,"225":1,"437":2,"443":1,"456":1}}],["can",{"0":{"448":1},"2":{"8":1,"24":2,"29":1,"35":2,"36":1,"40":3,"41":5,"43":3,"44":5,"45":3,"46":5,"47":3,"48":2,"54":1,"60":1,"61":1,"65":3,"69":2,"72":1,"76":1,"77":2,"84":4,"88":1,"90":1,"95":1,"102":3,"107":6,"108":5,"109":4,"110":1,"116":1,"119":1,"121":1,"126":1,"131":1,"133":1,"134":5,"135":5,"137":3,"145":4,"146":3,"148":4,"150":1,"152":1,"155":1,"158":1,"159":1,"160":2,"162":1,"164":2,"165":4,"166":2,"167":1,"168":1,"169":4,"170":2,"171":2,"172":2,"173":2,"175":3,"177":1,"178":1,"181":4,"183":2,"184":5,"187":3,"188":4,"189":2,"191":2,"192":2,"195":2,"196":2,"197":1,"200":1,"203":1,"206":1,"211":1,"212":3,"214":3,"215":2,"217":3,"218":2,"219":2,"220":3,"223":1,"224":5,"225":1,"226":2,"227":1,"230":1,"234":1,"238":6,"239":1,"241":1,"242":1,"243":1,"245":1,"247":1,"249":1,"254":1,"263":4,"264":1,"265":4,"266":1,"267":1,"268":1,"269":1,"270":1,"275":1,"280":1,"285":1,"287":5,"293":1,"296":1,"305":7,"306":1,"307":1,"308":4,"309":5,"310":1,"312":1,"313":1,"314":1,"317":1,"318":2,"322":1,"323":3,"324":1,"325":1,"326":1,"334":1,"337":1,"340":1,"341":1,"343":1,"346":2,"351":2,"355":1,"356":5,"358":2,"359":2,"360":1,"361":2,"363":3,"365":1,"366":1,"375":1,"376":1,"380":1,"381":1,"387":2,"393":1,"396":2,"402":7,"404":2,"405":1,"407":1,"408":3,"409":1,"410":1,"418":1,"420":3,"421":1,"422":1,"426":6,"429":1,"431":1,"432":2,"433":2,"434":1,"436":3,"437":1,"440":3,"443":2,"450":1,"451":2,"453":3,"456":2,"457":1,"458":1,"459":2,"460":1,"466":1,"470":1,"475":1,"477":1,"479":1,"481":2,"484":2,"486":1,"490":1,"497":1,"498":1,"505":3,"510":2,"513":1,"515":1,"517":1,"520":1,"526":1,"527":3,"531":1,"536":10,"537":4,"538":1,"539":2,"540":1,"541":1,"542":2,"543":2,"544":2,"545":4,"546":1,"547":2,"548":1,"551":2,"558":1,"564":1,"567":2,"571":1,"572":1,"573":1,"574":2,"576":1,"578":2,"579":1,"581":1,"582":1,"584":1,"586":1,"590":1,"594":1,"602":1,"605":1,"610":1,"612":1,"616":1,"621":2,"627":4,"629":1,"634":1,"635":1,"637":2,"639":1,"641":1,"642":1,"643":2,"646":1,"647":2,"649":1,"650":1,"651":2,"653":2,"655":1,"656":3,"657":1,"661":1,"662":1,"669":1,"670":1,"673":5,"678":2,"680":2,"683":1,"685":1,"686":1,"690":2,"696":1,"697":1,"701":1,"705":5,"706":1,"713":1,"714":3,"715":1,"718":1,"723":1,"724":3,"725":1,"734":2,"735":1,"736":2,"737":1,"740":1,"748":1,"750":1,"751":1,"753":1,"755":3,"762":1,"765":1,"771":1,"777":1,"783":3,"784":1,"785":1,"786":1,"794":1}}],["caldera",{"2":{"244":1,"245":1,"246":1,"248":1,"249":1,"251":1,"252":1,"284":2,"317":2}}],["calculation",{"0":{"419":1}}],["calculating",{"2":{"131":1,"183":1,"417":1,"420":1}}],["calculates",{"2":{"418":1,"419":1}}],["calculated",{"2":{"366":1,"417":1,"419":3,"478":1,"484":1,"724":1}}],["calculate",{"2":{"165":2,"168":2,"183":1,"419":1,"484":1}}],["callopts",{"2":{"153":2}}],["calling",{"2":{"117":2,"213":1,"215":1,"281":2}}],["called",{"2":{"116":1,"117":1,"134":1,"224":1,"230":1,"267":1,"276":1,"280":1,"281":1,"283":1,"414":1,"420":1,"437":1,"438":1,"459":1,"677":1}}],["calldata",{"2":{"110":1,"127":8,"215":2,"216":2,"287":2,"337":4}}],["calls",{"2":{"54":1,"121":1,"211":1,"239":1,"285":1,"748":1}}],["call",{"0":{"385":1},"2":{"5":2,"43":1,"53":1,"54":1,"76":4,"110":1,"121":4,"213":5,"228":1,"247":1,"285":4,"308":3,"309":3,"313":2,"317":4,"357":1,"370":1,"371":1,"385":1,"402":1}}],["calendar",{"0":{"5":1},"2":{"5":3,"45":1,"54":1,"64":1,"71":1}}],["clean",{"2":{"697":1}}],["clearing",{"0":{"603":1}}],["clears",{"2":{"428":1}}],["clear",{"2":{"2":1,"43":1,"682":4}}],["clock",{"2":{"682":4}}],["cloud",{"2":{"226":1,"545":1,"583":1,"589":1,"594":1,"737":1}}],["closely",{"2":{"246":1}}],["close",{"2":{"153":4,"170":4,"171":2,"172":2,"401":2,"402":2,"404":2,"426":2}}],["closer",{"2":{"131":1}}],["cloned",{"2":{"87":1}}],["clone",{"0":{"87":1},"2":{"1":1,"2":2,"75":3,"87":3,"211":3,"212":2,"217":3,"220":4,"223":2,"224":2,"268":2,"317":3,"408":2,"413":3,"581":3,"609":3}}],["cli",{"0":{"348":1,"357":1,"423":1,"424":1,"530":1},"1":{"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"356":1,"357":1,"358":2,"359":2,"360":2,"361":2,"362":2,"363":2,"364":2,"365":2,"366":2,"367":2,"368":2,"369":2,"370":2,"371":2,"372":2,"373":2,"374":2,"375":2,"376":2,"377":2,"378":2,"379":1,"380":1,"381":1,"382":1,"531":1,"532":1,"533":1,"534":1,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"542":1},"2":{"121":1,"285":1,"309":1,"345":1,"351":1,"357":1,"358":2,"359":3,"360":1,"361":1,"377":1,"530":2,"573":2,"578":1,"581":1,"582":1,"584":1,"601":1,"611":1,"681":2,"690":1,"714":1}}],["clientid",{"2":{"687":8}}],["client=",{"2":{"312":2}}],["clients",{"0":{"686":1,"687":1},"1":{"687":1,"688":1},"2":{"135":1,"335":1,"682":2,"685":2,"686":2,"687":2,"755":1,"771":1}}],["client",{"0":{"132":1,"152":1,"157":1,"159":1,"162":1,"321":1,"406":1,"425":1,"573":1},"1":{"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"322":1,"323":1,"324":1,"325":1,"326":1,"327":1,"407":1,"408":1,"409":1,"410":1,"411":1},"2":{"89":1,"109":1,"135":2,"143":1,"145":1,"149":1,"152":3,"153":4,"157":1,"158":1,"159":3,"162":1,"165":20,"166":4,"167":4,"168":6,"169":8,"172":50,"230":2,"237":2,"240":2,"305":2,"311":2,"312":2,"313":8,"321":1,"323":6,"324":4,"325":6,"326":6,"332":1,"400":2,"401":7,"402":16,"403":5,"404":8,"405":1,"406":1,"408":12,"409":10,"410":10,"420":1,"425":7,"573":4,"599":2,"601":2,"637":1,"686":8,"687":8,"748":1,"769":1}}],["clicking",{"2":{"263":1,"433":2}}],["click",{"2":{"68":1,"69":3,"71":4,"72":1,"83":1,"85":1,"86":1,"251":1,"314":1,"433":1,"434":3,"469":1,"545":3}}],["clubs",{"2":{"40":2}}],["clang",{"2":{"663":4}}],["classname=",{"2":{"432":4}}],["classes",{"2":{"16":1}}],["claim",{"0":{"72":1,"538":1},"2":{"30":1,"31":5,"71":1,"72":3,"466":1,"470":1,"475":1,"538":1}}],["claiming",{"2":{"30":1,"31":1}}],["clarifying",{"2":{"9":1}}],["clarity",{"2":{"2":1,"13":1}}],["coin",{"2":{"433":1,"434":1,"439":1}}],["coingeckoid",{"2":{"432":6}}],["coindecimals",{"2":{"432":6}}],["coindenom",{"2":{"432":6}}],["coinminimaldenom",{"2":{"432":6}}],["cointype",{"2":{"432":2}}],["copied",{"2":{"638":1}}],["copies",{"2":{"224":2}}],["copy",{"2":{"89":1,"133":1,"212":3,"310":2,"384":1,"396":1,"443":1,"581":1,"609":1}}],["cosmovisor",{"2":{"679":1}}],["cosmoslist",{"2":{"738":1,"752":1}}],["cosmosnetwork",{"2":{"683":1}}],["cosmossdk",{"2":{"682":4}}],["cosmostation",{"0":{"434":1},"2":{"431":1,"434":2}}],["cosmos",{"2":{"149":7,"265":1,"267":1,"276":2,"299":2,"330":4,"331":2,"332":1,"334":1,"335":1,"414":1,"418":1,"426":4,"433":1,"434":1,"455":1,"460":1,"483":3,"487":1,"491":1,"498":3,"508":1,"520":1,"530":2,"531":1,"536":5,"545":3,"548":1,"550":2,"551":1,"561":2,"562":4,"564":2,"565":2,"566":4,"574":1,"627":3,"680":1,"681":1,"682":9,"683":1,"725":1,"748":1,"749":1,"774":2,"776":2,"777":2}}],["costly",{"2":{"178":1}}],["cost",{"2":{"40":1,"82":1,"192":1,"194":1,"263":1,"336":1,"418":6,"419":5,"457":1}}],["costs",{"2":{"40":2,"41":1,"44":3,"46":1,"179":1,"202":1,"235":1,"418":3,"420":1}}],["coral",{"2":{"561":2}}],["corner",{"2":{"433":1,"434":1}}],["cors",{"2":{"313":2}}],["correspond",{"2":{"217":1}}],["corresponds",{"2":{"203":1,"363":1}}],["corresponding",{"0":{"158":1},"1":{"159":1},"2":{"145":1,"146":1,"148":2,"150":1,"153":2,"158":2,"169":1,"170":2,"172":2,"176":1,"177":3,"181":1,"210":1,"211":2,"212":1,"213":2,"218":1,"219":1,"220":2,"223":1,"450":1,"459":2,"554":1,"680":1}}],["correctly",{"2":{"117":2,"196":1,"200":1,"203":1,"211":1,"281":2,"456":1,"664":1,"681":1,"684":1,"774":1,"778":1}}],["correct",{"2":{"108":1,"196":1,"224":1,"269":1,"450":1,"528":1,"581":1,"583":2,"594":2,"664":1,"674":1,"692":1,"716":1,"740":1}}],["correction",{"0":{"13":1}}],["corrective",{"2":{"9":1}}],["cores",{"2":{"521":1,"667":1,"757":1,"758":1,"780":1}}],["core",{"0":{"355":1,"616":1},"2":{"59":1,"89":3,"107":1,"149":3,"261":1,"275":2,"276":2,"294":2,"295":2,"332":1,"350":1,"352":1,"355":16,"356":6,"380":2,"396":2,"429":1,"455":4,"488":3,"489":1,"497":1,"510":1,"512":1,"513":7,"520":8,"526":12,"527":6,"528":6,"586":2,"587":2,"588":2,"589":4,"592":2,"597":2,"602":2,"606":2,"616":2,"621":1,"623":1,"649":14,"655":6,"658":6,"673":5,"674":6,"692":1,"709":1,"713":8,"714":6,"716":6,"733":1,"734":5,"740":1,"745":1,"746":1,"757":2,"758":1,"778":2,"786":2,"794":14}}],["cooperation",{"2":{"52":1}}],["coordinating",{"2":{"677":1}}],["coordination",{"2":{"36":1,"505":1,"677":1,"765":1}}],["coordinated",{"2":{"679":1,"720":1}}],["coordinates",{"2":{"450":2}}],["coordinate",{"2":{"36":1,"46":2}}],["coworking",{"2":{"44":1}}],["coding",{"2":{"43":1,"441":2,"455":1,"477":1}}],["codelab",{"2":{"545":2}}],["coded",{"2":{"440":1,"441":1,"520":1,"724":1}}],["codespace",{"2":{"156":2,"426":4,"564":2,"783":2,"789":2}}],["codebase",{"2":{"107":1,"763":1}}],["code",{"0":{"6":1,"52":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1},"2":{"9":2,"10":1,"12":1,"14":1,"15":1,"17":4,"25":1,"52":4,"64":1,"107":2,"108":1,"117":1,"133":1,"156":2,"238":1,"245":1,"281":1,"305":2,"307":1,"313":1,"382":2,"394":1,"400":1,"426":18,"432":1,"520":1,"545":1,"564":2,"678":1,"724":1,"783":1,"789":1}}],["covers",{"2":{"59":1,"60":1,"61":1,"62":1,"66":1,"79":1,"238":1,"431":1,"622":1,"770":2}}],["cover",{"2":{"44":1,"46":1,"47":1,"66":1,"82":1,"240":1,"255":1,"289":1,"301":1,"348":1,"358":1,"568":1,"584":1}}],["covering",{"2":{"44":1,"47":2}}],["covered",{"2":{"42":1,"652":1,"769":1,"771":1}}],["covenant",{"2":{"17":4}}],["co",{"2":{"40":2,"44":2,"45":1,"47":1,"56":1,"738":1,"752":1}}],["course",{"2":{"264":1}}],["counterparty",{"2":{"682":2}}],["counterforge",{"2":{"120":1,"283":1,"284":1}}],["countertest",{"2":{"117":4,"281":4}}],["counter",{"2":{"115":6,"116":7,"117":31,"120":3,"279":6,"280":7,"281":31,"283":3,"284":3}}],["count",{"2":{"93":1}}],["country",{"2":{"24":1,"34":1}}],["couldn",{"2":{"46":2,"153":2,"170":2}}],["could",{"2":{"8":1,"133":1,"134":1,"136":1,"139":3,"154":1,"183":1,"184":1,"265":1,"320":1,"332":1,"358":1,"402":1,"404":1,"418":1,"419":1,"441":2,"452":1,"459":1,"481":3,"547":1}}],["columns",{"2":{"131":1,"148":1,"183":1,"450":1}}],["column",{"2":{"108":1,"131":3,"146":1,"148":2,"183":1,"313":4,"372":2,"452":1,"458":3}}],["collide",{"2":{"545":1}}],["collaboration",{"2":{"44":1,"50":1}}],["collaborate",{"2":{"40":1}}],["collectively",{"2":{"451":1}}],["collection",{"2":{"30":2,"49":1,"56":1,"134":1}}],["collect",{"2":{"33":5,"37":1,"530":4,"703":2}}],["collector",{"2":{"24":1,"91":4,"544":2,"589":2,"590":3}}],["color",{"2":{"7":1,"58":1}}],["cohorts",{"2":{"22":1,"23":3,"26":1}}],["cohort",{"0":{"22":1,"28":1},"2":{"22":3,"23":12,"24":1,"25":1,"26":1,"28":5}}],["conjured",{"2":{"545":1}}],["conn",{"2":{"426":6}}],["connects",{"2":{"590":1}}],["connectbutton",{"2":{"313":4}}],["connectors",{"2":{"312":4}}],["connectorsforwallets",{"2":{"312":4}}],["connectivity",{"2":{"459":1}}],["connecting",{"2":{"135":2,"303":1,"355":1,"526":1,"673":1,"734":1,"771":1,"789":1}}],["connectionid",{"2":{"687":8}}],["connectionside",{"2":{"687":4}}],["connections",{"0":{"589":1},"2":{"40":1,"42":1,"43":1,"65":1,"88":1,"544":6,"583":3,"594":3,"642":1,"680":2,"682":2,"685":2,"688":1,"704":2,"777":1}}],["connection",{"0":{"685":1,"687":1},"2":{"31":1,"32":1,"34":3,"44":1,"88":5,"103":1,"107":1,"135":6,"355":1,"426":2,"520":1,"527":1,"589":5,"673":1,"685":1,"687":30,"713":1}}],["connect",{"0":{"355":1,"629":1},"1":{"630":1,"631":1},"2":{"38":1,"42":1,"43":1,"55":1,"83":1,"107":1,"153":2,"170":2,"172":2,"247":1,"249":1,"310":1,"312":3,"313":4,"380":1,"432":2,"459":1,"491":1,"492":1,"508":2,"519":1,"520":1,"601":2,"627":4,"665":1,"725":2,"740":4,"755":1,"786":1,"789":2}}],["connected",{"2":{"24":1,"315":1,"433":1,"434":1,"440":2,"455":1,"629":1,"765":1}}],["congrats",{"2":{"391":1,"393":1}}],["congratulations",{"0":{"92":1,"393":1},"2":{"122":1,"286":1,"559":1,"567":1,"575":1,"655":1,"658":1,"687":1}}],["congested",{"2":{"287":1}}],["congests",{"2":{"264":1}}],["congestion",{"2":{"264":1,"428":1,"459":1}}],["concerned",{"2":{"442":1}}],["concepts",{"0":{"175":1},"1":{"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1}}],["concept",{"2":{"59":1,"480":1}}],["concrete",{"2":{"402":2,"404":2}}],["conclusion",{"0":{"173":1,"206":1,"575":1}}],["concise",{"2":{"2":1}}],["conf",{"2":{"102":2}}],["confidence",{"2":{"109":1,"439":2}}],["configs",{"2":{"102":2,"545":4}}],["configurable",{"2":{"110":1}}],["configurations",{"0":{"628":1},"1":{"629":1,"630":1,"631":1,"632":1,"633":1,"634":1},"2":{"86":1,"359":1,"596":1,"645":1,"682":1,"684":1}}],["configuration",{"0":{"86":1,"87":1,"646":1,"647":1,"682":1,"684":1,"791":1},"2":{"84":4,"85":1,"86":3,"311":1,"312":4,"313":1,"390":1,"392":1,"530":4,"544":2,"545":3,"573":3,"578":1,"584":1,"596":2,"602":2,"633":1,"637":2,"644":1,"646":2,"647":1,"682":1,"684":2,"791":1}}],["configuring",{"0":{"311":1,"312":1},"2":{"84":2,"86":1,"653":1,"681":1}}],["configures",{"2":{"531":1}}],["configurechains",{"2":{"312":4}}],["configured",{"2":{"89":1,"315":1,"387":1,"417":1,"683":1}}],["configure",{"0":{"84":1,"642":1,"688":1},"1":{"643":1,"644":1,"645":1},"2":{"83":1,"84":2,"89":1,"91":3,"311":1,"313":2,"314":1,"642":1,"646":1,"647":1,"685":1,"791":1}}],["config",{"0":{"68":1,"601":1,"602":1,"613":1,"615":1,"704":1},"1":{"614":1,"615":1,"616":2,"617":2,"618":2,"619":2,"620":2,"621":2},"2":{"68":1,"77":1,"86":4,"87":1,"88":1,"89":3,"102":5,"318":1,"392":1,"426":2,"530":2,"531":2,"544":1,"545":8,"569":2,"573":2,"578":2,"592":2,"601":1,"602":7,"604":1,"606":3,"615":4,"619":1,"621":1,"627":27,"629":1,"632":1,"637":2,"643":5,"644":4,"646":2,"647":2,"663":4,"681":1,"682":3,"684":5,"688":1,"701":1,"702":1,"703":4,"704":2,"712":1,"791":1}}],["confirming",{"2":{"300":1}}],["confirmed",{"2":{"108":1,"109":1,"426":2,"466":1,"470":1,"475":1,"682":2}}],["confirmations",{"2":{"234":1}}],["confirmation",{"2":{"53":1,"137":1,"579":1,"682":2,"712":1}}],["confirm",{"0":{"466":1,"470":1},"2":{"33":1,"34":2,"36":1,"131":1,"234":1,"300":1,"474":1,"545":1,"564":2,"789":1}}],["conferences",{"2":{"45":1}}],["conference",{"2":{"45":1}}],["conventions",{"2":{"596":1}}],["convenient",{"2":{"36":1}}],["conversion",{"2":{"165":1,"494":1}}],["conversations",{"2":{"8":1,"34":1,"37":1}}],["converts",{"2":{"402":2}}],["converting",{"0":{"163":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1}}],["converted",{"2":{"151":1,"156":1,"161":1,"164":1,"167":1,"363":1}}],["convert",{"2":{"121":1,"164":1,"165":1,"166":1,"168":1,"285":1,"402":3,"404":2}}],["conditioned",{"2":{"34":1}}],["conditions",{"2":{"31":1,"200":1,"551":1}}],["conducting",{"2":{"440":1}}],["conducted",{"2":{"34":1}}],["conduct",{"0":{"6":1,"52":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1},"2":{"8":1,"9":1,"10":1,"12":1,"14":1,"15":1,"17":4,"25":1,"36":1,"52":3,"64":1,"439":1,"755":1}}],["consoleconfirm",{"2":{"789":1}}],["consolecode",{"2":{"783":1,"789":1}}],["console$request",{"2":{"715":1}}],["console$",{"2":{"530":1}}],["console",{"2":{"386":1}}],["consoleblockhash",{"2":{"385":1}}],["consolebasefeepergas",{"2":{"384":1}}],["cons",{"0":{"180":1,"186":1,"190":1,"194":1,"198":1,"202":1,"205":1},"2":{"175":1}}],["consumer",{"2":{"682":4}}],["consumes",{"2":{"419":1}}],["consume",{"2":{"293":1,"419":1,"647":1}}],["consumed",{"2":{"149":1,"418":2}}],["consuming",{"2":{"107":1}}],["consulted",{"2":{"32":1}}],["consist",{"2":{"135":1,"420":1}}],["consists",{"2":{"134":1,"455":1,"456":1,"458":3,"477":1}}],["consistency",{"2":{"47":1}}],["consistent",{"2":{"47":2}}],["considerable",{"2":{"647":1}}],["considerations",{"0":{"590":1},"2":{"107":2,"586":1,"590":1}}],["consider",{"2":{"40":1,"42":2,"43":1,"46":3,"363":1,"439":1,"634":1,"649":1,"794":1}}],["considered",{"2":{"8":1}}],["consensus",{"0":{"423":1,"426":1,"511":1,"572":1,"622":1,"624":1,"629":1,"639":1,"640":1,"727":1,"728":1,"758":1,"773":1},"1":{"512":1,"513":1,"623":1,"624":1,"625":2,"626":2,"627":2,"628":1,"629":1,"630":2,"631":2,"632":1,"633":1,"634":1,"635":1,"636":1,"637":1,"638":1,"639":1,"640":1,"641":2,"642":2,"643":2,"644":2,"645":2,"646":2,"647":2,"648":1,"649":1,"728":1,"729":1,"730":1,"731":1,"774":1},"2":{"89":2,"107":1,"130":1,"133":1,"135":1,"145":1,"146":1,"237":3,"261":1,"264":1,"265":1,"330":1,"335":1,"336":1,"355":2,"372":2,"380":2,"417":1,"426":4,"452":1,"455":1,"456":6,"457":2,"483":1,"498":1,"504":1,"510":2,"512":1,"513":2,"519":1,"520":3,"536":1,"545":1,"559":1,"568":1,"572":2,"582":1,"583":1,"606":4,"622":3,"623":1,"629":1,"636":1,"642":1,"649":31,"652":2,"665":1,"679":2,"713":1,"714":2,"727":1,"733":1,"734":7,"740":2,"745":1,"746":8,"747":2,"749":4,"755":5,"758":1,"770":2,"773":1,"779":1,"781":1,"784":1,"789":1,"792":2,"794":31}}],["consents",{"2":{"34":1}}],["consent",{"2":{"33":1}}],["consequence",{"2":{"13":1,"14":1,"15":1,"16":1,"452":1}}],["consequences",{"2":{"12":1,"14":1,"32":1,"34":1,"437":2}}],["const",{"2":{"312":10,"313":54,"315":2,"432":8}}],["construction",{"2":{"180":1,"183":1,"192":2}}],["constructions",{"2":{"173":1,"187":1,"195":1}}],["constructing",{"2":{"169":2}}],["constructive",{"2":{"8":1}}],["constructed",{"2":{"166":1,"238":1,"440":1}}],["construct",{"2":{"163":1,"165":4,"168":1,"405":1}}],["constructs",{"2":{"146":1,"175":1,"191":1,"402":1}}],["constructor",{"2":{"127":2,"305":2}}],["constants",{"2":{"361":3,"365":1,"390":4,"432":18,"433":1,"593":4,"627":22,"638":6,"664":6,"783":2,"789":2}}],["constantly",{"2":{"289":1,"680":1}}],["constant",{"2":{"89":1,"419":1,"724":2}}],["constitute",{"2":{"30":1,"34":1}}],["context",{"2":{"152":4,"153":10,"157":2,"159":6,"172":8,"323":6,"324":4,"325":6,"326":4,"400":2,"401":4,"402":8,"403":4,"404":4,"425":6,"426":8}}],["contents",{"0":{"339":1},"2":{"405":1}}],["content",{"2":{"2":1,"31":1,"46":2,"65":1,"305":8,"313":17,"380":2,"386":2,"403":4,"536":2,"774":1,"776":1,"777":1,"778":1}}],["containerization",{"2":{"653":1}}],["container",{"0":{"276":1},"2":{"275":9,"276":11,"656":5,"657":4,"658":2}}],["containerstyle",{"2":{"312":4}}],["containers",{"2":{"275":1,"276":1}}],["contained",{"2":{"171":1,"176":1}}],["containing",{"2":{"148":1,"153":4,"154":1,"159":1,"165":1,"167":1,"169":3,"170":2,"172":4,"181":3,"189":1,"192":1,"208":1,"211":1,"219":1,"323":2,"425":2,"458":1,"545":2}}],["contain",{"2":{"86":1,"146":1,"148":1,"154":1,"159":1,"160":1,"165":1,"184":1,"291":1,"414":1,"450":1,"458":1,"481":1,"537":1}}],["contains",{"2":{"86":1,"89":1,"92":1,"116":1,"134":2,"153":4,"156":1,"158":1,"163":4,"169":3,"170":2,"172":2,"280":1,"291":1,"384":1,"415":1,"508":1,"537":1,"604":1,"725":1,"740":1}}],["contacts",{"2":{"45":1,"46":1}}],["contact",{"2":{"41":1,"48":1}}],["contrastingly",{"2":{"452":1}}],["contrast",{"2":{"233":1,"444":1}}],["contracttest",{"2":{"305":2}}],["contractaddress",{"2":{"121":2,"285":2,"313":6,"315":3}}],["contractforge",{"2":{"115":1,"279":1}}],["contractscript",{"2":{"307":2,"308":2,"309":2}}],["contracts",{"0":{"123":1,"126":1,"210":1,"242":1,"259":1,"413":1},"1":{"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1},"2":{"75":3,"77":3,"79":1,"82":1,"84":4,"85":4,"86":2,"89":2,"91":4,"92":1,"94":3,"95":1,"126":2,"127":6,"129":1,"131":1,"136":2,"137":4,"141":1,"143":2,"163":1,"189":1,"211":5,"212":4,"219":3,"230":1,"240":1,"242":2,"249":1,"259":1,"261":1,"265":1,"305":3,"310":1,"317":3,"318":3,"413":2}}],["contract",{"0":{"75":1,"76":1,"95":1,"112":1,"116":1,"117":1,"118":1,"121":1,"153":1,"217":1,"277":1,"280":1,"281":1,"282":1,"285":1,"305":1},"1":{"76":1,"96":1,"97":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":2,"120":2,"121":1,"122":1,"218":1,"219":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":2,"284":2,"285":1,"286":1},"2":{"31":1,"34":1,"73":1,"74":1,"75":6,"76":5,"77":4,"84":1,"85":2,"88":1,"89":4,"91":4,"98":1,"99":1,"107":2,"109":1,"113":2,"115":1,"116":8,"117":11,"120":5,"121":1,"122":1,"127":6,"129":1,"130":1,"131":7,"133":1,"135":4,"145":3,"146":1,"148":4,"149":1,"150":2,"151":1,"153":10,"156":1,"161":1,"163":6,"169":5,"170":4,"171":2,"172":10,"173":1,"174":1,"178":2,"180":1,"181":1,"183":1,"184":2,"188":1,"192":2,"194":1,"195":2,"196":3,"199":1,"200":1,"203":1,"208":2,"210":1,"211":7,"212":3,"213":8,"214":1,"217":2,"219":9,"220":5,"221":2,"222":1,"223":4,"224":1,"225":3,"226":2,"227":4,"228":2,"234":1,"237":2,"238":8,"239":5,"240":1,"242":2,"243":3,"263":1,"277":1,"279":1,"280":8,"281":11,"283":3,"284":4,"285":1,"286":1,"301":1,"303":1,"304":2,"305":15,"306":1,"307":7,"308":13,"309":11,"310":2,"313":16,"315":3,"317":13,"318":4,"339":1,"392":4,"413":1,"445":1,"497":1}}],["controlled",{"2":{"84":1}}],["control",{"2":{"30":1,"31":1,"34":1,"211":1,"475":1,"597":1,"647":1,"676":1}}],["contributor",{"2":{"17":4,"488":1}}],["contributors",{"2":{"7":1,"488":1,"489":1}}],["contributing",{"2":{"8":1}}],["contributiondao",{"2":{"728":1,"729":1,"730":1}}],["contributions",{"2":{"2":1,"9":1,"21":1,"27":3}}],["contribution",{"0":{"2":1},"2":{"2":2,"43":1,"105":1}}],["contributes",{"2":{"8":1,"418":1}}],["contribute",{"2":{"7":1,"24":1,"27":2,"44":1}}],["continuing",{"2":{"789":1}}],["continuousvestingaccount",{"2":{"565":3}}],["continuous",{"2":{"553":1,"564":1}}],["continuously",{"2":{"489":4,"505":1}}],["continues",{"2":{"543":1,"760":1}}],["continue",{"2":{"71":1,"85":1,"287":1,"409":2,"480":1,"481":1,"677":1}}],["continued",{"2":{"14":1,"34":1,"44":1}}],["continually",{"2":{"29":1}}],["comfortable",{"2":{"609":1}}],["comcelestia",{"2":{"513":1}}],["coming",{"2":{"303":1,"776":1,"777":1}}],["comexport",{"2":{"292":1,"655":1}}],["cometbft",{"2":{"233":1,"237":1,"483":1,"724":1}}],["come",{"2":{"133":1,"237":1,"255":1,"400":2,"719":1}}],["comes",{"2":{"107":1}}],["com",{"0":{"47":1},"2":{"45":2,"47":6,"75":2,"82":1,"87":2,"89":2,"149":18,"152":2,"153":14,"159":6,"169":2,"172":22,"211":2,"212":2,"217":2,"220":2,"223":18,"224":2,"268":2,"290":1,"292":1,"299":2,"300":2,"317":2,"322":2,"323":6,"338":1,"355":2,"392":2,"396":2,"399":4,"400":8,"413":2,"420":2,"425":6,"426":16,"433":3,"434":1,"492":1,"510":11,"513":1,"516":1,"517":2,"527":2,"550":2,"573":2,"581":2,"588":2,"609":2,"627":10,"649":28,"655":1,"663":2,"682":4,"713":2,"714":2,"728":10,"729":9,"730":8,"738":1,"746":4,"747":7,"748":7,"749":9,"750":8,"753":2,"794":28}}],["combines",{"2":{"394":1}}],["combined",{"0":{"373":1},"2":{"264":1}}],["combine",{"2":{"33":1}}],["computing",{"2":{"335":1}}],["computation",{"2":{"235":1}}],["computed",{"2":{"184":1,"418":1,"450":1}}],["computesquaresizefromshareproof",{"2":{"131":1}}],["computesquaresizefromrowproof",{"2":{"131":1,"183":1}}],["computes",{"2":{"131":2,"418":1,"458":1}}],["compute",{"2":{"108":1,"458":1}}],["comprised",{"2":{"478":1}}],["comprises",{"2":{"169":1}}],["comprising",{"2":{"208":1}}],["comprehensive",{"2":{"0":1}}],["compilation",{"2":{"117":2,"120":2,"281":2,"284":2}}],["compiling",{"2":{"116":4,"117":2,"120":2,"280":4,"281":2,"284":2,"663":1}}],["compiler",{"2":{"116":2,"126":1,"280":2}}],["compile",{"2":{"116":1,"223":6,"280":1}}],["compatmode",{"2":{"681":2}}],["compatibility",{"0":{"94":1,"333":1},"2":{"89":1}}],["compatible",{"0":{"761":1,"764":1,"766":1},"2":{"79":1,"94":1,"244":1,"246":1,"259":1,"302":1,"333":1,"677":1,"679":2,"681":1}}],["compared",{"2":{"235":1}}],["compare",{"2":{"184":1}}],["comparing",{"2":{"178":1}}],["compact",{"0":{"178":1},"2":{"178":4,"179":1,"192":1}}],["companion",{"2":{"56":1}}],["companies",{"2":{"44":3}}],["company",{"2":{"30":5,"31":8,"32":3,"34":8,"44":1}}],["compelling",{"2":{"44":1}}],["component",{"2":{"94":1,"265":1,"313":2,"432":2}}],["components",{"0":{"106":1},"1":{"107":1,"108":1,"109":1,"110":1},"2":{"27":1,"39":1,"106":1,"208":1,"210":1,"240":1,"414":1,"420":2,"432":8,"455":1,"678":1,"719":1}}],["compose",{"2":{"80":1,"89":1,"90":1,"275":2,"276":6,"387":2}}],["composition",{"2":{"28":1}}],["complex",{"2":{"646":1}}],["completing",{"2":{"79":1,"789":1}}],["completion",{"2":{"30":1,"34":3}}],["completes",{"2":{"439":1}}],["completely",{"2":{"362":1}}],["completed",{"2":{"33":1,"266":1,"581":1,"609":1}}],["complete",{"2":{"24":1,"31":3,"32":1,"53":1,"85":1,"91":2,"223":1,"224":1,"266":1,"309":2,"453":1,"486":1}}],["compliant",{"2":{"128":1}}],["compliance",{"2":{"24":1,"34":3}}],["comply",{"2":{"25":1,"33":1}}],["complaints",{"2":{"11":1}}],["comma",{"2":{"220":1,"627":2,"704":2}}],["commands",{"0":{"373":1,"530":1},"1":{"531":1,"532":1,"533":1,"534":1,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"542":1},"2":{"268":1,"299":1,"359":2,"399":1,"426":2,"530":2,"536":1,"542":1,"581":1,"582":1,"602":1,"606":1,"609":1,"627":1,"663":2}}],["command",{"0":{"358":1,"549":1},"2":{"76":2,"89":2,"91":1,"115":1,"116":1,"121":2,"126":1,"181":1,"268":1,"271":1,"275":2,"276":5,"279":1,"280":1,"284":1,"285":2,"294":2,"295":1,"315":1,"317":2,"355":2,"356":4,"357":1,"358":3,"360":1,"361":1,"362":1,"363":1,"365":3,"369":1,"372":1,"376":1,"377":2,"378":1,"396":2,"397":1,"404":1,"513":1,"515":1,"526":1,"527":1,"530":4,"534":4,"536":4,"537":2,"538":1,"539":2,"540":1,"541":3,"548":1,"564":4,"569":1,"571":2,"573":1,"579":1,"582":1,"586":2,"592":1,"597":1,"602":2,"603":1,"609":1,"610":1,"616":1,"638":1,"643":1,"647":1,"655":1,"657":2,"658":2,"663":2,"672":1,"673":1,"686":2,"687":1,"697":1,"698":1,"699":2,"700":1,"701":1,"702":2,"703":2,"705":2,"706":1,"712":1,"714":3,"715":1,"751":1,"783":1}}],["commission",{"2":{"24":1,"34":2,"474":1,"538":2,"542":6,"789":6}}],["commitment",{"0":{"148":1,"176":1,"177":1,"178":1,"179":1,"180":1,"225":1},"1":{"177":1,"178":1,"179":1,"180":1,"226":1,"227":1,"228":1},"2":{"148":5,"151":1,"163":2,"169":2,"175":1,"176":3,"177":9,"178":2,"179":2,"182":2,"184":3,"185":1,"192":6,"193":1,"195":1,"196":2,"197":1,"200":5,"203":7,"208":3,"228":1,"238":2,"295":1,"323":4,"337":5,"363":5,"365":10,"366":3,"380":2,"402":4,"404":2,"408":4,"425":4,"450":1,"452":1,"458":6,"477":2,"600":2}}],["commitments",{"0":{"171":1,"192":1,"193":1,"194":1,"199":1,"201":1,"202":1},"1":{"193":1,"194":1,"200":1,"201":1,"202":1},"2":{"109":1,"134":6,"136":1,"137":1,"171":1,"178":1,"189":1,"192":2,"195":1,"196":1,"199":1,"230":1,"295":2,"450":1,"459":1}}],["committing",{"0":{"136":1},"2":{"153":2,"170":2,"172":2}}],["committees",{"0":{"232":1},"1":{"233":1,"234":1,"235":1},"2":{"233":1}}],["committee",{"2":{"83":1}}],["committedto",{"2":{"172":4}}],["committed",{"0":{"153":1,"649":1,"794":1},"2":{"47":1,"128":1,"131":9,"134":1,"139":1,"146":2,"148":4,"150":2,"153":8,"163":8,"169":6,"172":4,"173":1,"177":1,"180":1,"181":1,"183":1,"184":2,"225":1,"238":1,"426":4,"458":1,"649":2,"794":2}}],["commitforge",{"2":{"126":1}}],["commits",{"2":{"9":1,"131":1,"136":1,"163":2,"169":2,"187":1,"203":1}}],["commit",{"2":{"2":3,"94":1,"126":1,"131":1,"136":1,"148":1,"192":1,"224":2,"372":4,"609":1}}],["commonly",{"2":{"437":1,"545":1}}],["common",{"2":{"17":1,"60":1,"153":2,"172":2,"321":1,"406":1,"456":2,"589":1,"708":1}}],["communities",{"2":{"65":1}}],["community",{"0":{"5":1,"48":1,"52":1,"64":1,"487":1,"510":1,"537":1,"728":1,"729":1,"730":1,"731":1,"733":1,"734":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1},"2":{"2":1,"3":2,"4":1,"5":5,"7":2,"8":2,"9":2,"10":3,"11":2,"12":2,"13":3,"14":2,"15":3,"16":3,"17":1,"25":1,"27":1,"36":1,"38":1,"39":1,"40":4,"43":2,"45":2,"47":1,"50":1,"52":3,"53":1,"55":1,"57":1,"63":1,"64":3,"65":1,"355":1,"421":1,"483":1,"487":2,"499":2,"510":1,"513":1,"536":1,"537":11,"719":1,"720":1,"726":1,"728":1,"734":1,"744":1,"760":1,"765":1}}],["communicating",{"2":{"545":2}}],["communications",{"0":{"45":1}}],["communication",{"2":{"15":1,"34":1,"45":1,"55":1,"305":2,"583":1,"589":1,"594":1,"619":1,"680":1,"748":1,"777":1}}],["communicate",{"2":{"9":1,"42":1,"89":1,"397":1,"784":1}}],["comments",{"2":{"8":1,"9":1}}],["fsudo",{"2":{"774":1,"776":1,"777":1,"778":1}}],["fssl",{"2":{"663":2}}],["f5nodes",{"2":{"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["fc",{"2":{"419":2}}],["fn",{"2":{"408":2,"409":2,"410":2}}],["fmt",{"2":{"139":4,"152":2,"153":4,"170":2,"171":2,"172":2,"323":2,"400":2,"402":6,"403":4,"425":2,"426":8}}],["f",{"2":{"139":22,"387":1,"774":1,"776":1,"777":1,"778":1}}],["floor",{"2":{"494":1}}],["flow",{"2":{"23":1,"43":1}}],["flipping",{"2":{"439":1}}],["flat",{"2":{"417":3,"420":1,"478":1}}],["flag",{"2":{"107":1,"223":1,"293":2,"294":1,"297":1,"322":1,"355":1,"358":2,"359":1,"360":1,"361":1,"365":1,"366":3,"372":2,"380":2,"401":2,"402":2,"404":2,"407":1,"526":1,"553":1,"564":2,"569":1,"573":1,"581":1,"583":1,"586":1,"589":3,"593":1,"594":1,"596":1,"597":1,"606":1,"616":1,"639":2,"657":1,"789":2}}],["flags",{"0":{"359":1,"586":1},"1":{"360":1,"361":1,"362":1,"587":1,"588":1,"589":1},"2":{"89":1,"102":2,"269":2,"358":4,"359":2,"423":2,"534":4,"571":2,"584":2,"586":2,"596":2,"655":1}}],["flexdirection",{"2":{"313":4}}],["flex",{"2":{"313":6}}],["flexibility",{"0":{"235":1},"2":{"206":1,"235":1,"265":1,"456":1}}],["flexible",{"2":{"41":1}}],["fun",{"2":{"394":1}}],["func2",{"2":{"649":2,"794":2}}],["func",{"2":{"137":2,"139":3,"145":2,"152":2,"153":6,"159":2,"165":7,"166":1,"167":1,"168":1,"169":1,"172":22,"323":2,"324":1,"325":2,"326":2,"400":2,"401":2,"402":5,"403":2,"404":1,"425":2,"426":2}}],["functionalities",{"2":{"740":1}}],["functionality",{"2":{"36":1,"94":1,"135":2,"293":1,"305":1,"332":1,"346":1}}],["functional",{"2":{"720":1}}],["functionids",{"2":{"219":1}}],["functionid",{"2":{"213":3,"215":2,"216":1,"219":1,"220":2,"227":1}}],["functionverifier",{"2":{"212":5,"224":4}}],["function",{"0":{"212":1,"213":1,"224":1,"401":1},"1":{"214":1,"215":1,"216":1},"2":{"110":1,"116":6,"117":13,"127":4,"131":5,"172":2,"211":3,"212":10,"213":16,"214":3,"215":4,"216":2,"219":8,"220":12,"223":1,"224":4,"227":2,"243":2,"280":6,"281":13,"305":24,"307":4,"313":10,"400":2,"401":1,"402":2,"403":1,"404":1,"418":2,"419":7,"420":3,"426":8,"432":5,"453":1,"456":1}}],["functions",{"0":{"402":1},"2":{"108":1,"116":1,"117":1,"131":4,"211":2,"261":3,"263":1,"280":1,"281":1,"305":1,"401":1,"402":1,"456":5,"551":1}}],["fund",{"0":{"570":1,"579":1},"2":{"76":1,"91":1,"119":1,"317":1,"356":2,"390":1,"396":1,"487":1,"527":1,"537":2,"570":1,"579":1,"673":1,"714":1}}],["funded",{"0":{"119":1},"2":{"74":1,"78":1,"80":1,"119":1,"284":1,"317":1,"319":1,"351":1,"356":1,"382":1,"390":2,"392":1,"396":2,"683":1}}],["funds",{"2":{"46":1,"69":2,"71":1,"82":1,"287":1,"290":2,"291":1,"295":1,"356":1,"437":1,"487":1,"536":1,"537":3,"549":4,"551":1,"715":1}}],["funding",{"2":{"44":1,"91":3,"289":1,"396":1}}],["fullfill",{"2":{"211":2}}],["fullnodes",{"2":{"139":1}}],["fullnode",{"2":{"135":6,"139":4}}],["full",{"0":{"100":1,"102":1,"103":1,"138":1,"153":1,"301":1,"599":1,"600":1,"665":1,"666":1,"668":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"743":1,"750":1,"776":1},"1":{"101":1,"102":1,"103":1,"139":1,"140":1,"141":1,"142":1,"143":1,"302":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"666":1,"667":1,"668":1,"669":2,"670":1,"671":1,"672":2,"673":2,"674":1,"675":1,"676":1,"744":1,"745":1,"746":1},"2":{"34":1,"55":1,"88":1,"89":3,"92":2,"102":1,"103":1,"107":1,"108":1,"135":4,"139":1,"145":2,"188":1,"192":1,"211":1,"267":1,"269":2,"270":2,"271":2,"301":1,"327":1,"335":1,"354":1,"411":1,"440":3,"441":4,"450":3,"459":1,"510":2,"513":1,"530":2,"569":1,"571":1,"596":1,"597":4,"599":1,"600":2,"603":1,"615":2,"658":1,"665":1,"666":2,"667":1,"672":6,"673":7,"674":9,"675":2,"676":1,"723":1,"728":1,"729":1,"730":1,"732":1,"734":2,"740":1,"746":4,"747":1,"748":1,"749":3,"750":7,"755":2,"757":1,"769":1,"776":17}}],["fully",{"2":{"24":1,"28":1,"80":1,"390":1,"480":2,"489":1,"736":1}}],["further",{"2":{"34":2,"269":1}}],["furthermore",{"2":{"27":1,"53":1,"453":1,"456":1}}],["future",{"2":{"22":1,"37":1,"38":2,"42":1,"43":1,"48":1,"94":1,"265":1,"332":1,"346":1,"351":1,"481":1,"488":1,"489":1,"590":1,"594":1,"639":1,"678":1,"777":1,"789":1}}],["feasible",{"2":{"451":1}}],["feature",{"2":{"84":1,"106":1,"265":1,"287":1}}],["features",{"2":{"65":1,"264":1,"342":1,"344":1,"405":1,"449":2,"609":1,"677":1,"678":6,"692":1}}],["federation",{"2":{"545":2}}],["federal",{"2":{"34":1}}],["fed",{"2":{"223":1}}],["fek44boeswewectexicgqiabelorfjcagrqagqhaqqeaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmsegovy2vszxn0awexdjhlc2n1n2z1owx2odc5a3p1nxvlz3vldxj0ctvzdzzoc20zbmushqaaaaaaaaaaaaaaaaaaaaaaaaaaaawey1oiszk=",{"2":{"156":2}}],["fetchposts",{"2":{"305":8,"308":2,"309":2,"313":8}}],["fetchpost",{"2":{"305":4}}],["fetches",{"2":{"305":4,"325":2,"326":2,"402":1}}],["fetchedblob",{"2":{"402":2,"404":4}}],["fetched",{"2":{"108":1,"402":3,"404":3,"596":1}}],["fetcher",{"2":{"107":1}}],["fetch",{"2":{"107":1,"211":1,"313":4,"323":2,"324":1,"325":3,"326":5,"394":1,"402":5,"404":4,"408":2,"409":3,"410":3,"425":2}}],["fetching",{"0":{"326":1,"410":1},"2":{"88":1,"325":2,"409":2,"410":2}}],["few",{"2":{"77":1,"139":1,"174":1,"180":1,"257":1,"263":2,"264":1,"318":1,"337":1,"396":1,"571":1,"637":1,"739":1,"754":1,"767":1}}],["fellow",{"2":{"40":1,"50":1,"55":1}}],["feecurrencies",{"2":{"432":2}}],["fee=gas",{"2":{"419":1}}],["feegrant",{"0":{"288":1,"293":1,"295":1,"297":1},"1":{"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":2,"299":1,"300":1},"2":{"289":1,"291":1,"292":2,"293":4,"297":1,"299":4,"300":1,"330":1,"418":1}}],["feel",{"2":{"210":1,"758":1}}],["fee",{"0":{"292":1,"299":1,"416":1,"419":1,"478":1},"1":{"293":1,"294":1,"300":1,"417":1,"418":1,"419":1,"420":1,"421":1},"2":{"84":1,"85":1,"91":20,"211":4,"291":1,"292":1,"293":3,"294":5,"297":2,"299":1,"300":1,"363":5,"375":6,"417":5,"419":3,"478":2,"483":1,"496":1,"564":2}}],["fees=21000utia",{"2":{"783":1,"789":2}}],["fees=21000utiacelestia",{"2":{"783":1}}],["fees",{"0":{"417":1},"1":{"418":1,"419":1,"420":1},"2":{"31":1,"289":1,"291":1,"296":2,"299":3,"300":2,"366":1,"417":3,"421":1,"428":1,"430":1,"478":3,"549":4,"564":6,"571":2,"682":4}}],["feedback",{"0":{"4":1,"29":1},"2":{"4":1,"8":1,"29":1,"36":1,"37":1,"38":2,"719":1,"758":1}}],["february",{"2":{"21":1,"28":1}}],["fatalf",{"2":{"401":2,"402":6,"404":8}}],["fatal",{"0":{"604":1},"2":{"401":2,"402":4,"404":4,"604":2}}],["faster",{"2":{"618":1}}],["fastest",{"2":{"582":1,"610":1}}],["fast",{"2":{"334":1,"336":1}}],["favourite",{"2":{"212":1}}],["favor",{"2":{"161":1,"162":1}}],["falsediscard",{"2":{"647":1}}],["false",{"2":{"153":2,"219":4,"459":3,"564":2,"583":1,"589":2,"594":1,"616":1,"618":1,"619":1,"647":3,"682":24,"774":1}}],["falls",{"2":{"681":1}}],["fallback",{"0":{"110":1,"287":1},"2":{"106":1,"110":6,"287":5}}],["fall",{"2":{"88":1,"110":1,"139":1,"287":1}}],["faults",{"2":{"135":1}}],["faulty",{"2":{"109":1,"189":1}}],["faucets",{"2":{"683":1}}],["faucet",{"0":{"251":1,"514":1,"751":1},"1":{"515":1,"516":1},"2":{"75":1,"80":1,"82":1,"119":1,"251":2,"278":1,"317":1,"356":2,"382":1,"396":1,"514":1,"515":3,"516":2,"570":1,"579":2,"751":4}}],["familiarity",{"2":{"80":1,"101":1}}],["family",{"2":{"45":2}}],["face",{"2":{"301":1}}],["fact",{"2":{"108":1,"146":1,"159":1,"178":1,"184":1}}],["factories",{"2":{"89":1}}],["factory",{"2":{"85":1}}],["factors",{"2":{"34":1,"42":1,"724":2}}],["facilitating",{"2":{"85":1}}],["facilitated",{"2":{"65":1}}],["facilitate",{"2":{"37":1,"305":2,"455":1}}],["failure",{"2":{"139":4,"649":2,"774":2,"776":2,"777":2,"778":2,"794":2}}],["failed",{"2":{"117":2,"281":2,"401":2,"402":10,"404":8,"408":8,"409":4,"410":6,"432":2,"599":2,"601":2}}],["fails",{"2":{"110":1,"459":1,"601":1}}],["fail",{"2":{"31":1,"220":1,"297":1,"360":1}}],["failing",{"2":{"25":1}}],["fairly",{"2":{"11":1,"330":1}}],["fair",{"2":{"9":1,"19":1,"505":1}}],["faq",{"0":{"207":1,"435":1,"648":1,"793":1},"1":{"208":1,"436":1,"437":1,"438":1,"439":1,"440":1,"441":1,"442":1,"443":1,"444":1,"445":1,"446":1,"447":1,"448":1,"649":1,"794":1},"2":{"17":2}}],["frequently",{"2":{"763":1}}],["frequency",{"2":{"220":1,"224":3}}],["fresh",{"2":{"641":1}}],["freeze",{"2":{"219":1}}],["free",{"2":{"7":1,"31":1,"40":1,"210":1,"481":2,"510":1,"565":2,"726":1,"728":1,"744":1,"758":1}}],["frameworks",{"2":{"265":2,"310":1}}],["framework",{"0":{"257":1},"2":{"310":2,"483":1,"749":1}}],["frame",{"2":{"84":1}}],["fraudulent",{"2":{"139":1,"637":1}}],["fraud",{"0":{"131":1,"452":1},"2":{"33":1,"108":2,"131":1,"136":1,"139":3,"172":5,"173":1,"187":1,"188":4,"189":1,"192":2,"195":1,"264":2,"440":1,"441":3,"452":1,"456":1,"666":2}}],["frontendcd",{"2":{"77":1,"318":1}}],["frontend",{"0":{"77":1,"78":1,"310":1,"318":1,"319":1},"1":{"311":1},"2":{"75":3,"76":1,"77":5,"303":1,"308":1,"309":1,"310":10,"311":1,"317":4,"318":5}}],["from=$validator",{"2":{"783":2,"789":2}}],["from=",{"2":{"538":2}}],["from",{"0":{"70":1,"71":1,"221":1,"227":1,"298":1,"421":1,"581":1,"606":1,"609":1},"1":{"71":1,"72":1,"607":1},"2":{"2":1,"4":1,"8":1,"13":1,"15":1,"16":1,"17":1,"27":2,"30":1,"31":5,"33":4,"34":9,"36":1,"37":1,"38":1,"43":1,"46":1,"47":1,"49":1,"50":1,"52":1,"54":1,"65":3,"66":1,"68":1,"69":1,"75":3,"76":2,"77":1,"81":1,"84":2,"85":1,"87":1,"88":2,"89":1,"90":1,"91":8,"95":1,"107":3,"108":1,"109":1,"116":1,"120":1,"121":1,"126":1,"130":1,"131":4,"135":8,"137":1,"139":8,"145":1,"155":1,"164":2,"165":2,"166":2,"169":2,"172":4,"181":1,"182":1,"183":1,"188":1,"195":1,"208":1,"211":2,"212":1,"213":1,"217":3,"220":2,"221":1,"223":1,"225":1,"227":4,"230":1,"234":1,"237":1,"238":1,"244":1,"263":2,"264":1,"265":2,"270":1,"271":1,"275":1,"278":2,"280":1,"283":1,"284":1,"285":1,"298":1,"300":1,"301":1,"303":1,"307":2,"309":3,"312":14,"313":23,"315":1,"317":5,"318":1,"323":2,"326":2,"332":1,"337":6,"348":1,"356":1,"359":3,"361":1,"362":1,"363":1,"365":3,"370":1,"372":1,"382":1,"384":1,"385":2,"394":1,"396":1,"400":2,"401":4,"402":7,"404":5,"405":1,"408":2,"410":4,"413":1,"417":3,"421":2,"425":2,"426":6,"428":1,"432":4,"437":1,"440":1,"441":1,"443":1,"444":1,"445":2,"453":1,"456":1,"457":2,"459":2,"473":1,"480":2,"481":2,"483":1,"489":5,"504":1,"505":1,"512":2,"513":1,"515":1,"520":2,"526":1,"527":1,"533":1,"535":5,"536":7,"537":2,"539":4,"540":2,"545":7,"548":2,"549":14,"551":2,"557":1,"563":3,"564":8,"566":1,"569":2,"571":2,"572":1,"573":1,"580":1,"596":1,"602":1,"604":1,"606":3,"612":1,"619":1,"627":1,"635":2,"637":2,"638":3,"639":1,"642":1,"643":1,"649":1,"655":1,"663":2,"673":2,"683":1,"691":2,"713":1,"715":1,"733":2,"734":1,"745":2,"746":3,"751":1,"763":1,"777":2,"778":1,"789":3,"794":1}}],["friends",{"2":{"44":1,"45":2,"696":1}}],["friendly",{"2":{"41":2}}],["firewall",{"2":{"583":2,"594":2}}],["first",{"2":{"23":4,"43":1,"50":1,"57":1,"59":1,"73":1,"84":1,"89":2,"91":1,"105":1,"115":1,"120":2,"134":3,"135":1,"136":1,"137":1,"139":1,"153":2,"165":2,"166":1,"169":2,"170":2,"172":6,"174":1,"181":1,"192":1,"213":1,"224":2,"230":2,"238":1,"243":1,"244":1,"266":1,"268":1,"279":1,"283":2,"284":2,"294":1,"295":1,"301":1,"305":8,"308":2,"309":4,"311":1,"313":2,"315":3,"317":2,"326":2,"329":1,"337":2,"339":1,"375":1,"385":1,"396":1,"402":5,"403":1,"410":2,"418":2,"421":1,"488":1,"494":1,"496":1,"508":1,"536":3,"537":1,"542":1,"545":1,"554":1,"561":1,"568":1,"578":1,"597":1,"611":1,"656":1,"663":1,"678":1,"679":1,"724":1,"725":1,"740":1,"781":1}}],["figment",{"2":{"550":1}}],["figure",{"2":{"453":1,"455":1,"458":2,"664":1}}],["figures",{"2":{"65":1}}],["five",{"2":{"488":1}}],["fit",{"0":{"445":1}}],["fits",{"2":{"264":1}}],["fields",{"2":{"637":1}}],["field",{"2":{"156":1,"164":2,"165":1,"169":1,"218":1,"402":1,"619":1,"644":2}}],["fide",{"2":{"34":1}}],["fine",{"2":{"459":1}}],["finished",{"2":{"116":2,"117":2,"280":2,"281":2,"778":1}}],["finish",{"0":{"91":1},"2":{"404":1}}],["finger",{"2":{"41":1}}],["finality",{"2":{"261":1}}],["finalizecommit",{"2":{"649":2,"794":2}}],["finalize",{"2":{"36":1,"469":1}}],["finally",{"2":{"103":1,"109":1,"169":1,"180":1,"184":1,"418":1,"545":1}}],["final",{"2":{"36":1,"223":1,"404":1,"456":3,"547":1,"549":2,"703":2}}],["financial",{"2":{"34":1,"44":1}}],["finding",{"2":{"5":1,"40":1,"44":1,"46":1,"48":2}}],["find",{"0":{"384":1,"386":1},"2":{"0":1,"4":1,"43":1,"44":1,"47":1,"60":1,"61":1,"64":1,"75":1,"88":2,"91":1,"96":1,"97":1,"107":3,"131":1,"136":2,"153":2,"170":2,"179":1,"224":2,"238":1,"239":1,"294":1,"317":1,"338":1,"346":1,"351":1,"355":1,"356":1,"510":1,"513":1,"527":1,"547":1,"557":1,"571":1,"594":1,"605":1,"615":1,"618":1,"661":1,"673":1,"701":1,"702":1,"714":1,"734":2,"736":1,"750":1,"771":1,"786":1}}],["fix",{"2":{"421":1,"605":1,"649":1,"794":1}}],["fixed",{"2":{"418":2,"419":2}}],["fixes",{"2":{"24":1}}],["fixing",{"2":{"2":1}}],["fill",{"2":{"219":2,"545":1}}],["filled",{"2":{"23":1}}],["filter",{"0":{"691":1},"2":{"324":2,"325":2,"409":2,"682":8,"688":4,"691":1}}],["filteropts",{"2":{"153":2,"170":2}}],["filterdatacommitmentstored",{"2":{"153":2,"170":2}}],["file=",{"2":{"545":2}}],["filecoin",{"2":{"448":1}}],["file",{"0":{"298":1,"703":1,"704":1},"2":{"84":3,"86":3,"92":1,"102":3,"116":1,"117":2,"211":1,"219":2,"220":2,"224":1,"227":1,"280":1,"281":2,"298":3,"305":1,"310":1,"311":1,"387":1,"400":2,"413":1,"426":2,"530":6,"533":2,"536":5,"537":4,"542":1,"544":1,"545":1,"546":1,"573":2,"578":1,"581":1,"582":1,"602":1,"604":2,"605":9,"610":1,"621":1,"627":5,"643":1,"646":1,"647":1,"683":9,"701":1,"702":2,"703":4,"704":2,"774":2,"776":2,"777":2,"778":1,"791":1}}],["filesystem",{"2":{"661":1}}],["fileserror",{"2":{"605":1}}],["files",{"0":{"86":1,"87":1,"605":1,"684":1},"2":{"3":1,"58":1,"85":1,"86":3,"87":1,"116":2,"117":2,"120":2,"280":2,"281":2,"284":2,"303":1,"530":2,"605":2,"663":1,"703":4}}],["fontsize",{"2":{"313":4}}],["four",{"2":{"177":1,"261":1,"422":1,"456":3,"536":1}}],["found",{"2":{"84":2,"95":1,"102":1,"108":1,"110":1,"131":1,"135":1,"145":1,"146":1,"148":1,"165":1,"166":1,"168":1,"169":1,"177":1,"178":1,"181":1,"184":2,"191":2,"217":1,"219":1,"226":1,"238":1,"241":1,"245":1,"323":1,"324":2,"325":2,"360":1,"380":1,"382":2,"394":1,"396":2,"408":1,"409":2,"420":2,"484":1,"513":1,"536":2,"637":3,"690":1,"723":1}}],["foundry",{"2":{"75":1,"114":1,"115":1,"121":1,"125":1,"211":2,"213":1,"217":2,"278":1,"279":1,"285":1,"301":1,"303":1,"304":2,"305":1,"310":2,"317":1}}],["foundation",{"0":{"18":1,"20":1},"1":{"19":1,"20":1,"21":2,"22":2,"23":2,"24":2,"25":2,"26":1,"27":1,"28":1,"29":1},"2":{"19":2,"21":1,"22":2,"24":2,"25":1,"27":2,"28":1,"488":1}}],["folders",{"2":{"557":4,"641":1,"682":1}}],["folder",{"2":{"92":1,"108":1,"115":1,"223":2,"224":4,"279":1,"581":1}}],["followed",{"2":{"136":1,"210":1,"221":1}}],["follows",{"2":{"24":1,"135":1,"163":1,"165":2,"166":2,"167":1,"168":1,"171":1,"172":1,"178":1,"184":1,"200":1,"203":1,"358":1,"545":1,"596":1,"690":1,"724":1}}],["follow",{"2":{"12":1,"35":2,"38":1,"48":1,"88":1,"102":1,"208":1,"222":1,"226":1,"227":1,"309":1,"413":2,"456":1,"523":1,"525":1,"529":1,"546":1,"582":1,"610":1,"625":1,"626":1,"639":1,"652":1,"653":1,"663":2,"669":1,"670":1,"675":1,"681":1,"683":1,"692":1,"693":1,"696":1,"717":1,"740":1,"781":1,"782":1,"785":1,"788":1,"789":1,"791":1}}],["following",{"2":{"1":1,"27":1,"34":3,"41":1,"42":1,"52":1,"53":1,"54":1,"83":1,"91":2,"95":1,"107":2,"115":1,"116":2,"117":1,"125":1,"134":1,"149":1,"163":1,"165":2,"168":1,"177":1,"181":1,"187":1,"188":1,"196":1,"200":1,"208":1,"210":1,"211":2,"220":3,"223":1,"225":1,"238":2,"242":1,"247":1,"266":1,"268":1,"269":1,"271":1,"276":1,"279":1,"280":2,"281":1,"294":1,"295":1,"299":1,"305":2,"307":1,"309":1,"310":1,"311":1,"313":1,"314":1,"315":1,"322":1,"352":1,"356":4,"359":1,"360":1,"361":1,"362":1,"363":3,"365":3,"376":1,"377":2,"395":1,"396":1,"397":1,"399":1,"404":1,"407":1,"427":1,"432":1,"433":1,"434":1,"453":1,"455":1,"456":1,"458":1,"465":1,"466":1,"469":2,"470":1,"491":1,"492":1,"515":1,"520":1,"521":1,"522":1,"526":1,"527":2,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"542":1,"545":1,"551":1,"564":1,"583":1,"585":1,"586":1,"590":1,"594":1,"597":1,"602":2,"609":1,"615":1,"623":1,"624":1,"627":1,"629":1,"638":1,"658":1,"667":1,"668":1,"672":1,"673":2,"680":1,"682":1,"684":1,"686":1,"687":1,"692":1,"694":1,"695":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":3,"704":2,"705":3,"706":1,"708":1,"709":1,"712":1,"714":3,"715":1,"724":1,"738":1,"751":1,"752":1,"780":1,"781":1,"786":1,"787":1,"789":1}}],["foster",{"2":{"52":1,"65":1}}],["fosters",{"2":{"43":1}}],["fostering",{"2":{"19":1,"41":1,"49":1}}],["focus",{"2":{"497":1,"504":1,"585":1}}],["focuses",{"2":{"342":1}}],["focused",{"2":{"42":2,"235":1,"504":1,"763":1,"765":1}}],["focusing",{"2":{"8":2,"43":1}}],["foods",{"2":{"41":1}}],["food",{"2":{"41":2}}],["fortunately",{"2":{"545":1}}],["forth",{"2":{"30":1}}],["forward",{"2":{"211":1,"774":1}}],["forget",{"2":{"71":1,"561":2}}],["forge",{"2":{"42":1,"75":2,"116":1,"117":2,"211":2,"212":6,"219":2,"280":1,"281":2,"284":1,"305":3,"307":2,"317":2}}],["forces",{"2":{"42":1}}],["forest",{"2":{"458":1}}],["forever",{"2":{"446":1}}],["foreign",{"2":{"34":1}}],["foregoing",{"2":{"33":1}}],["formula",{"2":{"420":1}}],["formcontainerstyle",{"2":{"313":4}}],["former",{"2":{"457":1}}],["formerly",{"2":{"230":1}}],["formed",{"2":{"34":1}}],["formatting",{"0":{"358":1}}],["format",{"2":{"163":1,"164":1,"211":2,"270":1,"313":2,"358":1,"363":3,"365":1,"369":1,"372":1,"375":1,"402":1,"533":1,"536":1,"573":2}}],["formation",{"2":{"33":1}}],["formal",{"2":{"42":1}}],["forms",{"2":{"32":1,"36":1,"37":1,"134":1}}],["forming",{"2":{"31":1}}],["form",{"0":{"53":1},"2":{"27":1,"29":1,"34":1,"53":1,"84":1,"227":1,"489":1}}],["fork",{"2":{"2":3,"308":2,"421":1}}],["for",{"0":{"48":1,"88":1,"89":1,"131":1,"171":1,"269":1,"270":1,"271":1,"272":1,"288":1,"294":1,"297":1,"328":1,"440":1,"441":1,"454":1,"464":1,"473":1,"476":1,"481":1,"496":1,"512":1,"513":1,"542":1,"607":1,"640":1,"702":1,"733":1,"734":1,"743":1,"745":1,"746":1,"761":1,"764":1,"766":1},"1":{"289":1,"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":2,"299":1,"300":1,"329":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1,"455":1,"477":1,"478":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"647":1,"744":1,"745":1,"746":1},"2":{"0":1,"2":1,"3":4,"4":1,"5":2,"7":1,"8":3,"9":2,"11":1,"12":1,"14":2,"15":1,"17":1,"19":1,"22":2,"23":3,"24":5,"25":2,"26":3,"27":3,"28":2,"30":3,"31":6,"32":2,"33":4,"34":12,"36":3,"37":1,"38":4,"39":1,"40":13,"41":6,"42":4,"43":6,"44":4,"45":2,"46":5,"47":8,"48":3,"49":2,"50":1,"52":2,"53":2,"56":1,"57":1,"60":2,"61":1,"63":3,"64":1,"65":1,"69":3,"75":1,"79":1,"80":1,"82":2,"84":15,"85":1,"86":5,"88":6,"89":13,"90":1,"91":14,"94":4,"102":1,"105":2,"107":11,"108":5,"110":3,"113":1,"115":1,"116":1,"117":2,"119":1,"121":1,"126":1,"127":1,"129":1,"131":1,"133":1,"134":2,"135":12,"136":4,"137":3,"139":3,"143":2,"145":8,"146":1,"148":2,"149":1,"151":2,"153":2,"156":2,"160":1,"161":3,"162":1,"164":1,"169":2,"170":4,"171":4,"172":13,"174":1,"179":1,"180":2,"181":1,"183":1,"185":1,"188":1,"189":1,"196":1,"203":1,"206":1,"211":17,"213":2,"214":2,"215":1,"216":1,"217":1,"219":3,"220":10,"221":1,"223":1,"224":7,"225":2,"227":2,"228":2,"230":3,"233":1,"235":1,"237":2,"238":3,"239":3,"240":1,"243":2,"245":1,"246":2,"247":2,"253":1,"255":3,"257":1,"264":1,"265":2,"267":1,"268":1,"269":5,"275":5,"276":1,"279":1,"280":1,"281":2,"285":1,"287":2,"289":1,"291":2,"292":2,"293":2,"294":1,"297":1,"299":2,"301":1,"302":1,"303":3,"305":7,"309":1,"310":4,"311":2,"312":4,"313":4,"317":1,"328":1,"330":2,"331":1,"332":2,"333":1,"337":4,"338":1,"341":1,"343":1,"344":1,"346":1,"347":1,"351":1,"352":3,"355":3,"356":5,"358":3,"359":1,"361":1,"362":1,"363":1,"365":2,"366":2,"368":1,"369":6,"377":1,"380":1,"383":1,"384":1,"385":1,"387":1,"390":1,"391":2,"392":2,"394":1,"395":1,"396":3,"397":2,"400":2,"402":1,"404":1,"405":2,"412":1,"413":4,"415":3,"417":2,"418":3,"419":12,"420":4,"421":1,"425":1,"426":4,"432":2,"436":2,"437":1,"438":3,"439":4,"440":3,"442":1,"443":1,"444":1,"446":2,"447":2,"448":2,"449":1,"450":4,"451":3,"452":2,"453":7,"455":2,"456":4,"457":2,"458":3,"459":5,"465":1,"469":1,"479":1,"480":1,"481":8,"484":2,"488":2,"489":2,"491":1,"492":1,"496":2,"497":1,"498":1,"502":1,"503":1,"504":2,"508":1,"509":2,"510":1,"512":1,"513":5,"517":1,"518":1,"521":3,"523":1,"525":1,"526":1,"527":6,"530":4,"533":2,"536":1,"543":2,"544":4,"545":1,"547":1,"548":1,"551":5,"552":1,"553":3,"557":1,"559":1,"564":3,"568":2,"569":3,"571":1,"572":1,"573":5,"576":1,"577":1,"578":1,"579":2,"581":2,"582":2,"583":3,"584":1,"585":3,"587":1,"588":1,"589":2,"590":2,"592":1,"593":3,"594":3,"596":2,"603":1,"604":1,"605":2,"606":1,"607":2,"609":1,"610":2,"615":4,"616":2,"619":1,"621":3,"623":3,"627":5,"633":1,"634":1,"635":1,"636":1,"637":1,"639":1,"642":1,"644":2,"646":2,"647":3,"649":2,"651":1,"652":1,"653":3,"654":2,"655":2,"656":3,"657":1,"661":3,"662":1,"663":2,"664":1,"667":3,"669":1,"670":1,"673":11,"677":1,"678":2,"680":2,"681":1,"682":2,"683":4,"684":2,"688":2,"690":1,"692":1,"697":1,"698":3,"699":1,"701":2,"702":1,"703":1,"706":1,"708":1,"709":3,"713":3,"714":3,"719":2,"723":1,"724":1,"725":1,"726":3,"728":1,"733":1,"734":5,"736":1,"737":1,"738":1,"740":3,"744":3,"745":1,"746":3,"748":1,"750":1,"752":1,"753":1,"760":1,"763":1,"772":1,"774":1,"777":1,"780":3,"783":1,"784":1,"785":1,"786":1,"789":1,"792":2,"794":2}}],["tls",{"0":{"589":1},"2":{"589":7}}],["tls=false",{"2":{"589":2}}],["tls=true",{"2":{"587":2,"588":2,"589":2}}],["tls=",{"2":{"586":2}}],["tld",{"2":{"380":1}}],["tb",{"2":{"521":1,"623":1,"635":1,"667":1,"757":2,"758":2,"780":1}}],["tbd",{"2":{"127":2,"330":1,"679":2}}],["tcp",{"2":{"152":2,"153":2,"275":2,"276":2,"370":6,"510":4,"573":2,"583":2,"584":4,"594":1,"601":2,"643":4,"777":2}}],["tj9wswcyhm0r0i8t+p3hpftdieuyr9wspvkl1r2s=",{"2":{"151":2}}],["tmproto",{"2":{"165":2,"172":2,"426":6}}],["tm",{"2":{"149":2,"330":1,"649":14,"794":14}}],["txtsudo",{"2":{"541":1}}],["txt",{"2":{"533":1,"541":5,"627":8}}],["txtcelestia",{"2":{"533":1}}],["txtvite",{"2":{"311":1}}],["txoption",{"2":{"426":2}}],["txhashcelestia",{"2":{"375":1}}],["txhash",{"2":{"157":4,"159":2,"375":1,"564":2,"783":3,"789":2}}],["txsizecost",{"2":{"419":1}}],["txsizecostperbyte",{"2":{"418":1}}],["txsharerange",{"2":{"181":1}}],["txs",{"2":{"134":4,"137":6,"159":2,"530":2}}],["tx",{"2":{"91":6,"153":14,"156":5,"157":5,"159":6,"170":4,"172":2,"299":2,"313":4,"384":2,"385":2,"415":1,"417":1,"418":1,"423":2,"458":1,"530":4,"535":6,"536":6,"537":2,"538":2,"539":4,"540":2,"549":10,"564":8,"571":4,"646":4,"682":10,"690":2,"783":7,"789":6}}],["ts",{"2":{"89":1}}],["tsx",{"2":{"77":2,"318":2}}],["tuning",{"2":{"459":1}}],["tuplerootnonce",{"0":{"170":1},"2":{"163":2,"169":5}}],["tuple",{"2":{"127":10,"128":1,"136":1,"137":1,"148":4,"150":3,"153":2,"163":14,"169":17,"173":1,"177":3,"178":1,"183":1,"184":4,"208":1}}],["tutorial",{"0":{"321":1,"345":1,"347":1,"348":1,"406":1},"1":{"322":1,"323":1,"324":1,"325":1,"326":1,"327":1,"349":1,"350":1,"351":1,"352":1,"353":1,"354":1,"355":1,"356":1,"357":1,"358":1,"359":1,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"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,"407":1,"408":1,"409":1,"410":1,"411":1},"2":{"79":1,"113":1,"115":1,"122":1,"266":3,"277":1,"279":1,"286":1,"301":1,"302":1,"303":1,"309":3,"316":1,"317":1,"321":1,"332":1,"345":1,"347":1,"348":1,"357":1,"381":1,"394":2,"396":2,"405":1,"406":1,"424":1,"425":1,"460":1,"519":1,"522":1,"523":1,"525":1,"529":1,"553":1,"568":2,"572":1,"577":1,"580":1,"581":1,"585":5,"609":1,"611":1,"624":1,"626":1,"639":1,"651":1,"652":1,"655":1,"665":1,"668":1,"669":1,"670":1,"675":1,"682":1,"707":1,"710":1,"717":1,"718":1,"755":1,"779":1,"781":1,"782":1,"785":1,"788":1,"789":1}}],["tutorials",{"2":{"0":1,"3":1,"24":1,"255":1,"758":1}}],["turned",{"2":{"632":1}}],["turn",{"2":{"48":1,"68":1,"208":1}}],["twitch",{"2":{"46":1}}],["twitter",{"2":{"27":1,"45":2,"46":1}}],["two",{"2":{"45":1,"66":1,"71":1,"116":1,"117":1,"146":2,"154":1,"160":1,"175":1,"177":1,"178":1,"184":1,"213":2,"224":2,"240":1,"261":1,"280":1,"281":1,"292":1,"337":1,"341":1,"414":1,"449":1,"453":1,"458":1,"477":1,"520":1,"536":1,"636":1,"637":1,"678":1,"680":1,"687":1,"715":1,"762":1,"771":1}}],["tar",{"2":{"638":24,"663":4,"664":32}}],["targets",{"2":{"545":6}}],["targetblock",{"2":{"228":1}}],["target",{"2":{"149":1,"210":1,"211":1,"213":1,"219":1,"220":3,"224":3,"225":2,"230":1,"243":1,"313":4,"484":1,"530":2,"604":1,"774":4,"776":4,"777":4,"778":4}}],["targeting",{"2":{"88":1}}],["tasked",{"2":{"441":1}}],["tasks",{"2":{"30":1,"91":1,"456":1,"663":1}}],["taking",{"2":{"107":1,"165":1,"166":1,"169":1,"178":1,"636":1}}],["taken",{"2":{"223":1}}],["takes",{"2":{"107":1,"117":1,"150":1,"160":1,"223":2,"224":1,"226":1,"281":1,"323":2,"326":1,"363":1,"402":1,"408":2,"410":1}}],["takeaways",{"2":{"38":1}}],["take",{"2":{"9":1,"53":1,"107":1,"116":1,"131":1,"134":1,"163":1,"164":1,"168":1,"184":1,"200":1,"203":1,"208":1,"212":1,"280":1,"308":2,"450":1,"455":1,"459":1,"572":1,"593":1,"596":1,"621":1,"637":1,"679":1}}],["tab=staking",{"2":{"491":1}}],["tables",{"2":{"305":2}}],["table",{"2":{"84":1,"488":1,"489":1,"513":1}}],["tab",{"2":{"69":2,"71":2,"217":1,"251":1,"269":1}}],["tag",{"2":{"45":1,"275":2,"581":12,"609":6,"655":6,"657":6,"658":6}}],["tags",{"2":{"36":1,"581":6,"609":6}}],["talented",{"2":{"43":1}}],["talks",{"2":{"40":1,"43":1,"46":1,"48":5}}],["talk",{"2":{"40":1,"43":1}}],["tailored",{"2":{"53":1,"65":1}}],["tailor",{"2":{"42":1,"44":1,"48":1}}],["tax",{"2":{"32":6,"34":2}}],["taxes",{"0":{"32":1},"2":{"31":1,"32":1}}],["t",{"0":{"446":1},"2":{"27":1,"35":1,"40":1,"43":1,"45":1,"46":3,"71":1,"88":1,"89":1,"107":2,"117":3,"139":1,"145":1,"153":2,"164":1,"165":1,"166":1,"168":1,"169":1,"170":2,"183":1,"192":1,"208":1,"211":3,"217":1,"238":1,"263":1,"264":1,"265":2,"281":3,"305":1,"346":2,"359":1,"382":1,"388":1,"390":1,"413":1,"426":2,"432":2,"440":1,"441":2,"446":2,"492":1,"557":4,"569":1,"571":1,"611":1,"639":1,"643":1,"646":1,"649":19,"665":1,"681":1,"685":1,"724":1,"747":1,"748":1,"763":1,"771":1,"789":1,"794":19}}],["tiny",{"2":{"434":1}}],["tia",{"0":{"460":1,"462":1,"465":1,"466":1,"467":1,"469":1,"470":1,"471":1,"474":1,"475":1,"488":1,"493":1,"494":1,"495":1,"501":1},"1":{"461":1,"462":1,"463":2,"464":2,"465":2,"466":2,"467":1,"468":2,"469":2,"470":2,"471":1,"472":2,"473":2,"474":2,"475":2,"489":1,"494":1,"495":1,"496":2,"497":2,"498":2,"499":2,"500":2,"501":2,"502":2,"503":2},"2":{"375":2,"432":6,"434":1,"460":3,"465":1,"483":1,"484":3,"486":1,"487":1,"488":1,"489":3,"494":2,"496":2,"497":1,"498":1,"499":1,"501":1,"502":2}}],["ticketing",{"2":{"320":1}}],["title",{"2":{"305":24,"313":12,"536":6,"537":2}}],["ti",{"2":{"275":2,"276":2}}],["tips",{"2":{"479":1}}],["tip",{"2":{"76":1,"89":1,"225":1,"269":1,"275":1,"293":1,"351":1,"354":1,"355":1,"356":1,"358":1,"362":1,"385":2,"390":1,"391":1,"392":1,"396":1,"400":1,"402":1,"527":1,"564":2,"579":1,"592":1,"602":2,"635":2,"649":1,"664":1,"673":1,"681":1,"706":1,"713":1,"734":1,"786":1,"794":1}}],["timing",{"2":{"65":1,"421":1}}],["timeout",{"2":{"426":2,"564":2,"682":4}}],["timeseries",{"2":{"545":2}}],["timestamp",{"2":{"372":2,"384":2,"484":1,"564":3,"783":2,"789":2}}],["times",{"2":{"34":1,"450":1,"677":1,"763":1}}],["timely",{"2":{"25":1}}],["time",{"2":{"14":1,"15":1,"31":2,"34":2,"36":1,"45":1,"84":2,"88":1,"116":1,"139":1,"220":2,"226":1,"238":1,"263":1,"280":1,"301":1,"335":1,"372":2,"387":1,"400":1,"404":1,"418":1,"421":2,"426":2,"443":1,"458":1,"484":1,"545":2,"551":1,"557":1,"564":2,"565":4,"572":1,"611":1,"635":2,"678":1,"679":1,"682":4,"684":1,"774":1,"778":1}}],["tiers",{"2":{"23":1}}],["tier",{"2":{"23":1,"65":1}}],["tr",{"2":{"627":10,"638":6}}],["tryfinalizecommit",{"2":{"649":2,"794":2}}],["try",{"2":{"307":1,"358":1,"382":1,"396":1,"405":1,"432":2,"627":1,"691":1}}],["trying",{"2":{"107":1,"382":1,"604":1,"605":1}}],["trpc",{"2":{"145":11,"152":4,"153":8,"157":2,"159":4,"162":2,"172":2}}],["trees",{"0":{"453":1},"2":{"351":1,"449":1,"453":1}}],["tree",{"2":{"108":2,"127":2,"128":1,"148":2,"165":6,"168":6,"197":1,"453":2,"455":2,"458":1}}],["treated",{"2":{"33":1,"219":1,"418":1}}],["tries",{"2":{"459":1}}],["triggered",{"2":{"287":3}}],["triggering",{"2":{"188":1}}],["trigger",{"2":{"188":1}}],["trick",{"2":{"108":1}}],["tripods",{"2":{"40":1}}],["truth",{"2":{"148":1}}],["true",{"2":{"89":6,"127":2,"153":2,"156":1,"157":2,"159":2,"219":1,"220":2,"305":6,"312":4,"365":1,"392":3,"544":4,"583":2,"589":1,"594":2,"618":1,"619":1,"637":3,"647":1,"682":10}}],["trusts",{"2":{"621":1}}],["trustedpeers",{"2":{"621":1}}],["trustedpeer",{"0":{"621":1}}],["trustedhash",{"0":{"621":1},"2":{"621":1}}],["trusted",{"0":{"218":1,"606":1},"1":{"607":1},"2":{"56":1,"217":3,"218":6,"219":6,"223":1,"520":2,"596":1,"606":8,"621":5,"637":2,"682":4,"728":1,"729":1,"730":1,"747":1,"748":1,"749":1}}],["trust",{"2":{"45":1,"449":1,"459":1,"606":3,"637":4,"682":4}}],["trustworthy",{"2":{"19":1}}],["troubles",{"2":{"734":1}}],["troubleshooting",{"0":{"382":1,"591":1,"661":1},"1":{"592":1,"593":1,"594":1,"595":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"602":1,"603":1,"604":1,"605":1},"2":{"60":1,"93":1,"269":1,"275":2,"355":1,"356":1,"358":1,"526":1,"527":1,"579":1,"612":1,"655":1,"673":2,"706":1,"713":1,"786":1}}],["trolling",{"2":{"8":1}}],["traditional",{"2":{"197":1,"337":1,"456":1}}],["tracking",{"2":{"607":1}}],["trackers",{"2":{"546":1}}],["track",{"2":{"36":1,"108":1,"136":1,"586":1}}],["transform",{"2":{"313":2}}],["transferred",{"2":{"690":1}}],["transferring",{"2":{"34":1,"91":2}}],["transferhermes",{"2":{"687":1}}],["transferownership",{"2":{"305":2}}],["transfers",{"2":{"305":2}}],["transfer",{"0":{"375":1,"690":1},"1":{"691":1},"2":{"34":6,"76":1,"84":1,"250":1,"317":1,"375":7,"489":1,"535":1,"680":1,"682":4,"687":7,"688":4,"690":6,"691":1}}],["transcript15",{"2":{"223":4}}],["transcript14",{"2":{"223":4}}],["transcript13",{"2":{"223":4}}],["transcript12",{"2":{"223":4}}],["transcript11",{"2":{"223":4}}],["transcript06",{"2":{"223":4}}],["transcript05",{"2":{"223":4}}],["transcript04",{"2":{"223":4}}],["transact",{"2":{"287":1,"491":1}}],["transactopts",{"2":{"172":2}}],["transactionindex",{"2":{"121":2,"285":2,"385":2}}],["transactionhash",{"2":{"121":2,"285":2}}],["transactions",{"0":{"421":1,"477":1,"632":1},"2":{"33":2,"34":2,"66":1,"69":2,"71":1,"72":1,"79":1,"85":2,"86":1,"90":1,"136":1,"139":1,"143":1,"146":1,"159":1,"237":1,"247":1,"260":3,"261":2,"264":1,"287":1,"293":3,"295":1,"308":1,"309":1,"310":1,"330":1,"331":1,"350":1,"355":1,"356":1,"384":3,"394":1,"414":2,"415":2,"416":2,"421":1,"426":4,"428":3,"429":1,"430":2,"433":1,"434":1,"436":1,"443":1,"449":1,"450":1,"451":1,"455":1,"456":6,"457":1,"458":6,"459":2,"477":2,"478":2,"496":1,"502":1,"513":1,"526":1,"527":1,"530":2,"550":1,"632":1,"646":5,"647":1,"673":3,"713":1,"714":1,"718":1,"734":1,"746":1,"747":1,"749":1,"791":1}}],["transaction",{"0":{"154":1,"155":2,"158":1,"208":1,"384":1,"385":1,"428":1,"458":1,"630":1,"646":1,"702":1,"791":1},"1":{"156":2,"157":2,"159":1,"429":1,"430":1,"459":1},"2":{"33":1,"34":2,"69":4,"71":3,"72":3,"83":3,"84":3,"85":4,"91":14,"120":2,"136":1,"139":1,"146":3,"153":8,"154":4,"155":3,"156":3,"157":2,"158":1,"159":4,"164":1,"165":1,"170":2,"172":4,"173":1,"176":1,"181":2,"184":1,"189":2,"200":1,"208":13,"211":3,"213":2,"261":2,"264":2,"265":1,"284":2,"287":1,"289":1,"293":3,"294":1,"297":1,"299":2,"363":3,"365":3,"366":1,"375":1,"380":1,"384":4,"385":2,"414":1,"415":5,"417":2,"418":3,"419":10,"420":1,"421":8,"426":14,"429":2,"436":2,"437":3,"438":1,"442":3,"443":3,"444":2,"445":2,"447":2,"448":2,"449":1,"456":1,"458":3,"465":1,"466":1,"469":2,"470":1,"475":1,"477":4,"478":2,"548":1,"549":4,"553":1,"564":3,"571":1,"573":2,"629":1,"632":1,"702":1,"724":4,"789":3,"791":1}}],["transitions",{"2":{"139":1,"188":1,"196":1,"200":1,"203":1,"456":1}}],["transition",{"2":{"19":1,"172":4,"188":2,"192":1}}],["translations",{"2":{"17":2}}],["tee",{"2":{"774":2,"776":2,"777":2,"778":2}}],["territories",{"2":{"720":1}}],["terminal",{"2":{"75":2,"76":2,"211":1,"317":4,"380":1,"396":1,"582":2,"610":2,"676":1,"712":1}}],["termination",{"2":{"34":1}}],["term",{"2":{"34":1,"484":1}}],["terms",{"0":{"30":1,"31":1},"1":{"31":1,"32":1,"33":1,"34":1},"2":{"14":1,"15":1,"30":15,"31":1,"33":2,"34":7,"474":1}}],["teach",{"2":{"357":1}}],["team",{"2":{"27":1,"36":1,"41":1,"43":1,"45":1,"52":1,"79":1,"91":1,"179":1,"200":1,"203":1,"206":1,"226":1,"227":1,"520":1,"677":1,"678":1}}],["text|json",{"2":{"573":2}}],["text$request",{"2":{"356":1,"515":1,"579":1,"751":1}}],["textarea",{"2":{"313":2}}],["textalign",{"2":{"313":4}}],["text",{"2":{"313":2,"363":2,"365":1,"536":1,"537":1,"573":2,"704":1}}],["testtia",{"2":{"700":1}}],["testkey",{"2":{"699":1}}],["test3",{"2":{"549":4}}],["test2sig",{"2":{"549":4}}],["test2",{"2":{"549":8}}],["test1sig",{"2":{"549":4}}],["test1",{"2":{"549":8}}],["testcelestia",{"2":{"531":1,"569":1,"578":1}}],["testcreatepost",{"2":{"305":2}}],["testonlyowner",{"2":{"305":2}}],["testfetchposts",{"2":{"305":2}}],["testforge",{"2":{"117":1,"281":1}}],["testupdatepost",{"2":{"305":2}}],["teststaking",{"2":{"702":1}}],["tests",{"0":{"305":1},"2":{"117":4,"281":4,"306":1}}],["testsetnumber",{"2":{"117":6,"281":6}}],["testincrement",{"2":{"117":6,"281":6}}],["testing",{"0":{"315":1},"2":{"113":1,"117":1,"119":1,"249":1,"281":1,"504":3,"505":1,"678":1,"719":1,"736":1,"760":1}}],["test",{"0":{"117":1,"281":1,"306":1},"2":{"117":14,"120":1,"165":1,"166":1,"168":1,"169":1,"223":4,"246":2,"269":6,"270":6,"271":6,"275":4,"276":4,"281":14,"283":2,"299":2,"305":7,"306":2,"307":1,"308":2,"309":3,"314":1,"315":3,"316":1,"340":1,"356":4,"399":4,"527":3,"528":1,"531":1,"545":1,"549":6,"559":1,"569":1,"573":2,"578":1,"673":3,"674":1,"682":4,"684":1,"692":2,"699":1,"700":1,"702":1,"714":4,"716":1,"740":2,"765":1,"769":1,"771":1}}],["tested",{"2":{"94":1,"307":1,"309":1,"333":1,"387":1}}],["testnetwork",{"2":{"692":1}}],["testnets",{"0":{"762":1},"1":{"763":1,"764":1,"765":1,"766":1},"2":{"30":1,"80":1,"101":1,"265":1,"432":1,"434":1,"678":2,"683":1,"762":1}}],["testnet",{"0":{"30":1,"89":1,"244":1,"277":1,"317":1,"392":1,"492":1,"588":1,"696":1,"715":1,"740":1,"751":1,"765":1,"766":1},"1":{"31":1,"32":1,"33":1,"34":1,"245":1,"246":1,"247":1,"248":1,"249":1,"250":1,"251":1,"252":1,"253":1,"254":1,"278":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"318":1,"319":1,"320":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"705":1,"706":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},"2":{"24":3,"27":1,"30":5,"68":1,"79":2,"80":3,"82":5,"85":5,"88":1,"95":1,"145":1,"242":3,"244":2,"245":5,"246":1,"247":1,"249":3,"250":2,"251":1,"254":1,"275":1,"277":1,"278":1,"286":1,"289":1,"290":1,"293":2,"302":1,"308":1,"312":4,"317":2,"339":4,"340":2,"355":1,"356":2,"382":2,"388":2,"390":1,"392":2,"396":1,"432":2,"434":5,"488":1,"492":4,"504":3,"505":1,"526":1,"527":4,"553":1,"559":1,"567":1,"568":2,"571":1,"575":1,"588":1,"627":1,"673":4,"678":1,"680":2,"682":11,"683":3,"685":1,"686":6,"687":8,"688":3,"692":1,"696":2,"698":1,"701":2,"706":1,"714":1,"715":2,"740":1,"746":6,"747":8,"748":8,"749":8,"751":1,"752":2,"753":8,"754":1,"765":2,"771":1,"786":1}}],["temp",{"2":{"582":1,"610":1}}],["temporarily",{"2":{"551":1}}],["temporary",{"0":{"15":1},"2":{"14":1,"15":1,"287":1,"559":1}}],["template",{"2":{"222":1,"223":2,"387":1}}],["templates",{"2":{"89":1}}],["tendermintrpc",{"2":{"107":1}}],["tendermint",{"2":{"89":3,"145":1,"149":4,"151":1,"152":4,"153":10,"156":1,"159":4,"161":1,"172":22,"218":1,"220":1,"227":1,"330":2,"331":1,"332":1,"334":1,"335":2,"372":4,"426":6,"455":6,"520":1,"530":8,"542":2,"573":2,"641":2,"649":29,"681":2,"687":8,"697":2,"705":2,"789":2,"794":29}}],["tell",{"2":{"48":1}}],["telegram",{"2":{"45":2,"518":1,"547":1,"739":1,"754":1,"767":1}}],["television",{"2":{"34":1}}],["telemetry",{"2":{"33":1,"682":6}}],["tech",{"2":{"42":2,"44":1,"105":1,"728":2,"729":2,"730":2,"731":2,"734":1,"737":1,"746":2,"747":1,"748":1,"749":1,"753":1}}],["technologies",{"2":{"48":1,"59":1,"264":1,"720":1}}],["technology",{"2":{"8":1,"42":1,"394":1}}],["technical",{"2":{"3":1,"27":1,"31":1,"36":1,"48":1}}],["typically",{"2":{"233":1,"501":1}}],["typical",{"2":{"136":1,"261":1,"335":2}}],["type=$node",{"2":{"655":6,"657":6,"658":6}}],["type=full",{"2":{"655":1}}],["type=fullexport",{"2":{"655":1}}],["type=bridge",{"2":{"655":1}}],["type=bridgeexport",{"2":{"655":1}}],["type=1",{"2":{"387":1}}],["type=spanbatch",{"2":{"387":1}}],["type=lightexport",{"2":{"655":1}}],["type=light",{"2":{"275":2,"276":2,"655":1}}],["type=ledger`",{"2":{"211":2}}],["type=private",{"2":{"211":4}}],["type",{"0":{"83":1},"2":{"117":1,"121":2,"134":8,"135":7,"156":4,"165":2,"168":2,"187":1,"211":4,"260":1,"267":1,"269":7,"270":6,"271":6,"275":2,"276":6,"281":1,"285":2,"293":1,"356":4,"360":4,"372":4,"380":2,"386":2,"387":2,"402":3,"404":2,"433":1,"434":1,"437":2,"508":1,"510":2,"513":2,"527":2,"536":4,"561":4,"562":8,"564":2,"565":3,"566":5,"584":2,"586":2,"587":2,"588":2,"589":4,"592":4,"596":2,"597":12,"602":4,"603":2,"604":4,"611":1,"615":1,"655":13,"657":8,"658":8,"664":1,"673":2,"682":12,"714":4,"725":1,"734":2,"740":3,"755":1,"757":1,"758":1}}],["typescargo",{"2":{"407":1}}],["types",{"0":{"635":1},"1":{"636":1,"637":1,"638":1},"2":{"3":1,"42":1,"172":6,"182":1,"192":1,"264":1,"323":4,"354":1,"400":4,"407":2,"408":4,"420":2,"425":4,"426":4,"447":1,"508":1,"510":1,"583":1,"594":1,"596":1,"611":1,"661":1,"725":2,"740":1,"769":1}}],["typography",{"2":{"58":1}}],["typos",{"2":{"2":1}}],["though",{"2":{"456":1,"458":1}}],["thought",{"2":{"134":2}}],["thorough",{"2":{"194":1}}],["those",{"2":{"8":1,"14":1,"15":1,"39":1,"40":1,"46":3,"49":1,"134":1,"135":1,"148":1,"177":1,"208":1,"213":2,"260":2,"261":1,"330":1,"334":1,"383":1,"445":1,"447":1,"450":1,"536":1,"677":1,"678":3,"703":1,"740":1}}],["thus",{"2":{"88":1,"89":1,"107":1,"109":1,"452":1,"456":3,"458":2}}],["thank",{"2":{"44":1,"79":1}}],["thanks",{"2":{"39":1,"106":1}}],["thanking",{"2":{"38":1}}],["than",{"2":{"25":1,"31":1,"34":2,"76":1,"208":1,"235":1,"261":1,"269":1,"293":1,"317":1,"335":1,"337":1,"415":2,"416":1,"445":1,"480":1,"481":1,"484":2,"544":2,"551":1,"571":1,"597":1,"605":1,"724":1}}],["that",{"0":{"153":1,"172":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"196":1,"197":1,"198":1,"199":1,"201":1,"202":1,"440":1},"1":{"189":1,"190":1,"191":1,"193":1,"194":1,"197":1,"198":1,"200":1,"201":1,"202":1},"2":{"7":1,"8":1,"9":2,"19":1,"22":1,"24":4,"30":2,"31":9,"32":3,"33":1,"34":21,"35":1,"36":1,"37":1,"40":2,"41":1,"42":1,"44":1,"48":1,"53":2,"65":3,"76":2,"78":1,"84":3,"85":2,"87":1,"89":6,"91":2,"94":1,"102":2,"103":1,"105":1,"107":3,"108":4,"109":4,"117":3,"126":2,"127":4,"129":2,"130":1,"131":13,"133":2,"134":18,"135":18,"136":4,"137":2,"139":6,"145":3,"146":3,"148":14,"150":1,"153":6,"154":2,"158":1,"163":13,"164":2,"165":1,"166":1,"169":9,"170":2,"172":12,"173":2,"174":3,"175":2,"176":1,"177":7,"178":1,"179":1,"181":1,"183":7,"184":8,"187":6,"188":6,"189":2,"191":1,"192":4,"194":1,"195":1,"196":4,"197":2,"200":3,"203":6,"206":2,"208":1,"211":6,"212":1,"213":3,"214":3,"215":1,"217":1,"218":1,"219":3,"220":1,"221":1,"223":1,"224":7,"225":1,"226":1,"227":1,"228":1,"230":1,"234":1,"237":4,"238":4,"239":1,"243":1,"245":1,"246":1,"247":1,"250":1,"254":1,"255":1,"257":1,"260":2,"261":2,"263":1,"264":3,"265":3,"266":1,"267":1,"269":3,"275":1,"281":3,"284":1,"287":1,"291":3,"293":1,"294":1,"295":2,"296":1,"297":1,"300":3,"302":3,"307":1,"308":1,"309":2,"310":2,"311":1,"312":1,"313":2,"315":2,"316":1,"317":2,"319":1,"324":1,"325":1,"330":1,"332":1,"334":1,"335":4,"336":1,"337":1,"339":1,"340":1,"355":1,"356":1,"358":5,"359":1,"360":1,"365":1,"375":1,"382":1,"384":1,"387":1,"388":1,"390":2,"394":2,"400":2,"401":1,"402":2,"404":1,"409":1,"415":1,"416":1,"417":3,"418":1,"419":5,"421":2,"426":6,"432":5,"433":1,"434":1,"436":4,"438":1,"439":1,"440":8,"441":2,"443":1,"444":1,"445":1,"446":1,"447":6,"448":1,"449":2,"450":3,"451":2,"452":1,"453":6,"455":4,"456":9,"457":4,"458":5,"459":4,"460":1,"469":1,"478":1,"479":5,"480":2,"481":2,"489":1,"497":1,"501":1,"504":2,"512":1,"513":1,"520":1,"526":1,"527":1,"529":1,"536":5,"537":2,"545":5,"548":1,"551":3,"552":2,"554":1,"557":1,"559":2,"565":2,"568":1,"571":1,"573":1,"579":1,"582":1,"583":4,"584":1,"586":1,"590":1,"594":4,"599":1,"602":2,"604":1,"605":2,"606":4,"609":1,"610":1,"611":1,"614":1,"621":1,"627":2,"633":1,"635":1,"639":1,"647":1,"649":1,"650":1,"652":1,"653":2,"656":1,"663":1,"664":1,"665":1,"666":1,"673":2,"675":1,"677":1,"679":1,"680":2,"681":2,"683":3,"685":2,"687":1,"688":1,"703":1,"705":2,"708":1,"712":1,"714":1,"719":1,"720":1,"724":3,"733":1,"734":1,"740":1,"745":1,"746":3,"762":1,"770":1,"771":1,"774":1,"783":1,"788":1,"789":4,"794":1}}],["think",{"2":{"134":1}}],["things",{"0":{"404":1,"448":1},"2":{"34":1,"77":1,"91":2,"312":1,"318":1,"363":1}}],["third",{"2":{"23":4,"31":10,"33":5,"34":1,"289":1,"291":1,"299":1,"328":1,"638":1}}],["this",{"0":{"445":1},"2":{"1":1,"2":2,"4":1,"9":1,"10":1,"12":1,"14":1,"15":1,"17":2,"23":4,"24":1,"27":1,"33":2,"42":2,"43":3,"44":2,"45":1,"46":2,"47":1,"48":7,"49":1,"50":1,"52":1,"53":1,"55":1,"56":2,"57":2,"59":1,"60":2,"61":2,"63":1,"64":1,"65":1,"66":2,"69":1,"76":2,"77":1,"79":4,"81":1,"82":2,"83":4,"84":7,"85":4,"86":2,"88":3,"89":1,"90":2,"91":2,"92":1,"94":3,"102":2,"103":1,"107":3,"108":3,"109":1,"113":1,"115":1,"116":1,"117":3,"126":1,"131":5,"133":4,"134":8,"135":6,"136":3,"137":3,"139":1,"148":4,"149":1,"150":2,"154":1,"156":1,"160":1,"164":3,"165":3,"169":3,"172":4,"174":1,"175":1,"176":1,"178":1,"180":2,"183":5,"184":3,"188":3,"192":2,"195":1,"196":2,"202":1,"208":3,"209":1,"211":2,"213":1,"214":1,"217":2,"222":1,"223":5,"224":5,"226":1,"227":1,"228":1,"230":2,"237":2,"245":1,"249":1,"255":2,"264":1,"265":1,"266":3,"268":1,"269":1,"275":1,"276":3,"277":1,"279":1,"280":1,"281":3,"287":2,"289":1,"293":1,"295":2,"297":2,"300":1,"301":3,"302":1,"305":3,"307":1,"308":1,"313":4,"316":1,"317":2,"318":1,"320":2,"321":1,"322":2,"324":2,"325":2,"326":1,"328":1,"330":1,"332":2,"334":1,"335":1,"337":3,"338":2,"339":1,"340":2,"348":1,"351":1,"354":1,"355":2,"357":1,"358":2,"361":2,"362":2,"363":1,"365":3,"370":1,"371":1,"372":2,"375":1,"378":1,"380":1,"383":1,"384":1,"387":2,"388":1,"390":2,"394":2,"396":5,"399":1,"400":2,"402":1,"405":1,"406":1,"407":2,"409":2,"410":1,"412":1,"415":2,"417":1,"418":3,"419":3,"420":3,"421":4,"426":10,"428":1,"429":1,"431":1,"432":4,"436":1,"437":1,"438":1,"439":1,"440":2,"448":1,"451":2,"452":2,"453":2,"455":1,"456":4,"457":1,"458":2,"459":2,"460":2,"463":1,"478":1,"479":1,"480":2,"481":4,"489":1,"497":1,"502":1,"508":1,"513":1,"514":1,"519":1,"520":2,"527":1,"536":3,"541":2,"545":7,"546":1,"549":4,"551":2,"553":2,"557":2,"559":1,"561":2,"564":1,"568":2,"572":1,"573":5,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"584":2,"585":3,"589":2,"590":2,"592":2,"597":2,"599":3,"600":1,"602":1,"603":1,"605":5,"606":3,"609":4,"610":1,"616":2,"619":2,"622":1,"627":2,"629":1,"631":2,"633":1,"634":3,"636":1,"637":2,"639":1,"641":1,"642":1,"643":2,"644":1,"646":7,"647":3,"649":1,"651":1,"652":1,"653":2,"656":4,"657":1,"661":1,"662":2,"663":2,"665":1,"676":1,"677":1,"680":2,"682":1,"685":2,"687":2,"692":2,"696":1,"698":1,"699":2,"702":1,"703":5,"707":1,"708":1,"710":1,"718":1,"719":1,"720":1,"724":1,"725":1,"734":1,"740":2,"748":1,"751":1,"755":3,"760":1,"768":1,"771":1,"777":1,"779":1,"784":1,"789":2,"794":1}}],["thread",{"2":{"439":1}}],["threatening",{"2":{"9":1}}],["threshold",{"2":{"417":1,"548":1,"549":2,"682":4}}],["three",{"2":{"217":1,"240":1,"366":1,"453":2,"456":1}}],["throughput",{"2":{"230":1,"235":1,"237":1,"451":1,"456":2}}],["throughout",{"2":{"34":1,"52":1,"394":1}}],["through",{"2":{"14":1,"33":1,"34":1,"38":1,"45":1,"72":1,"89":1,"91":2,"211":1,"239":1,"321":1,"339":1,"394":1,"406":1,"418":1,"419":1,"429":1,"490":1,"499":1,"544":1,"545":1,"577":1,"580":1,"597":1,"665":1,"690":1,"707":1,"755":1,"776":1,"777":1,"779":1,"783":1}}],["theta",{"2":{"682":9,"683":2,"685":1,"686":6,"687":8,"688":3}}],["then",{"2":{"68":1,"69":1,"84":1,"85":1,"90":1,"107":1,"108":1,"117":1,"133":2,"134":1,"136":2,"139":1,"148":5,"150":1,"157":1,"160":3,"165":1,"166":1,"171":1,"172":1,"173":1,"177":1,"183":1,"184":1,"188":2,"192":1,"200":3,"203":1,"206":1,"208":2,"211":3,"214":1,"217":1,"219":1,"220":2,"221":1,"223":1,"224":2,"225":1,"239":1,"243":2,"260":1,"271":1,"281":1,"294":1,"299":1,"308":2,"309":1,"313":4,"314":1,"337":2,"339":1,"361":1,"365":1,"375":1,"382":1,"401":1,"402":3,"404":2,"405":1,"415":1,"418":2,"419":1,"420":1,"421":1,"426":2,"433":1,"434":1,"436":1,"450":2,"459":3,"469":1,"474":1,"477":1,"478":1,"533":2,"536":2,"542":3,"545":3,"584":1,"590":2,"597":1,"602":1,"604":1,"618":1,"635":1,"637":1,"639":1,"649":1,"663":2,"679":2,"703":1,"789":1,"794":1}}],["therefore",{"2":{"135":1,"426":2,"436":1,"451":1,"505":1}}],["therefor",{"2":{"34":1}}],["therefrom",{"2":{"34":1}}],["thereof",{"2":{"34":2}}],["thereto",{"2":{"31":1,"34":2}}],["there",{"0":{"447":1},"2":{"23":1,"42":1,"45":1,"50":1,"84":1,"116":1,"117":1,"139":1,"178":1,"192":1,"195":1,"208":1,"213":1,"224":1,"249":1,"261":1,"263":1,"264":1,"280":1,"281":1,"297":1,"320":1,"332":1,"337":1,"341":1,"355":1,"363":1,"413":1,"415":1,"417":1,"440":1,"441":2,"446":1,"447":1,"450":1,"451":1,"456":1,"514":1,"517":1,"536":3,"593":1,"636":1,"680":1,"724":2,"736":1,"737":1,"739":1,"751":1,"753":1,"754":1,"755":1,"767":1}}],["these",{"2":{"12":1,"14":1,"15":1,"30":7,"33":2,"34":9,"35":1,"39":1,"40":1,"41":1,"45":1,"50":1,"85":1,"86":1,"88":1,"89":1,"131":2,"134":1,"135":2,"146":1,"148":1,"151":2,"156":1,"161":1,"165":1,"168":1,"177":1,"178":2,"180":1,"184":2,"191":1,"196":2,"203":1,"217":1,"220":2,"224":1,"227":1,"238":1,"240":1,"261":1,"264":1,"301":2,"320":1,"329":1,"335":1,"359":2,"366":1,"402":1,"413":1,"418":2,"420":1,"450":1,"456":2,"458":2,"481":1,"509":1,"510":1,"512":1,"513":1,"537":1,"545":2,"571":1,"582":1,"584":1,"610":1,"627":1,"637":1,"645":1,"647":1,"661":1,"663":2,"680":1,"696":1,"723":1,"724":1,"726":1,"733":1,"734":2,"744":1,"745":1,"746":1,"789":1}}],["they",{"2":{"8":1,"9":1,"12":1,"23":1,"30":1,"31":2,"34":2,"40":1,"44":4,"45":2,"46":1,"47":1,"65":1,"84":2,"86":1,"139":1,"151":1,"156":1,"161":1,"168":1,"178":1,"187":2,"188":2,"192":2,"225":1,"226":1,"247":1,"260":2,"261":1,"263":1,"265":1,"324":1,"325":1,"333":1,"336":1,"358":1,"400":1,"409":1,"417":1,"419":1,"421":3,"428":1,"430":1,"432":2,"438":2,"440":2,"441":1,"447":1,"448":2,"451":1,"456":1,"481":1,"505":1,"512":1,"513":1,"537":1,"551":3,"677":1,"685":1,"702":1,"703":1,"705":1,"708":2,"733":1,"734":1,"745":1,"746":1,"750":1,"765":1}}],["their",{"2":{"8":1,"28":1,"31":1,"34":1,"36":1,"38":1,"40":2,"42":2,"43":2,"44":6,"45":3,"46":2,"47":2,"48":1,"53":1,"65":1,"84":2,"133":1,"148":1,"173":1,"174":3,"175":1,"182":1,"187":1,"188":1,"211":1,"226":1,"230":1,"244":1,"246":1,"255":1,"263":2,"264":2,"265":3,"297":1,"301":1,"305":2,"312":1,"336":1,"337":1,"342":1,"344":1,"348":1,"351":1,"383":1,"417":1,"421":1,"430":1,"443":1,"447":1,"456":1,"457":2,"479":1,"481":4,"486":1,"497":3,"498":2,"504":1,"505":1,"512":1,"513":1,"545":2,"551":3,"590":1,"596":1,"632":1,"637":1,"677":1,"678":2,"701":1,"703":3,"733":1,"734":1,"740":2,"745":1,"746":1,"765":1}}],["theme",{"2":{"43":2}}],["them",{"2":{"2":1,"34":1,"38":1,"40":1,"44":4,"45":1,"46":3,"47":3,"102":1,"107":1,"130":1,"148":1,"165":3,"168":1,"173":1,"177":1,"181":1,"191":2,"212":2,"217":1,"220":2,"224":1,"226":1,"243":1,"261":1,"305":2,"337":2,"346":1,"351":1,"400":1,"449":1,"483":1,"508":1,"551":1,"594":1,"602":1,"607":1,"637":1,"702":1,"703":1,"725":1,"740":1,"746":1}}],["the",{"0":{"1":1,"18":1,"19":1,"36":1,"37":1,"38":1,"76":1,"77":1,"78":1,"87":1,"88":1,"130":1,"139":1,"146":1,"147":1,"148":1,"155":1,"158":1,"163":2,"170":1,"172":1,"208":2,"210":1,"212":1,"213":2,"217":1,"218":1,"222":1,"223":1,"224":1,"227":1,"245":1,"267":1,"300":1,"305":1,"306":1,"307":1,"309":1,"310":1,"312":1,"318":1,"319":1,"337":1,"366":1,"369":1,"385":1,"386":1,"398":1,"413":1,"421":1,"423":1,"424":1,"425":1,"426":1,"437":1,"440":1,"443":1,"444":1,"458":1,"473":1,"523":1,"524":1,"526":1,"527":1,"528":1,"529":1,"540":1,"555":1,"556":1,"557":1,"558":2,"565":1,"566":1,"567":2,"595":1,"603":1,"604":2,"625":1,"627":1,"639":1,"645":1,"657":1,"658":1,"669":1,"671":1,"672":1,"673":1,"674":1,"675":1,"676":1,"689":1,"702":1,"703":1,"706":1,"712":1,"713":1,"716":1,"759":1,"774":1,"784":1,"786":1,"787":1,"788":1,"789":1},"1":{"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"29":1,"147":1,"148":1,"156":1,"157":1,"159":1,"164":2,"165":2,"166":2,"167":2,"168":2,"169":2,"170":2,"171":2,"172":2,"211":1,"212":1,"213":1,"214":3,"215":3,"216":3,"217":1,"218":2,"219":2,"220":1,"221":1,"223":1,"224":1,"268":1,"269":1,"270":1,"271":1,"272":1,"311":1,"338":1,"399":1,"400":1,"401":1,"402":1,"403":1,"404":1,"459":1,"525":1,"526":1,"527":1,"528":2,"529":1,"556":1,"557":1,"558":1,"559":1,"596":1,"597":1,"598":1,"599":1,"600":1,"601":1,"672":1,"673":1,"714":1,"715":1,"716":1,"717":1,"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1,"785":1,"786":1,"787":1,"788":2},"2":{"0":2,"1":2,"2":3,"3":2,"4":2,"5":4,"8":4,"9":1,"10":1,"11":3,"12":1,"13":4,"14":2,"15":3,"16":1,"17":2,"19":5,"21":7,"22":3,"23":9,"24":17,"25":4,"26":3,"27":12,"28":3,"29":2,"30":24,"31":25,"32":7,"33":15,"34":105,"35":1,"36":8,"37":4,"38":6,"39":2,"40":12,"41":4,"42":13,"43":15,"44":14,"45":9,"46":8,"47":7,"48":15,"49":2,"50":5,"52":5,"53":5,"54":2,"55":1,"56":2,"57":3,"59":4,"60":3,"61":3,"62":4,"63":1,"64":2,"65":15,"68":5,"69":7,"71":9,"72":6,"73":1,"75":12,"76":9,"77":7,"79":8,"82":6,"83":6,"84":40,"85":13,"86":7,"87":6,"88":12,"89":31,"90":2,"91":46,"92":3,"94":8,"95":5,"102":10,"103":2,"105":5,"106":3,"107":31,"108":18,"109":5,"110":14,"111":1,"113":3,"115":2,"116":10,"117":27,"119":3,"120":4,"121":7,"125":1,"126":6,"127":7,"128":2,"129":4,"130":4,"131":34,"133":2,"134":54,"135":37,"136":25,"137":17,"139":34,"141":1,"142":2,"143":4,"145":11,"146":15,"148":29,"149":9,"150":8,"151":6,"152":2,"153":38,"154":10,"155":2,"156":10,"157":2,"158":5,"159":12,"160":9,"161":8,"162":6,"163":58,"164":9,"165":46,"166":12,"167":5,"168":24,"169":58,"170":20,"171":5,"172":58,"173":6,"174":3,"175":4,"176":4,"177":23,"178":15,"179":6,"180":8,"181":23,"182":3,"183":30,"184":47,"185":1,"187":4,"188":12,"189":6,"191":3,"192":23,"193":2,"194":5,"195":10,"196":29,"197":3,"199":2,"200":28,"202":1,"203":24,"205":1,"206":8,"208":31,"209":1,"210":4,"211":75,"212":23,"213":25,"214":9,"215":5,"217":16,"218":3,"219":51,"220":58,"221":6,"222":6,"223":24,"224":37,"225":9,"226":3,"227":13,"228":9,"230":11,"233":1,"234":4,"235":3,"236":3,"237":15,"238":17,"239":9,"240":2,"241":2,"242":3,"243":9,"244":1,"245":8,"247":4,"249":4,"250":2,"251":2,"252":1,"253":2,"254":1,"255":3,"261":4,"263":6,"264":5,"265":6,"266":3,"267":4,"268":4,"269":13,"270":1,"271":1,"274":1,"275":13,"276":11,"277":1,"278":2,"279":2,"280":10,"281":27,"283":3,"284":4,"285":7,"286":1,"287":6,"289":4,"290":2,"291":9,"292":8,"293":10,"294":9,"295":9,"296":2,"297":8,"299":4,"300":5,"301":2,"302":1,"305":29,"307":3,"308":10,"309":21,"310":9,"311":6,"312":4,"313":29,"314":3,"315":14,"317":23,"318":7,"321":2,"322":5,"323":23,"324":2,"325":14,"326":15,"327":2,"328":1,"330":5,"331":2,"332":7,"333":2,"334":2,"335":5,"336":1,"337":15,"338":1,"339":1,"340":3,"341":5,"342":6,"343":1,"344":4,"345":3,"346":5,"347":1,"348":2,"350":1,"351":5,"352":1,"354":2,"355":11,"356":16,"357":2,"358":18,"359":10,"360":8,"361":6,"362":4,"363":21,"364":1,"365":19,"366":13,"368":4,"369":6,"370":3,"372":4,"375":4,"376":1,"377":4,"378":4,"380":8,"381":1,"382":2,"384":2,"385":8,"386":2,"387":1,"388":2,"390":5,"391":1,"392":3,"394":7,"395":1,"396":11,"397":2,"399":2,"400":14,"401":15,"402":53,"403":6,"404":21,"405":4,"406":1,"407":5,"408":19,"409":12,"410":9,"411":2,"412":2,"413":10,"415":5,"416":1,"417":10,"418":26,"419":43,"420":6,"421":13,"424":1,"425":15,"426":48,"427":3,"428":2,"429":1,"430":1,"432":19,"433":3,"434":3,"436":14,"437":9,"438":2,"439":2,"440":4,"441":7,"442":2,"443":3,"445":5,"446":6,"448":2,"449":4,"450":18,"451":9,"452":17,"453":32,"455":26,"456":24,"457":10,"458":47,"459":32,"460":3,"463":1,"464":2,"465":2,"466":2,"468":1,"469":4,"470":2,"473":2,"474":1,"477":16,"478":3,"479":4,"480":6,"481":10,"483":3,"484":9,"486":1,"488":3,"489":10,"490":2,"491":2,"492":2,"494":1,"496":2,"497":2,"498":1,"499":2,"501":1,"502":2,"503":1,"504":2,"505":3,"508":5,"510":2,"512":1,"513":7,"515":2,"516":1,"518":2,"519":3,"520":13,"521":2,"522":1,"523":2,"525":3,"526":13,"527":9,"528":5,"529":3,"530":10,"531":3,"533":6,"536":22,"537":9,"538":1,"539":2,"540":1,"541":3,"542":3,"543":1,"544":7,"545":26,"546":4,"547":5,"548":3,"549":14,"551":20,"552":2,"553":2,"554":1,"556":2,"557":10,"558":1,"559":5,"561":4,"563":5,"564":15,"565":4,"566":3,"567":7,"568":3,"569":3,"570":1,"571":7,"572":4,"573":8,"574":1,"575":1,"578":3,"579":9,"581":16,"582":10,"583":6,"584":2,"585":2,"586":6,"589":5,"590":11,"592":3,"593":2,"594":8,"596":8,"597":4,"599":5,"600":3,"601":2,"602":4,"603":1,"604":8,"605":12,"606":13,"607":3,"609":15,"610":9,"611":2,"612":3,"615":2,"616":3,"618":5,"619":3,"621":5,"622":2,"623":1,"624":1,"625":1,"626":1,"627":9,"629":1,"631":1,"632":1,"633":3,"634":5,"635":5,"636":6,"637":10,"638":5,"639":7,"642":1,"643":5,"644":3,"645":1,"646":6,"647":10,"649":9,"650":1,"651":2,"652":1,"653":8,"655":9,"656":7,"657":9,"658":2,"661":3,"663":5,"664":4,"665":1,"666":2,"667":2,"668":1,"669":1,"670":1,"672":1,"673":17,"674":5,"675":2,"676":4,"677":7,"678":8,"679":13,"680":5,"681":3,"682":5,"683":4,"684":5,"685":2,"686":2,"687":3,"688":2,"689":1,"690":5,"691":3,"692":1,"694":1,"695":1,"697":2,"698":5,"699":4,"700":2,"701":6,"702":6,"703":10,"704":4,"705":6,"706":3,"708":3,"709":1,"710":1,"711":1,"712":4,"713":7,"714":10,"715":3,"716":5,"717":2,"719":6,"720":2,"723":2,"724":17,"725":6,"726":1,"728":1,"733":1,"734":6,"735":2,"736":1,"738":1,"739":2,"740":10,"744":1,"745":1,"746":3,"747":4,"748":5,"749":3,"750":2,"751":2,"752":1,"754":2,"755":6,"758":1,"760":3,"763":1,"765":2,"767":2,"768":1,"769":1,"770":3,"771":4,"773":1,"774":1,"776":2,"777":4,"778":5,"779":1,"780":1,"781":2,"782":1,"783":10,"784":3,"785":1,"786":6,"787":1,"788":3,"789":17,"790":1,"791":1,"792":2,"794":9}}],["tomlvim",{"2":{"682":1}}],["tomldiscard",{"2":{"647":1}}],["tomlexternal",{"2":{"644":1}}],["tomlsed",{"2":{"643":1}}],["tomlseeds=$",{"2":{"627":2}}],["tomlrpc",{"2":{"637":1}}],["tomlpruning",{"2":{"633":1,"634":1}}],["tomlpersistent",{"2":{"627":3}}],["tomlmin",{"2":{"631":1}}],["tomlindexer",{"2":{"630":1,"632":1,"646":1}}],["toml`",{"2":{"627":2}}],["toml",{"0":{"573":1,"613":1,"615":1},"1":{"614":1,"615":1,"616":2,"617":2,"618":2,"619":2,"620":2,"621":2},"2":{"392":2,"544":1,"545":1,"573":8,"606":3,"615":4,"627":7,"629":1,"631":1,"632":1,"633":1,"634":2,"637":2,"643":2,"644":1,"646":2,"647":2,"682":3,"684":1,"688":1,"704":1,"791":1}}],["tombstoned",{"2":{"25":1}}],["todo",{"2":{"325":2,"400":2,"401":3,"402":3,"404":1,"426":6}}],["today",{"2":{"242":1,"302":1,"541":2}}],["toggleview",{"2":{"313":6}}],["together",{"2":{"52":1,"336":1,"450":1,"456":1,"458":1,"459":1,"545":1}}],["tostring",{"2":{"313":4}}],["tosliceofbytes",{"2":{"159":2}}],["toattestationproof",{"2":{"169":2,"172":4}}],["torowproofs",{"2":{"168":2,"172":4}}],["torowroots",{"2":{"167":2,"172":4}}],["tonamespacenode",{"2":{"165":4,"167":2,"172":6}}],["tonamespacemerklemultiproofs",{"2":{"165":2,"172":4}}],["token=$",{"2":{"360":4,"362":2,"380":2}}],["tokencelestia",{"2":{"358":1}}],["tokenbridgeretryablesender",{"2":{"96":1,"97":1}}],["tokenbridgecreator",{"2":{"96":1,"97":1}}],["tokenbridgedeployment",{"2":{"91":2}}],["token",{"0":{"360":1,"362":1,"501":1,"535":1,"691":1},"2":{"80":1,"82":2,"84":8,"86":1,"89":8,"91":13,"93":1,"322":4,"323":4,"324":4,"325":4,"326":4,"358":7,"359":9,"360":6,"361":3,"362":2,"363":4,"368":1,"380":3,"386":2,"401":2,"402":2,"404":2,"407":4,"408":4,"409":4,"410":4,"425":4,"460":1,"497":3,"535":1,"537":1,"596":1,"690":1,"691":3}}],["tokens",{"0":{"465":1,"474":1,"539":1,"715":1},"2":{"8":1,"30":2,"33":1,"43":1,"80":1,"84":1,"85":1,"356":2,"375":1,"382":2,"396":2,"460":1,"465":1,"466":1,"470":1,"473":1,"475":1,"488":1,"489":6,"514":2,"515":1,"527":3,"535":1,"539":2,"564":1,"579":2,"673":3,"680":1,"683":2,"691":1,"714":1,"715":1,"751":3,"783":1,"789":1}}],["touch",{"2":{"65":1}}],["too",{"0":{"605":1},"2":{"605":3,"702":2}}],["tools",{"2":{"337":1}}],["toolset",{"2":{"213":1}}],["toolkit",{"0":{"57":1},"1":{"58":1,"59":1,"60":1,"61":1,"62":1,"63":1},"2":{"56":1,"57":1}}],["tool",{"2":{"31":1,"55":1,"213":1,"310":1,"530":2,"543":1,"647":1,"679":1}}],["toolings",{"2":{"590":1}}],["tooling",{"2":{"24":1,"175":1,"177":1,"193":1}}],["took",{"2":{"31":1}}],["topology",{"2":{"637":1}}],["topic",{"2":{"36":1,"42":1,"43":1,"445":1,"536":1}}],["topics",{"2":{"2":1,"36":1,"43":2,"48":2,"240":1}}],["top",{"2":{"24":2,"65":1,"68":1,"342":1,"433":1,"434":1,"455":1,"456":1,"468":1,"557":1,"728":1,"729":1,"730":1,"737":1,"753":1}}],["totaldifficulty",{"2":{"384":2}}],["total",{"2":{"21":1,"22":1,"76":1,"151":2,"153":2,"156":2,"161":2,"168":3,"169":2,"172":4,"183":1,"317":1,"372":4,"415":2,"417":1,"418":2,"419":6,"484":1,"488":1,"494":1,"567":4,"724":5}}],["towards",{"2":{"19":1,"25":1,"44":1,"551":1}}],["toward",{"2":{"8":1,"16":1}}],["to",{"0":{"59":1,"67":1,"69":1,"71":1,"104":1,"112":1,"136":1,"142":1,"143":1,"153":1,"163":1,"174":1,"208":1,"229":1,"240":1,"276":1,"309":1,"314":1,"324":1,"325":1,"335":1,"336":1,"355":1,"375":1,"391":1,"392":1,"409":1,"414":1,"426":1,"427":1,"432":1,"433":1,"434":1,"448":1,"460":1,"541":1,"553":1,"604":1,"629":1,"650":1,"755":1,"783":1},"1":{"68":1,"69":1,"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":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,"200":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"241":1,"242":1,"243":1,"337":1,"338":1,"339":1,"340":1,"415":1,"416":1,"417":1,"418":1,"419":1,"420":1,"421":1,"422":1,"423":1,"424":1,"425":1,"426":1,"427":1,"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"467":1,"468":1,"469":1,"470":1,"471":1,"472":1,"473":1,"474":1,"475":1,"554":1,"555":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,"572":1,"573":1,"574":1,"575":1,"630":1,"631":1,"651":1,"652":1,"756":1,"757":1,"758":1},"2":{"0":2,"1":1,"2":4,"5":2,"7":3,"8":3,"9":3,"11":2,"14":1,"15":1,"17":1,"19":5,"21":5,"22":1,"23":1,"24":7,"25":3,"26":4,"27":5,"28":1,"30":9,"31":20,"32":5,"33":12,"34":51,"35":3,"36":7,"37":1,"38":3,"39":2,"40":7,"41":4,"42":8,"43":14,"44":14,"45":10,"46":7,"47":14,"48":13,"49":1,"50":3,"52":4,"53":4,"54":2,"55":2,"56":2,"57":4,"59":2,"60":1,"61":1,"62":2,"63":1,"64":1,"65":6,"66":1,"69":3,"71":7,"72":3,"73":1,"74":1,"76":7,"77":2,"79":3,"82":5,"83":7,"84":19,"85":10,"86":5,"88":15,"89":21,"90":2,"91":21,"92":1,"94":1,"95":1,"102":2,"103":3,"105":2,"106":1,"107":15,"108":6,"109":4,"110":8,"111":1,"113":3,"116":3,"117":4,"119":1,"120":5,"121":4,"122":4,"125":1,"127":6,"128":2,"129":1,"130":4,"131":21,"133":8,"134":23,"135":21,"136":8,"137":8,"139":13,"142":2,"143":1,"145":8,"146":5,"148":17,"149":5,"150":8,"151":4,"153":14,"154":5,"156":5,"160":8,"161":3,"163":27,"164":3,"165":12,"166":4,"168":7,"169":19,"170":8,"172":20,"173":3,"174":4,"175":1,"177":24,"178":6,"179":3,"180":4,"181":5,"183":10,"184":18,"187":6,"188":6,"189":5,"191":2,"192":14,"193":1,"194":2,"195":3,"196":8,"197":1,"199":5,"200":5,"202":3,"203":8,"208":8,"209":2,"210":4,"211":44,"212":9,"213":11,"214":3,"215":4,"217":7,"219":14,"220":17,"221":3,"222":3,"223":7,"224":9,"225":5,"226":5,"227":1,"228":2,"230":5,"233":1,"234":1,"235":4,"236":2,"237":15,"238":3,"239":3,"241":1,"242":1,"243":5,"244":2,"245":2,"246":2,"247":2,"249":3,"250":1,"251":2,"252":2,"253":1,"255":2,"257":1,"260":3,"261":5,"263":6,"264":6,"265":4,"266":1,"267":1,"268":1,"269":6,"271":1,"274":1,"275":7,"276":4,"277":1,"280":3,"281":4,"283":2,"284":5,"285":4,"286":3,"287":7,"289":3,"290":1,"291":4,"292":4,"293":5,"294":4,"295":1,"296":1,"297":2,"298":1,"299":2,"300":1,"301":7,"303":3,"304":1,"305":5,"306":1,"307":3,"308":3,"309":12,"310":1,"311":1,"312":6,"313":15,"314":2,"315":11,"316":1,"317":9,"318":2,"320":1,"322":7,"323":7,"324":5,"325":7,"326":2,"327":1,"329":2,"330":3,"332":2,"333":1,"335":3,"336":4,"337":9,"339":1,"340":1,"342":2,"344":3,"345":1,"346":4,"348":2,"350":2,"351":3,"355":9,"356":8,"357":2,"358":10,"359":3,"360":5,"361":6,"362":1,"363":8,"364":1,"365":9,"366":4,"368":1,"370":1,"371":1,"375":1,"376":1,"377":2,"378":2,"380":4,"381":2,"382":1,"385":5,"386":1,"387":1,"388":3,"390":7,"391":2,"392":7,"394":7,"395":1,"396":5,"397":3,"399":1,"400":2,"401":6,"402":25,"403":3,"404":12,"405":8,"407":7,"408":7,"409":3,"410":4,"411":1,"412":1,"413":7,"414":2,"415":3,"417":3,"418":4,"419":9,"421":8,"425":7,"426":26,"430":2,"431":4,"432":14,"433":4,"434":3,"436":7,"437":3,"438":4,"439":2,"440":3,"441":7,"442":1,"443":5,"446":7,"447":4,"449":7,"450":4,"451":3,"452":6,"453":6,"455":9,"456":8,"457":8,"458":11,"459":8,"460":2,"463":1,"468":2,"469":1,"472":1,"474":1,"475":1,"477":6,"479":2,"480":3,"481":18,"483":3,"484":4,"486":3,"487":3,"488":2,"489":8,"490":2,"491":1,"492":1,"496":1,"497":5,"498":2,"499":1,"505":3,"508":9,"509":1,"510":2,"512":3,"513":6,"514":1,"518":1,"519":1,"520":5,"525":1,"526":7,"527":7,"528":1,"530":6,"533":4,"534":1,"535":6,"536":12,"537":10,"539":2,"543":2,"544":6,"545":23,"546":3,"547":4,"548":2,"549":8,"550":2,"551":10,"552":1,"553":3,"554":1,"557":1,"558":1,"559":3,"560":1,"561":2,"563":3,"564":8,"565":1,"567":1,"568":2,"569":3,"570":1,"571":6,"572":2,"573":3,"574":1,"575":2,"577":1,"578":2,"579":6,"581":5,"582":4,"583":6,"584":1,"586":4,"589":10,"590":6,"592":4,"593":2,"594":6,"596":2,"597":3,"599":2,"600":1,"601":3,"602":3,"604":4,"605":6,"606":5,"607":1,"609":1,"610":4,"611":2,"612":2,"616":1,"618":4,"619":3,"621":1,"622":2,"627":9,"629":2,"632":2,"633":2,"634":3,"635":2,"636":2,"637":4,"638":1,"639":4,"642":2,"643":3,"644":2,"645":1,"646":12,"647":9,"649":6,"650":1,"651":3,"652":1,"653":10,"655":5,"656":9,"657":6,"658":2,"661":3,"662":1,"663":1,"664":4,"665":1,"666":1,"673":14,"674":1,"675":1,"676":2,"677":5,"678":6,"679":10,"680":3,"681":2,"682":2,"683":7,"684":1,"685":2,"686":2,"687":4,"688":1,"690":2,"691":4,"692":4,"693":1,"694":1,"695":1,"696":2,"699":1,"701":3,"702":1,"703":4,"704":6,"705":2,"706":3,"707":1,"708":1,"713":6,"714":2,"715":2,"716":1,"719":2,"720":2,"723":1,"724":2,"725":10,"726":1,"733":3,"734":7,"735":1,"739":2,"740":21,"744":1,"745":3,"746":4,"747":2,"748":2,"749":3,"750":1,"751":1,"754":2,"755":3,"758":1,"760":1,"763":3,"765":3,"767":2,"768":2,"769":4,"770":2,"771":9,"773":1,"774":2,"776":1,"777":1,"778":1,"779":1,"783":7,"784":4,"786":4,"789":13,"790":1,"791":3,"792":1,"794":6}}]],"serializationVersion":2}';export{e as default}; diff --git a/pr-1680/assets/chunks/@localSearchIndexroot.f0900312.js b/pr-1680/assets/chunks/@localSearchIndexroot.f0900312.js new file mode 100644 index 0000000000..3edf40f18a --- /dev/null +++ b/pr-1680/assets/chunks/@localSearchIndexroot.f0900312.js @@ -0,0 +1 @@ +const e='{"documentCount":809,"nextId":809,"documentIds":{"0":"/docs-preview/pr-1680/README#celestia-documentation-site","1":"/docs-preview/pr-1680/README#building-the-site","2":"/docs-preview/pr-1680/README#contribution-guidelines","3":"/docs-preview/pr-1680/README#directory-structure","4":"/docs-preview/pr-1680/README#feedback-suggestions","5":"/docs-preview/pr-1680/community/calendar#community-calendar","6":"/docs-preview/pr-1680/community/coc#celestia-org-code-of-conduct","7":"/docs-preview/pr-1680/community/coc#our-pledge","8":"/docs-preview/pr-1680/community/coc#our-standards","9":"/docs-preview/pr-1680/community/coc#enforcement-responsibilities","10":"/docs-preview/pr-1680/community/coc#scope","11":"/docs-preview/pr-1680/community/coc#enforcement","12":"/docs-preview/pr-1680/community/coc#enforcement-guidelines","13":"/docs-preview/pr-1680/community/coc#_1-correction","14":"/docs-preview/pr-1680/community/coc#_2-warning","15":"/docs-preview/pr-1680/community/coc#_3-temporary-ban","16":"/docs-preview/pr-1680/community/coc#_4-permanent-ban","17":"/docs-preview/pr-1680/community/coc#attribution","18":"/docs-preview/pr-1680/community/foundation-delegation-program#the-celestia-foundation-delegation-program","19":"/docs-preview/pr-1680/community/foundation-delegation-program#objectives-of-the-program","20":"/docs-preview/pr-1680/community/foundation-delegation-program#foundation-delegation-process","21":"/docs-preview/pr-1680/community/foundation-delegation-program#program-launch","22":"/docs-preview/pr-1680/community/foundation-delegation-program#cohort-process","23":"/docs-preview/pr-1680/community/foundation-delegation-program#key-points","24":"/docs-preview/pr-1680/community/foundation-delegation-program#eligibility-criteria","25":"/docs-preview/pr-1680/community/foundation-delegation-program#undelegation-criteria","26":"/docs-preview/pr-1680/community/foundation-delegation-program#application","27":"/docs-preview/pr-1680/community/foundation-delegation-program#application-details","28":"/docs-preview/pr-1680/community/foundation-delegation-program#cohort-information","29":"/docs-preview/pr-1680/community/foundation-delegation-program#feedback-process","30":"/docs-preview/pr-1680/community/itn-tos#supplemental-incentivized-testnet-terms","31":"/docs-preview/pr-1680/community/itn-tos#_1-general-terms","32":"/docs-preview/pr-1680/community/itn-tos#_2-taxes","33":"/docs-preview/pr-1680/community/itn-tos#_3-supplemental-privacy-information","34":"/docs-preview/pr-1680/community/itn-tos#_4-certain-additional-representations","35":"/docs-preview/pr-1680/community/modular-meetup-guide#modular-meetup-guide","36":"/docs-preview/pr-1680/community/modular-meetup-guide#before-the-meetup","37":"/docs-preview/pr-1680/community/modular-meetup-guide#during-the-meetup","38":"/docs-preview/pr-1680/community/modular-meetup-guide#after-the-meetup","39":"/docs-preview/pr-1680/community/modular-meetup-guide#logistics-and-guidance","40":"/docs-preview/pr-1680/community/modular-meetup-guide#venue","41":"/docs-preview/pr-1680/community/modular-meetup-guide#catering-and-refreshments","42":"/docs-preview/pr-1680/community/modular-meetup-guide#audience","43":"/docs-preview/pr-1680/community/modular-meetup-guide#speakers","44":"/docs-preview/pr-1680/community/modular-meetup-guide#sponsors","45":"/docs-preview/pr-1680/community/modular-meetup-guide#communications-and-marketing","46":"/docs-preview/pr-1680/community/modular-meetup-guide#recording","47":"/docs-preview/pr-1680/community/modular-meetup-guide#utilizing-meetup-com-platform","48":"/docs-preview/pr-1680/community/modular-meetup-guide#onboarding-questions-for-community-members-joining-a-modular-meetup","49":"/docs-preview/pr-1680/community/modular-meetup-intro#celestia-modular-meetup-program","50":"/docs-preview/pr-1680/community/modular-meetup-intro#program-description","51":"/docs-preview/pr-1680/community/modular-meetup-intro#important-info","52":"/docs-preview/pr-1680/community/modular-meetup-intro#celestia-org-community-code-of-conduct","53":"/docs-preview/pr-1680/community/modular-meetup-intro#signup-form","54":"/docs-preview/pr-1680/community/modular-meetup-intro#emails","55":"/docs-preview/pr-1680/community/modular-meetup-intro#discord","56":"/docs-preview/pr-1680/community/modular-meetup-intro#materials","57":"/docs-preview/pr-1680/community/modular-meetup-toolkit#modular-meetup-toolkit","58":"/docs-preview/pr-1680/community/modular-meetup-toolkit#celestia-branding-guidelines","59":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-introduction-to-modularity-workshop-presentation","60":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-run-a-celestia-light-node-workshop-presentation","61":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-deploy-a-sovereign-rollup-workshop-presentation","62":"/docs-preview/pr-1680/community/modular-meetup-toolkit#sample-modular-meetup-introduction-workshop-presentation","63":"/docs-preview/pr-1680/community/modular-meetup-toolkit#swag-logistics","64":"/docs-preview/pr-1680/community/overview#community-overview","65":"/docs-preview/pr-1680/community/speaker-list#speaker-list","66":"/docs-preview/pr-1680/developers/arbitrum-bridge#bridging-in-and-out-of-your-orbit-rollup","67":"/docs-preview/pr-1680/developers/arbitrum-bridge#bridge-in-deposit-to-your-rollup","68":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-1-add-your-custom-chain-config","69":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-2-deposit-to-your-orbit-rollup","70":"/docs-preview/pr-1680/developers/arbitrum-bridge#bridge-out-withdrawal-from-your-rollup","71":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-1-choose-an-amount-to-withdraw-from-your-rollup","72":"/docs-preview/pr-1680/developers/arbitrum-bridge#step-2-claim-your-withdrawal","73":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#deploy-a-dapp-on-your-arbitrum-rollup-devnet","74":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#dependencies","75":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#setup-and-contract-deployment","76":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#interact-with-the-contract","77":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#update-the-frontend","78":"/docs-preview/pr-1680/developers/arbitrum-dapp-deploy#interact-with-the-frontend","79":"/docs-preview/pr-1680/developers/arbitrum-deploy#quickstart-deploy-an-arbitrum-orbit-rollup","80":"/docs-preview/pr-1680/developers/arbitrum-deploy#prerequisites","81":"/docs-preview/pr-1680/developers/arbitrum-deploy#setup","82":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-1-acquire-arbitrum-sepolia-eth","83":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-2-pick-your-deployment-type","84":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-3-configure-your-orbit-chain-s-deployment","85":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-3-review-deploy-your-orbit-chain","86":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-4-download-your-chain-s-configuration-files-and-launch-your-chain","87":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-5-clone-the-setup-script-repository-and-add-your-configuration-files","88":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-6-pick-an-l2-rpc-url-for-the-batch-poster","89":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-7-run-your-light-node-for-mocha-testnet","90":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-8-run-your-chain-s-node-and-block-explorer","91":"/docs-preview/pr-1680/developers/arbitrum-deploy#step-9-finish-setting-up-your-chain","92":"/docs-preview/pr-1680/developers/arbitrum-deploy#congratulations-with-celestia-underneath","93":"/docs-preview/pr-1680/developers/arbitrum-deploy#appendix","94":"/docs-preview/pr-1680/developers/arbitrum-deploy#compatibility-matrix","95":"/docs-preview/pr-1680/developers/arbitrum-deploy#blobstream-x-contract-deployments","96":"/docs-preview/pr-1680/developers/arbitrum-deploy#arbitrum-sepolia","97":"/docs-preview/pr-1680/developers/arbitrum-deploy#base-sepolia","98":"/docs-preview/pr-1680/developers/arbitrum-deploy#arbitrum-sepolia-additional-deployments","99":"/docs-preview/pr-1680/developers/arbitrum-deploy#base-sepolia-additional-deployments","100":"/docs-preview/pr-1680/developers/arbitrum-full-node#running-a-full-node-and-or-validator","101":"/docs-preview/pr-1680/developers/arbitrum-full-node#prerequisites","102":"/docs-preview/pr-1680/developers/arbitrum-full-node#running-a-full-node","103":"/docs-preview/pr-1680/developers/arbitrum-full-node#running-a-full-node-with-validation","104":"/docs-preview/pr-1680/developers/arbitrum-integration#introduction-to-arbitrum-rollups-with-celestia-as-da","105":"/docs-preview/pr-1680/developers/arbitrum-integration#overview","106":"/docs-preview/pr-1680/developers/arbitrum-integration#key-components","107":"/docs-preview/pr-1680/developers/arbitrum-integration#da-provider-implementation","108":"/docs-preview/pr-1680/developers/arbitrum-integration#preimage-oracle-implementation","109":"/docs-preview/pr-1680/developers/arbitrum-integration#blobstream-x-implementation","110":"/docs-preview/pr-1680/developers/arbitrum-integration#ethereum-fallback-mechanism-in-nitro","111":"/docs-preview/pr-1680/developers/arbitrum-integration#next-steps","112":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#deploy-a-smart-contract-to-your-arbitrum-rollup","113":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#overview","114":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#prerequisites","115":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#setup","116":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#create-your-smart-contract","117":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#test-your-smart-contract","118":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#deploying-your-smart-contract","119":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#funded-accounts","120":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#using-our-arbitrum-devnet","121":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#interacting-with-your-smart-contract","122":"/docs-preview/pr-1680/developers/arbitrum-smart-contract#next-steps","123":"/docs-preview/pr-1680/developers/blobstream-contracts#integrate-with-blobstream-contracts","124":"/docs-preview/pr-1680/developers/blobstream-contracts#getting-started","125":"/docs-preview/pr-1680/developers/blobstream-contracts#prerequisites","126":"/docs-preview/pr-1680/developers/blobstream-contracts#installing-blobstream-contracts","127":"/docs-preview/pr-1680/developers/blobstream-contracts#example-usage","128":"/docs-preview/pr-1680/developers/blobstream-contracts#data-structures","129":"/docs-preview/pr-1680/developers/blobstream-contracts#interface","130":"/docs-preview/pr-1680/developers/blobstream-contracts#querying-the-proof","131":"/docs-preview/pr-1680/developers/blobstream-contracts#verifying-data-inclusion-for-fraud-proofs","132":"/docs-preview/pr-1680/developers/blobstream-offchain#integrate-with-blobstream-client","133":"/docs-preview/pr-1680/developers/blobstream-offchain#blobstream-demo-rollup","134":"/docs-preview/pr-1680/developers/blobstream-offchain#defining-a-chain","135":"/docs-preview/pr-1680/developers/blobstream-offchain#rollup-sequencer","136":"/docs-preview/pr-1680/developers/blobstream-offchain#committing-to-data","137":"/docs-preview/pr-1680/developers/blobstream-offchain#creating-blocks","138":"/docs-preview/pr-1680/developers/blobstream-offchain#rollup-full-node","139":"/docs-preview/pr-1680/developers/blobstream-offchain#downloading-the-block","140":"/docs-preview/pr-1680/developers/blobstream-offchain#more-documentation","141":"/docs-preview/pr-1680/developers/blobstream-offchain#proving-inclusion-via-blobstream","142":"/docs-preview/pr-1680/developers/blobstream-offchain#submitting-block-data-to-celestia-via-light-node","143":"/docs-preview/pr-1680/developers/blobstream-offchain#posting-headers-to-ethereum","144":"/docs-preview/pr-1680/developers/blobstream-proof-queries#blobstream-proofs-queries","145":"/docs-preview/pr-1680/developers/blobstream-proof-queries#prerequisites","146":"/docs-preview/pr-1680/developers/blobstream-proof-queries#overview-of-the-proof-queries","147":"/docs-preview/pr-1680/developers/blobstream-proof-queries#the-celestia-square","148":"/docs-preview/pr-1680/developers/blobstream-proof-queries#the-commitment-scheme","149":"/docs-preview/pr-1680/developers/blobstream-proof-queries#hands-on-demonstration","150":"/docs-preview/pr-1680/developers/blobstream-proof-queries#_1-data-root-inclusion-proof","151":"/docs-preview/pr-1680/developers/blobstream-proof-queries#http-query","152":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client","153":"/docs-preview/pr-1680/developers/blobstream-proof-queries#full-example-of-proving-that-a-celestia-block-was-committed-to-by-blobstream-contract","154":"/docs-preview/pr-1680/developers/blobstream-proof-queries#_2-transaction-inclusion-proof","155":"/docs-preview/pr-1680/developers/blobstream-proof-queries#transaction-inclusion-proof-using-the-transaction-hash","156":"/docs-preview/pr-1680/developers/blobstream-proof-queries#http-request","157":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client-1","158":"/docs-preview/pr-1680/developers/blobstream-proof-queries#blob-inclusion-proof-using-the-corresponding-pfb-transaction-hash","159":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client-2","160":"/docs-preview/pr-1680/developers/blobstream-proof-queries#specific-share-range-inclusion-proof","161":"/docs-preview/pr-1680/developers/blobstream-proof-queries#http-request-1","162":"/docs-preview/pr-1680/developers/blobstream-proof-queries#golang-client-3","163":"/docs-preview/pr-1680/developers/blobstream-proof-queries#converting-the-proofs-to-be-usable-in-the-daverifier-library","164":"/docs-preview/pr-1680/developers/blobstream-proof-queries#data","165":"/docs-preview/pr-1680/developers/blobstream-proof-queries#shareproofs","166":"/docs-preview/pr-1680/developers/blobstream-proof-queries#namespace","167":"/docs-preview/pr-1680/developers/blobstream-proof-queries#rowroots","168":"/docs-preview/pr-1680/developers/blobstream-proof-queries#rowproofs","169":"/docs-preview/pr-1680/developers/blobstream-proof-queries#attestationproof","170":"/docs-preview/pr-1680/developers/blobstream-proof-queries#querying-the-proof-s-tuplerootnonce","171":"/docs-preview/pr-1680/developers/blobstream-proof-queries#listening-for-new-data-commitments","172":"/docs-preview/pr-1680/developers/blobstream-proof-queries#example-rollup-that-uses-the-daverifier","173":"/docs-preview/pr-1680/developers/blobstream-proof-queries#conclusion","174":"/docs-preview/pr-1680/developers/blobstream-rollups#introduction-to-blobstream-rollups","175":"/docs-preview/pr-1680/developers/blobstream-rollups#concepts","176":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment","177":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-proof-details","178":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-compact-proofs","179":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-pros","180":"/docs-preview/pr-1680/developers/blobstream-rollups#blob-share-commitment-cons","181":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans","182":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-proof-details","183":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-proving-unavailable-data","184":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-proving-inclusion-of-some-data","185":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-pros","186":"/docs-preview/pr-1680/developers/blobstream-rollups#sequence-of-spans-cons","187":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups","188":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans","189":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-pros","190":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-cons","191":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-a-sequence-of-spans-example","192":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments","193":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-pros","194":"/docs-preview/pr-1680/developers/blobstream-rollups#optimistic-rollups-that-use-blob-share-commitments-cons","195":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups","196":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-sequence-of-spans","197":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-pros","198":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-sequence-of-spans-cons","199":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-blob-share-commitments","200":"/docs-preview/pr-1680/developers/blobstream-rollups#protobuf-deserialization-inside-a-zk-circuit","201":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-pros","202":"/docs-preview/pr-1680/developers/blobstream-rollups#zk-rollups-that-use-blob-share-commitments-cons","203":"/docs-preview/pr-1680/developers/blobstream-rollups#heavy-merkle-proofs-usage","204":"/docs-preview/pr-1680/developers/blobstream-rollups#heavy-merkle-proofs-usage-pros","205":"/docs-preview/pr-1680/developers/blobstream-rollups#heavy-merkle-proofs-usage-cons","206":"/docs-preview/pr-1680/developers/blobstream-rollups#conclusion","207":"/docs-preview/pr-1680/developers/blobstream-rollups#faq","208":"/docs-preview/pr-1680/developers/blobstream-rollups#should-i-use-the-celestia-transaction-hash-to-reference-the-rollup-data","209":"/docs-preview/pr-1680/developers/blobstream-x-deploy#new-blobstream-x-deployments","210":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploying-the-contracts","211":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploy-a-new-succinctgateway","212":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploy-the-function-verifiers","213":"/docs-preview/pr-1680/developers/blobstream-x-deploy#register-the-function-verifier-in-the-deployed-succinctgateway","214":"/docs-preview/pr-1680/developers/blobstream-x-deploy#enable-prover-whitelisting","215":"/docs-preview/pr-1680/developers/blobstream-x-deploy#set-whitelist-status","216":"/docs-preview/pr-1680/developers/blobstream-x-deploy#add-custom-prover","217":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deploy-the-blobstreamx-contract","218":"/docs-preview/pr-1680/developers/blobstream-x-deploy#querying-the-trusted-hash","219":"/docs-preview/pr-1680/developers/blobstream-x-deploy#deployment-instructions","220":"/docs-preview/pr-1680/developers/blobstream-x-deploy#run-a-local-prover","221":"/docs-preview/pr-1680/developers/blobstream-x-deploy#run-a-proof-replayer-from-an-existing-deployment","222":"/docs-preview/pr-1680/developers/blobstream-x-deploy#optional-regenerating-the-downloaded-artifacts","223":"/docs-preview/pr-1680/developers/blobstream-x-deploy#regenerate-the-verifier-build","224":"/docs-preview/pr-1680/developers/blobstream-x-deploy#build-the-circuits-and-function-verifiers","225":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#requesting-data-commitment-ranges","226":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#local-proving","227":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#request-proofs-from-the-succinct-platform","228":"/docs-preview/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges#request-proofs-onchain","229":"/docs-preview/pr-1680/developers/blobstream#blobstream-streaming-modular-da-to-ethereum","230":"/docs-preview/pr-1680/developers/blobstream#what-is-blobstream","231":"/docs-preview/pr-1680/developers/blobstream#implementations-of-blobstream","232":"/docs-preview/pr-1680/developers/blobstream#blobstream-vs-data-availability-committees-dacs","233":"/docs-preview/pr-1680/developers/blobstream#decentralization-and-security","234":"/docs-preview/pr-1680/developers/blobstream#mechanism-of-verification","235":"/docs-preview/pr-1680/developers/blobstream#flexibility-and-scalability","236":"/docs-preview/pr-1680/developers/blobstream#what-is-sp1-blobstream","237":"/docs-preview/pr-1680/developers/blobstream#integrate-with-sp1-blobstream","238":"/docs-preview/pr-1680/developers/blobstream#how-to-integrate-with-blobstream","239":"/docs-preview/pr-1680/developers/blobstream#blobstream-rollups","240":"/docs-preview/pr-1680/developers/blobstream#deployed-contracts","241":"/docs-preview/pr-1680/developers/blobstreamx#blobstreamx-the-previous-zk-implementation-of-blobstream","242":"/docs-preview/pr-1680/developers/blobstreamx#what-is-blobstream-x","243":"/docs-preview/pr-1680/developers/blobstreamx#how-blobstream-x-works","244":"/docs-preview/pr-1680/developers/blobstreamx#deploy-blobstream-x","245":"/docs-preview/pr-1680/developers/bubs-testnet#bubs-testnet","246":"/docs-preview/pr-1680/developers/bubs-testnet#built-with-the-op-stack-and-celestia","247":"/docs-preview/pr-1680/developers/bubs-testnet#building-on-bubs","248":"/docs-preview/pr-1680/developers/bubs-testnet#rpc-urls","249":"/docs-preview/pr-1680/developers/bubs-testnet#https","250":"/docs-preview/pr-1680/developers/bubs-testnet#wss","251":"/docs-preview/pr-1680/developers/bubs-testnet#bridge","252":"/docs-preview/pr-1680/developers/bubs-testnet#faucet","253":"/docs-preview/pr-1680/developers/bubs-testnet#explorer","254":"/docs-preview/pr-1680/developers/bubs-testnet#status","255":"/docs-preview/pr-1680/developers/bubs-testnet#next-steps","256":"/docs-preview/pr-1680/developers/build-whatever#build-whatever","257":"/docs-preview/pr-1680/developers/build-whatever#quickstart-building-on-celestia","258":"/docs-preview/pr-1680/developers/build-whatever#choose-a-framework","259":"/docs-preview/pr-1680/developers/build-whatever#rollups-as-a-service","260":"/docs-preview/pr-1680/developers/build-whatever#smart-contracts","261":"/docs-preview/pr-1680/developers/build-whatever#what-is-a-rollup","262":"/docs-preview/pr-1680/developers/build-whatever#what-is-a-modular-blockchain","263":"/docs-preview/pr-1680/developers/build-whatever#benefits-of-modular-blockchains","264":"/docs-preview/pr-1680/developers/build-whatever#ease-of-deploying-a-chain","265":"/docs-preview/pr-1680/developers/build-whatever#scaling","266":"/docs-preview/pr-1680/developers/build-whatever#customizability","267":"/docs-preview/pr-1680/developers/celestia-node-key#create-a-wallet-with-celestia-node","268":"/docs-preview/pr-1680/developers/celestia-node-key#using-the-cel-key-utility","269":"/docs-preview/pr-1680/developers/celestia-node-key#installation","270":"/docs-preview/pr-1680/developers/celestia-node-key#steps-for-generating-node-keys","271":"/docs-preview/pr-1680/developers/celestia-node-key#steps-for-exporting-node-keys","272":"/docs-preview/pr-1680/developers/celestia-node-key#steps-for-importing-node-keys","273":"/docs-preview/pr-1680/developers/celestia-node-key#view-all-options-for-cel-key","274":"/docs-preview/pr-1680/developers/celestia-node-key#docker-and-cel-key","275":"/docs-preview/pr-1680/developers/celestia-node-key#prerequisites","276":"/docs-preview/pr-1680/developers/celestia-node-key#running-your-node","277":"/docs-preview/pr-1680/developers/celestia-node-key#mounting-existing-keys-to-container","278":"/docs-preview/pr-1680/developers/deploy-on-bubs#deploy-a-smart-contract-on-bubs-testnet","279":"/docs-preview/pr-1680/developers/deploy-on-bubs#dependencies","280":"/docs-preview/pr-1680/developers/deploy-on-bubs#setup","281":"/docs-preview/pr-1680/developers/deploy-on-bubs#create-your-smart-contract","282":"/docs-preview/pr-1680/developers/deploy-on-bubs#test-your-smart-contract","283":"/docs-preview/pr-1680/developers/deploy-on-bubs#deploying-your-smart-contract","284":"/docs-preview/pr-1680/developers/deploy-on-bubs#using-anvil","285":"/docs-preview/pr-1680/developers/deploy-on-bubs#using-bubs","286":"/docs-preview/pr-1680/developers/deploy-on-bubs#interacting-with-your-smart-contract","287":"/docs-preview/pr-1680/developers/deploy-on-bubs#next-steps","288":"/docs-preview/pr-1680/developers/ethereum-fallback#ethereum-fallback","289":"/docs-preview/pr-1680/developers/feegrant-for-blobs#feegrant-module-for-blobs-submission","290":"/docs-preview/pr-1680/developers/feegrant-for-blobs#overview","291":"/docs-preview/pr-1680/developers/feegrant-for-blobs#pre-requisites","292":"/docs-preview/pr-1680/developers/feegrant-for-blobs#introduction","293":"/docs-preview/pr-1680/developers/feegrant-for-blobs#granting-fee-allowances-using-celestia-node","294":"/docs-preview/pr-1680/developers/feegrant-for-blobs#feegrant-module-implementation-in-celestia-node","295":"/docs-preview/pr-1680/developers/feegrant-for-blobs#grant-permission-for-an-allowance-as-a-granter","296":"/docs-preview/pr-1680/developers/feegrant-for-blobs#using-a-feegrant-allowance-as-a-grantee-in-celestia-node","297":"/docs-preview/pr-1680/developers/feegrant-for-blobs#checking-account-balances-after-submission","298":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-revoke-permission-for-a-feegrant-allowance-as-a-granter","299":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-submitting-a-blob-from-file-input","300":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-granting-fee-allowances-using-celestia-appd","301":"/docs-preview/pr-1680/developers/feegrant-for-blobs#optional-checking-the-granter-s-account","302":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#full-stack-modular-blockchain-development-guide","303":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#getting-started","304":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#pre-requisites","305":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#project-setup","306":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#updating-the-contract-and-tests","307":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#running-the-test","308":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#updating-the-deployment-script","309":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#deploying-locally","310":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#deploying-to-the-ethermint-sovereign-rollup","311":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#building-the-frontend","312":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#configuring-environment-variables","313":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#configuring-the-entrypoint","314":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#creating-and-reading-posts","315":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#adding-ethermint-chain-to-metamask","316":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#testing-it-out-on-ethermint","317":"/docs-preview/pr-1680/developers/full-stack-modular-development-guide#now-give-it-a-spin-🌀","318":"/docs-preview/pr-1680/developers/gm-portal-bubs#deploying-a-dapp-on-bubs-testnet","319":"/docs-preview/pr-1680/developers/gm-portal-bubs#update-the-frontend","320":"/docs-preview/pr-1680/developers/gm-portal-bubs#interact-with-the-frontend","321":"/docs-preview/pr-1680/developers/gm-portal-bubs#next-steps","322":"/docs-preview/pr-1680/developers/golang-client-tutorial#golang-client-library","323":"/docs-preview/pr-1680/developers/golang-client-tutorial#project-setup","324":"/docs-preview/pr-1680/developers/golang-client-tutorial#submitting-and-retrieving-blobs","325":"/docs-preview/pr-1680/developers/golang-client-tutorial#subscribing-to-new-blobs","326":"/docs-preview/pr-1680/developers/golang-client-tutorial#subscribing-to-new-headers","327":"/docs-preview/pr-1680/developers/golang-client-tutorial#fetching-an-extended-data-square-eds","328":"/docs-preview/pr-1680/developers/golang-client-tutorial#api-documentation","329":"/docs-preview/pr-1680/developers/integrate-celestia#integrate-celestia-for-service-providers","330":"/docs-preview/pr-1680/developers/integrate-celestia#getting-started","331":"/docs-preview/pr-1680/developers/integrate-celestia#celestia-service-provider-notes","332":"/docs-preview/pr-1680/developers/integrate-celestia#custody-and-key-management","333":"/docs-preview/pr-1680/developers/integrate-celestia#rpc-and-querying","334":"/docs-preview/pr-1680/developers/integrate-celestia#compatibility","335":"/docs-preview/pr-1680/developers/integrate-celestia#syncing","336":"/docs-preview/pr-1680/developers/integrate-celestia#notable-exceptions-relative-to-other-blockchains","337":"/docs-preview/pr-1680/developers/intro-to-op-stack#introduction-to-op-stack-integration","338":"/docs-preview/pr-1680/developers/intro-to-op-stack#about-the-integration","339":"/docs-preview/pr-1680/developers/intro-to-op-stack#github-repository","340":"/docs-preview/pr-1680/developers/intro-to-op-stack#category-contents","341":"/docs-preview/pr-1680/developers/intro-to-op-stack#next-steps","342":"/docs-preview/pr-1680/developers/multiaccounts#multiaccounts-feature-for-blobs-submission","343":"/docs-preview/pr-1680/developers/multiaccounts#overview","344":"/docs-preview/pr-1680/developers/multiaccounts#running-a-node-with-a-different-default-key-name","345":"/docs-preview/pr-1680/developers/multiaccounts#submitting-blobs-with-a-different-signer-key-name","346":"/docs-preview/pr-1680/developers/multiaccounts#option-1-submit-passing-key-name","347":"/docs-preview/pr-1680/developers/multiaccounts#option-2-submit-passing-signer-address","348":"/docs-preview/pr-1680/developers/multiaccounts#key-management","349":"/docs-preview/pr-1680/developers/multiaccounts#creating-a-new-key","350":"/docs-preview/pr-1680/developers/multiaccounts#importing-an-existing-key","351":"/docs-preview/pr-1680/developers/multiaccounts#optional-flags-for-write-transactions","352":"/docs-preview/pr-1680/developers/node-api#node-api","353":"/docs-preview/pr-1680/developers/node-api#rpc-api","354":"/docs-preview/pr-1680/developers/node-api#library","355":"/docs-preview/pr-1680/developers/node-api#rpc","356":"/docs-preview/pr-1680/developers/node-api#rpc-api-tutorial","357":"/docs-preview/pr-1680/developers/node-api#gateway-api","358":"/docs-preview/pr-1680/developers/node-api#gateway-api-tutorial","359":"/docs-preview/pr-1680/developers/node-tutorial#celestia-node-rpc-cli-tutorial","360":"/docs-preview/pr-1680/developers/node-tutorial#introduction","361":"/docs-preview/pr-1680/developers/node-tutorial#blobs","362":"/docs-preview/pr-1680/developers/node-tutorial#namespaces","363":"/docs-preview/pr-1680/developers/node-tutorial#hardware-requirements","364":"/docs-preview/pr-1680/developers/node-tutorial#setting-up-dependencies","365":"/docs-preview/pr-1680/developers/node-tutorial#instantiate-a-celestia-light-node","366":"/docs-preview/pr-1680/developers/node-tutorial#connect-to-a-core-endpoint","367":"/docs-preview/pr-1680/developers/node-tutorial#keys-and-wallets","368":"/docs-preview/pr-1680/developers/node-tutorial#rpc-cli-guide","369":"/docs-preview/pr-1680/developers/node-tutorial#command-formatting","370":"/docs-preview/pr-1680/developers/node-tutorial#basic-flags","371":"/docs-preview/pr-1680/developers/node-tutorial#auth-token","372":"/docs-preview/pr-1680/developers/node-tutorial#node-store","373":"/docs-preview/pr-1680/developers/node-tutorial#auth-token-on-custom-or-private-network","374":"/docs-preview/pr-1680/developers/node-tutorial#submitting-data","375":"/docs-preview/pr-1680/developers/node-tutorial#optional-submit-with-curl","376":"/docs-preview/pr-1680/developers/node-tutorial#retrieving-data","377":"/docs-preview/pr-1680/developers/node-tutorial#setting-the-gas-price","378":"/docs-preview/pr-1680/developers/node-tutorial#examples","379":"/docs-preview/pr-1680/developers/node-tutorial#check-your-balance","380":"/docs-preview/pr-1680/developers/node-tutorial#check-the-balance-of-another-address","381":"/docs-preview/pr-1680/developers/node-tutorial#get-your-node-id","382":"/docs-preview/pr-1680/developers/node-tutorial#get-your-account-address","383":"/docs-preview/pr-1680/developers/node-tutorial#get-block-header-by-height","384":"/docs-preview/pr-1680/developers/node-tutorial#combined-commands","385":"/docs-preview/pr-1680/developers/node-tutorial#get-data-availability-sampler-stats","386":"/docs-preview/pr-1680/developers/node-tutorial#transfer-balance-of-utia-to-another-account","387":"/docs-preview/pr-1680/developers/node-tutorial#api-version","388":"/docs-preview/pr-1680/developers/node-tutorial#help","389":"/docs-preview/pr-1680/developers/node-tutorial#advanced-example","390":"/docs-preview/pr-1680/developers/node-tutorial#additional-resources","391":"/docs-preview/pr-1680/developers/node-tutorial#submitting-a-blob-using-curl","392":"/docs-preview/pr-1680/developers/node-tutorial#post-an-svg-as-a-pfb","393":"/docs-preview/pr-1680/developers/node-tutorial#troubleshooting","394":"/docs-preview/pr-1680/developers/optimism-devnet#optimism-devnet-deep-dive","395":"/docs-preview/pr-1680/developers/optimism-devnet#find-a-transaction","396":"/docs-preview/pr-1680/developers/optimism-devnet#read-the-transaction-call-data","397":"/docs-preview/pr-1680/developers/optimism-devnet#find-the-data-on-celestia","398":"/docs-preview/pr-1680/developers/optimism-devnet#span-batches","399":"/docs-preview/pr-1680/developers/optimism#run-an-op-stack-rollup-with-celestia-underneath","400":"/docs-preview/pr-1680/developers/optimism#dependency-setup","401":"/docs-preview/pr-1680/developers/optimism#setting-up-your-light-node","402":"/docs-preview/pr-1680/developers/optimism#deploying-a-devnet-to-mocha","403":"/docs-preview/pr-1680/developers/optimism#deploying-a-testnet-to-an-l1-or-l2-and-mocha","404":"/docs-preview/pr-1680/developers/optimism#congratulations","405":"/docs-preview/pr-1680/developers/prompt-scavenger#prompt-scavenger","406":"/docs-preview/pr-1680/developers/prompt-scavenger#dependencies","407":"/docs-preview/pr-1680/developers/prompt-scavenger#install-celestia-node-and-run-a-light-node","408":"/docs-preview/pr-1680/developers/prompt-scavenger#openai-key","409":"/docs-preview/pr-1680/developers/prompt-scavenger#building-the-prompt-scavenger","410":"/docs-preview/pr-1680/developers/prompt-scavenger#initialize-your-go-project","411":"/docs-preview/pr-1680/developers/prompt-scavenger#build-your-import-statements","412":"/docs-preview/pr-1680/developers/prompt-scavenger#main-function","413":"/docs-preview/pr-1680/developers/prompt-scavenger#utility-functions","414":"/docs-preview/pr-1680/developers/prompt-scavenger#prompting-chatgpt","415":"/docs-preview/pr-1680/developers/prompt-scavenger#wrapping-things-up","416":"/docs-preview/pr-1680/developers/prompt-scavenger#next-steps","417":"/docs-preview/pr-1680/developers/rust-client-tutorial#rust-client-library","418":"/docs-preview/pr-1680/developers/rust-client-tutorial#project-setup","419":"/docs-preview/pr-1680/developers/rust-client-tutorial#submitting-and-retrieving-blobs","420":"/docs-preview/pr-1680/developers/rust-client-tutorial#subscribing-to-new-headers","421":"/docs-preview/pr-1680/developers/rust-client-tutorial#fetching-an-extended-data-square-eds","422":"/docs-preview/pr-1680/developers/rust-client-tutorial#api-documentation","423":"/docs-preview/pr-1680/developers/sp1-blobstream-deploy#new-sp1-blobstream-deployments","424":"/docs-preview/pr-1680/developers/sp1-blobstream-deploy#deploying-the-contracts","425":"/docs-preview/pr-1680/developers/submit-data#submitting-data-blobs-to-celestia","426":"/docs-preview/pr-1680/developers/submit-data#maximum-blob-size","427":"/docs-preview/pr-1680/developers/submit-data#fee-market-and-mempool","428":"/docs-preview/pr-1680/developers/submit-data#fees-and-gas-limits","429":"/docs-preview/pr-1680/developers/submit-data#estimating-pfb-gas","430":"/docs-preview/pr-1680/developers/submit-data#gas-fee-calculation","431":"/docs-preview/pr-1680/developers/submit-data#estimating-gas-programmatically","432":"/docs-preview/pr-1680/developers/submit-data#submitting-multiple-transactions-in-one-block-from-the-same-account","433":"/docs-preview/pr-1680/developers/submit-data#api","434":"/docs-preview/pr-1680/developers/submit-data#the-celestia-app-consensus-node-cli","435":"/docs-preview/pr-1680/developers/submit-data#the-celestia-node-light-node-cli","436":"/docs-preview/pr-1680/developers/submit-data#the-celestia-node-api-golang-client","437":"/docs-preview/pr-1680/developers/submit-data#grpc-to-a-consensus-node-via-the-user-package","438":"/docs-preview/pr-1680/developers/submit-data#rpc-to-a-celestia-node","439":"/docs-preview/pr-1680/developers/transaction-resubmission#transaction-resubmission","440":"/docs-preview/pr-1680/developers/transaction-resubmission#monitoring-and-resubmission","441":"/docs-preview/pr-1680/developers/transaction-resubmission#notes","442":"/docs-preview/pr-1680/developers/wallets#wallet-integrations-with-celestia","443":"/docs-preview/pr-1680/developers/wallets#add-celestia-network-parameters-to-keplr-with-react","444":"/docs-preview/pr-1680/developers/wallets#adding-a-custom-chain-to-leap","445":"/docs-preview/pr-1680/developers/wallets#adding-a-custom-chain-to-cosmostation","446":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#data-availability-faq","447":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-data-availability","448":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-the-data-availability-problem","449":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#how-do-nodes-verify-data-availability-in-celestia","450":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-data-availability-sampling","451":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-are-some-of-the-security-assumptions-that-celestia-makes-for-data-availability-sampling","452":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#why-is-block-reconstruction-necessary-for-security","453":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-data-storage","454":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-the-problem-around-data-storage","455":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-is-the-difference-between-data-availability-and-data-storage","456":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#where-does-blockchain-state-fit-into-this","457":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#why-doesn-t-celestia-incentivize-storage-of-historical-data","458":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#who-may-store-historical-data-if-there-is-no-reward","459":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-faq#what-are-some-things-blockchains-can-do-to-provide-stronger-assurances-of-data-retrievability","460":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#celestia-s-data-availability-layer","461":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#data-availability-sampling-das","462":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#scalability","463":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#fraud-proofs-of-incorrectly-extended-data","464":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#namespaced-merkle-trees-nmts","465":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#building-a-pos-blockchain-for-da","466":"/docs-preview/pr-1680/learn/how-celestia-works/data-availability-layer#providing-data-availability","467":"/docs-preview/pr-1680/learn/how-celestia-works/monolithic-vs-modular#monolithic-vs-modular-blockchains","468":"/docs-preview/pr-1680/learn/how-celestia-works/overview#introduction","469":"/docs-preview/pr-1680/learn/how-celestia-works/transaction-lifecycle#the-lifecycle-of-a-celestia-app-transaction","470":"/docs-preview/pr-1680/learn/how-celestia-works/transaction-lifecycle#checking-data-availability","471":"/docs-preview/pr-1680/learn/how-to-stake-tia#how-to-stake-tia","472":"/docs-preview/pr-1680/learn/how-to-stake-tia#select-your-preferred-wallet","473":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-tia-with-keplr-wallet","474":"/docs-preview/pr-1680/learn/how-to-stake-tia#open-your-keplr-browser-extension","475":"/docs-preview/pr-1680/learn/how-to-stake-tia#select-celestia-network-and-search-for-a-validator","476":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-your-tia-tokens","477":"/docs-preview/pr-1680/learn/how-to-stake-tia#confirm-and-manage-your-tia","478":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-tia-with-leap-wallet","479":"/docs-preview/pr-1680/learn/how-to-stake-tia#open-your-leap-browser-extension","480":"/docs-preview/pr-1680/learn/how-to-stake-tia#select-a-validator-and-stake-tia","481":"/docs-preview/pr-1680/learn/how-to-stake-tia#confirm-and-manage-your-tia-1","482":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-tia-with-gem-wallet","483":"/docs-preview/pr-1680/learn/how-to-stake-tia#open-your-gem-wallet-app","484":"/docs-preview/pr-1680/learn/how-to-stake-tia#choose-the-amount-of-celestia-and-search-for-a-validator","485":"/docs-preview/pr-1680/learn/how-to-stake-tia#stake-your-tia-tokens-1","486":"/docs-preview/pr-1680/learn/how-to-stake-tia#manage-your-tia","487":"/docs-preview/pr-1680/learn/paying-for-blobspace#paying-for-blobspace","488":"/docs-preview/pr-1680/learn/paying-for-blobspace#payforblobs-transactions","489":"/docs-preview/pr-1680/learn/paying-for-blobspace#fee-market-overview","490":"/docs-preview/pr-1680/learn/retrievability#data-retrievability-and-pruning","491":"/docs-preview/pr-1680/learn/retrievability#data-retrievability-and-pruning-in-celestia-node","492":"/docs-preview/pr-1680/learn/retrievability#suggested-practices-for-rollups","493":"/docs-preview/pr-1680/learn/staking-governance-supply#staking-governance-supply","494":"/docs-preview/pr-1680/learn/staking-governance-supply#proof-of-stake-on-celestia","495":"/docs-preview/pr-1680/learn/staking-governance-supply#inflation","496":"/docs-preview/pr-1680/learn/staking-governance-supply#decentralised-governance","497":"/docs-preview/pr-1680/learn/staking-governance-supply#network-parameters","498":"/docs-preview/pr-1680/learn/staking-governance-supply#community-pool","499":"/docs-preview/pr-1680/learn/staking-governance-supply#tia-allocation-at-genesis","500":"/docs-preview/pr-1680/learn/staking-governance-supply#unlocks","501":"/docs-preview/pr-1680/learn/staking#staking-on-celestia","502":"/docs-preview/pr-1680/learn/staking#mainnet-beta","503":"/docs-preview/pr-1680/learn/staking#mocha-testnet","504":"/docs-preview/pr-1680/learn/tia#overview-of-tia","505":"/docs-preview/pr-1680/learn/tia#tia-at-a-glance","506":"/docs-preview/pr-1680/learn/tia#role-of-tia","507":"/docs-preview/pr-1680/learn/tia#paying-for-blobspace","508":"/docs-preview/pr-1680/learn/tia#bootstrapping-new-rollups","509":"/docs-preview/pr-1680/learn/tia#proof-of-stake","510":"/docs-preview/pr-1680/learn/tia#decentralised-governance","511":"/docs-preview/pr-1680/learn/tia#denominations","512":"/docs-preview/pr-1680/learn/tia#tia-display-token","513":"/docs-preview/pr-1680/learn/tia#utia-staking-denomination","514":"/docs-preview/pr-1680/learn/tia#microtia-staking-denomination-alias","515":"/docs-preview/pr-1680/nodes/arabica-devnet#arabica-devnet","516":"/docs-preview/pr-1680/nodes/arabica-devnet#network-stability-and-upgrades","517":"/docs-preview/pr-1680/nodes/arabica-devnet#network-details","518":"/docs-preview/pr-1680/nodes/arabica-devnet#software-version-numbers","519":"/docs-preview/pr-1680/nodes/arabica-devnet#integrations","520":"/docs-preview/pr-1680/nodes/arabica-devnet#production-rpc-endpoints","521":"/docs-preview/pr-1680/nodes/arabica-devnet#community-rpc-endpoints","522":"/docs-preview/pr-1680/nodes/arabica-devnet#using-consensus-endpoints-with-da-nodes","523":"/docs-preview/pr-1680/nodes/arabica-devnet#data-availability-da-rpc-endpoints-for-bridge-node-sync","524":"/docs-preview/pr-1680/nodes/arabica-devnet#data-availability-da-grpc-endpoints-for-state-access","525":"/docs-preview/pr-1680/nodes/arabica-devnet#arabica-devnet-faucet","526":"/docs-preview/pr-1680/nodes/arabica-devnet#discord","527":"/docs-preview/pr-1680/nodes/arabica-devnet#web","528":"/docs-preview/pr-1680/nodes/arabica-devnet#explorers","529":"/docs-preview/pr-1680/nodes/arabica-devnet#network-upgrades","530":"/docs-preview/pr-1680/nodes/bridge-node#setting-up-a-celestia-bridge-node","531":"/docs-preview/pr-1680/nodes/bridge-node#overview-of-bridge-nodes","532":"/docs-preview/pr-1680/nodes/bridge-node#hardware-requirements","533":"/docs-preview/pr-1680/nodes/bridge-node#setting-up-your-bridge-node","534":"/docs-preview/pr-1680/nodes/bridge-node#setup-the-dependencies","535":"/docs-preview/pr-1680/nodes/bridge-node#deploy-the-celestia-bridge-node","536":"/docs-preview/pr-1680/nodes/bridge-node#install-celestia-node","537":"/docs-preview/pr-1680/nodes/bridge-node#initialize-the-bridge-node","538":"/docs-preview/pr-1680/nodes/bridge-node#run-the-bridge-node","539":"/docs-preview/pr-1680/nodes/bridge-node#optional-run-the-bridge-node-with-a-custom-key","540":"/docs-preview/pr-1680/nodes/bridge-node#optional-migrate-node-id-to-another-server","541":"/docs-preview/pr-1680/nodes/bridge-node#optional-start-the-bridge-node-with-systemd","542":"/docs-preview/pr-1680/nodes/celestia-app-commands#helpful-cli-commands","543":"/docs-preview/pr-1680/nodes/celestia-app-commands#creating-a-wallet","544":"/docs-preview/pr-1680/nodes/celestia-app-commands#key-management","545":"/docs-preview/pr-1680/nodes/celestia-app-commands#importing-and-exporting-keys","546":"/docs-preview/pr-1680/nodes/celestia-app-commands#querying-subcommands","547":"/docs-preview/pr-1680/nodes/celestia-app-commands#token-management","548":"/docs-preview/pr-1680/nodes/celestia-app-commands#governance","549":"/docs-preview/pr-1680/nodes/celestia-app-commands#community-pool","550":"/docs-preview/pr-1680/nodes/celestia-app-commands#claim-validator-rewards","551":"/docs-preview/pr-1680/nodes/celestia-app-commands#delegate-undelegate-tokens","552":"/docs-preview/pr-1680/nodes/celestia-app-commands#unjailing-the-validator","553":"/docs-preview/pr-1680/nodes/celestia-app-commands#how-to-export-logs-with-systemd","554":"/docs-preview/pr-1680/nodes/celestia-app-commands#signing-genesis-for-a-new-network","555":"/docs-preview/pr-1680/nodes/celestia-app-metrics#metrics","556":"/docs-preview/pr-1680/nodes/celestia-app-metrics#setup","557":"/docs-preview/pr-1680/nodes/celestia-app-metrics#visualization","558":"/docs-preview/pr-1680/nodes/celestia-app-metrics#node-exporter","559":"/docs-preview/pr-1680/nodes/celestia-app-metrics#alerts","560":"/docs-preview/pr-1680/nodes/celestia-app-multisig#multisig","561":"/docs-preview/pr-1680/nodes/celestia-app-multisig#command-line","562":"/docs-preview/pr-1680/nodes/celestia-app-multisig#resources","563":"/docs-preview/pr-1680/nodes/celestia-app-slashing#jailing-and-slashing-on-celestia","564":"/docs-preview/pr-1680/nodes/celestia-app-upgrade-monitor#upgrade-monitor","565":"/docs-preview/pr-1680/nodes/celestia-app-vesting#how-to-create-a-vesting-account-with-celestia-app","566":"/docs-preview/pr-1680/nodes/celestia-app-vesting#local-devnet","567":"/docs-preview/pr-1680/nodes/celestia-app-vesting#setting-up-the-local-devnet","568":"/docs-preview/pr-1680/nodes/celestia-app-vesting#run-the-devnet","569":"/docs-preview/pr-1680/nodes/celestia-app-vesting#save-the-home-directory-path","570":"/docs-preview/pr-1680/nodes/celestia-app-vesting#check-the-version-of-the-devnet","571":"/docs-preview/pr-1680/nodes/celestia-app-vesting#next-steps","572":"/docs-preview/pr-1680/nodes/celestia-app-vesting#setting-up-vesting-account-on-devnet","573":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-a-new-key","574":"/docs-preview/pr-1680/nodes/celestia-app-vesting#list-your-keys","575":"/docs-preview/pr-1680/nodes/celestia-app-vesting#set-variables","576":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-your-devnet-vesting-account","577":"/docs-preview/pr-1680/nodes/celestia-app-vesting#query-the-devnet-vesting-account-details","578":"/docs-preview/pr-1680/nodes/celestia-app-vesting#query-the-devnet-base-account-details","579":"/docs-preview/pr-1680/nodes/celestia-app-vesting#query-the-balances-of-the-devnet-accounts","580":"/docs-preview/pr-1680/nodes/celestia-app-vesting#mocha","581":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-a-wallet","582":"/docs-preview/pr-1680/nodes/celestia-app-vesting#fund-your-account","583":"/docs-preview/pr-1680/nodes/celestia-app-vesting#create-a-vesting-account-on-mocha","584":"/docs-preview/pr-1680/nodes/celestia-app-vesting#optional-set-up-a-consensus-node-or-validator","585":"/docs-preview/pr-1680/nodes/celestia-app-vesting#optional-change-your-client-toml","586":"/docs-preview/pr-1680/nodes/celestia-app-vesting#notes","587":"/docs-preview/pr-1680/nodes/celestia-app-vesting#conclusion","588":"/docs-preview/pr-1680/nodes/celestia-app-wallet#create-a-wallet-with-celestia-app","589":"/docs-preview/pr-1680/nodes/celestia-app-wallet#prerequisites","590":"/docs-preview/pr-1680/nodes/celestia-app-wallet#create-a-wallet","591":"/docs-preview/pr-1680/nodes/celestia-app-wallet#fund-a-wallet","592":"/docs-preview/pr-1680/nodes/celestia-app#install-celestia-app","593":"/docs-preview/pr-1680/nodes/celestia-app#building-binary-from-source","594":"/docs-preview/pr-1680/nodes/celestia-app#installing-a-pre-built-binary","595":"/docs-preview/pr-1680/nodes/celestia-app#ports","596":"/docs-preview/pr-1680/nodes/celestia-node-custom-networks#custom-networks-and-values","597":"/docs-preview/pr-1680/nodes/celestia-node-metrics#celestia-node-metrics","598":"/docs-preview/pr-1680/nodes/celestia-node-metrics#running-metrics-flags","599":"/docs-preview/pr-1680/nodes/celestia-node-metrics#mainnet-beta","600":"/docs-preview/pr-1680/nodes/celestia-node-metrics#mocha-testnet","601":"/docs-preview/pr-1680/nodes/celestia-node-metrics#tls-connections","602":"/docs-preview/pr-1680/nodes/celestia-node-metrics#metrics-endpoint-design-considerations","603":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#troubleshooting","604":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#network-selection","605":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#chain-id","606":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#ports","607":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#changing-the-location-of-your-node-store","608":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#background","609":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#demonstration","610":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#examples","611":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#mainnet-beta-full-and-mocha-light","612":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#mocha-full-and-arabica-light","613":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#using-a-custom-rpc-config-address","614":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#resetting-your-config","615":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#clearing-the-data-store","616":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#fatal-headers-given-to-the-heightsub-are-in-the-wrong-order","617":"/docs-preview/pr-1680/nodes/celestia-node-troubleshooting#error-too-many-open-files","618":"/docs-preview/pr-1680/nodes/celestia-node-trusted-hash#syncing-a-light-node-from-a-trusted-hash","619":"/docs-preview/pr-1680/nodes/celestia-node-trusted-hash#for-service-operators","620":"/docs-preview/pr-1680/nodes/celestia-node#install-celestia-node","621":"/docs-preview/pr-1680/nodes/celestia-node#installing-from-source","622":"/docs-preview/pr-1680/nodes/celestia-node#installing-a-pre-built-binary","623":"/docs-preview/pr-1680/nodes/celestia-node#next-steps","624":"/docs-preview/pr-1680/nodes/celestia-node#upgrading-your-binary","625":"/docs-preview/pr-1680/nodes/config-toml#config-toml-guide","626":"/docs-preview/pr-1680/nodes/config-toml#pre-requisites","627":"/docs-preview/pr-1680/nodes/config-toml#understanding-config-toml","628":"/docs-preview/pr-1680/nodes/config-toml#core","629":"/docs-preview/pr-1680/nodes/config-toml#p2p","630":"/docs-preview/pr-1680/nodes/config-toml#bootstrap","631":"/docs-preview/pr-1680/nodes/config-toml#mutual-peers","632":"/docs-preview/pr-1680/nodes/config-toml#services","633":"/docs-preview/pr-1680/nodes/config-toml#trustedhash-and-trustedpeer","634":"/docs-preview/pr-1680/nodes/consensus-node#consensus-node","635":"/docs-preview/pr-1680/nodes/consensus-node#minimum-hardware-requirements","636":"/docs-preview/pr-1680/nodes/consensus-node#set-up-a-consensus-node","637":"/docs-preview/pr-1680/nodes/consensus-node#set-up-the-dependencies","638":"/docs-preview/pr-1680/nodes/consensus-node#install-celestia-app","639":"/docs-preview/pr-1680/nodes/consensus-node#set-up-the-p2p-networks","640":"/docs-preview/pr-1680/nodes/consensus-node#storage-and-pruning-configurations","641":"/docs-preview/pr-1680/nodes/consensus-node#optional-connect-a-consensus-node-to-a-bridge-node","642":"/docs-preview/pr-1680/nodes/consensus-node#enable-transaction-indexing","643":"/docs-preview/pr-1680/nodes/consensus-node#retain-all-block-data","644":"/docs-preview/pr-1680/nodes/consensus-node#query-transactions-by-hash","645":"/docs-preview/pr-1680/nodes/consensus-node#optional-access-historical-state","646":"/docs-preview/pr-1680/nodes/consensus-node#save-on-storage-requirements","647":"/docs-preview/pr-1680/nodes/consensus-node#sync-types","648":"/docs-preview/pr-1680/nodes/consensus-node#option-1-block-sync","649":"/docs-preview/pr-1680/nodes/consensus-node#option-2-state-sync","650":"/docs-preview/pr-1680/nodes/consensus-node#option-3-quick-sync","651":"/docs-preview/pr-1680/nodes/consensus-node#start-the-consensus-node","652":"/docs-preview/pr-1680/nodes/consensus-node#extra-resources-for-consensus-nodes","653":"/docs-preview/pr-1680/nodes/consensus-node#optional-reset-network","654":"/docs-preview/pr-1680/nodes/consensus-node#optional-configure-an-rpc-endpoint","655":"/docs-preview/pr-1680/nodes/consensus-node#expose-rpc","656":"/docs-preview/pr-1680/nodes/consensus-node#note-on-external-address","657":"/docs-preview/pr-1680/nodes/consensus-node#restart-the-node","658":"/docs-preview/pr-1680/nodes/consensus-node#optional-transaction-indexer-configuration-options","659":"/docs-preview/pr-1680/nodes/consensus-node#optional-discard-abci-responses-configuration","660":"/docs-preview/pr-1680/nodes/consensus-node#faq","661":"/docs-preview/pr-1680/nodes/consensus-node#_2-3-committed-an-invalid-block-wrong-block-header-version","662":"/docs-preview/pr-1680/nodes/decide-node#deciding-which-node-to-run","663":"/docs-preview/pr-1680/nodes/decide-node#beginner","664":"/docs-preview/pr-1680/nodes/decide-node#advanced","665":"/docs-preview/pr-1680/nodes/docker-images#🐳-docker-setup","666":"/docs-preview/pr-1680/nodes/docker-images#prerequisites","667":"/docs-preview/pr-1680/nodes/docker-images#quick-start","668":"/docs-preview/pr-1680/nodes/docker-images#light-node-setup-with-persistent-storage","669":"/docs-preview/pr-1680/nodes/docker-images#initialize-the-node-store-and-key","670":"/docs-preview/pr-1680/nodes/docker-images#start-the-node","671":"/docs-preview/pr-1680/nodes/docker-images#video-walkthrough","672":"/docs-preview/pr-1680/nodes/docker-images#_2-5-minute-version","673":"/docs-preview/pr-1680/nodes/docker-images#troubleshooting","674":"/docs-preview/pr-1680/nodes/environment#development-environment","675":"/docs-preview/pr-1680/nodes/environment#install-dependencies","676":"/docs-preview/pr-1680/nodes/environment#install-golang","677":"/docs-preview/pr-1680/nodes/full-storage-node#setting-up-a-celestia-full-storage-node","678":"/docs-preview/pr-1680/nodes/full-storage-node#overview-of-full-storage-nodes","679":"/docs-preview/pr-1680/nodes/full-storage-node#hardware-requirements","680":"/docs-preview/pr-1680/nodes/full-storage-node#setting-up-your-full-storage-node","681":"/docs-preview/pr-1680/nodes/full-storage-node#setup-the-dependencies","682":"/docs-preview/pr-1680/nodes/full-storage-node#install-celestia-node","683":"/docs-preview/pr-1680/nodes/full-storage-node#run-the-full-storage-node","684":"/docs-preview/pr-1680/nodes/full-storage-node#initialize-the-full-storage-node","685":"/docs-preview/pr-1680/nodes/full-storage-node#start-the-full-storage-node","686":"/docs-preview/pr-1680/nodes/full-storage-node#optional-run-the-full-storage-node-with-a-custom-key","687":"/docs-preview/pr-1680/nodes/full-storage-node#optional-migrate-node-id-to-another-server","688":"/docs-preview/pr-1680/nodes/full-storage-node#optional-start-the-full-storage-node-with-systemd","689":"/docs-preview/pr-1680/nodes/full-storage-node#stop-the-full-storage-node","690":"/docs-preview/pr-1680/nodes/hardfork-process#celestia-hardfork-process","691":"/docs-preview/pr-1680/nodes/hardfork-process#general-process","692":"/docs-preview/pr-1680/nodes/hardfork-process#lemongrass-hardfork","693":"/docs-preview/pr-1680/nodes/ibc-relayer#ibc-relaying-guide","694":"/docs-preview/pr-1680/nodes/ibc-relayer#hermes","695":"/docs-preview/pr-1680/nodes/ibc-relayer#configuration","696":"/docs-preview/pr-1680/nodes/ibc-relayer#add-relayer-wallets","697":"/docs-preview/pr-1680/nodes/ibc-relayer#verify-configuration-files","698":"/docs-preview/pr-1680/nodes/ibc-relayer#create-a-connection-between-2-chains","699":"/docs-preview/pr-1680/nodes/ibc-relayer#create-clients","700":"/docs-preview/pr-1680/nodes/ibc-relayer#open-connection-over-new-clients","701":"/docs-preview/pr-1680/nodes/ibc-relayer#configure-channels-in-hermes","702":"/docs-preview/pr-1680/nodes/ibc-relayer#start-the-relayer","703":"/docs-preview/pr-1680/nodes/ibc-relayer#transfer","704":"/docs-preview/pr-1680/nodes/ibc-relayer#token-filter","705":"/docs-preview/pr-1680/nodes/instantiate-testnet#celestia-app-network-instantiation-guide","706":"/docs-preview/pr-1680/nodes/instantiate-testnet#hardware-requirements","707":"/docs-preview/pr-1680/nodes/instantiate-testnet#setup-dependencies","708":"/docs-preview/pr-1680/nodes/instantiate-testnet#celestia-app-installation","709":"/docs-preview/pr-1680/nodes/instantiate-testnet#spin-up-a-celestia-testnet","710":"/docs-preview/pr-1680/nodes/instantiate-testnet#optional-reset-working-directory","711":"/docs-preview/pr-1680/nodes/instantiate-testnet#initialize-a-working-directory","712":"/docs-preview/pr-1680/nodes/instantiate-testnet#create-a-new-key","713":"/docs-preview/pr-1680/nodes/instantiate-testnet#add-genesis-account-keyname","714":"/docs-preview/pr-1680/nodes/instantiate-testnet#optional-adding-other-validators","715":"/docs-preview/pr-1680/nodes/instantiate-testnet#create-the-genesis-transaction-for-new-chain","716":"/docs-preview/pr-1680/nodes/instantiate-testnet#creating-the-genesis-json-file","717":"/docs-preview/pr-1680/nodes/instantiate-testnet#modify-your-config-file","718":"/docs-preview/pr-1680/nodes/instantiate-testnet#add-your-node-as-a-persistent-peer","719":"/docs-preview/pr-1680/nodes/instantiate-testnet#instantiate-the-network","720":"/docs-preview/pr-1680/nodes/light-node#setting-up-a-celestia-light-node","721":"/docs-preview/pr-1680/nodes/light-node#overview-of-light-nodes","722":"/docs-preview/pr-1680/nodes/light-node#hardware-requirements","723":"/docs-preview/pr-1680/nodes/light-node#setting-up-your-light-node","724":"/docs-preview/pr-1680/nodes/light-node#install-celestia-node","725":"/docs-preview/pr-1680/nodes/light-node#initialize-the-light-node","726":"/docs-preview/pr-1680/nodes/light-node#start-the-light-node","727":"/docs-preview/pr-1680/nodes/light-node#keys-and-wallets","728":"/docs-preview/pr-1680/nodes/light-node#testnet-tokens","729":"/docs-preview/pr-1680/nodes/light-node#optional-run-the-light-node-with-a-custom-key","730":"/docs-preview/pr-1680/nodes/light-node#optional-migrate-node-id-to-another-server","731":"/docs-preview/pr-1680/nodes/light-node#optional-start-light-node-with-systemd","732":"/docs-preview/pr-1680/nodes/light-node#data-availability-sampling","733":"/docs-preview/pr-1680/nodes/mainnet#mainnet-beta","734":"/docs-preview/pr-1680/nodes/mainnet#network-stability-and-upgrades","735":"/docs-preview/pr-1680/nodes/mainnet#network-details","736":"/docs-preview/pr-1680/nodes/mainnet#software-version-numbers","737":"/docs-preview/pr-1680/nodes/mainnet#network-parameters","738":"/docs-preview/pr-1680/nodes/mainnet#maximum-bytes","739":"/docs-preview/pr-1680/nodes/mainnet#integrations","740":"/docs-preview/pr-1680/nodes/mainnet#production-rpc-endpoints","741":"/docs-preview/pr-1680/nodes/mainnet#consensus-nodes","742":"/docs-preview/pr-1680/nodes/mainnet#community-consensus-rpc-endpoints","743":"/docs-preview/pr-1680/nodes/mainnet#community-api-endpoints","744":"/docs-preview/pr-1680/nodes/mainnet#community-grpc-endpoints","745":"/docs-preview/pr-1680/nodes/mainnet#community-websocket-endpoints","746":"/docs-preview/pr-1680/nodes/mainnet#data-availability-nodes","747":"/docs-preview/pr-1680/nodes/mainnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","748":"/docs-preview/pr-1680/nodes/mainnet#community-data-availability-da-grpc-endpoints-for-state-access","749":"/docs-preview/pr-1680/nodes/mainnet#archival-da-rpc-endpoints","750":"/docs-preview/pr-1680/nodes/mainnet#grove-archival-endpoints","751":"/docs-preview/pr-1680/nodes/mainnet#explorers","752":"/docs-preview/pr-1680/nodes/mainnet#analytics","753":"/docs-preview/pr-1680/nodes/mainnet#network-upgrades","754":"/docs-preview/pr-1680/nodes/mocha-testnet#mocha-testnet","755":"/docs-preview/pr-1680/nodes/mocha-testnet#network-details","756":"/docs-preview/pr-1680/nodes/mocha-testnet#software-version-numbers","757":"/docs-preview/pr-1680/nodes/mocha-testnet#rpc-for-da-bridge-full-and-light-nodes","758":"/docs-preview/pr-1680/nodes/mocha-testnet#production-rpc-endpoints","759":"/docs-preview/pr-1680/nodes/mocha-testnet#community-data-availability-da-rpc-endpoints-for-bridge-node-sync","760":"/docs-preview/pr-1680/nodes/mocha-testnet#community-data-availability-da-grpc-endpoints-for-state-access","761":"/docs-preview/pr-1680/nodes/mocha-testnet#community-rpc-endpoints","762":"/docs-preview/pr-1680/nodes/mocha-testnet#community-api-endpoints","763":"/docs-preview/pr-1680/nodes/mocha-testnet#community-grpc-endpoints","764":"/docs-preview/pr-1680/nodes/mocha-testnet#community-bridge-and-full-node-endpoints","765":"/docs-preview/pr-1680/nodes/mocha-testnet#mocha-testnet-faucet","766":"/docs-preview/pr-1680/nodes/mocha-testnet#analytics","767":"/docs-preview/pr-1680/nodes/mocha-testnet#explorers","768":"/docs-preview/pr-1680/nodes/mocha-testnet#network-upgrades","769":"/docs-preview/pr-1680/nodes/overview#overview-to-running-nodes-on-celestia","770":"/docs-preview/pr-1680/nodes/overview#recommended-celestia-node-requirements","771":"/docs-preview/pr-1680/nodes/overview#data-availability-nodes","772":"/docs-preview/pr-1680/nodes/overview#consensus-nodes","773":"/docs-preview/pr-1680/nodes/participate#participate-in-the-celestia-networks","774":"/docs-preview/pr-1680/nodes/participate#mainnet-beta","775":"/docs-preview/pr-1680/nodes/participate#compatible-software-versions-for-mainnet-beta","776":"/docs-preview/pr-1680/nodes/participate#testnets","777":"/docs-preview/pr-1680/nodes/participate#arabica-devnet","778":"/docs-preview/pr-1680/nodes/participate#compatible-software-versions-for-arabica-devnet","779":"/docs-preview/pr-1680/nodes/participate#mocha-testnet","780":"/docs-preview/pr-1680/nodes/participate#compatible-software-versions-for-mocha-testnet","781":"/docs-preview/pr-1680/nodes/participate#network-upgrades","782":"/docs-preview/pr-1680/nodes/quick-start#quick-start-guide","783":"/docs-preview/pr-1680/nodes/quick-start#celestia-node","784":"/docs-preview/pr-1680/nodes/quick-start#celestia-app","785":"/docs-preview/pr-1680/nodes/quick-start#getting-started","786":"/docs-preview/pr-1680/nodes/systemd#setting-up-your-node-as-a-background-process-with-systemd","787":"/docs-preview/pr-1680/nodes/systemd#consensus-nodes","788":"/docs-preview/pr-1680/nodes/systemd#start-the-celestia-app-with-systemd","789":"/docs-preview/pr-1680/nodes/systemd#data-availability-nodes","790":"/docs-preview/pr-1680/nodes/systemd#celestia-full-storage-node","791":"/docs-preview/pr-1680/nodes/systemd#celestia-bridge-node","792":"/docs-preview/pr-1680/nodes/systemd#celestia-light-node","793":"/docs-preview/pr-1680/nodes/validator-node#setting-up-a-celestia-validator-node","794":"/docs-preview/pr-1680/nodes/validator-node#hardware-requirements","795":"/docs-preview/pr-1680/nodes/validator-node#setting-up-a-validator-node","796":"/docs-preview/pr-1680/nodes/validator-node#wallet","797":"/docs-preview/pr-1680/nodes/validator-node#delegate-stake-to-a-validator","798":"/docs-preview/pr-1680/nodes/validator-node#optional-deploy-the-celestia-node","799":"/docs-preview/pr-1680/nodes/validator-node#install-celestia-node","800":"/docs-preview/pr-1680/nodes/validator-node#initialize-the-bridge-node","801":"/docs-preview/pr-1680/nodes/validator-node#run-the-bridge-node","802":"/docs-preview/pr-1680/nodes/validator-node#optional-start-the-bridge-node-with-systemd","803":"/docs-preview/pr-1680/nodes/validator-node#run-the-validator-node","804":"/docs-preview/pr-1680/nodes/validator-node#submit-your-validator-information","805":"/docs-preview/pr-1680/nodes/validator-node#optional-transaction-indexer-configuration-options","806":"/docs-preview/pr-1680/nodes/validator-node#additional-resources","807":"/docs-preview/pr-1680/nodes/validator-node#faq","808":"/docs-preview/pr-1680/nodes/validator-node#_2-3-committed-an-invalid-block-wrong-block-header-version"},"fieldIds":{"title":0,"titles":1,"text":2},"fieldLength":{"0":[3,1,24],"1":[3,3,22],"2":[2,3,69],"3":[2,3,34],"4":[3,3,25],"5":[2,1,32],"6":[5,1,1],"7":[2,5,62],"8":[2,5,114],"9":[2,5,57],"10":[1,5,43],"11":[1,5,39],"12":[2,5,22],"13":[2,7,38],"14":[2,7,57],"15":[3,7,50],"16":[3,7,34],"17":[1,5,47],"18":[5,1,1],"19":[4,5,57],"20":[3,5,1],"21":[2,7,53],"22":[2,7,41],"23":[2,7,110],"24":[2,7,174],"25":[2,7,62],"26":[1,5,45],"27":[2,6,147],"28":[2,5,53],"29":[2,5,17],"30":[4,1,150],"31":[3,4,229],"32":[2,4,69],"33":[4,4,137],"34":[4,4,460],"35":[3,1,31],"36":[3,3,129],"37":[3,3,69],"38":[3,3,72],"39":[3,3,39],"40":[1,6,164],"41":[3,6,124],"42":[1,6,150],"43":[1,6,190],"44":[1,6,170],"45":[3,6,159],"46":[1,6,132],"47":[4,6,145],"48":[9,6,167],"49":[4,1,28],"50":[2,4,64],"51":[2,4,1],"52":[6,6,71],"53":[2,6,70],"54":[1,6,35],"55":[1,6,28],"56":[1,6,48],"57":[3,1,37],"58":[3,3,12],"59":[6,3,44],"60":[8,3,58],"61":[7,3,48],"62":[6,3,23],"63":[2,3,37],"64":[2,1,26],"65":[2,1,143],"66":[8,1,29],"67":[6,8,1],"68":[7,11,47],"69":[7,11,68],"70":[6,8,1],"71":[10,11,81],"72":[5,11,40],"73":[8,1,18],"74":[1,8,14],"75":[4,8,85],"76":[4,12,94],"77":[3,8,51],"78":[4,8,15],"79":[6,1,77],"80":[1,6,52],"81":[1,6,10],"82":[6,7,63],"83":[6,7,58],"84":[8,7,238],"85":[8,7,115],"86":[10,7,74],"87":[12,7,39],"88":[11,7,129],"89":[9,7,238],"90":[10,7,56],"91":[7,7,231],"92":[4,7,49],"93":[1,6,17],"94":[2,7,75],"95":[4,7,32],"96":[2,11,13],"97":[2,11,13],"98":[4,7,48],"99":[4,7,48],"100":[7,1,1],"101":[1,7,20],"102":[4,7,71],"103":[6,7,34],"104":[8,1,1],"105":[1,8,51],"106":[2,8,33],"107":[3,10,174],"108":[3,10,128],"109":[3,10,77],"110":[5,10,86],"111":[2,8,17],"112":[8,1,1],"113":[1,8,33],"114":[1,8,18],"115":[1,8,35],"116":[4,8,103],"117":[4,8,139],"118":[4,8,1],"119":[2,9,51],"120":[4,9,87],"121":[5,8,91],"122":[2,8,28],"123":[4,1,1],"124":[2,4,1],"125":[1,6,9],"126":[3,6,57],"127":[2,6,93],"128":[2,4,43],"129":[1,4,50],"130":[3,4,31],"131":[6,4,124],"132":[4,1,1],"133":[3,4,74],"134":[3,4,149],"135":[2,4,168],"136":[3,6,101],"137":[2,6,115],"138":[3,4,1],"139":[3,7,164],"140":[2,7,1],"141":[4,9,10],"142":[8,9,13],"143":[4,9,39],"144":[3,1,1],"145":[1,3,119],"146":[5,3,101],"147":[3,7,1],"148":[3,7,130],"149":[3,3,72],"150":[5,6,50],"151":[2,11,78],"152":[2,11,56],"153":[14,6,237],"154":[4,6,44],"155":[7,6,13],"156":[2,13,163],"157":[2,13,31],"158":[9,6,35],"159":[2,15,89],"160":[5,6,60],"161":[2,11,108],"162":[2,11,50],"163":[9,3,86],"164":[1,11,54],"165":[1,11,198],"166":[1,11,94],"167":[1,11,47],"168":[1,11,113],"169":[1,11,185],"170":[5,11,136],"171":[5,11,94],"172":[6,11,375],"173":[1,3,58],"174":[4,1,47],"175":[1,4,53],"176":[3,5,23],"177":[5,8,92],"178":[5,8,83],"179":[4,8,41],"180":[4,8,63],"181":[3,5,85],"182":[5,8,31],"183":[6,8,119],"184":[7,8,119],"185":[4,8,15],"186":[4,8,2],"187":[2,4,57],"188":[8,5,70],"189":[9,11,50],"190":[9,11,2],"191":[9,11,42],"192":[7,5,107],"193":[8,10,18],"194":[8,10,27],"195":[2,4,66],"196":[7,5,88],"197":[8,10,36],"198":[8,10,2],"199":[7,5,30],"200":[6,10,82],"201":[8,10,2],"202":[8,10,26],"203":[4,5,79],"204":[5,9,2],"205":[5,9,13],"206":[1,4,48],"207":[1,4,1],"208":[12,5,104],"209":[4,1,14],"210":[3,4,34],"211":[4,7,232],"212":[4,7,104],"213":[7,7,113],"214":[3,13,59],"215":[3,13,61],"216":[3,13,22],"217":[4,7,116],"218":[4,10,40],"219":[2,10,180],"220":[4,7,186],"221":[8,7,36],"222":[5,4,34],"223":[4,9,175],"224":[6,9,176],"225":[4,1,89],"226":[2,4,75],"227":[6,4,92],"228":[3,4,63],"229":[6,1,1],"230":[4,6,119],"231":[3,9,7],"232":[7,6,1],"233":[3,12,40],"234":[3,12,42],"235":[3,12,69],"236":[5,6,126],"237":[4,6,67],"238":[5,9,30],"239":[2,9,17],"240":[2,9,43],"241":[7,1,1],"242":[5,7,86],"243":[4,7,58],"244":[3,7,57],"245":[2,1,32],"246":[7,2,56],"247":[3,2,49],"248":[2,4,34],"249":[1,6,8],"250":[1,6,40],"251":[1,4,22],"252":[1,4,20],"253":[1,4,12],"254":[1,4,12],"255":[2,2,22],"256":[2,1,43],"257":[4,2,1],"258":[3,6,23],"259":[4,6,9],"260":[2,6,10],"261":[5,2,41],"262":[6,2,100],"263":[4,2,1],"264":[5,6,81],"265":[1,6,123],"266":[1,6,107],"267":[6,1,42],"268":[5,6,42],"269":[1,11,56],"270":[5,11,106],"271":[5,11,32],"272":[5,11,33],"273":[6,11,5],"274":[4,6,1],"275":[1,10,16],"276":[3,10,144],"277":[5,10,147],"278":[7,1,14],"279":[1,7,26],"280":[1,7,35],"281":[4,7,103],"282":[4,7,139],"283":[4,7,1],"284":[2,9,62],"285":[2,9,90],"286":[5,7,90],"287":[2,7,27],"288":[2,1,95],"289":[5,1,1],"290":[1,5,37],"291":[2,5,31],"292":[1,5,60],"293":[6,5,52],"294":[6,11,36],"295":[8,11,42],"296":[9,5,69],"297":[5,5,37],"298":[9,5,13],"299":[7,12,11],"300":[7,5,87],"301":[6,12,48],"302":[6,1,88],"303":[2,6,34],"304":[2,8,34],"305":[2,8,26],"306":[5,10,193],"307":[3,10,18],"308":[4,10,70],"309":[2,10,120],"310":[6,8,142],"311":[3,8,97],"312":[3,11,75],"313":[3,8,121],"314":[4,8,270],"315":[5,8,60],"316":[5,8,98],"317":[6,8,32],"318":[6,1,156],"319":[3,6,51],"320":[4,6,15],"321":[2,6,34],"322":[4,1,27],"323":[2,4,66],"324":[4,4,132],"325":[4,4,86],"326":[4,4,101],"327":[7,4,59],"328":[2,4,11],"329":[5,1,18],"330":[2,5,28],"331":[4,5,84],"332":[4,7,27],"333":[3,7,62],"334":[1,7,36],"335":[1,7,28],"336":[6,7,81],"337":[5,1,43],"338":[3,5,109],"339":[2,7,26],"340":[2,5,50],"341":[2,5,35],"342":[5,1,1],"343":[1,5,27],"344":[8,5,39],"345":[8,5,1],"346":[6,12,26],"347":[6,12,36],"348":[2,5,19],"349":[4,7,15],"350":[4,7,16],"351":[5,5,56],"352":[2,1,28],"353":[2,2,46],"354":[1,3,16],"355":[1,3,48],"356":[3,3,19],"357":[2,2,66],"358":[3,3,12],"359":[5,1,26],"360":[1,5,1],"361":[1,6,19],"362":[1,6,66],"363":[2,5,30],"364":[3,5,11],"365":[5,8,55],"366":[5,8,130],"367":[3,8,107],"368":[3,5,39],"369":[2,6,124],"370":[2,6,77],"371":[3,8,67],"372":[2,8,65],"373":[7,10,70],"374":[2,6,118],"375":[4,8,10],"376":[2,6,113],"377":[4,6,74],"378":[1,6,1],"379":[3,7,46],"380":[6,7,43],"381":[4,7,49],"382":[4,7,28],"383":[5,7,107],"384":[2,7,20],"385":[5,7,6],"386":[7,7,72],"387":[2,7,17],"388":[1,7,21],"389":[2,6,35],"390":[2,5,1],"391":[5,7,124],"392":[6,7,21],"393":[1,7,46],"394":[4,1,21],"395":[3,4,83],"396":[5,4,84],"397":[5,4,51],"398":[2,4,57],"399":[8,1,47],"400":[2,8,5],"401":[5,10,73],"402":[5,8,48],"403":[10,8,115],"404":[1,8,22],"405":[2,1,80],"406":[1,2,28],"407":[8,3,145],"408":[2,3,42],"409":[4,2,1],"410":[4,5,38],"411":[4,5,100],"412":[2,5,110],"413":[2,5,232],"414":[2,5,84],"415":[3,5,160],"416":[2,2,60],"417":[4,1,29],"418":[2,4,63],"419":[4,4,107],"420":[4,4,87],"421":[7,4,57],"422":[2,4,11],"423":[4,1,22],"424":[3,4,106],"425":[5,1,27],"426":[3,5,94],"427":[4,5,26],"428":[4,9,103],"429":[3,12,141],"430":[3,12,152],"431":[3,12,78],"432":[10,9,118],"433":[1,5,11],"434":[6,6,14],"435":[5,6,19],"436":[6,6,100],"437":[9,6,199],"438":[5,6,21],"439":[2,1,53],"440":[3,2,42],"441":[1,2,37],"442":[4,1,21],"443":[8,4,181],"444":[6,4,82],"445":[6,4,100],"446":[3,1,1],"447":[5,3,82],"448":[7,3,73],"449":[9,3,41],"450":[6,3,62],"451":[15,3,80],"452":[8,3,65],"453":[5,3,33],"454":[8,3,70],"455":[10,3,26],"456":[8,3,51],"457":[10,3,73],"458":[11,3,42],"459":[15,3,34],"460":[5,1,69],"461":[5,5,122],"462":[1,9,86],"463":[6,9,122],"464":[5,5,130],"465":[6,5,1],"466":[3,11,120],"467":[4,1,172],"468":[1,1,90],"469":[7,1,158],"470":[3,7,163],"471":[4,1,44],"472":[4,4,1],"473":[5,4,1],"474":[6,8,20],"475":[9,8,15],"476":[5,8,25],"477":[6,8,22],"478":[5,4,1],"479":[6,8,17],"480":[7,8,29],"481":[6,8,22],"482":[5,4,1],"483":[6,8,7],"484":[12,8,13],"485":[5,8,12],"486":[4,8,24],"487":[3,1,1],"488":[2,3,70],"489":[3,3,44],"490":[4,1,60],"491":[7,4,93],"492":[4,4,143],"493":[4,1,1],"494":[5,4,68],"495":[1,4,73],"496":[2,4,1],"497":[2,5,35],"498":[2,5,37],"499":[4,4,82],"500":[1,8,109],"501":[3,1,30],"502":[2,3,34],"503":[2,3,31],"504":[3,1,1],"505":[4,3,33],"506":[3,3,1],"507":[3,4,33],"508":[3,4,68],"509":[3,4,41],"510":[2,4,41],"511":[1,4,1],"512":[3,5,15],"513":[3,5,27],"514":[4,5,9],"515":[2,1,45],"516":[4,2,64],"517":[2,2,1],"518":[3,4,1],"519":[1,2,49],"520":[3,3,37],"521":[3,3,95],"522":[6,3,1],"523":[9,9,39],"524":[8,9,111],"525":[3,2,24],"526":[1,3,41],"527":[1,3,12],"528":[1,2,19],"529":[2,2,22],"530":[6,1,23],"531":[4,6,108],"532":[2,6,30],"533":[5,6,16],"534":[3,7,7],"535":[5,6,1],"536":[3,8,17],"537":[4,8,102],"538":[4,8,112],"539":[9,9,49],"540":[7,9,30],"541":[7,8,23],"542":[3,1,102],"543":[3,3,27],"544":[2,3,19],"545":[4,5,52],"546":[2,3,19],"547":[2,3,47],"548":[1,3,175],"549":[2,4,89],"550":[3,3,28],"551":[4,3,28],"552":[3,3,24],"553":[6,3,38],"554":[6,3,93],"555":[1,1,41],"556":[1,1,80],"557":[1,1,243],"558":[2,1,52],"559":[1,1,63],"560":[1,1,40],"561":[2,1,97],"562":[1,1,29],"563":[5,1,135],"564":[2,1,24],"565":[9,1,42],"566":[2,9,18],"567":[5,11,1],"568":[3,15,20],"569":[5,15,79],"570":[5,15,22],"571":[2,15,53],"572":[6,11,17],"573":[4,14,89],"574":[3,14,32],"575":[2,14,20],"576":[5,14,144],"577":[6,14,62],"578":[6,14,42],"579":[6,14,62],"580":[1,9,41],"581":[3,10,50],"582":[3,10,10],"583":[6,10,91],"584":[8,10,39],"585":[5,10,88],"586":[1,9,25],"587":[1,9,20],"588":[6,1,18],"589":[1,6,20],"590":[3,6,57],"591":[3,6,75],"592":[3,1,19],"593":[4,3,110],"594":[5,3,108],"595":[1,3,90],"596":[4,1,82],"597":[3,1,28],"598":[3,3,58],"599":[2,5,23],"600":[2,5,27],"601":[2,5,78],"602":[4,3,80],"603":[1,1,1],"604":[2,1,64],"605":[2,3,48],"606":[1,1,106],"607":[7,1,1],"608":[1,8,99],"609":[1,8,81],"610":[1,8,1],"611":[6,9,58],"612":[5,9,42],"613":[6,9,47],"614":[3,1,81],"615":[4,1,26],"616":[10,1,71],"617":[7,1,109],"618":[7,1,92],"619":[3,7,27],"620":[3,1,1],"621":[3,3,126],"622":[5,3,102],"623":[2,3,39],"624":[3,3,26],"625":[3,1,1],"626":[2,3,12],"627":[3,3,34],"628":[1,4,35],"629":[1,4,1],"630":[1,5,45],"631":[2,5,31],"632":[1,4,1],"633":[3,5,61],"634":[2,1,24],"635":[3,2,30],"636":[5,2,16],"637":[4,6,7],"638":[3,6,8],"639":[5,6,140],"640":[4,2,1],"641":[7,6,34],"642":[3,12,6],"643":[4,12,25],"644":[4,6,25],"645":[4,6,49],"646":[4,6,54],"647":[2,2,50],"648":[4,4,41],"649":[4,4,113],"650":[4,4,72],"651":[4,2,78],"652":[5,2,1],"653":[3,7,22],"654":[5,7,28],"655":[2,12,65],"656":[4,12,56],"657":[3,12,13],"658":[5,7,94],"659":[5,7,90],"660":[1,2,1],"661":[10,3,163],"662":[5,1,16],"663":[1,5,38],"664":[1,5,29],"665":[3,1,71],"666":[1,3,14],"667":[2,3,105],"668":[6,3,77],"669":[6,8,79],"670":[3,8,64],"671":[2,3,1],"672":[4,5,1],"673":[1,3,54],"674":[2,1,24],"675":[2,2,80],"676":[2,2,108],"677":[7,1,31],"678":[5,7,26],"679":[2,7,31],"680":[6,7,16],"681":[3,9,11],"682":[3,7,10],"683":[5,10,1],"684":[5,12,17],"685":[5,12,141],"686":[10,10,50],"687":[7,16,31],"688":[8,10,24],"689":[5,10,32],"690":[3,1,65],"691":[2,3,84],"692":[2,4,112],"693":[3,1,93],"694":[1,3,85],"695":[1,4,180],"696":[3,4,84],"697":[3,4,49],"698":[6,3,52],"699":[2,3,31],"700":[5,5,85],"701":[4,5,44],"702":[3,3,7],"703":[1,3,41],"704":[2,4,37],"705":[5,1,42],"706":[2,5,8],"707":[2,5,11],"708":[3,5,12],"709":[5,5,32],"710":[4,9,38],"711":[4,9,44],"712":[4,9,49],"713":[4,9,29],"714":[4,9,48],"715":[7,9,76],"716":[5,9,74],"717":[4,9,38],"718":[7,9,66],"719":[3,9,42],"720":[6,1,25],"721":[4,6,42],"722":[2,6,30],"723":[5,6,22],"724":[3,7,10],"725":[4,6,37],"726":[4,6,83],"727":[3,8,80],"728":[2,11,38],"729":[9,8,49],"730":[7,13,30],"731":[6,8,15],"732":[3,6,16],"733":[2,1,49],"734":[4,2,66],"735":[2,2,1],"736":[3,2,1],"737":[2,2,31],"738":[2,4,109],"739":[1,2,56],"740":[3,3,59],"741":[2,3,4],"742":[4,5,74],"743":[3,5,55],"744":[3,5,57],"745":[3,5,14],"746":[3,3,6],"747":[10,6,39],"748":[9,6,129],"749":[4,6,37],"750":[3,10,31],"751":[1,2,30],"752":[1,2,26],"753":[2,2,31],"754":[2,1,106],"755":[2,2,1],"756":[3,2,1],"757":[8,2,1],"758":[3,10,59],"759":[10,10,39],"760":[9,10,99],"761":[3,2,67],"762":[3,2,81],"763":[3,2,85],"764":[6,2,33],"765":[3,2,63],"766":[1,2,14],"767":[1,2,32],"768":[2,2,31],"769":[6,1,71],"770":[4,6,1],"771":[3,6,30],"772":[2,6,47],"773":[5,1,1],"774":[2,5,40],"775":[6,7,1],"776":[1,5,12],"777":[2,6,45],"778":[6,8,1],"779":[2,6,48],"780":[6,6,1],"781":[2,5,31],"782":[3,1,25],"783":[2,3,48],"784":[2,3,29],"785":[2,3,76],"786":[10,1,13],"787":[2,10,21],"788":[6,12,113],"789":[3,10,1],"790":[4,13,72],"791":[3,13,106],"792":[3,13,93],"793":[6,1,23],"794":[2,6,30],"795":[5,6,25],"796":[1,6,8],"797":[5,6,113],"798":[5,6,48],"799":[3,10,10],"800":[4,10,47],"801":[4,10,8],"802":[7,12,23],"803":[4,6,192],"804":[4,6,16],"805":[5,6,19],"806":[2,6,14],"807":[1,6,1],"808":[10,7,163]},"averageFieldLength":[3.8800988875154534,5.7045735475896215,56.93325092707051],"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":"Community calendar","titles":[]},"6":{"title":"Celestia.org Code of Conduct","titles":[]},"7":{"title":"Our Pledge","titles":["Celestia.org Code of Conduct"]},"8":{"title":"Our Standards","titles":["Celestia.org Code of Conduct"]},"9":{"title":"Enforcement Responsibilities","titles":["Celestia.org Code of Conduct"]},"10":{"title":"Scope","titles":["Celestia.org Code of Conduct"]},"11":{"title":"Enforcement","titles":["Celestia.org Code of Conduct"]},"12":{"title":"Enforcement Guidelines","titles":["Celestia.org Code of Conduct"]},"13":{"title":"1. Correction","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"14":{"title":"2. Warning","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"15":{"title":"3. Temporary Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"16":{"title":"4. Permanent Ban","titles":["Celestia.org Code of Conduct","Enforcement Guidelines"]},"17":{"title":"Attribution","titles":["Celestia.org Code of Conduct"]},"18":{"title":"The Celestia Foundation Delegation Program","titles":[]},"19":{"title":"Objectives of the program","titles":["The Celestia Foundation Delegation Program"]},"20":{"title":"Foundation delegation process","titles":["The Celestia Foundation Delegation Program"]},"21":{"title":"Program launch","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"22":{"title":"Cohort process","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"23":{"title":"Key Points","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"24":{"title":"Eligibility criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"25":{"title":"Undelegation criteria","titles":["The Celestia Foundation Delegation Program","Foundation delegation process"]},"26":{"title":"Application","titles":["The Celestia Foundation Delegation Program"]},"27":{"title":"Application details","titles":["The Celestia Foundation Delegation Program","Application"]},"28":{"title":"Cohort information","titles":["The Celestia Foundation Delegation Program"]},"29":{"title":"Feedback process","titles":["The Celestia Foundation Delegation Program"]},"30":{"title":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS","titles":[]},"31":{"title":"1. General Terms","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"32":{"title":"2. Taxes","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"33":{"title":"3. Supplemental Privacy Information","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"34":{"title":"4. Certain Additional Representations","titles":["SUPPLEMENTAL INCENTIVIZED TESTNET TERMS"]},"35":{"title":"Modular Meetup guide","titles":[]},"36":{"title":"Before the Meetup","titles":["Modular Meetup guide"]},"37":{"title":"During the Meetup","titles":["Modular Meetup guide"]},"38":{"title":"After the Meetup","titles":["Modular Meetup guide"]},"39":{"title":"Logistics and guidance","titles":["Modular Meetup guide"]},"40":{"title":"Venue","titles":["Modular Meetup guide","Logistics and guidance"]},"41":{"title":"Catering and refreshments","titles":["Modular Meetup guide","Logistics and guidance"]},"42":{"title":"Audience","titles":["Modular Meetup guide","Logistics and guidance"]},"43":{"title":"Speakers","titles":["Modular Meetup guide","Logistics and guidance"]},"44":{"title":"Sponsors","titles":["Modular Meetup guide","Logistics and guidance"]},"45":{"title":"Communications and marketing","titles":["Modular Meetup guide","Logistics and guidance"]},"46":{"title":"Recording","titles":["Modular Meetup guide","Logistics and guidance"]},"47":{"title":"Utilizing Meetup.com platform","titles":["Modular Meetup guide","Logistics and guidance"]},"48":{"title":"Onboarding questions for community members joining a Modular Meetup","titles":["Modular Meetup guide","Logistics and guidance"]},"49":{"title":"Celestia Modular Meetup program","titles":[]},"50":{"title":"Program description","titles":["Celestia Modular Meetup program"]},"51":{"title":"Important info","titles":["Celestia Modular Meetup program"]},"52":{"title":"Celestia.org Community Code of Conduct","titles":["Celestia Modular Meetup program","Important info"]},"53":{"title":"Signup form","titles":["Celestia Modular Meetup program","Important info"]},"54":{"title":"Emails","titles":["Celestia Modular Meetup program","Important info"]},"55":{"title":"Discord","titles":["Celestia Modular Meetup program","Important info"]},"56":{"title":"Materials","titles":["Celestia Modular Meetup program","Important info"]},"57":{"title":"Modular Meetup Toolkit","titles":[]},"58":{"title":"Celestia branding guidelines","titles":["Modular Meetup Toolkit"]},"59":{"title":"Sample “Introduction to Modularity” workshop presentation","titles":["Modular Meetup Toolkit"]},"60":{"title":"Sample “Run a Celestia light node” workshop presentation","titles":["Modular Meetup Toolkit"]},"61":{"title":"Sample “Deploy a Sovereign Rollup” workshop presentation","titles":["Modular Meetup Toolkit"]},"62":{"title":"Sample “Modular Meetup Introduction” workshop presentation","titles":["Modular Meetup Toolkit"]},"63":{"title":"Swag logistics","titles":["Modular Meetup Toolkit"]},"64":{"title":"Community overview","titles":[]},"65":{"title":"Speaker list","titles":[]},"66":{"title":"Bridging in and out of your Orbit rollup","titles":[]},"67":{"title":"Bridge in (deposit) to your rollup","titles":["Bridging in and out of your Orbit rollup"]},"68":{"title":"Step 1: Add your custom chain config","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"69":{"title":"Step 2: Deposit to your Orbit rollup","titles":["Bridging in and out of your Orbit rollup","Bridge in (deposit) to your rollup"]},"70":{"title":"Bridge out (withdrawal) from your rollup","titles":["Bridging in and out of your Orbit rollup"]},"71":{"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"]},"72":{"title":"Step 2: Claim your withdrawal","titles":["Bridging in and out of your Orbit rollup","Bridge out (withdrawal) from your rollup"]},"73":{"title":"Deploy a dapp on your Arbitrum rollup devnet","titles":[]},"74":{"title":"Dependencies","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"75":{"title":"Setup and contract deployment","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"76":{"title":"Interact with the contract","titles":["Deploy a dapp on your Arbitrum rollup devnet","Setup and contract deployment"]},"77":{"title":"Update the frontend","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"78":{"title":"Interact with the frontend","titles":["Deploy a dapp on your Arbitrum rollup devnet"]},"79":{"title":"Quickstart: Deploy an Arbitrum Orbit rollup","titles":[]},"80":{"title":"Prerequisites","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"81":{"title":"Setup","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"82":{"title":"Step 1: Acquire Arbitrum Sepolia ETH","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"83":{"title":"Step 2: Pick your deployment type","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"84":{"title":"Step 3: Configure your Orbit chain\'s deployment","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"85":{"title":"Step 3: Review & Deploy your Orbit chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"86":{"title":"Step 4: Download your chain\'s configuration files and launch your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"87":{"title":"Step 5: Clone the setup script repository and add your configuration files","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"88":{"title":"Step 6: Pick an L2 RPC URL for the Batch Poster","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"89":{"title":"Step 7: Run your light node for Mocha testnet","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"90":{"title":"Step 8: Run your chain\'s node and block explorer","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"91":{"title":"Step 9: Finish setting up your chain","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"92":{"title":"Congratulations with Celestia underneath","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Setup"]},"93":{"title":"Appendix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup"]},"94":{"title":"Compatibility matrix","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"95":{"title":"Blobstream X contract deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"96":{"title":"Arbitrum Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"97":{"title":"Base Sepolia","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix","Blobstream X contract deployments"]},"98":{"title":"Arbitrum Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"99":{"title":"Base Sepolia additional deployments","titles":["Quickstart: Deploy an Arbitrum Orbit rollup","Appendix"]},"100":{"title":"Running a full node and/or validator","titles":[]},"101":{"title":"Prerequisites","titles":["Running a full node and/or validator"]},"102":{"title":"Running a full node","titles":["Running a full node and/or validator"]},"103":{"title":"Running a full node with validation","titles":["Running a full node and/or validator"]},"104":{"title":"Introduction to Arbitrum rollups with Celestia as DA","titles":[]},"105":{"title":"Overview","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"106":{"title":"Key components","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"107":{"title":"DA provider implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"108":{"title":"Preimage Oracle Implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"109":{"title":"Blobstream X implementation","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"110":{"title":"Ethereum fallback mechanism in Nitro","titles":["Introduction to Arbitrum rollups with Celestia as DA","Key components"]},"111":{"title":"Next steps","titles":["Introduction to Arbitrum rollups with Celestia as DA"]},"112":{"title":"Deploy a smart contract to your Arbitrum rollup","titles":[]},"113":{"title":"Overview","titles":["Deploy a smart contract to your Arbitrum rollup"]},"114":{"title":"Prerequisites","titles":["Deploy a smart contract to your Arbitrum rollup"]},"115":{"title":"Setup","titles":["Deploy a smart contract to your Arbitrum rollup"]},"116":{"title":"Create your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"117":{"title":"Test your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"118":{"title":"Deploying your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"119":{"title":"Funded accounts","titles":["Deploy a smart contract to your Arbitrum rollup","Deploying your smart contract"]},"120":{"title":"Using our Arbitrum devnet","titles":["Deploy a smart contract to your Arbitrum rollup","Deploying your smart contract"]},"121":{"title":"Interacting with your smart contract","titles":["Deploy a smart contract to your Arbitrum rollup"]},"122":{"title":"Next steps","titles":["Deploy a smart contract to your Arbitrum rollup"]},"123":{"title":"Integrate with Blobstream contracts","titles":[]},"124":{"title":"Getting started","titles":["Integrate with Blobstream contracts"]},"125":{"title":"Prerequisites","titles":["Integrate with Blobstream contracts","Getting started"]},"126":{"title":"Installing Blobstream contracts","titles":["Integrate with Blobstream contracts","Getting started"]},"127":{"title":"Example usage","titles":["Integrate with Blobstream contracts","Getting started"]},"128":{"title":"Data structures","titles":["Integrate with Blobstream contracts"]},"129":{"title":"Interface","titles":["Integrate with Blobstream contracts"]},"130":{"title":"Querying the proof","titles":["Integrate with Blobstream contracts"]},"131":{"title":"Verifying data inclusion for fraud proofs","titles":["Integrate with Blobstream contracts"]},"132":{"title":"Integrate with Blobstream client","titles":[]},"133":{"title":"Blobstream demo rollup","titles":["Integrate with Blobstream client"]},"134":{"title":"Defining a chain","titles":["Integrate with Blobstream client"]},"135":{"title":"Rollup sequencer","titles":["Integrate with Blobstream client"]},"136":{"title":"Committing to data","titles":["Integrate with Blobstream client","Rollup sequencer"]},"137":{"title":"Creating blocks","titles":["Integrate with Blobstream client","Rollup sequencer"]},"138":{"title":"Rollup full node","titles":["Integrate with Blobstream client"]},"139":{"title":"Downloading the block","titles":["Integrate with Blobstream client","Rollup full node"]},"140":{"title":"More documentation","titles":["Integrate with Blobstream client","Rollup full node"]},"141":{"title":"Proving inclusion via Blobstream","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"142":{"title":"Submitting block data to Celestia via light node","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"143":{"title":"Posting headers to Ethereum","titles":["Integrate with Blobstream client","Rollup full node","More documentation"]},"144":{"title":"Blobstream proofs queries","titles":[]},"145":{"title":"Prerequisites","titles":["Blobstream proofs queries"]},"146":{"title":"Overview of the proof queries","titles":["Blobstream proofs queries"]},"147":{"title":"The Celestia square","titles":["Blobstream proofs queries","Overview of the proof queries"]},"148":{"title":"The commitment scheme","titles":["Blobstream proofs queries","Overview of the proof queries"]},"149":{"title":"Hands-on demonstration","titles":["Blobstream proofs queries"]},"150":{"title":"1. Data root inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"151":{"title":"HTTP query","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"152":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","1. Data root inclusion proof"]},"153":{"title":"Full example of proving that a Celestia block was committed to by Blobstream contract","titles":["Blobstream proofs queries","Hands-on demonstration"]},"154":{"title":"2. Transaction inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"155":{"title":"Transaction inclusion proof using the transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"156":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"157":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Transaction inclusion proof using the transaction hash"]},"158":{"title":"Blob inclusion proof using the corresponding PFB transaction hash","titles":["Blobstream proofs queries","Hands-on demonstration"]},"159":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Blob inclusion proof using the corresponding PFB transaction hash"]},"160":{"title":"Specific share range inclusion proof","titles":["Blobstream proofs queries","Hands-on demonstration"]},"161":{"title":"HTTP request","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"162":{"title":"Golang client","titles":["Blobstream proofs queries","Hands-on demonstration","Specific share range inclusion proof"]},"163":{"title":"Converting the proofs to be usable in the DAVerifier library","titles":["Blobstream proofs queries"]},"164":{"title":"data","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"165":{"title":"shareProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"166":{"title":"namespace","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"167":{"title":"rowRoots","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"168":{"title":"rowProofs","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"169":{"title":"attestationProof","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"170":{"title":"Querying the proof\'s tupleRootNonce","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"171":{"title":"Listening for new data commitments","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"172":{"title":"Example rollup that uses the DAVerifier","titles":["Blobstream proofs queries","Converting the proofs to be usable in the DAVerifier library"]},"173":{"title":"Conclusion","titles":["Blobstream proofs queries"]},"174":{"title":"Introduction to Blobstream rollups","titles":[]},"175":{"title":"Concepts","titles":["Introduction to Blobstream rollups"]},"176":{"title":"Blob share commitment","titles":["Introduction to Blobstream rollups","Concepts"]},"177":{"title":"Blob share commitment: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"178":{"title":"Blob share commitment: Compact proofs","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"179":{"title":"Blob share commitment: Pros","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"180":{"title":"Blob share commitment: Cons","titles":["Introduction to Blobstream rollups","Concepts","Blob share commitment"]},"181":{"title":"Sequence of spans","titles":["Introduction to Blobstream rollups","Concepts"]},"182":{"title":"Sequence of spans: Proof details","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"183":{"title":"Sequence of spans: Proving unavailable data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"184":{"title":"Sequence of spans: Proving inclusion of some data","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"185":{"title":"Sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"186":{"title":"Sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Concepts","Sequence of spans"]},"187":{"title":"Optimistic rollups","titles":["Introduction to Blobstream rollups"]},"188":{"title":"Optimistic rollups that use a sequence of spans","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"189":{"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"]},"190":{"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"]},"191":{"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"]},"192":{"title":"Optimistic rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Optimistic rollups"]},"193":{"title":"Optimistic rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"194":{"title":"Optimistic rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Optimistic rollups","Optimistic rollups that use blob share commitments"]},"195":{"title":"Zk-rollups","titles":["Introduction to Blobstream rollups"]},"196":{"title":"Zk-rollups that use sequence of spans","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"197":{"title":"Zk-rollups that use sequence of spans: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"198":{"title":"Zk-rollups that use sequence of spans: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use sequence of spans"]},"199":{"title":"Zk-rollups that use blob share commitments","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"200":{"title":"Protobuf deserialization inside a zk-circuit","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"201":{"title":"Zk-rollups that use blob share commitments: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"202":{"title":"Zk-rollups that use blob share commitments: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Zk-rollups that use blob share commitments"]},"203":{"title":"Heavy merkle proofs usage","titles":["Introduction to Blobstream rollups","Zk-rollups"]},"204":{"title":"heavy merkle proofs usage: Pros","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"205":{"title":"heavy merkle proofs usage: Cons","titles":["Introduction to Blobstream rollups","Zk-rollups","Heavy merkle proofs usage"]},"206":{"title":"Conclusion","titles":["Introduction to Blobstream rollups"]},"207":{"title":"FAQ","titles":["Introduction to Blobstream rollups"]},"208":{"title":"Should I use the Celestia transaction hash to reference the rollup data?","titles":["Introduction to Blobstream rollups","FAQ"]},"209":{"title":"New Blobstream X deployments","titles":[]},"210":{"title":"Deploying the contracts","titles":["New Blobstream X deployments"]},"211":{"title":"Deploy a new SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"212":{"title":"Deploy the function verifiers","titles":["New Blobstream X deployments","Deploying the contracts"]},"213":{"title":"Register the function verifier in the deployed SuccinctGateway","titles":["New Blobstream X deployments","Deploying the contracts"]},"214":{"title":"Enable prover whitelisting","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"215":{"title":"Set Whitelist Status","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"216":{"title":"Add Custom Prover","titles":["New Blobstream X deployments","Deploying the contracts","Register the function verifier in the deployed SuccinctGateway"]},"217":{"title":"Deploy the BlobstreamX contract","titles":["New Blobstream X deployments","Deploying the contracts"]},"218":{"title":"Querying the trusted hash","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"219":{"title":"Deployment instructions","titles":["New Blobstream X deployments","Deploying the contracts","Deploy the BlobstreamX contract"]},"220":{"title":"Run a local prover","titles":["New Blobstream X deployments","Deploying the contracts"]},"221":{"title":"Run a proof replayer from an existing deployment","titles":["New Blobstream X deployments","Deploying the contracts"]},"222":{"title":"Optional: Regenerating the downloaded artifacts","titles":["New Blobstream X deployments"]},"223":{"title":"Regenerate the verifier-build","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"224":{"title":"Build the circuits and function verifiers","titles":["New Blobstream X deployments","Optional: Regenerating the downloaded artifacts"]},"225":{"title":"Requesting data commitment ranges","titles":[]},"226":{"title":"Local proving","titles":["Requesting data commitment ranges"]},"227":{"title":"Request proofs from the Succinct platform","titles":["Requesting data commitment ranges"]},"228":{"title":"Request proofs onchain","titles":["Requesting data commitment ranges"]},"229":{"title":"Blobstream: Streaming modular DA to Ethereum","titles":[]},"230":{"title":"What is Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"231":{"title":"Implementations of Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","What is Blobstream?"]},"232":{"title":"Blobstream vs. data availability committees (DACs)","titles":["Blobstream: Streaming modular DA to Ethereum"]},"233":{"title":"Decentralization and security","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"234":{"title":"Mechanism of verification","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"235":{"title":"Flexibility and scalability","titles":["Blobstream: Streaming modular DA to Ethereum","Blobstream vs. data availability committees (DACs)"]},"236":{"title":"What is SP1 Blobstream?","titles":["Blobstream: Streaming modular DA to Ethereum"]},"237":{"title":"Integrate with SP1 Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum"]},"238":{"title":"How to integrate with Blobstream","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"239":{"title":"Blobstream rollups","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"240":{"title":"Deployed contracts","titles":["Blobstream: Streaming modular DA to Ethereum","Integrate with SP1 Blobstream"]},"241":{"title":"BlobstreamX: the previous zk implementation of Blobstream","titles":[]},"242":{"title":"What is Blobstream X?","titles":["BlobstreamX: the previous zk implementation of Blobstream"]},"243":{"title":"How Blobstream X works","titles":["BlobstreamX: the previous zk implementation of Blobstream"]},"244":{"title":"Deploy Blobstream X","titles":["BlobstreamX: the previous zk implementation of Blobstream"]},"245":{"title":"Bubs testnet","titles":[]},"246":{"title":"Built with the OP Stack and Celestia","titles":["Bubs testnet"]},"247":{"title":"Building on Bubs","titles":["Bubs testnet"]},"248":{"title":"RPC URLs","titles":["Bubs testnet","Building on Bubs"]},"249":{"title":"HTTPS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"250":{"title":"WSS","titles":["Bubs testnet","Building on Bubs","RPC URLs"]},"251":{"title":"Bridge","titles":["Bubs testnet","Building on Bubs"]},"252":{"title":"Faucet","titles":["Bubs testnet","Building on Bubs"]},"253":{"title":"Explorer","titles":["Bubs testnet","Building on Bubs"]},"254":{"title":"Status","titles":["Bubs testnet","Building on Bubs"]},"255":{"title":"Next steps","titles":["Bubs testnet"]},"256":{"title":"Build whatever","titles":[]},"257":{"title":"Quickstart - Building on Celestia","titles":["Build whatever"]},"258":{"title":"Choose a framework","titles":["Build whatever","Quickstart - Building on Celestia"]},"259":{"title":"Rollups as a Service","titles":["Build whatever","Quickstart - Building on Celestia"]},"260":{"title":"Smart contracts","titles":["Build whatever","Quickstart - Building on Celestia"]},"261":{"title":"What is a rollup?","titles":["Build whatever"]},"262":{"title":"What is a modular blockchain?","titles":["Build whatever"]},"263":{"title":"Benefits of modular blockchains","titles":["Build whatever"]},"264":{"title":"Ease of deploying a chain","titles":["Build whatever","Benefits of modular blockchains"]},"265":{"title":"Scaling","titles":["Build whatever","Benefits of modular blockchains"]},"266":{"title":"Customizability","titles":["Build whatever","Benefits of modular blockchains"]},"267":{"title":"Create a wallet with celestia-node","titles":[]},"268":{"title":"Using the cel-key utility","titles":["Create a wallet with celestia-node"]},"269":{"title":"Installation","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"270":{"title":"Steps for generating node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"271":{"title":"Steps for exporting node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"272":{"title":"Steps for importing node keys","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"273":{"title":"View all options for cel-key","titles":["Create a wallet with celestia-node","Using the cel-key utility"]},"274":{"title":"Docker and cel-key","titles":["Create a wallet with celestia-node"]},"275":{"title":"Prerequisites","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"276":{"title":"Running your node","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"277":{"title":"Mounting existing keys to container","titles":["Create a wallet with celestia-node","Docker and cel-key"]},"278":{"title":"Deploy a smart contract on Bubs testnet","titles":[]},"279":{"title":"Dependencies","titles":["Deploy a smart contract on Bubs testnet"]},"280":{"title":"Setup","titles":["Deploy a smart contract on Bubs testnet"]},"281":{"title":"Create your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"282":{"title":"Test your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"283":{"title":"Deploying your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"284":{"title":"Using Anvil","titles":["Deploy a smart contract on Bubs testnet","Deploying your smart contract"]},"285":{"title":"Using Bubs","titles":["Deploy a smart contract on Bubs testnet","Deploying your smart contract"]},"286":{"title":"Interacting with your smart contract","titles":["Deploy a smart contract on Bubs testnet"]},"287":{"title":"Next steps","titles":["Deploy a smart contract on Bubs testnet"]},"288":{"title":"Ethereum fallback","titles":[]},"289":{"title":"FeeGrant module for blobs submission","titles":[]},"290":{"title":"Overview","titles":["FeeGrant module for blobs submission"]},"291":{"title":"Pre-requisites","titles":["FeeGrant module for blobs submission"]},"292":{"title":"Introduction","titles":["FeeGrant module for blobs submission"]},"293":{"title":"Granting fee allowances using celestia-node","titles":["FeeGrant module for blobs submission"]},"294":{"title":"FeeGrant module implementation in celestia-node","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"295":{"title":"Grant permission for an allowance as a granter","titles":["FeeGrant module for blobs submission","Granting fee allowances using celestia-node"]},"296":{"title":"Using a FeeGrant allowance as a grantee in celestia-node","titles":["FeeGrant module for blobs submission"]},"297":{"title":"Checking account balances after submission","titles":["FeeGrant module for blobs submission"]},"298":{"title":"Optional: Revoke permission for a FeeGrant allowance as a granter","titles":["FeeGrant module for blobs submission"]},"299":{"title":"Optional: Submitting a blob from file input","titles":["FeeGrant module for blobs submission","Optional: Revoke permission for a FeeGrant allowance as a granter"]},"300":{"title":"Optional: Granting fee allowances using celestia-appd","titles":["FeeGrant module for blobs submission"]},"301":{"title":"Optional: Checking the granter\'s account","titles":["FeeGrant module for blobs submission","Optional: Granting fee allowances using celestia-appd"]},"302":{"title":"Full stack modular blockchain development guide","titles":[]},"303":{"title":"Getting started","titles":["Full stack modular blockchain development guide"]},"304":{"title":"Pre-requisites","titles":["Full stack modular blockchain development guide","Getting started"]},"305":{"title":"Project setup","titles":["Full stack modular blockchain development guide","Getting started"]},"306":{"title":"Updating the contract and tests","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"307":{"title":"Running the test","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"308":{"title":"Updating the deployment script","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"309":{"title":"Deploying locally","titles":["Full stack modular blockchain development guide","Getting started","Project setup"]},"310":{"title":"Deploying to the Ethermint Sovereign Rollup","titles":["Full stack modular blockchain development guide","Getting started"]},"311":{"title":"Building the frontend","titles":["Full stack modular blockchain development guide","Getting started"]},"312":{"title":"Configuring environment variables","titles":["Full stack modular blockchain development guide","Getting started","Building the frontend"]},"313":{"title":"Configuring the entrypoint","titles":["Full stack modular blockchain development guide","Getting started"]},"314":{"title":"Creating and reading posts","titles":["Full stack modular blockchain development guide","Getting started"]},"315":{"title":"Adding Ethermint Chain to MetaMask","titles":["Full stack modular blockchain development guide","Getting started"]},"316":{"title":"Testing it out on Ethermint","titles":["Full stack modular blockchain development guide","Getting started"]},"317":{"title":"Now give it a spin 🌀","titles":["Full stack modular blockchain development guide","Getting started"]},"318":{"title":"Deploying a dapp on Bubs testnet","titles":[]},"319":{"title":"Update the frontend","titles":["Deploying a dapp on Bubs testnet"]},"320":{"title":"Interact with the frontend","titles":["Deploying a dapp on Bubs testnet"]},"321":{"title":"Next steps","titles":["Deploying a dapp on Bubs testnet"]},"322":{"title":"Golang client library tutorial","titles":[]},"323":{"title":"Project setup","titles":["Golang client library tutorial"]},"324":{"title":"Submitting and retrieving blobs","titles":["Golang client library tutorial"]},"325":{"title":"Subscribing to new blobs","titles":["Golang client library tutorial"]},"326":{"title":"Subscribing to new headers","titles":["Golang client library tutorial"]},"327":{"title":"Fetching an Extended Data Square (EDS)","titles":["Golang client library tutorial"]},"328":{"title":"API documentation","titles":["Golang client library tutorial"]},"329":{"title":"Integrate Celestia for service providers","titles":[]},"330":{"title":"Getting started","titles":["Integrate Celestia for service providers"]},"331":{"title":"Celestia service provider notes","titles":["Integrate Celestia for service providers"]},"332":{"title":"Custody and key management","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"333":{"title":"RPC and querying","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"334":{"title":"Compatibility","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"335":{"title":"Syncing","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"336":{"title":"Notable exceptions relative to other blockchains","titles":["Integrate Celestia for service providers","Celestia service provider notes"]},"337":{"title":"Introduction to OP Stack integration","titles":[]},"338":{"title":"About the integration","titles":["Introduction to OP Stack integration"]},"339":{"title":"GitHub repository","titles":["Introduction to OP Stack integration","About the integration"]},"340":{"title":"Category contents","titles":["Introduction to OP Stack integration"]},"341":{"title":"Next steps","titles":["Introduction to OP Stack integration"]},"342":{"title":"MultiAccounts feature for blobs submission","titles":[]},"343":{"title":"Overview","titles":["MultiAccounts feature for blobs submission"]},"344":{"title":"Running a node with a different default key name","titles":["MultiAccounts feature for blobs submission"]},"345":{"title":"Submitting blobs with a different signer/key name","titles":["MultiAccounts feature for blobs submission"]},"346":{"title":"Option 1: Submit passing key name","titles":["MultiAccounts feature for blobs submission","Submitting blobs with a different signer/key name"]},"347":{"title":"Option 2: Submit passing signer address","titles":["MultiAccounts feature for blobs submission","Submitting blobs with a different signer/key name"]},"348":{"title":"Key management","titles":["MultiAccounts feature for blobs submission"]},"349":{"title":"Creating a new key","titles":["MultiAccounts feature for blobs submission","Key management"]},"350":{"title":"Importing an existing key","titles":["MultiAccounts feature for blobs submission","Key management"]},"351":{"title":"Optional flags for write transactions","titles":["MultiAccounts feature for blobs submission"]},"352":{"title":"Node API","titles":[]},"353":{"title":"RPC API","titles":["Node API"]},"354":{"title":"Library","titles":["Node API","RPC API"]},"355":{"title":"RPC","titles":["Node API","RPC API"]},"356":{"title":"RPC API tutorial","titles":["Node API","RPC API"]},"357":{"title":"Gateway API","titles":["Node API"]},"358":{"title":"Gateway API tutorial","titles":["Node API","Gateway API"]},"359":{"title":"Celestia-node RPC CLI tutorial","titles":[]},"360":{"title":"Introduction","titles":["Celestia-node RPC CLI tutorial"]},"361":{"title":"Blobs","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"362":{"title":"Namespaces","titles":["Celestia-node RPC CLI tutorial","Introduction"]},"363":{"title":"Hardware requirements","titles":["Celestia-node RPC CLI tutorial"]},"364":{"title":"Setting up dependencies","titles":["Celestia-node RPC CLI tutorial"]},"365":{"title":"Instantiate a Celestia light node","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"366":{"title":"Connect to a core endpoint","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"367":{"title":"Keys and wallets","titles":["Celestia-node RPC CLI tutorial","Setting up dependencies"]},"368":{"title":"RPC CLI guide","titles":["Celestia-node RPC CLI tutorial"]},"369":{"title":"Command formatting","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"370":{"title":"Basic flags","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"371":{"title":"Auth token 🔐","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"372":{"title":"Node store","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags"]},"373":{"title":"Auth token on custom or private network","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Basic flags","Node store"]},"374":{"title":"Submitting data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"375":{"title":"Optional: Submit with curl","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Submitting data"]},"376":{"title":"Retrieving data","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"377":{"title":"Setting the gas price","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"378":{"title":"Examples","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"379":{"title":"Check your balance","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"380":{"title":"Check the balance of another address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"381":{"title":"Get your node ID","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"382":{"title":"Get your account address","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"383":{"title":"Get block header by height","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"384":{"title":"Combined commands","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"385":{"title":"Get data availability sampler stats","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"386":{"title":"Transfer balance of utia to another account","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"387":{"title":"API version","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"388":{"title":"Help","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide","Examples"]},"389":{"title":"Advanced example","titles":["Celestia-node RPC CLI tutorial","RPC CLI guide"]},"390":{"title":"Additional resources","titles":["Celestia-node RPC CLI tutorial"]},"391":{"title":"Submitting a blob using curl","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"392":{"title":"Post an SVG as a PFB","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"393":{"title":"Troubleshooting","titles":["Celestia-node RPC CLI tutorial","Additional resources"]},"394":{"title":"Optimism devnet deep dive","titles":[]},"395":{"title":"Find a transaction","titles":["Optimism devnet deep dive"]},"396":{"title":"Read the transaction call data","titles":["Optimism devnet deep dive"]},"397":{"title":"Find the data on Celestia","titles":["Optimism devnet deep dive"]},"398":{"title":"Span batches","titles":["Optimism devnet deep dive"]},"399":{"title":"Run an OP Stack rollup with Celestia underneath","titles":[]},"400":{"title":"Dependency setup","titles":["Run an OP Stack rollup with Celestia underneath"]},"401":{"title":"Setting up your light node","titles":["Run an OP Stack rollup with Celestia underneath","Dependency setup"]},"402":{"title":"Deploying a devnet to Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"403":{"title":"Deploying a testnet to an L1 (or L2) and Mocha","titles":["Run an OP Stack rollup with Celestia underneath"]},"404":{"title":"Congratulations","titles":["Run an OP Stack rollup with Celestia underneath"]},"405":{"title":"Prompt scavenger","titles":[]},"406":{"title":"Dependencies","titles":["Prompt scavenger"]},"407":{"title":"Install Celestia Node and run a light node","titles":["Prompt scavenger","Dependencies"]},"408":{"title":"OpenAI key","titles":["Prompt scavenger","Dependencies"]},"409":{"title":"Building the Prompt Scavenger","titles":["Prompt scavenger"]},"410":{"title":"Initialize your Go project","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"411":{"title":"Build your import statements","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"412":{"title":"Main function","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"413":{"title":"Utility functions","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"414":{"title":"Prompting ChatGPT","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"415":{"title":"Wrapping things up","titles":["Prompt scavenger","Building the Prompt Scavenger"]},"416":{"title":"Next steps","titles":["Prompt scavenger"]},"417":{"title":"Rust client library tutorial","titles":[]},"418":{"title":"Project setup","titles":["Rust client library tutorial"]},"419":{"title":"Submitting and retrieving blobs","titles":["Rust client library tutorial"]},"420":{"title":"Subscribing to new headers","titles":["Rust client library tutorial"]},"421":{"title":"Fetching an Extended Data Square (EDS)","titles":["Rust client library tutorial"]},"422":{"title":"API documentation","titles":["Rust client library tutorial"]},"423":{"title":"New SP1 Blobstream deployments","titles":[]},"424":{"title":"Deploying the contracts","titles":["New SP1 Blobstream deployments"]},"425":{"title":"Submitting data blobs to Celestia","titles":[]},"426":{"title":"Maximum blob size","titles":["Submitting data blobs to Celestia"]},"427":{"title":"Fee market and mempool","titles":["Submitting data blobs to Celestia"]},"428":{"title":"Fees and gas limits","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"429":{"title":"Estimating PFB gas","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"430":{"title":"Gas fee calculation","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"431":{"title":"Estimating gas programmatically","titles":["Submitting data blobs to Celestia","Fee market and mempool","Fees and gas limits"]},"432":{"title":"Submitting multiple transactions in one block from the same account","titles":["Submitting data blobs to Celestia","Fee market and mempool"]},"433":{"title":"API","titles":["Submitting data blobs to Celestia"]},"434":{"title":"The celestia-app consensus node CLI","titles":["Submitting data blobs to Celestia","API"]},"435":{"title":"The celestia-node light node CLI","titles":["Submitting data blobs to Celestia","API"]},"436":{"title":"The celestia-node API golang client","titles":["Submitting data blobs to Celestia","API"]},"437":{"title":"GRPC to a consensus node via the user package","titles":["Submitting data blobs to Celestia","API"]},"438":{"title":"RPC to a celestia-node","titles":["Submitting data blobs to Celestia","API"]},"439":{"title":"Transaction resubmission","titles":[]},"440":{"title":"Monitoring and resubmission","titles":["Transaction resubmission"]},"441":{"title":"Notes","titles":["Transaction resubmission"]},"442":{"title":"Wallet integrations with Celestia","titles":[]},"443":{"title":"Add Celestia network parameters to Keplr with React","titles":["Wallet integrations with Celestia"]},"444":{"title":"Adding a custom chain to Leap","titles":["Wallet integrations with Celestia"]},"445":{"title":"Adding a custom chain to Cosmostation","titles":["Wallet integrations with Celestia"]},"446":{"title":"Data availability FAQ","titles":[]},"447":{"title":"What is data availability?","titles":["Data availability FAQ"]},"448":{"title":"What is the data availability problem?","titles":["Data availability FAQ"]},"449":{"title":"How do nodes verify data availability in Celestia?","titles":["Data availability FAQ"]},"450":{"title":"What is data availability sampling?","titles":["Data availability FAQ"]},"451":{"title":"What are some of the security assumptions that Celestia makes for data availability sampling?","titles":["Data availability FAQ"]},"452":{"title":"Why is block reconstruction necessary for security?","titles":["Data availability FAQ"]},"453":{"title":"What is data storage?","titles":["Data availability FAQ"]},"454":{"title":"What is the problem around data storage?","titles":["Data availability FAQ"]},"455":{"title":"What is the difference between data availability and data storage?","titles":["Data availability FAQ"]},"456":{"title":"Where does blockchain state fit into this?","titles":["Data availability FAQ"]},"457":{"title":"Why doesn’t Celestia incentivize storage of historical data?","titles":["Data availability FAQ"]},"458":{"title":"Who may store historical data if there is no reward?","titles":["Data availability FAQ"]},"459":{"title":"What are some things blockchains can do to provide stronger assurances of data retrievability?","titles":["Data availability FAQ"]},"460":{"title":"Celestia\'s data availability layer","titles":[]},"461":{"title":"Data availability sampling (DAS)","titles":["Celestia\'s data availability layer"]},"462":{"title":"Scalability","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"463":{"title":"Fraud proofs of incorrectly extended data","titles":["Celestia\'s data availability layer","Data availability sampling (DAS)"]},"464":{"title":"Namespaced Merkle trees (NMTs)","titles":["Celestia\'s data availability layer"]},"465":{"title":"Building a PoS blockchain for DA","titles":["Celestia\'s data availability layer"]},"466":{"title":"Providing data availability","titles":["Celestia\'s data availability layer","Building a PoS blockchain for DA"]},"467":{"title":"Monolithic vs. modular blockchains","titles":[]},"468":{"title":"Introduction","titles":[]},"469":{"title":"The lifecycle of a celestia-app transaction","titles":[]},"470":{"title":"Checking data availability","titles":["The lifecycle of a celestia-app transaction"]},"471":{"title":"How to stake TIA","titles":[]},"472":{"title":"Select your preferred wallet","titles":["How to stake TIA"]},"473":{"title":"Stake TIA with Keplr wallet","titles":["How to stake TIA"]},"474":{"title":"1️⃣ Open your Keplr browser extension","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"475":{"title":"2️⃣ Select Celestia network and search for a validator","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"476":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"477":{"title":"4️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Keplr wallet"]},"478":{"title":"Stake TIA with Leap wallet","titles":["How to stake TIA"]},"479":{"title":"1️⃣ Open your Leap browser extension","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"480":{"title":"2️⃣ Select a validator and stake TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"481":{"title":"3️⃣ Confirm and manage your TIA","titles":["How to stake TIA","Stake TIA with Leap wallet"]},"482":{"title":"Stake TIA with Gem wallet","titles":["How to stake TIA"]},"483":{"title":"1️⃣ Open your Gem Wallet app","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"484":{"title":"2️⃣ Choose the amount of Celestia and search for a validator.","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"485":{"title":"3️⃣ Stake your TIA tokens","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"486":{"title":"4️⃣ Manage your TIA","titles":["How to stake TIA","Stake TIA with Gem wallet"]},"487":{"title":"Paying for blobspace","titles":[]},"488":{"title":"PayForBlobs transactions","titles":["Paying for blobspace"]},"489":{"title":"Fee market overview","titles":["Paying for blobspace"]},"490":{"title":"Data retrievability and pruning","titles":[]},"491":{"title":"Data retrievability and pruning in celestia-node","titles":["Data retrievability and pruning"]},"492":{"title":"Suggested practices for rollups","titles":["Data retrievability and pruning"]},"493":{"title":"Staking, governance, & supply","titles":[]},"494":{"title":"Proof-of-stake on Celestia","titles":["Staking, governance, & supply"]},"495":{"title":"Inflation","titles":["Staking, governance, & supply"]},"496":{"title":"Decentralised governance","titles":["Staking, governance, & supply"]},"497":{"title":"Network parameters","titles":["Staking, governance, & supply","Decentralised governance"]},"498":{"title":"Community pool","titles":["Staking, governance, & supply","Decentralised governance"]},"499":{"title":"TIA allocation at genesis","titles":["Staking, governance, & supply"]},"500":{"title":"Unlocks","titles":["Staking, governance, & supply","TIA allocation at genesis"]},"501":{"title":"Staking on Celestia","titles":[]},"502":{"title":"Mainnet Beta","titles":["Staking on Celestia"]},"503":{"title":"Mocha testnet","titles":["Staking on Celestia"]},"504":{"title":"Overview of TIA","titles":[]},"505":{"title":"TIA at a glance","titles":["Overview of TIA"]},"506":{"title":"Role of TIA","titles":["Overview of TIA"]},"507":{"title":"Paying for blobspace","titles":["Overview of TIA","Role of TIA"]},"508":{"title":"Bootstrapping new rollups","titles":["Overview of TIA","Role of TIA"]},"509":{"title":"Proof-of-stake","titles":["Overview of TIA","Role of TIA"]},"510":{"title":"Decentralised governance","titles":["Overview of TIA","Role of TIA"]},"511":{"title":"Denominations","titles":["Overview of TIA","Role of TIA"]},"512":{"title":"TIA: display token","titles":["Overview of TIA","Role of TIA","Denominations"]},"513":{"title":"utia: staking denomination","titles":["Overview of TIA","Role of TIA","Denominations"]},"514":{"title":"microtia: staking denomination alias","titles":["Overview of TIA","Role of TIA","Denominations"]},"515":{"title":"Arabica devnet","titles":[]},"516":{"title":"Network stability and upgrades","titles":["Arabica devnet"]},"517":{"title":"Network details","titles":["Arabica devnet"]},"518":{"title":"Software version numbers","titles":["Arabica devnet","Network details"]},"519":{"title":"Integrations","titles":["Arabica devnet"]},"520":{"title":"Production RPC endpoints","titles":["Arabica devnet","Integrations"]},"521":{"title":"Community RPC endpoints","titles":["Arabica devnet","Integrations"]},"522":{"title":"Using consensus endpoints with DA nodes","titles":["Arabica devnet","Integrations"]},"523":{"title":"Data availability (DA) RPC endpoints for bridge node sync","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"524":{"title":"Data availability (DA) gRPC endpoints for state access","titles":["Arabica devnet","Integrations","Using consensus endpoints with DA nodes"]},"525":{"title":"Arabica devnet faucet","titles":["Arabica devnet"]},"526":{"title":"Discord","titles":["Arabica devnet","Arabica devnet faucet"]},"527":{"title":"Web","titles":["Arabica devnet","Arabica devnet faucet"]},"528":{"title":"Explorers","titles":["Arabica devnet"]},"529":{"title":"Network upgrades","titles":["Arabica devnet"]},"530":{"title":"Setting up a Celestia bridge node","titles":[]},"531":{"title":"Overview of bridge nodes","titles":["Setting up a Celestia bridge node"]},"532":{"title":"Hardware requirements","titles":["Setting up a Celestia bridge node"]},"533":{"title":"Setting up your bridge node","titles":["Setting up a Celestia bridge node"]},"534":{"title":"Setup the dependencies","titles":["Setting up a Celestia bridge node","Setting up your bridge node"]},"535":{"title":"Deploy the Celestia bridge node","titles":["Setting up a Celestia bridge node"]},"536":{"title":"Install Celestia Node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"537":{"title":"Initialize the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"538":{"title":"Run the bridge node","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"539":{"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"]},"540":{"title":"Optional: Migrate node id to another server","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node","Run the bridge node"]},"541":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia bridge node","Deploy the Celestia bridge node"]},"542":{"title":"Helpful CLI commands","titles":[]},"543":{"title":"Creating a wallet","titles":["Helpful CLI commands"]},"544":{"title":"Key management","titles":["Helpful CLI commands"]},"545":{"title":"Importing and exporting keys","titles":["Helpful CLI commands","Key management"]},"546":{"title":"Querying subcommands","titles":["Helpful CLI commands"]},"547":{"title":"Token management","titles":["Helpful CLI commands"]},"548":{"title":"Governance","titles":["Helpful CLI commands"]},"549":{"title":"Community Pool","titles":["Helpful CLI commands","Governance"]},"550":{"title":"Claim validator rewards","titles":["Helpful CLI commands"]},"551":{"title":"Delegate & undelegate tokens","titles":["Helpful CLI commands"]},"552":{"title":"Unjailing the validator","titles":["Helpful CLI commands"]},"553":{"title":"How to export logs with SystemD","titles":["Helpful CLI commands"]},"554":{"title":"Signing genesis for a new network","titles":["Helpful CLI commands"]},"555":{"title":"Metrics","titles":[]},"556":{"title":"Setup","titles":["Metrics"]},"557":{"title":"Visualization","titles":["Metrics"]},"558":{"title":"Node exporter","titles":["Metrics"]},"559":{"title":"Alerts","titles":["Metrics"]},"560":{"title":"Multisig","titles":[]},"561":{"title":"Command line","titles":["Multisig"]},"562":{"title":"Resources","titles":["Multisig"]},"563":{"title":"Jailing and Slashing on Celestia","titles":[]},"564":{"title":"Upgrade Monitor","titles":[]},"565":{"title":"How to create a vesting account with celestia-app","titles":[]},"566":{"title":"Local devnet","titles":["How to create a vesting account with celestia-app"]},"567":{"title":"Setting up the local devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"568":{"title":"Run the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"569":{"title":"Save the home directory path","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"570":{"title":"Check the version of the devnet","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"571":{"title":"Next steps","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up the local devnet"]},"572":{"title":"Setting up vesting account on devnet","titles":["How to create a vesting account with celestia-app","Local devnet"]},"573":{"title":"Create a new key","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"574":{"title":"List your keys","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"575":{"title":"Set variables","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"576":{"title":"Create your devnet vesting account","titles":["How to create a vesting account with celestia-app","Local devnet","Setting up vesting account on devnet"]},"577":{"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"]},"578":{"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"]},"579":{"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"]},"580":{"title":"Mocha","titles":["How to create a vesting account with celestia-app"]},"581":{"title":"Create a wallet","titles":["How to create a vesting account with celestia-app","Mocha"]},"582":{"title":"Fund your account","titles":["How to create a vesting account with celestia-app","Mocha"]},"583":{"title":"Create a vesting account on Mocha","titles":["How to create a vesting account with celestia-app","Mocha"]},"584":{"title":"Optional: Set up a consensus node or validator","titles":["How to create a vesting account with celestia-app","Mocha"]},"585":{"title":"Optional: Change your client.toml","titles":["How to create a vesting account with celestia-app","Mocha"]},"586":{"title":"Notes","titles":["How to create a vesting account with celestia-app"]},"587":{"title":"Conclusion","titles":["How to create a vesting account with celestia-app"]},"588":{"title":"Create a wallet with celestia-app","titles":[]},"589":{"title":"Prerequisites","titles":["Create a wallet with celestia-app"]},"590":{"title":"Create a wallet","titles":["Create a wallet with celestia-app"]},"591":{"title":"Fund a wallet","titles":["Create a wallet with celestia-app"]},"592":{"title":"Install celestia-app","titles":[]},"593":{"title":"Building binary from source","titles":["Install celestia-app"]},"594":{"title":"Installing a pre-built binary","titles":["Install celestia-app"]},"595":{"title":"Ports","titles":["Install celestia-app"]},"596":{"title":"Custom networks and values","titles":[]},"597":{"title":"celestia-node metrics","titles":[]},"598":{"title":"Running metrics flags","titles":["celestia-node metrics"]},"599":{"title":"Mainnet Beta","titles":["celestia-node metrics","Running metrics flags"]},"600":{"title":"Mocha testnet","titles":["celestia-node metrics","Running metrics flags"]},"601":{"title":"TLS connections","titles":["celestia-node metrics","Running metrics flags"]},"602":{"title":"Metrics endpoint design considerations","titles":["celestia-node metrics"]},"603":{"title":"Troubleshooting","titles":[]},"604":{"title":"Network selection","titles":["Troubleshooting"]},"605":{"title":"Chain ID","titles":["Troubleshooting","Network selection"]},"606":{"title":"Ports","titles":["Troubleshooting"]},"607":{"title":"Changing the location of your node store","titles":["Troubleshooting"]},"608":{"title":"Background","titles":["Troubleshooting","Changing the location of your node store"]},"609":{"title":"Demonstration","titles":["Troubleshooting","Changing the location of your node store"]},"610":{"title":"Examples","titles":["Troubleshooting","Changing the location of your node store"]},"611":{"title":"Mainnet Beta full and Mocha light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"612":{"title":"Mocha full and Arabica light","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"613":{"title":"Using a custom rpc.config address","titles":["Troubleshooting","Changing the location of your node store","Examples"]},"614":{"title":"Resetting your config","titles":["Troubleshooting"]},"615":{"title":"Clearing the data store","titles":["Troubleshooting"]},"616":{"title":"FATAL headers given to the heightSub are in the wrong order","titles":["Troubleshooting"]},"617":{"title":"Error: "too many open files"","titles":["Troubleshooting"]},"618":{"title":"Syncing a light node from a trusted hash","titles":[]},"619":{"title":"For service operators","titles":["Syncing a light node from a trusted hash"]},"620":{"title":"Install celestia-node","titles":[]},"621":{"title":"Installing from source","titles":["Install celestia-node"]},"622":{"title":"Installing a pre-built binary","titles":["Install celestia-node"]},"623":{"title":"Next steps","titles":["Install celestia-node"]},"624":{"title":"Upgrading your binary","titles":["Install celestia-node"]},"625":{"title":"config.toml guide","titles":[]},"626":{"title":"Pre-requisites","titles":["config.toml guide"]},"627":{"title":"Understanding config.toml","titles":["config.toml guide"]},"628":{"title":"Core","titles":["config.toml guide","Understanding config.toml"]},"629":{"title":"P2P","titles":["config.toml guide","Understanding config.toml"]},"630":{"title":"Bootstrap","titles":["config.toml guide","Understanding config.toml","P2P"]},"631":{"title":"Mutual peers","titles":["config.toml guide","Understanding config.toml","P2P"]},"632":{"title":"Services","titles":["config.toml guide","Understanding config.toml"]},"633":{"title":"TrustedHash and TrustedPeer","titles":["config.toml guide","Understanding config.toml","Services"]},"634":{"title":"Consensus node","titles":[]},"635":{"title":"Minimum hardware requirements","titles":["Consensus node"]},"636":{"title":"Set up a consensus node","titles":["Consensus node"]},"637":{"title":"Set up the dependencies","titles":["Consensus node","Set up a consensus node"]},"638":{"title":"Install celestia-app","titles":["Consensus node","Set up a consensus node"]},"639":{"title":"Set up the P2P networks","titles":["Consensus node","Set up a consensus node"]},"640":{"title":"Storage and pruning configurations","titles":["Consensus node"]},"641":{"title":"Optional: Connect a consensus node to a bridge node","titles":["Consensus node","Storage and pruning configurations"]},"642":{"title":"Enable transaction indexing","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"643":{"title":"Retain all block data","titles":["Consensus node","Storage and pruning configurations","Optional: Connect a consensus node to a bridge node"]},"644":{"title":"Query transactions by hash","titles":["Consensus node","Storage and pruning configurations"]},"645":{"title":"Optional: Access historical state","titles":["Consensus node","Storage and pruning configurations"]},"646":{"title":"Save on storage requirements","titles":["Consensus node","Storage and pruning configurations"]},"647":{"title":"Sync types","titles":["Consensus node"]},"648":{"title":"Option 1: Block sync","titles":["Consensus node","Sync types"]},"649":{"title":"Option 2: State sync","titles":["Consensus node","Sync types"]},"650":{"title":"Option 3: Quick sync","titles":["Consensus node","Sync types"]},"651":{"title":"Start the consensus node","titles":["Consensus node"]},"652":{"title":"Extra resources for consensus nodes","titles":["Consensus node"]},"653":{"title":"Optional: Reset network","titles":["Consensus node","Extra resources for consensus nodes"]},"654":{"title":"Optional: Configure an RPC endpoint","titles":["Consensus node","Extra resources for consensus nodes"]},"655":{"title":"Expose RPC","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"656":{"title":"Note on external-address","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"657":{"title":"Restart the node","titles":["Consensus node","Extra resources for consensus nodes","Optional: Configure an RPC endpoint"]},"658":{"title":"Optional: Transaction indexer configuration options","titles":["Consensus node","Extra resources for consensus nodes"]},"659":{"title":"Optional: Discard ABCI responses configuration","titles":["Consensus node","Extra resources for consensus nodes"]},"660":{"title":"FAQ","titles":["Consensus node"]},"661":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Consensus node","FAQ"]},"662":{"title":"Deciding which node to run","titles":[]},"663":{"title":"Beginner","titles":["Deciding which node to run"]},"664":{"title":"Advanced","titles":["Deciding which node to run"]},"665":{"title":"🐳 Docker setup","titles":[]},"666":{"title":"Prerequisites","titles":["🐳 Docker setup"]},"667":{"title":"Quick start","titles":["🐳 Docker setup"]},"668":{"title":"Light node setup with persistent storage","titles":["🐳 Docker setup"]},"669":{"title":"Initialize the node store and key","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"670":{"title":"Start the node","titles":["🐳 Docker setup","Light node setup with persistent storage"]},"671":{"title":"Video walkthrough","titles":["🐳 Docker setup"]},"672":{"title":"2.5 minute version","titles":["🐳 Docker setup","Video walkthrough"]},"673":{"title":"Troubleshooting","titles":["🐳 Docker setup"]},"674":{"title":"Development environment","titles":[]},"675":{"title":"Install dependencies","titles":["Development environment"]},"676":{"title":"Install Golang","titles":["Development environment"]},"677":{"title":"Setting up a Celestia full storage Node","titles":[]},"678":{"title":"Overview of full storage nodes","titles":["Setting up a Celestia full storage Node"]},"679":{"title":"Hardware requirements","titles":["Setting up a Celestia full storage Node"]},"680":{"title":"Setting up your full storage node","titles":["Setting up a Celestia full storage Node"]},"681":{"title":"Setup the dependencies","titles":["Setting up a Celestia full storage Node","Setting up your full storage node"]},"682":{"title":"Install celestia-node","titles":["Setting up a Celestia full storage Node"]},"683":{"title":"Run the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"684":{"title":"Initialize the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"685":{"title":"Start the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node","Run the full storage node"]},"686":{"title":"Optional: run the full storage node with a custom key","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"687":{"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"]},"688":{"title":"Optional: start the full storage node with SystemD","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"689":{"title":"Stop the full storage node","titles":["Setting up a Celestia full storage Node","Install celestia-node"]},"690":{"title":"Celestia hardfork process","titles":[]},"691":{"title":"General process","titles":["Celestia hardfork process"]},"692":{"title":"Lemongrass hardfork","titles":["Celestia hardfork process","General process"]},"693":{"title":"IBC relaying guide","titles":[]},"694":{"title":"Hermes","titles":["IBC relaying guide"]},"695":{"title":"Configuration","titles":["IBC relaying guide","Hermes"]},"696":{"title":"Add relayer wallets","titles":["IBC relaying guide","Hermes"]},"697":{"title":"Verify configuration files","titles":["IBC relaying guide","Hermes"]},"698":{"title":"Create a connection between 2 chains","titles":["IBC relaying guide"]},"699":{"title":"Create clients","titles":["IBC relaying guide"]},"700":{"title":"Open connection over new clients","titles":["IBC relaying guide","Create clients"]},"701":{"title":"Configure channels in Hermes","titles":["IBC relaying guide","Create clients"]},"702":{"title":"Start the relayer","titles":["IBC relaying guide"]},"703":{"title":"Transfer","titles":["IBC relaying guide"]},"704":{"title":"Token filter","titles":["IBC relaying guide","Transfer"]},"705":{"title":"Celestia App network instantiation guide","titles":[]},"706":{"title":"Hardware requirements","titles":["Celestia App network instantiation guide"]},"707":{"title":"Setup dependencies","titles":["Celestia App network instantiation guide"]},"708":{"title":"celestia-app installation","titles":["Celestia App network instantiation guide"]},"709":{"title":"Spin up a Celestia testnet","titles":["Celestia App network instantiation guide"]},"710":{"title":"Optional: Reset working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"711":{"title":"Initialize a working directory","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"712":{"title":"Create a new key","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"713":{"title":"Add genesis account KeyName","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"714":{"title":"Optional: Adding other validators","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"715":{"title":"Create the genesis transaction for new chain","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"716":{"title":"Creating the genesis JSON file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"717":{"title":"Modify your config file","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"718":{"title":"Add your node as a persistent peer","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"719":{"title":"Instantiate the network","titles":["Celestia App network instantiation guide","Spin up a Celestia testnet"]},"720":{"title":"Setting up a Celestia light node","titles":[]},"721":{"title":"Overview of light nodes","titles":["Setting up a Celestia light node"]},"722":{"title":"Hardware requirements","titles":["Setting up a Celestia light node"]},"723":{"title":"Setting up your light node","titles":["Setting up a Celestia light node"]},"724":{"title":"Install celestia-node","titles":["Setting up a Celestia light node","Setting up your light node"]},"725":{"title":"Initialize the light node","titles":["Setting up a Celestia light node"]},"726":{"title":"Start the light node","titles":["Setting up a Celestia light node"]},"727":{"title":"Keys and wallets","titles":["Setting up a Celestia light node","Start the light node"]},"728":{"title":"Testnet tokens","titles":["Setting up a Celestia light node","Start the light node","Keys and wallets"]},"729":{"title":"Optional: run the light node with a custom key","titles":["Setting up a Celestia light node","Start the light node"]},"730":{"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"]},"731":{"title":"Optional: start light node with SystemD","titles":["Setting up a Celestia light node","Start the light node"]},"732":{"title":"Data availability sampling","titles":["Setting up a Celestia light node"]},"733":{"title":"Mainnet Beta","titles":[]},"734":{"title":"Network stability and upgrades","titles":["Mainnet Beta"]},"735":{"title":"Network details","titles":["Mainnet Beta"]},"736":{"title":"Software version numbers","titles":["Mainnet Beta"]},"737":{"title":"Network parameters","titles":["Mainnet Beta"]},"738":{"title":"Maximum bytes","titles":["Mainnet Beta","Network parameters"]},"739":{"title":"Integrations","titles":["Mainnet Beta"]},"740":{"title":"Production RPC endpoints","titles":["Mainnet Beta","Integrations"]},"741":{"title":"Consensus nodes","titles":["Mainnet Beta","Integrations"]},"742":{"title":"Community consensus RPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"743":{"title":"Community API endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"744":{"title":"Community gRPC endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"745":{"title":"Community WebSocket endpoints","titles":["Mainnet Beta","Integrations","Consensus nodes"]},"746":{"title":"Data availability nodes","titles":["Mainnet Beta","Integrations"]},"747":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"748":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"749":{"title":"Archival DA RPC endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes"]},"750":{"title":"Grove archival endpoints","titles":["Mainnet Beta","Integrations","Data availability nodes","Archival DA RPC endpoints"]},"751":{"title":"Explorers","titles":["Mainnet Beta"]},"752":{"title":"Analytics","titles":["Mainnet Beta"]},"753":{"title":"Network upgrades","titles":["Mainnet Beta"]},"754":{"title":"Mocha testnet","titles":[]},"755":{"title":"Network details","titles":["Mocha testnet"]},"756":{"title":"Software version numbers","titles":["Mocha testnet"]},"757":{"title":"RPC for DA bridge, full, and light nodes","titles":["Mocha testnet"]},"758":{"title":"Production RPC endpoints","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"759":{"title":"Community Data availability (DA) RPC endpoints for bridge node sync","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"760":{"title":"Community Data availability (DA) gRPC endpoints for state access","titles":["Mocha testnet","RPC for DA bridge, full, and light nodes"]},"761":{"title":"Community RPC endpoints","titles":["Mocha testnet"]},"762":{"title":"Community API endpoints","titles":["Mocha testnet"]},"763":{"title":"Community gRPC endpoints","titles":["Mocha testnet"]},"764":{"title":"Community bridge and full node endpoints","titles":["Mocha testnet"]},"765":{"title":"Mocha testnet faucet","titles":["Mocha testnet"]},"766":{"title":"Analytics","titles":["Mocha testnet"]},"767":{"title":"Explorers","titles":["Mocha testnet"]},"768":{"title":"Network upgrades","titles":["Mocha testnet"]},"769":{"title":"Overview to running nodes on Celestia","titles":[]},"770":{"title":"Recommended Celestia node requirements","titles":["Overview to running nodes on Celestia"]},"771":{"title":"Data availability nodes","titles":["Overview to running nodes on Celestia"]},"772":{"title":"Consensus nodes","titles":["Overview to running nodes on Celestia"]},"773":{"title":"Participate in the Celestia networks","titles":[]},"774":{"title":"Mainnet Beta","titles":["Participate in the Celestia networks"]},"775":{"title":"Compatible software versions for Mainnet Beta","titles":["Participate in the Celestia networks","Mainnet Beta"]},"776":{"title":"Testnets","titles":["Participate in the Celestia networks"]},"777":{"title":"Arabica Devnet","titles":["Participate in the Celestia networks","Testnets"]},"778":{"title":"Compatible software versions for Arabica devnet","titles":["Participate in the Celestia networks","Testnets","Arabica Devnet"]},"779":{"title":"Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"780":{"title":"Compatible software versions for Mocha testnet","titles":["Participate in the Celestia networks","Testnets"]},"781":{"title":"Network upgrades","titles":["Participate in the Celestia networks"]},"782":{"title":"Quick start guide","titles":[]},"783":{"title":"Celestia Node","titles":["Quick start guide"]},"784":{"title":"Celestia App","titles":["Quick start guide"]},"785":{"title":"Getting started","titles":["Quick start guide"]},"786":{"title":"Setting up your node as a background process with SystemD","titles":[]},"787":{"title":"Consensus nodes","titles":["Setting up your node as a background process with SystemD"]},"788":{"title":"Start the celestia-app with SystemD","titles":["Setting up your node as a background process with SystemD","Consensus nodes"]},"789":{"title":"Data availability nodes","titles":["Setting up your node as a background process with SystemD"]},"790":{"title":"Celestia full storage node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"791":{"title":"Celestia bridge node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"792":{"title":"Celestia light node","titles":["Setting up your node as a background process with SystemD","Data availability nodes"]},"793":{"title":"Setting up a Celestia validator node","titles":[]},"794":{"title":"Hardware requirements","titles":["Setting up a Celestia validator node"]},"795":{"title":"Setting up a validator node","titles":["Setting up a Celestia validator node"]},"796":{"title":"Wallet","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"797":{"title":"Delegate stake to a validator","titles":["Setting up a Celestia validator node","Setting up a validator node"]},"798":{"title":"Optional: Deploy the celestia-node","titles":["Setting up a Celestia validator node"]},"799":{"title":"Install celestia-node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"800":{"title":"Initialize the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"801":{"title":"Run the bridge node","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node"]},"802":{"title":"Optional: start the bridge node with SystemD","titles":["Setting up a Celestia validator node","Optional: Deploy the celestia-node","Run the bridge node"]},"803":{"title":"Run the validator node","titles":["Setting up a Celestia validator node"]},"804":{"title":"Submit your validator information","titles":["Setting up a Celestia validator node"]},"805":{"title":"Optional: Transaction indexer configuration options","titles":["Setting up a Celestia validator node"]},"806":{"title":"Additional resources","titles":["Setting up a Celestia validator node"]},"807":{"title":"FAQ","titles":["Setting up a Celestia validator node"]},"808":{"title":"+2/3 committed an invalid block: wrong Block.Header.Version","titles":["Setting up a Celestia validator node","FAQ"]}},"dirtCount":0,"index":[["∑i=1nssn",{"2":{"430":1}}],["×ss×gcpbb",{"2":{"430":1}}],["🌀",{"0":{"317":1}}],["🌉🌉🌉🌉🌉",{"2":{"91":2}}],["|",{"2":{"316":2,"374":4,"376":2,"384":2,"386":2,"389":2,"396":4,"398":1,"546":4,"639":14,"650":12,"788":4}}],["||",{"2":{"268":2}}],[">",{"2":{"258":1,"259":3}}],["^external",{"2":{"656":2}}],["^persistent",{"2":{"639":6}}],["^seeds",{"2":{"639":4}}],["^",{"2":{"212":2,"223":4,"224":4}}],["^0",{"2":{"116":2,"117":2,"127":2,"172":2,"281":2,"282":2,"306":4,"308":2}}],["\\tlog",{"2":{"413":6,"415":4}}],["\\tlatestblocknumber",{"2":{"153":2,"170":2}}],["\\tpromptanswer",{"2":{"415":2}}],["\\tproof",{"2":{"153":2}}],["\\tpayload",{"2":{"413":2}}],["\\theader",{"2":{"327":2}}],["\\theaderchan",{"2":{"326":2}}],["\\thelloworldblob",{"2":{"324":2,"436":2}}],["\\theight",{"2":{"153":2,"169":2,"172":4,"324":2,"413":2,"436":2}}],["\\tns",{"2":{"413":2}}],["\\tnodeip",{"2":{"412":2,"413":2,"415":2}}],["\\tnodeclient",{"2":{"411":2}}],["\\tnonce",{"2":{"153":2,"169":2,"172":4}}],["\\tnamespaceid",{"2":{"413":2,"415":2}}],["\\tnamespacebytes",{"2":{"413":2}}],["\\tnamespace",{"2":{"324":2,"325":2,"326":2,"436":2}}],["\\tretrievedblobs",{"2":{"324":2,"436":2}}],["\\treturn",{"2":{"153":4,"165":8,"166":2,"167":2,"168":2,"169":2,"172":18,"324":2,"327":2,"413":4,"414":4,"436":2}}],["\\trowproofs",{"2":{"168":2,"172":2}}],["\\trowroots",{"2":{"167":2,"172":2}}],["\\tmaxns",{"2":{"165":2,"172":2}}],["\\tmaxsquaresize",{"2":{"159":2}}],["\\tminns",{"2":{"165":2,"172":2}}],["\\tsimplerollup",{"2":{"172":2}}],["\\tsimplerollupwrapper",{"2":{"172":2}}],["\\tsidenodes",{"2":{"153":2,"169":2,"172":2}}],["\\tshareproofs",{"2":{"165":2,"172":2}}],["\\tsharesproof",{"2":{"162":1,"172":4}}],["\\tsubtreerootthreshold",{"2":{"159":2}}],["\\tversion",{"2":{"159":2,"165":4,"172":6}}],["\\tvalid",{"2":{"153":2}}],["\\tvar",{"2":{"153":2,"165":6,"166":2,"170":2,"172":10}}],["\\twrappedproof",{"2":{"153":2}}],["\\twrapper",{"2":{"153":2,"170":2}}],["\\tcreatedblob",{"2":{"413":4,"415":2}}],["\\tclient",{"2":{"324":4,"325":2,"326":2,"327":2,"412":2,"413":4,"415":2,"436":4}}],["\\tcopy",{"2":{"165":6,"166":2,"172":2}}],["\\tcommitted",{"2":{"153":2}}],["\\tctx",{"2":{"152":2,"153":2,"172":4,"412":2,"413":4,"415":2}}],["\\tfetchedblob",{"2":{"413":2,"415":2}}],["\\tfor",{"2":{"153":4,"165":2,"167":2,"168":2,"169":2,"170":2,"172":16,"325":2,"326":2}}],["\\tfmt",{"2":{"152":2,"324":4,"436":4}}],["\\tblobchan",{"2":{"325":2}}],["\\tblobsharerange",{"2":{"159":2}}],["\\tblobstreamxwrapper",{"2":{"153":4,"172":2}}],["\\tblockdataroot",{"2":{"169":2,"172":2}}],["\\tblockres",{"2":{"153":2,"159":2}}],["\\ttmproto",{"2":{"172":2}}],["\\ttuple",{"2":{"153":2}}],["\\ttxhash",{"2":{"159":2}}],["\\ttx",{"2":{"153":2,"159":2,"172":2}}],["\\ttrpc",{"2":{"152":2,"153":2}}],["\\teventsiterator",{"2":{"153":2,"170":2}}],["\\tethclient",{"2":{"153":2,"170":2,"172":2}}],["\\tethcmn",{"2":{"153":2,"172":2}}],["\\terr",{"2":{"145":2,"152":2,"153":6,"170":2,"172":4}}],["\\tdatarootinclusionproof",{"2":{"169":2,"172":4}}],["\\tdataroot",{"2":{"153":2,"172":2}}],["\\tdcproof",{"2":{"152":2,"153":2}}],["\\tdefer",{"2":{"145":2,"153":2,"170":2,"172":2,"412":4,"413":4,"415":4}}],["\\t",{"2":{"145":6,"152":14,"153":90,"157":2,"159":22,"162":2,"165":8,"166":2,"167":2,"168":2,"169":4,"170":27,"171":24,"172":98,"324":28,"325":12,"326":12,"327":8,"411":28,"412":24,"413":54,"415":26,"436":28}}],["\\t\\tlog",{"2":{"412":4,"413":10,"415":12}}],["\\t\\tuint64",{"2":{"172":2}}],["\\t\\tclient",{"2":{"172":2}}],["\\t\\tctx",{"2":{"172":2,"414":2}}],["\\t\\tcase",{"2":{"171":4,"325":4,"326":4}}],["\\t\\tcopy",{"2":{"169":2}}],["\\t\\tproof",{"2":{"169":2,"172":2}}],["\\t\\tvar",{"2":{"169":2,"172":2}}],["\\t\\tversion",{"2":{"165":4,"166":2,"172":6}}],["\\t\\trowproofs",{"2":{"168":2,"172":2}}],["\\t\\trowroots",{"2":{"167":2,"172":2}}],["\\t\\treturn",{"2":{"145":2,"153":30,"159":8,"170":14,"172":8,"324":10,"325":6,"326":6,"327":4,"413":6,"436":10}}],["\\t\\tdcproof",{"2":{"172":2}}],["\\t\\tdigest",{"2":{"165":2,"172":4}}],["\\t\\tdataroot",{"2":{"153":2}}],["\\t\\tmax",{"2":{"165":2,"172":2}}],["\\t\\tmaxsquaresize",{"2":{"159":2}}],["\\t\\tmin",{"2":{"165":2,"172":2}}],["\\t\\tfor",{"2":{"165":2,"168":2,"172":6}}],["\\t\\tfmt",{"2":{"152":6,"153":6,"172":2}}],["\\t\\tselect",{"2":{"325":2,"326":2}}],["\\t\\tsharesproof",{"2":{"172":2}}],["\\t\\tshareproofs",{"2":{"165":2,"172":2}}],["\\t\\tsimplerollupwrapper",{"2":{"172":2}}],["\\t\\tsidenodes",{"2":{"153":4,"165":2,"168":2,"169":2,"172":6}}],["\\t\\tsubtreerootthreshold",{"2":{"159":2}}],["\\t\\tid",{"2":{"165":4,"166":2,"172":12}}],["\\t\\tint",{"2":{"159":2}}],["\\t\\tif",{"2":{"145":2,"153":2,"170":2}}],["\\t\\tblockdataroot",{"2":{"172":2}}],["\\t\\tblockres",{"2":{"159":2,"172":2}}],["\\t\\tbig",{"2":{"153":2}}],["\\t\\twrappedproof",{"2":{"153":2}}],["\\t\\ttuplerootnonce",{"2":{"169":2,"172":2}}],["\\t\\ttuple",{"2":{"153":2,"169":2,"172":2}}],["\\t\\tnumleaves",{"2":{"153":2}}],["\\t\\tnil",{"2":{"153":6,"170":6}}],["\\t\\tkey",{"2":{"153":2}}],["\\t\\theight",{"2":{"153":2}}],["\\t\\tevent",{"2":{"172":2}}],["\\t\\te",{"2":{"153":2,"170":2}}],["\\t\\terr",{"2":{"145":2}}],["\\t\\tos",{"2":{"152":6,"153":2,"172":2}}],["\\t\\t\\tif",{"2":{"326":2}}],["\\t\\t\\tfmt",{"2":{"325":2,"326":2}}],["\\t\\t\\tfor",{"2":{"172":2}}],["\\t\\t\\tattestationproof",{"2":{"172":2}}],["\\t\\t\\trowproofs",{"2":{"172":2}}],["\\t\\t\\trowroots",{"2":{"172":2}}],["\\t\\t\\treturn",{"2":{"171":2,"325":2,"326":2}}],["\\t\\t\\tnamespace",{"2":{"172":2}}],["\\t\\t\\tnumleaves",{"2":{"168":2,"169":2,"172":4}}],["\\t\\t\\tdata",{"2":{"172":2}}],["\\t\\t\\tdataroot",{"2":{"169":2,"172":2}}],["\\t\\t\\theight",{"2":{"169":2,"172":2}}],["\\t\\t\\tkey",{"2":{"168":2,"169":2,"172":4}}],["\\t\\t\\tcopy",{"2":{"168":2}}],["\\t\\t\\tcontext",{"2":{"153":2,"170":2,"171":2,"172":2}}],["\\t\\t\\tvar",{"2":{"168":2,"172":2}}],["\\t\\t\\tblobs",{"2":{"326":2}}],["\\t\\t\\tbzsidenode",{"2":{"172":2}}],["\\t\\t\\tbeginkey",{"2":{"165":2,"172":2}}],["\\t\\t\\tbreak",{"2":{"153":2,"170":2}}],["\\t\\t\\tshareproofs",{"2":{"172":2}}],["\\t\\t\\tsidenodes",{"2":{"165":4,"168":4,"169":2,"172":10}}],["\\t\\t\\tstart",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tfmt",{"2":{"326":2}}],["\\t\\t\\t\\tbzsidenode",{"2":{"172":2}}],["\\t\\t\\t\\tdatacommitment",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tendblock",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tstartblock",{"2":{"153":2,"170":2}}],["\\t\\t\\t\\tproofnonce",{"2":{"153":2,"170":2}}],["\\t\\t\\tevent",{"2":{"153":2,"170":2}}],["\\t\\t\\tendkey",{"2":{"165":2,"172":2}}],["\\t\\t\\tend",{"2":{"153":2,"170":2}}],["\\t\\t\\t",{"2":{"145":2,"153":2,"170":2,"171":2,"172":2,"326":4}}],["\\t\\t",{"2":{"145":4,"153":8,"157":4,"159":2,"162":2,"165":4,"168":4,"169":4,"170":6,"171":4,"172":20,"325":2,"326":2}}],["\\tif",{"2":{"145":4,"152":6,"153":32,"159":8,"162":2,"170":14,"172":10,"324":10,"325":6,"326":6,"327":4,"412":4,"413":16,"414":2,"415":12,"436":10}}],["🤪",{"2":{"135":1}}],["`$home",{"2":{"639":2}}],["`job=",{"2":{"557":2}}],["`json",{"2":{"134":22}}],["```json",{"2":{"383":2}}],["```",{"2":{"383":2}}],["`https",{"2":{"314":4}}],["`celestia",{"2":{"437":4}}],["`cel",{"2":{"269":2}}],["`private",{"2":{"211":2}}],["`mnemonic",{"2":{"211":2}}],["`wallet",{"2":{"211":4}}],["`trpc",{"2":{"172":4}}],["`blobstreamdatacommitmentstored`",{"2":{"170":2,"171":2,"172":2}}],["`availabledataroot`",{"2":{"169":2}}],["`",{"2":{"134":22,"269":2,"314":4,"443":12,"557":2}}],["zshrcecho",{"2":{"676":1}}],["zshrc",{"2":{"676":3}}],["z20=",{"2":{"376":2}}],["zxrxj96",{"2":{"156":2}}],["zhsjrh",{"2":{"151":2}}],["zero",{"2":{"127":2,"133":1,"230":1}}],["zkvm",{"2":{"230":1,"236":1,"423":1}}],["zkp",{"2":{"127":2}}],["zk",{"0":{"195":1,"196":1,"197":1,"198":1,"199":1,"200":1,"201":1,"202":1,"241":1},"1":{"196":1,"197":2,"198":2,"199":1,"200":2,"201":2,"202":2,"203":1,"204":1,"205":1,"242":1,"243":1,"244":1},"2":{"127":7,"136":2,"148":2,"174":1,"178":1,"195":1,"196":2,"197":1,"199":2,"200":4,"202":1,"203":5,"205":1,"206":1,"230":1,"236":4}}],["zip",{"2":{"86":2}}],["~2",{"2":{"738":1}}],["~20",{"2":{"223":1}}],["~5",{"2":{"647":1}}],["~1",{"2":{"647":1}}],["~10",{"2":{"224":1}}],["~1hr",{"2":{"224":1}}],["~30",{"2":{"226":1}}],["~3",{"2":{"224":1,"647":1}}],["~",{"2":{"117":2,"277":2,"282":2,"407":2,"539":1,"540":1,"616":4,"650":18,"655":2,"686":1,"687":1,"729":1,"730":1}}],["μ",{"2":{"117":2,"282":2}}],["⠆",{"2":{"117":2,"120":2,"282":2,"285":2}}],["⠑",{"2":{"116":2,"281":2}}],["⠔",{"2":{"116":2,"281":2}}],["⠢",{"2":{"116":2,"281":2}}],["=1",{"2":{"738":1}}],["===",{"2":{"314":6}}],["==",{"2":{"153":2,"165":6,"168":3,"170":2,"306":2,"414":2,"429":1,"669":2,"670":2}}],["=",{"2":{"116":2,"117":2,"127":2,"137":28,"139":14,"145":12,"149":8,"152":14,"153":74,"157":8,"159":22,"162":4,"165":20,"167":6,"168":12,"169":10,"170":30,"171":18,"172":96,"184":4,"224":2,"225":1,"227":1,"242":1,"281":2,"282":2,"306":62,"313":10,"314":80,"316":2,"324":20,"325":14,"326":18,"327":8,"393":4,"403":29,"412":10,"413":34,"414":8,"415":26,"419":10,"420":20,"421":4,"428":1,"430":4,"431":2,"436":20,"437":44,"443":8,"513":1,"556":8,"585":10,"618":1,"628":1,"630":2,"639":22,"642":2,"643":2,"644":2,"645":3,"646":6,"649":8,"651":1,"656":4,"658":2,"659":2,"692":2,"695":170,"701":8,"717":2,"803":1}}],["⏰⏰⏰⏰⏰⏰",{"2":{"91":2}}],["🐳",{"0":{"665":1},"1":{"666":1,"667":1,"668":1,"669":1,"670":1,"671":1,"672":1,"673":1}}],["😎",{"2":{"401":1,"668":2}}],["🔐",{"0":{"371":1}}],["🙂",{"2":{"133":1}}],["🔃🔃🔃",{"2":{"91":2}}],["🚀🚀🚀🚀",{"2":{"91":2}}],["📝📝📝📝📝",{"2":{"91":2}}],["💰💰💰💰💰💰",{"2":{"91":2}}],["😁",{"2":{"89":1}}],["xzf",{"2":{"676":8}}],["xf",{"2":{"650":6}}],["x86",{"2":{"594":1,"622":1}}],["xv92a3qxexport",{"2":{"569":1}}],["xv92a3qx",{"2":{"569":3}}],["x64",{"2":{"533":1,"636":1,"680":1,"723":1,"795":1}}],["xxxxxxxxxxxxx",{"2":{"569":4}}],["xxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"408":1}}],["xxxxxxxxxxxxxxxxxxxxxxxxexport",{"2":{"408":1}}],["xxd",{"2":{"396":2}}],["xyz",{"2":{"227":1,"247":1,"249":1,"250":1,"252":1,"253":1,"285":2,"318":2,"520":3,"695":6,"740":3,"742":3,"743":3,"744":3,"748":2,"758":3,"760":2,"761":2,"763":2}}],["xthp6xws=",{"2":{"161":2}}],["xiijl+gqm0fqxiw0z0o",{"2":{"161":2}}],["x",{"0":{"95":1,"109":1,"209":1,"242":1,"243":1,"244":1},"1":{"96":1,"97":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1},"2":{"89":4,"94":1,"95":1,"106":1,"117":9,"130":1,"131":7,"172":4,"173":1,"210":1,"212":2,"225":3,"226":1,"227":4,"228":2,"230":3,"231":2,"242":6,"243":3,"244":3,"282":9,"324":1,"391":2,"397":2,"402":1,"403":1,"412":4,"413":10,"431":2,"437":2,"548":1,"563":1,"650":6,"651":2,"803":2}}],["✨",{"2":{"83":1,"91":2,"314":2}}],["07",{"2":{"700":8}}],["0ns",{"2":{"700":4}}],["09",{"2":{"692":1}}],["010",{"2":{"602":1}}],["01",{"2":{"443":2,"554":2,"695":6,"742":1,"743":1,"744":1,"761":1,"762":1,"763":1,"803":2}}],["011",{"2":{"178":1}}],["0blockhash",{"2":{"396":1}}],["08",{"2":{"386":1,"692":2}}],["025",{"2":{"695":2}}],["02",{"2":{"383":2,"443":2}}],["06",{"2":{"383":4}}],["0mfhykqui2bu+u1jxpzg7qy2bvv1lb3kiu+zak7nuiy=",{"2":{"374":2,"611":2,"612":4,"613":2}}],["0+",{"2":{"369":1,"608":1,"694":1}}],["0px",{"2":{"314":2}}],["03",{"2":{"223":2}}],["05",{"2":{"223":2,"407":4}}],["001hermes",{"2":{"699":2,"700":1}}],["001",{"2":{"695":3,"696":2,"698":1,"699":4,"700":7,"701":3}}],["003442",{"2":{"617":4}}],["000",{"2":{"429":2,"430":1,"499":3,"505":3,"513":2,"563":1}}],["000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000121312324243243288993946154604701154f739f3d1b5475786ddd960f06d8708d4e870da6501c51750",{"2":{"161":2}}],["00000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000584cb53884b394593052df4039e58c7d51f0e45cace7dd584125f62f9261b7900ac1eeef5e82349",{"2":{"156":2}}],["008",{"2":{"386":1}}],["004celestia",{"2":{"377":1}}],["004",{"2":{"377":3}}],["002",{"2":{"377":1,"391":2}}],["00",{"2":{"223":2,"692":3}}],["048091bc7ddc283f77bfbf91d73c44da58c3df8a9cbc867405d8b7f3daada22f",{"2":{"383":2}}],["04",{"2":{"223":16,"334":1,"533":1,"636":1,"661":2,"680":1,"723":1,"795":1,"808":2}}],["0xbe",{"2":{"324":2,"325":2,"326":2,"419":2,"420":2,"436":2}}],["0xb6b15c8cb491557369f3c7d2c287b053eb229daa9c22138887752191c9520659",{"2":{"119":1}}],["0xb6052122545aacd2bdda0ca9fa56416bd968cdbc",{"2":{"99":1}}],["0x",{"2":{"219":1,"374":2}}],["0x0",{"2":{"398":1,"661":2,"808":2}}],["0x0000000000000000",{"2":{"395":2}}],["0x0000000000000000000000000000000000000000",{"2":{"395":2}}],["0x0000000000000000000000000000000000000000000000000000000000000000",{"2":{"395":2}}],["0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",{"2":{"121":2,"286":2,"395":2}}],["0x0000000000000000000000000000000000000000000000000000000000000001",{"2":{"211":2}}],["0x000000000000000000000000000000000000000000000000000000000000000a",{"2":{"121":2,"286":2}}],["0x0000000000000000000000000000000000000001",{"2":{"211":2}}],["0x007d0b2a2e2b013612e8",{"2":{"224":2}}],["0x0c",{"2":{"107":1}}],["0x04cae899fc0b7ef45c529f8bf075d54f6fb70ed9",{"2":{"99":1}}],["0x03b43f7b61fa100611191f481ef48aa1fc98f434",{"2":{"99":1}}],["0x01b5905b154f21a393f5b5a0c6d15b53a493c05e",{"2":{"98":1}}],["0x019850732270d8c436585c7921219252422228b5d0f559da0da219f0fa2b7216",{"2":{"91":2}}],["0x8e1ede4ce0865b41d714",{"2":{"224":2}}],["0x8f15d6004598f0662dd673a9898dceef77be8cc28408cecc284b28d7be32307d",{"2":{"121":2,"286":2}}],["0x8f97cb7c643acd7f79f3b13841b24a243da51242",{"2":{"99":1}}],["0x89b7c7970c13bb587893a70697ad6d2a335b6a15",{"2":{"99":1}}],["0x8dee6e88d3b62b258c1574cbb7005e1c3cf193b60a99b5c2fcfae00819b7ed82",{"2":{"91":2}}],["0xd4b998a35d20d98ed3488221f0c161a0a9572d3de66399482553c8e3d2fae751",{"2":{"395":2}}],["0xd883010d04846765746888676f312e32312e33856c696e7578000000000000006b3afa42dce1f87f1f07a1ef569c4d43e41738ef93c865098bfa1458645f384e2e4498bcfe4ad9353ff1913a2e16162f496fafe5b0939a6c78fb5b503248d6da01",{"2":{"395":2}}],["0xde",{"2":{"324":2,"325":2,"326":2,"419":2,"420":2,"436":2}}],["0xdeadbeef",{"2":{"324":4,"325":3,"326":5,"420":3,"436":4}}],["0xd2d353916b34a877793628049c99858f04123ee1",{"2":{"98":1}}],["0xd0a6699fc7519966685181c80bf98d35afa1fc95",{"2":{"98":1}}],["0xef",{"2":{"324":2,"325":2,"326":2,"419":2,"420":2,"436":2}}],["0xe2662ff9b41f39e63a850e50e013ea66e60a4f37",{"2":{"98":1}}],["0xe24a60b758b51b0a3da5e8f4f6ddf1cd0aff646c",{"2":{"98":1}}],["0xe371afcb8437bf61bd831ef57be7a2496d88488b",{"2":{"98":1}}],["0x3",{"2":{"661":6,"808":6}}],["0x383ed2debf9f9055920cd7340418dda7e2bca6b989eb6992d83d123d4e322f2a",{"2":{"396":2}}],["0x3c44cdddb6a900fa2b585dd299e03d12fa4293bc",{"2":{"396":2}}],["0x3f1eae7d46d88f08fc2f8ed27fcb2ab183eb2d0e",{"2":{"119":1}}],["0x3b6e845fb9f0c8ee4e9f6d44781f6547d9c6359a",{"2":{"99":1}}],["0x3bc040eaca40b91fa06cf55ea91842fac88b1af4",{"2":{"98":1}}],["0x3681cbb0e95ab50b63f2fc524fbbcc78adefbd33",{"2":{"98":1}}],["0xaf5c1505c7dfcebca94d9a6a8c0caf99b6c87a8ed6d6c0b3161c9026f270a84f",{"2":{"396":2}}],["0xaf8ff6af1180c8be9e4e8f3a5f882b3b227233f4abbefa479836d3721682a389",{"2":{"395":2}}],["0xaddress",{"2":{"403":11}}],["0xadd3a5dc0b8c605aeac891098e87cbaff43bb642896ebbf74f964c0690e46df2",{"2":{"396":2}}],["0xad",{"2":{"324":2,"325":2,"326":2,"419":2,"420":2,"436":2}}],["0xa83ca7775bc2889825bcdedffa5b758cf69e8794",{"2":{"240":2}}],["0xa2140c9bde000dc5e21e",{"2":{"224":2}}],["0xac3427e621c6f10dc2abdab00188d92690503914",{"2":{"98":1}}],["0xa773e19dc9e822933a7e72df9c87ed1578701d29",{"2":{"98":1}}],["0xaa",{"2":{"219":1}}],["0xaa3b8b63ccca3c98b948fd1d6ed875d378de2c6c",{"2":{"97":1}}],["0xaae3a04931345df5ac6e784bb6bdeb29b1ff0286",{"2":{"96":1}}],["0x28",{"2":{"661":2,"808":2}}],["0x2b30a00",{"2":{"661":2,"808":2}}],["0x20d8153aacc4e6d29558fa3916bff422bede9b5e",{"2":{"99":1}}],["0x2588867f19e2de51f90f0ab852c7ad11228e3d83",{"2":{"98":1}}],["0x22a6580faeca49cf86cbb2f18f2b7f98031fc6ad",{"2":{"96":1}}],["0x5fbdb2315678afecb367f032d93f642f64180aa3",{"2":{"120":2,"285":2}}],["0x55527d53fda37dbf1924482b40acf8625e1caa5b",{"2":{"99":1}}],["0x5a48adf22f526ebd06e3e8856cfea2490923cc55",{"2":{"99":1}}],["0x51d196e07a27dba0f4461dd6cc26108424f196f7",{"2":{"99":1}}],["0x5187a92539bb4a2befe1fc078745c84ab6d37171",{"2":{"98":1}}],["0x53dea3a90fd6c82840a1f7224f799d622f142df4",{"2":{"98":1}}],["0x5810f0916bae1067ca1efcc00aaaf30301af001c",{"2":{"98":1}}],["0x59d2db6c5095b9e329c80211b7a761d20064379e3382d156b69e5cf3b5fe2fc7",{"2":{"91":2}}],["0x664bf4bb4a57dd5768a0a98991d77c58fb7a4e164c2581c79fb33ce9c3d4c250",{"2":{"395":2}}],["0x676d",{"2":{"374":3,"612":2}}],["0x61254e43e5c1e9e801f9c56b47a9ac3eadf6d1e9",{"2":{"99":1}}],["0x61e154128b6a1400ea8090b4431b4aa1dbb80cc4",{"2":{"98":1}}],["0x630093954cbf19fe4532a2edd0bd3b10deca7a4d",{"2":{"98":1}}],["0x6cb49605f10831749c6090ad09918bc61439bace",{"2":{"98":1}}],["0x6c7360a96165c570dcb7ce609d748d612c5fa5b76e229cd81ba5f5c93c00f805",{"2":{"91":2}}],["0x9f4dfae061b5ddd86f95a81be5daa0d7fe32e7f7f770f86dc375e0007d249bd2",{"2":{"396":2}}],["0x9039e58b2089e5f9abbb",{"2":{"224":2}}],["0x9c3f372a2aacc0d7272f56a4664311b7647b0031",{"2":{"223":32}}],["0x99e9d2f04352b42c18f1da5dd93a970f82c08afe",{"2":{"99":1}}],["0x9abc41fefae7e7543a01fa837aec909f96147280",{"2":{"99":1}}],["0x95cbda89325db5529eaf1813e181f66b83a7d65a",{"2":{"98":1}}],["0x95fea00e689e8d1cba909836e1ef1b941d5f21b1",{"2":{"98":1}}],["0x97b50f60b60d0e658fdbf185969db0a0327bd0ae9e57cd65af2a7f9be0eeb5b0",{"2":{"91":2}}],["0x40002a61b0",{"2":{"661":2,"808":2}}],["0x400065ea88",{"2":{"661":10,"808":10}}],["0x400143e048",{"2":{"661":2,"808":2}}],["0x400153b240",{"2":{"661":2,"808":2}}],["0x40f8c63e0a20b399bcd9631a22e57bb988a9400e",{"2":{"99":1}}],["0x42690c204d39600fddd3celestia",{"2":{"376":1,"384":1,"389":1}}],["0x42690c204d39600fddd3",{"2":{"296":2,"346":2,"347":2,"369":4,"374":5,"376":7,"377":2,"384":1,"389":1,"611":2,"612":2,"613":2}}],["0x4270889adcb82338c5ff5e64b45c0a3d31cfd08c",{"2":{"97":1}}],["0x44b412b291fef00398501b2ca353ea912ad0fe13",{"2":{"99":1}}],["0x4888fdf44251d456bbfca92bfc6e180cfe0b096ffbea2f6da2a203a16902214f",{"2":{"91":2}}],["0x1b91180",{"2":{"661":2,"808":2}}],["0x1bb8add5e878b12fa37756392642eb94c53a1cf4",{"2":{"97":1,"99":1}}],["0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",{"2":{"395":2}}],["0x1cb54d2369752ef73511c202ff9cdfd0eadf3a77b7aef0092bea63f2b5d57659",{"2":{"395":2}}],["0x1cc4551922c069a9ade06756bf14bf0410ea44ff",{"2":{"99":1}}],["0x1",{"2":{"306":2}}],["0x131822bef6eb59656d7e1387c19b75be667e587006710365ec5cf58030786c42",{"2":{"121":2,"286":2}}],["0x1ae3a8dc1e7efd37f418b2987d3df74c5a917a8b",{"2":{"99":1}}],["0x10c65b27d5031ce2351c719072e58f3153228887f027f9f6d65300d2b5b30152",{"2":{"94":1}}],["0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"395":2}}],["0x7973d0b475e898082df25c1617cbce1917cfed17",{"2":{"98":1}}],["0x79751b011bcc20f413a2c4e3af019b6e2a9738b9",{"2":{"96":1,"98":1}}],["0x7cf3876f681dbb6eda8f6ffc45d66b996df08fae",{"2":{"240":1}}],["0x78f8b2941dde5a8a312814ebd29c2e2a36f25e91",{"2":{"99":1}}],["0x7fc4d9a24949680fad666feee7cd6a100e39c4f0",{"2":{"98":1}}],["0x7fbeb5bc73a11b438891022786feb2c624f275f0",{"2":{"91":2}}],["0xff00000000000000000000000000000000000901",{"2":{"396":3}}],["0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1e",{"2":{"240":1}}],["0xf6759ff933786ddacb92",{"2":{"224":2}}],["0xfill",{"2":{"220":4}}],["0xf1a793a793cd9fc588f5132d99008565ea361eb3535d66499575e9e1908200b2",{"2":{"120":2,"285":2}}],["0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266",{"2":{"120":2,"285":2}}],["0xf31fd34f8a9d9057198d8b13e755e583766bd528459733d948d9ffbc980c9506",{"2":{"91":2}}],["0xf889a3174fddd9f78e6cd250ebf4c16f1bdd1b6a",{"2":{"99":1}}],["0xfb612fb83959b8acd3e49540b29c93c5a67e05f1",{"2":{"98":1}}],["0xf47dc66514fd78e4666e35abd12df7d1ae2c79f69f7dfedb8d98e4106142ab7c",{"2":{"91":2}}],["0xf2ddc2dad90e7e2b20a772bf89f989224165659d50824b98d7340e12265abf01",{"2":{"91":2}}],["0xcryptovestor",{"2":{"742":1}}],["0xce",{"2":{"396":2}}],["0xce3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"396":2}}],["0xce1636cfaf2bd5497c11",{"2":{"224":2}}],["0xc7535f078cb3880a0fd5e54fa7a3b4eaf09b3924",{"2":{"99":1}}],["0xc99eea0b8e67d5b2226ab6d37882daaf6dd7593b",{"2":{"99":1}}],["0xcd9fca5015b5ce2b06a2266e4a5dd54d9ca39f1a",{"2":{"99":1}}],["0xc61382d5609ab0ece36b2776349c8bdceeafdd13dde9624cdf3d746fb4cf7d79",{"2":{"91":2}}],["0xc3e209eb245fd59c8586777b499d6a665df3abd2",{"2":{"89":2,"95":1,"240":2}}],["0",{"2":{"80":2,"82":2,"89":6,"91":6,"94":1,"116":4,"117":5,"121":2,"126":1,"127":2,"137":2,"148":1,"149":6,"151":2,"156":16,"161":12,"162":3,"165":2,"169":2,"172":6,"183":1,"184":6,"215":1,"281":4,"282":5,"284":2,"286":2,"296":2,"297":2,"306":4,"312":6,"313":2,"314":4,"324":2,"355":1,"376":8,"377":5,"379":2,"380":2,"381":10,"382":2,"383":10,"386":3,"391":14,"396":7,"397":8,"407":1,"413":4,"414":2,"419":4,"428":4,"429":1,"432":2,"436":2,"437":8,"443":6,"445":3,"491":2,"556":2,"557":4,"576":10,"577":2,"578":2,"579":4,"594":1,"595":4,"612":2,"613":15,"643":3,"646":4,"649":2,"651":2,"655":20,"661":14,"692":3,"695":14,"700":14,"701":2,"797":8,"803":10,"808":14}}],["$ip",{"2":{"718":2}}],["$input",{"2":{"396":2}}],["$network",{"2":{"667":3,"669":3}}],["$networkdocker",{"2":{"667":3,"669":3}}],["$node",{"2":{"372":3,"667":6,"669":2,"718":2,"791":2}}],["$peer",{"2":{"718":1}}],["$peerpeer=",{"2":{"718":1}}],["$persistent",{"2":{"639":12}}],["$port",{"2":{"718":2}}],["$path",{"2":{"676":1}}],["$private",{"2":{"75":2,"76":4,"219":2,"284":2,"309":4,"310":4,"316":2,"318":6}}],["$from",{"2":{"576":6,"578":2,"579":2,"583":2}}],["$tia",{"2":{"713":2}}],["$to",{"2":{"576":6,"577":2,"579":2,"583":2}}],["$tx",{"2":{"396":2}}],["$broadcast",{"2":{"561":2}}],["$bubs",{"2":{"285":4,"286":6,"318":10}}],["$multisig",{"2":{"561":10}}],["$shell",{"2":{"676":1}}],["$seeds",{"2":{"639":8}}],["$staking",{"2":{"554":2,"715":3}}],["$signer",{"2":{"347":2}}],["$keyring",{"2":{"561":4}}],["$key",{"2":{"554":6,"712":3,"713":3,"715":3}}],["$validator",{"2":{"554":2,"561":6,"711":3,"797":2}}],["$external",{"2":{"656":2}}],["$encoded",{"2":{"397":2}}],["$etherscan",{"2":{"219":2}}],["$celes",{"2":{"554":2}}],["$celestia",{"2":{"391":2,"397":2,"573":2,"574":2,"576":6,"577":2,"578":2,"579":4}}],["$chain",{"2":{"554":4,"561":10,"711":4,"715":2}}],["$contract",{"2":{"76":6,"121":4,"286":4,"309":4,"310":4,"318":6}}],["$granter",{"2":{"296":2,"300":2,"301":2}}],["$grantee",{"2":{"295":2,"298":2,"300":2}}],["$address",{"2":{"386":6}}],["$auth",{"2":{"369":2}}],["$anvil",{"2":{"284":2}}],["$arb",{"2":{"75":2,"76":8,"120":2,"121":4}}],["$request",{"2":{"367":1,"526":1,"728":1,"765":1}}],["$receiver",{"2":{"76":2,"318":2}}],["$rpc",{"2":{"219":2,"295":2,"296":2,"300":2,"583":2,"667":6,"670":6}}],["$",{"2":{"121":2,"277":2,"286":2,"314":4,"384":2,"389":2,"594":2,"596":12,"622":2,"639":2,"650":6,"675":2}}],["$l2",{"2":{"120":2,"121":2}}],["$home",{"2":{"75":4,"77":2,"102":2,"115":3,"116":1,"212":2,"217":2,"220":2,"223":2,"224":2,"280":3,"281":1,"318":4,"319":2,"373":4,"401":2,"402":2,"557":3,"568":3,"569":1,"570":2,"573":2,"593":3,"594":1,"621":2,"622":1,"627":3,"639":11,"649":1,"650":6,"653":2,"656":2,"668":4,"669":8,"670":8,"676":20,"695":2,"710":2,"714":1,"715":1,"716":4,"717":1}}],["qo",{"2":{"656":2}}],["qgb",{"2":{"172":2,"230":1}}],["qmaezrnbtgexcryc8pcvgrbs+umukniborae4qye7osgwcrwbvys",{"2":{"383":2}}],["qm",{"2":{"156":2}}],["q5",{"2":{"48":1}}],["q4",{"2":{"48":1}}],["q3",{"2":{"48":1}}],["q2",{"2":{"48":1}}],["q1",{"2":{"48":1}}],["q",{"2":{"44":1,"59":1,"60":1,"61":1,"65":1,"546":6,"547":4,"548":4,"549":2}}],["qubelabs",{"2":{"650":12}}],["quorum",{"2":{"548":1}}],["quot",{"0":{"617":2},"2":{"30":18,"31":6,"34":6,"47":2,"53":2,"76":20,"85":2,"88":2,"89":72,"91":12,"102":4,"108":4,"116":6,"117":40,"121":8,"127":12,"134":44,"139":8,"145":8,"151":64,"152":24,"153":80,"156":356,"157":4,"159":24,"161":120,"170":16,"171":12,"172":84,"211":8,"213":12,"215":4,"216":4,"223":4,"252":2,"276":4,"277":24,"281":6,"282":40,"284":2,"286":8,"291":4,"296":36,"297":20,"300":4,"306":68,"308":12,"309":16,"310":16,"313":76,"314":232,"315":6,"316":4,"318":20,"324":40,"325":4,"326":8,"374":36,"376":128,"377":16,"379":32,"380":32,"381":52,"382":20,"383":364,"384":4,"389":4,"391":76,"393":4,"396":4,"397":60,"398":4,"403":44,"407":2,"411":36,"412":12,"413":44,"414":24,"415":32,"419":32,"420":24,"421":12,"426":2,"431":4,"436":40,"437":64,"443":96,"444":2,"445":4,"469":2,"492":2,"513":2,"521":2,"524":2,"548":156,"549":40,"554":4,"556":8,"557":36,"561":16,"569":2,"573":16,"574":32,"576":66,"577":20,"578":8,"579":16,"585":20,"590":2,"594":4,"596":16,"611":8,"612":36,"613":12,"616":2,"622":4,"639":58,"642":4,"644":6,"645":6,"646":10,"649":8,"650":36,"655":8,"656":12,"658":4,"661":8,"675":4,"676":68,"692":2,"695":188,"697":4,"700":64,"713":4,"717":4,"718":4,"788":2,"797":28,"803":36,"808":8}}],["quic",{"2":{"381":6}}],["quicker",{"2":{"648":1}}],["quickly",{"2":{"426":1,"508":1}}],["quick",{"0":{"650":1,"667":1,"782":1},"1":{"783":1,"784":1,"785":1},"2":{"335":1,"589":1,"647":1,"650":2,"669":1,"694":1,"709":1,"785":1}}],["quickstart",{"0":{"79":1,"257":1},"1":{"80":1,"81":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,"258":1,"259":1,"260":1},"2":{"73":1,"81":1,"101":1}}],["quite",{"2":{"316":1}}],["queried",{"2":{"145":1,"152":1,"155":1,"162":1,"163":1,"169":2,"181":1,"219":2,"380":1}}],["queries",{"0":{"144":1,"146":1},"1":{"145":1,"146":1,"147":2,"148":2,"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,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":1},"2":{"130":1,"145":1,"149":1,"151":1,"156":1,"161":2,"162":1,"172":1,"191":1,"366":2,"458":1,"461":1,"470":3,"537":2,"658":2,"659":3,"685":2,"763":1}}],["queryable",{"2":{"169":2}}],["querysharerange",{"2":{"159":2}}],["querying",{"0":{"130":1,"170":1,"218":1,"333":1,"546":1},"2":{"135":2,"150":1,"158":1,"160":1,"169":1,"191":1,"217":1,"218":1,"219":2,"238":1,"248":1,"333":1,"524":1,"542":2,"577":1,"649":1,"748":1,"760":1,"761":1}}],["query",{"0":{"151":1,"577":1,"578":1,"579":1,"644":1},"2":{"76":1,"129":1,"130":1,"146":1,"148":1,"150":1,"153":2,"155":1,"160":2,"164":1,"165":4,"166":1,"168":4,"169":1,"170":2,"172":2,"181":1,"184":2,"192":1,"218":1,"301":2,"318":1,"379":1,"380":1,"387":1,"437":2,"461":1,"491":1,"542":6,"546":2,"548":1,"577":2,"578":2,"579":4,"591":2,"596":1,"644":1,"645":1,"658":1,"685":1,"699":2,"726":1}}],["question",{"2":{"48":3,"447":1,"698":1,"797":1}}],["questions",{"0":{"48":1},"2":{"17":1,"47":2}}],["quad",{"2":{"635":1,"771":1,"772":1}}],["quadratic",{"2":{"462":1}}],["quantum",{"2":{"230":1}}],["qualify",{"2":{"34":1}}],["qualification",{"2":{"34":3}}],["qualified",{"2":{"34":1}}],["quality",{"2":{"24":1,"46":1,"47":1,"65":1}}],["quarterly",{"2":{"42":1}}],["quarter",{"2":{"29":1}}],["9390",{"2":{"744":1,"763":1}}],["96112",{"2":{"576":4}}],["96ms",{"2":{"117":2,"282":2}}],["999994999800000",{"2":{"579":2}}],["99",{"2":{"450":1}}],["973",{"2":{"426":1,"738":2}}],["9anbaxno1b4x5lr2qy5qwqwrmnozejkctxwzq9bexsg=",{"2":{"383":4}}],["91e04695cf9cf531bc0891e7b1d602b3e8022c86",{"2":{"383":8}}],["9545",{"2":{"309":4}}],["9545anvil",{"2":{"309":1}}],["9070",{"2":{"760":1}}],["9080",{"2":{"748":1}}],["9099",{"2":{"763":1}}],["9095",{"2":{"744":1}}],["9090",{"2":{"366":1,"391":1,"521":1,"524":1,"537":1,"538":1,"557":2,"595":2,"606":1,"685":1,"726":1,"744":3,"748":7,"760":2,"763":5}}],["90",{"2":{"314":2}}],["90vw",{"2":{"314":2}}],["900px",{"2":{"313":2}}],["9000",{"2":{"313":2,"315":1}}],["9000000utia",{"2":{"715":1}}],["90000",{"2":{"153":2,"170":4}}],["902",{"2":{"31":1,"34":5}}],["9",{"0":{"91":1},"2":{"33":1,"34":1,"499":1}}],["782",{"2":{"661":2,"808":2}}],["786bytes",{"2":{"738":1}}],["786",{"2":{"426":1,"738":1}}],["770",{"2":{"661":2,"808":2}}],["746",{"2":{"661":2,"808":2}}],["741743z",{"2":{"383":2}}],["75",{"2":{"439":1,"440":1,"441":1,"500":1}}],["767",{"2":{"395":2}}],["76au8rj4vsyvasph5lgqq2kg",{"2":{"156":2}}],["7a5fabb19713d732d967b1da84fa0df5e87a7b62302d783f78743e216c1a3550",{"2":{"383":2}}],["71",{"2":{"381":4}}],["7",{"0":{"89":1},"2":{"31":1,"34":1,"156":2,"383":4,"395":2,"499":2,"577":2,"694":1}}],["5s",{"2":{"557":2,"695":4}}],["554+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"407":2}}],["5iieerohbmff+ser3jpvroieejzjby+tre0ntadqll3",{"2":{"383":4}}],["564+0200\\tinfo\\tnode\\tnodebuilder",{"2":{"407":2}}],["56",{"2":{"363":2,"722":2,"771":1}}],["512gb",{"2":{"226":1}}],["5158076079",{"2":{"91":2}}],["53",{"2":{"223":2}}],["57",{"2":{"172":2}}],["58",{"2":{"91":2,"165":4,"172":2,"223":2}}],["5",{"0":{"87":1,"672":1},"2":{"31":1,"34":1,"151":2,"156":2,"172":2,"314":4,"405":2,"406":1,"414":1,"416":2,"432":2,"445":1,"495":1,"505":1,"557":2,"563":1,"695":4}}],["500ms",{"2":{"695":4}}],["5000100000000utia",{"2":{"554":2}}],["500000000",{"2":{"383":4}}],["500",{"2":{"363":1,"426":1,"695":2,"722":1,"771":1}}],["5001",{"2":{"314":2}}],["50px",{"2":{"314":2}}],["504g",{"2":{"223":1,"224":1}}],["50",{"2":{"21":1,"23":2,"28":1,"363":1}}],["+0x110",{"2":{"661":2,"808":2}}],["+0x1c8",{"2":{"661":2,"808":2}}],["+0x124",{"2":{"661":2,"808":2}}],["+0x2c4",{"2":{"661":2,"808":2}}],["+0x2d8",{"2":{"661":2,"808":2}}],["+0x26c",{"2":{"661":2,"808":2}}],["+0xd30",{"2":{"661":2,"808":2}}],["+0x44",{"2":{"661":2,"808":2}}],["+0x64",{"2":{"661":2,"808":2}}],["+2",{"0":{"661":1,"808":1},"2":{"661":2,"808":2}}],["+stake",{"2":{"479":1}}],["+sgf6mfzmmtdkz5mllh+y7mpv9moo2x5rljle3gbfqo=",{"2":{"151":2}}],["+mhkrh9borgjn3oqt",{"2":{"156":2}}],["+1",{"2":{"137":2,"139":4}}],["+",{"2":{"27":2,"102":1,"137":2,"139":2,"183":1,"184":2,"306":4,"314":6,"355":1,"443":10,"609":1,"689":1,"738":1}}],["856",{"2":{"661":2,"808":2}}],["8548",{"2":{"119":1}}],["8545cast",{"2":{"310":1,"395":1,"396":1}}],["8545export",{"2":{"284":1}}],["8545",{"2":{"119":1,"284":2,"309":1,"310":5,"313":2,"315":1,"316":1,"395":1,"396":1}}],["8547",{"2":{"75":1,"119":1,"120":2}}],["8547export",{"2":{"75":1,"120":1}}],["87",{"2":{"616":2}}],["80000",{"2":{"386":3}}],["80000celestia",{"2":{"386":1}}],["8000",{"2":{"386":4,"557":1}}],["800px",{"2":{"314":4}}],["8dxemrbwrpwj6hi+3uesz+0p5vrf3v8ssaqeabelorfgaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"161":2}}],["8woyobnjs3mt1dkfrqid8vc75oja2jnf3wn",{"2":{"156":2}}],["8449",{"2":{"91":3}}],["8",{"0":{"90":1},"2":{"23":2,"34":1,"94":2,"116":6,"117":4,"126":1,"127":2,"161":2,"172":2,"277":2,"281":6,"282":4,"306":4,"308":2,"312":4,"426":2,"495":1,"499":1,"505":1,"569":4,"772":1,"794":1}}],["kv",{"2":{"642":2,"644":3,"658":5}}],["kjnodes",{"2":{"503":1,"742":1,"743":1,"744":1,"752":1}}],["k×k",{"2":{"461":3,"463":1,"469":1}}],["kr",{"2":{"437":6}}],["kbps",{"2":{"363":2,"722":2,"771":1}}],["kqkhkpjxmiby",{"2":{"156":2}}],["known",{"2":{"160":1,"230":1,"236":1}}],["knowing",{"2":{"48":1}}],["know",{"2":{"44":1,"45":1,"47":2,"107":1,"228":1,"256":1,"262":1,"490":1,"645":1}}],["knowledgeable",{"2":{"42":1,"43":1}}],["knowledge",{"2":{"34":1,"43":1,"46":1,"65":1,"127":2,"133":1,"230":1,"290":1}}],["kept",{"2":{"448":1}}],["keplrbutton",{"2":{"443":2}}],["keplr",{"0":{"443":1,"473":1,"474":1},"1":{"474":1,"475":1,"476":1,"477":1},"2":{"442":1,"443":18,"471":1,"474":2,"475":1,"476":1,"502":1,"503":1,"560":1}}],["keeping",{"2":{"462":1}}],["keeps",{"2":{"108":1,"148":1}}],["keep",{"2":{"41":1,"42":1,"136":1,"221":1,"270":2,"403":1,"516":1,"558":1,"639":1,"646":3,"717":2,"803":1}}],["keymake",{"2":{"621":1}}],["keyfile",{"2":{"545":2}}],["keyforge",{"2":{"219":1}}],["keybase",{"2":{"545":1}}],["keyname",{"0":{"713":1},"2":{"277":2,"344":2,"367":6,"539":6,"686":6,"727":6,"729":6}}],["keyring",{"2":{"270":6,"271":7,"272":6,"276":2,"277":4,"300":2,"310":2,"316":2,"344":2,"349":2,"353":1,"367":10,"437":10,"538":2,"539":7,"543":4,"545":1,"561":6,"581":3,"585":4,"590":2,"609":3,"685":2,"686":7,"712":2,"713":2,"715":2,"727":10,"729":7,"797":2,"803":2}}],["key`",{"2":{"211":4,"269":4}}],["keycast",{"2":{"121":1,"286":1,"309":1,"310":1}}],["key=sk",{"2":{"408":2}}],["key=ac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80",{"2":{"318":2}}],["key=$",{"2":{"310":2,"316":2}}],["key=0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80",{"2":{"284":2,"285":2}}],["key=0xe887f7d17d07cc7b8004053fb8826f6657084e88904bb61590e498ca04704cf2",{"2":{"120":2}}],["key=0xb6b15c8cb491557369f3c7d2c287b053eb229daa9c22138887752191c9520659",{"2":{"75":2}}],["key=",{"2":{"91":2,"211":2,"314":2}}],["keys`",{"2":{"437":4}}],["keystore",{"2":{"347":1,"348":1}}],["keys",{"0":{"270":1,"271":1,"272":1,"277":1,"367":1,"545":1,"574":1,"727":1},"1":{"728":1},"2":{"27":1,"31":1,"86":1,"113":1,"211":2,"268":2,"270":2,"276":1,"277":8,"293":1,"309":2,"310":2,"316":2,"331":1,"348":1,"365":1,"403":2,"539":1,"540":1,"542":4,"543":1,"544":16,"545":6,"554":2,"561":10,"573":2,"574":2,"575":1,"581":8,"585":2,"590":4,"609":3,"673":1,"686":1,"687":1,"696":6,"697":1,"712":2,"714":1,"729":1,"730":1,"797":2}}],["key",{"0":{"23":1,"106":1,"268":1,"273":1,"274":1,"332":1,"344":1,"345":1,"346":1,"348":1,"349":1,"350":1,"408":1,"539":1,"544":1,"573":1,"669":1,"686":1,"712":1,"729":1},"1":{"107":1,"108":1,"109":1,"110":1,"269":1,"270":1,"271":1,"272":1,"273":1,"275":1,"276":1,"277":1,"346":1,"347":1,"349":1,"350":1,"545":1,"687":1,"730":1},"2":{"38":2,"43":1,"55":1,"75":5,"76":9,"84":3,"88":1,"91":2,"106":1,"119":3,"120":5,"121":3,"137":2,"156":8,"165":4,"168":5,"184":3,"211":14,"212":8,"213":8,"219":10,"220":2,"227":2,"267":2,"268":2,"269":5,"270":18,"271":13,"272":12,"273":2,"276":5,"277":11,"284":5,"285":5,"286":3,"292":1,"309":7,"310":12,"312":4,"316":6,"318":14,"332":1,"343":3,"344":2,"346":3,"348":2,"349":2,"350":2,"367":15,"379":1,"383":4,"401":1,"403":11,"406":1,"407":8,"408":5,"414":5,"437":2,"460":1,"510":1,"538":5,"539":9,"544":8,"545":13,"548":4,"561":2,"571":1,"572":1,"573":8,"574":6,"575":1,"577":2,"578":4,"579":4,"581":1,"608":2,"609":3,"621":2,"658":1,"665":2,"669":1,"685":5,"686":9,"695":12,"712":2,"713":1,"727":16,"729":9}}],["kib",{"2":{"426":1}}],["kit",{"2":{"57":2,"58":1,"63":1}}],["kickstarting",{"2":{"39":1}}],["kinds",{"2":{"191":1}}],["kindly",{"2":{"52":1}}],["kind",{"2":{"8":1,"34":1}}],["kindness",{"2":{"8":1}}],["k",{"2":{"31":1,"34":3,"156":2,"172":8,"463":3}}],["67",{"2":{"500":3}}],["64x64",{"2":{"426":1,"738":1}}],["64",{"2":{"424":1,"594":1,"622":1,"738":1}}],["64cpu",{"2":{"223":1,"224":1,"226":1}}],["6363c68770c200fd794445668f9b18f5b1dd1125180d6e8d5ab004f7dd7a0f48",{"2":{"383":4}}],["65",{"2":{"381":4,"429":1,"430":1}}],["62562",{"2":{"377":2}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2",{"2":{"576":1}}],["6093df76dba90f04ff63d197fc1569f04ed3dbe64081a0bba9bad4e69aa570d2gas",{"2":{"576":1}}],["60",{"2":{"220":1}}],["6962",{"2":{"128":1}}],["6",{"0":{"88":1},"2":{"21":1,"24":1,"27":1,"31":1,"34":1,"80":1,"82":1,"443":6,"444":1,"445":1,"499":2,"505":1,"532":1,"661":2,"679":1,"771":1,"808":2}}],["jemalloc",{"2":{"621":2}}],["jemallocmake",{"2":{"621":1}}],["jwt",{"2":{"412":2,"413":2,"415":2}}],["jq",{"2":{"384":2,"386":3,"389":3,"639":2,"675":10,"788":4}}],["jail",{"2":{"563":1}}],["jailing",{"0":{"563":1},"2":{"563":1}}],["jailed",{"2":{"24":2,"25":1,"27":1,"563":2}}],["javascriptyarn",{"2":{"311":1}}],["javascript",{"2":{"311":2}}],["j",{"2":{"165":4,"168":4,"172":8}}],["j2pyclt4khpiqvh7b6wp9kcdmghlct9edfydr7zaq9o=",{"2":{"156":2}}],["jh0tyrmtrdtha",{"2":{"156":2}}],["jsimport",{"2":{"443":3}}],["jsximport",{"2":{"313":1,"314":1}}],["jsx",{"2":{"313":1,"314":1,"316":3,"443":1}}],["jsxnpm",{"2":{"312":1}}],["jsxyarn",{"2":{"311":1}}],["js",{"2":{"114":2,"279":2,"304":1,"311":1,"443":2}}],["jsoncelestia",{"2":{"299":1}}],["jsonrpc",{"2":{"151":2,"156":2,"161":2,"379":2,"380":2,"381":2,"382":2,"383":2,"391":4,"397":4}}],["jsondocker",{"2":{"102":2}}],["json",{"0":{"716":1},"2":{"68":1,"77":4,"84":2,"86":2,"87":2,"88":1,"89":1,"91":2,"92":1,"102":6,"134":2,"137":2,"151":1,"156":1,"161":1,"296":2,"297":1,"299":1,"311":3,"314":2,"319":4,"333":1,"355":1,"374":2,"376":4,"377":1,"379":1,"380":1,"381":1,"382":1,"391":2,"397":2,"398":1,"438":1,"542":6,"548":9,"549":5,"554":1,"561":18,"639":3,"714":3,"715":3,"716":6}}],["jcstein",{"2":{"75":2,"318":2}}],["journalctl",{"2":{"553":6,"788":2,"790":2,"791":2,"792":2}}],["journey",{"2":{"35":1,"50":1}}],["jotzla2v3g2q7y+18ih5j0uxk",{"2":{"161":2}}],["job",{"2":{"48":1,"261":1,"457":1,"557":8}}],["joining",{"0":{"48":1},"2":{"42":1,"47":1,"53":1,"65":1}}],["join",{"2":{"19":1,"50":1,"529":1}}],["june",{"2":{"28":1}}],["jurisdiction",{"2":{"24":1,"34":5}}],["justifycontent",{"2":{"314":6}}],["just",{"2":{"8":1,"85":1,"91":2,"102":1,"126":1,"135":1,"268":1,"309":1,"386":1,"426":1,"470":1,"497":1,"502":1,"503":1,"516":1,"557":1,"565":1,"685":1,"779":1,"785":1}}],["4hermes",{"2":{"699":1}}],["4hr",{"2":{"224":1}}],["48pm",{"2":{"661":2,"808":2}}],["48",{"2":{"661":2,"808":2}}],["482",{"2":{"426":1,"738":1}}],["4️⃣",{"0":{"477":1,"486":1}}],["4k",{"2":{"461":1,"462":1,"463":1,"469":1,"470":1}}],["443celestia",{"2":{"547":1}}],["443export",{"2":{"300":1,"583":1}}],["443",{"2":{"291":1,"300":1,"301":2,"521":1,"547":3,"583":1,"585":2,"695":2,"742":2,"743":2,"744":7,"745":2,"760":2,"761":3,"763":4}}],["478",{"2":{"426":1,"738":1}}],["47",{"2":{"223":2}}],["41",{"2":{"223":2}}],["46",{"2":{"149":2}}],["43494",{"2":{"121":4,"286":4}}],["49",{"2":{"407":4}}],["49s",{"2":{"91":2}}],["4989526079",{"2":{"91":2}}],["400000",{"2":{"695":4}}],["400px",{"2":{"314":2}}],["401",{"2":{"611":4}}],["4094×482bytes",{"2":{"738":1}}],["4094",{"2":{"426":1}}],["4095",{"2":{"426":1,"738":1}}],["4096",{"2":{"426":1,"738":1}}],["40px",{"2":{"314":2}}],["40",{"2":{"43":1,"383":2}}],["4",{"0":{"16":1,"34":1,"86":1},"2":{"22":1,"23":3,"26":1,"27":1,"28":1,"31":1,"34":13,"80":1,"82":1,"85":1,"89":2,"91":2,"95":1,"156":2,"172":2,"183":1,"225":1,"237":1,"277":4,"300":2,"396":2,"412":2,"413":2,"415":2,"491":1,"499":1,"500":1,"503":1,"521":2,"692":1,"695":3,"696":2,"698":1,"699":5,"700":10,"701":3,"760":3,"761":2,"762":1,"763":4,"764":8}}],["3152",{"2":{"700":2}}],["3108",{"2":{"695":2,"701":2}}],["33373",{"2":{"742":1,"745":1}}],["33554432",{"2":{"695":4}}],["33",{"2":{"500":3,"596":2}}],["3️⃣",{"0":{"476":1,"481":1,"485":1}}],["3d96b7d238e7e0456f6af8e7cdf0a67bd6cf9c2089ecb559c659dcaa1f880353",{"2":{"383":2}}],["3dmfzfawzmtzvxhphf5txlcj+ct3evmmfopixfh+id4=",{"2":{"161":2}}],["3+fuhlzufkjnzd8yg",{"2":{"161":2}}],["3wl9cwxs8rqbddgupu9p8jcfj+jc77zsswdcf6pm=",{"2":{"156":2}}],["34",{"2":{"149":2,"661":14,"694":1,"808":14}}],["32cpu",{"2":{"220":1}}],["32",{"2":{"149":2,"153":6,"165":3,"168":4,"169":6,"172":14,"211":2,"213":4}}],["391",{"2":{"661":2,"808":2}}],["39",{"2":{"139":2,"153":2,"170":2,"172":2,"211":10,"277":4,"296":4,"324":2,"346":4,"347":4,"369":8,"374":8,"377":4,"383":2,"384":4,"389":4,"391":4,"397":4,"413":2,"415":4,"419":2,"436":2,"437":8,"443":62,"542":2,"557":2,"573":4,"574":8,"576":8,"577":4,"578":8,"585":2,"639":48,"655":4,"668":2,"701":24,"797":4,"803":4}}],["3767182372",{"2":{"121":2,"286":2}}],["30s",{"2":{"695":4}}],["3001",{"2":{"695":2}}],["30000",{"2":{"695":2}}],["30000000",{"2":{"395":2}}],["3000",{"2":{"557":1,"695":2}}],["300xzo8tilwpnurey6ojcrkzthq4y6yy6qh0waummrc=",{"2":{"161":2}}],["30t08",{"2":{"383":2}}],["30",{"2":{"91":2,"165":2,"172":2,"491":4,"695":4}}],["3663",{"2":{"694":1}}],["3623",{"2":{"694":1}}],["362101",{"2":{"391":2}}],["36",{"2":{"23":1,"223":2}}],["35",{"2":{"23":1,"223":14,"661":14,"808":14}}],["3",{"0":{"15":1,"33":1,"84":1,"85":1,"650":1,"661":1,"808":1},"2":{"23":1,"28":1,"30":1,"31":1,"34":1,"43":1,"89":2,"91":4,"94":1,"102":2,"106":1,"121":2,"148":1,"149":6,"172":2,"277":2,"286":2,"405":2,"406":1,"412":2,"413":2,"414":4,"415":6,"416":2,"500":1,"521":2,"548":1,"556":2,"561":4,"594":1,"622":1,"661":2,"695":4,"808":2}}],["2382",{"2":{"700":4}}],["2371495",{"2":{"651":1,"692":1,"803":1}}],["2371495celestia",{"2":{"651":1,"803":1}}],["23",{"2":{"612":2}}],["26357",{"2":{"760":1}}],["26557",{"2":{"748":1}}],["26660",{"2":{"556":4,"557":2}}],["26656",{"2":{"521":1,"656":2,"718":1}}],["26659version",{"2":{"277":1}}],["26659",{"2":{"276":4,"277":3,"606":1}}],["26657",{"2":{"89":2,"152":2,"153":2,"391":1,"521":1,"523":1,"538":2,"595":2,"606":1,"655":4,"695":4,"747":1,"748":6,"759":1,"760":1,"761":3,"788":2}}],["26658curl",{"2":{"391":1,"397":1}}],["26658",{"2":{"89":3,"323":2,"370":1,"391":1,"397":1,"415":2,"418":2,"606":1}}],["26",{"2":{"499":1}}],["2️⃣",{"0":{"475":1,"480":1,"484":1}}],["2k",{"2":{"463":1}}],["2k×2k",{"2":{"461":2,"469":1}}],["27090",{"2":{"760":1,"763":1}}],["2727",{"2":{"700":6}}],["27t13",{"2":{"383":2}}],["27709",{"2":{"117":2,"282":2}}],["2585031",{"2":{"651":1,"692":1,"803":1}}],["2585031celestia",{"2":{"651":1,"803":1}}],["25231",{"2":{"613":5}}],["252614",{"2":{"374":3,"376":9,"389":2}}],["252607",{"2":{"374":2}}],["25",{"2":{"445":1,"500":1,"563":1,"661":2,"808":2}}],["255",{"2":{"314":6}}],["25630",{"2":{"381":4}}],["256gb",{"2":{"220":1}}],["256",{"2":{"117":2,"282":2}}],["2s",{"2":{"262":1}}],["22t14",{"2":{"407":4}}],["2283",{"2":{"395":2}}],["22",{"2":{"172":2,"276":2,"277":2,"373":4}}],["2zdir",{"2":{"156":2}}],["299137127z",{"2":{"383":2}}],["29",{"2":{"149":2,"165":7,"166":1,"172":2,"661":14,"808":14}}],["28657",{"2":{"748":1}}],["28090",{"2":{"744":1,"748":1}}],["28",{"2":{"165":5,"166":3,"172":8,"692":1}}],["28409",{"2":{"117":2,"282":2}}],["28334",{"2":{"117":2,"282":2}}],["28217653",{"2":{"91":2}}],["28217647",{"2":{"91":2}}],["2f",{"2":{"69":1}}],["2e",{"2":{"69":1}}],["2d",{"2":{"69":1}}],["2c",{"2":{"69":1,"72":1}}],["2blockhash",{"2":{"121":1,"286":1}}],["2b",{"2":{"69":1,"72":1}}],["2ae1ddf74ef7",{"2":{"149":2}}],["2a",{"2":{"69":1,"72":1}}],["24s",{"2":{"116":2,"281":2}}],["24",{"2":{"25":1,"396":2,"661":4,"808":4}}],["21090",{"2":{"763":1}}],["214",{"2":{"661":2,"808":2}}],["216\\tnew",{"2":{"407":2}}],["211\\tno",{"2":{"407":2}}],["21572",{"2":{"396":2}}],["21568",{"2":{"395":2}}],["2121",{"2":{"276":2,"277":2,"381":8,"521":4,"595":2,"596":4,"606":2,"791":2}}],["21",{"2":{"23":1,"116":2,"276":2,"277":2,"281":2,"563":1}}],["2019",{"2":{"733":1}}],["2001",{"2":{"661":2,"808":2}}],["200",{"2":{"381":4}}],["20000",{"2":{"695":2}}],["20000utia",{"2":{"300":2}}],["2000",{"2":{"295":1}}],["2000celestia",{"2":{"295":1}}],["20+",{"2":{"311":1}}],["2048",{"2":{"224":4}}],["20ignition",{"2":{"223":16}}],["20210819022825",{"2":{"149":2}}],["2023",{"2":{"30":1,"383":4}}],["2025",{"2":{"28":1}}],["2024",{"2":{"21":1,"28":2,"223":14,"407":4,"661":1,"692":3,"808":1}}],["20",{"2":{"23":1,"28":1,"43":1,"151":1,"152":2,"334":1,"499":1,"533":1,"636":1,"680":1,"723":1,"795":1}}],["2",{"0":{"14":1,"32":1,"69":1,"72":1,"83":1,"154":1,"347":1,"649":1,"672":1,"698":1},"2":{"17":2,"23":2,"24":1,"27":1,"28":1,"31":1,"32":1,"34":1,"41":1,"43":1,"48":1,"71":1,"72":1,"80":1,"91":2,"94":4,"117":4,"121":1,"127":2,"148":1,"151":2,"154":1,"156":2,"161":2,"172":3,"184":1,"196":1,"215":1,"282":4,"286":1,"314":2,"355":1,"379":2,"380":2,"381":2,"382":2,"383":4,"391":4,"395":2,"397":4,"412":2,"413":2,"415":2,"426":1,"461":1,"463":3,"464":3,"466":1,"469":1,"498":1,"500":2,"510":1,"521":2,"554":2,"561":4,"563":1,"578":2,"635":1,"651":1,"661":2,"761":1,"762":1,"763":1,"764":6,"772":2,"794":1,"798":1,"803":3,"808":2}}],["1×478bytes",{"2":{"738":1}}],["1️⃣",{"0":{"474":1,"479":1,"483":1}}],["1utia",{"2":{"437":2,"561":2}}],["1usgft4=",{"2":{"156":2}}],["1751707",{"2":{"651":1,"692":1,"803":1}}],["1751707celestia",{"2":{"651":1,"803":1}}],["17",{"2":{"499":1,"692":1}}],["171",{"2":{"381":4}}],["172118057",{"2":{"379":2}}],["1px",{"2":{"314":2}}],["1s",{"2":{"261":1,"262":1}}],["1hr",{"2":{"220":2}}],["19000000utia",{"2":{"547":2}}],["19l",{"2":{"296":2}}],["196",{"2":{"223":32}}],["19",{"2":{"116":4,"126":1,"127":2,"223":16,"281":4,"383":2,"499":1,"692":1}}],["1933",{"2":{"31":2,"34":3}}],["1443",{"2":{"763":1}}],["1400000",{"2":{"617":1}}],["147105",{"2":{"384":2}}],["14",{"2":{"91":2,"149":2,"369":1,"596":2,"608":1,"661":2,"692":3,"808":2}}],["1318129",{"2":{"611":2,"612":2,"613":2}}],["1317",{"2":{"521":1,"762":1}}],["1350632",{"2":{"156":2}}],["13",{"2":{"80":1,"91":2,"94":2,"116":2,"117":2,"281":2,"282":2,"306":4,"308":2,"491":2,"622":1,"737":1}}],["1g",{"2":{"71":1}}],["1f",{"2":{"71":1}}],["1em",{"2":{"314":2}}],["1ether",{"2":{"76":2,"318":2}}],["1e",{"2":{"71":1}}],["1d",{"2":{"71":1}}],["1container",{"2":{"276":1,"277":1}}],["1c",{"2":{"68":1,"71":1}}],["1b",{"2":{"68":1,"71":1}}],["1a",{"2":{"68":1,"71":1}}],["11090",{"2":{"744":1}}],["11036",{"2":{"557":1}}],["115",{"2":{"596":2}}],["118",{"2":{"443":2,"444":1,"445":1}}],["11celestia",{"2":{"407":1}}],["11155111",{"2":{"403":2}}],["1117733",{"2":{"403":2}}],["1141",{"2":{"395":2}}],["11",{"2":{"34":1,"223":2,"344":2,"366":2,"383":4,"407":3,"444":2,"521":11,"524":2,"527":1,"528":1,"538":2,"661":4,"692":1,"726":2,"727":2,"808":4}}],["180000",{"2":{"695":4}}],["18",{"2":{"31":1,"84":1,"149":2,"313":2,"692":1}}],["16002",{"2":{"763":1}}],["1606",{"2":{"661":2,"808":2}}],["169",{"2":{"661":2,"808":2}}],["1699638350",{"2":{"395":2}}],["1637",{"2":{"661":2,"808":2}}],["1639397",{"2":{"296":2}}],["1687908352",{"2":{"577":2}}],["1686748051",{"2":{"576":8,"577":2,"583":2}}],["16px",{"2":{"314":2}}],["16xlarge",{"2":{"226":1}}],["16",{"2":{"30":1,"91":2,"172":2,"532":1,"635":1,"650":12,"679":1,"692":1,"771":2,"772":2,"794":1}}],["151",{"2":{"596":2}}],["15s",{"2":{"557":2}}],["1559",{"2":{"428":1}}],["15",{"2":{"28":2,"91":2,"151":1,"152":2,"161":1,"162":2,"169":1,"223":16,"314":4,"407":4,"499":1,"557":2}}],["15002",{"2":{"744":1}}],["1500",{"2":{"27":1}}],["10790",{"2":{"763":2}}],["10s",{"2":{"695":4}}],["103",{"2":{"548":2}}],["105",{"2":{"548":3}}],["1089",{"2":{"440":1}}],["1080694",{"2":{"156":2}}],["1040676758",{"2":{"396":2}}],["106",{"2":{"381":4}}],["10px",{"2":{"314":6}}],["1024cd",{"2":{"224":1}}],["1024",{"2":{"224":14}}],["1095604",{"2":{"156":2}}],["10+",{"2":{"40":1}}],["10",{"2":{"24":3,"34":1,"89":4,"121":3,"151":3,"152":2,"161":1,"162":1,"172":2,"286":3,"312":2,"374":1,"381":4,"403":1,"429":1,"444":1,"495":1,"505":1,"526":1,"532":1,"679":1,"695":4,"765":1,"771":2}}],["1000",{"2":{"695":2}}],["10001",{"2":{"668":4}}],["1000utia",{"2":{"561":4}}],["100000utia",{"2":{"561":2,"576":12,"583":4}}],["100000",{"2":{"386":4,"576":4,"577":2,"579":2,"583":2,"695":4}}],["10000000utia",{"2":{"713":2}}],["100000000000utia",{"2":{"549":2}}],["1000000000",{"2":{"548":2}}],["1000000000utia",{"2":{"548":2,"549":2}}],["1000000",{"2":{"380":2,"553":2}}],["1000000utia",{"2":{"300":2,"797":2}}],["100vh",{"2":{"314":2}}],["100",{"2":{"21":1,"89":2,"171":2,"314":2,"494":2,"695":2,"722":1,"771":1}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22",{"2":{"791":1}}],["12d3koowd5wcbjxkqudjhxfjtfmrzoysgvltvht5hmovbslcbv22node",{"2":{"791":1}}],["12d3koowkeertzvmpudxyszo2edqps6ms67n6lt5mpdulskpsxbq",{"2":{"596":2}}],["12d3koowlt1yssrd7xwsbjh7tu1hqanf5m64dhv6aum6cyejxmpk",{"2":{"521":1}}],["12d3koowewuqrjulanpukdfgvohw3roeuu53ec9t9v5cww3mkvdq",{"2":{"521":1}}],["12d3koowcmgm5ezwvfcn9zlavigfluwafxp5pcm78nfkb9jpbtua",{"2":{"521":1}}],["12d3koowgqwzdeqm54dce6lxzffr97bnhvm6rn7km7mfwdomfm4s",{"2":{"521":1}}],["12d3koowffhcaaqy56oeqy3plzudlsv4ryafvwkatzrepupdoslp",{"2":{"381":2}}],["127",{"2":{"284":1,"391":3,"397":2,"655":2,"695":4}}],["1234",{"2":{"211":3}}],["123456",{"2":{"618":1}}],["1234567890",{"2":{"437":2}}],["12345=",{"2":{"211":6}}],["12345",{"2":{"211":9,"306":14,"309":2,"310":2}}],["128gb",{"2":{"424":1}}],["128",{"2":{"156":2}}],["120000",{"2":{"156":2}}],["12",{"2":{"23":2,"336":1,"499":1}}],["1",{"0":{"13":1,"31":1,"68":1,"71":1,"82":1,"150":1,"346":1,"648":1},"1":{"151":1,"152":1},"2":{"17":2,"22":1,"23":7,"24":1,"25":1,"26":1,"28":4,"30":1,"31":8,"32":1,"34":2,"41":1,"48":1,"80":1,"82":1,"83":1,"91":4,"94":6,"102":4,"116":2,"117":3,"121":2,"137":4,"139":2,"148":1,"149":4,"151":2,"152":6,"153":2,"154":1,"156":2,"161":5,"162":2,"165":6,"166":2,"169":2,"172":14,"215":1,"225":1,"237":2,"261":2,"262":1,"276":1,"277":1,"281":2,"282":3,"284":1,"286":2,"306":12,"366":2,"379":2,"380":2,"381":6,"382":2,"383":13,"386":1,"391":7,"397":6,"398":1,"407":2,"412":2,"413":2,"415":2,"419":2,"426":4,"432":1,"437":2,"443":2,"445":1,"454":1,"463":1,"495":1,"499":1,"500":8,"505":3,"513":2,"521":2,"524":2,"532":2,"538":2,"548":1,"553":2,"554":2,"563":1,"613":5,"635":2,"647":1,"651":1,"655":2,"661":2,"679":2,"695":14,"726":2,"727":2,"738":1,"761":1,"762":1,"763":1,"764":4,"771":2,"772":2,"794":2,"803":3,"808":2}}],["ua",{"2":{"760":2,"761":1,"762":1,"763":1,"767":1}}],["uatom",{"2":{"695":2}}],["udp",{"2":{"381":6,"595":1,"606":1}}],["uri",{"2":{"366":6,"367":6,"537":8,"538":2,"539":6,"547":4,"598":4,"599":2,"600":2,"601":8,"604":2,"685":2,"686":6,"729":6,"791":2,"792":2,"800":2}}],["urldocker",{"2":{"670":3}}],["urlcelestia",{"2":{"295":1}}],["urlcast",{"2":{"76":3,"121":1,"286":1,"318":3}}],["url=this",{"2":{"667":2}}],["url=rpc",{"2":{"293":2}}],["url=",{"2":{"91":4,"218":2}}],["url=https",{"2":{"285":2,"300":2,"318":2,"583":2}}],["url=http",{"2":{"75":2,"120":2,"284":2}}],["urlexport",{"2":{"76":1,"318":1}}],["url",{"0":{"88":1},"2":{"47":2,"75":5,"76":12,"88":5,"89":4,"91":1,"120":4,"121":7,"212":4,"213":12,"219":5,"220":2,"227":2,"250":1,"279":1,"284":4,"285":5,"286":7,"295":1,"296":2,"300":3,"309":2,"310":6,"315":1,"318":17,"323":2,"324":4,"325":4,"326":4,"327":4,"369":1,"370":1,"395":2,"396":2,"403":2,"418":2,"419":4,"420":4,"421":4,"436":4,"444":3,"445":4,"520":1,"523":1,"524":3,"557":2,"583":5,"585":1,"667":9,"670":3,"695":4,"740":1,"747":1,"748":3,"758":1,"759":1,"760":1}}],["urls",{"0":{"248":1},"1":{"249":1,"250":1},"2":{"47":2,"88":1,"211":2,"220":1,"248":2}}],["ubuntu",{"2":{"334":1,"533":1,"636":1,"665":1,"675":1,"676":2,"680":1,"723":1,"795":1}}],["ugp0sv9ynei5poiyr7rdodswwlfbh2o3xirsmmnmbks=",{"2":{"161":2}}],["uhlbgdgo=",{"2":{"156":2}}],["uhhb3u6dpayj1pjnefrwq5he=",{"2":{"151":2}}],["utc",{"2":{"692":3}}],["ut8sjtguh+akimnqtkuuu",{"2":{"156":2}}],["utility",{"0":{"268":1,"413":1},"1":{"269":1,"270":1,"271":1,"272":1,"273":1},"2":{"267":1,"268":3,"270":1,"412":1,"413":2,"414":1,"621":1,"727":1}}],["utilizing",{"0":{"47":1}}],["utilize",{"2":{"43":1,"45":2,"46":1,"335":1}}],["utia=tia×10−6",{"2":{"505":1}}],["utiacelestia",{"2":{"301":1}}],["utia",{"0":{"386":1,"513":1},"2":{"89":1,"295":1,"296":2,"297":2,"301":1,"377":1,"379":2,"380":2,"386":6,"443":6,"444":1,"445":1,"513":3,"514":1,"548":2,"576":4,"577":2,"579":4,"695":2}}],["uint32",{"2":{"431":4,"437":4}}],["uint",{"2":{"306":18}}],["uint8",{"2":{"166":2,"215":2}}],["uint64",{"2":{"134":8,"135":4,"137":4,"139":4,"153":10,"169":4,"172":14,"228":3,"327":2,"413":2}}],["uint256",{"2":{"116":4,"117":4,"121":2,"127":2,"163":2,"165":4,"168":4,"169":4,"184":3,"228":1,"281":4,"282":4,"286":2}}],["ui",{"2":{"68":1,"71":1,"72":2,"84":1}}],["ultimate",{"2":{"49":1}}],["u",{"2":{"31":2,"34":5,"553":6,"788":2,"790":2,"791":2,"792":2}}],["upper",{"2":{"738":1}}],["upload",{"2":{"314":1,"336":1,"363":1,"532":1,"540":1,"635":1,"679":1,"687":1,"696":1,"722":1,"730":1,"794":1}}],["uploaded",{"2":{"310":1}}],["uploading",{"2":{"304":1}}],["updocker",{"2":{"277":1}}],["updating",{"0":{"306":1,"308":1},"2":{"180":1,"219":3,"225":1,"569":2}}],["updatepost",{"2":{"306":6}}],["updatename",{"2":{"306":2}}],["updateheaders",{"2":{"137":2}}],["updatesudo",{"2":{"675":1}}],["updates",{"2":{"117":1,"219":1,"243":1,"282":1,"306":4,"516":1,"734":1,"774":1,"777":1}}],["update",{"0":{"77":1,"319":1},"2":{"77":2,"84":1,"149":1,"180":1,"211":2,"219":5,"225":1,"236":3,"237":1,"243":1,"262":1,"306":2,"308":1,"313":1,"314":1,"316":1,"319":2,"415":1,"432":1,"448":1,"467":1,"491":1,"548":2,"614":4,"661":1,"675":4,"716":1,"808":1}}],["updatedpost",{"2":{"306":4}}],["updated",{"2":{"5":1,"91":2,"137":1,"211":1,"225":2,"237":1,"302":1,"413":1,"516":1,"777":1}}],["upgrading",{"0":{"624":1},"2":{"219":2}}],["upgraded",{"2":{"651":1,"661":1,"803":1,"808":1}}],["upgradeexecutor",{"2":{"91":2}}],["upgrade",{"0":{"564":1},"2":{"25":1,"91":4,"94":1,"219":2,"331":1,"564":1,"624":1,"651":10,"661":2,"675":3,"690":3,"691":4,"692":8,"803":10,"808":2}}],["upgrades",{"0":{"516":1,"529":1,"734":1,"753":1,"768":1,"781":1},"2":{"24":1,"515":1,"516":1,"529":2,"548":1,"564":1,"690":2,"691":1,"692":1,"733":1,"734":1,"753":2,"768":2,"779":1,"781":2}}],["upcoming",{"2":{"53":1,"161":1,"162":1,"175":1,"177":1,"230":1,"690":1}}],["ups",{"2":{"39":1}}],["upon",{"2":{"34":3,"56":1,"137":1,"143":1,"376":1,"391":1,"500":1,"539":1,"686":1,"729":1}}],["up",{"0":{"91":1,"364":1,"401":1,"415":1,"530":1,"533":1,"567":1,"572":1,"584":1,"636":1,"637":1,"639":1,"677":1,"680":1,"709":1,"720":1,"723":1,"786":1,"793":1,"795":1},"1":{"365":1,"366":1,"367":1,"531":1,"532":1,"533":1,"534":2,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"568":1,"569":1,"570":1,"571":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"637":1,"638":1,"639":1,"678":1,"679":1,"680":1,"681":2,"682":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"721":1,"722":1,"723":1,"724":2,"725":1,"726":1,"727":1,"728":1,"729":1,"730":1,"731":1,"732":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"794":1,"795":1,"796":2,"797":2,"798":1,"799":1,"800":1,"801":1,"802":1,"803":1,"804":1,"805":1,"806":1,"807":1,"808":1},"2":{"21":1,"23":1,"26":1,"36":1,"37":1,"38":1,"47":3,"48":1,"54":1,"60":1,"61":1,"88":2,"90":1,"115":1,"177":2,"208":1,"262":1,"267":1,"270":1,"276":2,"277":3,"280":1,"314":1,"338":3,"365":1,"373":1,"406":1,"408":2,"410":1,"411":2,"416":1,"439":1,"456":1,"457":1,"530":1,"540":1,"541":2,"555":1,"557":1,"558":1,"571":1,"580":2,"583":1,"584":1,"593":1,"601":1,"618":1,"621":1,"631":1,"634":1,"648":2,"674":1,"677":1,"681":1,"687":1,"697":1,"709":1,"710":1,"720":1,"723":2,"730":1,"731":1,"769":1,"772":1,"787":1,"788":1,"793":1,"795":1,"802":2,"803":1}}],["uptime",{"2":{"21":1,"23":1,"27":2,"33":1,"254":1,"598":1,"748":1}}],["unexplored",{"2":{"734":1}}],["unexpectedly",{"2":{"516":1}}],["unordered",{"2":{"700":2}}],["unmarshaling",{"2":{"611":2}}],["unjail",{"2":{"552":3,"563":2}}],["unjailing",{"0":{"552":1}}],["unbonded",{"2":{"563":1}}],["unbond",{"2":{"551":3}}],["unbonding",{"2":{"217":1,"563":1}}],["unused",{"2":{"411":1,"428":1,"430":1}}],["untested",{"2":{"334":1}}],["until",{"2":{"107":1,"139":1,"432":1,"437":2,"456":1,"495":1,"505":1,"516":1,"694":1,"788":1}}],["unknown",{"2":{"169":1}}],["unstable",{"2":{"777":1}}],["unstake",{"2":{"477":1,"481":1,"486":1}}],["unsafe",{"2":{"310":2,"316":2,"615":4,"653":2,"710":2}}],["unsubscribe",{"2":{"171":2}}],["unsignedtx",{"2":{"561":8}}],["unsigned",{"2":{"116":1,"117":1,"281":1,"282":1}}],["unsolicited",{"2":{"14":1,"15":1}}],["unpacked",{"2":{"109":1}}],["unpealed",{"2":{"108":2}}],["unprofessional",{"2":{"13":1}}],["unlocked",{"2":{"500":9}}],["unlocks",{"0":{"500":1},"2":{"500":4}}],["unlock",{"2":{"443":2,"500":3}}],["unlocking",{"2":{"55":1}}],["unlimited",{"2":{"556":2}}],["unlike",{"2":{"136":1,"178":1,"228":1,"353":1}}],["unlicensed",{"2":{"116":2,"117":2,"281":2,"282":2}}],["unless",{"2":{"24":1,"31":2,"34":4,"208":1,"391":1,"401":1,"709":1}}],["unix",{"2":{"608":1}}],["unify",{"2":{"292":1}}],["unified",{"2":{"148":1}}],["universal",{"2":{"223":1}}],["university",{"2":{"40":1}}],["universities",{"2":{"40":2,"44":1}}],["unit",{"2":{"117":1,"282":1,"437":2,"788":2,"790":2,"791":2,"792":2}}],["united",{"2":{"34":9}}],["unique",{"2":{"33":1,"47":1,"84":2,"264":1,"461":2,"463":1,"569":1}}],["unauthorized",{"2":{"611":2}}],["unavailability",{"2":{"288":1}}],["unavailable",{"0":{"183":1},"2":{"139":1,"188":1}}],["unaffected",{"2":{"265":1}}],["unaffiliated",{"2":{"31":1}}],["unable",{"2":{"31":3,"432":1,"454":1,"563":1}}],["unacceptable",{"2":{"8":1,"11":1}}],["undelegate",{"0":{"551":1},"2":{"551":1}}],["undelegation",{"0":{"25":1}}],["undergoes",{"2":{"516":1}}],["underneath",{"0":{"92":1,"399":1},"1":{"400":1,"401":1,"402":1,"403":1,"404":1},"2":{"107":2,"108":1,"245":1,"338":1,"340":2,"404":1}}],["underlying",{"2":{"84":1,"91":1,"107":1,"110":1}}],["underwriter",{"2":{"34":1}}],["undertake",{"2":{"34":1}}],["undertaking",{"2":{"34":1}}],["understanding",{"0":{"627":1},"1":{"628":1,"629":1,"630":1,"631":1,"632":1,"633":1},"2":{"42":1,"65":1,"114":2,"255":1,"262":1,"275":1,"279":2,"495":1,"666":2}}],["understand",{"2":{"30":1,"33":1,"34":4,"47":1,"48":3,"65":1,"89":1,"130":1,"341":1,"489":1,"583":1}}],["under",{"2":{"24":1,"27":1,"30":1,"31":1,"34":10,"68":2,"72":1,"88":1,"94":1,"129":1,"157":1,"203":1,"217":1,"219":1,"223":2,"224":1,"268":1,"270":1,"416":1,"426":2,"428":1,"556":2,"617":1,"649":1,"805":1}}],["unwelcome",{"2":{"13":1}}],["usr",{"2":{"594":1,"622":1,"661":4,"676":21,"808":4}}],["usual",{"2":{"184":1}}],["usually",{"2":{"84":1,"538":1,"631":1,"685":1,"726":1}}],["usable",{"0":{"163":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1},"2":{"130":1,"151":1,"156":1,"161":1}}],["usage",{"0":{"127":1,"203":1,"204":1,"205":1},"1":{"204":1,"205":1},"2":{"205":1,"412":2,"413":2,"415":2,"542":2,"545":1,"546":1,"547":2,"558":1,"621":1}}],["using",{"0":{"120":1,"155":1,"158":1,"268":1,"284":1,"285":1,"293":1,"296":1,"300":1,"391":1,"522":1,"613":1},"1":{"156":1,"157":1,"159":1,"269":1,"270":1,"271":1,"272":1,"273":1,"294":1,"295":1,"301":1,"523":1,"524":1},"2":{"10":1,"33":1,"36":1,"37":1,"48":1,"75":2,"79":1,"82":1,"84":1,"88":1,"89":6,"91":1,"108":1,"110":1,"111":1,"113":1,"119":1,"121":1,"126":3,"131":3,"135":1,"136":2,"139":1,"145":1,"146":1,"148":2,"150":1,"152":1,"154":1,"157":1,"158":2,"159":1,"162":1,"164":2,"169":2,"171":1,"172":3,"177":1,"178":1,"179":2,"181":3,"182":2,"184":6,"185":1,"187":1,"188":2,"193":1,"195":1,"197":1,"200":3,"203":1,"206":1,"208":4,"211":7,"213":1,"217":1,"218":1,"223":1,"224":1,"227":2,"230":2,"236":1,"242":1,"266":1,"267":1,"269":1,"276":1,"277":3,"286":1,"288":1,"294":1,"296":1,"306":1,"308":1,"309":1,"311":2,"312":1,"314":1,"316":3,"318":2,"322":1,"325":3,"326":3,"327":1,"331":1,"338":2,"343":1,"361":1,"367":1,"368":1,"370":1,"371":1,"372":2,"373":2,"375":1,"389":1,"391":2,"399":1,"403":1,"405":3,"407":1,"413":8,"414":2,"415":2,"417":1,"420":1,"421":1,"423":1,"424":1,"431":2,"435":1,"437":4,"438":2,"443":2,"463":1,"464":2,"466":3,"469":2,"488":1,"492":2,"508":1,"524":1,"525":1,"537":1,"539":1,"548":1,"549":1,"559":1,"560":1,"565":1,"575":1,"583":1,"588":1,"593":1,"596":1,"609":3,"613":1,"614":1,"619":2,"644":1,"646":1,"648":1,"665":3,"667":1,"669":2,"673":1,"676":1,"685":1,"686":1,"693":1,"695":1,"727":1,"728":1,"729":1,"762":2,"763":1,"765":1,"797":1}}],["useaccount",{"2":{"314":4}}],["useeffect",{"2":{"314":6}}],["useful",{"2":{"48":1,"57":1,"90":1,"516":1,"639":1,"762":1,"786":1,"788":1}}],["user=$user",{"2":{"788":2,"790":2,"791":2,"792":2}}],["user",{"0":{"437":1},"2":{"42":1,"47":2,"48":1,"131":2,"133":1,"261":1,"288":1,"306":2,"311":1,"313":1,"331":1,"352":1,"353":1,"370":2,"374":1,"428":2,"430":3,"432":1,"437":8,"441":1,"443":4,"509":1,"512":1,"557":1,"562":1,"609":8,"633":1,"668":1,"704":2,"788":2,"790":2,"791":2,"792":2}}],["users",{"2":{"19":1,"30":1,"84":1,"174":1,"192":1,"230":2,"265":1,"288":1,"314":3,"355":1,"357":1,"373":1,"402":1,"425":1,"428":3,"430":3,"431":1,"432":2,"433":1,"447":2,"454":2,"457":2,"458":1,"468":1,"469":1,"492":1,"501":1,"523":1,"524":1,"665":1,"673":1,"734":1,"747":1,"748":1,"759":1,"760":1,"761":1,"762":1,"763":1,"774":1}}],["usestate",{"2":{"314":10}}],["uses",{"0":{"172":1},"2":{"40":1,"94":1,"105":1,"110":1,"121":1,"135":4,"139":1,"172":4,"187":1,"191":1,"197":1,"206":1,"233":1,"234":1,"236":1,"242":1,"246":1,"268":1,"286":1,"306":1,"324":2,"338":1,"340":1,"356":1,"414":2,"428":1,"430":1,"431":1,"432":1,"436":2,"452":1,"461":1,"489":1,"495":1,"509":1,"556":1,"563":1,"611":1,"612":1,"649":1,"693":1,"704":1}}],["use",{"0":{"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"196":1,"197":1,"198":1,"199":1,"201":1,"202":1,"208":1},"1":{"189":1,"190":1,"191":1,"193":1,"194":1,"197":1,"198":1,"200":1,"201":1,"202":1},"2":{"8":1,"13":1,"19":1,"31":3,"33":3,"34":1,"45":1,"47":1,"48":2,"82":1,"88":2,"89":3,"102":2,"107":1,"119":1,"120":1,"121":1,"133":1,"134":2,"136":2,"137":1,"142":1,"146":1,"148":1,"153":2,"161":1,"162":1,"163":1,"165":2,"170":4,"171":3,"172":4,"174":1,"183":2,"184":2,"195":1,"199":1,"206":1,"208":1,"211":4,"213":3,"219":1,"220":1,"222":1,"224":1,"230":1,"236":3,"242":1,"250":1,"265":1,"269":1,"270":1,"272":1,"286":1,"290":1,"293":1,"296":1,"300":1,"306":2,"308":1,"309":4,"310":1,"316":1,"323":4,"324":2,"331":2,"333":1,"344":1,"347":1,"348":1,"357":1,"359":1,"362":1,"366":1,"369":4,"370":1,"371":1,"372":2,"374":4,"376":5,"377":2,"386":1,"387":1,"388":2,"391":1,"399":1,"411":3,"413":3,"418":4,"419":7,"424":1,"427":1,"428":1,"429":1,"437":6,"442":1,"443":1,"466":1,"467":1,"492":1,"507":1,"528":1,"537":1,"548":2,"549":1,"557":2,"564":1,"566":1,"569":1,"570":1,"576":1,"581":1,"583":2,"584":1,"585":1,"593":1,"601":1,"606":1,"608":1,"619":1,"621":1,"628":1,"665":1,"676":1,"685":1,"689":1,"692":1,"694":1,"696":1,"698":1,"699":2,"700":1,"701":1,"711":2,"716":1,"751":1,"767":1,"785":1}}],["used",{"2":{"3":1,"30":1,"84":2,"88":1,"89":4,"91":1,"107":3,"108":1,"134":2,"136":1,"137":2,"139":1,"145":2,"156":2,"158":1,"160":1,"165":1,"166":1,"175":2,"183":1,"196":2,"208":2,"211":5,"222":2,"223":3,"224":3,"225":1,"230":1,"236":1,"243":1,"268":1,"292":1,"294":1,"331":1,"334":1,"336":1,"354":1,"366":1,"370":2,"377":1,"389":1,"413":1,"428":1,"429":2,"430":1,"431":2,"461":1,"466":1,"469":1,"515":1,"520":1,"536":1,"538":1,"548":1,"555":1,"563":1,"576":2,"590":1,"593":1,"595":1,"606":1,"627":1,"656":1,"659":1,"668":1,"674":1,"685":2,"691":1,"693":1,"696":1,"740":1,"758":1,"763":1,"764":1,"797":2,"803":2}}],["us",{"2":{"8":1,"24":1,"27":1,"30":1,"31":3,"33":2,"34":1,"48":6,"109":3,"265":1,"389":1,"412":1,"414":1,"443":1,"738":2}}],["huzwottdmd36n1f75a9bshxnlrascnnpqiwqihdvhcu",{"2":{"383":4}}],["hub",{"2":{"247":1,"252":1,"693":1,"695":1,"696":1}}],["h2",{"2":{"314":8}}],["h3",{"2":{"314":8}}],["h1",{"2":{"314":8}}],["hzfy",{"2":{"156":2}}],["historic",{"2":{"491":1,"492":3}}],["historical",{"0":{"457":1,"458":1,"645":1},"2":{"454":2,"457":2,"458":2,"459":1,"490":1,"492":9,"645":1}}],["history",{"2":{"454":1,"458":1,"524":1,"618":1,"634":1,"748":1,"749":1,"769":1}}],["hidden",{"2":{"135":1,"405":1}}],["hiring",{"2":{"44":1}}],["highly",{"2":{"538":1,"663":1,"685":1}}],["highlighted",{"2":{"146":1}}],["highlight",{"2":{"44":1,"64":1}}],["highlights",{"2":{"38":1}}],["higher",{"2":{"84":1,"265":1,"377":1,"426":1,"427":1,"432":1,"489":1,"495":1}}],["high",{"2":{"23":1,"46":1,"65":1,"84":1,"108":1,"109":2,"131":1,"133":1,"230":1,"235":1,"236":1,"403":1,"443":2,"461":1,"617":1,"763":1}}],["h",{"2":{"34":1,"391":4,"397":4}}],["hollow",{"2":{"573":2}}],["holds",{"2":{"86":1}}],["holders",{"2":{"497":1,"549":1}}],["holder",{"2":{"34":1}}],["hold",{"2":{"34":1,"42":1}}],["holding",{"2":{"34":2}}],["hooks",{"2":{"311":1}}],["hood",{"2":{"94":1,"268":1,"428":1}}],["homebrew",{"2":{"675":4}}],["homecd",{"2":{"573":1}}],["home=",{"2":{"569":2}}],["home",{"0":{"569":1},"2":{"270":1,"370":1,"569":4,"573":3,"574":4,"576":12,"577":4,"578":4,"579":8,"595":1,"606":1,"609":8,"653":2,"669":8,"670":8,"710":2}}],["hosted",{"2":{"227":1,"245":1,"246":1,"601":1}}],["hosts",{"2":{"89":2}}],["host",{"2":{"89":8,"102":2,"261":1,"262":1,"314":2,"585":2,"613":2,"668":3,"695":4,"699":6}}],["hosting",{"2":{"27":1,"43":1,"46":1,"48":2,"79":1}}],["honesty",{"2":{"454":1}}],["honest",{"2":{"84":1,"451":2,"461":1,"463":1,"470":2}}],["hour",{"2":{"48":1,"225":1,"237":2,"647":1}}],["hours",{"2":{"25":1,"71":1,"72":1,"180":1,"225":1,"237":1,"647":1}}],["hope",{"2":{"48":2}}],["however",{"2":{"44":1,"47":1,"135":1,"139":1,"184":1,"195":1,"206":1,"208":1,"370":1,"428":1,"429":1,"452":1,"462":1,"464":1,"466":1,"548":1,"601":1,"633":1,"659":1}}],["how",{"0":{"238":1,"243":1,"449":1,"471":1,"553":1,"565":1},"1":{"472":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"480":1,"481":1,"482":1,"483":1,"484":1,"485":1,"486":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1},"2":{"22":1,"41":1,"42":1,"44":2,"47":1,"48":1,"60":1,"66":1,"84":1,"89":1,"92":1,"109":1,"111":1,"113":1,"122":2,"130":1,"131":1,"133":1,"135":1,"136":1,"143":2,"146":1,"148":2,"181":1,"191":1,"225":1,"237":1,"244":1,"266":1,"275":1,"276":1,"287":1,"302":2,"333":1,"340":1,"343":2,"359":1,"368":1,"369":2,"371":1,"399":1,"402":1,"403":1,"405":1,"429":2,"430":1,"431":2,"437":2,"442":2,"443":2,"450":1,"471":1,"488":1,"489":1,"491":1,"494":2,"495":1,"497":1,"498":1,"507":1,"509":1,"519":2,"555":2,"562":1,"564":1,"565":1,"579":1,"580":2,"584":1,"587":2,"588":1,"601":1,"618":1,"634":1,"658":1,"659":1,"693":2,"739":2,"754":3,"769":1,"782":1}}],["http2",{"2":{"762":1}}],["httpexport",{"2":{"285":1,"318":1}}],["http",{"0":{"151":1,"156":1,"161":1},"2":{"88":1,"89":4,"90":1,"91":3,"119":2,"120":1,"145":6,"151":1,"152":4,"153":4,"159":2,"164":1,"165":1,"172":2,"249":1,"285":1,"309":2,"310":6,"312":2,"313":4,"314":2,"315":1,"318":1,"323":2,"357":1,"370":1,"397":2,"418":2,"595":1,"606":2,"611":2,"613":2,"667":1,"762":1}}],["https",{"0":{"249":1},"2":{"17":3,"75":2,"87":2,"91":2,"165":2,"166":2,"169":2,"211":2,"212":2,"217":2,"220":2,"223":18,"224":2,"227":1,"247":1,"249":1,"252":1,"253":1,"269":2,"291":1,"301":2,"314":2,"315":1,"318":2,"339":1,"403":2,"413":2,"424":2,"444":3,"445":4,"502":3,"503":3,"520":4,"521":2,"527":1,"528":3,"547":4,"562":4,"585":2,"593":2,"594":2,"621":2,"622":2,"639":10,"650":12,"667":1,"675":2,"676":8,"695":8,"696":2,"740":4,"751":9,"752":5,"758":4,"762":16,"766":1,"767":9}}],["html",{"2":{"17":1,"165":2,"166":2}}],["halo",{"2":{"531":1}}],["halting",{"2":{"448":1}}],["hamburger",{"2":{"445":1}}],["handpicking",{"2":{"557":1}}],["handful",{"2":{"309":1}}],["hand",{"2":{"235":1}}],["hands",{"0":{"149":1},"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}}],["handling",{"2":{"110":1,"338":1}}],["handlemsg",{"2":{"661":2,"808":2}}],["handlecompleteproposal",{"2":{"661":2,"808":2}}],["handled",{"2":{"428":1}}],["handles",{"2":{"91":1,"228":1,"338":1,"370":1}}],["handle",{"2":{"31":1,"351":1,"437":4,"468":1}}],["happen",{"2":{"470":1,"691":1}}],["happens",{"2":{"107":1,"691":1}}],["happened",{"2":{"85":1}}],["happening",{"2":{"5":1}}],["happy",{"2":{"47":1,"63":1}}],["having",{"2":{"40":2,"41":1,"84":1,"179":1,"180":1,"192":1,"202":1,"220":1,"227":1,"450":2,"665":1}}],["haven",{"2":{"443":2,"623":1}}],["have",{"2":{"4":1,"9":1,"24":3,"27":1,"30":1,"31":5,"32":3,"34":8,"40":4,"41":1,"42":1,"43":1,"45":1,"46":2,"47":1,"63":1,"72":1,"76":1,"79":1,"85":1,"89":1,"90":1,"91":2,"108":2,"119":1,"125":1,"133":1,"135":1,"149":1,"163":4,"178":1,"192":2,"202":1,"211":4,"217":1,"218":1,"219":1,"220":1,"223":2,"224":1,"225":1,"236":1,"244":1,"255":1,"266":1,"270":1,"295":1,"296":1,"297":1,"301":2,"302":1,"311":1,"313":2,"317":1,"318":1,"322":1,"336":2,"351":1,"357":1,"362":2,"364":1,"368":1,"370":1,"393":1,"399":1,"401":2,"403":1,"404":1,"407":1,"408":1,"415":1,"417":1,"419":1,"432":1,"448":1,"449":2,"452":1,"458":1,"464":1,"470":2,"486":1,"492":1,"499":1,"531":1,"541":1,"563":3,"571":1,"572":1,"580":1,"591":2,"594":1,"596":1,"597":1,"606":1,"622":1,"626":1,"662":1,"667":1,"670":1,"676":1,"695":2,"696":1,"698":1,"700":1,"701":1,"710":1,"715":1,"716":1,"719":1,"721":1,"728":1,"738":1,"748":1,"754":1,"788":1,"802":1,"803":1}}],["had",{"2":{"32":1,"172":2,"303":1,"369":1}}],["hash=580b3dff8a7c716968161d91116a1e171f486298d582874e93714e489c9e6e88",{"2":{"596":2}}],["hash=",{"2":{"596":2}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7",{"2":{"395":1}}],["hash=0x79a0a7a1b4936aafe7a37dbfb07a6a9e55c145a4ed6fd54f962649b4b7db8de7export",{"2":{"395":1}}],["hash=0xef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"156":1}}],["hashtopost",{"2":{"306":8}}],["hashtags",{"2":{"45":1}}],["hashing",{"2":{"108":1}}],["hashes",{"2":{"108":2,"127":4,"236":1}}],["hash",{"0":{"155":1,"158":1,"208":1,"218":1,"618":1,"644":1},"1":{"156":1,"157":1,"159":1,"619":1},"2":{"91":6,"108":2,"120":2,"127":10,"134":2,"137":2,"151":2,"153":2,"155":1,"156":5,"157":2,"158":1,"159":4,"161":2,"169":1,"181":1,"208":8,"218":3,"219":5,"285":2,"306":30,"314":1,"383":24,"386":1,"395":4,"396":4,"464":1,"596":6,"618":10,"619":1,"621":1,"633":2,"644":1,"649":3,"658":2,"797":3,"803":2}}],["has",{"2":{"28":1,"32":1,"34":2,"47":1,"50":1,"84":1,"89":1,"91":3,"94":1,"107":2,"108":1,"110":2,"127":3,"177":1,"178":1,"179":1,"206":1,"208":1,"228":1,"288":1,"305":1,"309":1,"310":1,"324":1,"357":1,"369":1,"393":1,"407":2,"426":1,"429":2,"447":1,"457":1,"462":1,"464":1,"491":1,"492":1,"516":1,"526":1,"531":1,"557":1,"559":1,"577":1,"608":2,"650":1,"651":1,"661":1,"665":1,"685":1,"700":1,"725":1,"737":1,"738":1,"765":1,"776":1,"788":1,"792":1,"803":1,"808":1}}],["hard",{"2":{"738":2}}],["hardforks",{"2":{"690":1,"691":1,"779":1}}],["hardfork",{"0":{"690":1,"692":1},"1":{"691":1,"692":1},"2":{"516":1,"529":2,"690":2,"691":2,"692":4,"753":2,"768":2,"781":2}}],["hardhat",{"2":{"91":1}}],["hardware",{"0":{"363":1,"532":1,"635":1,"679":1,"706":1,"722":1,"794":1},"2":{"27":1,"60":1,"61":1,"363":1,"532":1,"635":1,"679":1,"706":1,"722":1,"794":1}}],["harassing",{"2":{"11":1}}],["harassment",{"2":{"7":1,"8":1,"16":1}}],["harmfully",{"2":{"563":1}}],["harmful",{"2":{"9":1,"25":1}}],["hermes",{"0":{"694":1,"701":1},"1":{"695":1,"696":1,"697":1},"2":{"693":2,"694":9,"695":4,"696":4,"697":2,"698":1,"702":1}}],["hereby",{"2":{"32":1,"34":4}}],["herein",{"2":{"30":1}}],["here",{"2":{"0":1,"22":1,"52":1,"60":1,"61":1,"64":1,"108":1,"109":1,"117":1,"134":1,"135":1,"137":1,"139":1,"227":1,"258":1,"282":1,"306":3,"310":1,"313":1,"371":1,"374":2,"376":3,"380":1,"383":2,"386":1,"403":1,"411":1,"413":2,"437":4,"537":1,"538":1,"548":1,"557":2,"583":1,"599":1,"600":1,"601":1,"602":1,"649":1,"712":2,"713":1,"715":1,"739":1,"787":1,"803":1}}],["hence",{"2":{"429":1,"677":1}}],["helloworldblob",{"2":{"324":4,"436":4}}],["hello",{"2":{"324":4,"374":1,"419":4,"436":4}}],["helpful",{"0":{"542":1},"1":{"543":1,"544":1,"545":1,"546":1,"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1},"2":{"593":1,"594":1}}],["helpcelestia",{"2":{"388":2,"546":1,"547":1,"583":1,"593":1,"703":1}}],["helper",{"2":{"141":1,"165":1,"168":1,"169":1}}],["helping",{"2":{"47":1,"288":1,"542":2,"705":1}}],["helps",{"2":{"2":1,"43":1,"46":1,"48":4,"84":1}}],["help",{"0":{"388":1},"2":{"0":1,"33":1,"35":2,"36":1,"39":1,"40":1,"41":1,"42":3,"43":2,"44":1,"45":2,"46":2,"47":3,"48":2,"57":2,"131":1,"265":1,"273":2,"388":4,"412":1,"414":1,"509":1,"542":6,"546":1,"547":1,"583":2,"593":2,"602":1,"630":1,"703":2,"754":1,"782":1}}],["height=",{"2":{"218":1}}],["height=15",{"2":{"151":1,"161":1,"169":1}}],["heightsub",{"0":{"616":1},"2":{"616":4}}],["heights",{"2":{"217":1,"226":1,"692":1}}],["height",{"0":{"383":1},"2":{"107":2,"128":1,"134":8,"135":4,"137":2,"139":6,"148":3,"150":2,"151":1,"153":16,"156":2,"159":2,"160":1,"169":17,"170":8,"172":8,"177":1,"181":2,"192":2,"196":1,"217":1,"218":4,"219":2,"221":1,"242":1,"296":3,"314":4,"324":8,"325":4,"326":11,"327":7,"374":5,"376":6,"377":3,"383":10,"384":2,"389":3,"391":1,"413":17,"415":4,"419":10,"420":13,"421":1,"436":6,"464":1,"495":1,"542":4,"576":4,"618":3,"619":2,"645":1,"648":1,"649":3,"651":9,"658":2,"661":1,"692":6,"797":2,"803":11,"808":1}}],["hexbytes",{"2":{"167":2,"172":2}}],["hextoaddress",{"2":{"153":2,"170":2,"171":2,"172":2}}],["hexadecimal",{"2":{"121":1,"286":1,"374":1,"413":1}}],["hex",{"2":{"76":1,"89":1,"157":2,"159":4,"164":1,"165":1,"166":1,"211":2,"219":1,"318":1,"374":8,"376":2,"411":2,"413":11,"415":2,"434":4,"435":4}}],["health",{"2":{"555":1,"697":4,"748":1}}],["healthy",{"2":{"7":1,"697":1}}],["heavy",{"0":{"203":1,"204":1,"205":1},"1":{"204":1,"205":1},"2":{"205":1}}],["headerclient",{"2":{"419":2}}],["headerchan",{"2":{"326":2}}],["headerrangefunctionid",{"2":{"227":1}}],["header",{"0":{"383":1,"661":1,"808":1},"2":{"89":1,"107":2,"108":1,"127":2,"128":1,"129":1,"134":11,"135":9,"136":1,"137":18,"139":19,"159":2,"169":2,"183":1,"213":2,"217":5,"219":8,"220":10,"224":16,"226":1,"227":2,"236":2,"326":16,"327":7,"383":8,"384":2,"389":4,"414":2,"420":22,"421":13,"461":1,"464":1,"469":1,"470":4,"488":1,"616":2,"649":1,"661":2,"808":2}}],["headers",{"0":{"143":1,"326":1,"420":1,"616":1},"2":{"89":1,"95":1,"107":1,"133":1,"137":1,"139":5,"143":1,"148":1,"230":1,"314":2,"326":6,"420":6,"461":1,"462":1,"463":1,"470":5,"531":2,"616":3,"618":2,"678":2,"721":3,"791":1,"792":1}}],["head",{"2":{"72":1,"131":1,"135":1,"262":1,"367":1,"421":2,"559":1,"582":1,"648":1,"675":2}}],["heard",{"2":{"262":1}}],["hear",{"2":{"48":2}}],["hesitate",{"2":{"40":1,"45":1}}],["hedging",{"2":{"34":1}}],["hetzner",{"2":{"24":1}}],["vlog",{"2":{"617":4}}],["vcpu",{"2":{"424":1}}],["vghpcybpcybhbiblegftcgxlig9mihnvbwugymxvyibkyxrh",{"2":{"391":2}}],["vv",{"2":{"307":1}}],["vvforge",{"2":{"307":1}}],["vms",{"2":{"266":1}}],["vm",{"2":{"265":1,"266":4,"306":4,"308":4}}],["vs",{"0":{"232":1,"467":1},"1":{"233":1,"234":1,"235":1},"2":{"749":1}}],["vk",{"2":{"223":2}}],["vkrarg7fgtz",{"2":{"151":2}}],["v",{"2":{"102":2,"324":2,"326":2,"330":1,"396":2,"412":2,"413":8,"415":8,"436":2,"669":11,"670":10}}],["v1beta1",{"2":{"300":2,"548":4,"576":2,"577":2,"578":2}}],["v1",{"2":{"94":2,"149":8,"156":4,"161":1,"162":1,"172":2,"300":2,"381":6,"428":2,"432":1,"594":1,"651":1,"661":14,"694":1,"803":1,"808":14}}],["v2",{"2":{"94":1,"102":2,"159":2,"161":1,"651":10,"661":1,"692":3,"803":10,"808":1}}],["vulnerability",{"2":{"84":1}}],["v0",{"2":{"80":1,"94":3,"149":4,"369":1,"419":3,"420":2,"491":2,"608":1,"622":1,"661":14,"692":1,"694":1,"808":14}}],["void",{"2":{"573":2}}],["voice",{"2":{"40":1}}],["vote",{"2":{"471":1,"497":2,"498":1,"548":5,"549":1}}],["voting",{"2":{"383":4,"510":1,"548":1,"769":1}}],["volume",{"2":{"668":2,"669":6,"670":2,"673":1}}],["volumes",{"2":{"277":2}}],["volunteer",{"2":{"36":1}}],["volunteers",{"2":{"36":1,"38":1,"52":1}}],["vouch",{"2":{"233":1}}],["vest",{"2":{"576":1}}],["vestingcelestia",{"2":{"581":1}}],["vesting",{"0":{"565":1,"572":1,"576":1,"577":1,"583":1},"1":{"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":2,"574":2,"575":2,"576":2,"577":2,"578":2,"579":2,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1},"2":{"331":1,"429":1,"565":4,"571":1,"572":1,"573":5,"574":2,"575":1,"576":19,"577":8,"579":3,"580":2,"581":4,"583":10,"586":1,"587":2}}],["veto",{"2":{"548":2}}],["vec",{"2":{"419":2}}],["ve",{"2":{"45":1,"65":1,"76":1,"120":1,"122":1,"256":1,"262":1,"285":1,"287":1,"303":1,"308":1,"310":1,"318":1,"405":1,"413":2,"579":1,"587":1,"623":1}}],["venv",{"2":{"402":7}}],["venue",{"0":{"40":1},"2":{"36":2,"37":1,"40":4,"44":2,"45":2}}],["vendors",{"2":{"31":1}}],["ver=",{"2":{"676":3}}],["very",{"2":{"133":1,"226":2,"336":1}}],["verifiable",{"2":{"236":1}}],["verified",{"2":{"146":1,"172":2,"177":1,"189":1,"192":1,"195":1,"199":1,"203":1,"211":1,"215":1,"447":1,"448":1,"449":1,"457":1}}],["verifiercd",{"2":{"212":1}}],["verifiers",{"0":{"212":1,"224":1},"2":{"211":2,"212":5,"213":4,"223":1}}],["verifier",{"0":{"213":1,"223":1},"1":{"214":1,"215":1,"216":1},"2":{"130":1,"131":1,"141":1,"172":2,"200":1,"203":1,"211":2,"212":7,"213":10,"214":4,"215":1,"219":6,"220":5,"222":1,"223":22,"224":13,"243":1,"424":4}}],["verifies",{"2":{"117":2,"129":2,"131":3,"236":2,"243":1,"282":2}}],["verification",{"0":{"234":1},"2":{"31":1,"89":1,"107":1,"131":1,"148":1,"169":1,"196":2,"200":1,"203":1,"208":3,"211":1,"223":1,"429":1,"649":1}}],["verifydatarootinclusion",{"2":{"153":4}}],["verifymultirowrootstodataroottupleroot",{"2":{"131":1}}],["verifyrowroottodataroottupleroot",{"2":{"131":2}}],["verifysharestodataroottupleroot",{"2":{"131":2,"172":2}}],["verifying",{"0":{"131":1},"2":{"128":2,"135":2,"136":1,"148":1,"173":1,"177":2,"188":1,"331":1,"332":1,"449":1,"455":1,"463":1}}],["verifyzkp",{"2":{"127":4}}],["verifyattestation",{"2":{"110":1,"127":2,"129":1,"153":2}}],["verify",{"0":{"449":1,"697":1},"2":{"89":2,"126":1,"127":4,"131":4,"136":1,"145":1,"153":6,"163":2,"165":6,"168":4,"169":2,"172":10,"173":1,"181":1,"184":1,"187":1,"188":1,"189":1,"191":1,"192":1,"195":1,"196":2,"200":2,"203":3,"208":2,"211":1,"212":4,"213":2,"219":2,"222":1,"242":1,"265":2,"297":1,"447":5,"449":2,"450":1,"451":1,"452":1,"457":1,"460":1,"461":1,"463":1,"464":1,"467":1,"468":2,"573":2,"576":1,"621":1,"649":1,"676":1,"694":1,"698":1}}],["versed",{"2":{"65":1}}],["versioned",{"2":{"738":1}}],["versiongo",{"2":{"676":1}}],["versioncelestia",{"2":{"621":1}}],["versioncd",{"2":{"570":1}}],["versions",{"0":{"775":1,"778":1,"780":1},"2":{"89":1,"94":1,"149":2,"690":1}}],["version",{"0":{"387":1,"518":1,"570":1,"661":1,"672":1,"736":1,"756":1,"808":1},"2":{"17":2,"94":2,"126":1,"156":2,"159":6,"161":2,"165":11,"166":11,"172":6,"224":2,"246":1,"331":1,"340":1,"374":1,"376":8,"383":2,"387":1,"391":2,"415":1,"424":1,"428":2,"466":1,"491":1,"492":1,"542":6,"566":1,"570":2,"580":1,"583":1,"593":1,"612":2,"621":6,"624":1,"651":1,"661":4,"676":4,"693":1,"694":1,"700":12,"803":1,"808":4}}],["vpn",{"2":{"31":1}}],["vanilla",{"2":{"466":1}}],["vastly",{"2":{"265":1}}],["vault",{"2":{"211":6}}],["var",{"2":{"137":2,"569":4}}],["vary",{"2":{"41":1,"429":1,"495":1,"738":1}}],["variant",{"2":{"311":2}}],["variablescd",{"2":{"219":1}}],["variables",{"0":{"312":1,"575":1},"2":{"89":1,"211":1,"219":3,"220":1,"227":1,"293":1,"312":1,"430":1,"575":1,"581":1,"669":1}}],["variable",{"2":{"75":2,"91":1,"116":2,"117":2,"120":1,"121":1,"164":1,"211":2,"220":3,"281":2,"282":2,"285":2,"286":1,"309":1,"310":1,"316":1,"318":2,"372":1,"386":1,"395":1,"396":1,"408":1,"414":3,"430":1,"489":1,"569":1,"797":1}}],["variety",{"2":{"41":1,"266":1}}],["varies",{"2":{"23":1}}],["various",{"2":{"34":1,"36":1,"47":1,"65":1,"256":1}}],["val",{"2":{"797":2}}],["valconspub",{"2":{"443":2}}],["valcons",{"2":{"443":2}}],["valoperpub",{"2":{"443":2}}],["valoper",{"2":{"443":2,"550":2,"551":4}}],["validao",{"2":{"742":1,"743":1,"744":1}}],["validating",{"2":{"92":1,"103":1,"145":1,"690":1}}],["validation",{"0":{"103":1},"2":{"84":2,"139":2}}],["validatehermes",{"2":{"697":1}}],["validates",{"2":{"466":1,"542":2}}],["validated",{"2":{"27":1}}],["validate",{"2":{"27":1,"192":1,"462":1,"463":1,"531":1,"542":2,"648":1,"697":1,"777":1}}],["validator1",{"2":{"711":1}}],["validatorwalletcreator",{"2":{"98":1,"99":1}}],["validatorutils",{"2":{"98":1,"99":1}}],["validators",{"0":{"714":1},"2":{"19":1,"21":1,"22":1,"24":1,"26":1,"27":1,"29":1,"84":9,"85":1,"108":1,"133":1,"134":1,"217":1,"236":2,"264":1,"336":1,"383":6,"427":1,"452":1,"489":1,"494":1,"516":1,"548":3,"690":3,"691":2,"714":3,"715":1,"718":1,"754":1,"777":2,"779":1}}],["validator",{"0":{"100":1,"475":1,"480":1,"484":1,"550":1,"552":1,"584":1,"793":1,"795":1,"797":1,"803":1,"804":1},"1":{"101":1,"102":1,"103":1,"794":1,"795":1,"796":2,"797":2,"798":1,"799":1,"800":1,"801":1,"802":1,"803":1,"804":1,"805":1,"806":1,"807":1,"808":1},"2":{"19":2,"21":2,"23":2,"24":4,"27":7,"28":5,"84":2,"86":1,"91":1,"103":1,"108":1,"137":1,"264":1,"366":2,"383":4,"407":2,"456":1,"475":1,"480":1,"484":1,"494":3,"501":1,"509":2,"515":3,"521":4,"524":2,"531":1,"538":5,"542":2,"550":5,"551":6,"552":3,"554":2,"561":6,"563":15,"571":2,"574":2,"575":1,"579":1,"583":1,"584":2,"590":4,"595":1,"606":1,"664":1,"685":3,"692":1,"712":1,"717":4,"718":2,"726":4,"727":2,"741":1,"754":1,"769":1,"772":1,"779":1,"784":1,"785":1,"787":1,"793":2,"794":1,"797":7,"798":2,"803":16}}],["validiums",{"2":{"448":1}}],["validity",{"2":{"195":1,"230":1,"265":3}}],["valid",{"2":{"131":2,"153":2,"177":2,"187":1,"188":1,"192":1,"196":2,"200":2,"203":2,"211":1,"219":1,"265":1,"461":1,"467":2,"470":1,"697":2}}],["valuable",{"2":{"40":1,"43":2,"48":1,"65":1}}],["valuelog",{"2":{"617":2}}],["values",{"0":{"596":1},"2":{"24":1,"85":1,"151":1,"156":1,"161":1,"165":1,"227":1,"270":1,"374":1,"497":1,"596":2,"614":3}}],["value",{"2":{"4":1,"44":1,"76":3,"89":2,"116":2,"121":1,"156":8,"165":6,"166":1,"196":1,"213":1,"219":3,"281":2,"286":1,"314":15,"318":3,"374":2,"377":1,"381":1,"383":4,"396":2,"420":2,"428":1,"429":1,"430":1,"548":4,"601":1,"617":3,"646":2,"658":2,"659":1,"711":2,"712":1}}],["visualize",{"2":{"557":1}}],["visualizer",{"2":{"557":1}}],["visualization",{"0":{"557":1}}],["vision",{"2":{"508":1}}],["visited",{"2":{"443":2}}],["visit",{"2":{"79":1,"83":1,"84":1,"88":1,"90":1,"251":1,"252":1,"253":1,"254":1,"408":1,"665":1}}],["visibility",{"2":{"45":1}}],["visible",{"2":{"7":1}}],["vite",{"2":{"302":1,"311":4,"312":2,"314":4}}],["vitepress",{"2":{"1":1}}],["virtual",{"2":{"247":1}}],["virtually",{"2":{"65":1}}],["vim",{"2":{"219":2,"220":2}}],["vibrant",{"2":{"55":1}}],["video",{"0":{"671":1},"1":{"672":1},"2":{"40":1,"46":1,"60":1,"61":1}}],["videos",{"2":{"37":1,"46":1}}],["viewed",{"2":{"602":1}}],["viewing",{"2":{"548":1}}],["viewstate",{"2":{"314":6}}],["view",{"0":{"273":1},"2":{"34":2,"69":1,"71":1,"90":1,"121":1,"246":1,"286":1,"306":5,"314":15,"352":1,"388":2,"444":1,"445":1,"542":1,"549":1,"583":1,"594":1,"622":1}}],["viewpoints",{"2":{"8":1}}],["violate",{"2":{"23":1,"34":1}}],["violating",{"2":{"14":1,"15":1,"24":1,"25":1}}],["violation",{"2":{"12":1,"13":1,"14":1,"15":1,"16":1,"31":1}}],["via",{"0":{"141":1,"142":1,"437":1},"2":{"10":1,"45":2,"134":1,"136":1,"139":1,"146":1,"148":1,"154":1,"165":1,"166":1,"169":1,"183":1,"184":1,"200":1,"212":1,"217":1,"218":1,"228":1,"269":4,"270":1,"437":2,"469":1,"471":1,"548":1,"591":1,"604":1,"696":1,"702":1,"703":1,"779":1}}],["egrep",{"2":{"650":6}}],["egg",{"2":{"573":2}}],["egeiggrjtkryaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa=",{"2":{"156":2}}],["eye",{"2":{"558":1}}],["eprintln",{"2":{"420":4}}],["ephemeral",{"2":{"265":1}}],["eq",{"2":{"419":6}}],["equally",{"2":{"468":1}}],["equality",{"2":{"306":1}}],["equal",{"2":{"117":1,"282":1,"324":4,"436":4}}],["equipments",{"2":{"40":1}}],["equipment",{"2":{"36":2,"37":1,"40":2,"46":1}}],["equivalent",{"2":{"34":2}}],["e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",{"2":{"383":8}}],["eofsudo",{"2":{"788":1,"790":1,"791":1,"792":1}}],["eof",{"2":{"611":2,"788":3,"790":3,"791":3,"792":3}}],["eoa",{"2":{"211":2}}],["eoujy0=",{"2":{"156":2}}],["ef9f50bfb39f11b022a6cd7026574eccdc6d596689bdccc7b2c482a1b26b26b8",{"2":{"156":3}}],["efficient",{"2":{"265":1,"431":1,"468":1}}],["efficiently",{"2":{"176":1,"447":1}}],["efficiency",{"2":{"230":1}}],["effect",{"2":{"462":1}}],["effects",{"2":{"172":2}}],["effectivegasprice",{"2":{"121":2,"286":2}}],["effectively",{"2":{"45":1,"57":1,"650":1}}],["effective",{"2":{"44":1,"48":1,"738":1}}],["effected",{"2":{"34":1}}],["efforts",{"2":{"34":2,"47":1}}],["eclipse",{"2":{"451":1}}],["ecfg",{"2":{"437":4}}],["ec2",{"2":{"226":1}}],["echo",{"2":{"121":1,"286":1,"316":2,"396":2,"639":10,"676":1,"718":2}}],["ecosystem",{"2":{"8":1,"21":1,"27":3,"43":3,"48":1,"50":1,"53":1,"60":1,"61":1,"65":3,"230":1,"302":1,"498":1,"499":2,"500":2,"557":1,"733":1}}],["economic",{"2":{"7":1,"24":1}}],["era",{"2":{"508":1}}],["erasure",{"2":{"146":1,"334":1,"451":1,"452":3,"466":1,"469":1,"488":1,"531":2}}],["err=",{"2":{"661":2,"808":2}}],["err",{"2":{"137":18,"139":12,"145":10,"152":16,"153":78,"157":8,"159":24,"162":4,"170":34,"171":26,"172":30,"324":30,"325":18,"326":24,"327":12,"412":6,"413":42,"414":6,"415":30,"420":4,"436":30,"437":50,"661":2,"808":2}}],["errorcodes",{"2":{"172":2}}],["errorf",{"2":{"139":4,"153":2,"170":2,"413":6,"414":4}}],["error",{"0":{"617":1},"2":{"93":1,"135":10,"137":4,"139":4,"153":6,"159":2,"170":2,"172":4,"288":3,"324":2,"325":2,"326":4,"327":2,"393":3,"413":8,"414":4,"420":4,"436":2,"437":2,"608":1,"611":2,"613":2,"614":3,"617":6,"661":1,"715":1,"808":1}}],["errors",{"2":{"89":1,"401":1,"696":1}}],["erc20outbox",{"2":{"98":1,"99":1}}],["erc20rollupeventinbox",{"2":{"98":1,"99":1}}],["erc20inbox",{"2":{"98":1,"99":1}}],["erc20bridge",{"2":{"98":1,"99":1}}],["erc20tokenbridge",{"2":{"91":2}}],["erc20",{"2":{"91":2}}],["eight",{"2":{"464":1}}],["eighteen",{"2":{"31":1}}],["eip",{"2":{"428":1}}],["eip4844",{"2":{"107":1}}],["eiokkc9jzwxlc3rpys5ibg9ilnyxlk1zz1bheuzvckjsb2jzumvzcg9uc2u=",{"2":{"156":2}}],["either",{"2":{"65":1,"102":1,"178":1,"195":1,"212":2,"213":1,"220":2,"224":1,"269":1,"308":1,"312":1,"367":1,"370":1,"391":1,"428":1,"470":1,"500":1,"557":3,"591":1,"594":1,"622":1,"667":1}}],["es",{"2":{"742":1,"743":1,"744":1}}],["estimates",{"2":{"430":1}}],["estimategas",{"2":{"430":2}}],["estimated",{"2":{"430":1,"437":2}}],["estimate",{"2":{"42":1,"91":8,"430":1,"431":1,"576":2}}],["estimating",{"0":{"429":1,"431":1},"2":{"42":2,"430":1,"437":2}}],["established",{"2":{"700":1}}],["establish",{"2":{"42":1,"88":2,"693":1}}],["especially",{"2":{"40":1,"50":1,"439":1}}],["essentially",{"2":{"602":1}}],["essential",{"2":{"40":1,"45":1,"47":1,"53":1,"86":1,"88":1,"248":1,"501":1,"507":1,"595":1,"606":1,"675":5}}],["eu",{"2":{"34":2}}],["eth0",{"2":{"656":2}}],["ethers",{"2":{"312":2,"314":12}}],["etherscan",{"2":{"211":6,"212":6,"217":1,"219":6}}],["ethermintd",{"2":{"310":2,"316":2}}],["ethermint",{"0":{"310":1,"315":1,"316":1},"2":{"303":1,"309":1,"310":4,"313":15,"314":4,"315":1,"316":7,"317":1}}],["ethereumclient",{"2":{"135":6,"137":4,"139":2}}],["ethereum",{"0":{"110":1,"143":1,"229":1,"288":1},"1":{"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1},"2":{"39":1,"76":1,"80":3,"82":1,"83":1,"89":1,"101":2,"105":1,"106":1,"109":2,"110":4,"114":1,"121":1,"129":1,"133":2,"134":4,"135":12,"137":3,"139":4,"143":3,"153":12,"172":12,"225":1,"230":3,"234":1,"235":2,"236":8,"237":2,"240":1,"247":1,"251":1,"279":1,"285":1,"286":1,"288":6,"302":1,"314":8,"315":1,"318":1,"337":2,"338":7,"403":4,"428":1,"508":1}}],["ethcmn",{"2":{"153":2,"170":2,"171":2,"172":2}}],["ethclient",{"2":{"153":10,"170":8,"171":8,"172":8}}],["eths",{"2":{"91":2}}],["eth",{"0":{"82":1},"2":{"69":1,"76":2,"80":2,"82":5,"84":1,"85":2,"88":1,"89":6,"91":7,"93":1,"279":1,"310":2,"316":2,"318":2,"403":1,"508":1}}],["ethnicity",{"2":{"7":1}}],["etc",{"2":{"33":1,"36":2,"38":1,"48":1,"146":1,"183":1,"311":1,"369":2,"524":1,"617":2,"748":1,"760":1,"788":4,"790":4,"791":4,"792":4}}],["eliminating",{"2":{"608":1}}],["eligible",{"2":{"30":1,"31":1}}],["eligibility",{"0":{"24":1},"2":{"21":1,"23":1,"31":1,"33":1,"34":2}}],["else",{"2":{"153":2,"443":2,"696":1}}],["elastic",{"2":{"39":1}}],["electronic",{"2":{"34":1}}],["element",{"2":{"30":1}}],["early",{"2":{"230":1,"499":4,"500":2,"573":2}}],["earn",{"2":{"30":1,"31":1,"494":1,"563":1}}],["easiest",{"2":{"665":2}}],["easier",{"2":{"48":1}}],["easily",{"2":{"294":1,"337":1}}],["ease",{"0":{"264":1}}],["easy2stake",{"2":{"742":1,"743":1}}],["easy",{"2":{"47":1,"246":1,"264":1,"311":1,"468":1,"508":1}}],["eager",{"2":{"48":1}}],["each",{"2":{"26":1,"28":2,"42":1,"52":1,"65":1,"89":1,"108":1,"116":1,"128":1,"134":1,"136":1,"139":1,"169":2,"175":1,"180":1,"211":4,"223":1,"281":1,"292":1,"331":1,"351":1,"369":1,"416":1,"426":1,"428":1,"429":3,"430":2,"431":2,"432":2,"461":1,"462":1,"468":1,"469":2,"470":1,"488":1,"489":1,"492":1,"495":1,"519":1,"563":1,"585":1,"608":2,"609":1,"696":2,"738":1,"739":1,"754":2,"769":2}}],["evolution",{"2":{"466":1,"733":1}}],["evolved",{"2":{"302":1}}],["evidence",{"2":{"331":1,"383":2}}],["evm",{"2":{"79":1,"105":1,"153":4,"170":6,"171":2,"172":4,"174":1,"211":1,"219":1,"220":2,"230":1,"240":1,"245":2,"247":2,"260":1,"266":1,"303":1,"304":2,"310":3,"402":1,"403":3,"554":6}}],["evaluated",{"2":{"26":1}}],["evaluate",{"2":{"24":1,"34":1,"38":1}}],["ever",{"2":{"34":1,"573":2}}],["everything",{"2":{"63":1,"127":2,"195":1,"646":5,"697":1}}],["everyone",{"2":{"7":1,"41":1,"52":2,"709":1,"711":1,"714":1,"716":1,"754":1}}],["every",{"2":{"2":1,"22":1,"26":1,"29":1,"107":1,"220":1,"225":2,"237":2,"265":2,"362":1,"411":1,"426":1,"461":3,"462":1,"464":3,"467":1,"469":5,"470":1,"495":1,"557":4,"569":1,"581":1,"585":1,"648":1,"709":1}}],["even",{"2":{"31":1,"34":1,"40":2,"214":1,"439":1,"463":1,"467":1,"668":1,"691":1}}],["eventually",{"2":{"432":1,"470":1}}],["eventpayforblobs",{"2":{"156":2}}],["event",{"2":{"10":1,"24":1,"31":1,"36":5,"37":2,"38":3,"40":2,"41":2,"42":1,"43":5,"44":11,"45":9,"46":5,"52":2,"56":1,"89":3,"110":1,"153":12,"170":8,"171":8,"172":2,"217":1,"228":1,"288":2,"306":4,"659":1,"695":4}}],["eventschan",{"2":{"171":6}}],["eventsiterator",{"2":{"153":8,"170":8}}],["events",{"2":{"5":2,"42":6,"52":1,"54":1,"56":1,"65":1,"88":3,"89":2,"153":4,"156":4,"169":2,"170":6,"171":2,"172":4,"217":2,"306":4,"576":2,"659":2,"690":1}}],["e",{"2":{"10":1,"23":1,"31":1,"33":1,"38":1,"48":2,"128":1,"153":12,"169":1,"170":12,"183":2,"184":1,"196":1,"215":1,"226":1,"276":4,"291":1,"306":2,"314":8,"338":1,"369":1,"420":8,"424":1,"426":1,"432":1,"450":1,"461":3,"462":1,"463":4,"464":4,"466":2,"467":6,"469":4,"470":9,"557":1,"605":1,"618":1,"639":10,"651":1,"656":2,"667":12,"669":12,"670":12,"721":1,"803":1}}],["ed25519",{"2":{"331":1}}],["eds",{"0":{"327":1,"421":1},"2":{"327":8,"421":10}}],["editing",{"2":{"617":1,"655":1,"697":1}}],["edits",{"2":{"9":1}}],["edit",{"2":{"9":1,"220":2,"585":1,"617":1,"695":2,"701":1}}],["education",{"2":{"7":1,"50":1}}],["embedded",{"2":{"531":1}}],["embark",{"2":{"405":1}}],["emvpw0p8nijmvnocp4bv6k+v6gjmwdxuku=",{"2":{"391":2}}],["emit",{"2":{"306":4}}],["emitted",{"2":{"228":1}}],["emits",{"2":{"153":2,"170":2,"172":2}}],["employed",{"2":{"563":1}}],["employees",{"2":{"47":1}}],["employ",{"2":{"447":1}}],["empty",{"2":{"219":1,"323":1,"412":2,"413":3,"415":2,"418":1,"630":1}}],["empowering",{"2":{"52":1}}],["empower",{"2":{"50":1}}],["emphasizing",{"2":{"40":1}}],["empathy",{"2":{"8":1}}],["emergency",{"2":{"24":1}}],["emails",{"0":{"54":1},"2":{"54":2}}],["email",{"2":{"8":1,"24":1,"27":1,"36":1,"45":2,"47":2,"53":1,"54":1,"63":1}}],["engine",{"2":{"666":1,"668":1}}],["engages",{"2":{"563":1}}],["engaged",{"2":{"42":1}}],["engagement",{"2":{"38":1,"43":1}}],["engage",{"2":{"34":1,"44":1,"45":1,"46":1,"50":1,"501":1}}],["engaging",{"2":{"25":1,"41":1,"43":1,"47":1,"55":1,"63":1,"65":1}}],["ens",{"2":{"311":1}}],["ensuring",{"2":{"19":1,"45":1,"65":1}}],["ensures",{"2":{"288":1,"447":1,"451":1,"467":1,"659":1}}],["ensure",{"2":{"2":1,"37":1,"42":1,"43":1,"45":1,"46":2,"47":1,"84":1,"86":1,"88":1,"235":1,"288":1,"393":1,"467":1,"490":2,"617":1,"691":1,"697":1,"716":1,"721":1,"734":1}}],["enabling",{"2":{"290":1,"443":2,"468":1,"601":1,"779":1}}],["enabled=0",{"2":{"223":2}}],["enabled",{"2":{"211":2,"398":1,"556":1,"595":1,"606":1,"695":12,"703":1}}],["enables",{"2":{"110":1,"230":1,"251":1,"265":1,"266":1,"288":1,"460":1,"462":1,"466":2,"467":1,"468":1,"494":1,"598":1,"601":1,"621":1,"798":1}}],["enablement",{"2":{"31":1}}],["enable",{"0":{"214":1,"642":1},"2":{"19":1,"89":4,"220":2,"337":1,"357":1,"398":1,"403":1,"443":2,"460":1,"463":1,"466":1,"598":1,"601":2,"641":1,"649":2,"693":1,"788":3,"790":3,"791":3,"792":3}}],["envcd",{"2":{"220":1}}],["env",{"2":{"211":4,"219":11,"220":7,"227":1,"312":1,"314":4,"424":1}}],["environments",{"2":{"520":1,"740":1,"758":1}}],["environment",{"0":{"312":1,"674":1},"1":{"675":1,"676":1},"2":{"8":1,"30":1,"52":1,"211":4,"219":3,"220":10,"247":1,"250":1,"267":1,"277":2,"303":1,"309":1,"312":1,"341":1,"406":1,"408":1,"414":3,"424":1,"467":1,"593":1,"601":1,"621":1,"665":1,"674":2,"723":1,"733":1,"797":1}}],["enough",{"2":{"145":1,"236":1,"461":1}}],["encrypt",{"2":{"545":2}}],["encrypted",{"2":{"271":1,"545":5}}],["encapsulating",{"2":{"86":1}}],["encounter",{"2":{"393":1,"614":1,"617":1,"661":1,"715":1,"734":1,"808":1}}],["encouraging",{"2":{"50":1}}],["encouraged",{"2":{"366":1,"614":1,"754":1}}],["encourages",{"2":{"41":1,"44":1,"47":1,"84":1}}],["encourage",{"2":{"37":1,"43":1,"44":1,"45":1}}],["encode",{"2":{"164":2,"396":1,"437":2,"461":1}}],["encoded",{"2":{"134":1,"136":1,"146":1,"151":1,"156":1,"161":1,"178":2,"192":1,"199":1,"200":1,"203":1,"374":9,"376":2,"396":2,"397":1,"434":4,"435":4,"548":1}}],["encoding",{"2":{"134":1,"159":2,"180":1,"411":2,"437":6,"452":2,"461":2,"463":8,"466":1,"469":1}}],["encompasses",{"2":{"531":1}}],["encompass",{"2":{"47":1}}],["enjoyed",{"2":{"317":1}}],["enjoy",{"2":{"52":1,"65":1,"91":2}}],["enjoyable",{"2":{"41":1}}],["enlightening",{"2":{"50":1}}],["endkey",{"2":{"165":3}}],["ending",{"2":{"165":2,"407":1,"467":1}}],["endshare=1",{"2":{"161":1}}],["endblock",{"2":{"153":6,"170":4}}],["end=20",{"2":{"151":1}}],["endpoint",{"0":{"366":1,"602":1,"654":1},"1":{"655":1,"656":1,"657":1},"2":{"89":3,"107":2,"120":1,"145":4,"150":1,"151":1,"152":1,"153":4,"156":1,"158":1,"160":1,"161":3,"162":1,"169":1,"170":4,"172":4,"211":1,"219":1,"220":2,"284":1,"309":1,"314":4,"366":4,"374":1,"391":1,"403":1,"519":1,"521":2,"524":1,"531":1,"537":1,"538":1,"557":4,"598":6,"599":2,"600":2,"601":4,"602":1,"618":2,"649":1,"654":1,"656":1,"667":1,"685":3,"726":3,"739":1,"748":1,"750":1,"761":1,"762":1,"763":1}}],["endpoints",{"0":{"520":1,"521":1,"522":1,"523":1,"524":1,"740":1,"742":1,"743":1,"744":1,"745":1,"747":1,"748":1,"749":1,"750":1,"758":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1},"1":{"523":1,"524":1,"750":1},"2":{"33":1,"248":1,"322":1,"333":1,"357":1,"362":1,"365":1,"417":1,"521":7,"523":1,"524":3,"583":1,"606":1,"649":2,"740":1,"742":1,"747":1,"748":3,"758":1,"759":1,"760":2,"762":2,"764":1,"784":1,"800":1}}],["end",{"2":{"44":1,"134":2,"150":1,"156":6,"160":1,"161":4,"165":3,"172":4,"181":1,"184":1,"225":2,"228":1,"464":1,"469":1,"576":2,"577":2,"695":4}}],["enhancement",{"2":{"608":1}}],["enhanced",{"2":{"515":1}}],["enhances",{"2":{"41":1,"44":1}}],["enhance",{"2":{"38":1,"470":1}}],["entails",{"2":{"463":1,"467":4,"468":1}}],["entering",{"2":{"797":1}}],["enter",{"2":{"272":1,"315":1,"476":1,"480":1,"545":2,"557":1,"563":1,"573":2}}],["enters",{"2":{"24":1}}],["entrypoint",{"0":{"313":1},"2":{"211":1,"219":1,"243":2,"276":2,"277":2,"313":1}}],["entry",{"2":{"84":2,"250":1}}],["enthusiastic",{"2":{"49":1}}],["enthusiasts",{"2":{"43":1,"50":1}}],["entire",{"2":{"35":1,"108":1,"277":1,"451":1,"460":1,"470":1,"618":1,"634":1,"650":1,"749":1}}],["entirely",{"2":{"34":1,"143":1}}],["entitle",{"2":{"525":1,"765":1}}],["entitles",{"2":{"31":1}}],["entities",{"2":{"233":1,"457":1}}],["entity",{"2":{"27":2,"31":5,"33":1,"34":2,"601":1,"618":2}}],["enforced",{"2":{"428":1,"673":1}}],["enforce",{"2":{"52":1}}],["enforcement",{"0":{"9":1,"11":1,"12":1},"1":{"13":1,"14":1,"15":1,"16":1},"2":{"11":1,"17":1}}],["enforcing",{"2":{"9":1,"14":1,"15":1}}],["exit",{"2":{"152":6,"153":2,"172":2}}],["existent",{"2":{"136":1}}],["exist",{"2":{"34":1,"210":2,"296":1,"491":1,"492":1,"502":1,"503":1,"539":1,"611":1,"686":1,"729":1}}],["exists",{"2":{"34":1,"176":1,"179":1,"699":1}}],["existing",{"0":{"221":1,"277":1,"350":1},"2":{"23":1,"26":1,"42":1,"47":1,"60":1,"61":1,"89":1,"193":1,"213":1,"217":4,"219":1,"221":2,"226":1,"266":2,"276":1,"277":2,"306":2,"332":1,"338":1,"340":1,"401":1,"432":1,"557":1,"593":1,"614":1,"616":1,"621":1,"698":1,"700":1,"701":1,"716":1,"776":1}}],["exhaustive",{"2":{"107":2}}],["extradata",{"2":{"395":2}}],["extra",{"0":{"652":1},"1":{"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1},"2":{"89":2,"93":1,"184":1,"430":1,"806":1}}],["extends",{"2":{"469":1}}],["extendeddatasquare",{"2":{"327":2,"419":2,"421":2}}],["extendedheaders",{"2":{"721":1}}],["extendedheader",{"2":{"326":2}}],["extended",{"0":{"327":1,"421":1,"463":1},"2":{"183":1,"184":1,"327":1,"389":1,"420":4,"421":1,"461":4,"463":6,"469":4,"470":2,"488":1}}],["extension",{"0":{"474":1,"479":1},"2":{"443":2,"576":4}}],["extent",{"2":{"34":1}}],["external",{"0":{"656":1},"2":{"14":1,"76":1,"105":1,"264":1,"318":1,"357":1,"557":4,"656":3}}],["execstart=$",{"2":{"788":2,"790":2,"791":2,"792":2}}],["exec",{"2":{"276":2,"277":2}}],["executable",{"2":{"223":2,"469":4,"488":2}}],["execution",{"2":{"139":1,"213":1,"245":1,"247":1,"262":2,"265":3,"266":3,"303":1,"336":1,"338":1,"460":2,"466":1,"467":7,"468":1,"508":1}}],["executing",{"2":{"91":2,"467":1,"659":1}}],["executor",{"2":{"91":6}}],["executes",{"2":{"647":2}}],["executed",{"2":{"467":1,"469":1,"651":1,"692":1,"803":1}}],["execute",{"2":{"57":1,"63":1,"213":1,"262":1,"265":1,"466":1,"576":1,"609":1,"648":1,"675":1}}],["exercises",{"2":{"135":1}}],["exemptions",{"2":{"34":1}}],["exemption",{"2":{"34":8}}],["exact",{"2":{"431":1,"495":1,"738":1}}],["exactly",{"2":{"26":1,"331":1,"557":2}}],["example",{"0":{"127":1,"153":1,"172":1,"191":1,"389":1},"2":{"66":1,"88":1,"91":1,"127":1,"151":2,"156":2,"161":2,"164":1,"165":1,"166":1,"168":1,"169":3,"172":5,"181":1,"189":1,"191":1,"211":8,"219":5,"220":3,"227":1,"262":1,"276":1,"277":1,"296":1,"297":1,"300":1,"305":1,"306":1,"317":1,"325":1,"326":1,"344":1,"366":2,"369":1,"371":1,"373":2,"374":4,"376":3,"380":1,"383":1,"386":1,"389":1,"391":2,"403":1,"415":1,"420":1,"429":1,"464":2,"467":1,"470":1,"492":1,"524":2,"537":1,"538":1,"545":1,"547":2,"576":1,"583":1,"590":1,"595":1,"599":1,"600":1,"606":1,"609":1,"611":1,"612":1,"618":2,"639":1,"645":1,"658":1,"659":1,"668":1,"669":1,"698":1,"791":1,"797":1}}],["examples",{"0":{"378":1,"610":1},"1":{"379":1,"380":1,"381":1,"382":1,"383":1,"384":1,"385":1,"386":1,"387":1,"388":1,"611":1,"612":1,"613":1},"2":{"8":2,"10":1,"143":1,"377":1,"391":1,"436":1,"596":1,"601":1}}],["exceed",{"2":{"647":1}}],["exceptions",{"0":{"336":1}}],["exceptional",{"2":{"19":1,"43":1}}],["except",{"2":{"153":2,"439":1}}],["exclusively",{"2":{"515":1}}],["exclusive",{"2":{"53":1,"65":1,"156":1}}],["exchange",{"2":{"24":1,"34":3,"85":1}}],["exposes",{"2":{"762":1}}],["expose",{"0":{"655":1}}],["exposed",{"2":{"135":1,"333":1,"355":1,"365":1,"538":1,"685":1,"726":1}}],["exporter",{"0":{"558":1},"2":{"558":1}}],["exported",{"2":{"545":2}}],["exporting",{"0":{"271":1,"545":1}}],["export",{"0":{"553":1},"2":{"75":3,"91":1,"120":2,"271":7,"276":1,"284":2,"285":2,"293":4,"300":4,"309":1,"310":4,"314":2,"316":2,"318":3,"371":2,"372":1,"373":2,"391":1,"396":3,"443":10,"542":4,"545":3,"553":1,"557":1,"575":2,"581":2,"596":15,"676":4}}],["expand",{"2":{"46":1,"52":1}}],["expiration",{"2":{"34":1}}],["express",{"2":{"44":1}}],["expressed",{"2":{"34":1}}],["expression",{"2":{"7":1}}],["expensive",{"2":{"180":1,"192":1,"194":1,"197":1,"208":2}}],["expenses",{"2":{"44":1}}],["experiment",{"2":{"705":1}}],["experimentation",{"2":{"266":1}}],["experimentalsuggestchain",{"2":{"443":4}}],["experimental",{"2":{"230":1,"621":2,"734":1,"774":1}}],["experimenting",{"2":{"258":1}}],["experiences",{"2":{"8":1}}],["experience",{"2":{"7":2,"8":1,"27":1,"34":1,"38":1,"41":1,"44":1,"52":1,"353":1,"399":1,"405":1,"774":1}}],["experts",{"2":{"43":2,"65":1}}],["expertise",{"2":{"43":1,"48":1,"65":1}}],["expects",{"2":{"598":1,"673":1}}],["expectrevert",{"2":{"306":2}}],["expect",{"2":{"54":1,"65":1,"133":1,"277":1,"419":10,"420":6,"421":6}}],["expectations",{"2":{"42":1}}],["expected",{"2":{"24":1,"36":1,"139":2,"213":1,"492":2,"577":1,"611":1,"612":1,"613":1,"661":2,"808":2}}],["exploring",{"2":{"255":1,"662":1}}],["exploreme",{"2":{"751":1}}],["explored",{"2":{"206":1}}],["explorers",{"0":{"528":1,"751":1,"767":1},"2":{"329":1,"458":1,"528":1,"751":2,"767":3,"803":1}}],["explorer",{"0":{"90":1,"253":1},"2":{"71":1,"90":2,"253":2,"413":2,"444":2,"445":1,"503":1,"528":1,"751":3,"767":2,"797":1,"803":1}}],["explore",{"2":{"5":1,"40":1,"56":1,"57":1,"341":1}}],["explains",{"2":{"343":1,"693":1}}],["explain",{"2":{"302":1}}],["explained",{"2":{"192":1,"197":1,"206":1}}],["explanation",{"2":{"13":1,"450":1}}],["explicit",{"2":{"8":1}}],["python3",{"2":{"402":2}}],["pbcopy",{"2":{"316":1}}],["pbcopyprivate",{"2":{"316":1}}],["pnpm",{"2":{"312":1}}],["pwd",{"2":{"277":2}}],["psql",{"2":{"658":2}}],["ps",{"2":{"276":1,"277":1}}],["psdocker",{"2":{"276":1,"277":1}}],["p",{"2":{"224":2,"276":2,"314":12,"396":2,"650":6}}],["pk",{"2":{"223":2}}],["pkg",{"2":{"153":2,"159":2,"172":2,"437":6,"661":14,"675":4,"808":14}}],["pfbs",{"2":{"178":1,"192":1,"194":1,"304":1,"431":1}}],["pfb",{"0":{"158":1,"392":1,"429":1},"1":{"159":1},"2":{"91":1,"146":5,"148":1,"154":1,"158":1,"159":2,"178":4,"179":1,"180":1,"200":2,"376":3,"426":1,"429":4,"489":1,"738":2}}],["p2p",{"0":{"629":1,"639":1},"1":{"630":1,"631":1},"2":{"89":4,"135":1,"270":9,"271":6,"272":6,"276":4,"277":3,"295":2,"296":2,"344":2,"349":2,"365":4,"366":8,"367":8,"369":2,"371":4,"373":4,"381":2,"391":2,"403":4,"407":4,"466":1,"521":5,"524":2,"537":4,"538":6,"539":4,"542":2,"595":2,"596":4,"598":2,"600":2,"601":4,"604":4,"605":5,"606":2,"609":6,"614":4,"615":4,"616":4,"618":4,"667":12,"669":12,"670":6,"684":4,"685":2,"686":4,"725":4,"726":6,"727":8,"729":4,"764":1,"791":2}}],["pinnacle",{"2":{"733":1}}],["pinning",{"2":{"492":1}}],["pin",{"2":{"492":1}}],["pings",{"2":{"227":1}}],["pink",{"2":{"146":1}}],["pieces",{"2":{"134":1}}],["pick",{"0":{"83":1,"88":1},"2":{"270":1,"475":1,"590":1,"623":1,"639":1,"803":1}}],["pitches",{"2":{"44":1}}],["pitch",{"2":{"44":2}}],["pizza",{"2":{"41":1}}],["phase",{"2":{"633":1}}],["phrase",{"2":{"573":2,"696":1}}],["photos",{"2":{"37":1,"38":1}}],["physical",{"2":{"8":1}}],["plugin",{"2":{"559":1}}],["plus",{"2":{"82":1,"411":1}}],["plonky2x",{"2":{"223":7,"224":3,"242":1}}],["plonk",{"2":{"211":1,"212":1,"222":1,"223":3,"224":1}}],["plw1gxabnavhwwurqswb0xh25zv9xhielqtvld0xqc4=",{"2":{"156":2}}],["plasma",{"2":{"394":1,"399":1}}],["plastic",{"2":{"41":1}}],["plain",{"2":{"374":1,"376":1,"502":1}}],["plaintext",{"2":{"374":1}}],["play",{"2":{"510":1,"663":1,"719":1}}],["playbook",{"2":{"50":1}}],["playlist",{"2":{"46":1}}],["platform",{"0":{"47":1,"227":1},"2":{"55":1,"212":1,"220":2,"227":3,"228":1,"247":1,"665":1,"733":1}}],["platforms",{"2":{"36":1,"45":1,"46":1,"302":2,"334":1}}],["planned",{"2":{"42":1,"45":1}}],["planning",{"2":{"38":1,"48":1,"623":1,"785":1}}],["plans",{"2":{"41":1}}],["plan",{"2":{"36":1,"41":1,"42":1,"45":1,"46":1,"47":1,"57":1,"63":1,"785":1}}],["placeholder=",{"2":{"314":4}}],["placement",{"2":{"23":2,"27":1}}],["place",{"2":{"23":10,"44":1,"256":1,"323":1,"418":1,"557":1,"573":2,"692":1,"698":1}}],["plethora",{"2":{"558":1}}],["pledge",{"0":{"7":1},"2":{"7":2,"34":1}}],["please",{"2":{"2":1,"4":1,"27":4,"30":3,"36":1,"53":2,"63":1,"89":1,"133":1,"143":1,"161":1,"162":1,"172":2,"230":1,"270":1,"443":2,"616":2,"626":1,"664":1,"665":1,"694":2,"696":1,"738":1,"772":1,"804":1}}],["polypore",{"2":{"695":6}}],["polyfills",{"2":{"313":2}}],["policies",{"2":{"31":1,"33":1}}],["policy",{"2":{"30":2,"33":3,"695":4,"701":4}}],["political",{"2":{"8":1}}],["popup",{"2":{"476":1}}],["populating",{"2":{"412":1,"656":1}}],["populates",{"2":{"523":1,"524":1,"747":1,"748":1,"759":1,"760":1}}],["populated",{"2":{"413":1}}],["populate",{"2":{"108":1}}],["popularity",{"2":{"42":1}}],["popular",{"2":{"42":1,"45":1}}],["pops",{"2":{"276":2,"277":2,"366":2,"445":2,"538":2,"547":4,"583":2,"585":2,"609":2,"695":2,"726":4,"727":2,"742":1,"743":1,"744":1,"748":1,"760":1,"762":1,"763":1}}],["point",{"2":{"250":1,"270":1,"432":1,"467":2,"557":2,"573":2,"618":1,"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["pointing",{"2":{"181":1}}],["pointer",{"2":{"107":1,"110":1,"134":2,"136":1,"181":1}}],["points",{"0":{"23":1},"2":{"347":1,"608":1}}],["portid",{"2":{"700":4}}],["portions",{"2":{"450":1,"451":1,"452":1}}],["portion",{"2":{"22":1,"146":1,"462":1,"500":1,"509":1,"580":1,"584":1}}],["ports",{"0":{"595":1,"606":1},"2":{"276":4,"277":4,"366":2,"521":3,"524":2,"537":2,"591":2,"595":7,"604":2,"606":7,"667":2,"685":2,"719":2,"726":2,"800":2}}],["portrays",{"2":{"191":1}}],["port",{"2":{"89":1,"309":3,"314":2,"315":1,"366":5,"391":2,"523":1,"524":5,"537":5,"538":1,"557":3,"558":1,"585":2,"595":2,"606":4,"608":1,"613":2,"685":1,"695":4,"700":8,"717":4,"718":3,"726":1,"747":1,"748":20,"759":1,"760":5,"761":1,"762":1,"763":1}}],["portal",{"2":{"75":8,"77":8,"78":1,"79":1,"83":3,"84":1,"287":1,"318":8,"319":8,"320":1,"340":1}}],["poolcelestia",{"2":{"549":1}}],["pool",{"0":{"498":1,"549":1},"2":{"42":1,"498":2,"510":1,"549":9}}],["potentially",{"2":{"42":1,"46":1,"334":1,"429":1,"430":1}}],["potential",{"2":{"36":1,"42":1,"43":2,"44":2,"55":1,"89":1,"235":1}}],["powerful",{"2":{"555":1}}],["power",{"2":{"24":1,"383":4,"405":1,"469":1}}],["pos",{"0":{"465":1},"1":{"466":1},"2":{"466":2}}],["possibly",{"2":{"441":1}}],["possible",{"2":{"45":1,"79":1,"106":1,"139":2,"158":1,"191":1,"217":1,"244":1,"265":1,"294":1,"331":1,"393":1,"461":1,"463":1,"470":1,"490":1,"492":1,"616":1}}],["possibilities",{"2":{"321":1,"341":1,"467":1}}],["postgresql",{"2":{"658":1}}],["postcontainerstyle",{"2":{"314":4}}],["postcontent",{"2":{"314":4}}],["postcreated",{"2":{"306":4}}],["postupdated",{"2":{"306":4}}],["postid",{"2":{"306":20}}],["postings",{"2":{"86":1}}],["posting",{"0":{"143":1},"2":{"10":1,"84":3,"85":1,"88":2,"89":1,"107":1,"133":1,"137":1,"288":2,"338":4,"340":1,"416":1,"663":1}}],["poster",{"0":{"88":1},"2":{"84":4,"86":1,"88":2,"89":7,"91":3,"107":3}}],["posted",{"2":{"76":1,"83":3,"84":1,"89":1,"91":2,"107":2,"110":1,"127":1,"131":1,"133":1,"134":2,"135":1,"139":3,"143":1,"145":1,"146":1,"148":1,"163":4,"177":2,"189":1,"195":1,"196":1,"200":1,"203":1,"246":1,"318":1,"324":1,"338":1,"361":1,"413":1,"419":1,"611":1}}],["post",{"0":{"392":1},"2":{"40":1,"43":1,"45":1,"78":1,"79":1,"84":1,"89":1,"107":2,"133":1,"137":2,"174":2,"187":1,"188":1,"237":1,"292":1,"304":1,"306":72,"309":2,"310":3,"314":28,"317":1,"320":1,"324":2,"337":1,"391":4,"392":1,"397":2,"401":1,"403":1,"415":1,"436":2,"613":2}}],["posts",{"0":{"314":1},"2":{"36":1,"38":1,"83":1,"306":24,"314":25,"338":3,"399":1}}],["positions",{"2":{"184":1}}],["position",{"2":{"34":3,"107":1}}],["positiveerror",{"2":{"614":1}}],["positives",{"2":{"470":1}}],["positive",{"2":{"8":1,"52":1,"470":1,"614":3}}],["peerexchange",{"2":{"631":1}}],["peers=$",{"2":{"639":6}}],["peers",{"0":{"631":1},"2":{"630":2,"633":3,"639":38,"649":1,"656":1,"717":3,"764":1}}],["peer",{"0":{"718":1},"2":{"439":1,"492":6,"633":3,"718":3,"804":1}}],["peerid",{"2":{"381":1}}],["pending",{"2":{"69":1,"71":1}}],["percentage",{"2":{"494":1,"549":1,"563":2}}],["persist",{"2":{"668":1}}],["persisted",{"2":{"659":1,"673":1}}],["persistent",{"0":{"668":1,"718":1},"1":{"669":1,"670":1},"2":{"639":13,"670":1,"717":5,"718":1}}],["perspective",{"2":{"470":1,"531":1}}],["persons",{"2":{"34":1}}],["person",{"2":{"31":3,"34":7,"46":2,"65":1}}],["personal",{"2":{"5":1,"7":1,"8":1,"27":1,"43":1,"44":1}}],["per",{"2":{"43":1,"429":2,"430":2,"431":1,"437":2,"489":1,"495":1,"505":1,"526":2,"692":1,"765":2}}],["perfect",{"2":{"40":1}}],["perform",{"2":{"139":2,"309":1,"310":1,"467":2,"470":1,"491":1,"720":1,"721":1}}],["performing",{"2":{"121":1,"248":1,"286":1,"462":1,"470":2}}],["performs",{"2":{"117":1,"282":1,"369":1,"469":1}}],["performed",{"2":{"33":1,"335":1,"462":1,"697":2,"723":1}}],["performance",{"2":{"19":1,"21":1,"24":1,"33":1,"38":1,"230":1,"266":1,"515":1,"555":1,"617":1,"621":1,"734":1,"763":1,"774":1}}],["pertain",{"2":{"34":1}}],["permit",{"2":{"34":1}}],["permissions",{"2":{"355":1,"668":1,"673":2}}],["permissioned",{"2":{"234":1}}],["permissionless",{"2":{"215":1,"460":1,"467":1,"509":1}}],["permissionlss",{"2":{"214":1}}],["permission",{"0":{"295":1,"298":1},"1":{"299":1},"2":{"8":1,"294":1}}],["permanently",{"2":{"31":1,"490":1,"563":1}}],["permanent",{"0":{"16":1},"2":{"14":1,"15":1,"16":1}}],["periods",{"2":{"24":1}}],["period",{"2":{"14":1,"15":2,"23":1,"25":1,"34":5,"84":2,"217":1,"563":3,"700":2}}],["people",{"2":{"8":1,"14":1,"15":1,"40":1,"42":1,"47":1,"48":1}}],["packet",{"2":{"695":8,"701":4}}],["packets",{"2":{"693":3,"694":1,"695":2}}],["packages",{"2":{"675":1,"782":1}}],["package",{"0":{"437":1},"2":{"102":1,"152":1,"153":1,"172":1,"411":1,"437":2,"543":1,"557":1}}],["panic",{"2":{"661":2,"808":2}}],["panel",{"2":{"486":1}}],["pagination",{"2":{"579":4}}],["pages",{"2":{"73":1}}],["page",{"2":{"27":1,"69":1,"85":1,"111":1,"169":1,"254":1,"256":1,"270":1,"276":2,"279":1,"302":1,"318":1,"350":1,"366":3,"367":1,"394":1,"426":1,"442":1,"469":1,"474":1,"529":1,"537":3,"538":1,"557":2,"559":1,"563":1,"583":1,"591":1,"593":1,"594":1,"604":1,"665":2,"667":2,"674":1,"685":4,"719":1,"723":1,"726":1,"753":1,"754":2,"768":1,"781":1,"800":3,"806":1}}],["paired",{"2":{"557":1}}],["paid",{"2":{"85":1,"403":1,"492":1}}],["padded",{"2":{"469":1}}],["padding",{"2":{"314":6}}],["path=$path",{"2":{"676":4}}],["path",{"0":{"569":1},"2":{"212":2,"220":3,"224":2,"269":2,"314":2,"370":1,"372":3,"373":5,"539":1,"540":1,"548":4,"549":2,"569":1,"627":1,"669":6,"670":4,"673":1,"686":1,"687":1,"729":1,"730":1}}],["pattern",{"2":{"16":1}}],["payee",{"2":{"695":2}}],["payer",{"2":{"576":2}}],["paying",{"0":{"487":1,"507":1},"1":{"488":1,"489":1},"2":{"508":1}}],["payload",{"2":{"413":4}}],["payforblob",{"2":{"153":6,"159":1,"170":2,"172":2,"538":1,"685":2,"727":1,"732":1}}],["payforblobs",{"0":{"488":1},"2":{"146":1,"288":1,"367":1,"393":1,"401":1,"430":1,"434":2,"469":3,"470":1,"488":3,"507":1,"726":1}}],["pay",{"2":{"85":1,"89":1,"292":2,"300":1,"367":1,"403":1,"430":1,"538":1,"685":1,"727":1}}],["payments",{"2":{"84":1}}],["payment",{"2":{"32":1,"292":1,"331":1,"488":2}}],["paradigm",{"2":{"467":2}}],["parallel",{"2":{"266":1}}],["param",{"2":{"548":2}}],["paramfilter",{"2":{"548":1}}],["params=",{"2":{"443":6}}],["params",{"2":{"89":1,"331":1,"391":2,"397":3,"443":27,"548":3,"633":1}}],["parameterchangeproposal",{"2":{"548":2}}],["parameters",{"0":{"443":1,"497":1,"737":1},"1":{"738":1},"2":{"91":1,"163":4,"169":2,"213":1,"351":1,"369":1,"426":1,"429":2,"430":1,"442":1,"443":3,"444":1,"445":1,"470":1,"497":2,"510":1,"548":1,"563":1,"737":2}}],["parameter",{"2":{"84":2,"131":1,"156":1,"429":1,"430":1,"431":1,"548":3,"617":2,"738":2,"803":1}}],["parity",{"2":{"183":1,"461":1,"463":1}}],["parsing",{"2":{"178":1,"179":2,"188":1,"192":1,"203":1}}],["parsed",{"2":{"208":1,"219":1,"413":2}}],["parse",{"2":{"172":2,"178":2,"180":1,"192":1,"194":1,"208":1,"389":1,"413":2}}],["parenthash",{"2":{"395":2}}],["parent",{"2":{"84":1,"88":2,"91":18}}],["parts",{"2":{"383":4,"488":1,"510":1}}],["partnering",{"2":{"40":1,"44":1}}],["part",{"2":{"34":1,"53":1,"146":1,"148":2,"149":1,"154":1,"172":6,"183":1,"184":5,"188":1,"192":3,"196":1,"236":1,"264":1,"464":2,"467":1,"500":1,"507":1,"508":1,"694":1,"737":1,"785":1,"798":1}}],["partitioned",{"2":{"464":1,"469":1}}],["partitions",{"2":{"362":1,"464":1}}],["particularly",{"2":{"334":1,"447":1}}],["particular",{"2":{"236":1}}],["participating",{"2":{"30":1,"31":1,"34":1,"48":1,"52":1,"65":1,"519":1,"554":1,"711":1,"739":1,"754":1,"783":1}}],["participations",{"2":{"34":1}}],["participation",{"2":{"7":1,"19":1,"24":1,"30":2,"31":2,"32":4,"34":4,"38":1,"55":1,"84":1}}],["participates",{"2":{"769":1}}],["participate",{"0":{"773":1},"1":{"774":1,"775":1,"776":1,"777":1,"778":1,"779":1,"780":1,"781":1},"2":{"30":3,"31":5,"33":1,"34":2,"44":1,"53":1,"65":1,"84":1,"468":1,"521":1,"709":1,"739":1,"754":1,"769":1,"776":1,"777":1,"793":1,"803":1}}],["participant",{"2":{"24":1,"54":1}}],["participants",{"2":{"23":1,"31":1,"46":1,"48":3,"52":1,"65":1,"714":1,"716":4,"717":2,"718":1}}],["parties",{"2":{"33":1,"187":1,"457":1}}],["party",{"2":{"31":10,"33":4,"290":1,"292":1,"300":1,"329":1,"457":1,"650":1}}],["paper",{"2":{"34":1,"461":1,"464":1,"470":1}}],["passphrase",{"2":{"545":2,"797":3}}],["passport",{"2":{"33":1}}],["password",{"2":{"545":3,"557":1,"573":2}}],["passes",{"2":{"370":1,"469":1}}],["passed",{"2":{"117":2,"282":2,"377":1,"413":2,"539":1,"542":2,"685":1,"686":1,"726":1,"729":1}}],["passing",{"0":{"346":1,"347":1}}],["passionate",{"2":{"65":1}}],["pass",{"2":{"117":4,"131":1,"282":4,"323":1,"370":1,"412":3,"413":3,"415":2,"418":1,"443":2,"548":1}}],["pasting",{"2":{"408":1}}],["paste",{"2":{"89":1,"133":1,"407":1}}],["past",{"2":{"5":1,"44":1,"453":1,"454":3,"455":1,"457":1,"458":2,"576":1,"645":1,"710":1}}],["punish",{"2":{"563":1}}],["put",{"2":{"488":1}}],["pub",{"2":{"383":4,"443":2,"577":2,"578":2}}],["pubkey=$",{"2":{"554":2,"803":2}}],["pubkeyed25519",{"2":{"383":4}}],["pubkey",{"2":{"277":4,"573":4,"574":8,"578":2}}],["pubs",{"2":{"42":1}}],["publish",{"2":{"459":1,"488":1,"556":1}}],["published",{"2":{"107":1,"130":1,"148":1,"153":2,"173":1,"234":1,"261":1,"262":1,"306":14,"314":4,"447":2,"490":2,"492":1}}],["publishing",{"2":{"8":1,"557":3}}],["publicnode",{"2":{"403":2}}],["publicprovider",{"2":{"313":4}}],["publicly",{"2":{"34":1,"65":1,"655":1}}],["public",{"2":{"3":1,"8":1,"10":1,"13":1,"15":2,"16":1,"33":1,"34":4,"43":1,"79":1,"85":1,"113":1,"116":8,"117":9,"119":2,"127":6,"172":2,"227":2,"281":8,"282":9,"306":26,"308":4,"313":2,"357":1,"403":3,"455":1,"491":1,"492":2,"499":1,"500":1,"525":1,"591":2,"654":1,"655":1,"656":1,"714":1,"742":1,"743":1,"744":1,"748":1,"760":1,"761":1,"763":1,"765":1,"803":1}}],["pure",{"2":{"127":2}}],["purchasers",{"2":{"34":1}}],["purchased",{"2":{"8":1}}],["purposes",{"2":{"113":1,"135":1,"366":1,"453":1,"673":1,"754":1}}],["purpose",{"2":{"34":1,"52":1,"269":1,"338":1,"457":1,"490":1,"631":1}}],["pursuant",{"2":{"30":1,"31":2,"34":3}}],["pulled",{"2":{"415":1}}],["pull",{"2":{"2":2,"269":1,"614":1,"716":1,"772":1}}],["push",{"2":{"2":2,"127":2,"695":4}}],["prune",{"2":{"491":1,"646":2,"749":1}}],["pruned",{"2":{"24":1,"28":1,"441":1,"491":1}}],["pruning",{"0":{"490":1,"491":1,"640":1},"1":{"491":1,"492":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1},"2":{"490":1,"491":4,"524":1,"645":2,"646":1,"748":1,"749":1}}],["pragma",{"2":{"116":2,"117":2,"127":2,"172":1,"281":2,"282":2,"306":4,"308":2}}],["practices",{"0":{"492":1},"2":{"31":1,"33":1,"60":1}}],["precise",{"2":{"738":1}}],["precedence",{"2":{"608":1}}],["precompiles",{"2":{"266":1}}],["preserved",{"2":{"614":1}}],["presence",{"2":{"439":1,"608":1}}],["presenters",{"2":{"43":1}}],["presented",{"2":{"34":1}}],["presenting",{"2":{"43":1}}],["presentation",{"0":{"59":1,"60":1,"61":1,"62":1},"2":{"36":1,"43":1,"44":1,"59":3,"60":3,"61":3,"62":2}}],["presentations",{"2":{"36":1,"37":1,"43":1,"60":1,"61":1,"65":1}}],["presently",{"2":{"34":1}}],["present",{"2":{"34":1,"234":1,"604":1,"614":1}}],["presumes",{"2":{"593":1}}],["press",{"2":{"485":1}}],["predetermined",{"2":{"450":1}}],["prefix",{"2":{"396":2,"444":1,"445":1,"695":12}}],["prefixed",{"2":{"374":1,"469":1}}],["preferences",{"2":{"594":1,"622":1}}],["preferred",{"0":{"472":1}}],["prefer",{"2":{"366":1,"537":1}}],["preimage",{"0":{"108":1},"2":{"106":1,"108":3}}],["pre",{"0":{"291":1,"304":1,"594":1,"622":1,"626":1},"2":{"84":1,"213":1,"310":1,"394":1,"592":1,"594":3,"622":3}}],["prerequisites",{"0":{"80":1,"101":1,"114":1,"125":1,"145":1,"275":1,"589":1,"666":1},"2":{"267":1}}],["prerequisite",{"2":{"53":1,"267":1,"561":2}}],["preparing",{"2":{"37":1}}],["prepared",{"2":{"661":1,"808":1}}],["prepare",{"2":{"36":2,"45":1}}],["previoushash",{"2":{"134":2,"137":2}}],["previous",{"0":{"241":1},"1":{"242":1,"243":1,"244":1},"2":{"38":1,"85":1,"110":1,"117":1,"134":2,"213":2,"222":1,"224":3,"225":1,"236":1,"242":1,"282":1,"453":1,"479":1,"576":1,"580":1,"584":1,"608":1,"616":1,"715":1,"785":1}}],["previously",{"2":{"31":1,"338":1,"369":1,"591":1,"803":1}}],["preventing",{"2":{"288":1}}],["prevent",{"2":{"33":1,"584":1,"585":1,"704":1}}],["pro",{"2":{"751":1}}],["probabilistically",{"2":{"470":1}}],["probability",{"2":{"461":1}}],["probably",{"2":{"262":1}}],["problems",{"2":{"454":1,"456":1}}],["problem",{"0":{"448":1,"454":1},"2":{"448":2,"457":2,"460":1,"467":1,"468":1}}],["problematic",{"2":{"447":1}}],["proj",{"2":{"408":2}}],["project",{"0":{"305":1,"323":1,"410":1,"418":1},"1":{"306":1,"307":1,"308":1,"309":1},"2":{"115":7,"116":2,"172":2,"178":1,"280":7,"281":2,"305":1,"311":5,"312":7,"323":1,"410":2,"418":1,"549":2}}],["projector",{"2":{"40":1}}],["projectors",{"2":{"36":1,"40":1}}],["projects",{"2":{"24":1,"44":1,"311":1,"321":1,"353":1}}],["proposal",{"2":{"498":1,"548":14,"549":5}}],["proposalscelestia",{"2":{"548":1}}],["proposals",{"2":{"471":1,"497":2,"510":1,"548":6,"549":3}}],["proposing",{"2":{"469":1}}],["propose",{"2":{"497":1,"563":1}}],["proposer",{"2":{"338":1,"383":8,"403":4,"548":4}}],["proposed",{"2":{"34":1,"448":1}}],["property",{"2":{"470":1,"505":1}}],["properties",{"2":{"265":1,"531":1}}],["properly",{"2":{"307":1,"633":1}}],["proxy",{"2":{"227":1}}],["pros",{"0":{"179":1,"185":1,"189":1,"193":1,"197":1,"201":1,"204":1},"2":{"175":1,"179":1}}],["prospectus",{"2":{"34":1}}],["prospective",{"2":{"21":1}}],["producers",{"2":{"463":2,"470":1}}],["producer",{"2":{"448":2,"469":4}}],["produced",{"2":{"325":1,"326":1,"420":1}}],["produceblock",{"2":{"137":2}}],["producing",{"2":{"135":2,"559":1,"769":1}}],["product",{"2":{"429":1,"430":2}}],["production",{"0":{"520":1,"740":1,"758":1},"2":{"84":2,"264":1,"520":1,"521":2,"531":1,"639":1,"733":1,"740":3,"742":2,"758":3,"774":1}}],["products",{"2":{"31":2,"516":1}}],["provably",{"2":{"490":1}}],["provers",{"2":{"214":1,"215":1,"424":1}}],["prover=network",{"2":{"424":1}}],["prover=local",{"2":{"424":1}}],["prover=",{"2":{"211":2}}],["prover",{"0":{"214":1,"216":1,"220":1},"2":{"211":7,"214":1,"215":2,"216":3,"217":2,"220":7,"221":1,"237":1,"424":1}}],["proven",{"2":{"189":1,"196":1,"225":1,"242":1}}],["proveshars`",{"2":{"172":2}}],["provesharesv2`",{"2":{"172":2}}],["provesharesv2",{"2":{"162":1}}],["proveshares",{"2":{"158":1,"160":1,"162":3,"172":2,"184":1}}],["proves",{"2":{"165":2,"230":1}}],["prove=true",{"2":{"156":1}}],["proved",{"2":{"136":1}}],["prove",{"2":{"130":1,"134":3,"137":1,"139":1,"146":1,"148":5,"150":1,"154":1,"156":1,"161":3,"163":2,"166":1,"168":1,"173":1,"174":1,"177":5,"183":2,"184":6,"187":1,"192":1,"197":1,"200":1,"220":3,"236":1,"262":1,"464":1,"469":1}}],["provision",{"2":{"750":1}}],["provisions",{"2":{"34":2,"495":1}}],["proving",{"0":{"141":1,"153":1,"183":1,"184":1,"226":1},"2":{"133":1,"154":1,"173":1,"174":1,"176":1,"178":2,"184":2,"188":4,"220":1,"226":2,"227":1,"244":1,"424":4,"447":1}}],["provided",{"2":{"30":1,"32":1,"33":1,"34":2,"39":1,"43":1,"50":1,"79":1,"91":1,"113":1,"166":1,"183":1,"192":1,"200":2,"211":2,"268":1,"331":1,"464":3,"630":1,"633":1,"649":2,"691":1}}],["provides",{"2":{"30":1,"47":1,"131":1,"247":1,"256":1,"290":1,"353":1,"355":1,"366":1,"423":1,"460":1,"464":1,"466":1,"467":1,"468":1,"492":1,"537":1,"555":1,"685":1,"738":1}}],["providers",{"0":{"329":1},"1":{"330":1,"331":1,"332":1,"333":1,"334":1,"335":1,"336":1},"2":{"31":1,"40":1,"264":1,"313":3,"314":4,"329":1,"357":1,"492":2,"520":1,"521":1,"740":2,"742":1,"758":2}}],["provider",{"0":{"107":1,"331":1},"1":{"332":1,"333":1,"334":1,"335":1,"336":1},"2":{"27":1,"31":1,"40":1,"88":1,"106":1,"107":1,"217":1,"259":1,"313":4,"314":8,"399":1,"520":1,"650":1,"740":1,"758":1}}],["provide",{"0":{"459":1},"2":{"19":1,"27":1,"30":2,"31":1,"32":1,"33":1,"37":1,"41":1,"46":1,"47":1,"102":1,"109":1,"148":1,"149":1,"150":1,"154":1,"183":1,"184":2,"306":1,"374":1,"452":1,"457":2,"458":2,"460":1,"464":2,"492":1,"523":1,"524":2,"555":1,"576":1,"630":1,"651":1,"715":1,"747":1,"748":2,"752":1,"759":1,"760":2,"766":1,"772":1,"784":1,"803":2}}],["providing",{"0":{"466":1},"2":{"13":1,"41":1,"50":1,"55":1,"110":1,"208":1,"245":1,"266":1,"355":1,"391":1,"515":1}}],["procedure",{"2":{"248":1,"368":1}}],["proceeding",{"2":{"85":1,"139":1,"694":1}}],["proceed",{"2":{"71":1,"84":2,"173":1,"200":1,"203":1,"267":1,"485":1,"663":1,"714":1,"785":1}}],["processing",{"2":{"266":1}}],["processed",{"2":{"261":1,"439":1}}],["processes",{"2":{"31":1,"414":2,"440":1,"458":1,"531":1,"693":1,"786":1,"788":1}}],["process",{"0":{"20":1,"22":1,"29":1,"690":1,"691":1,"786":1},"1":{"21":1,"22":1,"23":1,"24":1,"25":1,"691":1,"692":2,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1},"2":{"22":1,"31":1,"36":1,"47":1,"79":1,"84":1,"110":1,"136":1,"139":3,"171":2,"195":1,"196":1,"236":1,"251":1,"261":1,"267":1,"292":1,"338":1,"351":1,"405":1,"415":2,"452":1,"467":1,"529":1,"531":3,"541":1,"602":1,"609":1,"651":1,"688":1,"690":1,"691":1,"731":1,"737":1,"753":1,"768":1,"781":1,"787":1,"792":1,"802":1}}],["proofnonce",{"2":{"153":4,"170":2,"172":2}}],["proofs",{"0":{"131":1,"144":1,"163":1,"178":1,"203":1,"204":1,"205":1,"227":1,"228":1,"463":1},"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":2,"165":2,"166":2,"167":2,"168":2,"169":2,"170":2,"171":2,"172":2,"173":1,"204":1,"205":1},"2":{"108":1,"130":1,"131":2,"136":1,"145":1,"146":1,"148":1,"149":1,"154":1,"156":6,"160":4,"161":4,"163":4,"165":8,"168":10,"171":1,"172":15,"173":1,"177":9,"178":5,"180":1,"183":1,"184":5,"185":1,"187":1,"188":3,"189":1,"191":2,"192":4,"194":1,"195":1,"199":1,"200":1,"203":3,"205":1,"211":1,"212":1,"214":1,"215":3,"217":1,"220":6,"221":1,"222":2,"224":3,"225":1,"226":2,"230":1,"236":2,"238":1,"242":2,"243":1,"244":1,"265":1,"451":1,"452":1,"461":1,"463":2,"464":1,"467":1,"470":1,"678":2,"693":1}}],["proof",{"0":{"130":1,"146":1,"150":1,"154":1,"155":1,"158":1,"160":1,"170":1,"177":1,"182":1,"221":1,"494":1,"509":1},"1":{"147":1,"148":1,"151":1,"152":1,"156":1,"157":1,"159":1,"161":1,"162":1},"2":{"33":1,"108":1,"127":12,"128":2,"129":1,"130":1,"131":5,"133":1,"136":5,"139":2,"141":1,"148":2,"149":1,"150":4,"151":4,"152":2,"153":14,"154":3,"155":1,"156":9,"157":2,"158":1,"160":5,"161":3,"163":9,"164":1,"165":12,"167":1,"168":14,"169":11,"172":40,"173":2,"177":6,"178":1,"179":1,"182":1,"183":6,"184":11,"188":1,"191":1,"192":3,"196":3,"197":2,"200":3,"203":5,"206":1,"208":3,"211":4,"214":1,"215":1,"217":2,"219":2,"220":1,"223":3,"225":1,"226":1,"227":2,"228":3,"233":1,"236":4,"265":3,"452":2,"461":1,"464":1,"470":1,"471":1,"494":3,"501":1,"509":2,"531":1,"563":1}}],["proto",{"2":{"172":2,"437":2}}],["protobuf",{"0":{"200":1},"2":{"149":4,"178":2,"179":1,"180":1,"192":2,"199":1,"200":2,"202":1,"203":2}}],["protocol",{"2":{"24":1,"30":2,"43":1,"105":1,"135":1,"236":1,"242":1,"314":2,"323":1,"418":1,"428":1,"494":1,"499":1,"595":1,"601":1,"606":1,"693":1}}],["protection",{"2":{"355":1}}],["protect",{"2":{"25":1,"31":1,"89":1,"355":1}}],["prohibited",{"2":{"24":1,"31":1,"608":1}}],["prometheuslistenaddr",{"2":{"556":2}}],["prometheus",{"2":{"556":9,"557":17,"558":1,"602":1,"694":1}}],["prompts",{"2":{"416":1}}],["promptanswer",{"2":{"415":2}}],["prompting",{"0":{"414":1},"2":{"415":1}}],["prompt",{"0":{"405":1,"409":1},"1":{"406":1,"407":1,"408":1,"409":1,"410":2,"411":2,"412":2,"413":2,"414":2,"415":2,"416":1},"2":{"85":1,"358":1,"405":1,"410":2,"411":2,"412":8,"413":13,"414":2,"415":14}}],["prompted",{"2":{"83":1,"545":2,"803":1}}],["promptly",{"2":{"11":1,"107":1}}],["promise",{"2":{"314":2}}],["promised",{"2":{"31":1}}],["prominent",{"2":{"65":1}}],["promote",{"2":{"42":1,"45":2,"46":3,"65":1,"266":1}}],["promotions",{"2":{"37":1}}],["promotional",{"2":{"36":1,"37":1}}],["promoting",{"2":{"19":1}}],["profileecho",{"2":{"676":1}}],["profile",{"2":{"676":3}}],["proficient",{"2":{"19":1}}],["professionals",{"2":{"46":1}}],["professional",{"2":{"8":1,"34":1,"492":2}}],["programs",{"2":{"499":1}}],["programmatic",{"2":{"354":1}}],["programmatically",{"0":{"431":1},"2":{"143":1,"437":2}}],["programming",{"2":{"116":1,"173":1,"281":1}}],["program",{"0":{"18":1,"19":1,"21":1,"49":1,"50":1},"1":{"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"29":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1},"2":{"19":1,"21":2,"23":2,"24":4,"26":1,"27":3,"28":1,"29":2,"30":11,"31":9,"32":2,"33":4,"34":10,"39":1,"42":1,"43":1,"50":1,"53":2,"54":1,"56":1,"62":3,"65":3,"237":1,"411":4,"412":5,"413":6,"415":2}}],["primitive",{"2":{"449":1,"468":1}}],["primitives",{"2":{"447":1}}],["primarily",{"2":{"84":2,"353":1}}],["primary",{"2":{"19":1,"55":1,"110":1}}],["pricing",{"2":{"235":1}}],["priced",{"2":{"427":1}}],["price",{"0":{"377":1},"2":{"89":3,"324":3,"377":10,"413":2,"419":3,"426":1,"428":4,"430":3,"437":2,"489":1,"695":8}}],["prices",{"2":{"8":1,"427":1}}],["printf",{"2":{"324":4,"325":2,"326":4,"413":6,"415":4,"436":4}}],["printed",{"2":{"211":1,"219":1}}],["println",{"2":{"152":8,"153":6,"171":2,"172":2,"419":2,"420":2,"437":6}}],["print",{"2":{"36":1,"542":2}}],["prioritised",{"2":{"489":2}}],["prioritized",{"2":{"427":2}}],["priority",{"2":{"383":4}}],["prior",{"2":{"26":1,"34":3,"36":1,"45":1,"561":2,"690":1,"691":1,"692":3}}],["privacy",{"0":{"33":1},"2":{"11":1,"30":2,"31":1,"33":3,"65":1}}],["privatekey",{"2":{"403":10}}],["privatecelestia",{"2":{"373":1}}],["private",{"0":{"373":1},"2":{"8":2,"13":1,"15":1,"27":1,"40":1,"75":5,"76":5,"84":2,"86":1,"91":2,"113":1,"119":2,"120":7,"121":4,"127":4,"211":10,"212":4,"213":8,"219":4,"220":2,"266":1,"271":1,"284":5,"285":7,"286":4,"306":6,"309":6,"310":6,"316":2,"318":10,"373":7,"542":2,"545":4,"561":2,"571":1,"576":6,"608":1,"616":4}}],["pr",{"2":{"2":1}}],["ncdu",{"2":{"675":4}}],["ncreated",{"2":{"661":2,"808":2}}],["ntfs",{"2":{"673":1}}],["ngithub",{"2":{"661":12,"808":12}}],["nruntime",{"2":{"661":2,"808":2}}],["nw",{"2":{"562":1}}],["n11",{"2":{"464":2}}],["n12",{"2":{"464":2}}],["n14",{"2":{"464":1}}],["n7",{"2":{"464":1}}],["n8",{"2":{"464":1}}],["n2",{"2":{"462":1,"463":1,"464":1}}],["ns",{"2":{"413":2,"437":6}}],["nsoy0rgl7hqt4vwlg441gqkjsz2fbunzxipgns8ov",{"2":{"277":2}}],["n",{"2":{"324":4,"325":2,"326":4,"413":6,"415":4,"436":4,"454":1,"462":1,"463":2,"553":2,"576":2,"595":1,"606":1,"618":2,"639":12,"661":20,"803":2,"808":20}}],["nft",{"2":{"321":1,"453":1}}],["nfts",{"2":{"43":1}}],["npanic",{"2":{"661":2,"808":2}}],["np5wre24w+e79",{"2":{"156":2}}],["npm",{"2":{"115":3,"280":3,"312":1}}],["nyzlbfjjnskofrzur8xvjijla+wbptwm0kbyglilxlg=",{"2":{"151":2}}],["nmbwwwhpiphwagai7maqm",{"2":{"151":2}}],["nmts",{"0":{"464":1},"2":{"362":1,"460":2,"464":2,"469":1}}],["nmtproof",{"2":{"165":2,"172":2}}],["nmt",{"2":{"148":2,"160":2,"163":2,"419":2,"464":2}}],["nidstring",{"2":{"413":4}}],["nil",{"2":{"137":10,"139":6,"145":6,"152":6,"153":36,"157":4,"159":8,"162":2,"170":14,"171":12,"172":12,"324":12,"325":8,"326":10,"327":8,"412":2,"413":22,"414":4,"415":10,"436":12,"437":16}}],["nitro",{"0":{"110":1},"2":{"90":1,"94":4,"102":4,"105":1,"106":1,"107":3,"108":2,"110":2,"113":1,"114":1,"119":2,"288":1}}],["nice",{"2":{"40":1,"313":1}}],["null",{"2":{"314":4,"576":4,"577":2,"579":4,"658":1,"788":2,"790":2,"791":2,"792":2,"797":2,"803":2}}],["numerator",{"2":{"695":4}}],["numerous",{"2":{"448":1,"467":1}}],["num",{"2":{"695":4}}],["numia",{"2":{"520":4,"740":4,"742":1,"743":1,"744":1,"748":1,"758":4,"760":1,"761":1,"763":1}}],["numleaves",{"2":{"168":3,"184":2}}],["number=26656",{"2":{"718":1}}],["number=26656ip",{"2":{"718":1}}],["numbers",{"0":{"518":1,"736":1,"756":1}}],["number++",{"2":{"116":2,"281":2}}],["number",{"2":{"36":1,"42":1,"76":1,"84":2,"91":8,"116":7,"117":9,"121":3,"168":2,"174":1,"181":1,"183":2,"219":1,"230":1,"265":1,"281":7,"282":9,"286":3,"318":1,"395":2,"429":3,"430":1,"432":1,"437":2,"451":1,"462":1,"468":2,"470":2,"556":4,"558":1,"577":2,"578":2,"617":1,"691":2,"718":2,"738":1}}],["nutshell",{"2":{"148":1}}],["nurturing",{"2":{"53":1}}],["necessitate",{"2":{"602":1}}],["necessity",{"2":{"601":1}}],["necessary",{"0":{"452":1},"2":{"25":1,"33":1,"36":1,"40":3,"86":1,"88":1,"107":2,"108":1,"163":4,"169":2,"183":1,"192":1,"219":3,"234":1,"265":1,"370":1,"439":1,"451":1,"466":1,"470":1,"656":1,"675":1,"695":1,"803":2}}],["net",{"2":{"366":1,"573":2,"727":1,"742":2,"743":2,"744":2,"745":1,"748":2,"751":1,"752":1,"760":1,"761":1,"762":1,"763":1,"767":1}}],["netcelestia",{"2":{"366":1,"727":1}}],["network=$network",{"2":{"667":6,"669":6,"670":6}}],["network=celestia",{"2":{"667":1}}],["network=celestiaexport",{"2":{"667":1}}],["network=custom",{"2":{"596":2}}],["network=",{"2":{"596":2}}],["network=arabicaexport",{"2":{"667":1}}],["network=arabica",{"2":{"344":2,"667":1}}],["network=mochaexport",{"2":{"667":1}}],["network=mochacelestia",{"2":{"296":1}}],["network=mocha",{"2":{"276":2,"296":1,"667":1}}],["networking",{"2":{"37":1,"41":1,"48":2}}],["networks",{"0":{"596":1,"639":1,"773":1},"1":{"774":1,"775":1,"776":1,"777":1,"778":1,"779":1,"780":1,"781":1},"2":{"27":1,"84":1,"135":1,"302":1,"442":1,"460":1,"509":1,"554":1,"604":1,"605":1,"608":1,"639":9,"649":1,"690":1,"693":1,"698":1,"700":1,"718":1,"721":1,"728":1,"748":1,"754":1,"769":1,"785":1,"803":1,"804":1}}],["network",{"0":{"373":1,"443":1,"475":1,"497":1,"516":1,"517":1,"529":1,"554":1,"604":1,"653":1,"705":1,"719":1,"734":1,"735":1,"737":1,"753":1,"755":1,"768":1,"781":1},"1":{"518":1,"605":1,"706":1,"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"738":1},"2":{"19":2,"25":1,"31":1,"43":1,"44":1,"79":1,"83":2,"84":2,"88":3,"89":4,"91":6,"102":2,"135":1,"139":2,"149":2,"163":2,"236":1,"240":1,"262":1,"265":1,"270":20,"271":12,"272":12,"276":3,"277":3,"295":2,"308":1,"313":4,"314":2,"315":3,"324":4,"329":1,"337":1,"338":1,"349":2,"357":1,"361":1,"365":4,"366":8,"367":13,"371":8,"373":8,"374":2,"391":3,"403":1,"407":4,"411":2,"412":2,"413":10,"415":2,"419":4,"424":1,"436":4,"439":2,"442":1,"443":4,"447":1,"456":1,"461":1,"462":1,"466":1,"467":3,"468":2,"470":4,"471":1,"475":1,"479":1,"485":1,"491":2,"492":3,"494":1,"497":1,"501":3,"507":2,"509":2,"510":1,"519":1,"523":1,"524":3,"529":1,"531":5,"537":4,"538":9,"539":4,"541":1,"554":1,"562":1,"563":1,"564":1,"566":1,"571":1,"585":2,"586":1,"593":2,"596":8,"598":4,"600":2,"601":8,"604":10,"605":6,"608":2,"609":6,"614":8,"615":6,"616":10,"618":10,"621":1,"630":1,"639":1,"649":1,"651":1,"655":2,"661":2,"667":7,"669":6,"676":1,"684":4,"685":5,"686":4,"690":4,"691":3,"692":3,"705":1,"711":1,"715":1,"720":1,"725":4,"726":6,"727":12,"729":4,"733":2,"734":2,"737":1,"739":1,"747":1,"748":2,"753":1,"754":2,"759":1,"760":1,"761":1,"764":1,"768":1,"769":4,"774":2,"779":1,"781":1,"793":1,"798":2,"802":1,"803":2,"808":2}}],["nearby",{"2":{"45":1}}],["negatives",{"2":{"470":1}}],["negatively",{"2":{"27":1,"44":1}}],["negotiate",{"2":{"40":1}}],["nextheaderfunctionid",{"2":{"227":1}}],["nextheight",{"2":{"139":4}}],["next",{"0":{"111":1,"122":1,"255":1,"287":1,"321":1,"341":1,"416":1,"571":1,"623":1},"2":{"38":1,"76":2,"77":1,"83":2,"84":1,"88":1,"92":1,"107":1,"111":1,"115":1,"122":2,"131":1,"139":2,"151":1,"153":2,"156":1,"161":1,"170":2,"180":1,"211":1,"213":2,"219":4,"220":5,"224":2,"227":1,"238":1,"276":1,"280":1,"287":1,"306":1,"309":2,"311":1,"312":1,"313":1,"316":2,"318":3,"319":1,"367":1,"374":1,"383":2,"412":2,"413":7,"415":2,"420":2,"468":1,"469":2,"554":1,"557":1,"568":1,"579":6,"609":1,"712":1,"785":1}}],["needing",{"2":{"189":1,"309":1,"449":1,"460":1,"492":1,"576":1,"584":1,"585":1}}],["needs",{"2":{"44":1,"47":1,"48":1,"175":1,"177":1,"192":1,"208":1,"226":1,"243":1,"265":1,"302":1,"401":1,"454":1,"464":1}}],["needed",{"2":{"36":1,"37":1,"40":1,"43":1,"86":1,"89":1,"107":1,"134":1,"145":1,"163":2,"169":2,"184":2,"219":1,"224":2,"406":1,"408":1,"413":1,"429":1,"430":1,"451":1,"452":1,"453":1,"466":1,"557":1,"560":1,"628":1,"633":1,"651":1,"782":1,"791":1,"803":1}}],["need",{"2":{"34":1,"47":1,"63":1,"76":2,"77":1,"82":1,"84":1,"86":1,"89":2,"107":2,"108":1,"135":5,"136":1,"145":1,"150":1,"151":1,"154":1,"156":1,"161":1,"177":1,"179":1,"184":2,"189":1,"192":2,"194":1,"196":1,"199":2,"202":1,"203":1,"210":1,"211":1,"217":1,"244":2,"264":2,"265":1,"269":1,"270":1,"276":1,"292":1,"293":1,"294":1,"309":1,"310":2,"312":1,"314":4,"315":1,"316":2,"318":3,"319":1,"323":1,"351":1,"367":2,"368":1,"369":1,"370":1,"371":1,"373":1,"391":1,"402":1,"403":1,"411":1,"412":2,"413":2,"414":1,"418":1,"424":2,"443":2,"452":1,"462":1,"463":1,"492":1,"508":1,"523":1,"524":1,"538":2,"540":1,"557":4,"561":2,"572":1,"581":1,"583":2,"586":1,"589":1,"595":2,"598":1,"601":1,"605":1,"606":2,"608":1,"609":1,"617":1,"618":1,"630":1,"631":1,"641":1,"651":1,"655":1,"656":1,"658":1,"661":1,"668":2,"669":1,"685":2,"687":1,"690":2,"692":3,"696":2,"700":1,"701":1,"706":1,"707":1,"708":1,"712":1,"714":1,"715":1,"727":1,"730":1,"747":1,"748":1,"759":1,"760":1,"779":1,"785":1,"797":1,"800":1,"803":1,"808":1}}],["neither",{"2":{"31":2,"466":1,"611":1}}],["newmetric",{"2":{"520":2,"740":2,"742":1,"743":1,"744":1,"748":1,"758":2,"760":1,"761":1,"763":1}}],["newcredentials",{"2":{"437":2}}],["newclient",{"2":{"324":2,"325":2,"326":2,"327":2,"412":2,"413":2,"414":2,"415":2,"436":2}}],["newblob",{"2":{"437":2}}],["newblobv0",{"2":{"324":3,"413":2,"436":2}}],["newblobnamespacev0",{"2":{"324":3,"325":2,"326":2,"413":2,"436":2}}],["newblobstreamxfilterer",{"2":{"171":2}}],["newblobstreamx",{"2":{"153":2,"170":2}}],["newowner",{"2":{"306":4}}],["newer",{"2":{"302":1,"548":1}}],["newwrappers",{"2":{"172":2}}],["newint",{"2":{"153":8,"165":4,"168":4,"169":8,"172":16}}],["newnumber",{"2":{"116":4,"281":4}}],["newly",{"2":{"91":1,"448":1,"701":1}}],["newsubmitoptions",{"2":{"324":4}}],["newsletters",{"2":{"38":1}}],["newspaper",{"2":{"34":1}}],["new",{"0":{"171":1,"209":1,"211":1,"325":1,"326":1,"349":1,"420":1,"423":1,"508":1,"554":1,"573":1,"700":1,"712":1,"715":1},"1":{"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"424":1},"2":{"2":2,"23":2,"24":2,"26":1,"42":1,"43":1,"47":3,"48":1,"75":1,"88":1,"115":1,"116":1,"117":3,"134":1,"145":2,"152":2,"153":4,"161":1,"162":1,"170":2,"171":3,"172":2,"209":1,"210":1,"217":1,"221":1,"236":2,"237":1,"264":2,"265":2,"266":1,"280":1,"281":1,"282":3,"302":1,"305":1,"306":7,"308":2,"310":2,"311":1,"312":1,"313":1,"314":8,"315":1,"317":1,"318":1,"325":4,"326":11,"348":1,"405":1,"407":2,"410":1,"413":4,"414":1,"416":1,"419":8,"420":9,"421":2,"423":1,"424":1,"432":1,"439":1,"444":3,"445":1,"447":2,"448":1,"449":2,"455":1,"468":1,"474":1,"490":1,"492":2,"540":1,"544":2,"557":1,"563":1,"571":1,"581":1,"609":1,"614":2,"630":1,"639":1,"657":1,"658":1,"659":1,"661":1,"687":1,"690":1,"691":2,"693":1,"698":3,"699":1,"700":3,"701":1,"705":2,"710":1,"712":1,"715":1,"716":1,"719":1,"721":1,"730":1,"777":1,"783":1,"808":1}}],["navigating",{"2":{"217":1}}],["navigate",{"2":{"88":1,"474":1,"479":1,"483":1}}],["name=$",{"2":{"650":6}}],["name=",{"2":{"561":2}}],["name=validator",{"2":{"554":2,"712":2}}],["name=validator1",{"2":{"554":2,"711":2}}],["namekey",{"2":{"554":1}}],["namevalidator",{"2":{"554":1}}],["names",{"2":{"224":1,"276":2,"277":2}}],["namespce",{"2":{"137":2}}],["namespacebytes",{"2":{"413":2}}],["namespacehex",{"2":{"412":2,"413":4,"415":4}}],["namespaced",{"0":{"464":1},"2":{"362":1,"460":1,"464":1,"466":1,"469":3}}],["namespaceid",{"2":{"166":5,"172":8,"413":14,"415":8}}],["namespacenode",{"2":{"163":2,"165":12,"167":4,"172":10}}],["namespacemerklemultiproof",{"2":{"163":2,"165":10,"172":6}}],["namespaces",{"0":{"362":1},"2":{"156":2,"183":1,"324":2,"362":1,"419":2,"464":3,"469":1,"491":1,"492":1}}],["namespace",{"0":{"166":1},"2":{"89":8,"91":1,"107":2,"134":8,"137":2,"148":2,"154":2,"156":4,"161":4,"163":6,"165":31,"166":21,"172":16,"184":2,"246":1,"324":11,"325":6,"326":11,"359":1,"374":7,"376":12,"384":2,"389":3,"391":2,"397":1,"411":2,"412":6,"413":23,"415":10,"416":2,"419":16,"420":13,"434":2,"435":2,"436":10,"437":6,"464":6,"469":5,"488":3,"492":1,"556":4,"611":1,"612":2}}],["named",{"2":{"116":1,"281":1,"306":1,"311":1,"312":1,"343":1,"401":1,"593":1,"594":1,"622":1}}],["name",{"0":{"344":1,"345":1,"346":1},"1":{"346":1,"347":1},"2":{"27":1,"36":1,"69":1,"84":2,"211":2,"220":2,"265":1,"270":7,"271":6,"272":6,"276":2,"277":2,"306":18,"310":2,"311":2,"313":4,"315":1,"343":1,"344":1,"346":3,"367":8,"407":2,"444":1,"445":1,"539":7,"544":8,"545":4,"554":8,"557":6,"573":2,"574":4,"590":2,"596":2,"639":7,"650":6,"668":2,"686":7,"695":4,"711":4,"712":4,"713":4,"715":3,"727":2,"729":7,"797":2,"803":2}}],["naming",{"2":{"2":1,"47":3}}],["natural",{"2":{"457":1}}],["nature",{"2":{"13":1,"34":1,"235":1,"456":1,"460":1,"549":1}}],["nativecurrency",{"2":{"313":2}}],["natively",{"2":{"84":1}}],["native",{"2":{"80":1,"82":1,"91":6,"93":1,"106":1,"444":1,"471":1,"507":1,"513":1,"696":1,"703":1,"704":1}}],["nationality",{"2":{"7":1}}],["natnet",{"2":{"63":1}}],["nat",{"2":{"36":1,"656":1}}],["novel",{"2":{"460":1}}],["now",{"0":{"317":1},"2":{"34":1,"76":1,"78":1,"85":1,"89":2,"92":1,"107":1,"117":2,"120":2,"121":1,"172":2,"211":1,"213":1,"214":1,"220":1,"224":1,"255":1,"276":1,"277":1,"282":2,"284":2,"285":1,"286":1,"287":1,"294":2,"296":1,"303":1,"307":1,"308":2,"309":1,"310":2,"311":1,"312":1,"314":1,"316":4,"317":1,"318":2,"320":1,"338":1,"341":1,"351":1,"365":1,"366":1,"383":1,"395":1,"396":2,"404":1,"407":2,"413":4,"415":4,"443":1,"444":1,"445":1,"456":1,"491":1,"557":1,"571":2,"579":1,"623":1,"662":1,"667":1,"668":1,"670":1,"688":1,"695":1,"696":1,"700":1,"701":1,"716":1,"718":1,"719":1,"748":1,"791":1,"792":1,"803":3}}],["nominee",{"2":{"34":1}}],["normal",{"2":{"139":3,"173":1,"429":1,"447":1,"649":1}}],["normally",{"2":{"40":1}}],["nor",{"2":{"31":2,"34":1,"466":1,"611":1}}],["none",{"2":{"186":1,"190":1,"198":1,"201":1,"204":1,"370":1,"700":4}}],["nonce",{"2":{"127":4,"129":1,"153":4,"163":4,"169":10,"170":2,"172":6,"288":1,"395":2,"396":2,"432":2,"437":2}}],["non",{"2":{"24":1,"28":1,"34":1,"107":2,"136":1,"372":1,"403":1,"497":1,"576":2,"608":1,"704":1}}],["no",{"0":{"458":1},"2":{"14":1,"15":1,"23":1,"30":1,"31":5,"34":8,"40":1,"117":2,"120":2,"126":2,"180":1,"195":1,"246":1,"264":1,"282":2,"285":2,"291":1,"314":2,"357":1,"377":1,"426":1,"428":1,"447":1,"463":1,"470":1,"508":1,"513":1,"524":1,"525":1,"548":5,"559":1,"605":2,"613":3,"633":1,"748":1,"765":1}}],["notably",{"2":{"429":1}}],["notable",{"0":{"336":1},"2":{"451":1}}],["notfound",{"2":{"393":2}}],["notify",{"2":{"721":1}}],["notification",{"2":{"72":1}}],["notice",{"2":{"163":4,"165":6,"166":2,"168":2,"169":4,"374":1,"466":1,"577":1,"578":1,"772":1}}],["nothing",{"2":{"34":1,"645":3}}],["noted",{"2":{"336":1,"709":1}}],["note",{"0":{"656":1},"2":{"27":1,"30":1,"53":1,"89":2,"102":1,"103":1,"108":1,"126":1,"134":1,"135":3,"137":1,"139":2,"149":1,"151":1,"156":1,"160":1,"161":1,"172":2,"173":1,"175":1,"177":1,"181":1,"183":1,"213":1,"223":1,"224":1,"225":1,"226":1,"227":1,"230":1,"236":1,"242":2,"243":1,"270":1,"295":1,"302":1,"309":2,"310":2,"366":1,"369":1,"398":1,"424":1,"429":2,"437":2,"464":1,"467":1,"469":2,"470":1,"526":1,"538":1,"548":1,"557":1,"561":2,"565":1,"569":1,"576":1,"584":1,"589":1,"598":1,"604":2,"611":1,"617":1,"645":1,"664":1,"685":1,"696":1,"715":1,"718":1,"738":1,"765":1,"785":1,"791":1}}],["notes",{"0":{"331":1,"441":1,"586":1},"1":{"332":1,"333":1,"334":1,"335":1,"336":1},"2":{"5":1,"54":1,"491":1,"647":1}}],["not",{"2":{"8":1,"9":1,"23":1,"24":7,"27":1,"30":6,"31":11,"32":3,"33":3,"34":24,"40":1,"41":2,"65":1,"84":2,"88":2,"89":1,"91":2,"94":1,"108":1,"110":1,"126":1,"133":2,"136":1,"137":1,"153":2,"154":1,"172":2,"177":1,"182":1,"183":1,"187":1,"188":1,"189":1,"192":2,"202":1,"208":1,"210":1,"211":3,"217":1,"219":5,"220":2,"224":2,"236":1,"243":1,"270":2,"276":1,"288":1,"295":2,"296":2,"297":1,"302":1,"310":1,"322":1,"333":1,"334":1,"336":1,"362":1,"364":1,"366":1,"367":1,"368":1,"371":3,"377":1,"393":2,"414":2,"417":1,"428":3,"429":1,"430":1,"432":3,"437":2,"439":3,"440":1,"441":1,"451":1,"452":1,"457":1,"463":2,"469":1,"470":2,"490":1,"491":2,"492":2,"497":1,"515":1,"521":1,"524":2,"525":1,"537":1,"538":1,"548":1,"557":1,"563":1,"569":1,"586":1,"589":1,"596":1,"604":1,"605":1,"614":1,"618":1,"633":2,"646":1,"656":1,"659":2,"661":1,"673":1,"676":1,"677":1,"685":1,"689":1,"690":1,"691":1,"692":1,"696":1,"740":1,"742":1,"748":1,"758":1,"760":1,"762":1,"765":1,"769":1,"777":1,"798":2,"808":1}}],["noders",{"2":{"742":1,"743":1,"744":1,"748":1,"760":1,"761":1,"762":1,"763":1}}],["nodebuilder",{"2":{"614":6}}],["nodeclient",{"2":{"412":2,"413":4,"415":2}}],["nodeconfig",{"2":{"86":1,"87":1,"88":1,"89":1,"102":2}}],["nodeip",{"2":{"412":4,"413":4,"415":6}}],["node",{"0":{"60":1,"89":1,"90":1,"100":1,"102":1,"103":1,"138":1,"142":1,"267":1,"270":1,"271":1,"272":1,"276":1,"293":1,"294":1,"296":1,"344":1,"352":1,"359":1,"365":1,"372":1,"381":1,"401":1,"407":2,"434":1,"435":2,"436":1,"437":1,"438":1,"491":1,"523":1,"530":1,"533":1,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"558":1,"584":1,"597":1,"607":1,"618":1,"620":1,"634":1,"636":1,"641":2,"651":1,"657":1,"662":1,"668":1,"669":1,"670":1,"677":1,"680":1,"682":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1,"718":1,"720":1,"723":1,"724":1,"725":1,"726":1,"729":1,"730":1,"731":1,"747":1,"759":1,"764":1,"770":1,"783":1,"786":1,"790":1,"791":1,"792":1,"793":1,"795":1,"798":1,"799":1,"800":1,"801":1,"802":1,"803":1},"1":{"101":1,"102":1,"103":1,"139":1,"140":1,"141":1,"142":1,"143":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"277":1,"294":1,"295":1,"353":1,"354":1,"355":1,"356":1,"357":1,"358":1,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"369":1,"370":1,"371":1,"372":1,"373":2,"374":1,"375":1,"376":1,"377":1,"378":1,"379":1,"380":1,"381":1,"382":1,"383":1,"384":1,"385":1,"386":1,"387":1,"388":1,"389":1,"390":1,"391":1,"392":1,"393":1,"531":1,"532":1,"533":1,"534":2,"535":1,"536":2,"537":2,"538":2,"539":3,"540":3,"541":2,"598":1,"599":1,"600":1,"601":1,"602":1,"608":1,"609":1,"610":1,"611":1,"612":1,"613":1,"619":1,"621":1,"622":1,"623":1,"624":1,"635":1,"636":1,"637":2,"638":2,"639":2,"640":1,"641":1,"642":3,"643":3,"644":1,"645":1,"646":1,"647":1,"648":1,"649":1,"650":1,"651":1,"652":1,"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"660":1,"661":1,"663":1,"664":1,"669":1,"670":1,"678":1,"679":1,"680":1,"681":2,"682":1,"683":2,"684":3,"685":3,"686":2,"687":3,"688":2,"689":2,"721":1,"722":1,"723":1,"724":2,"725":1,"726":1,"727":2,"728":2,"729":2,"730":3,"731":2,"732":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"794":1,"795":1,"796":2,"797":2,"798":1,"799":2,"800":2,"801":2,"802":3,"803":1,"804":1,"805":1,"806":1,"807":1,"808":1},"2":{"3":1,"24":2,"25":1,"27":2,"28":1,"48":1,"60":6,"80":1,"85":1,"86":1,"88":4,"89":10,"90":1,"91":1,"92":1,"94":3,"102":3,"103":3,"107":6,"108":1,"110":1,"114":2,"135":13,"139":1,"142":1,"145":5,"146":1,"165":16,"172":12,"177":1,"265":1,"267":1,"268":2,"269":5,"270":10,"271":6,"272":6,"275":1,"276":15,"277":9,"279":2,"290":1,"291":3,"292":6,"293":1,"294":2,"295":1,"296":3,"297":2,"300":3,"301":2,"304":2,"311":1,"322":1,"323":3,"324":3,"333":2,"336":1,"338":2,"343":2,"344":3,"349":2,"350":1,"352":2,"353":1,"354":1,"355":1,"356":2,"359":1,"362":1,"363":1,"364":1,"365":4,"366":3,"367":9,"368":2,"369":7,"370":6,"371":6,"372":10,"373":8,"374":7,"376":3,"379":2,"380":1,"381":2,"382":1,"387":3,"391":7,"397":2,"400":1,"401":4,"405":2,"406":1,"407":8,"411":2,"412":3,"413":2,"416":1,"417":1,"418":3,"419":1,"428":3,"431":1,"435":1,"436":3,"437":6,"438":1,"439":1,"447":3,"450":2,"451":4,"453":1,"461":1,"462":2,"464":1,"470":8,"491":3,"492":3,"499":1,"519":3,"521":3,"523":2,"524":7,"530":1,"531":4,"532":1,"536":3,"537":4,"538":8,"539":2,"540":3,"541":2,"542":4,"547":12,"553":6,"556":1,"557":1,"558":1,"559":1,"561":4,"562":1,"568":3,"569":2,"580":1,"581":1,"583":3,"584":2,"585":3,"589":1,"591":1,"593":1,"594":1,"595":5,"596":6,"597":4,"598":6,"599":2,"600":2,"601":4,"602":3,"604":5,"605":1,"606":5,"608":7,"609":26,"611":4,"612":3,"613":1,"614":6,"615":2,"616":6,"617":1,"618":5,"621":17,"622":5,"623":6,"624":1,"626":1,"627":4,"628":1,"630":1,"633":7,"634":1,"635":1,"639":10,"641":3,"645":1,"647":1,"648":1,"649":1,"650":2,"651":2,"654":1,"656":1,"658":1,"661":4,"663":3,"664":3,"665":7,"667":30,"668":5,"669":27,"670":30,"673":1,"675":1,"676":2,"677":3,"679":1,"682":1,"685":12,"686":2,"687":3,"688":2,"689":2,"692":4,"695":4,"711":1,"715":1,"718":7,"719":2,"720":1,"722":1,"724":1,"725":2,"726":6,"727":9,"729":2,"730":3,"731":1,"732":1,"734":1,"738":1,"739":3,"740":1,"741":2,"746":3,"747":2,"748":5,"754":10,"758":1,"759":2,"760":4,"761":1,"762":1,"763":1,"764":4,"769":11,"771":4,"772":2,"782":1,"783":3,"784":2,"785":4,"787":1,"788":1,"790":2,"791":4,"792":6,"793":1,"794":1,"795":1,"798":5,"799":1,"800":1,"802":2,"803":2,"804":2,"806":1,"808":4}}],["nodessection",{"2":{"806":1}}],["nodestake",{"2":{"742":1,"743":1,"744":1,"751":1,"767":1}}],["nodes",{"0":{"449":1,"522":1,"531":1,"652":1,"678":1,"721":1,"741":1,"746":1,"757":1,"769":1,"771":1,"772":1,"787":1,"789":1},"1":{"523":1,"524":1,"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"742":1,"743":1,"744":1,"745":1,"747":1,"748":1,"749":1,"750":1,"758":1,"759":1,"760":1,"770":1,"771":1,"772":1,"788":1,"790":1,"791":1,"792":1},"2":{"3":2,"60":1,"85":1,"130":1,"134":2,"135":1,"156":2,"161":2,"165":8,"168":2,"172":4,"188":1,"192":1,"265":2,"294":1,"330":1,"353":1,"357":1,"365":1,"432":1,"447":1,"448":1,"449":2,"450":2,"451":5,"452":5,"454":1,"459":1,"460":1,"461":6,"462":6,"463":3,"464":3,"466":1,"467":3,"468":2,"470":5,"490":1,"491":8,"492":12,"521":3,"523":1,"524":2,"530":1,"531":4,"557":2,"595":3,"602":1,"606":3,"608":1,"615":1,"619":1,"630":1,"631":1,"633":2,"634":1,"639":3,"654":1,"662":1,"674":1,"678":5,"691":1,"717":2,"721":3,"739":1,"742":1,"743":1,"744":1,"747":1,"748":4,"749":3,"754":1,"759":1,"760":2,"761":3,"762":2,"763":2,"764":1,"779":1,"783":4,"784":1,"791":1,"793":1,"798":1}}],["ignore",{"2":{"464":1}}],["ignition",{"2":{"223":16}}],["icon",{"2":{"445":1}}],["icons",{"2":{"58":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=celestia",{"2":{"376":1}}],["ixg+08hv5rspf3lle8ph+b2tugsgusbiseflxh6wb5e=",{"2":{"374":2,"376":11,"377":2}}],["ibc",{"0":{"693":1},"1":{"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1},"2":{"693":3,"694":2,"695":4,"700":1,"703":4}}],["ibctransfer",{"2":{"331":1}}],["ibchost",{"2":{"331":1}}],["i++",{"2":{"137":2,"306":2}}],["illustrate",{"2":{"133":1}}],["illustrations",{"2":{"58":1}}],["i",{"0":{"208":1},"2":{"128":1,"137":6,"153":4,"165":4,"167":4,"168":4,"169":5,"172":32,"183":2,"184":1,"196":1,"215":1,"226":1,"306":10,"338":1,"432":1,"461":3,"462":1,"463":4,"464":3,"466":2,"467":6,"469":3,"470":8,"605":1,"639":10,"655":2,"656":2,"721":1}}],["io",{"2":{"91":2,"165":2,"166":2,"276":2,"314":6,"413":2,"445":1,"502":1,"528":1,"562":1,"650":12,"667":6,"669":6,"670":6,"742":1,"743":1,"744":1,"751":3,"752":1,"761":1,"762":1,"763":1,"767":3}}],["ip=",{"2":{"791":2}}],["ip=consensus",{"2":{"344":2}}],["ip6",{"2":{"381":4}}],["ip4",{"2":{"381":8,"596":4,"791":2}}],["ipfs",{"2":{"304":1,"306":2,"310":1,"312":3,"314":22}}],["ip",{"2":{"89":2,"276":2,"277":2,"295":2,"296":2,"315":1,"366":14,"367":6,"391":2,"407":2,"412":2,"413":2,"415":2,"521":1,"523":2,"524":6,"537":11,"538":6,"539":6,"596":2,"598":2,"599":2,"600":2,"601":4,"604":2,"609":2,"614":2,"618":2,"655":2,"667":6,"670":6,"685":3,"686":6,"717":4,"726":7,"727":6,"729":6,"747":2,"748":4,"759":2,"760":2,"791":2,"792":2,"800":2}}],["irrevocably",{"2":{"31":1}}],["idvalidator",{"2":{"711":1}}],["id=$",{"2":{"718":2}}],["id=",{"2":{"561":2,"797":2,"803":2}}],["id=testnet",{"2":{"554":2,"711":2}}],["id=your",{"2":{"312":2}}],["idtopost",{"2":{"306":10}}],["ids",{"2":{"213":1,"219":2,"596":1,"605":1}}],["idaoracle",{"2":{"126":1,"127":6,"129":1,"131":1,"172":6}}],["ide",{"2":{"411":1}}],["idea",{"2":{"262":1}}],["ideas",{"2":{"41":1}}],["ideally",{"2":{"43":1}}],["ideal",{"2":{"40":1,"247":1}}],["identically",{"2":{"133":1}}],["identify",{"2":{"41":1,"48":1,"107":1,"134":2,"464":1}}],["identifying",{"2":{"31":1,"38":1}}],["identification",{"2":{"33":2}}],["identifiers",{"2":{"244":2,"464":1}}],["identifier",{"2":{"33":1,"84":1,"116":2,"117":2,"127":2,"281":2,"282":2,"306":4,"308":2}}],["identity",{"2":{"7":2,"31":1,"469":1,"488":1}}],["id",{"0":{"381":1,"540":1,"605":1,"687":1,"730":1},"2":{"27":3,"84":2,"89":4,"134":1,"151":2,"156":4,"161":4,"165":19,"166":13,"172":12,"211":4,"213":3,"215":2,"216":2,"218":1,"219":3,"220":10,"227":4,"270":1,"276":9,"277":10,"300":2,"306":12,"312":1,"313":2,"314":8,"315":1,"367":1,"376":1,"379":2,"380":2,"381":6,"382":2,"383":10,"391":4,"397":4,"403":6,"411":2,"412":2,"413":2,"444":1,"469":1,"526":1,"538":1,"540":1,"547":6,"548":14,"550":4,"551":8,"552":4,"554":8,"557":1,"561":20,"576":6,"583":3,"585":5,"596":5,"605":2,"639":6,"685":1,"687":1,"692":1,"695":4,"700":40,"711":5,"715":4,"718":4,"730":1,"765":1,"797":1}}],["ifconfig",{"2":{"718":2}}],["if",{"0":{"458":1},"2":{"4":1,"24":3,"25":1,"26":1,"27":5,"30":1,"31":4,"33":1,"34":3,"36":2,"37":1,"40":3,"41":1,"42":2,"43":1,"44":2,"45":1,"46":2,"47":3,"48":3,"76":1,"77":1,"79":2,"89":4,"103":1,"107":3,"110":2,"117":2,"126":1,"134":1,"135":1,"136":1,"137":8,"139":10,"148":2,"157":4,"160":1,"163":4,"164":2,"165":1,"169":1,"171":6,"172":4,"177":1,"178":1,"179":1,"181":1,"183":3,"187":1,"188":2,"189":1,"192":1,"194":1,"200":1,"206":1,"208":1,"210":1,"211":12,"214":1,"217":1,"219":2,"224":6,"225":1,"226":1,"234":1,"236":1,"243":1,"256":1,"262":1,"265":2,"270":2,"282":2,"295":1,"302":1,"314":2,"315":1,"316":1,"317":1,"318":1,"319":1,"322":1,"323":1,"357":1,"362":2,"364":1,"366":2,"367":1,"368":1,"370":2,"371":2,"372":1,"373":1,"374":2,"377":2,"386":1,"392":1,"393":1,"399":1,"402":1,"403":2,"405":1,"407":2,"411":1,"413":1,"414":2,"416":1,"417":1,"418":1,"424":1,"426":2,"428":1,"429":2,"431":1,"432":4,"437":26,"440":1,"441":1,"443":8,"444":1,"447":1,"449":1,"451":1,"452":1,"461":1,"463":2,"464":1,"470":3,"513":1,"515":1,"516":1,"537":2,"538":1,"548":1,"553":1,"556":3,"557":3,"559":1,"563":3,"565":1,"570":1,"573":2,"576":2,"585":1,"591":2,"593":1,"595":2,"596":1,"601":1,"604":1,"606":3,"609":1,"614":1,"616":1,"619":1,"621":1,"623":2,"624":1,"630":2,"633":2,"639":3,"641":1,"645":1,"646":2,"651":3,"658":1,"661":2,"663":1,"664":1,"665":2,"667":1,"668":1,"675":1,"676":1,"685":1,"688":1,"691":1,"692":2,"697":1,"698":2,"699":1,"704":1,"705":2,"709":1,"710":1,"714":1,"715":2,"760":1,"762":1,"772":1,"783":1,"785":3,"787":1,"788":3,"790":1,"791":1,"792":2,"797":3,"798":1,"800":1,"803":3,"808":2}}],["ini",{"2":{"617":1}}],["initcelestia",{"2":{"365":1,"373":1,"684":1,"725":1}}],["initgit",{"2":{"126":1}}],["init",{"2":{"115":5,"126":1,"280":5,"305":2,"310":3,"365":5,"373":5,"407":6,"410":2,"537":8,"542":2,"554":2,"604":3,"609":3,"616":4,"618":2,"639":6,"669":9,"684":5,"711":2,"725":5,"800":2}}],["initiatives",{"2":{"498":1,"499":2,"500":1}}],["initiated",{"2":{"33":1}}],["initially",{"2":{"783":1}}],["initialisation",{"2":{"604":1,"630":1}}],["initialise",{"2":{"524":1,"748":1}}],["initialization",{"2":{"343":1,"627":1,"633":1}}],["initializing",{"2":{"217":1,"365":1,"407":1,"537":1}}],["initializes",{"2":{"117":1,"282":1}}],["initialize",{"0":{"410":1,"537":1,"669":1,"684":1,"711":1,"725":1,"800":1},"2":{"115":1,"126":1,"264":1,"280":1,"292":1,"373":2,"410":1,"411":2,"412":3,"413":2,"542":2,"614":1,"616":1,"618":1,"633":1,"639":1,"669":1}}],["initialized",{"2":{"85":1,"126":1,"145":1,"626":1,"703":1,"710":1,"725":1}}],["initial",{"2":{"23":1,"84":1,"467":2,"494":1,"499":1,"500":1,"548":2}}],["inherently",{"2":{"490":1}}],["inherits",{"2":{"560":1}}],["inherit",{"2":{"264":1}}],["inheriting",{"2":{"230":1}}],["inability",{"2":{"454":1}}],["inappropriate",{"2":{"8":1,"9":1,"13":2,"15":1,"16":1}}],["injectedwallet",{"2":{"313":4}}],["innercontainerstyle",{"2":{"314":4}}],["innernode",{"2":{"165":12,"172":12}}],["innovative",{"2":{"265":1}}],["inputting",{"2":{"797":1,"803":1}}],["input=$",{"2":{"396":2}}],["input=3500000000000000769074a923011bdda721eacc34c8a77c69c10f2b6c8e659f987e82f217a5340f",{"2":{"396":2}}],["inputstyle",{"2":{"314":6}}],["inputs",{"2":{"127":2,"347":1}}],["input",{"0":{"299":1},"2":{"127":2,"196":3,"200":2,"203":2,"212":1,"299":3,"314":2,"351":1,"396":4,"397":2,"598":1}}],["inbox",{"2":{"98":1,"99":1,"108":1}}],["indeed",{"2":{"460":1,"469":1,"470":1}}],["independently",{"2":{"235":1,"467":1}}],["indexing",{"0":{"642":1},"2":{"453":1,"641":1,"644":1,"658":1}}],["index`",{"2":{"211":2}}],["index",{"2":{"134":2,"151":2,"153":2,"156":6,"159":8,"160":2,"161":2,"168":3,"169":2,"172":4,"181":1,"183":1,"184":3,"313":2,"314":4,"573":2,"612":2,"658":2,"805":1}}],["indexer",{"0":{"658":1,"805":1},"2":{"642":1,"644":2,"658":3,"805":1}}],["indexers",{"2":{"458":1}}],["indexed",{"2":{"129":1,"658":2}}],["indexes",{"2":{"84":1}}],["induced",{"2":{"139":1}}],["industry",{"2":{"44":1}}],["indicates",{"2":{"296":1,"391":1,"617":1}}],["indicated",{"2":{"223":1}}],["indicators",{"2":{"38":1}}],["individual",{"2":{"10":1,"16":1,"27":1,"65":1,"131":1,"306":2}}],["individuals",{"2":{"8":1,"16":1,"233":1}}],["inflation",{"0":{"495":1},"2":{"495":3,"505":2}}],["infra",{"2":{"357":1}}],["infrastructure",{"2":{"24":2,"27":1,"48":1,"91":4,"492":1,"499":1,"602":1,"754":1,"779":1}}],["infura",{"2":{"304":1,"312":6,"314":12}}],["infocurl",{"2":{"788":1}}],["infocelestia",{"2":{"381":1,"387":1}}],["infos",{"2":{"576":2}}],["informed",{"2":{"753":1,"768":1,"781":1}}],["inform",{"2":{"107":1}}],["informative",{"2":{"48":1,"63":1,"65":1}}],["information$",{"2":{"542":1}}],["information",{"0":{"28":1,"33":1,"804":1},"2":{"8":1,"30":4,"31":1,"32":1,"33":18,"34":1,"42":1,"48":2,"79":2,"85":1,"86":1,"92":1,"103":1,"107":1,"109":1,"110":1,"134":2,"135":2,"136":2,"145":1,"148":1,"151":1,"156":1,"161":1,"172":1,"181":1,"183":1,"211":1,"219":1,"242":1,"243":1,"244":1,"254":1,"270":1,"276":2,"366":1,"367":1,"381":1,"383":1,"431":1,"437":2,"453":2,"454":1,"456":1,"537":1,"538":1,"542":1,"548":1,"557":2,"559":1,"585":2,"591":1,"604":1,"667":1,"685":3,"703":1,"719":1,"726":2,"800":1}}],["informalsystems",{"2":{"562":1}}],["informal",{"2":{"37":1}}],["info",{"0":{"51":1},"1":{"52":1,"53":1,"54":1,"55":1,"56":1},"2":{"27":1,"77":1,"156":2,"319":1,"369":1,"381":1,"387":1,"456":1,"576":4,"695":2,"788":1,"797":2,"803":2}}],["intuitive",{"2":{"208":1}}],["int64",{"2":{"153":8,"165":4,"169":4,"170":4,"172":8}}],["intake",{"2":{"47":2}}],["introducing",{"2":{"468":1}}],["introduction",{"0":{"59":1,"62":1,"104":1,"174":1,"292":1,"337":1,"360":1,"468":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":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,"200":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"338":1,"339":1,"340":1,"341":1,"361":1,"362":1},"2":{"43":1,"59":2,"61":1,"62":3,"79":1,"80":1,"101":1,"105":1,"246":1,"330":1}}],["introduces",{"2":{"491":1}}],["introduced",{"2":{"440":1}}],["introduce",{"2":{"37":1,"302":1}}],["intel",{"2":{"676":1}}],["integrating",{"2":{"238":1,"329":1}}],["integrations",{"0":{"442":1,"519":1,"739":1},"1":{"443":1,"444":1,"445":1,"520":1,"521":1,"522":1,"523":1,"524":1,"740":1,"741":1,"742":1,"743":1,"744":1,"745":1,"746":1,"747":1,"748":1,"749":1,"750":1},"2":{"31":1,"288":1,"559":1}}],["integration",{"0":{"337":1,"338":1},"1":{"338":1,"339":2,"340":1,"341":1},"2":{"31":1,"73":1,"79":2,"80":1,"94":1,"101":1,"105":2,"106":2,"107":2,"108":1,"109":2,"110":1,"230":1,"246":2,"255":1,"338":1,"339":2,"341":2,"403":1,"559":1,"734":1}}],["integrate",{"0":{"123":1,"132":1,"237":1,"238":1,"329":1},"1":{"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"238":1,"239":1,"240":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1,"336":1},"2":{"237":1,"238":2,"266":1,"405":1,"559":1}}],["integrated",{"2":{"109":1}}],["integrates",{"2":{"94":1}}],["integrity",{"2":{"84":2}}],["integer",{"2":{"84":1,"116":1,"117":1,"281":1,"282":1}}],["interruptions",{"2":{"734":1}}],["inter",{"2":{"693":1}}],["interval",{"2":{"557":4,"614":4,"695":2}}],["intermediate",{"2":{"462":1,"463":1,"469":1,"470":1}}],["interfaces",{"2":{"135":2,"306":2,"311":1,"502":1,"503":1,"512":1,"655":2}}],["interface",{"0":{"129":1},"2":{"107":2,"126":1,"129":3,"131":1,"135":4,"228":1,"368":1,"466":1,"560":1,"585":2}}],["internally",{"2":{"531":1}}],["internal",{"2":{"89":5,"353":1}}],["interestingly",{"2":{"468":1}}],["interested",{"2":{"44":2,"45":3,"48":3,"302":1,"394":1}}],["interest",{"2":{"42":2,"43":1,"53":1}}],["interests",{"2":{"42":1,"47":1,"48":1}}],["interactivecelestia",{"2":{"590":1}}],["interactive",{"2":{"65":1,"590":1}}],["interactions",{"2":{"14":1,"135":1,"248":1}}],["interaction",{"2":{"14":2,"15":3,"16":1,"31":1,"37":1,"88":1,"531":1}}],["interacting",{"0":{"121":1,"286":1},"2":{"3":1,"143":1,"340":1,"352":1,"356":1,"369":2,"595":1,"605":1,"606":1}}],["interact",{"0":{"76":1,"78":1,"320":1},"2":{"7":1,"76":2,"77":1,"120":1,"131":1,"145":1,"240":1,"248":1,"250":1,"276":2,"277":2,"285":1,"318":2,"319":1,"333":1,"352":1,"368":1,"369":2,"370":1,"371":1,"372":2,"673":1,"721":1,"761":1,"762":1,"763":1}}],["intensive",{"2":{"645":1}}],["intended",{"2":{"301":1}}],["intend",{"2":{"34":1}}],["intent",{"2":{"34":1}}],["intention",{"2":{"34":1}}],["into",{"0":{"456":1},"2":{"23":1,"26":1,"59":1,"69":1,"75":1,"87":1,"91":1,"94":1,"107":1,"108":1,"109":1,"146":2,"148":1,"217":1,"223":1,"230":1,"270":1,"311":3,"314":2,"318":1,"362":1,"413":2,"428":1,"461":2,"463":1,"464":2,"467":1,"469":5,"488":3,"545":1,"555":1,"559":1,"568":1,"593":1,"598":1,"605":1,"614":1,"621":1,"624":1,"691":1,"696":1,"734":1}}],["inception",{"2":{"733":1}}],["incentive",{"2":{"470":1}}],["incentives",{"2":{"43":1,"457":1}}],["incentivizes",{"2":{"459":1}}],["incentivize",{"0":{"457":1},"2":{"457":1}}],["incentivized",{"0":{"30":1},"1":{"31":1,"32":1,"33":1,"34":1},"2":{"30":1,"499":1}}],["incurred",{"2":{"292":1,"300":1}}],["incubators",{"2":{"40":1}}],["increment",{"2":{"116":3,"117":4,"281":3,"282":4}}],["incredible",{"2":{"50":1}}],["increased",{"2":{"91":2}}],["increases",{"2":{"45":1,"84":1,"116":1,"117":1,"281":1,"282":1,"450":1,"468":1}}],["increase",{"2":{"44":1,"45":1,"467":1,"468":1,"556":2,"617":1}}],["increasing",{"2":{"42":1,"462":1,"468":1,"617":1}}],["incomplete",{"2":{"464":1}}],["incoming",{"2":{"420":2}}],["income",{"2":{"34":1}}],["incorrectly",{"0":{"463":1},"2":{"451":1,"452":1,"463":2}}],["incorrect",{"2":{"89":1,"288":1,"452":1}}],["incorporate",{"2":{"30":1}}],["incident",{"2":{"11":1,"14":1}}],["inclusion",{"0":{"131":1,"141":1,"150":1,"154":1,"155":1,"158":1,"160":1,"184":1},"1":{"151":1,"152":1,"156":1,"157":1,"159":1,"161":1,"162":1},"2":{"46":1,"126":1,"128":2,"129":1,"131":4,"134":1,"136":3,"141":1,"146":1,"148":1,"150":1,"151":1,"153":2,"155":1,"156":2,"160":1,"164":1,"165":1,"169":1,"172":1,"173":1,"177":3,"178":2,"183":2,"184":7,"197":1,"200":1,"208":2,"236":2,"440":1}}],["inclusive",{"2":{"7":1,"52":1,"225":1}}],["including",{"2":{"14":1,"15":2,"16":1,"27":1,"31":1,"33":2,"34":4,"36":3,"37":1,"47":1,"52":1,"65":1,"84":1,"86":1,"92":1,"351":1,"430":1,"499":1,"797":1}}],["included",{"2":{"129":2,"136":2,"137":3,"146":1,"169":2,"181":1,"183":1,"192":1,"236":1,"306":1,"324":2,"374":1,"376":1,"377":1,"419":2,"426":2,"432":3,"436":2,"439":1,"440":1,"441":1,"488":1,"738":1}}],["includes",{"2":{"14":1,"57":1,"58":1,"85":1,"94":1,"109":1,"117":1,"282":1,"335":1,"456":1,"464":1,"488":1,"500":1,"692":1,"694":1,"716":1}}],["include",{"2":{"8":2,"10":1,"30":3,"44":1,"181":1,"225":1,"237":1,"266":1,"306":1,"370":1,"398":1,"458":1,"488":1,"558":1,"717":1}}],["invocations",{"2":{"651":1,"803":1}}],["invoke",{"2":{"306":2}}],["involves",{"2":{"429":1,"455":1}}],["involve",{"2":{"135":2,"136":1}}],["involvement",{"2":{"43":1}}],["involved",{"2":{"14":1,"15":1,"199":1,"338":1,"429":1,"430":1}}],["involving",{"2":{"34":1}}],["investigations",{"2":{"194":1}}],["investigate",{"2":{"42":1,"44":1}}],["investigated",{"2":{"11":1,"179":1,"192":1,"202":1}}],["invalid",{"0":{"661":1,"808":1},"2":{"136":2,"139":2,"172":4,"183":1,"188":2,"192":2,"419":2,"420":2,"463":2,"470":1,"614":2,"661":2,"808":2}}],["invites",{"2":{"54":1}}],["invite",{"2":{"43":2,"45":2}}],["invitations",{"2":{"36":1}}],["invitation",{"2":{"34":2,"53":1}}],["invisible",{"2":{"7":1}}],["inspect",{"2":{"447":1}}],["inspired",{"2":{"17":1,"187":1,"211":1}}],["insecure",{"2":{"437":4}}],["inside",{"0":{"200":1},"2":{"181":2,"196":1,"197":1,"200":2,"202":1,"203":3,"205":1,"268":1,"270":1,"411":1,"416":1,"539":1,"593":1,"686":1,"715":1,"716":1,"717":1,"729":1}}],["insight",{"2":{"555":1}}],["insightful",{"2":{"50":1}}],["insights",{"2":{"5":1,"38":1,"43":1,"65":1,"562":1}}],["instrumentation",{"2":{"556":6}}],["instructions",{"0":{"219":1},"2":{"209":1,"220":2,"223":1,"226":1,"227":1,"402":1,"403":1,"423":1,"424":1,"538":1,"564":1,"565":1,"576":1,"594":1,"622":1,"624":1,"637":1,"665":3,"673":1,"675":2,"685":1,"754":2,"795":1,"803":1,"805":1}}],["instead",{"2":{"102":1,"108":1,"135":1,"139":3,"170":4,"171":4,"172":4,"185":1,"203":1,"288":1,"338":1,"376":1,"428":3,"432":1,"491":1,"508":1}}],["instability",{"2":{"734":1,"774":1}}],["instantaneous",{"2":{"689":1}}],["instantiation",{"0":{"705":1},"1":{"706":1,"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1}}],["instantiating",{"2":{"103":1,"310":1,"365":1}}],["instantiate",{"0":{"365":1,"719":1},"2":{"365":1,"467":1,"705":1}}],["instance",{"2":{"69":1,"75":1,"90":2,"117":1,"223":1,"224":1,"244":1,"282":1,"318":1,"424":1,"533":1,"557":1,"597":1,"616":1,"636":1,"680":1,"723":1,"795":1}}],["instances",{"2":{"11":1}}],["installer",{"2":{"665":1}}],["installed",{"2":{"114":1,"125":1,"211":1,"217":1,"275":1,"279":1,"291":1,"406":1,"443":1,"569":1,"580":1,"589":1,"593":1,"623":1,"626":1,"662":1,"676":2,"694":1,"695":1}}],["installmake",{"2":{"593":1,"621":1}}],["installs",{"2":{"269":2,"621":1}}],["installation",{"0":{"269":1,"708":1},"2":{"267":1,"310":1,"594":2,"622":2}}],["installing",{"0":{"126":1,"594":1,"621":1,"622":1},"2":{"534":1,"536":1,"592":1,"594":1,"621":1,"622":1,"637":1,"638":1,"665":1,"673":1,"675":2,"682":1,"724":1,"782":1,"785":1,"799":1}}],["install",{"0":{"407":1,"536":1,"592":1,"620":1,"638":1,"675":1,"676":1,"682":1,"724":1,"799":1},"1":{"593":1,"594":1,"595":1,"621":1,"622":1,"623":1,"624":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1},"2":{"87":2,"126":3,"212":2,"219":2,"269":2,"311":1,"312":3,"316":1,"322":1,"364":1,"368":1,"407":1,"417":1,"443":2,"536":1,"557":1,"559":1,"564":1,"566":1,"589":1,"593":3,"594":1,"621":3,"622":1,"624":1,"665":1,"675":15,"676":2,"694":1,"708":1,"724":1,"783":1,"784":1,"785":1,"788":2,"790":2,"791":2,"792":2}}],["insulting",{"2":{"8":1}}],["in",{"0":{"66":1,"67":1,"110":1,"163":1,"213":1,"294":1,"296":1,"432":1,"449":1,"491":1,"616":1,"701":1,"773":1},"1":{"67":1,"68":2,"69":2,"70":1,"71":1,"72":1,"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"214":1,"215":1,"216":1,"774":1,"775":1,"776":1,"777":1,"778":1,"779":1,"780":1,"781":1},"2":{"3":1,"4":2,"5":1,"7":2,"8":1,"9":1,"10":1,"12":2,"13":1,"14":1,"19":1,"21":1,"23":6,"24":6,"25":3,"27":2,"29":1,"30":10,"31":17,"32":3,"33":3,"34":41,"35":1,"37":1,"38":1,"39":1,"40":2,"41":4,"42":3,"43":2,"44":6,"45":7,"46":4,"48":7,"50":2,"52":2,"53":2,"54":1,"56":1,"60":1,"61":1,"65":4,"66":2,"68":3,"69":4,"71":3,"72":3,"75":3,"76":4,"77":1,"82":1,"83":2,"84":12,"85":4,"86":1,"87":1,"88":5,"89":10,"91":10,"92":3,"93":1,"94":1,"95":1,"102":4,"105":1,"106":1,"107":7,"108":10,"109":1,"110":3,"111":1,"113":1,"115":1,"116":4,"117":8,"122":1,"128":2,"129":2,"130":1,"131":2,"134":13,"135":3,"136":12,"137":4,"139":1,"145":3,"146":8,"148":9,"149":1,"150":1,"159":2,"161":3,"162":2,"164":3,"165":13,"166":1,"167":1,"168":9,"169":8,"170":2,"171":1,"173":2,"174":1,"175":2,"176":1,"177":3,"178":4,"180":3,"181":4,"182":1,"183":9,"184":9,"188":2,"189":1,"191":2,"192":5,"193":1,"194":1,"195":1,"196":3,"197":1,"199":1,"200":2,"203":1,"206":2,"208":5,"210":1,"211":7,"212":3,"213":5,"214":1,"217":6,"219":6,"220":16,"222":2,"223":2,"224":7,"225":3,"226":2,"228":1,"230":2,"233":1,"235":1,"236":5,"237":1,"239":1,"242":2,"243":1,"244":1,"246":2,"247":1,"250":1,"262":1,"264":1,"265":2,"266":2,"268":1,"269":4,"270":2,"271":1,"276":3,"277":3,"278":1,"280":1,"281":4,"282":8,"288":4,"292":2,"295":1,"302":2,"306":6,"309":2,"310":3,"311":2,"312":1,"317":1,"318":7,"319":1,"323":1,"324":1,"325":5,"326":6,"331":1,"332":1,"333":4,"336":2,"338":3,"341":1,"344":1,"347":1,"351":1,"352":1,"357":1,"359":1,"362":1,"365":1,"366":2,"367":2,"369":3,"370":1,"371":1,"372":1,"373":1,"374":4,"376":4,"377":1,"381":2,"382":1,"386":6,"389":1,"391":3,"394":1,"398":2,"399":1,"401":2,"403":1,"404":1,"405":1,"407":5,"408":1,"410":1,"411":1,"413":3,"418":1,"419":1,"420":4,"423":1,"424":5,"426":5,"427":1,"428":3,"429":4,"430":4,"431":2,"432":2,"433":1,"435":1,"438":1,"439":2,"440":1,"441":1,"443":2,"444":2,"445":2,"449":2,"452":1,"454":1,"455":1,"456":1,"457":1,"460":1,"461":4,"462":3,"464":1,"467":9,"468":1,"469":3,"470":3,"471":1,"474":1,"475":1,"479":1,"488":1,"489":2,"490":3,"491":3,"492":4,"494":1,"495":2,"498":1,"499":1,"500":2,"505":1,"507":1,"508":3,"509":2,"510":1,"512":1,"513":1,"516":2,"519":2,"520":1,"521":2,"524":2,"531":3,"537":1,"539":1,"540":1,"545":1,"548":4,"549":2,"554":2,"557":3,"558":1,"563":3,"565":1,"569":1,"571":1,"573":3,"576":1,"577":1,"578":1,"580":2,"583":1,"585":1,"586":1,"590":1,"593":1,"594":2,"596":1,"597":1,"598":1,"601":2,"602":3,"606":1,"608":4,"609":2,"611":1,"614":1,"616":2,"617":4,"618":1,"621":1,"622":2,"627":1,"630":1,"631":1,"633":1,"634":1,"639":7,"641":1,"643":1,"644":1,"645":2,"646":2,"649":3,"656":1,"658":2,"659":6,"661":2,"663":2,"664":1,"665":2,"669":3,"673":1,"676":1,"685":1,"686":1,"687":1,"689":2,"690":2,"691":3,"692":2,"693":2,"694":1,"697":2,"698":5,"709":1,"710":1,"711":1,"714":3,"715":2,"716":2,"718":1,"725":1,"726":1,"727":2,"728":1,"729":1,"730":1,"733":2,"737":1,"738":6,"739":4,"740":1,"750":1,"754":3,"758":1,"760":1,"762":1,"763":1,"764":1,"769":2,"776":1,"779":1,"782":2,"783":2,"785":4,"788":3,"792":2,"793":2,"797":2,"803":3,"808":2}}],["imagine",{"2":{"266":1}}],["image",{"2":{"102":1,"276":3,"277":6,"445":1,"667":1}}],["imagery",{"2":{"8":1}}],["images",{"2":{"3":1,"445":1}}],["immutable",{"2":{"84":2,"127":2}}],["improperly",{"2":{"451":1}}],["improve",{"2":{"47":1}}],["improvement",{"2":{"38":1,"462":1}}],["improvements",{"2":{"4":1,"734":1}}],["improved",{"2":{"29":1,"230":1,"555":1}}],["improves",{"2":{"24":1}}],["improving",{"2":{"2":1}}],["impractical",{"2":{"447":1}}],["imported",{"2":{"316":1}}],["importing",{"0":{"272":1,"350":1,"545":1},"2":{"170":2,"171":2,"172":2,"596":1}}],["import",{"0":{"411":1},"2":{"117":4,"127":6,"152":2,"153":4,"159":1,"170":4,"171":4,"172":10,"272":1,"282":4,"306":4,"308":4,"313":19,"314":17,"316":2,"324":1,"350":2,"411":4,"431":1,"436":1,"437":1,"443":7,"531":1,"545":5,"557":2,"596":1,"696":1}}],["importance",{"2":{"65":1}}],["important",{"0":{"51":1},"1":{"52":1,"53":1,"54":1,"55":1,"56":1},"2":{"24":1,"28":1,"30":1,"108":1,"134":2,"430":1,"439":1,"466":1,"557":1,"558":1,"573":2,"605":1,"690":1}}],["impose",{"2":{"34":1}}],["implement",{"2":{"416":1,"467":1,"492":2}}],["implements",{"2":{"107":1}}],["implementations",{"0":{"231":1},"2":{"135":2,"693":1}}],["implementation",{"0":{"107":1,"108":1,"109":1,"241":1,"294":1},"1":{"242":1,"243":1,"244":1},"2":{"33":1,"106":3,"131":1,"133":1,"172":4,"230":3,"231":1,"235":1,"236":2,"242":1,"351":1,"369":1,"423":1,"531":1,"691":1,"694":1}}],["implemented",{"2":{"31":1,"173":1,"424":1,"491":4,"762":1}}],["impactful",{"2":{"43":1,"65":1}}],["impact",{"2":{"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"27":1,"44":1}}],["itrocket",{"2":{"742":1,"743":1,"744":1,"745":1,"748":1,"751":1,"752":1,"760":1,"761":1,"762":1,"763":1,"767":1}}],["ith",{"2":{"430":2}}],["item",{"2":{"415":1}}],["items",{"2":{"412":1,"413":1}}],["itemcount",{"2":{"306":6}}],["itn",{"2":{"30":7,"31":11,"32":3,"33":1,"34":38}}],["itself",{"2":{"30":1,"94":1,"557":2}}],["its",{"2":{"19":2,"27":2,"30":3,"34":1,"84":4,"85":2,"108":1,"148":1,"156":1,"158":1,"165":2,"166":2,"172":2,"175":1,"177":1,"181":1,"183":1,"187":1,"191":1,"192":1,"196":1,"208":1,"211":1,"218":1,"219":1,"234":1,"235":1,"255":2,"379":1,"416":1,"428":1,"429":1,"449":1,"450":1,"464":2,"467":1,"501":1,"509":1,"557":1,"617":1,"733":1,"788":1,"790":1,"791":1,"792":1}}],["it",{"0":{"316":1,"317":1},"2":{"2":2,"24":1,"30":1,"34":1,"35":1,"41":1,"42":1,"47":2,"48":1,"53":1,"69":1,"75":1,"76":1,"84":5,"86":2,"88":1,"89":3,"90":1,"102":1,"107":6,"108":1,"110":1,"116":1,"117":5,"120":2,"128":1,"129":1,"131":6,"133":1,"135":2,"139":2,"145":1,"146":2,"148":2,"150":2,"160":2,"164":2,"166":2,"169":1,"172":2,"174":1,"177":1,"179":1,"181":1,"183":2,"188":1,"191":1,"192":1,"196":2,"203":1,"208":1,"211":10,"212":4,"213":3,"217":1,"219":8,"220":2,"223":4,"224":5,"225":1,"226":1,"227":1,"228":1,"235":1,"236":2,"242":1,"243":3,"244":1,"246":1,"247":2,"250":1,"261":1,"264":1,"267":1,"269":1,"281":1,"282":5,"285":2,"290":1,"294":1,"306":3,"308":1,"309":3,"310":2,"311":2,"314":4,"316":1,"318":2,"324":2,"336":1,"338":1,"351":1,"355":1,"357":1,"366":2,"369":1,"374":1,"383":2,"392":2,"393":1,"395":1,"396":1,"403":1,"405":1,"407":3,"408":1,"413":7,"414":3,"415":1,"416":2,"426":2,"429":2,"430":4,"432":4,"436":2,"437":2,"440":1,"441":1,"443":4,"447":5,"450":2,"451":1,"456":1,"457":1,"463":1,"464":1,"467":1,"468":1,"469":5,"470":1,"492":2,"495":1,"516":5,"537":2,"538":1,"555":1,"556":2,"557":6,"558":1,"559":1,"563":1,"569":1,"573":2,"576":1,"587":1,"590":1,"594":1,"595":1,"598":1,"601":2,"604":1,"605":1,"606":1,"613":1,"614":2,"616":2,"617":1,"619":1,"622":1,"623":1,"646":1,"650":1,"654":1,"655":2,"659":1,"661":1,"663":1,"668":2,"685":2,"690":1,"693":1,"694":2,"696":1,"697":1,"704":1,"714":1,"716":2,"717":1,"725":1,"733":1,"734":1,"738":1,"754":1,"760":1,"774":1,"777":1,"779":1,"785":1,"788":2,"797":1,"798":2,"808":1}}],["issuing",{"2":{"508":1}}],["issuance",{"2":{"495":2}}],["issued",{"2":{"34":1}}],["issues",{"2":{"9":1,"60":1,"89":1,"339":1,"403":3,"624":1}}],["issue",{"2":{"4":1,"91":1,"432":1,"454":1,"495":1,"508":1,"694":1,"772":2}}],["isn",{"2":{"139":1,"424":1,"738":1}}],["isvalid",{"2":{"139":2}}],["isolated",{"2":{"665":1}}],["isolates",{"2":{"265":1}}],["isolate",{"2":{"135":1}}],["is",{"0":{"230":1,"236":1,"242":1,"261":1,"262":1,"447":1,"448":1,"450":1,"452":1,"453":1,"454":1,"455":1,"458":1},"1":{"231":1},"2":{"1":1,"5":1,"8":1,"10":1,"15":1,"17":1,"21":1,"22":1,"24":1,"26":1,"27":2,"30":5,"31":3,"33":1,"34":7,"35":1,"37":1,"40":1,"43":1,"44":1,"45":2,"47":3,"48":1,"49":1,"52":1,"53":2,"55":2,"56":1,"57":1,"59":1,"60":2,"61":2,"65":3,"71":1,"82":1,"83":3,"84":8,"85":1,"86":3,"88":3,"89":7,"91":10,"92":1,"94":2,"106":3,"107":7,"108":2,"109":1,"110":2,"117":7,"126":2,"127":2,"128":3,"129":2,"131":6,"133":3,"134":30,"135":5,"136":6,"137":6,"139":6,"143":1,"145":1,"146":3,"148":5,"150":2,"154":1,"156":2,"157":1,"158":2,"159":1,"160":1,"161":1,"162":1,"164":2,"165":5,"166":3,"168":2,"169":12,"172":6,"173":1,"174":1,"176":1,"177":1,"178":1,"181":3,"182":1,"183":9,"184":12,"187":3,"188":6,"189":1,"192":9,"194":1,"195":1,"196":6,"197":1,"200":6,"202":1,"203":4,"206":1,"208":6,"211":13,"213":2,"214":2,"217":3,"219":4,"220":6,"221":2,"222":1,"223":8,"224":7,"227":1,"228":1,"230":4,"233":1,"234":2,"235":2,"236":3,"242":2,"243":3,"244":1,"245":2,"246":3,"250":1,"251":1,"261":1,"262":1,"264":2,"265":1,"267":1,"268":1,"282":7,"288":3,"292":1,"294":1,"301":1,"303":2,"306":4,"307":1,"308":2,"309":1,"310":3,"312":1,"314":3,"316":1,"323":1,"329":1,"331":2,"333":1,"334":1,"335":1,"336":3,"337":2,"338":8,"339":1,"341":1,"352":1,"355":1,"356":1,"357":2,"361":1,"365":1,"366":1,"367":1,"369":5,"370":2,"371":2,"372":1,"373":3,"374":3,"376":3,"377":2,"379":1,"380":1,"381":2,"382":1,"383":1,"386":2,"393":1,"394":1,"401":2,"402":1,"403":1,"407":2,"411":1,"413":5,"415":2,"418":1,"423":1,"426":4,"428":4,"429":4,"430":14,"431":2,"432":2,"437":8,"439":2,"440":1,"441":1,"443":5,"447":2,"448":3,"449":1,"450":3,"451":6,"452":3,"453":2,"454":2,"455":2,"456":3,"457":3,"459":1,"460":2,"461":6,"463":7,"464":8,"466":7,"467":3,"468":3,"469":5,"470":9,"471":1,"477":1,"481":1,"486":1,"488":2,"490":5,"491":3,"492":4,"494":1,"500":3,"507":1,"508":1,"512":1,"513":4,"514":1,"515":4,"516":1,"519":1,"526":1,"527":1,"531":5,"533":1,"537":1,"538":4,"541":1,"548":3,"555":1,"557":5,"559":2,"560":1,"563":6,"564":1,"571":3,"573":2,"576":1,"577":1,"578":1,"585":2,"590":1,"594":2,"595":2,"596":1,"597":1,"599":1,"600":1,"601":2,"604":2,"605":4,"606":2,"608":1,"609":1,"611":1,"613":1,"614":3,"616":2,"617":2,"618":2,"619":1,"621":2,"622":2,"628":1,"630":1,"631":2,"633":4,"636":1,"639":3,"641":1,"643":2,"645":1,"646":2,"648":1,"651":2,"656":3,"658":7,"659":1,"661":1,"663":1,"664":1,"665":3,"667":2,"668":1,"673":2,"676":1,"677":1,"680":1,"685":3,"689":1,"690":3,"692":1,"693":1,"694":4,"697":3,"703":1,"704":1,"705":1,"711":2,"713":1,"714":1,"718":2,"721":1,"726":1,"728":1,"733":2,"734":2,"738":7,"739":2,"749":1,"750":1,"754":4,"761":2,"762":3,"763":3,"765":1,"774":2,"777":2,"779":1,"784":1,"785":2,"786":1,"788":3,"791":1,"792":1,"795":1,"798":3,"802":1,"803":3,"808":1}}],["lcd",{"2":{"743":2}}],["l5dhzjldczo",{"2":{"573":2,"574":2}}],["ljj6hspn0kn09qf9fy8kdyh40000gn",{"2":{"569":4}}],["luckily",{"2":{"454":1,"457":1}}],["lumina",{"2":{"417":1}}],["lunaroasis",{"2":{"366":2,"727":2,"742":1,"743":1,"744":1,"748":1}}],["ls",{"2":{"223":2,"224":2}}],["ldflags",{"2":{"223":2}}],["lfg",{"2":{"91":2}}],["l1",{"0":{"403":1},"2":{"82":2,"84":1,"91":8,"119":3,"395":1,"396":1,"403":4,"448":1}}],["l2genesisdeltatimeoffset",{"2":{"398":1}}],["l2s",{"2":{"110":1,"230":2,"235":1,"288":2,"338":1}}],["l2",{"0":{"88":1,"403":1},"2":{"77":1,"82":1,"84":2,"85":1,"86":1,"91":6,"109":1,"113":1,"119":4,"120":2,"129":1,"131":1,"230":1,"234":2,"238":1,"288":1,"319":1,"337":1,"403":2,"448":2}}],["lts",{"2":{"334":1,"533":1,"636":1,"680":1,"723":1,"795":1}}],["lt",{"2":{"69":1,"75":2,"76":2,"89":8,"137":2,"145":3,"151":1,"153":4,"156":1,"157":2,"159":7,"161":1,"170":4,"171":6,"212":8,"213":30,"215":4,"216":4,"218":6,"224":4,"225":1,"242":1,"270":13,"271":12,"272":12,"276":5,"277":8,"293":4,"300":4,"306":2,"309":2,"310":2,"313":14,"314":100,"318":4,"325":6,"326":6,"366":6,"367":21,"369":6,"371":6,"372":4,"374":8,"376":8,"380":2,"383":4,"386":6,"388":4,"395":1,"412":6,"413":6,"415":12,"434":4,"435":4,"443":14,"524":6,"526":3,"537":8,"538":4,"539":12,"544":8,"545":6,"546":8,"547":18,"548":20,"549":4,"550":6,"551":16,"552":4,"553":6,"554":2,"557":2,"585":4,"596":10,"598":10,"599":4,"600":4,"601":16,"604":10,"609":10,"614":8,"615":4,"616":8,"618":9,"670":2,"685":4,"686":12,"696":4,"727":6,"728":3,"729":12,"748":6,"765":3,"788":4,"790":4,"791":6,"792":6,"797":4,"800":2,"803":2}}],["l3s",{"2":{"110":1,"230":1,"288":1}}],["l3configuration",{"2":{"91":2}}],["l3",{"2":{"66":1,"69":1,"71":1,"86":2,"91":6}}],["living",{"2":{"737":1}}],["lives",{"2":{"48":1,"108":1,"571":1}}],["live",{"2":{"46":4,"68":1,"308":1,"309":1,"341":1,"403":1,"571":1,"734":1}}],["life",{"2":{"488":1,"733":1}}],["lifecycle",{"0":{"469":1},"1":{"470":1}}],["libp2p",{"2":{"470":1,"531":1}}],["libssl",{"2":{"675":4}}],["libs",{"2":{"172":2}}],["library",{"0":{"163":1,"322":1,"354":1,"417":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"323":1,"324":1,"325":1,"326":1,"327":1,"328":1,"418":1,"419":1,"420":1,"421":1,"422":1},"2":{"131":3,"163":1,"172":2,"183":1,"192":1,"200":1,"306":1,"311":2,"322":1,"348":1,"354":1,"355":1,"417":1}}],["libraries",{"2":{"40":2,"197":1,"311":1,"332":1,"334":1,"335":1,"411":1,"782":1}}],["lib",{"2":{"127":2,"131":1,"172":2}}],["lightdsudo",{"2":{"792":2}}],["lightd",{"2":{"792":13}}],["lightbridgefull",{"2":{"667":1}}],["light$home",{"2":{"401":1}}],["light",{"0":{"60":1,"89":1,"142":1,"365":1,"401":1,"407":1,"435":1,"611":1,"612":1,"618":1,"668":1,"720":1,"721":1,"723":1,"725":1,"726":1,"729":1,"731":1,"757":1,"792":1},"1":{"619":1,"669":1,"670":1,"721":1,"722":1,"723":1,"724":2,"725":1,"726":1,"727":2,"728":2,"729":2,"730":3,"731":2,"732":1,"758":1,"759":1,"760":1},"2":{"60":7,"80":1,"89":7,"109":1,"135":9,"142":1,"143":1,"230":2,"236":2,"265":1,"268":1,"270":2,"271":2,"272":2,"276":5,"277":10,"291":1,"293":1,"295":2,"296":4,"297":2,"304":1,"336":1,"344":2,"349":2,"357":1,"363":1,"365":8,"366":14,"367":12,"371":3,"372":3,"373":12,"374":1,"391":3,"401":7,"406":1,"407":10,"431":1,"449":1,"450":4,"451":6,"452":2,"460":1,"461":5,"462":8,"463":3,"468":2,"470":9,"491":6,"521":1,"524":3,"531":1,"537":1,"597":2,"602":1,"608":1,"611":1,"612":1,"615":3,"618":7,"619":1,"623":1,"627":2,"633":6,"649":2,"663":3,"669":6,"670":6,"678":2,"685":1,"720":1,"721":2,"722":1,"725":6,"726":7,"727":12,"729":9,"730":3,"731":1,"732":1,"746":1,"748":1,"749":2,"754":1,"769":2,"771":1,"783":2,"785":2,"791":1,"792":7}}],["lightning",{"2":{"48":1,"337":1}}],["lisbon",{"2":{"50":1}}],["listcelestia",{"2":{"581":1,"590":1}}],["listing",{"2":{"544":2}}],["listed",{"2":{"424":1,"521":1,"692":1,"740":1,"742":1,"758":1}}],["listens",{"2":{"655":1}}],["listeners",{"2":{"306":2}}],["listen",{"2":{"228":1,"470":1,"556":4,"557":1,"655":1,"721":1}}],["listening",{"0":{"171":1},"2":{"171":1,"655":1}}],["list",{"0":{"65":1,"574":1},"2":{"27":2,"31":1,"36":1,"42":1,"43":2,"56":2,"65":6,"84":1,"107":3,"127":2,"165":2,"168":2,"212":1,"214":1,"215":2,"220":1,"227":1,"276":3,"277":3,"328":1,"367":2,"422":1,"461":1,"484":1,"497":1,"537":2,"538":2,"544":2,"548":1,"556":2,"574":2,"581":2,"590":1,"609":2,"639":2,"685":4,"695":4,"701":4,"717":2,"727":2,"739":1,"754":1,"800":3,"803":1}}],["lines",{"2":{"553":2}}],["linear",{"2":{"430":1}}],["line",{"0":{"561":1},"2":{"366":1,"368":1,"537":1,"560":1,"585":1,"616":1,"628":1,"659":1,"667":1,"717":1}}],["lineup",{"2":{"43":1}}],["linuxdocker",{"2":{"668":1}}],["linux",{"2":{"89":1,"334":1,"533":1,"594":1,"622":1,"636":1,"666":1,"673":1,"676":12,"680":1,"723":1,"795":1}}],["linked",{"2":{"142":1}}],["link",{"2":{"33":1,"240":1,"413":2,"519":1,"557":2,"558":1,"739":1,"754":1}}],["links",{"2":{"27":2,"54":1,"64":1,"145":1}}],["little",{"2":{"40":1,"85":1,"336":1,"715":1}}],["liechtenstein",{"2":{"34":3}}],["license",{"2":{"33":1,"116":2,"117":2,"127":2,"281":2,"282":2,"306":4,"308":2}}],["limitnofile=65535",{"2":{"788":2}}],["limitnofile=1400000",{"2":{"617":2,"790":2,"791":2}}],["limitnofile",{"2":{"617":2}}],["limit=fc+∑i=1nssn",{"2":{"430":1}}],["limit×gas",{"2":{"430":1}}],["limits",{"0":{"428":1},"1":{"429":1,"430":1,"431":1},"2":{"377":1,"467":1,"556":2,"617":1}}],["limit",{"2":{"295":2,"300":2,"374":1,"377":1,"386":1,"428":2,"430":4,"431":1,"437":2,"526":1,"576":2,"617":1,"738":1,"765":1}}],["limited",{"2":{"33":1,"34":2,"331":1,"462":2,"468":1,"548":1}}],["limitations",{"2":{"180":1}}],["limitation",{"2":{"31":1}}],["liable",{"2":{"31":2,"33":1}}],["liability",{"2":{"30":1,"31":2}}],["likely",{"2":{"135":5,"336":2,"458":1,"614":1,"661":1,"808":1}}],["likelihood",{"2":{"45":1,"470":1}}],["like",{"2":{"14":1,"36":1,"40":2,"41":1,"46":1,"47":2,"48":1,"80":1,"82":1,"84":2,"89":1,"90":1,"102":1,"133":1,"134":1,"139":1,"211":3,"224":2,"256":1,"261":1,"262":2,"265":2,"276":1,"277":1,"302":3,"323":1,"357":2,"362":1,"366":1,"367":1,"373":1,"376":1,"383":2,"386":3,"392":1,"393":1,"395":1,"399":1,"407":1,"418":1,"443":1,"447":1,"448":1,"450":1,"456":1,"459":1,"494":1,"509":1,"519":1,"529":1,"539":1,"557":1,"565":1,"566":1,"570":1,"576":3,"596":2,"601":1,"606":1,"609":1,"616":1,"617":1,"619":1,"651":1,"661":1,"665":1,"667":2,"675":1,"686":1,"688":1,"692":1,"697":1,"729":1,"734":1,"739":1,"753":1,"754":2,"768":1,"781":1,"783":1,"808":1}}],["laddr",{"2":{"595":1}}],["ladder",{"2":{"17":1}}],["lang",{"2":{"585":2}}],["languages",{"2":{"145":1,"173":1}}],["language",{"2":{"8":1,"13":1}}],["lag",{"2":{"516":1}}],["laid",{"2":{"200":1,"203":1}}],["latter",{"2":{"196":1,"468":1}}],["latency",{"2":{"695":4}}],["latestblock",{"2":{"237":1,"242":5}}],["latestblocknumber",{"2":{"153":4,"170":4}}],["latestrollupheight",{"2":{"135":2,"137":6}}],["latest",{"2":{"93":1,"94":1,"102":1,"135":2,"149":1,"225":2,"230":1,"236":5,"242":1,"276":2,"331":1,"395":2,"421":6,"423":1,"448":1,"492":2,"515":1,"516":2,"580":1,"593":6,"594":1,"621":6,"622":1,"624":1,"661":1,"667":6,"669":6,"670":6,"685":1,"693":1,"777":1,"808":1}}],["later",{"2":{"40":1,"224":1,"309":1,"311":1,"454":1,"469":1,"470":1,"593":1,"712":1,"783":1,"785":1}}],["large",{"2":{"180":1,"226":1,"316":1,"336":2}}],["larger",{"2":{"40":1,"42":1,"336":1,"462":1,"556":2}}],["layout",{"2":{"136":1,"146":2,"177":1}}],["layers",{"2":{"460":2,"466":1,"467":7,"490":2}}],["layer",{"0":{"460":1},"1":{"461":1,"462":1,"463":1,"464":1,"465":1,"466":1},"2":{"89":1,"105":2,"109":1,"187":2,"230":1,"236":1,"245":1,"246":1,"247":1,"261":3,"262":3,"288":1,"330":1,"333":1,"338":5,"340":1,"359":1,"361":1,"460":3,"462":2,"464":4,"466":4,"467":6,"469":1,"470":1,"488":1,"508":1,"530":2,"531":1,"634":1,"692":1,"784":2}}],["label",{"2":{"557":2,"703":1}}],["labels",{"2":{"557":4}}],["labeled",{"2":{"53":1}}],["labs",{"2":{"24":1,"30":1,"43":2,"44":2,"45":2,"46":5,"47":10,"65":1,"79":2,"91":1,"245":1,"499":1,"515":1,"690":1}}],["lastly",{"2":{"557":1}}],["lastblock",{"2":{"137":6}}],["last",{"2":{"27":1,"30":1,"41":1,"43":1,"217":1,"225":1,"383":6,"415":1,"553":2,"563":1}}],["laws",{"2":{"34":11}}],["law",{"2":{"25":1,"34":1}}],["launching",{"2":{"42":1}}],["launch",{"0":{"21":1,"86":1},"2":{"85":1,"86":1,"246":1,"468":1,"500":2,"508":1}}],["lemongrass",{"0":{"692":1},"2":{"529":1,"692":3,"753":1,"768":1,"781":1}}],["lemonade",{"2":{"41":1}}],["ledger",{"2":{"211":2,"447":1}}],["len",{"2":{"137":8,"139":6,"153":2,"165":4,"167":2,"168":4,"169":2,"172":12,"325":2,"326":2,"412":2,"413":2,"415":2,"419":2,"420":2,"437":4}}],["length",{"2":{"134":2,"306":6}}],["left",{"2":{"135":1,"188":2,"196":1,"200":1,"203":1,"457":1}}],["lets",{"2":{"265":1}}],["let",{"2":{"47":3,"85":1,"120":1,"131":1,"284":1,"303":1,"306":2,"308":1,"312":1,"314":2,"316":1,"324":2,"365":1,"366":1,"369":1,"379":1,"380":1,"383":1,"405":1,"407":1,"412":1,"419":12,"420":12,"421":4,"436":2,"627":1}}],["leveraging",{"2":{"303":1,"700":1}}],["leverages",{"2":{"127":1}}],["leverage",{"2":{"43":1,"44":1,"45":1,"750":1}}],["leveldb",{"2":{"658":1}}],["levels",{"2":{"355":1}}],["level",{"2":{"7":1,"131":1,"133":1,"146":1,"208":1,"224":1,"355":1,"450":1,"501":1,"515":1,"558":1,"695":2}}],["legacy",{"2":{"548":3,"549":2}}],["legal",{"2":{"30":1,"33":1,"34":1}}],["legended",{"2":{"34":1}}],["legend",{"2":{"34":3}}],["legends",{"2":{"34":2}}],["lessons",{"2":{"38":1}}],["less",{"2":{"24":1,"25":1,"178":1,"192":1,"262":1,"492":1,"738":1}}],["leave",{"2":{"788":1}}],["leaves",{"2":{"127":2,"165":6,"168":2,"469":1}}],["leaving",{"2":{"738":1}}],["leapwallet",{"2":{"502":1}}],["leap",{"0":{"444":1,"478":1,"479":1},"1":{"479":1,"480":1,"481":1},"2":{"442":1,"444":3,"471":1}}],["leafs",{"2":{"464":1}}],["leaf",{"2":{"151":2,"156":2,"161":2,"168":2}}],["least",{"2":{"24":1,"41":1,"45":1,"80":1,"82":1,"220":1,"403":1,"451":1,"461":1,"463":1,"470":2,"561":2,"649":1,"715":1}}],["lead",{"2":{"14":1,"15":1,"43":1}}],["leaders",{"2":{"7":1,"9":2,"11":2,"12":1,"13":1}}],["learned",{"2":{"38":1,"122":1,"287":1,"580":1,"587":1}}],["learning",{"2":{"3":1,"8":1,"46":1,"48":2,"302":1,"341":1}}],["learn",{"2":{"3":1,"46":1,"52":1,"56":1,"71":1,"79":2,"84":1,"92":1,"105":1,"111":1,"113":1,"116":1,"134":1,"146":1,"236":1,"246":1,"247":1,"262":1,"276":1,"281":1,"292":1,"330":1,"332":1,"333":1,"340":1,"350":1,"369":1,"377":1,"404":1,"405":2,"426":1,"435":1,"438":1,"471":1,"488":1,"494":2,"497":2,"498":1,"509":1,"510":1,"519":1,"529":1,"543":1,"565":1,"579":1,"586":1,"593":1,"594":2,"621":1,"622":1,"665":1,"699":1,"739":1,"750":1,"753":1,"768":1,"769":1,"781":1}}],["locked",{"2":{"443":2,"500":1}}],["lock",{"2":{"266":1,"608":1}}],["located",{"2":{"136":1,"305":1,"540":1,"687":1,"730":1}}],["locate",{"2":{"134":1}}],["location",{"0":{"607":1},"1":{"608":1,"609":1,"610":1,"611":1,"612":1,"613":1},"2":{"24":1,"27":1,"41":2,"65":1,"134":2,"136":1,"137":1,"181":1,"182":1,"183":3,"196":1,"373":1,"542":4,"569":1,"609":10,"627":1,"716":1,"725":1}}],["localroot",{"2":{"277":1}}],["localized",{"2":{"167":1}}],["locally",{"0":{"309":1},"2":{"79":1,"212":2,"221":1,"303":1,"308":1,"309":2,"310":1,"428":1,"571":1,"601":1}}],["localhost",{"2":{"75":2,"90":1,"91":3,"119":3,"120":3,"152":2,"153":2,"284":2,"309":2,"310":6,"313":6,"315":1,"316":1,"323":2,"370":1,"395":2,"396":2,"407":1,"415":2,"418":2,"556":2,"557":4,"595":3,"606":3,"655":2,"788":2}}],["local",{"0":{"220":1,"226":1,"566":1,"567":1},"1":{"567":1,"568":2,"569":2,"570":2,"571":2,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1},"2":{"2":1,"40":1,"42":1,"43":2,"44":2,"45":3,"46":2,"53":1,"69":1,"71":1,"79":1,"85":1,"91":1,"92":1,"120":1,"217":2,"220":5,"226":2,"244":1,"271":1,"277":1,"284":3,"309":4,"312":1,"421":2,"424":2,"545":2,"565":1,"570":1,"573":2,"574":4,"579":1,"580":1,"587":1,"594":1,"601":1,"622":1,"639":2,"661":4,"669":2,"670":2,"676":21,"760":1,"797":1,"808":4}}],["loads",{"2":{"314":2}}],["load",{"2":{"69":1,"270":1,"411":2,"412":3,"413":2,"437":2,"657":1,"658":1,"659":1}}],["lookups",{"2":{"306":2}}],["looks",{"2":{"84":1,"376":1}}],["looking",{"2":{"48":1,"79":2,"91":1,"169":1,"236":1,"247":1,"396":1,"407":1,"664":1,"665":1}}],["look",{"2":{"46":1,"90":1,"102":1,"116":2,"121":2,"131":1,"133":1,"153":2,"170":4,"172":2,"211":1,"276":1,"277":1,"281":2,"286":2,"366":1,"373":1,"376":1,"379":1,"386":1,"395":1,"396":1,"397":1,"461":1,"466":1,"470":1,"576":1,"596":2,"617":1,"669":1,"670":1,"716":1}}],["loop",{"2":{"30":1,"220":1}}],["log=debug",{"2":{"224":2}}],["log",{"2":{"156":2,"309":1,"407":1,"411":2,"557":1,"576":2,"616":1,"617":2,"651":1,"695":2,"797":2,"803":3}}],["logging",{"2":{"93":1,"306":1}}],["logged",{"2":{"88":1}}],["logsbloom",{"2":{"121":2,"286":2,"395":2}}],["logs",{"0":{"553":1},"2":{"71":1,"91":1,"121":2,"219":1,"220":1,"286":2,"398":1,"553":7,"576":2,"611":1,"617":1,"649":1,"788":1,"790":1,"791":1,"792":1,"797":2,"803":2}}],["logos",{"2":{"47":1}}],["logo",{"2":{"44":1,"47":1,"58":1,"444":1}}],["logic",{"2":{"107":2,"110":1,"135":1,"188":1,"223":1,"238":2,"266":1,"466":1,"531":1}}],["logical",{"2":{"43":1}}],["login",{"2":{"78":1,"320":1,"557":1}}],["logistics",{"0":{"39":1,"63":1},"1":{"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1},"2":{"36":1,"39":1,"43":1}}],["lost",{"2":{"614":1,"668":1}}],["lose",{"2":{"563":1,"590":1}}],["loses",{"2":{"24":1}}],["loss",{"2":{"31":2}}],["lowers",{"2":{"84":1}}],["lower",{"2":{"84":2}}],["low",{"2":{"27":1,"146":1,"288":1,"337":1,"439":1,"443":2,"445":1}}],["lot",{"2":{"27":1,"39":1,"40":1,"57":1,"208":1}}],["longer",{"2":{"84":1,"336":1,"403":1,"447":1,"463":1,"508":1,"559":1}}],["long",{"2":{"23":1,"34":1,"85":1,"461":1,"491":1,"492":1,"495":1}}],["love",{"2":{"2":1,"48":1}}],["ll",{"2":{"0":1,"41":1,"56":1,"63":1,"65":1,"68":1,"69":1,"71":1,"76":1,"82":1,"84":1,"85":1,"92":1,"107":1,"120":1,"121":1,"276":1,"277":1,"284":2,"285":1,"286":1,"296":1,"303":1,"309":2,"311":1,"313":1,"314":2,"315":1,"316":2,"318":1,"369":1,"395":1,"405":4,"415":1,"424":1,"444":1,"445":1,"447":1,"580":1,"609":1,"651":1,"661":1,"669":1,"712":1,"803":1,"808":1}}],["wget",{"2":{"656":2,"675":10,"676":8}}],["w",{"2":{"223":2,"413":4,"414":2}}],["wrong",{"0":{"616":1,"661":1,"808":1},"2":{"616":2,"661":2,"808":2}}],["wrapped",{"2":{"224":1,"721":1}}],["wrappers",{"2":{"172":2}}],["wrapper",{"2":{"153":4,"170":2,"220":2,"223":4,"224":2}}],["wrapping",{"0":{"415":1},"2":{"135":1}}],["wraps",{"2":{"135":2,"223":1}}],["writing",{"2":{"135":2,"143":1}}],["write",{"0":{"351":1},"2":{"39":1,"121":1,"277":1,"286":1,"351":2,"405":1,"573":2,"772":1}}],["written",{"2":{"13":1,"31":2,"230":1,"338":2,"676":1}}],["wsl",{"2":{"673":2}}],["ws",{"2":{"119":1,"250":1,"323":2,"415":2,"418":2,"695":4,"745":2}}],["wss",{"0":{"250":1},"2":{"88":6,"89":6,"250":1,"745":3}}],["won",{"2":{"88":1,"89":1,"192":1,"217":1,"401":1,"777":1}}],["wonderful",{"2":{"39":1}}],["worry",{"2":{"107":1,"665":1}}],["world",{"2":{"49":1,"324":4,"405":1,"419":4,"436":4,"733":1}}],["words",{"2":{"129":1,"183":1,"225":1,"454":1,"467":1}}],["word",{"2":{"42":1,"45":1}}],["workshop",{"0":{"59":1,"60":1,"61":1,"62":1}}],["workshops",{"2":{"40":1,"43":1}}],["works",{"0":{"243":1},"2":{"41":2,"94":1,"429":1,"431":1,"432":1,"450":1,"494":1,"509":1,"577":1,"602":1}}],["working",{"0":{"710":1,"711":1},"2":{"36":1,"40":2,"269":2,"301":1,"307":1,"311":1,"339":1,"556":1,"621":1,"710":1}}],["work",{"2":{"22":1,"24":1,"41":1,"131":1,"143":1,"178":1,"261":1,"334":1,"407":1,"464":1,"524":1,"690":1}}],["wouldn",{"2":{"452":1}}],["would",{"2":{"40":1,"45":1,"48":5,"102":1,"131":1,"133":1,"135":9,"136":1,"139":3,"192":2,"194":1,"200":2,"203":1,"212":1,"234":1,"235":1,"321":1,"323":1,"357":1,"362":1,"367":1,"373":1,"386":1,"399":1,"418":1,"424":1,"443":1,"519":1,"548":1,"566":1,"576":1,"596":1,"606":1,"639":1,"651":1,"665":1,"667":2,"688":1,"739":1,"754":2}}],["www",{"2":{"17":3,"520":1,"740":1,"758":1}}],["walkthrough",{"0":{"671":1},"1":{"672":1}}],["wallet=",{"2":{"797":2,"803":2}}],["wallets",{"0":{"367":1,"696":1,"727":1},"1":{"728":1},"2":{"311":1,"313":4,"442":1,"471":1,"512":1,"590":1,"696":3}}],["wallet",{"0":{"267":1,"442":1,"472":1,"473":1,"478":1,"482":1,"483":1,"543":1,"581":1,"588":1,"590":1,"591":1,"796":1},"1":{"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"277":1,"443":1,"444":1,"445":1,"474":1,"475":1,"476":1,"477":1,"479":1,"480":1,"481":1,"483":1,"484":1,"485":1,"486":1,"589":1,"590":1,"591":1},"2":{"31":2,"33":4,"69":1,"71":1,"72":1,"76":1,"78":1,"80":1,"83":3,"85":2,"211":6,"267":1,"285":1,"292":1,"304":1,"311":1,"313":1,"314":4,"315":1,"318":1,"320":1,"350":1,"353":1,"355":1,"357":1,"367":5,"443":5,"444":2,"445":2,"502":2,"503":1,"538":1,"547":1,"548":6,"549":2,"550":2,"551":4,"552":2,"554":1,"588":1,"590":3,"591":2,"645":1,"685":1,"697":1,"727":1,"728":2,"796":1,"797":8,"803":4}}],["wagmiclient",{"2":{"313":4}}],["wagmiconfig",{"2":{"313":6}}],["wagmi",{"2":{"311":1,"312":2,"313":4,"314":2}}],["wanting",{"2":{"355":1}}],["want",{"2":{"211":9,"212":1,"214":1,"217":1,"219":1,"222":1,"228":1,"256":1,"262":1,"265":1,"270":1,"310":1,"313":2,"327":2,"357":1,"369":2,"421":2,"432":1,"437":4,"444":1,"450":1,"458":1,"548":1,"556":2,"590":1,"602":1,"630":2,"639":1,"645":2,"646":2,"651":1,"695":1,"705":2,"709":1,"714":1,"754":1,"777":1,"785":1,"797":2,"803":2}}],["wantedby=multi",{"2":{"788":2,"790":2,"791":2,"792":2}}],["wanted",{"2":{"156":2,"576":2,"797":2,"803":2}}],["wants",{"2":{"145":1,"709":1}}],["waiting",{"2":{"91":6,"135":1,"137":1,"139":3,"180":2,"407":1,"437":2}}],["wait",{"2":{"89":1,"107":1,"139":1,"172":2,"220":1,"314":2,"407":1,"432":1,"437":2,"480":1,"591":1}}],["waive",{"2":{"31":1}}],["watchopts",{"2":{"171":2}}],["watchdatacommitmentstored",{"2":{"171":3}}],["watch",{"2":{"46":1}}],["watchlist",{"2":{"31":1}}],["water",{"2":{"41":2}}],["way",{"2":{"34":1,"44":1,"82":1,"108":1,"149":1,"175":1,"178":2,"179":1,"180":1,"181":1,"192":2,"200":1,"208":1,"212":2,"213":1,"313":1,"336":1,"341":1,"356":1,"405":1,"457":1,"460":1,"516":1,"548":1,"557":1,"573":2,"590":1,"594":1,"622":1,"665":2,"721":1}}],["ways",{"2":{"7":1,"174":1,"239":1,"264":1,"338":1,"352":1,"433":1,"753":1,"768":1,"769":1,"781":1}}],["warn",{"2":{"559":1}}],["warning",{"0":{"14":1},"2":{"13":1,"14":1,"89":1,"161":1,"162":1,"339":1,"357":1,"362":1,"516":1,"521":1,"525":1,"606":1,"618":1,"740":1,"742":1,"758":1,"765":1}}],["warehouse",{"2":{"520":1,"740":1,"758":1}}],["warm",{"2":{"45":1}}],["warranties",{"2":{"34":1}}],["wasm",{"2":{"94":1}}],["was",{"0":{"153":1},"2":{"13":1,"34":1,"79":1,"81":1,"91":5,"109":1,"130":1,"131":5,"133":1,"137":1,"139":1,"145":1,"146":1,"148":2,"153":6,"163":6,"164":1,"169":7,"172":2,"173":1,"177":2,"183":1,"189":1,"195":1,"196":1,"200":1,"203":1,"213":2,"214":1,"217":1,"223":1,"224":2,"242":1,"262":1,"276":1,"311":1,"324":3,"338":1,"374":1,"376":2,"377":1,"413":1,"419":3,"436":2,"437":4,"447":1,"464":1,"469":1,"470":1,"569":1,"571":1,"593":1,"611":1,"650":1,"661":1,"676":1,"697":1,"723":1,"788":1,"790":1,"791":1,"792":1,"797":1,"808":1}}],["width",{"2":{"313":2,"314":8}}],["windows",{"2":{"666":1,"673":2}}],["window",{"2":{"276":1,"277":1,"314":6,"407":1,"439":1,"440":1,"441":1,"443":8,"491":5,"563":1,"689":1}}],["wise",{"2":{"469":1}}],["wish",{"2":{"225":1,"236":1,"428":1,"432":1,"492":1}}],["wisdom",{"2":{"56":1}}],["wiki",{"2":{"9":1}}],["willingness",{"2":{"432":1}}],["willing",{"2":{"353":1,"430":1}}],["will",{"2":{"9":2,"11":1,"12":1,"21":2,"22":2,"23":3,"24":2,"26":2,"27":1,"28":1,"29":1,"31":6,"33":1,"34":8,"40":1,"41":1,"42":2,"43":1,"44":1,"47":1,"48":3,"50":1,"52":1,"53":2,"64":2,"66":1,"71":1,"72":2,"76":1,"77":1,"79":2,"82":1,"83":2,"84":1,"85":2,"86":1,"88":3,"89":3,"90":3,"91":1,"102":1,"103":2,"107":5,"113":1,"119":3,"120":2,"121":2,"122":2,"126":2,"133":1,"134":1,"135":3,"139":1,"145":1,"148":1,"149":1,"150":1,"153":2,"154":1,"161":1,"162":1,"163":5,"165":1,"170":2,"172":4,"174":1,"175":2,"177":1,"178":4,"180":1,"181":1,"183":4,"184":2,"192":1,"195":1,"196":1,"197":1,"199":1,"200":2,"202":1,"203":3,"209":1,"211":2,"212":2,"213":5,"217":1,"219":3,"223":1,"224":3,"225":1,"228":2,"230":1,"237":4,"244":3,"256":1,"264":2,"267":2,"269":1,"270":4,"276":1,"277":2,"278":1,"285":2,"286":2,"287":1,"292":4,"293":1,"301":1,"302":2,"303":1,"309":3,"310":3,"314":4,"316":1,"318":2,"319":1,"322":1,"323":1,"325":2,"326":2,"336":3,"340":1,"344":1,"346":1,"357":1,"359":1,"362":1,"365":1,"366":1,"367":2,"368":2,"369":1,"370":1,"371":3,"372":1,"373":1,"374":5,"376":6,"377":3,"379":1,"380":1,"383":3,"386":1,"391":3,"395":1,"396":1,"397":1,"398":1,"399":1,"401":1,"402":1,"403":1,"407":4,"408":1,"410":1,"411":2,"412":2,"413":3,"415":3,"417":1,"418":1,"420":4,"426":2,"427":1,"432":3,"437":4,"439":1,"443":4,"444":1,"445":1,"447":2,"448":1,"450":1,"451":1,"457":1,"458":1,"470":1,"471":1,"474":1,"476":1,"477":1,"481":1,"486":1,"489":1,"490":1,"491":5,"492":2,"494":1,"499":1,"500":2,"512":1,"516":2,"519":1,"523":1,"524":2,"530":1,"536":1,"537":1,"538":2,"545":3,"548":1,"557":6,"561":2,"563":8,"565":1,"569":3,"572":1,"573":1,"576":2,"577":1,"578":1,"579":2,"583":3,"584":1,"585":1,"588":1,"592":1,"593":4,"594":3,"596":3,"597":1,"598":3,"602":3,"604":2,"606":1,"609":1,"611":2,"612":1,"614":1,"617":1,"618":2,"621":2,"622":3,"627":1,"633":1,"639":1,"641":1,"645":1,"646":3,"648":2,"653":1,"658":2,"659":2,"668":4,"669":1,"670":1,"674":1,"676":1,"677":1,"685":2,"689":1,"690":1,"691":1,"692":6,"695":1,"696":1,"704":1,"706":1,"707":1,"708":1,"711":2,"712":1,"715":3,"716":3,"720":2,"725":2,"727":2,"734":2,"739":1,"747":1,"748":1,"754":1,"759":1,"760":1,"777":1,"779":1,"783":1,"785":2,"788":1,"790":1,"791":2,"792":3,"793":1,"797":1,"803":2}}],["withheld",{"2":{"448":1}}],["withhold",{"2":{"448":1,"470":1}}],["withholding",{"2":{"448":1}}],["withtransportcredentials",{"2":{"437":2}}],["withcancel",{"2":{"412":2,"413":2,"415":2}}],["withfeegranteraddress",{"2":{"324":1}}],["withsigneraddress",{"2":{"324":1}}],["withkeyname",{"2":{"324":1}}],["withgas",{"2":{"324":1}}],["withgasprice",{"2":{"324":2}}],["withdraw",{"0":{"71":1},"2":{"550":2}}],["withdrawalsroot",{"2":{"395":2}}],["withdrawals",{"2":{"84":1}}],["withdrawal",{"0":{"70":1,"72":1},"1":{"71":1,"72":1},"2":{"24":1,"66":2,"71":2,"72":2}}],["within",{"2":{"10":1,"16":1,"21":1,"24":4,"33":2,"34":1,"40":1,"43":1,"50":1,"65":1,"84":1,"369":1,"439":1,"440":1,"488":1,"491":3,"673":1}}],["without",{"2":{"8":1,"31":1,"34":1,"88":1,"107":1,"146":1,"179":1,"264":1,"290":1,"294":1,"314":2,"323":1,"372":1,"401":1,"418":1,"449":1,"450":1,"460":1,"468":1,"492":1,"500":1,"576":1,"665":1,"667":1,"749":1}}],["with",{"0":{"76":1,"78":1,"92":1,"103":1,"104":1,"121":1,"123":1,"132":1,"237":1,"238":1,"246":1,"267":1,"286":1,"320":1,"344":1,"345":1,"375":1,"399":1,"442":1,"443":1,"473":1,"478":1,"482":1,"522":1,"539":1,"541":1,"553":1,"565":1,"588":1,"668":1,"686":1,"688":1,"729":1,"731":1,"786":1,"788":1,"802":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"238":1,"239":1,"240":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"277":1,"346":1,"347":1,"400":1,"401":1,"402":1,"403":1,"404":1,"443":1,"444":1,"445":1,"474":1,"475":1,"476":1,"477":1,"479":1,"480":1,"481":1,"483":1,"484":1,"485":1,"486":1,"523":1,"524":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1,"589":1,"590":1,"591":1,"669":1,"670":1,"687":1,"730":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1},"2":{"1":1,"2":1,"3":2,"5":1,"14":3,"15":3,"24":2,"25":1,"26":1,"27":2,"30":1,"31":5,"32":6,"33":4,"34":18,"36":2,"37":1,"38":2,"40":5,"42":5,"43":7,"44":2,"45":2,"46":5,"47":3,"48":1,"49":1,"50":1,"53":1,"54":2,"55":1,"61":1,"63":1,"65":1,"76":4,"77":3,"78":1,"79":1,"80":1,"82":1,"84":2,"85":1,"88":2,"89":2,"91":6,"94":5,"101":1,"102":2,"105":1,"106":1,"107":3,"108":2,"109":2,"110":1,"115":2,"116":2,"117":1,"120":2,"121":1,"131":3,"135":3,"139":1,"143":1,"145":1,"148":1,"151":1,"153":2,"156":1,"159":1,"161":1,"165":2,"166":1,"167":1,"168":1,"169":6,"170":2,"172":2,"173":1,"174":1,"175":1,"181":1,"184":1,"187":1,"192":1,"211":1,"212":1,"217":1,"219":1,"223":1,"225":1,"226":1,"227":2,"228":1,"230":2,"234":1,"236":3,"237":1,"238":3,"240":1,"242":3,"245":3,"246":1,"248":2,"250":1,"259":1,"262":1,"265":1,"266":2,"267":1,"270":1,"275":1,"276":3,"277":5,"280":2,"281":2,"282":1,"284":1,"285":2,"286":1,"288":2,"290":1,"291":2,"292":2,"293":1,"302":1,"306":2,"308":1,"309":3,"310":1,"311":1,"312":1,"313":1,"314":1,"316":2,"318":4,"319":3,"320":1,"321":1,"322":1,"324":2,"325":2,"326":2,"331":1,"333":1,"334":1,"337":2,"338":2,"340":5,"341":1,"343":1,"344":1,"346":1,"350":1,"352":2,"355":2,"356":1,"366":3,"367":4,"368":1,"369":5,"370":1,"371":3,"372":2,"373":2,"374":2,"376":1,"379":1,"386":1,"391":2,"393":1,"395":1,"401":1,"403":4,"404":1,"405":2,"407":2,"408":2,"411":2,"412":5,"413":6,"415":6,"416":1,"417":1,"419":2,"424":1,"426":1,"427":1,"430":1,"432":2,"439":1,"448":1,"452":1,"453":1,"454":1,"459":1,"461":2,"462":1,"463":6,"464":2,"466":1,"467":1,"468":1,"469":4,"470":3,"474":1,"488":1,"489":1,"494":1,"501":1,"509":1,"513":1,"515":1,"516":1,"521":3,"524":4,"526":1,"531":3,"537":2,"538":2,"541":2,"542":2,"548":6,"550":1,"551":2,"552":1,"553":1,"557":5,"559":1,"560":1,"561":2,"563":1,"569":1,"576":2,"586":1,"591":1,"592":1,"593":1,"594":2,"595":1,"596":2,"598":1,"605":1,"606":1,"609":3,"614":1,"615":1,"618":2,"621":2,"622":2,"633":1,"639":1,"641":1,"645":1,"651":1,"655":1,"661":1,"663":3,"667":1,"670":1,"673":1,"685":4,"688":1,"690":3,"691":1,"694":1,"696":1,"703":1,"705":2,"709":1,"712":1,"714":3,"715":2,"716":2,"718":4,"719":1,"721":1,"726":2,"727":3,"731":1,"732":1,"734":2,"738":1,"740":1,"742":1,"748":2,"758":1,"761":1,"762":2,"763":1,"765":1,"779":1,"782":1,"783":1,"798":1,"802":2,"803":1,"808":1}}],["whole",{"2":{"461":1}}],["whom",{"2":{"160":1}}],["whose",{"2":{"156":1,"211":2}}],["who",{"0":{"458":1},"2":{"22":1,"24":1,"31":1,"34":1,"43":1,"45":2,"46":3,"65":1,"246":1,"353":1,"357":1,"373":1,"709":1,"716":1,"777":1}}],["whitelist",{"0":{"215":1},"2":{"214":1,"215":3}}],["whitelisting",{"0":{"214":1},"2":{"211":1,"214":2,"424":1}}],["whitelisted",{"2":{"211":1}}],["whiteboard",{"2":{"40":1}}],["whiteboards",{"2":{"36":1,"40":1}}],["white",{"2":{"34":1}}],["while",{"2":{"19":1,"41":1,"91":1,"116":1,"165":1,"174":1,"230":1,"236":1,"267":1,"281":1,"331":1,"336":1,"338":2,"386":1,"407":1,"420":2,"462":1,"467":1,"470":1,"492":1,"617":4,"734":1,"774":1,"784":1}}],["which",{"0":{"662":1},"1":{"663":1,"664":1},"2":{"8":1,"27":1,"30":3,"31":1,"34":3,"41":1,"47":1,"48":1,"76":1,"83":1,"84":3,"86":1,"88":2,"89":1,"90":1,"95":1,"102":1,"106":1,"107":1,"108":3,"109":3,"110":2,"131":1,"134":1,"135":2,"137":1,"146":2,"148":4,"150":1,"151":1,"156":1,"158":1,"160":1,"161":1,"163":2,"165":2,"166":1,"167":1,"169":5,"175":1,"177":1,"183":1,"188":1,"189":1,"193":1,"196":1,"200":1,"202":1,"203":1,"208":1,"211":3,"213":3,"214":1,"215":3,"220":2,"222":2,"223":3,"224":2,"227":1,"228":1,"230":2,"233":1,"234":1,"243":1,"244":1,"270":1,"276":1,"313":2,"318":1,"324":1,"331":1,"338":1,"352":1,"356":1,"357":1,"366":1,"374":4,"376":4,"377":1,"379":1,"398":1,"413":2,"414":1,"429":1,"448":1,"456":1,"457":1,"467":1,"488":2,"492":1,"494":1,"510":1,"519":1,"536":1,"537":1,"538":1,"548":1,"557":2,"591":1,"593":1,"596":1,"602":1,"604":1,"648":1,"655":2,"658":2,"662":1,"664":1,"667":1,"677":1,"685":2,"690":2,"693":1,"694":1,"704":1,"716":2,"718":1,"719":1,"720":1,"726":2,"738":4,"739":1,"754":1,"762":3,"783":1,"785":1,"788":2,"790":2,"791":2,"792":2,"800":1,"805":1}}],["why",{"0":{"452":1,"457":1},"2":{"13":1,"27":1,"48":5,"65":1,"223":1,"690":1}}],["whenever",{"2":{"45":1,"288":1,"754":1}}],["when",{"2":{"9":1,"10":1,"42":1,"48":1,"50":1,"65":1,"88":1,"89":2,"107":2,"146":1,"148":1,"153":2,"166":1,"170":2,"172":2,"178":1,"184":1,"188":1,"195":1,"196":2,"214":1,"223":1,"228":1,"276":1,"296":1,"306":2,"309":1,"314":3,"316":1,"323":1,"330":1,"338":1,"367":1,"369":1,"370":1,"403":1,"418":1,"430":1,"431":1,"447":2,"448":1,"464":1,"500":1,"548":1,"556":2,"557":2,"595":1,"601":1,"605":1,"606":1,"609":1,"611":1,"612":1,"613":1,"617":2,"639":2,"656":1,"658":2,"669":1,"691":1,"715":1,"728":1}}],["whereas",{"2":{"84":1}}],["where",{"0":{"456":1},"2":{"8":1,"107":2,"108":1,"136":1,"156":1,"163":2,"167":1,"210":1,"219":1,"220":1,"365":1,"367":1,"369":1,"405":1,"407":1,"424":1,"426":1,"428":1,"429":1,"430":1,"439":1,"452":1,"463":1,"469":1,"477":1,"481":1,"486":1,"491":1,"492":3,"526":1,"531":1,"543":1,"585":2,"613":1,"618":1,"689":1,"691":1,"728":1,"733":1,"765":1}}],["whether",{"2":{"2":1,"34":1,"42":1,"439":1,"443":3,"448":1,"454":1,"460":1,"659":1}}],["whatever",{"0":{"256":1},"1":{"257":1,"258":1,"259":1,"260":1,"261":1,"262":1,"263":1,"264":1,"265":1,"266":1},"2":{"302":1,"330":1,"590":1}}],["what",{"0":{"230":1,"236":1,"242":1,"261":1,"262":1,"447":1,"448":1,"450":1,"451":1,"453":1,"454":1,"455":1,"459":1},"1":{"231":1},"2":{"8":1,"22":1,"48":4,"59":1,"60":1,"61":1,"71":1,"85":1,"117":1,"122":1,"133":1,"136":1,"139":1,"183":1,"220":2,"256":1,"282":1,"287":1,"303":1,"321":1,"373":1,"376":1,"386":1,"415":2,"490":1,"515":1,"594":1,"598":1,"622":1,"676":1,"690":1}}],["went",{"2":{"797":1}}],["we+s5gft6g944xbkvvygqb9oy+u",{"2":{"573":2,"574":2}}],["week",{"2":{"526":1,"765":1}}],["weeks",{"2":{"45":1,"217":1,"647":1,"648":1}}],["weak",{"2":{"454":1,"649":1}}],["weth",{"2":{"91":2}}],["webhook",{"2":{"559":1}}],["web",{"0":{"527":1},"2":{"311":1,"527":1,"557":1}}],["websocket",{"0":{"745":1},"2":{"88":5,"145":2,"152":2,"153":2,"695":4,"745":3}}],["websites",{"2":{"752":1,"766":1}}],["website",{"2":{"27":1,"46":1,"88":1,"443":2}}],["web3provider",{"2":{"314":4}}],["web3",{"2":{"48":1,"50":1,"302":1}}],["were",{"2":{"17":1,"31":1,"34":2,"131":5,"163":6,"164":1,"225":1,"236":1,"416":1,"500":1}}],["well",{"2":{"14":1,"30":1,"40":1,"41":2,"65":2,"107":1,"108":1,"211":1,"266":1,"309":1,"334":1,"353":1,"490":1,"685":1,"694":1}}],["welcoming",{"2":{"7":1,"40":1,"52":1}}],["welcome",{"2":{"0":1,"21":1,"30":1,"37":1,"47":2,"48":1,"49":1,"54":1,"57":1,"113":1,"405":1,"733":1}}],["we",{"2":{"2":1,"4":1,"7":2,"24":1,"30":2,"31":5,"33":9,"40":1,"48":8,"52":2,"65":2,"83":2,"84":1,"88":1,"103":1,"107":1,"117":1,"120":2,"121":2,"122":1,"126":2,"131":1,"134":4,"135":3,"136":1,"139":4,"146":1,"148":5,"150":1,"153":2,"154":1,"163":5,"164":2,"165":6,"168":1,"170":2,"172":4,"173":1,"178":1,"181":1,"182":1,"183":4,"184":5,"195":1,"211":4,"213":4,"214":1,"217":2,"218":2,"219":10,"220":1,"223":1,"224":1,"265":1,"269":1,"276":1,"277":2,"278":1,"282":1,"284":1,"285":3,"286":2,"302":1,"303":1,"306":5,"307":1,"308":2,"309":7,"310":7,"311":2,"312":1,"313":4,"314":8,"315":3,"316":2,"325":1,"326":1,"330":1,"331":2,"332":1,"333":1,"335":1,"336":1,"339":1,"359":1,"369":1,"374":6,"376":2,"379":1,"383":1,"391":1,"395":1,"403":2,"405":1,"407":3,"411":4,"412":8,"413":26,"414":1,"415":11,"420":3,"424":1,"432":1,"437":12,"443":5,"490":1,"515":1,"548":2,"557":1,"559":2,"565":1,"569":1,"579":1,"580":2,"583":4,"588":1,"590":1,"598":1,"602":1,"609":1,"623":2,"628":1,"653":1,"669":2,"676":1,"695":1,"696":2,"698":1,"700":1,"701":2,"711":2,"712":1,"734":1,"754":1,"760":1,"782":1,"785":1,"791":1}}],["dteam",{"2":{"742":1,"743":1,"744":1,"745":1,"748":1,"751":1,"760":2,"761":1,"762":1,"763":1,"767":1}}],["dl",{"2":{"676":8}}],["dbbackend",{"2":{"658":1}}],["d6",{"2":{"464":1}}],["d5",{"2":{"464":2}}],["d4",{"2":{"464":2}}],["d3",{"2":{"464":1}}],["dns4",{"2":{"521":4}}],["dns",{"2":{"391":1}}],["d85c907ce660878a8203ac74baa147ccc1f87114b45b568b72ad207b62afe45e",{"2":{"383":2}}],["dynamic",{"2":{"265":1,"429":1,"430":1}}],["d7wrs",{"2":{"156":2}}],["dcproof",{"2":{"152":2,"153":2}}],["dfcelestia",{"2":{"102":1}}],["drafted",{"2":{"737":1}}],["drawing",{"2":{"56":1}}],["drop",{"2":{"432":1,"499":1}}],["dropped",{"2":{"432":1}}],["dropdown",{"2":{"68":1,"315":1}}],["drift",{"2":{"695":4}}],["drinks",{"2":{"41":4}}],["driver",{"2":{"33":1}}],["d",{"2":{"31":1,"34":1,"47":2,"89":1,"90":1,"139":4,"314":18,"324":2,"325":4,"326":4,"386":1,"392":1,"397":2,"413":4,"436":2,"499":1,"500":2,"565":1,"570":1,"576":2,"650":6}}],["daemon",{"2":{"608":1,"617":3,"786":1,"788":6,"790":3,"791":3,"792":4,"798":1}}],["darwin",{"2":{"594":1,"622":1,"676":12}}],["daring",{"2":{"573":2}}],["dah",{"2":{"383":2,"384":2,"389":2}}],["dac",{"2":{"234":1,"235":1}}],["dacs",{"0":{"232":1},"1":{"233":1,"234":1,"235":1},"2":{"233":1,"235":2}}],["daverifier",{"0":{"163":1,"172":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1},"2":{"131":3,"163":1,"172":11,"183":1}}],["daser",{"2":{"618":1}}],["das",{"0":{"461":1},"1":{"462":1,"463":1},"2":{"108":1,"230":1,"385":2,"450":1,"460":2,"461":2,"462":4,"463":1,"470":4,"720":1,"721":1,"792":1}}],["dashboard",{"2":{"33":1,"474":2,"475":1,"477":1,"481":1,"524":1,"557":5,"602":1,"748":2}}],["dashboards",{"2":{"24":1,"494":1,"557":1,"803":1}}],["da",{"0":{"104":1,"107":1,"229":1,"465":1,"522":1,"523":1,"524":1,"747":1,"748":1,"749":1,"757":1,"759":1,"760":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"466":1,"523":1,"524":1,"750":1,"758":1,"759":1,"760":1},"2":{"89":3,"94":1,"103":1,"106":1,"107":1,"110":1,"111":1,"133":1,"135":4,"136":1,"139":1,"187":2,"195":1,"230":2,"236":3,"246":1,"268":1,"288":1,"291":1,"292":4,"330":1,"337":1,"338":8,"340":1,"353":2,"355":2,"357":1,"361":1,"397":2,"402":1,"403":1,"404":1,"460":3,"462":2,"464":4,"466":3,"467":6,"470":5,"521":5,"523":1,"524":5,"531":1,"618":1,"627":1,"692":1,"720":1,"721":1,"747":1,"748":7,"749":1,"759":1,"760":2,"764":8,"783":2,"784":1}}],["dao",{"2":{"84":1}}],["dappforge",{"2":{"305":1}}],["dappsys",{"2":{"306":1}}],["dapps",{"2":{"302":1}}],["dapp",{"0":{"73":1,"318":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"319":1,"320":1,"321":1},"2":{"122":1,"302":1,"305":3,"310":1,"315":1,"317":1,"340":1}}],["day",{"2":{"45":1,"491":2}}],["days",{"2":{"41":1,"491":2,"563":1}}],["damage",{"2":{"31":1}}],["dat2024",{"2":{"223":1}}],["dat",{"2":{"223":31}}],["datalen",{"2":{"181":2,"183":1}}],["datahash",{"2":{"153":2,"172":2}}],["datacommitmentstored",{"2":{"217":1,"228":1}}],["datacommitment",{"2":{"153":2,"170":2}}],["datasharelen",{"2":{"134":4}}],["datasharestart",{"2":{"134":4}}],["datarootinclusionproof",{"2":{"152":2,"153":2,"169":9,"172":10}}],["dataroot",{"2":{"127":4,"148":2,"153":2,"169":5,"172":2}}],["dataroottupleroot",{"2":{"150":1}}],["dataroottuples",{"2":{"128":5,"129":1}}],["dataroottuple",{"2":{"127":4,"128":2,"129":1,"131":1,"150":1,"153":2,"163":2,"169":7,"172":2}}],["dataavailabilityprovider",{"2":{"107":2}}],["data",{"0":{"128":1,"131":1,"136":1,"142":1,"150":1,"164":1,"171":1,"183":1,"184":1,"208":1,"225":1,"232":1,"327":1,"374":1,"376":1,"385":1,"396":1,"397":1,"421":1,"425":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"453":1,"454":1,"455":2,"457":1,"458":1,"459":1,"460":1,"461":1,"463":1,"466":1,"470":1,"490":1,"491":1,"523":1,"524":1,"615":1,"643":1,"732":1,"746":1,"747":1,"748":1,"759":1,"760":1,"771":1,"789":1},"1":{"151":1,"152":1,"226":1,"227":1,"228":1,"233":1,"234":1,"235":1,"375":1,"426":1,"427":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"454":1,"455":1,"456":1,"457":1,"458":1,"459":1,"461":1,"462":2,"463":2,"464":1,"465":1,"466":1,"491":1,"492":1,"747":1,"748":1,"749":1,"750":1,"790":1,"791":1,"792":1},"2":{"27":1,"31":2,"43":1,"48":1,"59":1,"79":1,"83":5,"88":3,"89":1,"105":2,"107":10,"108":8,"109":5,"110":6,"127":5,"128":1,"129":1,"130":1,"131":8,"133":2,"134":31,"135":7,"136":7,"137":16,"139":10,"142":1,"145":1,"146":5,"148":9,"150":6,"151":2,"153":10,"154":3,"156":5,"158":1,"160":3,"161":2,"163":14,"164":2,"166":1,"167":1,"168":1,"169":31,"171":2,"172":14,"173":3,"174":4,"176":2,"177":8,"178":3,"179":2,"181":9,"182":1,"183":7,"184":19,"187":2,"188":7,"189":1,"191":2,"192":3,"195":2,"196":8,"199":1,"200":5,"203":5,"208":6,"223":9,"230":3,"233":2,"234":4,"235":2,"236":5,"237":1,"240":1,"242":1,"246":2,"248":1,"262":3,"265":2,"288":2,"290":1,"300":1,"314":16,"327":1,"333":3,"334":1,"337":2,"338":14,"359":2,"361":1,"362":3,"365":1,"374":9,"376":10,"383":2,"391":4,"396":1,"399":1,"401":2,"405":3,"411":2,"412":2,"413":5,"415":5,"419":2,"421":1,"425":2,"434":2,"435":2,"437":8,"438":1,"447":11,"448":7,"449":7,"450":9,"451":2,"452":6,"453":4,"454":6,"455":4,"456":3,"457":9,"458":4,"459":6,"460":5,"461":11,"462":3,"463":11,"464":14,"466":5,"467":2,"468":6,"469":15,"470":9,"488":9,"490":7,"491":7,"492":12,"507":1,"508":1,"520":1,"521":1,"530":1,"531":3,"557":4,"576":2,"597":1,"598":1,"602":2,"612":2,"615":1,"616":1,"617":4,"622":1,"641":1,"643":2,"646":3,"647":2,"650":19,"653":1,"654":2,"663":3,"668":3,"677":1,"678":1,"720":2,"721":1,"734":1,"740":1,"749":5,"754":1,"758":1,"769":5,"783":2,"792":1,"797":2,"798":2,"803":2}}],["date",{"2":{"26":1,"34":3,"36":1,"621":1,"692":1}}],["duty",{"2":{"573":2}}],["dubbing",{"2":{"466":1}}],["dumps",{"2":{"269":2}}],["dummy",{"2":{"223":3}}],["dues",{"2":{"47":4}}],["due",{"2":{"24":1,"31":1,"65":1,"89":1,"288":1,"429":1,"432":1,"460":1,"467":1,"470":1,"604":1}}],["duration",{"2":{"23":3,"28":1}}],["during",{"0":{"37":1},"2":{"15":1,"23":1,"25":1,"34":1,"37":1,"41":1,"44":1,"169":1,"223":1,"236":1,"294":1,"343":1,"439":1,"451":1,"563":1,"594":1,"622":1,"630":1,"633":1,"651":1,"803":1}}],["double",{"2":{"563":2,"614":1}}],["dos",{"2":{"355":1}}],["domain",{"2":{"391":1}}],["dom",{"2":{"313":2}}],["doing",{"2":{"117":1,"139":1,"165":1,"262":1,"282":1,"313":1,"394":1,"594":1,"622":1}}],["downside",{"2":{"463":1}}],["down",{"2":{"269":1,"431":1,"444":1,"445":1,"627":1,"691":1}}],["downtime",{"2":{"110":1,"288":2,"563":1}}],["downloads",{"2":{"557":1,"621":1,"647":4,"650":1}}],["downloading",{"0":{"139":1},"2":{"139":1,"212":1,"449":1,"463":2,"675":1}}],["downloaded",{"0":{"222":1},"1":{"223":1,"224":1},"2":{"86":1,"87":1,"212":2,"220":1,"222":1,"223":1,"224":2,"448":1,"492":1,"647":1}}],["download",{"0":{"86":1},"2":{"85":1,"86":3,"135":1,"139":10,"212":2,"220":1,"223":16,"336":1,"362":1,"363":1,"410":1,"447":3,"449":2,"450":1,"460":2,"461":1,"462":3,"463":1,"464":1,"466":1,"492":1,"532":1,"566":1,"594":1,"622":1,"635":1,"639":7,"647":1,"676":1,"679":1,"692":3,"722":1,"760":2,"794":1}}],["do",{"0":{"449":1,"459":1},"2":{"30":3,"31":1,"32":1,"34":2,"48":1,"82":1,"133":1,"168":1,"208":1,"213":1,"219":1,"225":1,"262":1,"270":2,"276":1,"288":1,"308":1,"310":1,"313":1,"316":1,"333":1,"366":1,"367":1,"412":1,"428":1,"444":1,"449":1,"452":1,"490":1,"491":1,"492":1,"516":1,"521":1,"524":1,"537":1,"538":1,"557":2,"589":1,"602":1,"604":1,"646":1,"655":1,"673":1,"685":1,"689":1,"690":1,"692":1,"696":1,"698":1,"705":1,"710":1,"740":1,"742":1,"758":1,"760":1,"783":1,"792":1}}],["done",{"2":{"77":1,"91":10,"133":1,"136":1,"154":1,"164":1,"171":2,"184":2,"194":1,"319":1,"325":2,"326":2,"432":1,"440":1,"533":1,"548":1,"636":1,"680":1,"709":1,"779":1,"795":1}}],["don",{"2":{"27":1,"40":1,"45":1,"46":1,"71":1,"107":2,"211":2,"242":1,"264":1,"265":1,"266":1,"351":1,"357":1,"399":1,"437":2,"452":1,"457":1,"581":1,"651":1,"658":1,"698":1,"785":1,"803":1}}],["docker",{"0":{"274":1,"665":1},"1":{"275":1,"276":1,"277":1,"666":1,"667":1,"668":1,"669":1,"670":1,"671":1,"672":1,"673":1},"2":{"80":2,"89":7,"90":2,"275":2,"276":3,"277":4,"398":2,"665":7,"666":4,"668":1,"669":2,"670":2}}],["docs",{"2":{"24":1,"88":1,"102":2,"141":1,"177":1,"237":1,"404":1,"438":1,"520":2,"559":1,"562":1,"594":2,"602":1,"622":2,"649":1,"740":2,"758":2}}],["documented",{"2":{"171":1,"217":2}}],["documents",{"2":{"102":2}}],["document",{"2":{"23":1,"38":1,"148":1,"174":1,"209":1,"313":2,"329":1,"343":1,"423":1,"490":1,"561":6,"737":1}}],["documentation",{"0":{"0":1,"140":1,"328":1,"422":1},"1":{"1":1,"2":1,"3":1,"4":1,"141":1,"142":1,"143":1},"2":{"0":1,"1":1,"3":1,"4":1,"24":1,"31":3,"37":1,"79":1,"93":1,"130":1,"131":1,"135":2,"136":3,"172":1,"184":2,"191":1,"211":1,"212":1,"217":1,"221":1,"226":1,"239":1,"243":1,"244":2,"328":1,"332":1,"352":1,"422":1,"519":1,"543":2,"548":1,"556":2,"586":1,"739":1}}],["doesn",{"0":{"457":1},"2":{"145":1,"183":1,"208":1,"266":1,"370":1,"393":1,"677":1,"694":1}}],["does",{"0":{"456":1},"2":{"23":1,"27":1,"30":1,"34":3,"108":1,"210":1,"211":1,"295":1,"296":2,"428":1,"430":1,"432":1,"463":1,"469":1,"515":1,"525":1,"569":1,"673":1,"691":1,"762":1,"765":1,"769":1}}],["dir",{"2":{"609":3}}],["direct",{"2":{"521":2,"524":1,"559":1}}],["directories",{"2":{"492":1}}],["directory",{"0":{"3":1,"569":1,"710":1,"711":1},"2":{"68":1,"75":1,"87":1,"92":1,"115":1,"116":2,"126":1,"269":2,"270":4,"277":5,"280":1,"281":2,"306":1,"310":1,"311":3,"312":1,"318":1,"367":2,"370":1,"401":1,"410":1,"411":1,"539":1,"540":1,"554":1,"568":1,"569":4,"571":1,"593":1,"616":1,"621":1,"647":1,"650":1,"668":4,"676":1,"686":1,"687":1,"710":2,"716":3,"727":2,"729":1,"730":1}}],["directly",{"2":{"135":1,"139":2,"228":1,"234":1,"333":1,"372":1,"428":1,"430":1,"437":2,"443":1}}],["directed",{"2":{"34":1,"685":1,"726":1}}],["dimensional",{"2":{"461":1,"463":4,"466":1,"469":1}}],["digest",{"2":{"165":9,"172":4,"223":2}}],["digital",{"2":{"8":1,"331":1}}],["dial",{"2":{"153":2,"170":2,"171":2,"172":2,"437":2,"613":2,"656":1}}],["diagram",{"2":{"148":1,"243":1,"495":1}}],["diagrams",{"2":{"3":1,"146":1}}],["did",{"2":{"48":2,"220":2}}],["difficulty",{"2":{"40":1,"42":1,"395":2}}],["difference",{"0":{"455":1},"2":{"102":1,"139":1,"184":1,"192":2,"203":1}}],["different",{"0":{"344":1,"345":1},"1":{"346":1,"347":1},"2":{"5":1,"39":1,"64":1,"76":1,"88":1,"89":1,"131":1,"139":1,"173":1,"182":2,"188":1,"191":1,"195":1,"206":1,"211":5,"225":3,"239":1,"242":1,"251":1,"256":1,"318":1,"343":2,"344":1,"346":1,"347":1,"355":1,"407":1,"416":1,"432":1,"456":2,"467":1,"500":1,"519":1,"548":1,"557":1,"583":1,"605":2,"609":2,"649":1,"656":1,"739":1,"769":1,"785":1}}],["differing",{"2":{"8":1}}],["dividing",{"2":{"428":1}}],["divided",{"2":{"23":1,"26":1}}],["div",{"2":{"313":4,"314":36,"443":4}}],["dive",{"0":{"394":1},"1":{"395":1,"396":1,"397":1,"398":1},"2":{"394":1}}],["dives",{"2":{"48":1,"59":1}}],["diverse",{"2":{"7":1}}],["disk",{"2":{"363":1,"532":1,"558":1,"635":1,"659":2,"679":1,"722":1,"771":1,"772":1,"794":1}}],["disruptions",{"2":{"288":1}}],["disruptive",{"2":{"19":1}}],["disables",{"2":{"601":1,"658":1}}],["disable",{"2":{"383":2,"601":2}}],["disabled",{"2":{"215":1,"412":2,"413":2,"415":2}}],["disability",{"2":{"7":1}}],["distinguish",{"2":{"84":1}}],["distributor",{"2":{"34":1}}],["distributors",{"2":{"34":1}}],["distributing",{"2":{"34":1}}],["distribution",{"2":{"34":2,"331":1,"525":1,"549":2,"550":2,"765":1}}],["distributed",{"2":{"467":1}}],["distribute",{"2":{"22":1}}],["disputes",{"2":{"84":1,"467":1}}],["dispute",{"2":{"84":1,"262":1}}],["displayed",{"2":{"545":1}}],["displaydenom",{"2":{"512":1}}],["displaying",{"2":{"37":1}}],["display",{"0":{"512":1},"2":{"33":1,"84":1,"314":8,"376":1}}],["disparagement",{"2":{"16":1}}],["disqualify",{"2":{"24":1,"31":1}}],["discard",{"0":{"659":1},"2":{"107":1,"109":1,"659":1}}],["disclaimer",{"2":{"71":1}}],["disclosure",{"2":{"34":1}}],["discussed",{"2":{"180":1}}],["discussion",{"2":{"43":2}}],["discussions",{"2":{"37":1,"50":1}}],["discuss",{"2":{"43":1,"46":1,"57":1,"195":1,"490":1}}],["discover",{"2":{"48":1}}],["discovering",{"2":{"43":1,"649":1}}],["discounts",{"2":{"40":1}}],["discord",{"0":{"55":1,"526":1},"2":{"11":1,"27":1,"45":2,"53":3,"54":1,"55":2,"317":1,"366":1,"367":2,"526":2,"591":1,"696":3,"728":1,"753":1,"765":2,"768":1,"781":2}}],["discretionary",{"2":{"30":1}}],["discretion",{"2":{"25":1,"30":1,"31":1,"34":1}}],["discrepancies",{"2":{"4":1}}],["debug",{"2":{"542":2,"661":4,"808":4}}],["debugging",{"2":{"90":1,"542":2}}],["denoted",{"2":{"469":2}}],["denominator",{"2":{"695":4}}],["denomination",{"0":{"513":1,"514":1},"2":{"513":2}}],["denominations",{"0":{"511":1},"1":{"512":1,"513":1,"514":1}}],["denominated",{"2":{"507":1}}],["denominate",{"2":{"85":1}}],["denom",{"2":{"296":2,"297":2,"301":2,"379":2,"380":2,"444":1,"445":1,"548":2,"576":4,"577":2,"579":4,"695":4}}],["deducting",{"2":{"428":1}}],["deducted",{"2":{"297":2,"301":2,"428":1}}],["dedicated",{"2":{"24":1,"37":1,"53":1,"245":1,"260":1}}],["demosubmitdata",{"2":{"437":2}}],["demo",{"0":{"133":1},"2":{"131":1,"133":1,"134":1,"135":4,"437":2}}],["demonstration",{"0":{"149":1,"609":1},"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},"2":{"366":1,"712":1}}],["demonstrating",{"2":{"8":1,"16":1}}],["demonstrate",{"2":{"44":1,"443":1}}],["degree",{"2":{"108":1,"109":1}}],["defer",{"2":{"171":4,"437":2}}],["defaultestimategas",{"2":{"430":1,"431":2,"437":2}}],["defaultgasprice",{"2":{"413":2,"436":2}}],["default",{"0":{"344":1},"2":{"110":2,"211":3,"214":3,"215":2,"225":1,"265":1,"270":3,"313":2,"314":2,"323":1,"324":2,"331":1,"343":2,"344":2,"351":1,"366":1,"370":2,"372":1,"377":2,"379":1,"391":1,"401":2,"413":2,"418":1,"419":3,"427":1,"429":1,"432":1,"436":2,"443":2,"491":1,"523":1,"524":2,"537":1,"539":1,"540":1,"542":2,"556":2,"557":6,"595":1,"596":1,"604":1,"605":1,"606":1,"608":1,"627":1,"628":1,"630":2,"633":1,"643":3,"646":4,"648":1,"655":1,"658":1,"659":1,"686":1,"687":1,"695":4,"718":1,"729":1,"730":1,"747":1,"748":1,"749":1,"759":1,"760":1,"761":1,"762":1,"763":1}}],["defaults",{"2":{"84":1,"366":1,"430":1,"537":1,"548":1,"658":1}}],["definitions",{"2":{"500":2}}],["defining",{"0":{"134":1},"2":{"135":1}}],["defines",{"2":{"803":1}}],["define",{"2":{"43":1,"134":2,"160":1,"184":1,"188":2,"196":1,"200":1,"203":1,"214":1,"265":1,"763":1}}],["defined",{"2":{"30":3,"31":1,"34":6,"84":1,"135":1,"151":1,"156":1,"165":1,"178":1,"180":1,"181":1,"203":1,"225":1,"500":2,"691":1,"803":1}}],["defi",{"2":{"43":1}}],["deeper",{"2":{"501":1}}],["deepen",{"2":{"65":1}}],["deep",{"0":{"394":1},"1":{"395":1,"396":1,"397":1,"398":1},"2":{"48":1,"59":1,"394":1}}],["deemed",{"2":{"13":1,"34":3}}],["deem",{"2":{"9":1,"12":1,"32":1}}],["decline",{"2":{"573":2}}],["declare",{"2":{"270":1,"276":1,"367":1,"538":1,"583":1,"605":1,"685":1}}],["decreasing",{"2":{"505":1}}],["decreases",{"2":{"495":1}}],["decentralised",{"0":{"496":1,"510":1},"1":{"497":1,"498":1},"2":{"510":2}}],["decentralized",{"2":{"235":1,"321":1}}],["decentralization",{"0":{"233":1},"2":{"752":1}}],["decouple",{"2":{"467":1}}],["decoupling",{"2":{"265":1,"266":1,"468":1}}],["decoding",{"2":{"166":1,"413":2,"695":4}}],["decode",{"2":{"208":1,"405":1,"413":2,"415":2,"416":1,"437":2}}],["decoder",{"2":{"202":1}}],["decoded",{"2":{"165":4,"376":1}}],["decodestring",{"2":{"157":2,"159":2,"413":2}}],["deciding",{"0":{"662":1},"1":{"663":1,"664":1}}],["decide",{"2":{"658":1}}],["decimal",{"2":{"219":1}}],["decimals",{"2":{"84":1,"313":2,"444":1,"445":1,"505":1}}],["decisions",{"2":{"9":1}}],["deck",{"2":{"44":2}}],["deal",{"2":{"470":1}}],["dealing",{"2":{"463":1}}],["dealer",{"2":{"34":1}}],["deadbeef",{"2":{"419":2}}],["deadline",{"2":{"24":2,"26":1}}],["derivation",{"2":{"695":4}}],["derivative",{"2":{"34":2}}],["derogatory",{"2":{"8":1}}],["descendants",{"2":{"464":2}}],["desc",{"2":{"393":2}}],["descriptor",{"2":{"617":1}}],["descriptors",{"2":{"617":1}}],["description=celestia",{"2":{"788":2,"790":2,"791":2,"792":2}}],["descriptions",{"2":{"84":2}}],["description",{"0":{"50":1},"2":{"42":1,"44":1,"47":3,"84":1,"429":1,"499":1,"548":6,"549":2,"595":1,"606":1,"691":1}}],["describing",{"2":{"466":1}}],["describes",{"2":{"134":2,"639":1,"693":1,"798":1}}],["described",{"2":{"21":1,"30":1,"31":1,"34":1,"166":1,"196":1,"469":3,"499":1,"500":1}}],["deserialization",{"0":{"200":1},"2":{"200":1,"203":1}}],["deserialize",{"2":{"199":1}}],["deserialized",{"2":{"107":1,"200":2}}],["desktop",{"2":{"89":1,"665":1,"666":1,"668":1}}],["destination",{"2":{"71":1,"591":1,"693":1}}],["desired",{"2":{"82":1,"243":1,"391":1,"480":1,"593":1,"621":1,"676":1}}],["desire",{"2":{"44":1}}],["designs",{"2":{"206":1}}],["design",{"0":{"602":1},"2":{"180":1,"235":1,"266":1,"557":1,"598":1,"602":1,"633":1}}],["designate",{"2":{"37":1}}],["designated",{"2":{"30":2}}],["designed",{"2":{"21":1,"49":1,"50":1,"57":1,"235":1,"354":1,"463":1,"754":2,"777":1}}],["delta",{"2":{"398":1}}],["deleting",{"2":{"544":2}}],["deleted",{"2":{"668":1}}],["delete",{"2":{"268":1,"544":2,"616":1,"653":1,"668":1}}],["delegate",{"0":{"551":1,"797":1},"2":{"551":3,"563":1,"797":5}}],["delegated",{"2":{"26":2,"264":1,"563":1,"577":4,"803":1}}],["delegating",{"2":{"501":1,"509":1}}],["delegation=1000000",{"2":{"803":3}}],["delegation=1",{"2":{"554":2}}],["delegations",{"2":{"21":1,"28":1}}],["delegation",{"0":{"18":1,"20":1},"1":{"19":1,"20":1,"21":2,"22":2,"23":2,"24":2,"25":2,"26":1,"27":1,"28":1,"29":1},"2":{"19":1,"23":4,"24":4,"25":1,"27":2,"494":2,"542":2}}],["delegators",{"2":{"494":1,"563":2}}],["delegator",{"2":{"471":1,"494":1}}],["delayedcelestia",{"2":{"583":1}}],["delayed",{"2":{"565":2,"576":7,"583":1}}],["delay",{"2":{"220":1,"695":4,"700":4}}],["delays",{"2":{"84":1}}],["delivering",{"2":{"65":1}}],["delivery",{"2":{"41":1}}],["delivers",{"2":{"19":1}}],["deprecated",{"2":{"161":1,"162":1,"172":2,"357":1,"362":1,"606":1}}],["depth",{"2":{"84":1,"495":1}}],["depositing",{"2":{"93":1}}],["deposited",{"2":{"91":2}}],["deposit",{"0":{"67":1,"69":1},"1":{"68":1,"69":1},"2":{"66":2,"69":2,"91":5,"548":5,"549":2}}],["dependent",{"2":{"143":1,"430":1,"651":1,"803":1}}],["dependency",{"0":{"400":1},"1":{"401":1},"2":{"126":1,"310":1,"323":1,"418":1}}],["dependencies",{"0":{"74":1,"279":1,"364":1,"406":1,"534":1,"637":1,"675":1,"681":1,"707":1},"1":{"365":1,"366":1,"367":1,"407":1,"408":1},"2":{"87":1,"312":1,"322":1,"364":1,"368":1,"406":1,"417":1,"534":1,"637":1,"662":1,"665":1,"681":1,"707":1,"723":1}}],["depend",{"2":{"89":1,"95":1,"235":1,"448":1,"451":1}}],["depending",{"2":{"40":1,"41":1,"65":1,"180":1,"224":1,"313":2,"411":1,"429":1,"519":1,"584":1,"594":1,"622":1,"648":1,"649":1,"658":1,"739":1,"754":1}}],["depends",{"2":{"34":1,"647":1,"738":1}}],["dependable",{"2":{"19":1}}],["deployer",{"2":{"120":2,"211":2,"285":2,"403":4}}],["deployed",{"0":{"213":1,"240":1},"1":{"214":1,"215":1,"216":1},"2":{"48":1,"84":2,"85":1,"89":1,"91":3,"120":3,"213":2,"214":1,"220":2,"227":1,"240":1,"242":1,"243":3,"244":1,"285":3,"306":2,"309":2,"310":2,"316":1,"357":1,"424":1,"516":1,"639":1,"691":1}}],["deployhelper",{"2":{"98":1,"99":1}}],["deploy",{"0":{"61":1,"73":1,"79":1,"85":1,"112":1,"211":1,"212":1,"217":1,"244":1,"278":1,"535":1,"798":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"80":1,"81":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,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"218":1,"219":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"287":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"799":1,"800":1,"801":1,"802":1},"2":{"61":1,"73":2,"74":1,"75":1,"83":1,"84":2,"85":3,"91":4,"101":1,"105":1,"111":1,"113":1,"120":2,"122":2,"209":1,"210":1,"211":8,"212":2,"213":1,"217":1,"219":6,"221":1,"224":2,"226":2,"230":1,"236":1,"244":2,"245":1,"250":1,"259":1,"260":1,"264":2,"278":1,"284":2,"285":1,"287":1,"308":1,"309":1,"310":1,"318":3,"337":1,"340":2,"402":1,"403":4,"424":2,"516":1,"754":1,"777":1,"779":1}}],["deployments",{"0":{"95":1,"98":1,"99":1,"209":1,"423":1},"1":{"96":1,"97":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"424":1},"2":{"89":1,"95":2,"96":1,"97":1,"211":3,"224":1,"225":1,"230":1,"236":2,"237":1,"242":1,"521":2,"740":2,"742":2,"758":2}}],["deployment",{"0":{"75":1,"83":1,"84":1,"219":1,"221":1,"308":1},"1":{"76":1},"2":{"30":2,"75":1,"79":2,"83":3,"84":4,"85":1,"120":1,"211":1,"217":4,"219":4,"221":1,"224":1,"226":1,"240":6,"243":1,"244":1,"285":1,"308":1,"318":1,"424":1}}],["deploying",{"0":{"118":1,"210":1,"264":1,"283":1,"309":1,"310":1,"318":1,"402":1,"403":1,"424":1},"1":{"119":1,"120":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"284":1,"285":1,"319":1,"320":1,"321":1},"2":{"3":1,"61":1,"79":1,"82":1,"113":1,"211":1,"213":1,"214":1,"217":1,"219":2,"256":1,"264":2,"304":1,"308":1,"310":1,"315":1,"403":1,"423":1,"424":1,"508":2,"733":1,"774":1}}],["deter",{"2":{"563":1}}],["deterministic",{"2":{"467":1}}],["determining",{"2":{"12":1,"429":1}}],["determined",{"2":{"137":1,"430":1,"738":3}}],["determines",{"2":{"84":1}}],["determine",{"2":{"33":1,"36":1,"41":2,"43":1,"48":1,"324":1,"419":1,"500":1,"519":1,"739":1,"754":1}}],["detecting",{"2":{"649":1}}],["detection",{"2":{"608":1}}],["detects",{"2":{"443":1}}],["detected",{"2":{"139":1}}],["detect",{"2":{"33":1,"135":1}}],["details",{"0":{"27":1,"177":1,"182":1,"517":1,"577":1,"578":1,"735":1,"755":1},"1":{"518":1},"2":{"21":1,"47":1,"69":2,"71":1,"72":2,"85":1,"94":1,"146":1,"148":1,"149":1,"177":1,"178":1,"184":1,"191":1,"192":1,"196":1,"200":1,"203":4,"206":1,"243":1,"315":1,"357":1,"358":1,"362":1,"430":1,"461":1,"464":1,"466":2,"470":1,"480":1,"505":1,"563":1,"573":1,"577":1,"578":1,"606":1,"608":1}}],["detailed",{"2":{"2":1,"22":1,"47":1,"79":1,"224":1,"488":1,"548":1}}],["devs",{"2":{"499":1}}],["devnpm",{"2":{"316":1}}],["devnetl1",{"2":{"398":1}}],["devnet",{"0":{"73":1,"120":1,"394":1,"402":1,"515":1,"525":1,"566":1,"567":1,"568":1,"570":1,"572":1,"576":1,"577":1,"578":1,"579":1,"777":1,"778":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"395":1,"396":1,"397":1,"398":1,"516":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1,"526":2,"527":2,"528":1,"529":1,"567":1,"568":2,"569":2,"570":2,"571":2,"572":1,"573":2,"574":2,"575":2,"576":2,"577":2,"578":2,"579":2,"778":1},"2":{"74":1,"111":1,"113":1,"114":1,"119":3,"122":1,"284":1,"340":2,"366":1,"367":1,"398":1,"399":1,"402":2,"443":2,"444":2,"515":1,"516":1,"519":1,"521":1,"524":1,"526":1,"537":1,"561":2,"565":1,"568":1,"569":1,"570":1,"571":4,"579":1,"580":1,"583":1,"587":1,"628":1,"639":2,"685":2,"691":1,"728":1,"754":1,"777":2,"785":1,"800":1}}],["devcd",{"2":{"75":1,"318":1}}],["devrel",{"2":{"41":1,"43":1}}],["developing",{"2":{"685":1}}],["development",{"0":{"302":1,"674":1},"1":{"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1,"675":1,"676":1},"2":{"79":1,"84":2,"264":1,"311":1,"499":2,"621":1,"674":2,"754":1,"774":1}}],["developer",{"2":{"24":1,"45":1,"68":1,"175":1,"256":1,"352":1,"441":1,"602":1,"705":1}}],["developers",{"2":{"3":1,"84":1,"105":2,"230":2,"237":1,"245":1,"247":2,"248":1,"256":1,"258":1,"265":1,"266":3,"290":1,"337":1,"353":1,"442":1,"488":1,"490":1,"492":1,"499":1,"507":2,"508":3,"515":1,"516":1,"754":1,"777":1,"779":1}}],["develop",{"2":{"24":1,"44":1}}],["devops",{"2":{"24":1,"399":1,"601":1}}],["dev",{"2":{"1":1,"75":1,"77":4,"102":1,"169":2,"316":1,"318":1,"319":4,"675":4,"788":2,"790":2,"791":2,"792":2}}],["devyarn",{"2":{"1":1}}],["yum",{"2":{"675":4}}],["ysudo",{"2":{"675":3}}],["yconfirm",{"2":{"803":1}}],["ycelestia",{"2":{"550":1,"552":1}}],["ycd",{"2":{"115":1,"280":1}}],["yparity",{"2":{"396":2}}],["yield",{"2":{"208":1}}],["y33zld2luvedelzzr9cf92+2etaimiwhn9pcaqaszwpqckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwoha36hewmw",{"2":{"161":2}}],["yh2zdyne9u",{"2":{"156":2}}],["yhcdb4cz7z4lrxmvrq5f8=",{"2":{"151":2}}],["y91da3zryfzmc7l",{"2":{"156":2}}],["y",{"2":{"115":1,"280":1,"550":1,"552":1,"576":9,"675":3,"803":4}}],["yamlversion",{"2":{"277":1}}],["yamlextra",{"2":{"89":1}}],["yarncd",{"2":{"311":1}}],["yarn",{"2":{"1":2,"75":4,"87":1,"91":2,"311":1,"312":1,"318":4}}],["ymlglobal",{"2":{"557":1}}],["yml",{"2":{"89":1,"277":2,"398":1,"557":3,"558":1}}],["yet",{"2":{"91":2,"137":1,"210":1,"393":1,"623":1,"648":1}}],["yesterday",{"2":{"553":2}}],["yescelestia",{"2":{"300":1}}],["yes",{"2":{"48":1,"300":1,"494":1,"548":1,"561":2,"576":1}}],["years",{"2":{"31":1,"774":1}}],["year",{"2":{"25":1,"26":1,"34":4,"495":2,"500":11,"505":2}}],["youth",{"2":{"573":2}}],["youtube",{"2":{"40":1,"46":2}}],["yours",{"2":{"569":1}}],["yourself",{"2":{"34":1,"557":2}}],["yourprivatekey",{"2":{"91":3}}],["your",{"0":{"66":1,"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"73":1,"83":1,"84":1,"85":1,"86":2,"87":1,"89":1,"90":1,"91":1,"112":1,"116":1,"117":1,"118":1,"121":1,"276":1,"281":1,"282":1,"283":1,"286":1,"379":1,"381":1,"382":1,"401":1,"410":1,"411":1,"472":1,"474":1,"476":1,"477":1,"479":1,"481":1,"483":1,"485":1,"486":1,"533":1,"574":1,"576":1,"582":1,"585":1,"607":1,"614":1,"624":1,"680":1,"717":1,"718":1,"723":1,"786":1,"804":1},"1":{"67":1,"68":2,"69":2,"70":1,"71":2,"72":2,"74":1,"75":1,"76":1,"77":1,"78":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":2,"120":2,"121":1,"122":1,"284":1,"285":1,"534":1,"608":1,"609":1,"610":1,"611":1,"612":1,"613":1,"681":1,"724":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1},"2":{"2":5,"5":1,"24":2,"25":1,"27":5,"30":5,"31":5,"32":7,"33":9,"34":15,"35":1,"40":4,"41":7,"42":6,"43":11,"44":14,"45":15,"46":7,"47":8,"48":1,"50":1,"53":1,"55":1,"56":2,"57":1,"63":1,"65":3,"66":2,"68":2,"69":7,"71":7,"72":4,"73":1,"74":1,"75":3,"76":2,"77":2,"78":2,"80":1,"82":2,"83":3,"84":11,"85":13,"86":8,"87":1,"88":6,"89":16,"90":3,"91":20,"92":5,"113":1,"114":1,"115":1,"116":2,"117":2,"119":1,"121":1,"122":2,"149":1,"212":1,"213":1,"214":1,"215":2,"224":2,"238":4,"243":1,"244":1,"250":1,"259":1,"260":1,"262":1,"267":1,"270":3,"272":1,"275":1,"276":2,"277":3,"279":1,"280":1,"281":2,"282":2,"285":2,"286":1,"293":5,"294":1,"295":1,"296":2,"300":5,"304":4,"310":2,"312":1,"314":6,"315":2,"316":3,"317":3,"318":6,"319":2,"320":2,"323":6,"324":1,"340":1,"341":1,"356":1,"365":2,"366":2,"367":6,"369":3,"370":1,"371":3,"372":5,"373":5,"376":3,"381":1,"382":1,"386":1,"387":1,"391":2,"392":1,"393":1,"397":1,"398":2,"399":1,"401":2,"402":1,"403":6,"407":5,"408":1,"410":1,"411":1,"418":6,"424":5,"426":2,"440":1,"444":1,"445":1,"475":1,"476":1,"480":1,"486":1,"494":1,"502":1,"503":1,"515":1,"519":1,"521":1,"524":3,"530":1,"537":3,"538":3,"542":4,"545":1,"550":1,"551":1,"552":1,"553":7,"554":2,"555":1,"556":3,"557":3,"559":2,"565":1,"570":1,"571":2,"573":5,"576":1,"579":1,"581":1,"582":1,"583":1,"585":1,"590":2,"591":2,"593":1,"594":3,"595":3,"596":2,"597":2,"598":4,"602":1,"604":2,"606":3,"609":6,"614":5,"617":1,"618":1,"621":1,"622":3,"623":2,"624":2,"630":2,"639":4,"641":2,"643":1,"644":1,"645":1,"646":2,"647":1,"651":1,"654":1,"656":1,"658":1,"659":1,"661":5,"665":2,"667":2,"668":2,"669":1,"673":1,"674":1,"675":1,"676":3,"681":1,"685":7,"696":1,"705":1,"709":1,"711":1,"712":1,"714":2,"715":3,"718":3,"719":2,"725":2,"726":1,"727":3,"728":1,"732":1,"739":1,"740":1,"748":3,"750":2,"754":1,"758":1,"785":2,"788":1,"797":2,"800":1,"803":9,"804":2,"805":1,"808":5}}],["you",{"2":{"0":2,"2":1,"4":1,"24":3,"26":1,"27":6,"30":6,"31":23,"32":9,"33":4,"34":29,"35":4,"36":1,"39":1,"40":4,"41":7,"42":4,"43":3,"45":1,"46":3,"47":11,"48":8,"53":2,"54":1,"56":2,"57":2,"60":1,"61":1,"63":2,"64":1,"65":4,"68":1,"69":3,"71":3,"72":3,"75":1,"76":8,"77":3,"78":1,"79":4,"82":1,"83":1,"84":2,"85":5,"86":1,"87":1,"89":9,"90":2,"91":4,"92":1,"102":4,"103":1,"107":5,"108":2,"109":1,"113":1,"116":1,"119":1,"120":2,"122":2,"126":1,"134":1,"135":2,"148":2,"172":3,"177":1,"211":13,"212":3,"213":1,"214":2,"217":1,"219":1,"220":4,"222":1,"223":1,"224":6,"225":3,"228":1,"236":1,"237":1,"240":1,"242":1,"244":2,"248":1,"250":2,"255":2,"256":5,"258":1,"262":3,"267":3,"269":1,"270":6,"271":1,"276":4,"277":2,"281":1,"284":1,"285":2,"287":3,"292":4,"293":1,"294":1,"296":1,"297":1,"302":4,"303":2,"306":1,"309":2,"310":3,"313":2,"314":2,"316":6,"317":2,"318":10,"319":3,"320":1,"322":2,"323":5,"324":1,"325":1,"326":1,"327":3,"333":1,"340":1,"341":2,"346":1,"347":1,"351":2,"357":2,"362":4,"364":1,"366":4,"367":11,"368":3,"369":7,"370":1,"371":3,"372":4,"373":2,"374":1,"376":3,"377":3,"380":1,"386":3,"387":1,"391":1,"392":2,"393":2,"396":1,"398":1,"399":2,"401":4,"402":2,"403":5,"404":2,"405":5,"407":4,"408":1,"411":1,"413":1,"415":4,"416":3,"417":2,"418":5,"419":1,"420":1,"421":3,"424":2,"431":1,"443":2,"444":6,"445":4,"447":1,"471":3,"477":2,"481":2,"486":2,"494":1,"512":1,"515":1,"519":3,"521":2,"525":1,"526":1,"528":1,"537":3,"538":8,"540":1,"541":1,"543":1,"545":3,"548":2,"550":1,"551":2,"552":1,"553":2,"554":3,"556":6,"557":10,"559":3,"565":1,"566":1,"569":1,"570":2,"571":2,"572":2,"573":3,"576":4,"577":1,"578":1,"579":3,"580":1,"581":1,"583":2,"584":3,"585":4,"586":1,"587":1,"588":1,"589":1,"590":4,"591":2,"592":1,"593":4,"594":3,"595":3,"596":3,"597":1,"598":1,"601":1,"602":2,"604":1,"606":5,"609":5,"614":2,"616":2,"617":2,"618":5,"619":1,"621":4,"622":3,"623":3,"624":2,"626":1,"627":1,"630":3,"631":1,"634":1,"639":7,"641":1,"645":3,"646":3,"649":2,"651":7,"654":1,"655":2,"656":1,"658":3,"659":2,"661":3,"662":2,"663":3,"664":2,"665":5,"667":4,"668":10,"669":3,"670":1,"673":1,"675":1,"676":2,"677":1,"681":1,"682":1,"685":9,"687":1,"688":2,"692":5,"695":3,"696":1,"697":1,"698":2,"699":1,"700":3,"705":3,"706":1,"707":1,"708":1,"709":2,"710":3,"711":1,"712":1,"714":2,"715":5,"716":4,"718":6,"719":2,"720":2,"726":1,"727":6,"728":3,"730":1,"732":1,"739":4,"748":2,"749":1,"750":2,"751":1,"754":8,"760":3,"765":2,"767":1,"769":2,"772":1,"776":1,"782":2,"783":3,"784":2,"785":5,"787":1,"788":2,"790":2,"791":2,"792":1,"793":2,"797":8,"798":2,"799":1,"800":2,"802":1,"803":11,"808":3}}],["ahzu6yr9xmpixlquhgbhj9xl3wiaoz6pe3cvml",{"2":{"574":2,"578":2}}],["ahead",{"2":{"41":1,"139":1,"317":1}}],["a5jf",{"2":{"573":2,"574":2}}],["away",{"2":{"508":1,"691":1}}],["await",{"2":{"314":14,"419":6,"420":8,"421":6,"443":4}}],["awareness",{"2":{"36":1}}],["awards",{"2":{"30":1,"34":1}}],["award",{"2":{"30":4}}],["a1",{"2":{"277":2}}],["aztec",{"2":{"223":17}}],["aka",{"2":{"195":1,"217":1,"225":1,"432":1}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaecawqfbgcicra=",{"2":{"391":2,"397":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaba==",{"2":{"156":2,"161":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaap8aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaazz5aj1mijjrowjdcifyjkr0pcroiu2jigmd9bzuhzro",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaeaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqs98k+8wq2ix2bdctfohjtrqbqybtpdb1bufy",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaabxaaaacbaagroagqgaqqdaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseqovy2vszxn0awexdwc1zwt0mmnjn250dzrkdg1zzdlsn3n0ctbzn3z5ztd5btjyzhishqaaaaaaaaaaaaaaaaaaaaaaaaasexiyqkmkmoizggkxaiigrflow1m",{"2":{"161":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqbaaacugaaacbaagrnagqfaqqcaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmseaovy2vszxn0awexywxwngzwbhf5d21jnmn1adl5mzvly2xychf5cwf4mjn2z3zrczushqaaaaaaaaaaaaaaaaaaaaaaaaaaaagicagicagiggfeiiazloeqsgxg3row7sr1rkq7dvjygp3axkaqy4og6hyc0eibabjnclikrgofl2nvc21vcy5jcnlwdg8uc2vjcdi1nmsxllb1yktlerijcieca4ief8fzeabqlvc2wocefs+lhak0mdnmpnsxylkqv7qsbaoccaey5pebehekcwoedxrpyridmtyweltvbbpa7xbbsgyfrwtzcfhq3va1vhtbriczyd0elkajo6klsdooeqcwovaguwtdp55v8btf3wc7",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaqaaaaaaeuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5rt0t52lwq3l0fnm6kqqka7nrxfnm8zc",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaaaaaaaaaaaaaaaaaaaaaaaaaaaafhmtties5ru6k2enim7thjqycl82hsxpinycelhed9qk+p9zbnide",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouu=",{"2":{"156":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaaejpdcbnowap3dm=",{"2":{"376":8,"612":2}}],["aaaaaaaaaaaaaaaaaaaaaaaaabitejjcqyqyijkaaaaaaaaaaaaaaaaaaaaaaaaaehmsmkjdjdkimbiwnpodwizbfr0uifhpkwgy",{"2":{"161":2}}],["axtrw6s+qsnuzfgfeg37da6igop2zqck+04egqkaggbgaisewoncgr1dglheguymtawmbdq6awaqclylqpnrfod6h8mgmwxjfenhwhru39ecrvkmfknq8+hhuodhdoqig",{"2":{"161":2}}],["airdrop",{"2":{"525":1,"765":1}}],["ai",{"2":{"405":1,"502":1,"503":1,"742":1,"743":1,"744":1,"748":1,"752":1}}],["aiming",{"2":{"235":1}}],["aims",{"2":{"50":1,"331":1}}],["aim",{"2":{"43":1,"235":1}}],["aid",{"2":{"35":1,"452":1}}],["aura",{"2":{"562":2}}],["augments",{"2":{"470":1,"531":1}}],["aunt",{"2":{"153":4}}],["aunts",{"2":{"151":2,"153":4,"156":2,"161":2,"168":5,"169":4,"172":8}}],["audible",{"2":{"40":1}}],["audience",{"0":{"42":1},"2":{"40":1,"42":3,"43":1,"44":1,"45":1,"46":1}}],["authcelestia",{"2":{"407":1}}],["authentication",{"2":{"355":1,"370":1,"371":5,"372":1,"414":2,"608":2}}],["authenticated",{"2":{"184":1,"208":1}}],["authorize",{"2":{"560":1}}],["authorization",{"2":{"314":4,"370":1,"391":2,"397":2}}],["authority",{"2":{"84":1,"314":2}}],["authorities",{"2":{"34":1}}],["auth",{"0":{"371":1,"373":1},"2":{"89":10,"314":4,"323":5,"331":1,"369":2,"370":5,"371":9,"372":2,"373":7,"374":4,"376":2,"379":1,"391":7,"397":2,"407":1,"412":4,"413":4,"415":4,"418":5,"429":1,"548":2,"576":2,"578":2}}],["automate",{"2":{"608":1}}],["automated",{"2":{"440":1}}],["automatically",{"2":{"24":1,"84":1,"324":1,"351":1,"377":1,"419":1,"431":1,"437":2,"563":1}}],["autoconnect",{"2":{"313":2}}],["autogenerated",{"2":{"276":1}}],["auto",{"2":{"84":2,"313":2,"314":4,"550":2,"552":2,"576":6,"695":2}}],["amd",{"2":{"676":1}}],["amd64",{"2":{"594":1,"622":1,"676":12}}],["amanda",{"2":{"545":2}}],["amazonaws",{"2":{"223":16}}],["amountceles",{"2":{"554":1}}],["amount=1000000utia",{"2":{"803":2}}],["amount=9000000utia",{"2":{"715":2}}],["amount=5000000000000utia",{"2":{"554":2}}],["amount=",{"2":{"554":2,"713":2}}],["amount",{"0":{"71":1,"484":1},"2":{"41":1,"69":1,"84":1,"226":1,"295":3,"296":2,"297":2,"379":2,"380":2,"386":3,"429":1,"430":1,"451":1,"459":1,"468":1,"476":1,"480":1,"484":1,"500":2,"547":2,"548":2,"549":2,"551":4,"554":3,"576":8,"577":2,"579":4,"659":2,"713":2,"714":1,"715":3,"803":1}}],["amounts",{"2":{"34":1}}],["among",{"2":{"34":1,"37":1,"41":1,"466":1,"467":1,"531":1,"690":1}}],["amended",{"2":{"31":1}}],["ample",{"2":{"45":1}}],["amp",{"0":{"4":1,"85":1,"493":1,"551":1},"1":{"494":1,"495":1,"496":1,"497":1,"498":1,"499":1,"500":1},"2":{"1":4,"2":2,"44":1,"59":1,"60":1,"61":1,"65":1,"75":12,"85":1,"115":8,"151":2,"153":14,"156":1,"159":2,"161":2,"165":6,"166":2,"170":10,"171":2,"172":10,"224":8,"227":1,"280":8,"304":1,"314":12,"316":4,"318":4,"419":10,"420":8,"421":6,"499":3,"500":5,"531":1,"557":1,"581":4,"618":2,"675":10,"790":4,"791":4}}],["affect",{"2":{"440":1,"617":1}}],["affected",{"2":{"8":1}}],["affordable",{"2":{"46":1}}],["affiliated",{"2":{"44":1}}],["affirm",{"2":{"34":1}}],["after=network",{"2":{"788":2,"790":2,"791":2,"792":2}}],["afterwards",{"2":{"25":1}}],["after",{"0":{"38":1,"297":1},"2":{"23":2,"24":2,"34":1,"40":1,"45":1,"46":1,"69":1,"71":2,"72":2,"79":1,"84":2,"86":1,"88":1,"90":1,"94":1,"117":1,"173":1,"181":1,"212":1,"213":1,"219":1,"220":1,"282":1,"297":1,"301":1,"366":1,"376":1,"413":2,"415":1,"439":1,"477":1,"481":1,"486":1,"491":1,"537":1,"545":1,"563":2,"594":1,"614":1,"622":1,"627":1,"647":1,"651":1,"657":1,"658":1,"659":1,"661":1,"668":1,"675":2,"690":1,"695":1,"697":1,"716":1,"792":1,"797":1,"803":2,"804":1,"808":1}}],["agnostic",{"2":{"466":1}}],["ago",{"2":{"276":2,"277":2}}],["again",{"2":{"76":1,"318":1,"393":1,"407":1,"432":1,"470":1,"609":1,"614":1,"701":1}}],["against",{"2":{"31":3,"89":1,"128":1,"131":2,"236":1,"243":1,"616":1}}],["agreement",{"2":{"31":2,"34":3,"262":1}}],["agree",{"2":{"30":1,"31":5,"32":1,"33":1,"34":1,"467":1}}],["agreeing",{"2":{"30":1,"33":1,"34":2,"467":1}}],["ag",{"2":{"30":1}}],["aggression",{"2":{"16":1}}],["agenda",{"2":{"36":1}}],["agendas",{"2":{"5":1,"36":1}}],["agent",{"2":{"34":1}}],["age",{"2":{"7":1,"31":1}}],["avril14th",{"2":{"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["average",{"2":{"443":2,"445":1}}],["avoid",{"2":{"41":1,"44":1,"45":1,"89":1,"403":2,"430":1,"557":1,"668":1,"696":1}}],["avoiding",{"2":{"14":1,"19":1}}],["availability",{"0":{"232":1,"385":1,"446":1,"447":1,"448":1,"449":1,"450":1,"451":1,"455":1,"460":1,"461":1,"466":1,"470":1,"523":1,"524":1,"732":1,"746":1,"747":1,"748":1,"759":1,"760":1,"771":1,"789":1},"1":{"233":1,"234":1,"235":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"454":1,"455":1,"456":1,"457":1,"458":1,"459":1,"461":1,"462":2,"463":2,"464":1,"465":1,"466":1,"747":1,"748":1,"749":1,"750":1,"790":1,"791":1,"792":1},"2":{"34":1,"36":1,"42":1,"43":1,"59":1,"83":1,"105":2,"109":1,"110":2,"129":1,"131":1,"174":3,"188":1,"191":1,"203":1,"230":2,"233":2,"234":1,"235":2,"246":1,"262":1,"265":2,"288":2,"290":1,"300":1,"333":2,"337":1,"338":2,"359":1,"403":1,"447":7,"448":3,"449":5,"450":4,"451":1,"452":1,"455":1,"456":1,"457":1,"460":4,"463":1,"467":1,"468":5,"469":1,"488":1,"490":2,"491":1,"507":1,"508":1,"521":1,"530":1,"531":2,"597":1,"602":1,"622":1,"654":2,"663":2,"720":2,"721":1,"734":1,"749":1,"754":1,"769":4,"783":2,"792":1,"798":2}}],["available",{"2":{"5":1,"17":2,"22":1,"30":2,"33":1,"34":6,"35":1,"37":1,"46":2,"56":1,"109":1,"131":1,"183":1,"187":1,"188":1,"236":2,"258":1,"261":1,"306":1,"324":1,"328":1,"422":1,"450":2,"455":1,"457":1,"460":1,"461":2,"466":1,"467":1,"469":3,"470":4,"488":2,"492":2,"500":2,"527":1,"542":2,"548":1,"556":2,"594":3,"622":3,"655":3,"658":1,"659":2,"738":1,"749":1}}],["aria2",{"2":{"675":4}}],["aria2c",{"2":{"650":6}}],["arise",{"2":{"456":1}}],["arises",{"2":{"448":1}}],["arm",{"2":{"676":1}}],["arm64",{"2":{"594":1,"622":1,"676":12}}],["armored",{"2":{"271":1,"545":2}}],["arrived",{"2":{"591":1}}],["array",{"2":{"313":1,"419":3,"633":1}}],["arranging",{"2":{"37":1}}],["arranges",{"2":{"469":1}}],["arranged",{"2":{"461":1,"467":1}}],["arrange",{"2":{"36":2,"42":1,"43":1}}],["arrangement",{"2":{"34":1,"467":1}}],["arg",{"2":{"542":2}}],["args",{"2":{"369":3,"372":2,"412":8,"413":8,"415":8,"669":4,"670":4}}],["arguments",{"2":{"196":1,"369":1,"411":2,"412":5,"413":5,"415":2}}],["argument",{"2":{"117":1,"200":1,"203":1,"282":1}}],["architectnodes",{"2":{"695":2,"761":1,"762":1,"763":1}}],["architecture",{"2":{"602":1}}],["architectures",{"2":{"302":1,"468":1,"594":1,"622":1}}],["archives",{"2":{"742":1,"743":1,"744":1}}],["archive",{"2":{"524":1,"645":1,"742":1,"743":1,"744":1,"748":1}}],["archival",{"0":{"749":1,"750":1},"1":{"750":1},"2":{"24":1,"28":1,"491":3,"492":5,"749":2,"750":1}}],["arabicaversions",{"2":{"593":2,"621":2,"667":2,"669":2,"670":2}}],["arabicaresturl",{"2":{"443":2}}],["arabicarpcurl",{"2":{"443":2}}],["arabicachainid",{"2":{"376":1,"401":2,"443":2,"444":1,"605":1,"639":6,"650":2}}],["arabicacelestia",{"2":{"365":1,"366":2,"367":1,"407":1,"537":1,"538":1,"539":1,"684":1,"686":1,"725":1,"726":1,"727":1,"729":1}}],["arabica",{"0":{"515":1,"525":1,"612":1,"777":1,"778":1},"1":{"516":1,"517":1,"518":1,"519":1,"520":1,"521":1,"522":1,"523":1,"524":1,"525":1,"526":2,"527":2,"528":1,"529":1,"778":1},"2":{"270":2,"344":2,"349":2,"365":1,"366":5,"367":3,"371":3,"383":2,"407":9,"413":3,"443":6,"444":6,"515":2,"516":3,"519":1,"521":12,"524":5,"526":2,"527":1,"528":3,"537":2,"538":5,"539":1,"591":1,"605":2,"608":1,"612":1,"618":1,"639":3,"667":1,"684":1,"685":4,"686":1,"691":1,"692":3,"725":1,"726":4,"727":3,"728":1,"729":1,"754":1,"777":3,"779":1,"785":2,"800":1}}],["artifacts",{"0":{"222":1},"1":{"223":1,"224":1},"2":{"212":1}}],["arfge6qnxuiz18vlglgewtw",{"2":{"156":4}}],["arbitrary",{"2":{"135":2,"549":1}}],["arbitrum",{"0":{"73":1,"79":1,"82":1,"96":1,"98":1,"104":1,"112":1,"120":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"80":1,"81":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,"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1},"2":{"66":1,"68":1,"69":3,"71":4,"73":3,"74":1,"75":2,"79":4,"80":3,"81":1,"82":3,"83":1,"85":5,"88":6,"89":1,"91":2,"93":1,"95":1,"96":1,"101":3,"102":2,"105":5,"106":1,"107":1,"109":1,"110":2,"111":1,"113":1,"122":2,"225":1,"237":1,"240":2,"288":1}}],["arb",{"2":{"75":2,"120":2}}],["around",{"0":{"454":1},"2":{"13":1,"49":1,"302":1,"448":1,"454":1,"456":1,"602":1,"663":1,"719":1}}],["areas",{"2":{"38":1,"43":1,"48":1}}],["area",{"2":{"37":1,"42":1,"43":1,"44":1,"45":1,"48":1}}],["aren",{"2":{"35":1,"583":1}}],["are",{"0":{"451":1,"459":1,"616":1},"2":{"9":2,"11":1,"17":1,"19":1,"21":2,"23":2,"24":3,"26":1,"30":2,"31":7,"32":2,"33":2,"34":8,"35":1,"36":1,"39":2,"41":1,"42":2,"48":3,"50":1,"52":1,"59":1,"65":1,"66":1,"76":1,"84":3,"85":1,"88":1,"89":4,"91":2,"107":1,"108":1,"116":1,"117":1,"127":2,"128":2,"134":1,"135":3,"136":1,"137":1,"139":3,"143":1,"145":1,"146":3,"148":3,"151":1,"153":2,"156":1,"160":1,"161":1,"165":1,"167":2,"168":2,"170":2,"172":2,"173":1,"177":2,"182":1,"183":1,"187":1,"188":1,"189":1,"194":1,"195":1,"196":2,"197":1,"200":1,"203":1,"206":1,"208":1,"211":5,"212":1,"213":1,"219":1,"220":2,"222":1,"224":5,"227":2,"233":1,"234":1,"240":1,"242":1,"248":2,"256":1,"258":2,"261":2,"262":1,"264":1,"265":1,"266":1,"270":3,"276":2,"281":1,"282":1,"297":1,"302":2,"306":1,"318":1,"321":1,"324":3,"325":1,"326":1,"331":1,"333":1,"334":2,"336":2,"338":2,"339":1,"351":1,"352":1,"353":1,"363":1,"365":1,"366":3,"369":1,"370":1,"371":1,"372":1,"373":2,"393":1,"396":1,"397":1,"402":1,"403":2,"406":1,"420":1,"428":2,"429":3,"430":1,"432":1,"436":2,"439":1,"441":2,"449":1,"451":4,"454":1,"456":1,"457":1,"458":1,"460":3,"461":3,"462":1,"463":2,"466":1,"467":3,"469":4,"470":1,"488":1,"489":2,"491":1,"492":2,"495":1,"500":4,"515":1,"519":1,"520":1,"525":1,"528":1,"532":1,"537":1,"538":1,"543":2,"548":5,"549":2,"553":1,"554":1,"555":1,"556":2,"557":3,"563":1,"565":1,"571":1,"576":1,"583":1,"585":2,"591":1,"594":1,"595":3,"601":1,"604":1,"606":3,"608":4,"614":2,"616":3,"622":1,"628":1,"630":1,"635":1,"639":1,"648":1,"649":2,"651":2,"658":1,"659":6,"663":1,"664":1,"665":1,"667":1,"675":4,"676":1,"678":1,"679":1,"685":2,"688":1,"690":1,"691":2,"692":2,"693":1,"698":1,"714":1,"719":1,"722":1,"726":1,"739":1,"740":1,"751":1,"753":1,"754":3,"758":1,"760":1,"764":1,"765":1,"767":1,"768":1,"769":1,"779":1,"781":1,"783":2,"785":1,"787":2,"794":1,"798":1,"800":1,"803":6}}],["abstain",{"2":{"548":1}}],["abbreviation",{"2":{"505":1}}],["abci",{"0":{"659":1},"2":{"466":1,"659":8}}],["abci++",{"2":{"466":1,"469":1}}],["abigen",{"2":{"145":1}}],["abi",{"2":{"77":1,"153":2,"164":2,"172":2,"311":1,"314":4,"319":1}}],["ability",{"2":{"30":1,"110":1,"178":1,"448":1,"452":1,"453":1,"563":1,"685":2,"726":2}}],["able",{"2":{"34":3,"40":2,"41":1,"65":1,"71":2,"72":1,"88":1,"89":1,"134":2,"148":1,"178":1,"192":1,"194":1,"199":1,"213":1,"220":1,"264":1,"401":1,"413":1,"416":1,"432":1,"444":1,"445":1,"449":1,"452":1,"464":2,"491":1,"559":1,"602":1,"777":1,"788":1,"790":1,"791":1,"792":1,"803":1}}],["abusive",{"2":{"11":1}}],["about",{"0":{"338":1},"1":{"339":1},"2":{"3":1,"8":1,"17":1,"21":1,"30":2,"33":1,"36":1,"42":1,"43":1,"48":5,"49":1,"65":1,"71":1,"79":2,"84":1,"92":1,"105":1,"107":1,"108":1,"116":1,"134":2,"146":1,"220":2,"243":1,"246":1,"262":1,"281":1,"292":1,"302":1,"340":1,"341":1,"361":1,"362":1,"369":2,"376":1,"377":1,"404":1,"431":1,"454":1,"455":1,"456":2,"510":1,"519":1,"529":1,"542":2,"573":1,"594":1,"621":1,"622":1,"665":2,"739":1,"749":1,"750":1,"753":2,"768":2,"769":1,"781":2}}],["above",{"2":{"2":1,"24":1,"31":1,"34":1,"75":2,"83":1,"89":1,"103":1,"120":1,"139":1,"142":1,"148":3,"163":1,"164":1,"166":1,"171":1,"172":1,"173":1,"178":1,"181":1,"195":1,"200":1,"206":1,"211":1,"219":1,"318":2,"373":1,"374":1,"376":3,"379":1,"429":1,"437":2,"466":1,"469":2,"521":1,"524":1,"531":1,"549":1,"576":1,"624":1,"661":1,"668":1,"714":1,"715":1,"727":1,"808":1}}],["atomic",{"2":{"468":1}}],["atlas",{"2":{"94":1}}],["atmosphere",{"2":{"40":1,"41":1}}],["at",{"0":{"499":1,"505":1},"1":{"500":1},"2":{"10":1,"11":1,"17":3,"24":1,"27":1,"30":2,"33":1,"34":2,"40":2,"41":2,"42":2,"43":1,"44":3,"45":1,"46":1,"48":1,"80":1,"82":1,"91":1,"95":1,"116":1,"119":1,"131":2,"133":1,"163":2,"169":4,"189":1,"208":1,"220":1,"221":1,"224":3,"225":2,"226":1,"227":1,"230":1,"236":1,"247":1,"261":1,"281":1,"305":1,"308":1,"313":1,"324":3,"325":2,"326":7,"327":3,"339":1,"376":1,"403":1,"413":4,"419":3,"420":5,"421":1,"426":2,"432":1,"436":2,"451":1,"454":1,"461":3,"463":1,"466":1,"469":1,"470":3,"494":1,"495":2,"498":1,"499":1,"500":6,"501":1,"505":1,"523":1,"524":1,"527":1,"539":1,"540":1,"542":4,"557":2,"559":1,"561":2,"569":1,"586":1,"594":1,"595":1,"602":1,"606":1,"618":1,"622":1,"645":1,"649":1,"686":1,"687":1,"691":1,"692":2,"694":1,"696":1,"714":1,"715":1,"729":1,"730":1,"734":1,"747":1,"748":1,"759":1,"760":1,"777":1,"791":1}}],["attach",{"2":{"557":2}}],["attack",{"2":{"448":3,"451":1}}],["attacks",{"2":{"8":1,"84":1}}],["attempting",{"2":{"698":1}}],["attempt",{"2":{"447":1}}],["attesting",{"2":{"169":1}}],["attestations",{"2":{"234":2,"288":1}}],["attestation",{"2":{"163":2,"169":4}}],["attestationproof",{"0":{"169":1},"2":{"163":6,"169":6,"172":4}}],["attests",{"2":{"148":1}}],["attested",{"2":{"127":2,"240":1}}],["attended",{"2":{"45":1}}],["attendees",{"2":{"36":3,"37":4,"38":3,"40":2,"41":2,"42":2,"43":2,"45":1,"46":1,"48":1,"52":1,"65":2}}],["attending",{"2":{"45":2}}],["attend",{"2":{"42":1,"46":3}}],["attendance",{"2":{"36":1,"38":1,"42":3,"45":2}}],["attention",{"2":{"8":1,"403":1}}],["attributes",{"2":{"156":4}}],["attribution",{"0":{"17":1}}],["attracting",{"2":{"45":1}}],["attract",{"2":{"42":1,"43":1}}],["ad5ezbg0",{"2":{"391":2}}],["adoption",{"2":{"302":1}}],["adopted",{"2":{"34":1}}],["adjusted",{"2":{"429":1,"430":1}}],["adjust",{"2":{"266":1,"618":1}}],["adr019",{"2":{"495":1}}],["adrs",{"2":{"466":1,"531":1}}],["adr",{"2":{"178":1,"602":2}}],["adapt",{"2":{"148":1,"163":1}}],["adapted",{"2":{"17":1,"81":1,"500":1}}],["admin",{"2":{"89":2,"371":4,"373":2,"391":2,"403":4,"557":1}}],["administrative",{"2":{"84":1,"353":1}}],["adhere",{"2":{"52":1}}],["adhering",{"2":{"24":1}}],["adventure",{"2":{"405":1}}],["advertise",{"2":{"656":1}}],["advertising",{"2":{"34":1}}],["adverse",{"2":{"32":1}}],["advantages",{"2":{"208":1}}],["advanced",{"0":{"389":1,"664":1},"2":{"416":1}}],["advance",{"2":{"41":1,"45":1,"692":1}}],["advances",{"2":{"8":1,"236":1}}],["advice",{"2":{"32":3}}],["advise",{"2":{"760":1}}],["advised",{"2":{"604":1,"639":1}}],["adviser",{"2":{"32":1}}],["advisable",{"2":{"32":1,"426":1}}],["addnetworkkeplr",{"2":{"443":17}}],["adds",{"2":{"429":1,"469":1,"618":1}}],["addcustomprover",{"2":{"215":1,"216":2}}],["addblock",{"2":{"137":2,"139":4}}],["addrs",{"2":{"381":2}}],["addr",{"2":{"89":1,"437":4,"556":2,"614":2,"695":8}}],["addressed",{"2":{"302":1}}],["addresses",{"2":{"84":2,"89":3,"92":1,"119":1,"300":1,"348":1,"424":1}}],["addresscelestia",{"2":{"296":1,"298":1,"347":1,"382":1}}],["address=$",{"2":{"656":2,"718":2}}],["address=$evm",{"2":{"554":2}}],["address=address",{"2":{"581":4}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"575":1}}],["address=celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5export",{"2":{"575":1}}],["address=celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"575":2}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0d",{"2":{"386":1}}],["address=celestia1c425ckmve2489atttx022qpc02gxspa29wmh0dexport",{"2":{"386":1}}],["address=0x5fbdb2315678afecb367f032d93f642f64180aa3",{"2":{"120":1,"285":1}}],["address=0x5fbdb2315678afecb367f032d93f642f64180aa3export",{"2":{"120":1,"285":1}}],["address=",{"2":{"75":2,"293":4,"300":4,"309":2,"310":2,"318":2,"554":2,"557":1}}],["address",{"0":{"347":1,"380":1,"382":1,"613":1,"656":1},"2":{"8":1,"10":1,"24":1,"27":3,"33":2,"44":1,"75":3,"76":8,"77":2,"84":8,"89":6,"91":4,"98":1,"99":1,"121":4,"134":1,"153":2,"170":2,"171":2,"172":2,"211":9,"212":2,"213":21,"215":1,"216":4,"218":2,"219":6,"220":4,"227":2,"240":1,"277":4,"286":4,"293":4,"295":2,"296":3,"298":1,"300":8,"301":2,"306":10,"309":10,"310":8,"314":10,"315":1,"316":4,"318":11,"319":2,"344":1,"346":1,"347":3,"366":1,"367":7,"370":1,"380":9,"382":2,"383":8,"386":2,"396":1,"407":4,"424":2,"437":2,"444":1,"445":1,"526":5,"537":1,"538":2,"547":10,"549":1,"554":5,"556":2,"573":3,"574":4,"575":3,"576":16,"577":5,"578":5,"579":4,"582":1,"583":4,"591":2,"595":2,"596":2,"606":1,"608":1,"613":2,"639":2,"655":1,"656":8,"685":2,"695":4,"712":1,"717":8,"718":4,"727":2,"728":5,"765":5,"797":2}}],["added",{"2":{"84":1,"91":2,"110":1,"314":4,"348":1,"416":1,"447":1,"557":2,"560":1,"714":1,"716":1}}],["addition",{"2":{"34":1,"40":1,"457":1,"470":1,"508":1,"631":1}}],["additionally",{"2":{"33":1,"45":1,"89":1,"106":1,"107":2,"110":1,"135":1,"461":1,"497":1}}],["additional",{"0":{"34":1,"98":1,"99":1,"390":1,"806":1},"1":{"391":1,"392":1,"393":1},"2":{"32":1,"34":1,"38":1,"44":1,"46":1,"96":1,"97":1,"105":1,"134":1,"197":1,"312":1,"355":1,"369":1,"429":1,"463":1,"477":1,"481":1,"486":1,"806":1}}],["adding",{"0":{"315":1,"444":1,"445":1,"714":1},"2":{"2":1,"91":2,"266":1,"544":2,"558":1,"696":1,"697":1}}],["add",{"0":{"68":1,"87":1,"216":1,"443":1,"696":1,"713":1,"718":1},"2":{"5":1,"45":1,"47":1,"68":1,"83":1,"89":2,"135":2,"139":4,"214":1,"216":1,"268":1,"270":6,"272":6,"312":1,"314":4,"315":2,"323":1,"333":1,"349":2,"366":1,"367":2,"411":1,"418":3,"442":2,"443":6,"444":4,"445":3,"492":1,"500":1,"537":1,"542":4,"544":2,"554":5,"557":1,"561":8,"565":1,"573":2,"581":5,"590":2,"598":1,"609":1,"630":1,"676":1,"691":1,"695":1,"696":6,"701":3,"712":2,"713":2,"716":1,"717":1,"727":2}}],["apt",{"2":{"675":6}}],["aptyummac",{"2":{"675":1}}],["aptyum",{"2":{"675":1}}],["apache",{"2":{"127":2}}],["api",{"0":{"328":1,"352":1,"353":1,"356":1,"357":1,"358":1,"387":1,"422":1,"433":1,"436":1,"743":1,"762":1},"1":{"353":1,"354":2,"355":2,"356":2,"357":1,"358":2,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"48":1,"88":1,"211":6,"212":4,"219":6,"227":3,"312":4,"328":1,"333":2,"352":5,"353":4,"354":1,"355":1,"357":2,"358":1,"359":1,"366":1,"368":1,"370":1,"371":1,"372":2,"387":1,"405":3,"406":1,"408":3,"411":2,"412":3,"413":2,"416":1,"422":1,"436":1,"438":2,"444":1,"445":1,"458":1,"492":2,"520":1,"521":3,"548":1,"597":1,"654":1,"663":1,"694":1,"740":1,"743":21,"758":1,"762":18}}],["apology",{"2":{"13":1}}],["apologizing",{"2":{"8":1}}],["appcelestia",{"2":{"653":1,"710":1}}],["appcd",{"2":{"593":1}}],["appconsts",{"2":{"159":6,"437":4}}],["appdsudo",{"2":{"788":2}}],["appd",{"0":{"300":1},"1":{"301":1},"2":{"300":2,"301":2,"434":2,"437":2,"542":4,"543":2,"544":8,"545":6,"546":6,"547":10,"548":10,"549":4,"550":2,"551":4,"552":2,"554":10,"561":18,"569":2,"570":2,"573":2,"574":2,"576":6,"577":2,"578":2,"579":4,"581":8,"583":4,"590":6,"591":4,"593":5,"594":5,"639":12,"651":9,"653":2,"657":1,"658":1,"659":1,"661":1,"703":3,"710":3,"711":2,"712":2,"713":2,"715":2,"716":3,"718":2,"719":2,"787":1,"788":15,"797":4,"803":13,"808":1}}],["append",{"2":{"127":2,"139":2}}],["appendix",{"0":{"93":1},"1":{"94":1,"95":1,"96":1,"97":1,"98":1,"99":1},"2":{"89":1}}],["appear",{"2":{"91":1,"476":1,"557":1}}],["appearance",{"2":{"7":1}}],["appeal",{"2":{"42":1}}],["app",{"0":{"434":1,"469":1,"483":1,"565":1,"588":1,"592":1,"638":1,"705":1,"708":1,"784":1,"788":1},"1":{"470":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1,"589":1,"590":1,"591":1,"593":1,"594":1,"595":1,"706":1,"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1},"2":{"77":1,"88":2,"153":2,"159":4,"161":1,"162":1,"165":4,"166":4,"172":6,"313":6,"314":5,"316":5,"319":1,"333":1,"383":4,"428":2,"431":2,"432":1,"437":20,"439":1,"466":6,"469":1,"470":2,"502":1,"503":1,"520":1,"531":3,"542":2,"557":4,"563":1,"565":1,"566":1,"568":3,"569":8,"570":2,"573":4,"574":2,"576":6,"577":2,"578":2,"579":4,"580":1,"588":1,"589":1,"592":1,"593":12,"594":4,"595":1,"638":1,"639":13,"643":1,"645":1,"646":2,"649":1,"650":18,"651":4,"653":1,"655":2,"656":2,"658":1,"659":1,"661":1,"677":1,"692":1,"693":1,"705":1,"708":1,"710":1,"714":1,"715":1,"716":3,"717":1,"737":1,"738":1,"740":1,"758":1,"769":1,"784":3,"785":2,"788":1,"791":1,"798":1,"803":3,"808":1}}],["appreciate",{"2":{"48":1,"52":1}}],["appreciation",{"2":{"43":2}}],["approximate",{"2":{"692":1}}],["approximately",{"2":{"71":1,"72":1}}],["approximation",{"2":{"429":1,"738":1}}],["approving",{"2":{"71":1}}],["approvedprovers",{"2":{"424":1}}],["approve",{"2":{"69":1,"72":1,"83":1,"476":1}}],["approval",{"2":{"53":1,"476":1}}],["approaching",{"2":{"426":1}}],["approaches",{"2":{"173":1}}],["approach",{"2":{"42":1,"43":1,"44":1,"195":1,"202":1,"208":1,"519":1,"739":1,"754":1}}],["appropriate",{"2":{"9":2,"135":2,"324":1,"419":1,"488":1,"617":1,"695":1}}],["apple",{"2":{"594":1,"622":1,"676":1}}],["applicable",{"2":{"25":2,"27":1,"31":1,"33":1,"34":9,"36":1}}],["applicant",{"2":{"23":1}}],["applicants",{"2":{"23":8,"24":2,"26":2}}],["applications",{"2":{"24":1,"26":1,"28":3,"245":1,"247":2,"250":1,"261":1,"265":2,"266":2,"341":1,"362":2,"458":1,"464":1,"490":1,"492":1,"515":1,"733":1,"774":1,"786":1,"788":1}}],["application",{"0":{"26":1,"27":1},"1":{"27":1},"2":{"21":3,"24":3,"27":1,"265":2,"266":1,"302":1,"309":1,"311":1,"316":1,"362":1,"391":2,"397":2,"424":1,"428":2,"432":1,"464":7,"466":3,"508":1,"531":1,"542":10,"558":1,"590":1,"617":1,"650":1,"658":1}}],["applies",{"2":{"10":2,"103":1,"351":1}}],["applying",{"2":{"27":1,"38":1,"461":1}}],["apply",{"2":{"21":1,"25":1,"26":1,"34":1,"467":1,"598":1,"649":1}}],["appointed",{"2":{"10":1}}],["acelestia",{"2":{"797":1}}],["achieve",{"2":{"347":1}}],["achieved",{"2":{"50":1,"558":1,"641":1}}],["acquire",{"0":{"82":1},"2":{"82":1}}],["acquaintances",{"2":{"44":1,"45":1}}],["across",{"2":{"47":2,"107":1,"165":1,"265":1,"499":1,"704":1}}],["acknowledging",{"2":{"44":1}}],["acknowledge",{"2":{"31":4,"34":4}}],["accurately",{"2":{"430":1,"613":1}}],["accurate",{"2":{"428":1}}],["accuracy",{"2":{"33":1,"34":1}}],["accomplish",{"2":{"277":1}}],["accommodate",{"2":{"36":1}}],["accordingly",{"2":{"48":1,"89":1,"344":1,"618":1}}],["according",{"2":{"41":1,"236":1}}],["accordance",{"2":{"33":1,"34":3}}],["accountexport",{"2":{"581":1}}],["accounted",{"2":{"429":1}}],["accountname",{"2":{"437":2}}],["accountaddress",{"2":{"369":1}}],["accounts",{"0":{"119":1,"579":1},"2":{"91":5,"120":1,"153":2,"172":2,"284":1,"292":1,"293":1,"309":1,"429":1,"560":4,"561":2,"579":1,"586":1}}],["account",{"0":{"297":1,"301":1,"382":1,"386":1,"432":1,"565":1,"572":1,"576":1,"577":1,"578":1,"582":1,"583":1,"713":1},"1":{"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":2,"574":2,"575":2,"576":2,"577":2,"578":2,"579":2,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1},"2":{"10":1,"34":4,"74":1,"76":2,"84":2,"88":3,"91":9,"211":5,"290":2,"291":2,"292":6,"293":4,"296":1,"297":2,"300":7,"301":1,"304":1,"312":1,"316":2,"318":3,"379":2,"382":3,"393":4,"401":2,"403":10,"407":4,"408":2,"429":3,"432":1,"437":6,"444":1,"445":1,"456":1,"542":4,"548":4,"554":3,"561":10,"565":3,"571":1,"572":1,"573":2,"576":12,"577":11,"578":6,"579":3,"580":2,"581":4,"583":4,"587":2,"605":1,"685":1,"695":4,"696":1,"713":2,"726":1}}],["accessed",{"2":{"655":1}}],["accessing",{"2":{"454":1,"455":1}}],["accessibility",{"2":{"302":1}}],["accessible",{"2":{"36":1,"65":1,"236":1,"269":4,"454":1,"595":2,"606":2}}],["access",{"0":{"524":1,"645":1,"748":1,"760":1},"2":{"31":4,"42":1,"43":1,"53":2,"56":1,"65":1,"90":1,"145":1,"179":1,"193":1,"202":1,"211":2,"230":1,"291":1,"353":1,"354":1,"366":1,"391":1,"429":1,"443":2,"449":1,"453":1,"454":2,"458":2,"486":1,"492":4,"520":4,"524":2,"537":1,"685":2,"726":1,"740":4,"748":1,"758":4,"760":1}}],["accepts",{"2":{"109":1,"220":1,"470":2}}],["accept",{"2":{"30":1,"196":1,"428":1,"432":1,"470":1,"556":2,"654":1}}],["accepted",{"2":{"23":1,"108":1}}],["acceptable",{"2":{"9":1}}],["accepting",{"2":{"8":2}}],["actors",{"2":{"458":1}}],["acts",{"2":{"211":1}}],["actually",{"2":{"336":1,"447":1}}],["actual",{"2":{"135":3,"137":1,"146":1,"182":1,"223":1,"429":1,"495":1}}],["activating",{"2":{"690":1,"691":1}}],["activation",{"2":{"398":1}}],["activate",{"2":{"402":1,"630":1}}],["activatecd",{"2":{"402":1}}],["activity",{"2":{"90":1}}],["activities",{"2":{"25":1,"33":3,"36":1,"37":1,"64":1}}],["active",{"2":{"21":1,"24":3,"27":2,"55":1,"276":1,"277":1,"531":1}}],["acting",{"2":{"10":1,"34":1}}],["actions",{"2":{"14":1,"31":2,"135":4}}],["action",{"2":{"9":1,"12":1,"31":1,"156":2,"369":1}}],["act",{"2":{"7":1,"31":3,"34":13,"563":1}}],["aside",{"2":{"500":1}}],["async",{"2":{"314":6,"419":2,"420":1,"421":1,"443":2}}],["ascii",{"2":{"271":1,"545":2}}],["asked",{"2":{"52":1,"208":1,"754":1}}],["ask",{"2":{"40":1,"43":1,"44":1,"443":2,"470":1}}],["aspects",{"2":{"47":1,"65":1}}],["aspect",{"2":{"31":1}}],["assumption",{"2":{"430":1,"451":2,"454":1,"618":1}}],["assumptions",{"0":{"451":1},"2":{"233":1,"454":1,"608":1}}],["assumed",{"2":{"451":1,"513":1}}],["assumes",{"2":{"224":2,"391":1,"430":1,"451":1,"597":1,"621":1}}],["assume",{"2":{"135":1,"211":1,"265":1,"407":1}}],["assurances",{"0":{"459":1},"2":{"34":2}}],["assign",{"2":{"84":1,"554":1}}],["assist",{"2":{"46":1,"47":1}}],["assistance",{"2":{"45":1,"47":1}}],["associated",{"2":{"24":1,"32":1,"45":1,"169":2,"338":1,"346":1,"379":1,"469":2}}],["asset",{"2":{"507":1}}],["assets",{"2":{"8":1,"251":1}}],["assert",{"2":{"200":1,"306":1,"419":6}}],["asserted",{"2":{"196":2}}],["asserteq",{"2":{"117":4,"282":4,"306":9}}],["asserts",{"2":{"117":1,"282":1}}],["assertion",{"2":{"306":2}}],["assertions",{"2":{"84":3}}],["asserting",{"2":{"117":1,"282":1}}],["assessing",{"2":{"38":1}}],["assess",{"2":{"21":1,"42":1}}],["as",{"0":{"104":1,"259":1,"295":1,"296":1,"298":1,"392":1,"718":1,"786":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"299":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1},"2":{"7":1,"8":2,"10":1,"14":2,"23":1,"24":2,"30":5,"31":3,"32":1,"34":10,"36":1,"40":2,"42":1,"43":3,"44":2,"45":2,"47":1,"50":1,"54":1,"56":1,"57":1,"65":3,"71":1,"75":2,"76":1,"84":1,"85":2,"86":2,"89":1,"91":1,"107":2,"108":2,"111":1,"119":1,"120":1,"126":1,"128":1,"131":1,"134":5,"135":2,"136":2,"139":1,"142":1,"145":1,"148":1,"156":1,"161":2,"162":2,"163":1,"164":1,"165":2,"166":3,"167":1,"168":1,"171":2,"172":5,"178":1,"184":1,"187":1,"189":2,"192":1,"193":1,"195":1,"196":3,"197":1,"200":6,"203":2,"206":1,"208":1,"211":3,"212":2,"213":1,"217":1,"219":3,"220":2,"222":1,"224":2,"230":1,"233":1,"235":1,"236":2,"242":2,"243":1,"246":1,"250":1,"264":6,"285":1,"288":2,"293":2,"301":1,"306":4,"309":5,"310":1,"318":3,"323":3,"325":1,"326":1,"329":1,"331":2,"332":1,"338":5,"340":1,"353":2,"354":1,"355":2,"365":1,"369":3,"373":1,"374":2,"386":1,"391":1,"395":1,"396":2,"399":1,"408":1,"411":1,"412":2,"413":2,"415":2,"416":1,"418":3,"419":1,"420":1,"428":2,"429":1,"430":2,"432":1,"437":2,"439":1,"447":2,"450":2,"451":1,"453":1,"454":1,"457":2,"461":4,"463":3,"464":4,"466":1,"467":5,"469":3,"470":3,"471":1,"490":3,"491":4,"492":4,"494":1,"498":1,"500":2,"508":3,"509":1,"510":1,"516":1,"524":1,"531":1,"538":1,"541":1,"542":2,"548":1,"549":1,"555":1,"557":5,"558":1,"560":1,"569":1,"575":3,"576":1,"577":1,"581":1,"583":1,"590":2,"595":1,"601":1,"602":1,"605":1,"606":1,"608":2,"612":1,"613":1,"633":1,"643":1,"649":1,"650":1,"651":1,"673":1,"685":4,"688":1,"689":1,"694":3,"703":1,"705":1,"713":1,"717":1,"718":1,"726":2,"731":1,"733":1,"734":1,"737":2,"738":1,"754":1,"762":1,"777":1,"779":1,"785":1,"786":1,"787":1,"788":1,"792":1,"797":2,"798":1,"802":1,"804":1}}],["anger",{"2":{"573":2}}],["anchoring",{"2":{"314":1}}],["analogously",{"2":{"129":1}}],["analogous",{"2":{"128":1}}],["analog",{"2":{"127":2}}],["analytics",{"0":{"752":1,"766":1},"2":{"752":2,"766":1}}],["analysis",{"2":{"192":1}}],["analyse",{"2":{"33":1}}],["analyze",{"2":{"38":1}}],["anvil",{"0":{"284":1},"2":{"120":1,"284":4,"309":3}}],["another",{"0":{"380":1,"386":1,"540":1,"687":1,"730":1},"2":{"84":1,"91":2,"179":1,"192":1,"276":1,"277":1,"288":1,"292":1,"293":1,"306":2,"366":1,"380":1,"428":1,"469":1,"537":1,"547":1,"563":1,"633":1,"678":1,"704":1,"798":1}}],["answer",{"2":{"48":1,"414":1,"576":1}}],["answers",{"2":{"17":1,"47":1,"447":1}}],["annual",{"2":{"495":2}}],["annually",{"2":{"495":1,"505":1}}],["announced",{"2":{"45":1,"692":1}}],["announce",{"2":{"45":1}}],["announcements",{"2":{"753":1,"768":1,"781":2}}],["announcement",{"2":{"45":1,"529":1,"753":1,"754":1,"768":1,"781":1}}],["announcing",{"2":{"45":2}}],["anniversary",{"2":{"34":3}}],["anticipate",{"2":{"42":1}}],["anticipation",{"2":{"31":1}}],["an",{"0":{"71":1,"79":1,"88":1,"221":1,"295":1,"327":1,"350":1,"392":1,"399":1,"403":1,"421":1,"654":1,"661":1,"808":1},"1":{"80":1,"81":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,"400":1,"401":1,"402":1,"403":1,"404":1,"655":1,"656":1,"657":1},"2":{"4":1,"7":1,"10":5,"13":1,"16":1,"22":1,"24":4,"27":1,"30":1,"31":3,"34":9,"37":1,"40":1,"42":1,"43":2,"44":1,"47":1,"52":1,"53":2,"55":1,"59":1,"60":1,"61":1,"65":1,"69":2,"71":1,"73":1,"74":1,"76":2,"82":1,"84":2,"85":1,"88":4,"91":1,"92":1,"101":1,"105":2,"107":1,"108":1,"109":1,"110":2,"111":1,"117":1,"126":1,"128":1,"131":2,"133":1,"135":4,"136":2,"145":1,"150":1,"153":2,"160":2,"164":1,"165":2,"166":1,"168":1,"169":3,"170":2,"172":4,"180":1,"181":2,"184":1,"187":2,"188":1,"191":1,"208":2,"211":6,"212":1,"217":3,"219":3,"221":1,"226":1,"227":1,"230":2,"231":1,"237":1,"245":1,"247":3,"265":1,"277":2,"282":1,"285":1,"288":2,"303":2,"305":1,"306":4,"309":1,"312":1,"314":2,"318":2,"321":1,"323":2,"324":1,"327":1,"340":1,"355":1,"366":2,"371":1,"372":1,"373":2,"374":3,"376":2,"380":1,"381":1,"382":1,"383":1,"386":1,"393":1,"403":1,"404":1,"405":1,"406":1,"407":1,"408":6,"412":2,"413":3,"415":2,"418":2,"419":2,"421":1,"424":2,"428":1,"429":3,"431":1,"432":1,"437":2,"448":1,"451":3,"460":1,"464":4,"466":1,"467":6,"468":1,"469":1,"470":1,"494":1,"495":1,"501":1,"505":1,"507":1,"514":1,"524":2,"531":2,"533":1,"537":2,"538":1,"542":4,"545":1,"549":2,"554":1,"555":1,"557":1,"558":1,"563":1,"583":3,"584":1,"590":1,"593":1,"594":1,"598":1,"599":1,"600":1,"602":2,"604":1,"608":2,"612":1,"614":3,"617":1,"622":1,"633":1,"636":1,"645":1,"658":1,"659":1,"661":3,"665":1,"667":3,"669":1,"680":1,"685":1,"690":1,"692":1,"694":2,"700":1,"715":1,"723":1,"738":1,"748":1,"795":1,"797":2,"803":1,"808":3}}],["anyway",{"2":{"357":1,"362":1,"606":1}}],["anything",{"2":{"189":1,"401":1,"696":1}}],["anytrust",{"2":{"83":1,"84":1,"105":1,"107":1}}],["anyone",{"2":{"116":1,"281":1,"337":1,"447":1,"468":1,"693":1}}],["any",{"2":{"4":1,"8":1,"9":1,"11":1,"12":1,"15":1,"16":1,"24":4,"25":1,"27":1,"30":5,"31":19,"32":4,"33":2,"34":36,"36":3,"37":2,"45":2,"48":1,"89":1,"133":1,"183":1,"208":1,"210":1,"215":1,"217":1,"230":1,"262":1,"264":1,"266":2,"268":1,"296":1,"315":1,"333":1,"335":1,"336":1,"369":1,"401":1,"424":1,"426":1,"447":1,"462":1,"509":1,"525":2,"542":2,"557":4,"593":1,"614":1,"621":1,"624":1,"627":1,"633":1,"649":1,"703":1,"734":1,"749":1,"765":2,"772":1,"797":1}}],["and",{"0":{"39":1,"41":1,"45":1,"66":1,"75":1,"86":1,"87":1,"90":1,"100":1,"224":1,"233":1,"235":1,"246":1,"274":1,"306":1,"314":1,"324":1,"332":1,"333":1,"367":1,"403":1,"407":1,"419":1,"427":1,"428":1,"440":1,"455":1,"475":1,"477":1,"480":1,"481":1,"484":1,"490":1,"491":1,"516":1,"545":1,"563":1,"596":1,"611":1,"612":1,"633":1,"640":1,"669":1,"727":1,"734":1,"757":1,"764":1},"1":{"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"76":1,"101":1,"102":1,"103":1,"275":1,"276":1,"277":1,"428":1,"429":2,"430":2,"431":2,"432":1,"491":1,"492":1,"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"728":1,"758":1,"759":1,"760":1},"2":{"0":1,"1":1,"2":4,"3":3,"5":1,"7":5,"8":8,"9":6,"10":1,"11":3,"13":1,"19":3,"21":2,"22":1,"23":3,"24":11,"26":1,"27":10,"28":2,"30":7,"31":20,"32":3,"33":11,"34":37,"36":12,"37":7,"38":6,"39":1,"40":6,"41":9,"42":7,"43":6,"44":8,"45":11,"46":11,"47":4,"48":3,"50":4,"52":4,"53":2,"54":1,"56":2,"57":3,"58":1,"59":1,"60":1,"61":1,"62":1,"63":2,"64":2,"65":10,"66":3,"71":3,"72":1,"73":1,"75":4,"78":1,"79":5,"80":3,"83":2,"84":13,"85":4,"86":3,"87":1,"88":6,"89":1,"90":2,"91":5,"92":2,"94":2,"101":1,"103":1,"105":2,"107":9,"108":3,"109":1,"113":2,"114":1,"115":1,"116":1,"117":4,"119":5,"120":1,"128":1,"130":1,"131":9,"133":3,"134":3,"135":8,"136":3,"137":1,"139":10,"141":1,"145":1,"146":5,"148":4,"149":2,"150":1,"153":2,"154":2,"156":2,"159":1,"160":2,"165":5,"166":2,"168":3,"169":4,"170":4,"171":2,"172":4,"173":3,"174":1,"175":2,"177":3,"178":1,"181":3,"182":2,"183":2,"184":5,"187":3,"188":3,"189":2,"191":1,"192":5,"194":1,"195":2,"196":3,"200":4,"203":2,"205":1,"206":2,"208":4,"211":8,"212":4,"213":3,"214":3,"217":3,"218":1,"219":6,"220":3,"223":2,"224":5,"225":3,"226":2,"227":1,"228":1,"230":4,"235":5,"236":4,"237":1,"238":1,"242":4,"243":1,"244":4,"247":1,"248":1,"250":1,"251":1,"252":1,"254":1,"255":2,"256":3,"258":1,"261":2,"262":4,"265":4,"266":2,"268":1,"270":1,"271":1,"279":1,"280":1,"281":1,"282":4,"284":1,"285":1,"288":3,"292":1,"293":1,"296":1,"300":2,"302":4,"306":8,"309":1,"310":3,"311":3,"312":3,"314":11,"315":1,"316":2,"317":1,"318":5,"320":1,"322":1,"323":1,"324":3,"326":2,"327":1,"329":1,"331":5,"332":2,"333":1,"335":2,"336":1,"337":3,"338":4,"339":1,"341":2,"343":1,"344":1,"348":1,"351":2,"352":2,"353":4,"354":1,"355":1,"357":1,"359":1,"362":3,"364":1,"365":2,"366":2,"368":1,"369":2,"370":1,"371":2,"373":1,"374":4,"376":1,"377":2,"386":2,"388":1,"391":1,"392":1,"393":1,"395":1,"396":1,"398":2,"399":3,"401":4,"402":1,"403":1,"405":3,"407":4,"408":2,"410":1,"411":4,"412":5,"413":19,"414":4,"415":7,"416":1,"417":1,"418":2,"419":2,"421":1,"424":1,"425":1,"426":1,"428":2,"429":3,"430":6,"431":3,"432":2,"433":1,"437":14,"440":1,"441":2,"442":3,"443":2,"444":3,"445":4,"447":2,"448":3,"451":1,"452":1,"453":3,"454":2,"455":2,"456":2,"457":4,"459":2,"460":3,"461":4,"462":1,"463":3,"464":8,"466":3,"467":9,"468":2,"469":7,"470":3,"471":2,"474":1,"475":1,"476":1,"479":1,"480":2,"483":1,"484":1,"485":1,"488":4,"489":1,"490":4,"491":1,"492":4,"494":2,"495":2,"497":4,"499":6,"500":3,"501":1,"508":1,"510":1,"512":1,"513":1,"515":2,"521":1,"524":1,"530":1,"531":5,"537":1,"538":1,"540":1,"542":6,"545":2,"548":5,"549":2,"555":3,"557":9,"558":1,"561":2,"563":8,"564":1,"565":1,"566":2,"568":1,"569":2,"573":1,"575":1,"576":2,"577":1,"580":1,"581":1,"582":1,"585":1,"587":1,"589":1,"592":1,"593":2,"595":2,"596":1,"598":2,"602":1,"606":3,"608":7,"611":3,"612":2,"613":2,"614":1,"615":1,"616":1,"617":2,"618":2,"619":1,"621":7,"623":1,"624":1,"626":1,"628":1,"630":1,"639":1,"641":1,"643":1,"645":1,"647":2,"648":1,"649":3,"650":1,"654":1,"656":1,"658":2,"659":4,"661":2,"663":1,"665":2,"666":2,"668":1,"669":1,"674":1,"675":4,"676":2,"678":2,"685":1,"687":1,"691":2,"692":4,"693":4,"694":1,"695":2,"696":1,"697":2,"698":5,"701":2,"704":1,"705":1,"716":1,"721":1,"724":1,"725":1,"726":1,"730":1,"733":2,"734":4,"738":4,"748":2,"754":2,"760":1,"761":1,"763":2,"764":1,"769":2,"772":1,"774":4,"777":1,"782":1,"783":2,"784":1,"785":3,"788":1,"790":1,"791":3,"792":1,"798":1,"803":3,"804":1,"808":2}}],["alias",{"0":{"514":1},"2":{"514":1,"546":2}}],["alignitems",{"2":{"314":4}}],["align",{"2":{"44":1}}],["aligned",{"2":{"9":1,"24":1}}],["algorithm",{"2":{"466":1}}],["alertmanager",{"2":{"557":2}}],["alerts",{"0":{"559":1},"2":{"557":2,"559":1}}],["alert",{"2":{"443":4}}],["alerting",{"2":{"27":1}}],["although",{"2":{"470":3}}],["alt",{"2":{"402":1,"403":1,"404":1}}],["alternatives",{"2":{"648":1}}],["alternatively",{"2":{"119":1,"139":2,"192":1,"199":1,"212":1,"218":1,"226":1,"326":1,"347":1,"369":1,"413":1,"463":1,"470":1}}],["alternative",{"2":{"110":1,"180":1,"181":1,"221":1}}],["along",{"2":{"135":1,"148":1,"169":1,"172":2,"212":1,"237":1,"242":1,"309":1,"366":1,"405":1,"488":1}}],["alongside",{"2":{"48":1,"105":1,"693":1}}],["alphab",{"2":{"502":1,"503":1,"742":1,"743":1,"744":1,"748":1,"752":1}}],["alpha",{"2":{"94":1,"149":2,"227":1}}],["alchemy",{"2":{"88":3}}],["alcohol",{"2":{"41":1}}],["already",{"2":{"24":1,"46":1,"47":1,"50":1,"89":1,"160":1,"210":1,"217":1,"225":2,"322":1,"332":1,"362":1,"364":1,"368":1,"417":1,"432":1,"464":1,"559":1,"572":1,"597":1,"630":1,"633":1,"676":1,"698":1,"699":1,"701":1,"710":1}}],["also",{"2":{"10":1,"24":1,"41":3,"44":1,"45":1,"46":2,"48":1,"69":1,"84":2,"109":1,"136":1,"139":2,"149":1,"152":1,"156":2,"177":1,"191":1,"195":1,"202":1,"217":1,"220":2,"223":1,"224":1,"236":1,"244":1,"270":1,"276":1,"277":1,"288":1,"294":1,"306":4,"309":1,"313":1,"355":1,"366":1,"369":1,"372":1,"374":1,"403":1,"405":1,"413":1,"443":2,"464":1,"469":1,"470":1,"510":1,"531":2,"555":1,"558":1,"563":1,"571":1,"583":1,"601":1,"628":1,"649":2,"663":1,"664":1,"714":1,"715":1,"725":1,"754":1,"760":1,"779":1,"783":1,"784":1}}],["allocation",{"0":{"499":1},"1":{"500":1},"2":{"499":1,"500":1}}],["allocating",{"2":{"46":1}}],["allocated",{"2":{"499":1,"500":1,"549":1}}],["allocate",{"2":{"41":1}}],["allotting",{"2":{"43":1}}],["allowance",{"0":{"295":1,"296":1,"298":1},"1":{"299":1},"2":{"293":1,"301":1}}],["allowances",{"0":{"293":1,"300":1},"1":{"294":1,"295":1,"301":1},"2":{"300":1}}],["allowing",{"2":{"47":1,"300":1,"703":1,"754":1}}],["allow",{"2":{"44":2,"84":1,"90":1,"178":1,"206":1,"214":1,"215":1,"230":2,"236":1,"248":1,"337":1,"372":1,"443":2,"447":1,"492":3,"523":1,"595":1,"596":1,"602":2,"606":1,"634":1,"668":1,"695":4,"701":4,"720":1,"747":1,"759":1,"761":1,"762":1,"763":1,"793":1}}],["allows",{"2":{"23":1,"46":2,"47":1,"84":1,"105":1,"109":2,"110":1,"116":1,"129":1,"131":1,"150":1,"160":1,"174":1,"176":1,"179":1,"181":1,"183":1,"185":1,"187":2,"215":2,"219":1,"226":1,"281":1,"292":1,"313":1,"314":3,"323":1,"333":1,"338":1,"353":1,"362":1,"377":1,"401":1,"418":1,"443":1,"462":1,"471":1,"510":1,"559":1,"595":2,"606":2,"608":1,"617":1,"654":1,"659":1,"665":1,"718":1,"762":1,"783":2,"784":2}}],["allowed",{"2":{"15":1,"300":2}}],["alleged",{"2":{"31":1}}],["all",{"0":{"273":1,"643":1},"2":{"3":1,"5":2,"10":1,"11":2,"27":2,"32":1,"33":1,"34":1,"47":1,"48":1,"52":3,"64":1,"76":1,"91":2,"134":2,"173":1,"177":1,"211":1,"224":1,"230":1,"236":3,"262":1,"264":3,"265":2,"266":1,"306":3,"314":2,"318":1,"325":1,"326":5,"348":1,"351":3,"365":1,"370":1,"376":6,"411":1,"413":1,"419":2,"420":5,"429":1,"430":1,"431":1,"437":2,"441":1,"447":3,"449":3,"450":1,"456":1,"464":3,"467":3,"470":1,"491":1,"492":1,"498":1,"500":1,"516":1,"524":1,"542":1,"546":1,"573":2,"586":1,"590":1,"595":1,"606":1,"619":1,"641":1,"643":2,"646":1,"647":2,"650":1,"653":3,"655":2,"665":1,"668":1,"677":1,"678":1,"692":1,"697":2,"710":2,"714":2,"716":4,"733":1,"748":1,"749":1,"769":1,"803":1}}],["always",{"2":{"2":1,"40":1,"107":1,"213":1,"270":1,"429":1,"516":1,"639":2,"658":2,"779":1}}],["a",{"0":{"48":1,"60":1,"61":1,"73":1,"100":1,"102":1,"103":1,"112":1,"134":1,"153":1,"188":1,"189":1,"190":1,"191":1,"200":1,"211":1,"220":1,"221":1,"258":1,"259":1,"261":1,"262":1,"264":1,"267":1,"278":1,"295":1,"296":2,"298":2,"299":1,"317":1,"318":1,"344":2,"345":1,"349":1,"365":1,"366":1,"391":1,"392":1,"395":1,"402":1,"403":1,"407":1,"437":1,"438":1,"444":1,"445":1,"465":1,"469":1,"475":1,"480":1,"484":1,"505":1,"530":1,"539":1,"543":1,"554":1,"565":1,"573":1,"581":1,"583":1,"584":1,"588":1,"590":1,"591":1,"594":1,"613":1,"618":2,"622":1,"636":1,"641":2,"677":1,"686":1,"698":1,"709":1,"711":1,"712":1,"718":1,"720":1,"729":1,"786":1,"793":1,"795":1,"797":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":1,"101":1,"102":1,"103":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"189":1,"190":1,"191":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"277":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"287":1,"299":2,"319":1,"320":1,"321":1,"346":1,"347":1,"466":1,"470":1,"531":1,"532":1,"533":1,"534":1,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1,"589":1,"590":1,"591":1,"619":2,"637":1,"638":1,"639":1,"642":2,"643":2,"678":1,"679":1,"680":1,"681":1,"682":1,"683":1,"684":1,"685":1,"686":1,"687":2,"688":1,"689":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"721":1,"722":1,"723":1,"724":1,"725":1,"726":1,"727":1,"728":1,"729":1,"730":2,"731":1,"732":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"794":1,"795":1,"796":2,"797":2,"798":1,"799":1,"800":1,"801":1,"802":1,"803":1,"804":1,"805":1,"806":1,"807":1,"808":1},"2":{"2":4,"3":3,"7":1,"8":3,"13":2,"14":5,"15":4,"16":2,"19":3,"21":1,"22":2,"23":2,"24":6,"25":1,"26":1,"27":2,"28":1,"29":1,"30":5,"31":10,"32":3,"33":2,"34":15,"35":2,"36":6,"37":1,"39":3,"40":12,"41":3,"42":8,"43":7,"44":7,"45":3,"46":3,"47":8,"48":4,"50":1,"52":2,"53":2,"54":1,"56":1,"57":1,"59":1,"60":7,"61":5,"65":5,"66":2,"71":1,"72":1,"73":1,"74":1,"75":3,"76":3,"77":1,"78":1,"79":3,"80":3,"82":2,"83":2,"84":15,"85":3,"86":1,"88":7,"89":10,"90":1,"91":2,"92":1,"101":1,"102":2,"103":3,"105":1,"106":1,"107":21,"108":5,"109":3,"110":2,"113":2,"115":2,"116":3,"117":2,"119":2,"120":3,"121":3,"122":2,"126":1,"127":3,"128":8,"129":4,"131":13,"133":3,"134":15,"135":19,"136":3,"137":3,"139":6,"145":3,"146":10,"148":17,"150":5,"154":5,"155":1,"158":1,"160":7,"163":2,"165":4,"166":3,"168":2,"169":8,"172":2,"174":1,"176":1,"177":2,"178":5,"179":1,"180":1,"181":7,"182":1,"183":6,"184":12,"185":1,"187":3,"188":3,"189":3,"192":7,"195":1,"196":1,"197":1,"200":1,"202":2,"203":1,"206":1,"208":3,"209":1,"210":3,"211":17,"212":1,"213":6,"214":1,"215":2,"216":2,"217":11,"218":1,"219":4,"220":7,"221":2,"223":10,"224":10,"225":4,"226":5,"227":3,"228":3,"230":2,"233":2,"234":1,"235":3,"236":8,"237":2,"239":1,"242":1,"243":3,"244":3,"245":1,"246":3,"247":2,"250":1,"251":1,"255":1,"256":1,"258":1,"259":1,"261":3,"262":5,"264":7,"265":3,"266":2,"267":1,"268":1,"270":5,"271":1,"272":1,"276":2,"277":1,"278":1,"279":1,"280":2,"281":3,"282":2,"284":3,"285":3,"286":3,"287":1,"288":2,"290":2,"291":1,"292":4,"295":1,"296":2,"297":1,"299":1,"300":2,"302":1,"304":1,"305":1,"306":7,"308":1,"309":5,"311":7,"312":1,"313":3,"314":5,"316":1,"317":1,"318":8,"319":1,"320":1,"323":1,"324":7,"325":6,"326":5,"327":1,"331":1,"333":1,"336":1,"337":2,"338":4,"339":1,"340":4,"341":2,"343":4,"344":2,"346":2,"347":1,"348":1,"350":1,"352":1,"353":2,"354":1,"355":1,"357":1,"362":1,"363":1,"365":2,"366":3,"367":2,"368":1,"369":1,"371":2,"372":3,"373":4,"374":7,"375":1,"377":2,"386":3,"388":1,"391":3,"393":1,"394":1,"395":4,"396":1,"399":2,"401":2,"402":3,"403":4,"405":1,"407":3,"410":2,"411":5,"412":4,"413":21,"414":3,"415":4,"416":3,"418":1,"419":4,"420":1,"421":1,"423":1,"424":4,"425":1,"426":6,"427":1,"428":6,"429":10,"430":13,"431":4,"432":7,"436":4,"437":10,"439":2,"440":2,"441":1,"443":2,"444":1,"445":1,"447":2,"448":5,"449":3,"450":6,"451":5,"452":3,"453":2,"454":4,"455":1,"456":2,"457":4,"459":1,"460":5,"461":9,"462":3,"463":7,"464":4,"466":5,"467":10,"468":3,"469":13,"470":9,"471":2,"474":1,"475":1,"476":1,"480":1,"484":1,"486":1,"488":5,"489":3,"491":3,"492":2,"494":4,"497":2,"498":1,"499":2,"500":1,"501":4,"507":1,"508":6,"509":3,"510":1,"515":2,"516":2,"523":3,"524":4,"526":2,"531":6,"537":1,"538":5,"539":2,"540":1,"541":2,"542":10,"545":4,"548":7,"549":4,"551":2,"553":1,"554":1,"555":2,"556":2,"557":16,"558":1,"559":3,"560":3,"561":2,"563":9,"564":2,"565":4,"569":1,"571":4,"572":1,"573":3,"576":3,"577":1,"579":2,"580":4,"581":3,"583":2,"584":2,"585":2,"586":1,"587":3,"588":1,"591":1,"592":1,"593":1,"594":2,"595":5,"596":2,"597":1,"601":6,"602":2,"604":1,"605":1,"606":5,"608":2,"609":3,"611":4,"612":1,"613":1,"616":4,"617":1,"618":7,"621":2,"622":2,"623":1,"627":2,"630":1,"631":1,"633":5,"634":1,"635":1,"639":4,"641":1,"645":2,"646":1,"647":2,"648":1,"649":3,"650":2,"651":2,"654":1,"655":1,"656":2,"658":1,"659":2,"661":2,"663":3,"664":4,"665":2,"666":2,"667":1,"668":6,"669":1,"670":2,"673":3,"677":3,"685":8,"686":2,"687":1,"688":2,"690":2,"691":3,"692":7,"693":1,"694":2,"696":1,"698":1,"699":3,"700":17,"704":3,"705":2,"709":1,"710":2,"712":2,"718":1,"719":1,"720":1,"722":1,"726":5,"727":1,"729":2,"730":1,"731":1,"733":1,"734":1,"737":2,"738":9,"739":1,"747":3,"748":3,"750":1,"753":1,"754":2,"759":3,"760":5,"763":2,"765":2,"768":1,"769":1,"772":3,"777":1,"779":1,"781":1,"782":1,"783":1,"784":1,"785":3,"786":1,"787":2,"788":1,"793":1,"794":1,"795":1,"796":1,"797":3,"798":4,"800":1,"802":2,"803":4,"804":1,"808":2}}],["bzsidenode",{"2":{"168":6,"169":6,"172":8}}],["blind",{"2":{"573":2}}],["blue",{"2":{"146":1}}],["blobtypes",{"2":{"431":4,"437":6}}],["blobtxs",{"2":{"433":1}}],["blobtx",{"2":{"425":1,"437":4}}],["blobclient",{"2":{"419":2}}],["blobchan",{"2":{"325":2}}],["blobresponse",{"2":{"325":2}}],["blobpointer",{"2":{"107":1}}],["blobspace",{"0":{"487":1,"507":1},"1":{"488":1,"489":1}}],["blobsharerange",{"2":{"159":2,"172":4}}],["blobs",{"0":{"289":1,"324":1,"325":1,"342":1,"345":1,"361":1,"419":1,"425":1},"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,"343":1,"344":1,"345":1,"346":2,"347":2,"348":1,"349":1,"350":1,"351":1,"426":1,"427":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"107":1,"146":1,"159":1,"290":1,"292":2,"324":5,"325":11,"326":13,"343":1,"359":1,"376":1,"397":1,"413":1,"419":13,"420":17,"425":1,"426":1,"429":1,"430":3,"436":2,"488":2,"491":1,"524":1,"748":1,"760":1}}],["blobstreamgit",{"2":{"424":1}}],["blobstreamwrapper",{"2":{"171":4}}],["blobstreamxcd",{"2":{"217":1}}],["blobstreamxdatacommitmentstored",{"2":{"153":4,"170":4,"171":2}}],["blobstreamxwrapper",{"2":{"153":14,"170":6,"171":4}}],["blobstreamxsp1",{"2":{"145":1,"153":1,"170":1,"171":1,"172":1}}],["blobstreamx",{"0":{"217":1,"241":1},"1":{"218":1,"219":1,"242":1,"243":1,"244":1},"2":{"89":4,"107":3,"109":2,"127":1,"129":1,"145":4,"153":16,"163":2,"170":8,"171":4,"172":10,"209":1,"211":2,"212":5,"213":2,"217":5,"219":4,"220":9,"221":2,"224":7,"226":3,"242":4,"243":1}}],["blobstream",{"0":{"95":1,"109":1,"123":1,"126":1,"132":1,"133":1,"141":1,"144":1,"153":1,"174":1,"209":1,"229":1,"230":1,"231":1,"232":1,"236":1,"237":1,"238":1,"239":1,"241":1,"242":1,"243":1,"244":1,"423":1},"1":{"96":1,"97":1,"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":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,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1,"173":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,"200":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"210":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1,"222":1,"223":1,"224":1,"230":1,"231":2,"232":1,"233":2,"234":2,"235":2,"236":1,"237":1,"238":2,"239":2,"240":2,"242":1,"243":1,"244":1,"424":1},"2":{"27":1,"88":3,"89":6,"94":1,"95":1,"106":1,"108":1,"109":1,"110":1,"126":4,"127":22,"130":1,"131":9,"133":3,"134":2,"135":4,"136":3,"137":1,"139":2,"141":1,"145":4,"146":2,"148":5,"150":2,"153":7,"163":4,"169":6,"170":5,"171":5,"172":13,"173":1,"174":2,"175":2,"177":2,"180":1,"183":1,"184":2,"187":2,"195":1,"210":1,"212":2,"221":1,"225":3,"226":1,"227":4,"228":2,"230":11,"231":3,"233":2,"234":2,"235":3,"236":12,"237":6,"238":4,"239":2,"240":8,"242":8,"243":3,"244":3,"288":1,"423":3,"424":6}}],["blob",{"0":{"158":1,"176":1,"177":1,"178":1,"179":1,"180":1,"192":1,"193":1,"194":1,"199":1,"201":1,"202":1,"299":1,"391":1,"426":1},"1":{"159":1,"177":1,"178":1,"179":1,"180":1,"193":1,"194":1,"200":1,"201":1,"202":1},"2":{"89":1,"91":1,"107":1,"108":2,"145":4,"146":2,"148":1,"153":4,"154":1,"156":6,"158":1,"159":7,"164":1,"165":1,"169":2,"170":2,"172":4,"175":1,"176":1,"177":8,"178":2,"179":1,"182":1,"184":3,"185":1,"192":5,"193":1,"195":1,"197":1,"199":1,"200":5,"203":7,"208":2,"296":4,"297":1,"299":5,"300":2,"324":30,"325":5,"326":2,"346":3,"347":3,"351":1,"369":8,"374":12,"375":1,"376":10,"377":3,"391":5,"411":8,"412":6,"413":51,"415":11,"416":1,"419":34,"420":2,"425":2,"426":2,"429":6,"430":6,"431":6,"434":2,"435":3,"436":24,"437":14,"438":1,"488":1,"489":1,"491":1,"611":4,"612":2,"613":2,"738":4}}],["blocktimes",{"2":{"336":1}}],["blockdataroot",{"2":{"169":3,"172":8}}],["blockres",{"2":{"153":2,"159":2}}],["blocknumber",{"2":{"121":2,"153":2,"170":2,"286":2,"396":2}}],["block",{"0":{"90":1,"139":1,"142":1,"153":1,"383":1,"432":1,"452":1,"643":1,"648":1,"661":2,"808":2},"2":{"89":1,"91":12,"127":16,"128":2,"129":1,"131":5,"133":1,"134":34,"135":2,"136":4,"137":17,"139":15,"146":4,"148":3,"150":3,"153":10,"158":1,"159":6,"160":1,"161":1,"169":16,"170":4,"172":6,"177":3,"180":1,"181":3,"183":1,"192":1,"196":1,"208":1,"218":4,"224":2,"225":6,"230":1,"236":2,"237":1,"242":3,"300":2,"327":2,"336":1,"338":1,"362":1,"374":1,"376":6,"377":1,"383":10,"391":1,"395":3,"413":2,"421":2,"426":2,"432":2,"437":2,"444":1,"447":3,"448":4,"449":2,"450":4,"451":4,"452":2,"455":1,"458":1,"460":1,"461":8,"462":3,"463":4,"464":3,"466":2,"468":2,"469":10,"470":13,"488":3,"490":1,"492":4,"495":3,"498":1,"510":1,"524":1,"531":2,"549":1,"561":2,"618":2,"641":1,"643":2,"646":3,"647":1,"648":2,"649":1,"659":3,"661":5,"678":2,"691":2,"692":1,"695":4,"721":1,"738":3,"748":1,"797":1,"803":1,"808":5}}],["blocks",{"0":{"137":1},"2":{"84":2,"90":1,"134":3,"135":4,"136":1,"137":12,"139":13,"148":4,"154":1,"170":2,"181":2,"187":2,"217":1,"225":1,"336":2,"338":3,"432":2,"447":1,"451":2,"452":1,"455":1,"462":1,"463":1,"491":3,"492":3,"495":1,"523":1,"531":3,"563":2,"571":1,"643":3,"646":4,"647":2,"649":1,"747":1,"759":1,"760":2,"769":2,"791":1}}],["blockscout",{"2":{"69":1,"90":2}}],["blockchains",{"0":{"263":1,"336":1,"459":1,"467":1},"1":{"264":1,"265":1,"266":1},"2":{"59":3,"62":1,"65":1,"136":1,"251":1,"256":2,"262":3,"264":2,"265":2,"266":1,"302":4,"447":2,"449":1,"457":1,"459":1,"467":6,"468":1,"563":1}}],["blockchain",{"0":{"262":1,"302":1,"456":1,"465":1},"1":{"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1,"466":1},"2":{"19":1,"31":1,"40":1,"57":1,"59":1,"134":3,"135":3,"139":1,"143":1,"248":3,"261":1,"262":3,"264":3,"302":1,"314":2,"336":2,"337":2,"405":3,"415":3,"437":2,"447":1,"448":1,"454":1,"456":1,"457":1,"459":1,"460":2,"466":3,"467":1,"468":2,"471":1,"494":2,"507":1,"508":2,"634":1,"648":2,"650":1,"690":1,"693":1,"769":1}}],["blog",{"2":{"36":1,"38":1,"306":43,"308":6,"311":3,"314":12}}],["bidirectional",{"2":{"631":1}}],["bitszn",{"2":{"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["bitter",{"2":{"573":2}}],["bitcoin",{"2":{"302":1}}],["billion",{"2":{"500":1}}],["bip44",{"2":{"443":2}}],["bip39",{"2":{"272":1}}],["bi",{"2":{"430":2}}],["bigger",{"2":{"447":1,"451":1}}],["big",{"2":{"153":8,"165":4,"168":4,"169":8,"172":18}}],["bincd",{"2":{"223":1}}],["bin",{"2":{"218":2,"220":2,"223":5,"224":2,"276":2,"277":2,"402":2,"561":2,"593":1,"594":1,"622":1,"675":2,"676":9}}],["binaries",{"2":{"212":2,"220":1,"594":2,"622":2,"674":1}}],["binarymerkleproof",{"2":{"127":4,"128":1,"153":2,"163":4,"168":9,"169":5,"172":8}}],["binary",{"0":{"593":1,"594":1,"622":1,"624":1},"2":{"94":1,"102":1,"108":2,"127":2,"128":1,"131":1,"148":1,"150":1,"154":1,"160":2,"163":2,"169":2,"183":2,"184":1,"220":5,"223":1,"224":1,"269":4,"291":1,"407":1,"536":1,"542":2,"564":2,"569":1,"592":1,"593":5,"594":4,"621":4,"622":4,"624":1,"661":1,"665":1,"691":4,"692":4,"724":1,"808":1}}],["bind",{"2":{"153":6,"170":2,"171":2,"172":4,"655":1}}],["bindings",{"2":{"145":7,"153":4,"170":2,"171":2,"172":4,"237":1,"242":1}}],["binding",{"2":{"31":1,"153":2,"170":2,"172":2}}],["biometric",{"2":{"33":3}}],["b",{"2":{"31":2,"32":1,"34":2,"139":10,"172":24,"419":4,"424":1,"499":1,"500":1,"621":1,"700":8}}],["brew",{"2":{"557":1,"675":4}}],["brevity",{"2":{"467":1}}],["break",{"2":{"516":1,"627":1}}],["breaking",{"2":{"431":1,"692":1}}],["breaks",{"2":{"37":1,"43":1}}],["br",{"2":{"314":2}}],["brush",{"2":{"262":1}}],["broken",{"2":{"573":2,"691":1}}],["browsers",{"2":{"357":1}}],["browser",{"0":{"474":1,"479":1},"2":{"80":1,"474":1,"557":1,"750":1}}],["broadcasting",{"2":{"524":1,"576":2,"585":2,"748":1,"760":1,"761":1,"803":2}}],["broadcasttx",{"2":{"437":2}}],["broadcastforge",{"2":{"309":1,"310":1}}],["broadcast",{"2":{"75":1,"219":2,"300":2,"309":1,"310":1,"318":1,"468":1,"561":4,"585":2,"763":1}}],["broadcastcd",{"2":{"75":1,"318":1}}],["broader",{"2":{"30":1,"43":1,"46":1,"65":1,"734":1}}],["branding",{"0":{"58":1}}],["brand",{"2":{"47":1,"58":1}}],["branch",{"2":{"2":3}}],["brightlystake",{"2":{"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["brightest",{"2":{"65":1}}],["bridging",{"0":{"66":1},"1":{"67":1,"68":1,"69":1,"70":1,"71":1,"72":1},"2":{"66":1,"85":1,"236":2,"251":1}}],["bridge=",{"2":{"596":4}}],["bridgefulllight",{"2":{"270":1,"271":1,"272":1}}],["bridgesudo",{"2":{"617":1}}],["bridges",{"2":{"236":1,"769":1}}],["bridgecreator",{"2":{"98":1,"99":1}}],["bridge",{"0":{"67":1,"70":1,"251":1,"523":1,"530":1,"531":1,"533":1,"535":1,"537":1,"538":1,"539":1,"541":1,"641":1,"747":1,"757":1,"759":1,"764":1,"791":1,"800":1,"801":1,"802":1},"1":{"68":1,"69":1,"71":1,"72":1,"531":1,"532":1,"533":1,"534":2,"535":1,"536":2,"537":2,"538":2,"539":3,"540":3,"541":2,"642":1,"643":1,"758":1,"759":1,"760":1,"802":1},"2":{"24":2,"27":3,"28":1,"66":2,"68":1,"69":1,"71":1,"72":2,"82":2,"86":1,"91":8,"92":1,"98":1,"99":1,"103":1,"135":2,"172":4,"230":1,"251":2,"268":1,"270":2,"271":2,"272":2,"279":1,"288":1,"365":1,"467":1,"521":6,"523":1,"524":2,"530":2,"531":4,"532":1,"536":1,"537":9,"538":12,"539":9,"540":3,"541":2,"595":2,"596":4,"606":2,"608":1,"615":1,"616":4,"617":10,"627":2,"628":1,"631":1,"633":3,"641":1,"664":1,"746":1,"747":1,"748":2,"754":1,"759":1,"760":2,"764":7,"769":1,"771":1,"783":1,"791":20,"792":1,"798":3,"800":2,"801":2,"802":2}}],["briefly",{"2":{"44":1,"85":1}}],["bringing",{"2":{"557":1}}],["bring",{"2":{"41":1,"65":1}}],["bound",{"2":{"738":1}}],["bounds",{"2":{"183":2,"188":1}}],["bot",{"2":{"696":1}}],["both",{"2":{"23":1,"24":1,"28":1,"86":1,"91":1,"95":1,"119":1,"135":1,"195":1,"213":1,"235":1,"338":1,"347":1,"430":1,"460":1,"464":1,"467":1,"488":1,"497":1,"557":1,"565":1,"585":1,"592":1,"696":1,"785":1}}],["bonded",{"2":{"563":2}}],["bonddenomalias",{"2":{"514":1}}],["bonddenom",{"2":{"513":1}}],["bonus",{"2":{"416":1,"436":2}}],["bona",{"2":{"34":1}}],["border",{"2":{"314":2}}],["borrowing",{"2":{"40":1}}],["bob",{"2":{"306":4}}],["box",{"2":{"266":1}}],["boxes",{"2":{"71":1}}],["bootstrappeers",{"2":{"630":2}}],["bootstrappers",{"2":{"630":1,"748":1}}],["bootstrapper",{"2":{"596":1,"630":3,"764":1}}],["bootstrapping",{"0":{"508":1},"2":{"492":1}}],["bootstrap",{"0":{"630":1},"2":{"508":1,"633":1}}],["boolean",{"2":{"598":2,"601":1}}],["bool",{"2":{"127":2,"153":2,"172":2,"306":6}}],["boost",{"2":{"46":1}}],["book",{"2":{"40":1,"143":1}}],["board",{"2":{"43":2}}],["body",{"2":{"7":1,"576":2}}],["bare",{"2":{"667":1}}],["barrier",{"2":{"84":2}}],["bak",{"2":{"639":10,"656":2}}],["bad",{"2":{"452":2}}],["balances",{"0":{"297":1,"579":1},"2":{"301":2,"366":1,"456":2,"524":1,"537":1,"547":5,"576":1,"579":6,"591":2,"685":1,"748":1,"760":1}}],["balancecelestia",{"2":{"296":1,"297":1,"379":1}}],["balance",{"0":{"379":1,"380":1,"386":1},"2":{"91":4,"235":1,"288":1,"296":3,"297":2,"301":1,"316":1,"379":2,"380":7,"407":3,"444":1,"445":1,"549":1,"579":3,"645":1,"685":1,"726":1}}],["batcher",{"2":{"338":5,"396":1,"398":1,"403":4}}],["batched",{"2":{"234":1}}],["batches",{"0":{"398":1},"2":{"84":2,"88":1,"107":1,"109":2,"128":1,"153":2,"170":2,"172":2,"180":1,"224":5,"242":2,"338":3,"398":2,"469":1}}],["batchposter",{"2":{"110":1}}],["batch",{"0":{"88":1},"2":{"84":4,"85":1,"86":2,"88":2,"89":5,"91":3,"93":1,"107":8,"129":2,"148":4,"169":1,"217":1,"225":1,"398":4,"695":8}}],["backward",{"2":{"690":1}}],["backed",{"2":{"658":2}}],["backers",{"2":{"499":2,"500":2}}],["backend=test",{"2":{"803":2}}],["backend=",{"2":{"561":2}}],["backend",{"2":{"270":6,"271":6,"272":6,"276":2,"277":2,"300":2,"310":2,"316":2,"349":2,"367":4,"538":2,"543":4,"561":8,"581":3,"585":4,"590":2,"601":1,"685":2,"712":2,"713":2,"715":2,"727":4}}],["background",{"0":{"608":1,"786":1},"1":{"787":1,"788":1,"789":1,"790":1,"791":1,"792":1},"2":{"152":2,"153":4,"159":4,"172":2,"412":2,"413":2,"415":2,"541":1,"651":1,"688":1,"731":1,"786":1,"787":1,"788":1,"792":1,"802":1}}],["back",{"2":{"72":1,"88":1,"107":1,"110":1,"139":1,"188":3,"208":1,"211":1,"288":1,"324":2,"338":1,"411":1,"413":2,"415":2,"416":2,"419":2,"436":2,"540":1,"687":1,"694":1,"704":1,"730":1}}],["basis",{"2":{"692":1}}],["basically",{"2":{"266":1}}],["basic",{"0":{"370":1},"1":{"371":1,"372":1,"373":1},"2":{"114":2,"279":2,"306":2,"314":2,"369":1,"370":1,"557":1,"658":1,"662":1,"666":2}}],["basechainhandle",{"2":{"700":8}}],["baseaccount",{"2":{"578":3}}],["basefeepergas",{"2":{"395":1}}],["base64=truecelestia",{"2":{"376":2}}],["base64=true",{"2":{"376":3}}],["base64",{"2":{"151":1,"156":1,"161":1,"165":1,"166":1,"314":2,"374":4,"376":4,"392":1,"396":3,"397":1}}],["base",{"0":{"97":1,"99":1,"578":1},"2":{"82":2,"84":13,"85":6,"86":1,"89":2,"91":12,"92":1,"95":1,"97":1,"121":1,"194":1,"225":1,"237":1,"240":2,"286":1,"314":1,"467":2,"577":4}}],["based",{"2":{"23":2,"24":1,"80":1,"131":1,"223":1,"233":1,"331":1,"336":2,"377":1,"405":1,"426":2,"429":2,"430":3,"441":1,"459":1,"471":1,"489":1,"494":1,"495":1,"508":1,"593":1,"621":1}}],["bashmoniker=",{"2":{"803":1}}],["bashmake",{"2":{"593":1,"621":4}}],["bashhermes",{"2":{"696":1,"697":1,"699":3,"700":2}}],["bashvalidator",{"2":{"797":1}}],["bashvim",{"2":{"695":1}}],["bashver=",{"2":{"676":3}}],["bashzsh",{"2":{"676":1}}],["bashpersistent",{"2":{"639":3}}],["bashprometheus",{"2":{"557":1}}],["bashprivate",{"2":{"91":1,"310":1,"316":1}}],["bashsuccess",{"2":{"697":1,"700":2}}],["bashsudo",{"2":{"617":2,"668":1,"675":4}}],["bashseeds=$",{"2":{"639":2}}],["bashnano",{"2":{"617":1}}],["bashnpm",{"2":{"316":1}}],["bashbash",{"2":{"594":1,"622":1}}],["bashbalances",{"2":{"579":2}}],["bashblockhash",{"2":{"121":1,"286":1}}],["bash$home",{"2":{"401":3}}],["bashgas",{"2":{"576":1}}],["bashgrafana",{"2":{"557":1}}],["bashgo",{"2":{"323":1,"676":1}}],["bashgit",{"2":{"87":1,"593":3,"621":3}}],["bashanvil",{"2":{"309":1}}],["bashanvilanvil",{"2":{"284":1}}],["bashroot",{"2":{"277":1}}],["bashdocker",{"2":{"276":4,"277":4,"667":3,"669":3,"670":3}}],["bash2024",{"2":{"223":1,"661":1,"808":1}}],["bashenter",{"2":{"797":1}}],["basherror",{"2":{"617":1}}],["bashecho",{"2":{"121":1,"286":1,"676":2}}],["bashexport",{"2":{"75":2,"76":1,"120":2,"284":1,"285":2,"293":1,"300":1,"309":1,"310":1,"318":3,"371":2,"372":1,"386":1,"391":1,"395":1,"396":1,"569":1,"575":1,"581":1,"583":1,"596":2,"667":7}}],["bash0x000000000000000000000000000000000000000000000000000000000000000a0x000000000000000000000000000000000000000000000000000000000000000a",{"2":{"121":1,"286":1}}],["bash",{"2":{"116":1,"117":1,"120":1,"270":3,"271":3,"272":3,"276":2,"277":1,"281":1,"282":1,"285":1,"367":2,"373":2,"391":1,"556":1,"561":1,"569":1,"573":1,"574":2,"576":3,"577":2,"578":2,"579":2,"594":1,"601":1,"609":2,"611":1,"612":1,"613":1,"622":1,"639":1,"668":1,"669":1,"670":1,"675":3,"676":4,"701":2}}],["bashfatal",{"2":{"616":1}}],["bashforge",{"2":{"115":1,"116":1,"117":1,"120":1,"280":1,"281":1,"282":1,"284":1,"285":1,"305":1,"307":1,"309":1,"310":1}}],["bashfunding",{"2":{"91":1}}],["bashcargo",{"2":{"418":1}}],["bashcast",{"2":{"76":3,"121":2,"286":2,"309":2,"310":2,"318":3,"395":1,"396":1}}],["bashcurl",{"2":{"391":1,"397":1,"556":1}}],["bashcp",{"2":{"311":1}}],["bashcontainer",{"2":{"276":1,"277":1}}],["bashcelestia",{"2":{"89":2,"295":2,"296":3,"297":1,"298":1,"299":1,"300":1,"301":1,"365":3,"366":6,"367":3,"369":3,"372":1,"373":2,"374":4,"376":5,"377":1,"379":1,"380":2,"381":1,"382":1,"383":2,"384":1,"385":1,"386":3,"387":1,"388":2,"389":1,"434":1,"435":1,"524":2,"581":3,"583":2,"596":1,"609":2,"614":2,"615":2,"621":1,"639":6,"703":1,"748":1,"797":2,"800":1,"801":1}}],["bashcd",{"2":{"75":2,"77":1,"115":1,"224":1,"280":1,"311":1,"318":2,"319":1,"568":1,"570":1,"573":1,"593":1,"621":1,"650":3,"668":1,"676":4}}],["bashyarn",{"2":{"1":1}}],["bandwidth",{"2":{"336":2,"363":1,"462":1,"532":1,"635":1,"679":1,"722":1,"771":1,"772":1,"794":1}}],["bank",{"2":{"300":2,"301":2,"331":1,"547":10,"561":4,"579":4,"591":2}}],["banner",{"2":{"44":1}}],["banners",{"2":{"44":1}}],["ban",{"0":{"15":1,"16":1},"2":{"14":1,"15":2,"16":1}}],["buckets",{"2":{"695":8}}],["bug",{"2":{"616":2,"772":1}}],["bugs",{"2":{"31":1}}],["burned",{"2":{"548":1}}],["buffer",{"2":{"314":6}}],["bubs",{"0":{"245":1,"247":1,"278":1,"285":1,"318":1},"1":{"246":1,"247":1,"248":2,"249":2,"250":2,"251":2,"252":2,"253":2,"254":2,"255":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"287":1,"319":1,"320":1,"321":1},"2":{"245":2,"246":3,"247":2,"248":1,"249":1,"250":3,"251":2,"252":2,"253":1,"254":1,"255":1,"278":1,"279":5,"285":8,"287":1,"318":6,"340":3,"341":1}}],["budget",{"2":{"41":3,"46":1}}],["buy",{"2":{"34":1}}],["businesses",{"2":{"44":1}}],["business",{"2":{"34":1}}],["buttonstyle",{"2":{"314":6}}],["buttoncontainerstyle",{"2":{"314":6}}],["button",{"2":{"85":1,"86":1,"314":16,"443":4,"479":1,"557":1}}],["but",{"2":{"8":1,"24":1,"27":1,"30":1,"32":1,"33":1,"34":2,"35":1,"40":1,"41":3,"44":1,"47":1,"48":1,"65":1,"84":4,"107":2,"108":1,"134":1,"135":2,"170":2,"171":2,"172":2,"179":1,"217":1,"219":1,"228":1,"235":1,"236":2,"262":1,"310":1,"333":1,"334":1,"347":1,"403":1,"432":1,"456":1,"469":1,"491":1,"500":2,"516":1,"558":1,"569":1,"572":1,"646":2,"659":1,"661":1,"677":1,"691":1,"696":1,"711":1,"734":1,"754":1,"769":1,"798":1,"808":1}}],["buildmake",{"2":{"621":1}}],["builds",{"2":{"569":1}}],["builders",{"2":{"264":1}}],["builder",{"2":{"223":1}}],["buildcd",{"2":{"211":1}}],["buildforge",{"2":{"116":1,"281":1}}],["build",{"0":{"223":1,"224":1,"256":1,"411":1},"1":{"257":1,"258":1,"259":1,"260":1,"261":1,"262":1,"263":1,"264":1,"265":1,"266":1},"2":{"43":1,"116":1,"122":1,"174":1,"175":1,"187":1,"192":1,"211":2,"212":2,"220":3,"222":2,"223":14,"224":22,"230":1,"239":1,"247":1,"264":1,"281":1,"287":1,"302":3,"321":1,"330":1,"507":1,"568":2,"569":3,"570":2,"573":2,"593":1,"621":10,"675":4,"676":1,"705":1}}],["building",{"0":{"1":1,"247":1,"257":1,"311":1,"409":1,"465":1,"593":1},"1":{"248":1,"249":1,"250":1,"251":1,"252":1,"253":1,"254":1,"258":1,"259":1,"260":1,"312":1,"410":1,"411":1,"412":1,"413":1,"414":1,"415":1,"466":1},"2":{"175":1,"224":1,"258":1,"303":1,"311":1,"353":1,"407":1,"621":1,"674":1,"724":1}}],["built",{"0":{"246":1,"594":1,"622":1},"2":{"1":1,"108":1,"175":1,"177":1,"187":1,"223":2,"233":1,"242":1,"269":1,"321":1,"337":2,"338":1,"341":1,"466":2,"492":1,"509":1,"531":2,"563":1,"592":1,"594":3,"622":3,"693":2,"703":1}}],["bypassing",{"2":{"608":1}}],["bytes=",{"2":{"738":1}}],["bytes28",{"2":{"165":2,"166":2}}],["bytes1",{"2":{"165":2,"166":2}}],["bytes",{"0":{"738":1},"2":{"127":4,"163":2,"164":2,"165":5,"166":1,"167":4,"172":6,"183":1,"213":4,"324":4,"374":1,"413":2,"426":4,"429":1,"436":4,"437":2,"462":2,"463":3,"469":1,"737":1,"738":4}}],["bytes32",{"2":{"127":8,"151":1,"156":1,"161":1,"165":2,"168":3,"169":2,"172":2,"213":11,"215":3,"216":2,"228":1}}],["byte",{"2":{"89":3,"134":8,"153":10,"165":17,"166":7,"168":4,"169":6,"172":36,"211":2,"235":1,"324":4,"325":2,"326":2,"413":4,"430":1,"431":1,"436":4,"437":4}}],["by",{"0":{"153":1,"383":1,"644":1},"2":{"8":1,"17":1,"19":1,"21":1,"23":2,"24":2,"30":6,"31":4,"33":3,"34":11,"38":1,"41":1,"42":1,"43":1,"46":1,"47":1,"48":1,"60":1,"65":2,"79":1,"83":1,"84":2,"85":1,"87":1,"88":1,"89":2,"91":3,"107":1,"110":1,"116":1,"117":2,"119":1,"127":2,"129":1,"131":7,"133":1,"134":1,"135":5,"137":2,"139":2,"148":3,"149":1,"150":1,"151":1,"153":6,"156":1,"163":4,"166":1,"169":2,"172":6,"173":1,"177":2,"180":1,"181":1,"183":2,"184":2,"187":1,"192":1,"196":1,"211":1,"213":2,"214":1,"215":2,"221":1,"223":2,"224":1,"225":3,"227":2,"228":1,"230":2,"242":1,"243":1,"245":1,"246":1,"264":1,"265":1,"266":1,"268":1,"276":1,"277":2,"281":1,"282":2,"288":1,"292":1,"300":1,"306":6,"310":1,"311":1,"331":1,"335":2,"336":1,"338":2,"343":1,"346":2,"347":1,"357":1,"359":1,"361":1,"367":3,"374":3,"383":4,"384":4,"389":6,"398":2,"401":1,"407":2,"411":1,"413":1,"420":2,"424":1,"427":2,"428":6,"429":5,"430":6,"431":2,"432":2,"444":1,"448":1,"449":1,"450":1,"451":1,"452":1,"461":2,"462":1,"464":2,"466":3,"468":2,"469":5,"470":3,"489":1,"491":3,"492":3,"495":1,"500":1,"501":1,"508":1,"509":1,"538":2,"542":4,"548":2,"556":1,"557":3,"558":1,"561":2,"562":1,"563":1,"577":1,"591":1,"595":3,"597":1,"606":3,"621":1,"628":2,"630":2,"633":2,"646":1,"648":1,"649":1,"655":2,"658":2,"661":2,"668":1,"685":2,"691":2,"693":2,"694":1,"700":1,"707":1,"708":1,"709":1,"710":1,"717":1,"719":1,"724":1,"727":3,"738":4,"749":1,"761":1,"769":2,"779":1,"797":1,"808":2}}],["beautiful",{"2":{"311":1}}],["bearer",{"2":{"391":2,"397":2}}],["bear",{"2":{"31":2,"34":2}}],["bedrock",{"2":{"246":1,"340":1}}],["belong",{"2":{"163":2,"177":2,"183":1}}],["below",{"2":{"21":1,"22":1,"34":1,"47":1,"66":1,"84":1,"89":1,"95":1,"96":1,"97":1,"120":1,"136":1,"146":1,"169":1,"180":1,"197":1,"242":1,"243":1,"285":1,"323":1,"396":1,"397":1,"418":1,"466":1,"469":2,"492":1,"495":1,"499":1,"500":1,"521":1,"591":1,"593":1,"594":1,"622":1,"669":1,"670":1,"685":1,"726":1,"740":1,"742":1,"758":1,"760":1,"764":1,"797":1,"803":2}}],["bech",{"2":{"797":2}}],["bech32prefixconspub",{"2":{"443":2}}],["bech32prefixconsaddr",{"2":{"443":2}}],["bech32prefixvalpub",{"2":{"443":2}}],["bech32prefixvaladdr",{"2":{"443":2}}],["bech32prefixaccpub",{"2":{"443":2}}],["bech32prefixaccaddr",{"2":{"443":2}}],["bech32config",{"2":{"443":2}}],["because",{"2":{"108":1,"137":1,"182":1,"266":1,"309":1,"310":1,"336":1,"407":1,"413":1,"447":1,"457":1,"611":1,"647":1,"694":1}}],["becomes",{"2":{"344":1,"447":2,"633":1}}],["become",{"2":{"31":1,"53":1,"56":1}}],["behind",{"2":{"107":1,"336":1,"516":1,"656":1,"779":1}}],["behave",{"2":{"560":1}}],["behavior",{"2":{"8":2,"9":2,"11":1,"13":2,"14":1,"15":1,"16":1,"369":1,"563":1,"608":1,"649":1,"721":1}}],["behalf",{"2":{"30":1,"34":2,"294":1}}],["beefy",{"2":{"220":1,"223":1,"224":1}}],["beer",{"2":{"41":1}}],["been",{"2":{"27":1,"31":1,"34":4,"91":2,"94":1,"107":1,"110":2,"127":3,"177":1,"228":1,"297":1,"301":2,"309":1,"310":1,"357":1,"362":1,"407":1,"447":1,"456":1,"457":1,"492":2,"563":1,"577":1,"591":1,"606":1,"608":1,"700":1,"725":1,"737":1,"788":1,"792":1}}],["beginner",{"0":{"663":1},"2":{"663":1}}],["beginning",{"2":{"44":2,"165":2,"169":1,"217":1,"495":1}}],["beginkey",{"2":{"165":3,"184":2}}],["begin",{"2":{"38":1,"139":1,"184":1,"293":1,"314":2,"412":1,"557":1}}],["benefits",{"0":{"263":1},"1":{"264":1,"265":1,"266":1},"2":{"40":1,"44":1,"59":1,"62":1,"65":2,"256":2,"302":1}}],["benefit",{"2":{"34":2,"44":2,"46":1,"109":1}}],["beneficial",{"2":{"34":1,"48":1}}],["better",{"2":{"47":1,"48":1,"135":1,"175":1,"206":1,"208":1,"255":1,"492":1}}],["between",{"0":{"455":1,"698":1},"2":{"31":1,"42":1,"43":1,"85":1,"139":1,"184":1,"192":1,"211":1,"235":1,"251":2,"306":2,"467":1,"495":1,"595":1,"606":1,"678":1,"693":2,"694":1,"695":1,"698":1,"700":1,"769":1,"791":1}}],["betaarabicamocha",{"2":{"729":1}}],["betaarabica",{"2":{"401":1}}],["betamochaarabica",{"2":{"365":1,"366":2,"367":1,"443":1,"537":1,"539":1,"593":1,"621":1,"639":4,"650":1,"651":1,"667":2,"669":1,"670":1,"676":1,"684":1,"686":1,"725":1,"726":1,"727":1,"803":1}}],["beta",{"0":{"502":1,"599":1,"611":1,"733":1,"774":1,"775":1},"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,"775":1},"2":{"24":1,"25":1,"28":1,"110":1,"145":1,"240":3,"270":3,"276":1,"277":1,"288":1,"339":1,"367":1,"391":1,"426":1,"502":1,"538":1,"599":1,"604":1,"605":3,"611":2,"618":1,"639":1,"667":1,"685":1,"692":3,"733":2,"734":2,"739":2,"748":1,"751":1,"753":2,"774":1,"781":1}}],["be",{"0":{"163":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1},"2":{"8":2,"11":2,"13":1,"21":1,"23":3,"26":3,"27":1,"29":1,"31":2,"33":1,"34":14,"40":3,"41":3,"43":1,"44":3,"45":4,"48":4,"53":1,"65":1,"71":2,"72":1,"76":1,"77":1,"83":1,"84":5,"85":1,"88":1,"89":4,"90":2,"95":1,"103":1,"107":3,"108":2,"109":2,"110":1,"117":1,"119":2,"122":1,"126":1,"131":1,"134":4,"135":5,"136":2,"137":3,"139":3,"145":8,"146":2,"148":3,"149":1,"150":1,"151":2,"152":1,"154":1,"155":1,"156":2,"158":1,"160":1,"161":3,"162":2,"164":2,"165":2,"166":2,"167":1,"168":1,"169":4,"170":2,"171":1,"172":3,"173":1,"175":3,"177":3,"178":4,"179":1,"180":2,"181":4,"183":2,"184":6,"187":2,"189":3,"191":2,"192":5,"194":1,"195":1,"196":4,"197":2,"199":2,"200":2,"202":1,"203":2,"206":1,"210":1,"211":11,"212":2,"213":1,"215":2,"217":3,"218":1,"219":3,"220":2,"223":1,"224":4,"225":3,"226":1,"227":1,"228":2,"230":1,"237":2,"239":1,"242":4,"243":2,"244":1,"246":1,"264":4,"266":2,"268":1,"269":1,"270":2,"276":1,"277":1,"282":1,"288":3,"292":1,"294":1,"302":2,"303":1,"306":2,"309":2,"311":1,"314":1,"316":2,"317":1,"318":1,"319":1,"321":2,"324":2,"331":1,"335":1,"336":3,"346":1,"348":1,"354":1,"357":2,"362":1,"365":1,"366":1,"367":1,"369":1,"370":2,"371":2,"374":6,"377":2,"380":1,"391":1,"398":3,"401":3,"403":1,"405":2,"406":1,"407":4,"408":1,"411":1,"413":1,"419":2,"424":1,"426":2,"427":1,"428":1,"429":3,"430":1,"431":2,"432":3,"437":4,"439":2,"440":2,"444":1,"445":1,"448":1,"451":1,"452":3,"454":2,"457":2,"458":1,"461":1,"462":1,"463":3,"464":1,"467":3,"469":2,"470":1,"488":2,"489":1,"490":1,"491":4,"492":3,"495":2,"500":2,"508":1,"516":2,"520":1,"524":1,"536":1,"537":1,"538":1,"539":1,"545":3,"548":5,"549":1,"555":1,"556":1,"558":1,"559":1,"560":1,"561":2,"563":4,"569":1,"580":1,"586":2,"591":1,"593":2,"594":1,"595":1,"598":1,"602":2,"604":2,"606":2,"614":4,"617":1,"622":1,"628":1,"630":1,"633":2,"641":1,"644":1,"649":5,"654":1,"655":1,"658":2,"659":1,"667":1,"668":2,"674":1,"685":4,"686":1,"689":2,"690":2,"691":3,"692":3,"693":1,"695":1,"696":2,"700":2,"703":3,"704":1,"709":1,"714":1,"715":1,"716":1,"719":1,"726":2,"727":1,"729":1,"734":1,"737":1,"738":4,"740":1,"758":1,"762":1,"764":1,"777":3,"779":2,"783":1,"788":1,"790":2,"791":2,"792":1,"800":1,"803":3}}],["best",{"2":{"8":1,"60":1,"65":1,"265":1,"519":1,"558":1,"739":1,"754":1,"783":1}}],["being",{"2":{"8":1,"24":1,"26":1,"84":1,"89":2,"102":1,"108":1,"137":1,"159":2,"161":1,"162":1,"165":2,"166":1,"167":1,"168":1,"169":3,"196":1,"211":1,"223":1,"331":1,"377":1,"441":1,"454":1,"470":1,"531":1,"604":1,"641":1,"647":1,"704":1}}],["before",{"0":{"36":1},"2":{"2":1,"24":2,"27":1,"42":2,"43":1,"45":1,"77":1,"85":1,"89":2,"110":1,"136":1,"139":3,"164":1,"180":1,"220":1,"242":1,"243":1,"315":1,"319":1,"369":1,"402":1,"443":3,"469":1,"571":1,"576":2,"604":1,"649":1,"668":1,"694":1,"710":1,"713":1,"788":1,"803":2}}],["rf",{"2":{"593":2,"616":4,"621":2,"650":6,"676":8}}],["rfc",{"2":{"128":1}}],["rsmt2d",{"2":{"327":2}}],["rsvp",{"2":{"36":1}}],["rgba",{"2":{"314":2}}],["r6a",{"2":{"226":1}}],["r",{"2":{"224":2,"384":2,"389":2,"396":4,"499":1,"500":2,"639":2}}],["r1cs",{"2":{"223":2}}],["r1",{"2":{"146":1}}],["r0",{"2":{"146":1}}],["rm",{"2":{"102":2,"593":2,"616":4,"621":2,"650":6,"676":16}}],["rc0",{"2":{"692":1}}],["rc",{"2":{"94":1,"102":2}}],["rblocks",{"2":{"86":1}}],["rpcs",{"2":{"524":1,"748":1}}],["rpcurls",{"2":{"313":2}}],["rpc",{"0":{"88":1,"248":1,"333":1,"353":1,"355":1,"356":1,"359":1,"368":1,"438":1,"520":1,"521":1,"523":1,"613":1,"654":1,"655":1,"740":1,"742":1,"747":1,"749":1,"757":1,"758":1,"759":1,"761":1},"1":{"249":1,"250":1,"354":1,"355":1,"356":1,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"369":2,"370":2,"371":2,"372":2,"373":2,"374":2,"375":2,"376":2,"377":2,"378":2,"379":2,"380":2,"381":2,"382":2,"383":2,"384":2,"385":2,"386":2,"387":2,"388":2,"389":2,"390":1,"391":1,"392":1,"393":1,"655":1,"656":1,"657":1,"750":1,"758":1,"759":1,"760":1},"2":{"75":7,"76":16,"88":3,"89":18,"91":7,"107":1,"120":7,"121":9,"135":4,"142":1,"145":5,"146":1,"151":1,"152":2,"153":8,"156":1,"159":2,"161":1,"170":4,"171":2,"172":6,"211":7,"212":4,"213":12,"217":1,"218":5,"219":4,"220":5,"227":2,"248":2,"249":1,"250":1,"276":2,"277":2,"279":1,"284":7,"285":10,"286":9,"291":1,"293":2,"300":5,"301":2,"309":2,"310":6,"315":1,"318":25,"322":1,"323":1,"333":2,"352":1,"353":3,"355":3,"356":1,"359":1,"362":1,"365":1,"366":3,"368":1,"369":2,"370":4,"371":1,"372":1,"381":1,"382":1,"391":1,"393":2,"395":2,"396":2,"403":7,"407":2,"412":2,"413":2,"415":2,"417":1,"418":4,"419":4,"420":2,"421":2,"438":1,"443":10,"444":2,"445":2,"520":3,"521":4,"523":2,"524":1,"531":1,"537":1,"538":2,"547":4,"583":8,"584":1,"585":5,"595":2,"596":1,"606":2,"608":1,"609":2,"611":2,"613":3,"618":2,"623":1,"649":4,"654":1,"655":3,"656":1,"659":3,"667":5,"685":1,"695":16,"726":5,"727":3,"740":3,"742":25,"743":1,"744":2,"745":1,"747":2,"748":12,"758":3,"759":2,"760":6,"761":16,"763":1,"784":1,"800":1}}],["rigorous",{"2":{"733":1}}],["rights",{"2":{"30":2}}],["right",{"2":{"9":1,"34":1,"68":1,"89":1,"256":1,"314":6,"316":1,"479":1,"508":1,"691":1}}],["richer",{"2":{"353":1}}],["risk",{"2":{"230":1}}],["risks",{"2":{"34":2}}],["rounds",{"2":{"450":2}}],["round",{"2":{"383":2}}],["roughly",{"2":{"336":1,"432":1}}],["route",{"2":{"613":2}}],["router",{"2":{"595":1,"606":1}}],["routes",{"2":{"219":1,"613":1}}],["routine",{"2":{"42":1}}],["robusta",{"2":{"373":2}}],["robust",{"2":{"247":1}}],["rowproof",{"2":{"167":1,"168":1,"172":4}}],["rowproofs",{"0":{"168":1},"2":{"163":2,"168":2,"169":1,"172":2,"184":4}}],["rowroots",{"0":{"167":1},"2":{"163":4,"167":3,"172":4}}],["row",{"2":{"108":3,"131":4,"146":1,"148":6,"154":3,"156":8,"160":6,"161":8,"163":2,"165":1,"168":1,"169":1,"177":2,"183":2,"184":7,"383":2,"463":1,"469":4}}],["rows",{"2":{"108":2,"131":3,"148":1,"160":1,"163":8,"165":1,"167":1,"168":1,"177":2,"183":2,"461":1}}],["ro",{"2":{"102":2}}],["room",{"2":{"426":1}}],["rooms",{"2":{"40":1}}],["roots",{"2":{"107":1,"108":5,"109":1,"131":2,"137":1,"146":1,"148":4,"156":2,"160":3,"161":2,"163":2,"165":1,"167":8,"169":1,"172":6,"177":6,"234":1,"236":2,"383":4,"461":3,"462":1,"463":1,"469":2,"470":1,"531":1}}],["root",{"0":{"150":1},"1":{"151":1,"152":1},"2":{"68":1,"87":2,"90":1,"91":1,"94":1,"108":2,"109":2,"110":1,"121":2,"127":4,"128":4,"131":10,"134":1,"136":5,"137":1,"148":9,"150":8,"151":1,"153":12,"154":5,"156":1,"160":6,"163":14,"167":4,"168":1,"169":26,"172":10,"173":2,"177":8,"178":2,"183":5,"184":15,"196":4,"200":3,"203":2,"208":2,"230":1,"236":4,"277":2,"286":2,"311":1,"313":2,"370":1,"461":1,"463":1,"464":1,"469":2,"488":1}}],["role",{"0":{"506":1},"1":{"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1,"514":1},"2":{"60":1,"61":1,"84":1,"414":2,"510":1}}],["roles",{"2":{"36":1}}],["rolling",{"2":{"563":1}}],["rollback",{"2":{"542":8}}],["roll",{"2":{"399":1,"400":1,"402":3}}],["rollkit",{"2":{"48":1,"61":2,"310":1,"316":1}}],["rollupinclusionproofs",{"2":{"164":1,"165":1,"166":1,"168":1,"169":1,"191":1}}],["rollupuserlogic",{"2":{"98":1,"99":1}}],["rollupadminlogic",{"2":{"98":1,"99":1}}],["rollupeventinbox",{"2":{"98":1,"99":1}}],["rollupcreator",{"2":{"89":1,"96":1,"97":1,"98":1,"99":1}}],["rollup",{"0":{"61":1,"66":1,"67":1,"69":1,"70":1,"71":1,"73":1,"79":1,"112":1,"133":1,"135":1,"138":1,"172":1,"208":1,"261":1,"310":1,"399":1},"1":{"67":1,"68":2,"69":2,"70":1,"71":2,"72":2,"74":1,"75":1,"76":1,"77":1,"78":1,"80":1,"81":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,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"136":1,"137":1,"139":1,"140":1,"141":1,"142":1,"143":1,"400":1,"401":1,"402":1,"403":1,"404":1},"2":{"44":1,"61":4,"66":2,"69":4,"71":1,"73":2,"74":1,"79":3,"82":1,"83":3,"86":2,"88":1,"90":1,"91":8,"92":2,"101":1,"111":1,"113":1,"114":1,"122":2,"127":15,"131":1,"133":3,"134":11,"135":15,"139":4,"143":1,"146":2,"148":2,"149":1,"154":2,"158":1,"166":1,"167":1,"169":2,"172":4,"174":1,"175":1,"178":4,"179":2,"180":1,"181":7,"184":3,"187":3,"188":7,"189":2,"191":1,"192":7,"195":2,"196":5,"199":2,"200":4,"203":4,"206":1,"208":2,"236":1,"238":1,"239":1,"243":1,"246":1,"247":1,"259":1,"261":1,"262":1,"264":2,"265":1,"266":5,"304":2,"310":2,"314":2,"315":1,"316":3,"317":1,"321":1,"338":4,"401":1,"403":2,"404":1,"464":1,"490":2,"492":7,"499":1,"507":1,"619":1,"685":2}}],["rollups",{"0":{"104":1,"174":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,"239":1,"259":1,"492":1,"508":1},"1":{"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":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":2,"189":3,"190":3,"191":3,"192":2,"193":3,"194":3,"195":1,"196":2,"197":3,"198":3,"199":2,"200":3,"201":3,"202":3,"203":2,"204":2,"205":2,"206":1,"207":1,"208":1},"2":{"3":1,"43":1,"48":1,"59":1,"61":1,"82":1,"103":1,"133":1,"136":3,"173":1,"174":2,"175":2,"180":1,"187":3,"188":1,"195":2,"200":1,"206":2,"236":4,"239":1,"246":1,"256":1,"260":1,"261":1,"262":1,"264":2,"265":6,"266":3,"337":1,"340":1,"394":1,"399":1,"448":1,"458":1,"467":1,"490":1,"492":3,"508":1,"515":1,"516":1,"733":1,"754":1,"774":1,"777":1,"779":1}}],["roster",{"2":{"27":1}}],["rustasync",{"2":{"420":1,"421":1}}],["rustuse",{"2":{"419":1}}],["rust",{"0":{"417":1},"1":{"418":1,"419":1,"420":1,"421":1,"422":1},"2":{"224":2,"230":1,"236":1,"417":1,"423":1,"693":1,"694":1}}],["rule",{"2":{"31":1,"34":5}}],["rules",{"2":{"23":1,"135":1,"214":1,"467":1}}],["runners",{"2":{"524":1}}],["running",{"0":{"100":1,"102":1,"103":1,"276":1,"307":1,"344":1,"598":1,"769":1},"1":{"101":1,"102":1,"103":1,"599":1,"600":1,"601":1,"770":1,"771":1,"772":1},"2":{"24":1,"60":1,"74":1,"80":1,"87":1,"88":1,"89":1,"91":6,"92":1,"103":1,"107":2,"114":1,"117":2,"119":1,"126":1,"135":1,"220":1,"221":1,"227":1,"236":1,"277":1,"282":2,"291":1,"304":2,"316":1,"317":1,"324":2,"330":1,"362":1,"363":1,"367":3,"370":1,"371":1,"391":1,"402":1,"403":2,"404":1,"407":4,"428":1,"436":2,"451":1,"519":1,"532":1,"538":2,"553":1,"555":1,"556":1,"557":1,"558":1,"561":2,"571":1,"584":1,"597":2,"602":1,"608":3,"613":1,"617":1,"621":1,"633":1,"635":1,"639":2,"651":2,"661":3,"663":1,"664":2,"667":1,"668":1,"670":1,"674":1,"675":2,"679":1,"685":2,"688":1,"689":1,"694":1,"696":1,"710":1,"719":1,"722":1,"727":3,"732":1,"739":1,"754":1,"760":1,"779":1,"783":1,"784":1,"785":1,"786":1,"787":1,"788":2,"794":1,"798":3,"803":2,"808":3}}],["runtime",{"2":{"294":1,"661":4,"700":8,"808":4}}],["rundown",{"2":{"256":1}}],["runs",{"2":{"117":2,"282":2,"430":1,"557":2,"569":1}}],["run",{"0":{"60":1,"89":1,"90":1,"220":1,"221":1,"399":1,"407":1,"538":1,"539":1,"568":1,"662":1,"683":1,"686":1,"729":1,"801":1,"803":1},"1":{"400":1,"401":1,"402":1,"403":1,"404":1,"539":1,"540":1,"663":1,"664":1,"684":1,"685":1,"687":1,"730":1,"802":1},"2":{"1":1,"24":2,"27":1,"57":1,"60":2,"89":1,"90":1,"91":3,"92":1,"102":4,"103":1,"116":3,"117":1,"135":1,"211":1,"213":1,"217":4,"218":2,"219":1,"220":6,"223":3,"224":3,"226":2,"227":2,"244":1,"266":2,"275":1,"276":3,"281":3,"282":1,"284":1,"285":1,"292":1,"293":1,"298":1,"301":1,"303":1,"307":1,"308":2,"310":1,"316":7,"323":1,"340":1,"343":1,"353":1,"355":1,"357":1,"366":2,"368":1,"374":1,"399":1,"401":1,"402":1,"407":1,"410":1,"412":2,"413":2,"415":8,"418":1,"424":1,"519":1,"521":1,"524":1,"531":3,"536":1,"537":1,"539":1,"542":2,"554":1,"557":4,"562":1,"568":3,"569":2,"571":1,"576":1,"585":1,"590":1,"591":1,"593":2,"594":1,"595":2,"602":1,"606":2,"614":1,"616":1,"618":1,"622":1,"623":2,"624":1,"645":1,"650":1,"651":1,"662":1,"664":2,"665":6,"667":9,"669":9,"670":9,"674":1,"676":2,"684":1,"686":1,"688":1,"692":2,"693":1,"697":1,"711":1,"712":1,"713":1,"715":2,"716":1,"718":2,"725":1,"729":1,"739":2,"748":1,"754":3,"760":1,"769":1,"782":1,"783":1,"784":1,"785":3,"797":2,"798":1,"800":1,"801":1,"803":1}}],["rate=0",{"2":{"554":6,"803":6}}],["rates",{"2":{"495":1}}],["rate",{"2":{"445":3,"495":1}}],["rather",{"2":{"235":1,"262":1,"495":1,"515":1}}],["rapid",{"2":{"311":1}}],["rapidly",{"2":{"50":1}}],["rainbow",{"2":{"312":2,"313":8,"314":2}}],["rainbowkitprovider",{"2":{"313":6}}],["rainbowkit",{"2":{"302":1,"311":1,"312":2,"313":10,"314":2}}],["raises",{"2":{"84":1}}],["raise",{"2":{"4":1,"36":1}}],["raas",{"2":{"259":1,"399":2}}],["ram",{"2":{"220":1,"223":1,"224":1,"226":1,"363":1,"424":1,"532":1,"621":1,"635":1,"679":1,"722":1,"771":3,"772":2,"794":1}}],["rawlog",{"2":{"437":4}}],["raw",{"2":{"164":1,"445":1,"531":2,"576":2,"639":10,"675":2,"721":1,"797":2,"803":2}}],["rawmessage",{"2":{"134":2,"137":2}}],["rand",{"2":{"89":1}}],["randomly",{"2":{"461":1}}],["randomness",{"2":{"223":1}}],["random",{"2":{"89":1,"192":1,"223":1,"450":1,"468":1,"470":2}}],["ranges",{"0":{"225":1},"1":{"226":1,"227":1,"228":1},"2":{"225":2,"242":3}}],["range",{"0":{"160":1},"1":{"161":1,"162":1},"2":{"89":1,"107":3,"151":1,"153":6,"156":2,"158":1,"160":3,"165":4,"167":2,"168":4,"169":2,"170":6,"172":26,"183":1,"213":1,"219":2,"220":5,"224":14,"225":1,"226":1,"227":1,"228":2,"236":1,"237":2,"464":2}}],["radio",{"2":{"34":1}}],["race",{"2":{"7":1}}],["reinitializing",{"2":{"710":1}}],["reinitialize",{"2":{"604":1}}],["reindexing",{"2":{"659":2}}],["reindex",{"2":{"659":1}}],["rejoin",{"2":{"563":1}}],["rejected",{"2":{"470":1,"704":1}}],["rejects",{"2":{"470":1}}],["reject",{"2":{"9":1,"463":1}}],["reed",{"2":{"461":2,"463":5,"466":1,"469":1}}],["redelegate",{"2":{"477":1,"481":1,"486":1}}],["redeploy",{"2":{"310":1}}],["reducing",{"2":{"468":1}}],["reduces",{"2":{"351":1}}],["reduce",{"2":{"264":1,"338":1}}],["reduced",{"2":{"40":1,"189":1,"264":1,"470":1,"734":1,"774":1}}],["redundant",{"2":{"452":1}}],["revoke",{"0":{"298":1},"1":{"299":1},"2":{"294":1,"298":3}}],["revert",{"2":{"172":2}}],["reveal",{"2":{"108":1}}],["revisit",{"2":{"46":1}}],["revised",{"2":{"30":1}}],["reviewing",{"2":{"38":1}}],["reviewed",{"2":{"11":1,"21":1,"24":1}}],["review",{"0":{"85":1},"2":{"2":1,"36":1,"53":1,"73":1,"84":1,"85":2,"318":1,"480":2,"485":1}}],["retain",{"0":{"643":1},"2":{"641":1,"643":5,"646":4}}],["retrial",{"2":{"470":1}}],["retried",{"2":{"169":1}}],["retrievable",{"2":{"457":1,"490":1,"749":1}}],["retrievability",{"0":{"459":1,"490":1,"491":1},"1":{"491":1,"492":1},"2":{"456":1,"490":1,"491":1}}],["retrieval",{"2":{"453":1}}],["retrieving",{"0":{"324":1,"376":1,"419":1},"2":{"107":1,"453":1,"457":1,"649":1,"663":1}}],["retrievedblobs",{"2":{"324":2,"436":2}}],["retrieved",{"2":{"145":1,"164":1,"169":1,"370":1,"411":2,"412":2,"413":2,"419":8,"454":1,"492":1}}],["retrieve",{"2":{"107":2,"160":1,"314":1,"359":1,"376":1,"392":1,"401":2,"411":2,"412":2,"413":2,"414":1,"419":2,"454":1}}],["retryable",{"2":{"91":6}}],["retryables",{"2":{"91":4}}],["returning",{"2":{"324":2,"419":2}}],["return",{"2":{"120":1,"127":2,"137":10,"139":12,"171":8,"212":2,"213":3,"224":2,"285":1,"306":4,"314":4,"376":3,"386":1,"414":2,"437":18,"443":2}}],["returns",{"2":{"89":1,"127":2,"135":4,"181":1,"213":1,"306":4,"325":1,"326":1,"327":1,"374":1,"413":1,"414":2,"420":1,"421":1}}],["returned",{"2":{"76":1,"213":3,"314":2,"318":1,"376":1,"464":1,"563":1,"704":1,"797":1}}],["rebasing",{"2":{"84":1}}],["rename",{"2":{"544":2}}],["renaming",{"2":{"544":2}}],["render",{"2":{"313":2}}],["rentals",{"2":{"46":1}}],["renewals",{"2":{"23":1}}],["renewal",{"2":{"23":1,"26":1}}],["refresh",{"2":{"695":2}}],["refreshments",{"0":{"41":1},"2":{"36":1,"41":6,"44":1}}],["refund",{"2":{"428":1,"430":1}}],["refunded",{"2":{"428":1}}],["refers",{"2":{"183":2,"531":1}}],["referred",{"2":{"145":1,"467":1,"469":2}}],["referrals",{"2":{"43":2}}],["referencing",{"2":{"136":1,"179":2,"181":1,"182":1,"208":2}}],["references",{"2":{"196":1}}],["referenced",{"2":{"177":1,"181":1,"192":1,"196":1,"200":1,"203":1}}],["reference",{"0":{"208":1},"2":{"0":1,"3":1,"30":1,"42":1,"148":1,"188":1,"191":1,"195":1,"199":1,"200":1,"208":3,"351":1,"699":6}}],["refer",{"2":{"84":1,"145":1,"211":1,"217":1,"270":1,"276":2,"366":1,"367":1,"375":1,"416":1,"430":2,"436":1,"464":1,"495":1,"521":1,"537":1,"538":1,"563":1,"591":1,"604":1,"624":1,"665":1,"667":2,"685":2,"719":1,"726":1,"754":1,"800":1,"806":1}}],["reward",{"0":{"458":1},"2":{"31":1,"34":1,"43":1,"459":1}}],["rewards",{"0":{"550":1},"2":{"30":5,"31":10,"32":3,"33":1,"34":37,"477":1,"481":1,"486":1,"494":2,"498":1,"500":1,"501":1,"509":1,"510":1,"549":1,"550":3,"563":1}}],["regenerate",{"0":{"223":1}}],["regenerated",{"2":{"212":1}}],["regeneration",{"2":{"220":1}}],["regenerating",{"0":{"222":1},"1":{"223":1,"224":1},"2":{"212":1}}],["regen",{"2":{"149":4}}],["regions",{"2":{"47":1}}],["registry",{"2":{"211":1,"445":1,"639":3,"649":1}}],["registration",{"2":{"34":8,"36":1,"37":1,"53":1,"213":1,"219":1}}],["registering",{"2":{"219":1}}],["registerfunction",{"2":{"213":4}}],["register",{"0":{"213":1},"1":{"214":1,"215":1,"216":1},"2":{"34":2,"213":3,"224":1,"695":2}}],["registered",{"2":{"34":5,"36":1,"211":1,"214":2,"220":2,"244":1}}],["regular",{"2":{"42":1,"48":1,"82":1,"466":1,"560":1}}],["regulation",{"2":{"31":1,"34":6}}],["regardless",{"2":{"7":1,"178":1,"439":1,"441":1}}],["reaped",{"2":{"432":1}}],["reapplying",{"2":{"26":1}}],["reapply",{"2":{"24":1}}],["reactjs",{"2":{"443":1}}],["reactmarkdown",{"2":{"314":4}}],["reactdom",{"2":{"313":4}}],["react",{"0":{"443":1},"2":{"302":1,"311":4,"312":2,"313":2,"314":2,"316":1,"442":1,"443":4}}],["reaching",{"2":{"505":1}}],["reaches",{"2":{"450":1,"495":1}}],["reached",{"2":{"437":2}}],["reach",{"2":{"24":1,"36":1,"43":1,"44":1,"45":1,"46":3,"302":1}}],["real",{"2":{"88":1,"733":1,"788":1,"792":1}}],["readme",{"2":{"402":1,"403":1,"424":1,"564":1}}],["reads",{"2":{"338":2,"414":1}}],["readable",{"2":{"314":2}}],["reader",{"2":{"135":1,"145":1}}],["reading",{"0":{"314":1},"2":{"135":2,"338":4,"366":1,"453":1,"537":1,"623":1,"685":1}}],["read",{"0":{"396":1},"2":{"30":1,"71":1,"76":1,"79":2,"94":1,"107":1,"108":1,"121":1,"134":1,"135":1,"217":1,"286":1,"302":1,"309":1,"310":1,"314":3,"318":1,"357":1,"361":1,"362":1,"369":1,"376":1,"396":1,"429":1,"673":1,"749":1,"754":1}}],["ready",{"2":{"27":1,"76":1,"120":1,"149":1,"258":1,"264":1,"285":2,"287":1,"316":1,"318":1,"405":1,"571":1,"649":1,"690":1,"691":1,"803":1}}],["reasonable",{"2":{"226":1}}],["reasonably",{"2":{"8":1}}],["reason",{"2":{"25":1,"31":2,"336":1}}],["reasons",{"2":{"9":1,"208":1}}],["resubmission",{"0":{"439":1,"440":1},"1":{"440":1,"441":1},"2":{"439":1}}],["resubmitted",{"2":{"440":1}}],["resubmit",{"2":{"432":2,"441":1}}],["results",{"2":{"148":1,"149":1,"383":2,"563":1,"659":4}}],["resulting",{"2":{"148":1,"463":1,"467":1,"608":1}}],["result",{"2":{"24":2,"32":1,"117":2,"121":2,"151":2,"156":4,"161":2,"164":1,"165":1,"218":1,"282":2,"286":2,"296":4,"297":2,"347":1,"374":6,"376":8,"377":2,"379":2,"380":2,"381":2,"382":2,"383":2,"384":2,"386":2,"389":2,"391":3,"397":3,"461":1,"464":2,"467":3,"611":2,"612":3,"613":2,"673":1,"788":2}}],["resolved",{"2":{"694":1}}],["resolve",{"2":{"467":1}}],["resolving",{"2":{"339":1}}],["resolution",{"2":{"262":1,"616":1}}],["resources",{"0":{"390":1,"562":1,"652":1,"806":1},"1":{"391":1,"392":1,"393":1,"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1},"2":{"45":1,"46":2,"49":1,"50":2,"56":1,"57":1,"64":2,"93":1,"143":1,"330":1,"806":2}}],["resource",{"2":{"43":1,"56":1,"65":1,"235":1,"462":2,"468":1,"645":1}}],["resides",{"2":{"108":1}}],["resilience",{"2":{"27":1}}],["resetting",{"0":{"614":1}}],["reset",{"0":{"653":1,"710":1},"2":{"604":1,"615":4,"653":2,"661":2,"710":2,"808":2}}],["reserved",{"2":{"183":1,"469":2,"738":1}}],["reserves",{"2":{"34":1}}],["research",{"2":{"42":1,"44":1,"499":1}}],["restartsec=3",{"2":{"788":2,"790":2,"791":2,"792":2}}],["restart=on",{"2":{"788":2,"790":2,"791":2,"792":2}}],["restart",{"0":{"657":1},"2":{"294":1,"556":1,"598":1,"617":3,"624":1,"657":1,"658":1,"659":1,"661":1,"808":1}}],["restaurant",{"2":{"40":1}}],["restaurants",{"2":{"40":2}}],["rest",{"2":{"136":1,"223":1,"357":1,"407":1,"443":10,"444":1,"445":1,"606":1,"694":1,"695":2,"743":3,"762":4}}],["restrict",{"2":{"214":1,"266":1}}],["restricted",{"2":{"34":5}}],["restrictions",{"2":{"31":1,"34":4,"500":1}}],["resale",{"2":{"34":2}}],["resp",{"2":{"325":6,"414":4,"437":20}}],["respectively",{"2":{"227":1}}],["respective",{"2":{"28":1,"135":1,"139":1,"146":1,"523":1,"524":1,"554":1,"649":2,"747":1,"748":1,"754":1,"759":1,"760":1}}],["respect",{"2":{"11":1,"30":1,"31":1,"32":1,"34":3}}],["respectfully",{"2":{"52":1}}],["respectful",{"2":{"8":1}}],["responses",{"0":{"659":1},"2":{"48":1,"405":1,"416":1,"659":9}}],["response",{"2":{"9":1,"48":1,"151":1,"156":1,"161":1,"163":1,"165":4,"166":1,"168":4,"169":1,"276":1,"277":1,"296":1,"314":4,"376":3,"379":1,"380":1,"381":1,"382":1,"414":2,"415":2,"437":4,"461":1,"611":2}}],["responsible",{"2":{"9":1,"11":1,"31":1,"32":1,"33":2,"84":1,"85":1,"88":1,"135":2,"338":1,"468":1,"492":2}}],["responsibilities",{"0":{"9":1}}],["responsibility",{"2":{"8":1,"9":1,"131":2,"441":1,"457":1}}],["requiring",{"2":{"468":1}}],["requires",{"2":{"128":1,"175":1,"180":1,"202":1,"211":1,"217":1,"226":1,"227":1,"228":1,"236":1,"238":1,"398":1,"457":1}}],["requirement",{"2":{"41":1,"463":1,"560":1}}],["requirements",{"0":{"363":1,"532":1,"635":1,"646":1,"679":1,"706":1,"722":1,"770":1,"794":1},"2":{"24":1,"34":4,"36":1,"43":1,"60":1,"61":1,"84":1,"206":1,"336":2,"363":1,"532":1,"635":1,"646":1,"679":1,"706":1,"722":1,"794":1}}],["required",{"2":{"32":1,"34":1,"35":1,"36":1,"84":1,"158":1,"197":1,"211":1,"220":1,"246":1,"264":1,"276":1,"310":1,"366":1,"372":1,"410":1,"411":1,"430":1,"463":1,"537":1,"591":1,"595":1,"604":1,"605":2,"606":1,"649":1,"665":1,"667":1,"685":1,"719":1,"726":1,"798":1,"800":1}}],["require",{"2":{"31":1,"103":1,"127":4,"173":1,"178":1,"180":1,"236":1,"265":1,"306":2,"369":1,"457":1,"458":1,"463":2,"467":2,"608":1,"645":1,"690":1}}],["requisites",{"0":{"291":1,"304":1,"626":1},"2":{"310":1}}],["requestheaderrange",{"2":{"228":1,"242":1}}],["requesting",{"0":{"225":1},"1":{"226":1,"227":1,"228":1},"2":{"227":1,"228":1,"476":1}}],["requests",{"2":{"211":2,"227":1,"228":1,"370":1,"459":2,"464":1,"470":1,"492":1,"531":1,"654":1}}],["requested",{"2":{"13":1,"225":1,"227":1,"228":1,"242":1}}],["request",{"0":{"156":1,"161":1,"227":1,"228":1},"2":{"2":2,"44":1,"107":1,"151":1,"156":1,"161":1,"164":1,"165":1,"225":1,"227":1,"228":1,"367":1,"369":1,"371":1,"407":1,"443":2,"469":1,"526":1,"538":1,"563":1,"608":1,"611":2,"612":2,"648":1,"685":1,"728":1,"765":1,"772":1}}],["rec",{"2":{"437":4}}],["recipient",{"2":{"386":1,"549":2}}],["recipients",{"2":{"34":1}}],["recency",{"2":{"491":2}}],["recent",{"2":{"107":1,"395":1,"749":1}}],["receiptsroot",{"2":{"395":2}}],["receipt",{"2":{"32":3,"34":4,"500":1}}],["receiving",{"2":{"27":1,"31":2,"34":1,"420":2}}],["receiveroutine",{"2":{"661":4,"808":4}}],["receiver",{"2":{"76":2,"91":4,"318":2}}],["receiver=",{"2":{"76":2,"318":2}}],["received",{"2":{"24":1,"33":1,"171":1,"461":1,"470":2,"721":1}}],["receives",{"2":{"23":3,"447":1,"498":1,"510":1}}],["receive",{"2":{"21":1,"23":1,"27":1,"29":1,"30":1,"31":4,"33":3,"34":3,"53":1,"54":1,"211":1,"325":1,"326":1,"377":1,"420":1,"451":1,"461":1,"501":1,"734":1,"774":1}}],["recap",{"2":{"54":1}}],["recruiting",{"2":{"48":2}}],["reconstructing",{"2":{"463":1}}],["reconstruction",{"0":{"452":1}}],["reconstruct",{"2":{"451":1,"452":1,"492":1}}],["recoverable",{"2":{"463":1}}],["recovered",{"2":{"461":1}}],["recover",{"2":{"272":6,"573":2,"590":1}}],["recompute",{"2":{"108":1}}],["recommend",{"2":{"84":1,"103":1,"302":1,"330":1,"403":2,"424":1,"515":1,"623":2,"754":1}}],["recommends",{"2":{"47":1}}],["recommendations",{"2":{"41":1}}],["recommended",{"0":{"770":1},"2":{"24":1,"35":1,"88":1,"208":1,"211":2,"220":1,"267":1,"313":2,"356":1,"363":1,"443":2,"470":1,"532":1,"538":1,"548":1,"619":1,"621":1,"635":1,"663":1,"673":1,"679":1,"685":1,"722":1,"785":1,"794":1,"798":1}}],["recognizable",{"2":{"84":1}}],["recognize",{"2":{"53":1}}],["recognition",{"2":{"43":1}}],["recorded",{"2":{"46":4}}],["record",{"2":{"40":1}}],["recording",{"0":{"46":1},"2":{"40":2,"46":6}}],["recordings",{"2":{"5":1,"40":1,"46":3}}],["recourse",{"2":{"31":2}}],["remainder",{"2":{"293":1,"310":1,"563":1,"569":1,"576":1}}],["remain",{"2":{"265":1,"426":1,"490":1,"555":1,"643":1,"692":1,"711":1}}],["remaining",{"2":{"165":2,"166":1,"262":1,"301":1,"500":4,"579":1,"738":1}}],["remains",{"2":{"19":1,"208":1,"230":1,"734":1,"774":1}}],["removing",{"2":{"563":1}}],["removed",{"2":{"91":2,"161":1,"162":1,"357":1,"362":1,"411":1,"563":2,"606":1}}],["removechainowner",{"2":{"91":2}}],["remove",{"2":{"9":1,"313":2,"396":2,"593":1,"615":1,"621":1}}],["remote",{"2":{"46":1,"248":1,"368":1,"424":1,"531":1,"542":2,"557":2,"628":3,"633":1}}],["remember",{"2":{"40":1,"44":1,"250":1,"266":1,"396":1,"658":1,"659":1,"734":1}}],["reminders",{"2":{"45":1}}],["reminder",{"2":{"36":1,"45":1,"71":1}}],["repeat",{"2":{"714":1}}],["replicated",{"2":{"467":1}}],["replaced",{"2":{"170":2}}],["replace",{"2":{"153":2,"192":1,"371":1,"432":1,"569":1,"716":1,"726":1}}],["replaces",{"2":{"149":1,"223":1,"466":1,"655":1}}],["replacing",{"2":{"91":2,"276":1,"277":1,"591":1}}],["replaying",{"2":{"220":1,"221":1,"492":1}}],["replayer",{"0":{"221":1},"2":{"217":2}}],["replay",{"2":{"94":1,"108":1}}],["repo",{"2":{"126":2,"211":1,"212":1,"236":1,"531":2,"554":1,"639":1,"716":1,"718":1}}],["report",{"2":{"28":1,"616":2}}],["reporting",{"2":{"24":1}}],["reporter",{"2":{"11":1}}],["reported",{"2":{"11":1}}],["repository",{"0":{"87":1,"339":1},"2":{"0":1,"1":1,"2":2,"4":1,"87":3,"90":1,"91":1,"126":1,"217":1,"220":2,"221":1,"237":1,"242":1,"246":1,"268":1,"269":1,"339":1,"424":1,"593":1,"621":1,"639":2,"804":1}}],["represents",{"2":{"107":2,"369":1}}],["represented",{"2":{"34":1}}],["represent",{"2":{"32":1,"33":1,"34":2,"146":1}}],["representation",{"2":{"34":2,"135":1,"165":2,"166":2}}],["representations",{"0":{"34":1},"2":{"31":1,"34":2}}],["representative",{"2":{"10":1}}],["representing",{"2":{"10":2}}],["reloadsudo",{"2":{"617":1}}],["reload",{"2":{"617":2}}],["rely",{"2":{"224":1,"234":1,"332":1,"492":1,"521":2,"740":2,"742":2,"758":2}}],["relying",{"2":{"32":1,"233":1,"492":1}}],["relaying",{"0":{"693":1},"1":{"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1},"2":{"288":1,"694":1,"696":3}}],["relayers",{"2":{"693":1}}],["relayer",{"0":{"696":1,"702":1},"2":{"215":1,"237":1,"244":1,"693":3,"694":2,"702":1}}],["relayed",{"2":{"107":2,"128":1,"129":1,"133":1,"136":1,"137":1,"228":1}}],["relay",{"2":{"107":1,"220":1,"244":1,"693":1,"695":1}}],["relays",{"2":{"95":1,"109":1,"230":1}}],["relatively",{"2":{"336":1,"439":1}}],["relative",{"0":{"336":1},"2":{"202":1,"336":1}}],["relations",{"2":{"45":1}}],["relationships",{"2":{"38":1,"42":1}}],["relating",{"2":{"32":1}}],["related",{"2":{"31":1,"33":1,"34":1,"44":1,"48":1,"64":1,"366":1,"456":1,"537":1,"685":2,"726":1}}],["release",{"2":{"220":1,"224":4,"491":1,"691":1,"693":1}}],["releasesource",{"2":{"220":1}}],["releases",{"2":{"161":1,"162":1,"594":1,"622":1}}],["released",{"2":{"31":1,"694":1}}],["relevant",{"2":{"30":1,"34":1,"43":2,"45":2,"48":1,"437":2,"460":1,"470":1,"519":2,"661":1,"721":1,"739":2,"754":2,"808":1}}],["relevantly",{"2":{"2":1}}],["relies",{"2":{"649":1,"693":1}}],["relied",{"2":{"34":1}}],["reliability",{"2":{"33":1}}],["reliance",{"2":{"31":3,"34":2}}],["religion",{"2":{"7":1}}],["re",{"2":{"2":1,"40":1,"41":1,"52":1,"75":1,"76":1,"79":2,"84":2,"89":1,"120":1,"126":1,"148":1,"172":2,"182":1,"187":1,"192":1,"211":3,"219":6,"224":2,"236":1,"256":1,"258":1,"265":1,"277":1,"285":2,"287":1,"302":1,"313":2,"315":1,"316":2,"318":2,"405":1,"416":1,"424":1,"437":4,"439":1,"444":1,"445":1,"559":1,"604":1,"614":1,"616":1,"619":1,"621":1,"623":1,"661":1,"668":2,"698":1,"808":1}}],["sql",{"2":{"520":1,"740":1,"758":1}}],["squaresizeupperbound",{"2":{"159":2}}],["square",{"0":{"147":1,"327":1,"421":1},"2":{"107":1,"108":2,"131":3,"136":1,"146":2,"153":2,"159":6,"172":2,"177":1,"181":2,"182":1,"183":9,"184":1,"327":1,"421":1,"469":3,"738":4}}],["snaps",{"2":{"650":12}}],["snapshots",{"2":{"492":4,"646":1,"649":3}}],["snapshot",{"2":{"456":1,"647":2,"650":1}}],["snap",{"2":{"650":24}}],["snippets",{"2":{"145":1,"149":1,"411":1}}],["ss",{"2":{"430":1}}],["ssd",{"2":{"363":1,"532":1,"635":1,"679":1,"722":1,"771":3,"772":2,"794":1}}],["sgvsbg8gd28ybgqh",{"2":{"397":2}}],["svg",{"0":{"392":1},"2":{"392":2,"445":1}}],["s3",{"2":{"223":16}}],["srl59gitsiwc9lqdyaszfc6tvusyy7njx8",{"2":{"161":2}}],["src",{"2":{"77":2,"116":1,"117":2,"120":2,"169":2,"212":2,"281":1,"282":2,"284":2,"285":2,"305":1,"306":3,"308":2,"313":1,"316":2,"319":2,"443":8,"661":4,"808":4}}],["skipauth",{"2":{"608":1}}],["skip",{"2":{"210":1,"224":2,"323":1,"362":1,"407":2,"412":2,"413":2,"415":2,"418":1,"698":1,"785":1,"798":1}}],["skipped",{"2":{"117":2,"120":2,"282":2,"285":2}}],["skillsets",{"2":{"52":1}}],["sdk",{"2":{"94":4,"149":7,"266":1,"268":1,"331":4,"332":2,"333":1,"335":1,"336":1,"424":1,"425":1,"429":1,"437":2,"466":1,"471":1,"494":3,"498":1,"509":1,"519":1,"531":1,"542":2,"548":2,"560":1,"563":1,"694":1,"739":1,"762":1,"763":1}}],["switching",{"2":{"604":1}}],["switch",{"2":{"83":1,"172":2,"316":1,"338":1,"443":2,"445":1,"557":1}}],["swag",{"0":{"63":1},"2":{"43":1}}],["symbol",{"2":{"313":2,"315":1,"445":2}}],["sync|async|block",{"2":{"585":2}}],["sync",{"0":{"523":1,"647":1,"648":1,"649":1,"650":1,"747":1,"759":1},"1":{"648":1,"649":1,"650":1},"2":{"335":3,"401":1,"454":1,"492":3,"523":1,"584":1,"585":2,"618":1,"634":1,"647":4,"648":2,"649":4,"650":2,"661":1,"747":1,"759":1,"769":1,"788":4,"792":1,"808":1}}],["syncing",{"0":{"335":1,"618":1},"1":{"619":1},"2":{"335":1,"453":1,"490":1,"541":1,"618":1,"648":1,"661":1,"790":1,"791":2,"792":1,"802":1,"808":1}}],["synced",{"2":{"80":1,"401":1}}],["syndtr",{"2":{"149":4}}],["systemctl",{"2":{"617":4,"788":6,"790":4,"791":4,"792":6}}],["systemd",{"0":{"541":1,"553":1,"688":1,"731":1,"786":1,"788":1,"802":1},"1":{"787":1,"788":1,"789":1,"790":1,"791":1,"792":1},"2":{"541":1,"553":7,"617":2,"651":1,"688":1,"731":1,"786":1,"788":6,"790":5,"791":5,"792":4,"802":1}}],["systems",{"2":{"332":1,"557":2,"594":1,"622":1}}],["system",{"2":{"23":1,"36":1,"233":1,"355":1,"429":1,"430":2,"467":2,"555":2,"558":1,"559":1,"617":5,"621":1,"665":1,"697":1,"788":4,"790":4,"791":4,"792":4}}],["smartstake",{"2":{"752":1}}],["smart",{"0":{"112":1,"116":1,"117":1,"118":1,"121":1,"260":1,"278":1,"281":1,"282":1,"283":1,"286":1},"1":{"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":2,"120":2,"121":1,"122":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":2,"285":2,"286":1,"287":1},"2":{"73":1,"74":1,"79":1,"85":2,"88":1,"113":2,"116":1,"122":1,"131":7,"133":1,"145":1,"148":1,"150":1,"151":1,"156":1,"161":1,"163":5,"169":2,"173":1,"178":1,"183":1,"184":2,"225":1,"236":2,"237":1,"238":1,"240":1,"242":1,"243":1,"250":1,"260":1,"262":1,"264":1,"266":1,"278":1,"281":1,"285":1,"287":1,"302":1,"304":1,"305":1,"306":2,"308":1,"310":1,"314":2,"318":2,"340":1,"424":1,"456":1,"508":1}}],["smartphone",{"2":{"40":1}}],["smaller",{"2":{"426":1}}],["small",{"2":{"46":1,"107":1,"134":1,"206":1,"265":1,"450":1,"462":1,"468":1}}],["smooth",{"2":{"43":1}}],["sausage",{"2":{"573":2}}],["sandbox",{"2":{"750":1}}],["sanity",{"2":{"412":1}}],["sanctions",{"2":{"24":1,"31":1}}],["sashabaranov",{"2":{"410":2,"411":2}}],["salt=",{"2":{"211":2}}],["salt",{"2":{"211":5,"213":4,"219":2}}],["sales",{"2":{"34":1,"44":1,"525":1,"765":1}}],["sale",{"2":{"34":3}}],["save",{"0":{"569":1,"646":1},"2":{"211":1,"219":1,"407":2,"411":1,"548":1,"557":1,"590":1,"614":1,"646":1,"658":1,"659":1,"712":1,"749":1}}],["saved",{"2":{"146":1,"148":1,"178":1,"193":1,"196":1}}],["saving",{"2":{"43":1,"180":1,"548":1}}],["said",{"2":{"94":1}}],["sampling",{"0":{"450":1,"451":1,"461":1,"732":1},"1":{"462":1,"463":1},"2":{"59":1,"230":1,"265":1,"336":1,"385":2,"449":1,"450":5,"451":1,"452":1,"460":1,"461":3,"463":1,"468":2,"491":3,"531":1,"720":1,"734":1,"769":1,"783":1,"792":1}}],["samplefrom",{"2":{"618":2}}],["samples",{"2":{"462":1}}],["sampled",{"2":{"451":1,"470":1}}],["sampler",{"0":{"385":1}}],["sample",{"0":{"59":1,"60":1,"61":1,"62":1},"2":{"59":2,"60":2,"61":2,"62":2,"172":1,"468":1,"491":1,"618":1}}],["same",{"0":{"432":1},"2":{"34":1,"75":1,"110":1,"134":1,"148":1,"179":1,"184":1,"193":1,"196":1,"200":2,"211":2,"213":1,"233":1,"244":1,"318":1,"333":1,"347":1,"355":1,"437":2,"467":2,"557":4,"563":1,"608":1,"619":3,"639":1,"711":1,"713":1,"803":1}}],["safely",{"2":{"109":1,"468":1,"609":1}}],["safe",{"2":{"52":1,"407":2,"562":1,"573":2}}],["satisfied",{"2":{"34":1}}],["satisfy",{"2":{"34":1}}],["shnode",{"2":{"791":1}}],["shpeer=",{"2":{"718":1}}],["ship",{"2":{"718":1}}],["shirts",{"2":{"43":1}}],["shtia",{"2":{"713":1}}],["shutdown",{"2":{"689":1}}],["shsed",{"2":{"655":1}}],["shstaking",{"2":{"554":1,"715":1}}],["shsudo",{"2":{"553":1,"788":4,"790":2,"791":2,"792":4}}],["shkey",{"2":{"554":1,"712":1}}],["shvalidator",{"2":{"554":1,"711":1}}],["shgo",{"2":{"415":2}}],["shgit",{"2":{"126":1,"269":1}}],["shmkdir",{"2":{"410":1}}],["shexternal",{"2":{"656":1}}],["shexport",{"2":{"408":1}}],["sherror",{"2":{"614":1}}],["shevm",{"2":{"554":1}}],["shellsource",{"2":{"220":1}}],["shellforge",{"2":{"219":1}}],["shelltendermint",{"2":{"218":1}}],["shellcast",{"2":{"213":3,"215":1,"216":1}}],["shellcd",{"2":{"211":1,"212":1,"217":1,"219":1,"220":1,"223":1}}],["shell",{"2":{"211":2,"676":1}}],["shellgit",{"2":{"211":1,"424":1}}],["shcurl",{"2":{"788":1}}],["shcat",{"2":{"788":1,"790":1,"791":1,"792":1}}],["shceles",{"2":{"554":1}}],["shcelestia",{"2":{"344":1,"346":1,"347":1,"407":3,"537":4,"538":3,"539":3,"543":1,"545":3,"546":2,"547":5,"548":5,"549":2,"550":1,"551":2,"552":1,"590":3,"591":1,"593":1,"598":1,"599":1,"600":1,"604":1,"618":2,"651":4,"653":1,"684":3,"685":1,"686":3,"710":1,"716":1,"719":1,"725":3,"726":3,"727":3,"729":3,"803":4}}],["shcd",{"2":{"402":1,"568":1}}],["sha3uncles",{"2":{"395":2}}],["sharing",{"2":{"46":1,"65":1,"492":1}}],["shareversionzero",{"2":{"437":2}}],["shareclient",{"2":{"419":2}}],["shareindexinrowmajororder",{"2":{"184":2}}],["shareindexinrow",{"2":{"184":4}}],["shareproof",{"2":{"172":2,"184":6}}],["shareproofs",{"0":{"165":1},"2":{"163":2,"165":3,"172":4,"184":2}}],["sharesize",{"2":{"430":1}}],["sharesproof",{"2":{"163":3,"165":1,"166":1,"167":1,"168":1,"172":18}}],["shares",{"2":{"127":2,"131":5,"134":3,"136":1,"146":4,"148":3,"154":1,"160":3,"161":4,"163":14,"164":1,"165":2,"166":1,"167":1,"168":1,"172":4,"178":1,"181":1,"184":4,"189":1,"208":4,"233":1,"376":2,"426":2,"429":2,"430":2,"431":1,"461":5,"463":4,"464":3,"468":1,"469":4,"470":3,"531":1,"678":2,"738":4}}],["shared",{"2":{"65":1,"302":2,"715":1}}],["share",{"0":{"160":1,"176":1,"177":1,"178":1,"179":1,"180":1,"192":1,"193":1,"194":1,"199":1,"201":1,"202":1},"1":{"161":1,"162":1,"177":1,"178":1,"179":1,"180":1,"193":1,"194":1,"200":1,"201":1,"202":1},"2":{"27":1,"31":1,"36":1,"38":1,"40":1,"43":1,"45":4,"46":3,"48":1,"134":6,"146":2,"148":5,"156":5,"158":1,"160":6,"161":2,"172":2,"175":1,"176":1,"177":11,"178":2,"179":1,"181":2,"182":1,"183":2,"184":9,"185":1,"189":2,"192":7,"193":1,"195":1,"197":1,"199":1,"200":5,"203":7,"208":3,"314":2,"317":1,"324":7,"325":2,"326":4,"327":3,"374":1,"376":8,"384":2,"389":3,"391":2,"411":2,"413":7,"421":3,"426":2,"429":1,"430":2,"436":6,"461":1,"469":1,"470":1,"492":2,"501":1,"554":1,"612":2,"614":4,"714":1,"716":1,"718":3,"738":3}}],["sh",{"2":{"211":2,"269":2,"273":1,"276":2,"277":2,"310":3,"349":1,"350":1,"393":1,"538":1,"544":1,"561":4,"568":1,"569":2,"594":2,"616":1,"622":2,"675":2,"685":1,"727":2}}],["shforge",{"2":{"126":1}}],["shove",{"2":{"573":2}}],["shoutout",{"2":{"44":1}}],["shouldn",{"2":{"457":1}}],["should",{"0":{"208":1},"2":{"27":1,"40":1,"44":1,"56":1,"84":1,"85":1,"116":1,"117":1,"145":1,"164":1,"195":1,"196":1,"208":1,"211":3,"213":1,"217":1,"219":1,"220":1,"223":5,"224":2,"225":2,"230":1,"270":1,"281":1,"282":1,"316":1,"336":2,"374":1,"398":2,"403":1,"407":1,"428":1,"429":1,"440":1,"492":1,"508":1,"521":1,"557":1,"594":1,"609":1,"617":1,"622":1,"643":1,"645":1,"649":3,"697":1,"700":2,"705":1,"711":1,"715":1,"716":2,"740":1,"742":1,"758":1,"790":1,"791":1,"797":2,"803":2}}],["showing",{"2":{"297":1}}],["shown",{"2":{"243":1,"612":1,"803":1}}],["shows",{"2":{"148":1,"191":1,"389":1,"437":2,"464":1,"466":1}}],["showcase",{"2":{"44":1}}],["show",{"2":{"43":1,"44":1,"183":1,"301":1,"302":1,"391":1,"399":1,"443":1,"519":1,"554":2,"579":2,"609":1,"611":1,"621":1,"676":1,"718":2,"725":2,"739":1,"754":1,"782":1,"797":2,"803":3}}],["shortly",{"2":{"69":1}}],["short",{"2":{"34":1,"43":1,"669":1,"691":1}}],["scan",{"2":{"693":1}}],["scattered",{"2":{"405":1}}],["scavenger",{"0":{"405":1,"409":1},"1":{"406":1,"407":1,"408":1,"409":1,"410":2,"411":2,"412":2,"413":2,"414":2,"415":2,"416":1},"2":{"358":1,"405":1,"410":6,"415":1}}],["scaling",{"0":{"265":1},"2":{"265":2,"447":1,"448":1,"460":1}}],["scalable",{"2":{"235":1,"302":1,"338":1,"457":1,"460":1,"468":1}}],["scalability",{"0":{"235":1,"462":1},"2":{"109":1,"235":2}}],["scale",{"2":{"265":2,"462":1}}],["scaleway",{"2":{"223":1,"224":1}}],["scales",{"2":{"174":1,"230":1,"468":2}}],["scraped",{"2":{"557":2}}],["scrape",{"2":{"557":16}}],["scratches",{"2":{"266":1}}],["scratch",{"2":{"264":1}}],["scroll",{"2":{"445":1}}],["scrolling",{"2":{"444":1}}],["scripting",{"2":{"308":1}}],["scripts",{"2":{"119":1,"561":2,"568":2,"569":2}}],["script",{"0":{"87":1,"308":1},"2":{"68":1,"75":4,"87":5,"90":1,"91":7,"92":1,"211":2,"219":4,"227":2,"308":7,"309":4,"310":6,"318":4,"407":1,"415":1,"561":2,"568":1,"594":1,"622":1}}],["screening",{"2":{"31":1}}],["screen",{"2":{"24":1,"40":1,"476":1,"480":1}}],["scheme",{"0":{"148":1},"2":{"177":1,"461":1,"463":1,"466":1,"469":1}}],["schemes",{"2":{"58":1,"331":1}}],["schedules",{"2":{"500":1}}],["schedule",{"2":{"36":1,"37":1,"41":1,"43":1,"48":1,"500":2,"505":1}}],["schools",{"2":{"44":1}}],["scene",{"2":{"42":1}}],["scope",{"0":{"10":1},"2":{"62":1}}],["sl",{"2":{"594":2,"622":2,"639":8}}],["slack",{"2":{"559":1}}],["slas",{"2":{"521":1,"740":1,"742":1,"758":1}}],["slashboard",{"2":{"752":1}}],["slashing",{"0":{"563":1},"2":{"331":1,"552":2,"563":3}}],["slashed",{"2":{"24":1,"25":1,"27":1,"217":1,"563":4}}],["slower",{"2":{"779":1}}],["slowest",{"2":{"648":1}}],["slowly",{"2":{"403":3}}],["slots",{"2":{"21":1,"23":1}}],["slightly",{"2":{"738":1}}],["slice",{"2":{"324":3,"413":2}}],["slides",{"2":{"43":1}}],["soundness",{"2":{"470":1}}],["sourcing",{"2":{"264":1}}],["source",{"0":{"593":1,"621":1},"2":{"89":1,"148":1,"219":2,"402":2,"549":2,"557":4,"592":1,"602":1,"676":4,"694":1,"695":4,"763":1}}],["sources",{"2":{"33":1,"557":1}}],["soon",{"2":{"304":1}}],["software",{"0":{"518":1,"736":1,"756":1,"775":1,"778":1,"780":1},"2":{"60":1,"61":1,"110":1,"230":1,"516":1,"674":1,"690":2,"754":1,"784":1,"785":1}}],["sovereign",{"0":{"61":1,"310":1},"2":{"59":1,"61":5,"317":1,"516":1,"685":2,"754":1,"777":1,"779":1}}],["soda",{"2":{"41":1}}],["sometimes",{"2":{"531":1,"678":1}}],["something",{"2":{"102":1,"108":1,"224":2,"383":2,"407":1,"557":1,"596":1}}],["somewhere",{"2":{"407":2,"712":1}}],["some",{"0":{"184":1,"451":1,"459":1},"2":{"40":1,"46":1,"82":1,"90":1,"134":3,"135":1,"137":1,"163":4,"169":2,"175":1,"261":1,"265":1,"266":1,"293":1,"331":1,"334":1,"374":1,"405":1,"407":1,"412":2,"415":1,"419":2,"420":4,"421":2,"437":2,"458":1,"459":1,"469":1,"490":1,"492":1,"500":1,"548":1,"549":1,"557":1,"561":4,"584":1,"586":1,"602":1,"627":1,"691":1,"700":8}}],["someone",{"2":{"37":1,"45":1}}],["solomon",{"2":{"461":2,"463":5,"466":1,"469":1}}],["solution",{"2":{"139":1,"174":1,"206":1,"230":1,"235":1,"460":1,"463":1,"467":1,"468":1}}],["solutions",{"2":{"109":1,"432":1,"448":1,"460":1}}],["solc",{"2":{"116":2,"281":2}}],["solid",{"2":{"314":2}}],["solidityuint256",{"2":{"184":1}}],["soliditypragma",{"2":{"172":1}}],["solidity",{"2":{"114":1,"116":4,"117":3,"126":1,"127":4,"151":1,"156":1,"161":1,"163":1,"165":6,"166":1,"168":4,"169":2,"172":2,"173":1,"177":1,"222":1,"240":1,"279":1,"281":4,"282":3,"306":6,"308":4}}],["soliciting",{"2":{"38":1}}],["solicits",{"2":{"34":1}}],["solicit",{"2":{"34":1}}],["solicited",{"2":{"34":1}}],["solicitation",{"2":{"34":3}}],["sol",{"2":{"75":2,"77":3,"109":1,"116":1,"117":7,"120":2,"127":7,"129":1,"131":1,"164":1,"165":1,"166":1,"168":1,"169":1,"172":4,"212":3,"219":2,"223":4,"224":4,"237":1,"242":1,"243":1,"281":1,"282":7,"284":2,"285":2,"305":1,"306":6,"308":5,"309":2,"310":2,"311":2,"318":2,"319":3}}],["sold",{"2":{"34":1}}],["solely",{"2":{"31":1,"492":1}}],["sole",{"2":{"25":1,"30":1,"31":1,"34":1}}],["so",{"2":{"23":1,"24":2,"29":1,"32":1,"34":1,"41":2,"45":1,"71":1,"89":1,"126":1,"134":2,"148":2,"158":1,"159":1,"165":3,"182":1,"183":1,"196":1,"208":1,"219":1,"224":1,"258":1,"270":1,"308":1,"310":1,"311":1,"313":2,"316":1,"366":1,"370":1,"405":1,"444":1,"449":1,"451":1,"452":2,"464":1,"470":1,"490":1,"516":1,"537":1,"539":1,"576":1,"581":1,"614":1,"646":1,"651":1,"653":1,"673":1,"676":1,"686":1,"705":1,"710":1,"718":2,"729":1,"748":1,"749":1,"803":1}}],["sorted",{"2":{"441":1}}],["sort",{"2":{"15":1,"16":1,"34":1}}],["social",{"2":{"10":1,"14":1,"36":1,"38":1,"45":4,"46":1,"321":1,"548":1}}],["socio",{"2":{"7":1}}],["spidey",{"2":{"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["spinning",{"2":{"601":1}}],["spin",{"0":{"317":1,"709":1},"1":{"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1},"2":{"709":1}}],["splits",{"2":{"469":1}}],["split",{"2":{"146":1,"461":1,"463":1,"469":1,"488":1,"499":1}}],["sp1blobstreamwrapper",{"2":{"153":2,"170":2,"171":2,"172":2}}],["sp1blobstream",{"2":{"145":2,"237":1}}],["sp1",{"0":{"236":1,"237":1,"423":1},"1":{"238":1,"239":1,"240":1,"424":1},"2":{"145":2,"153":4,"170":4,"171":4,"172":4,"230":3,"231":1,"236":10,"237":6,"240":8,"423":3,"424":14}}],["sparse",{"2":{"738":2}}],["sparsesharesneeded",{"2":{"430":1}}],["spans",{"0":{"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"188":1,"189":1,"190":1,"191":1,"196":1,"197":1,"198":1},"1":{"182":1,"183":1,"184":1,"185":1,"186":1,"189":1,"190":1,"191":1,"197":1,"198":1},"2":{"156":1,"160":1,"175":1,"181":3,"182":1,"183":3,"184":7,"185":1,"188":4,"191":1,"192":2,"195":1,"196":5,"206":3,"208":2}}],["span",{"0":{"398":1},"2":{"134":12,"135":4,"136":2,"137":8,"139":3,"163":4,"165":1,"183":1,"398":2}}],["space",{"2":{"52":1,"558":1,"658":1,"659":2,"742":1,"743":1,"744":1,"749":1}}],["spaces",{"2":{"10":2,"14":1,"40":5,"44":1}}],["spdx",{"2":{"116":2,"117":2,"127":2,"281":2,"282":2,"306":4,"308":2}}],["sponsoring",{"2":{"44":1}}],["sponsorship",{"2":{"44":5}}],["sponsors",{"0":{"44":1},"2":{"44":9,"45":1,"52":1}}],["spread",{"2":{"42":1,"45":1}}],["speed",{"2":{"440":1,"647":1}}],["spend",{"2":{"295":2,"300":2,"430":1,"498":1,"548":1,"549":7}}],["spec",{"2":{"750":1}}],["specialization",{"2":{"467":1}}],["specialized",{"2":{"467":3}}],["specialize",{"2":{"262":1}}],["specif",{"2":{"163":2,"169":2}}],["specifying",{"2":{"346":1,"347":1,"428":1,"557":1}}],["specify",{"2":{"84":1,"211":4,"270":1,"351":1,"366":2,"377":1,"432":1,"537":2,"608":1,"669":2}}],["specifies",{"2":{"84":1,"270":1,"295":1}}],["specified",{"2":{"14":1,"15":1,"85":1,"211":1,"212":1,"220":2,"222":1,"224":2,"227":1,"270":1,"295":1,"369":1,"377":1,"391":1,"428":2,"430":1,"491":1,"513":1,"542":2,"602":1}}],["specifications",{"2":{"134":1,"563":1,"691":1,"737":1}}],["specifically",{"2":{"65":1,"88":1,"447":1,"456":1,"649":1}}],["specific",{"0":{"160":1},"1":{"161":1,"162":1},"2":{"34":1,"41":1,"43":1,"48":1,"84":1,"107":1,"129":2,"134":2,"135":4,"137":1,"216":1,"223":2,"224":3,"226":2,"233":1,"235":1,"242":1,"302":1,"369":2,"388":1,"443":1,"529":1,"558":1,"595":1,"606":1,"608":1,"691":1,"714":1,"753":1,"768":1,"781":1}}],["specs",{"2":{"146":2,"148":1,"165":2,"166":2,"169":4,"376":1,"431":1,"548":2}}],["speak",{"2":{"43":1}}],["speaking",{"2":{"42":1,"48":1}}],["speaker",{"0":{"65":1},"2":{"36":1,"40":1,"42":1,"43":3,"56":1,"65":5}}],["speakers",{"0":{"43":1},"2":{"36":3,"37":1,"38":1,"40":1,"42":5,"43":13,"44":2,"45":3,"48":2,"52":1,"62":1,"65":2}}],["sed",{"2":{"639":12,"656":2}}],["semantic",{"2":{"621":1}}],["semi",{"2":{"233":1}}],["severe",{"2":{"563":1}}],["severity",{"2":{"448":1}}],["several",{"2":{"107":1,"225":1,"366":1,"500":1,"691":1,"738":1,"767":1,"769":1}}],["sequential",{"2":{"266":1,"695":4}}],["sequence",{"0":{"181":1,"182":1,"183":1,"184":1,"185":1,"186":1,"188":1,"189":1,"190":1,"191":1,"196":1,"197":1,"198":1},"1":{"182":1,"183":1,"184":1,"185":1,"186":1,"189":1,"190":1,"191":1,"197":1,"198":1},"2":{"175":1,"181":3,"182":1,"183":3,"184":7,"185":1,"188":4,"191":1,"192":2,"195":1,"196":5,"206":3,"208":2,"288":1,"429":1,"432":1,"437":2,"467":2,"577":2,"578":2,"696":1}}],["sequencers",{"2":{"171":1,"192":1,"264":1}}],["sequencersignature",{"2":{"134":2,"137":2,"139":2}}],["sequenceraddress",{"2":{"134":2,"139":2}}],["sequencer",{"0":{"135":1},"1":{"136":1,"137":1},"2":{"108":1,"110":2,"134":3,"135":7,"136":2,"137":8,"139":8,"288":1,"403":4}}],["sequencerinbox",{"2":{"89":2,"98":2,"99":2,"109":1}}],["separation",{"2":{"467":1}}],["separating",{"2":{"265":1}}],["separately",{"2":{"192":1}}],["separated",{"2":{"146":1,"220":1,"639":2,"717":2}}],["separate",{"2":{"31":2,"165":1,"293":1,"355":1,"461":1,"470":1,"531":2,"601":1}}],["sepoliaeth",{"2":{"403":1}}],["sepoliafaucet",{"2":{"82":1}}],["sepolia",{"0":{"82":1,"96":1,"97":1,"98":1,"99":1},"2":{"69":2,"71":2,"79":1,"80":1,"82":3,"83":1,"85":1,"88":4,"91":2,"95":2,"96":1,"97":1,"240":3,"247":1,"249":1,"250":1,"251":1,"252":1,"253":1,"285":2,"318":2,"403":5}}],["session",{"2":{"59":1,"60":1,"61":1}}],["sessions",{"2":{"44":1,"65":1}}],["seamless",{"2":{"734":1}}],["seamlessly",{"2":{"288":1}}],["search",{"0":{"475":1,"484":1}}],["sealfields",{"2":{"395":2}}],["seasoned",{"2":{"56":1}}],["seating",{"2":{"37":1,"40":1}}],["seats",{"2":{"28":4}}],["sentry",{"2":{"639":1,"695":6}}],["sent",{"2":{"91":2,"148":1,"262":1,"429":1,"591":1}}],["sensitive",{"2":{"86":1,"353":1}}],["sense",{"2":{"42":1,"46":1}}],["sendrequest",{"2":{"611":2,"613":2}}],["sender",{"2":{"306":4,"469":1,"488":1,"700":16}}],["sending",{"2":{"220":1,"248":1,"288":1,"309":1,"310":1,"386":1,"469":1,"591":1}}],["sends",{"2":{"110":1}}],["send",{"2":{"36":2,"38":1,"45":3,"47":1,"76":5,"119":2,"121":3,"211":1,"213":2,"286":3,"300":1,"309":3,"310":3,"318":5,"547":6,"549":1,"561":8,"563":1,"583":1,"678":1,"704":1}}],["self",{"2":{"226":1,"542":2,"554":2,"803":4}}],["sell",{"2":{"34":5}}],["selling",{"2":{"34":3}}],["selecting",{"2":{"40":1,"88":1,"105":1,"566":1}}],["selection",{"0":{"604":1},"1":{"605":1},"2":{"27":1,"65":1}}],["select",{"0":{"472":1,"475":1,"480":1},"2":{"36":1,"68":2,"83":1,"171":2,"270":1,"311":4,"315":1,"474":1,"475":1,"476":2,"479":2,"480":1,"483":1,"484":1,"576":1,"593":1,"604":1,"646":1,"658":1,"754":3,"805":1}}],["selected",{"2":{"24":1,"28":1,"492":1}}],["serving",{"2":{"453":1,"459":1,"492":1}}],["servicecat",{"2":{"788":1,"790":1,"791":1,"792":1}}],["servicenano",{"2":{"617":1}}],["service",{"0":{"259":1,"329":1,"331":1,"619":1},"1":{"330":1,"331":1,"332":2,"333":2,"334":2,"335":2,"336":2},"2":{"30":5,"329":1,"355":1,"399":1,"521":1,"553":7,"617":9,"655":3,"734":1,"740":1,"742":1,"758":1,"786":1,"788":8,"790":7,"791":7,"792":7}}],["services",{"0":{"632":1},"1":{"633":1},"2":{"24":1,"30":4,"31":9,"33":3,"40":1,"277":2,"619":2,"742":2,"743":2,"744":2,"748":1,"752":2,"760":1,"761":2,"762":2,"763":2}}],["served",{"2":{"556":2}}],["serves",{"2":{"250":1,"470":1,"531":1,"704":1,"733":1}}],["servergrafana",{"2":{"557":1}}],["server",{"0":{"540":1,"687":1,"730":1},"2":{"53":1,"284":1,"314":2,"437":2,"526":1,"540":1,"557":6,"595":2,"602":1,"606":2,"687":1,"696":1,"730":1,"765":1}}],["servers",{"2":{"27":1,"649":2}}],["serve",{"2":{"50":1,"457":1,"459":1,"654":1}}],["serialized",{"2":{"107":1}}],["serious",{"2":{"15":1}}],["series",{"2":{"14":1,"499":1,"500":1,"557":2}}],["secretvite",{"2":{"312":1}}],["secret=your",{"2":{"312":2}}],["secret",{"2":{"312":2,"314":2}}],["secp256k1",{"2":{"277":2,"331":1,"573":2,"574":4,"578":2}}],["sections",{"2":{"206":1,"238":1,"519":1,"627":1,"739":1,"754":1,"783":1,"785":1}}],["section",{"2":{"30":1,"33":1,"34":1,"42":1,"64":1,"81":1,"84":2,"88":1,"107":1,"117":1,"131":1,"136":1,"151":1,"156":1,"161":1,"165":1,"169":1,"172":4,"175":1,"180":1,"183":1,"192":2,"195":1,"196":1,"200":1,"203":2,"208":1,"212":1,"213":2,"217":2,"219":4,"220":2,"222":2,"224":5,"256":1,"270":1,"276":3,"282":1,"322":1,"362":1,"366":1,"367":1,"368":1,"373":1,"375":1,"411":1,"417":1,"466":1,"524":1,"537":1,"538":1,"569":1,"580":1,"591":1,"593":1,"596":1,"598":1,"604":1,"609":1,"617":1,"621":1,"624":1,"628":1,"658":1,"659":1,"663":1,"664":1,"665":1,"667":1,"669":1,"685":2,"693":1,"698":1,"719":1,"726":1,"782":1,"785":2,"798":1,"800":1}}],["securing",{"2":{"42":1,"43":1,"44":2}}],["securities",{"2":{"31":1,"34":13}}],["security",{"0":{"233":1,"451":1,"452":1},"2":{"11":1,"27":2,"31":1,"34":1,"230":2,"233":1,"235":1,"244":1,"264":2,"447":1,"454":1,"673":1}}],["securely",{"2":{"86":1,"174":1,"230":1,"288":1,"314":2,"468":1,"691":1}}],["secure",{"2":{"25":1,"36":1,"235":1,"457":1,"471":1,"501":1,"509":2,"601":1,"648":1}}],["seconds",{"2":{"91":2,"276":4,"277":4,"336":1,"407":1,"557":4}}],["second",{"2":{"23":4,"165":1,"192":1,"242":1,"306":6,"432":1,"439":1,"440":1,"441":1,"451":1,"699":1}}],["setgaslimitandfee",{"2":{"437":2}}],["setcontent",{"2":{"314":4}}],["setposts",{"2":{"314":4}}],["setviewstate",{"2":{"314":6}}],["setwhiteliststatus",{"2":{"215":2}}],["sets",{"2":{"117":1,"156":1,"282":1,"371":1,"443":1}}],["setnumber",{"2":{"116":3,"117":7,"121":2,"281":3,"282":7,"286":2}}],["settitle",{"2":{"314":4}}],["settingpruning",{"2":{"646":1}}],["settingmin",{"2":{"643":1}}],["settings",{"2":{"68":1,"557":1,"608":1,"641":1,"658":1,"659":1}}],["setting",{"0":{"91":1,"364":1,"377":1,"401":1,"530":1,"533":1,"567":1,"572":1,"677":1,"680":1,"720":1,"723":1,"786":1,"793":1,"795":1},"1":{"365":1,"366":1,"367":1,"531":1,"532":1,"533":1,"534":2,"535":1,"536":1,"537":1,"538":1,"539":1,"540":1,"541":1,"568":1,"569":1,"570":1,"571":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"678":1,"679":1,"680":1,"681":2,"682":1,"683":1,"684":1,"685":1,"686":1,"687":1,"688":1,"689":1,"721":1,"722":1,"723":1,"724":2,"725":1,"726":1,"727":1,"728":1,"729":1,"730":1,"731":1,"732":1,"787":1,"788":1,"789":1,"790":1,"791":1,"792":1,"794":1,"795":1,"796":2,"797":2,"798":1,"799":1,"800":1,"801":1,"802":1,"803":1,"804":1,"805":1,"806":1,"807":1,"808":1},"2":{"8":1,"47":2,"60":1,"61":1,"91":8,"220":1,"247":1,"267":1,"365":1,"372":1,"386":1,"398":1,"406":1,"437":4,"530":1,"541":1,"593":1,"617":1,"621":1,"633":1,"639":1,"643":2,"646":1,"674":1,"677":1,"681":1,"720":1,"723":1,"731":1,"787":1,"793":1,"795":1,"802":1}}],["settling",{"2":{"236":1}}],["settlement",{"2":{"146":1,"174":1,"180":1,"181":1,"188":1,"189":1,"192":2,"194":1,"195":2,"196":3,"199":1,"200":1,"203":1,"236":1,"262":1,"338":1,"460":2,"466":1,"467":4}}],["settles",{"2":{"105":1}}],["settle",{"2":{"79":1,"85":1,"109":1,"236":1,"337":1}}],["settled",{"2":{"69":1,"72":1}}],["setupprivate",{"2":{"91":1}}],["setup",{"0":{"75":1,"81":1,"87":1,"115":1,"280":1,"305":1,"323":1,"400":1,"418":1,"534":1,"556":1,"665":1,"668":1,"681":1,"707":1},"1":{"76":1,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1,"92":1,"306":1,"307":1,"308":1,"309":1,"401":1,"666":1,"667":1,"668":1,"669":2,"670":2,"671":1,"672":1,"673":1},"2":{"27":2,"36":1,"68":1,"84":1,"87":5,"90":1,"91":2,"117":3,"211":2,"214":1,"215":1,"223":1,"246":1,"282":3,"306":2,"308":2,"310":2,"368":1,"411":1,"420":2,"437":2,"557":2,"559":1,"572":1,"594":1,"597":1,"622":1,"649":1,"693":1,"707":1,"798":1}}],["setupsigner",{"2":{"437":2}}],["setups",{"2":{"24":1,"608":1}}],["set",{"0":{"215":1,"575":1,"584":1,"636":1,"637":1,"639":1},"1":{"637":1,"638":1,"639":1},"2":{"19":2,"21":1,"23":1,"24":1,"27":1,"30":1,"36":1,"37":1,"42":1,"47":2,"71":1,"75":2,"76":2,"88":1,"89":4,"91":10,"115":1,"116":1,"120":2,"131":1,"134":4,"137":1,"160":1,"177":1,"187":1,"211":7,"214":2,"215":1,"219":6,"220":5,"233":1,"264":2,"266":1,"280":1,"281":1,"284":1,"285":3,"293":1,"300":1,"306":2,"309":1,"310":1,"314":1,"318":4,"324":1,"353":1,"355":1,"369":4,"370":2,"371":5,"372":4,"373":4,"374":1,"376":1,"377":3,"383":2,"386":1,"391":1,"395":1,"396":1,"398":1,"408":1,"410":1,"411":1,"414":4,"419":1,"424":3,"430":4,"456":1,"461":1,"467":1,"494":2,"500":1,"541":1,"545":3,"557":1,"558":1,"563":3,"569":1,"575":1,"580":2,"581":2,"583":2,"584":1,"585":1,"586":1,"601":1,"617":1,"618":2,"628":1,"631":1,"634":1,"639":6,"644":1,"649":2,"658":1,"659":1,"667":3,"668":1,"669":1,"676":1,"697":1,"712":1,"723":1,"769":1,"802":1}}],["seeing",{"2":{"700":2,"790":1,"791":1}}],["seeds",{"2":{"639":13}}],["seed",{"2":{"499":1,"500":1,"639":2,"696":5,"804":1}}],["sees",{"2":{"448":1}}],["seen",{"2":{"306":2}}],["seeking",{"2":{"621":1}}],["seek",{"2":{"40":1,"43":1}}],["see",{"2":{"17":1,"33":1,"68":1,"69":4,"71":3,"72":1,"85":1,"89":1,"91":1,"92":1,"108":1,"109":1,"136":2,"143":1,"165":2,"166":2,"219":1,"220":1,"223":1,"236":1,"243":1,"254":1,"284":1,"292":1,"296":1,"316":1,"323":1,"328":2,"351":1,"376":1,"399":1,"402":1,"403":1,"406":1,"407":1,"418":1,"422":2,"437":4,"444":1,"445":1,"447":1,"466":1,"477":1,"481":1,"488":1,"497":1,"512":1,"529":1,"531":3,"546":1,"547":1,"556":1,"557":1,"564":1,"569":1,"573":1,"585":2,"591":1,"593":1,"594":1,"622":1,"649":1,"651":1,"658":1,"692":1,"694":2,"697":1,"738":1,"748":1,"753":1,"768":1,"781":1,"788":1,"790":1,"791":2,"792":1,"797":2,"803":2}}],["sexualized",{"2":{"8":1}}],["sexual",{"2":{"7":1,"8":1}}],["sex",{"2":{"7":1}}],["sudo",{"2":{"553":4,"675":2,"676":16,"788":2,"790":4,"791":4,"792":2}}],["sudden",{"2":{"19":1}}],["superior",{"2":{"353":1}}],["supply",{"0":{"493":1},"1":{"494":1,"495":1,"496":1,"497":1,"498":1,"499":1,"500":1},"2":{"495":1,"499":1,"500":6,"505":1,"531":1}}],["supplemented",{"2":{"30":1}}],["supplemental",{"0":{"30":1,"33":1},"1":{"31":1,"32":1,"33":1,"34":1},"2":{"30":2}}],["supporters",{"2":{"499":2}}],["supported",{"2":{"177":1,"288":1,"335":1,"750":1}}],["supports",{"2":{"332":1,"494":1}}],["supportive",{"2":{"52":1}}],["supporting",{"2":{"44":1,"47":1,"62":1}}],["support",{"2":{"36":1,"39":1,"41":1,"44":4,"46":1,"49":1,"50":1,"63":2,"79":2,"88":1,"108":1,"245":1,"265":1,"266":2,"492":2,"494":1,"555":1,"560":1,"673":1,"693":1,"694":1,"762":1,"798":1}}],["suits",{"2":{"175":1}}],["suitable",{"2":{"36":1,"658":2}}],["summarize",{"2":{"146":1}}],["summarizes",{"2":{"135":4}}],["summary",{"2":{"59":1,"60":1,"61":1,"235":1}}],["surface",{"2":{"266":1}}],["sure",{"2":{"89":2,"125":1,"126":1,"148":2,"149":2,"173":1,"177":1,"184":1,"192":2,"196":2,"200":1,"203":1,"211":2,"213":1,"220":3,"223":1,"224":2,"270":1,"307":1,"317":1,"371":1,"407":1,"555":1,"556":2,"580":1,"593":1,"595":3,"606":3,"626":1,"689":1,"788":1}}],["surveys",{"2":{"37":1}}],["suggest",{"2":{"443":2}}],["suggested",{"0":{"492":1},"2":{"432":1,"492":1}}],["suggests",{"2":{"47":1}}],["suggestions",{"0":{"4":1},"2":{"4":1,"40":1}}],["sustainable",{"2":{"44":1}}],["sustained",{"2":{"15":1,"16":1}}],["sufficiently",{"2":{"470":1}}],["sufficient",{"2":{"34":1,"40":1,"183":1,"291":1,"463":2}}],["suffer",{"2":{"32":1}}],["succinct",{"0":{"227":1},"2":{"211":4,"212":2,"213":6,"214":1,"220":5,"227":7,"228":1,"230":1,"236":1,"242":1,"244":1,"424":1}}],["succinctxgit",{"2":{"211":1}}],["succinctx",{"2":{"211":4,"223":4,"224":2}}],["succinctgateway",{"0":{"211":1,"213":1},"1":{"214":1,"215":1,"216":1},"2":{"211":7,"213":1,"214":1,"219":3,"224":1,"243":2}}],["succinctlabs",{"2":{"145":4,"153":4,"170":2,"171":2,"172":4,"211":2,"212":2,"217":2,"220":2,"223":2,"224":2,"424":2}}],["succeeds",{"2":{"107":1}}],["success",{"2":{"38":1,"50":1,"69":1,"376":1,"697":3,"700":2}}],["successful",{"2":{"30":1,"35":1,"42":1,"44":1,"45":1,"57":1,"63":1,"91":1,"116":2,"117":1,"120":1,"213":1,"281":2,"282":1,"285":1,"391":1,"413":1,"437":4,"470":1,"797":1}}],["successfully",{"2":{"24":1,"31":1,"88":1,"131":2,"177":1,"228":1,"309":1,"324":1,"407":1,"413":2,"419":1,"447":1,"450":1,"454":1,"541":1,"591":2,"593":1,"695":1,"696":1,"700":1,"788":1,"790":1,"791":1,"792":1,"802":1}}],["such",{"2":{"8":1,"30":3,"31":10,"33":1,"34":9,"36":1,"42":1,"43":2,"44":1,"84":1,"134":2,"135":1,"288":1,"323":1,"329":1,"365":1,"369":2,"416":1,"418":1,"429":1,"437":2,"448":1,"451":1,"453":1,"454":1,"457":1,"463":1,"467":1,"469":1,"470":2,"490":1,"510":1,"558":1,"560":1,"595":1,"606":1,"685":1,"726":1,"737":1}}],["subcommands",{"0":{"546":1},"2":{"542":6}}],["subdomain",{"2":{"391":1}}],["subtract",{"2":{"333":1}}],["subtrees",{"2":{"469":1}}],["subtree",{"2":{"177":6}}],["subtreerootthreshold",{"2":{"159":2}}],["subspace",{"2":{"548":4}}],["subset",{"2":{"497":1}}],["subsequently",{"2":{"133":1}}],["subsequent",{"2":{"23":1,"34":1}}],["subscribing",{"0":{"325":1,"326":1,"420":1},"2":{"416":1,"420":2}}],["subscribes",{"2":{"326":2}}],["subscribeblobs",{"2":{"325":2}}],["subscribeheaders",{"2":{"323":1,"326":4,"418":1}}],["subscribe",{"2":{"88":3,"89":1,"325":6,"326":6,"420":6}}],["subscription",{"2":{"171":6,"323":1,"418":1,"420":1}}],["subscriptions",{"2":{"88":1}}],["submitpayforblob",{"2":{"437":2,"438":1}}],["submitdata",{"2":{"437":2}}],["submitblob",{"2":{"324":4,"436":4}}],["submitblockdata",{"2":{"135":2,"137":2}}],["submitfraudproof",{"2":{"172":8}}],["submitter",{"2":{"548":1}}],["submitted",{"2":{"85":1,"134":8,"153":2,"164":2,"170":2,"172":2,"181":2,"217":1,"225":1,"376":1,"377":1,"413":2,"415":1,"432":3,"549":1,"695":2,"716":1}}],["submitting",{"0":{"142":1,"299":1,"324":1,"345":1,"374":1,"391":1,"419":1,"425":1,"432":1},"1":{"346":1,"347":1,"375":1,"426":1,"427":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1},"2":{"143":1,"166":1,"189":1,"192":1,"195":1,"196":1,"220":1,"226":1,"297":1,"351":1,"366":1,"374":1,"375":1,"376":1,"416":1,"419":2,"429":1,"431":1,"489":1,"537":1,"548":1,"685":1,"732":1}}],["submits",{"2":{"135":2,"324":2,"413":3,"436":2,"693":1}}],["submitheader",{"2":{"135":4,"137":2}}],["submitrollupblock",{"2":{"127":2}}],["submit",{"0":{"346":1,"347":1,"375":1,"804":1},"2":{"85":1,"142":1,"172":5,"180":1,"211":1,"214":1,"215":3,"217":1,"220":1,"224":1,"226":1,"290":1,"294":1,"296":3,"299":3,"324":5,"343":1,"346":3,"347":3,"351":1,"359":1,"369":6,"374":12,"377":2,"391":2,"393":1,"401":1,"405":1,"411":2,"412":2,"413":11,"415":2,"416":2,"419":7,"425":2,"426":1,"430":1,"432":2,"433":1,"435":3,"436":4,"437":6,"438":2,"470":1,"488":2,"497":1,"498":1,"507":1,"548":10,"549":4,"685":2,"726":2,"804":1}}],["submission",{"0":{"289":1,"297":1,"342":1},"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,"343":1,"344":1,"345":1,"346":1,"347":1,"348":1,"349":1,"350":1,"351":1},"2":{"53":1,"195":1,"214":2,"215":1,"220":1,"338":1,"377":1,"391":1,"549":1}}],["submissions",{"2":{"21":1,"292":1}}],["sub",{"2":{"34":1,"420":4,"437":2}}],["subjectivity",{"2":{"649":1}}],["subject",{"2":{"24":1,"31":1,"43":1,"331":1,"336":1,"426":1,"441":1,"500":2,"516":1}}],["sig",{"2":{"562":1}}],["signal",{"2":{"187":1}}],["signatures",{"2":{"383":2,"560":1,"576":2}}],["signature",{"2":{"134":4,"137":4,"139":4,"383":2,"429":1,"469":1,"488":1}}],["signers",{"2":{"343":1}}],["signer",{"0":{"345":1,"347":1},"1":{"346":1,"347":1},"2":{"156":2,"211":2,"314":4,"324":2,"347":4,"436":2,"437":12,"576":2}}],["signedtx",{"2":{"561":2}}],["signed",{"2":{"137":1,"346":1,"561":4}}],["signbytes",{"2":{"137":2}}],["signs",{"2":{"136":1}}],["sign",{"2":{"88":1,"137":2,"211":2,"408":2,"437":6,"561":6}}],["signifies",{"2":{"608":1}}],["significant",{"2":{"491":1,"645":1,"659":1}}],["significantly",{"2":{"44":1,"264":1,"336":1,"426":1}}],["signing",{"0":{"554":1},"2":{"86":1,"311":1,"331":1,"332":1,"355":1,"357":1,"563":2,"576":2,"803":2}}],["signup",{"0":{"53":1}}],["situation",{"2":{"452":1}}],["site",{"0":{"0":1,"1":1},"1":{"1":1,"2":1,"3":1,"4":1},"2":{"1":1,"443":8}}],["sidebar",{"2":{"557":2}}],["sidenode",{"2":{"168":4,"169":4,"172":8}}],["sidenodes",{"2":{"153":2,"165":6,"168":6,"169":2,"172":6}}],["side",{"2":{"165":2,"168":2,"177":2,"700":8}}],["simultaneous",{"2":{"556":2}}],["simulated",{"2":{"288":1}}],["simulates",{"2":{"213":1}}],["simplifies",{"2":{"351":1}}],["simplicity",{"2":{"181":1}}],["simply",{"2":{"135":2,"338":1,"531":1,"557":1,"704":1}}],["simpler",{"2":{"185":1,"450":1}}],["simplerollup",{"2":{"172":8}}],["simple",{"2":{"133":1,"136":1,"172":1,"189":1,"197":1,"212":1,"213":1,"243":1,"264":1}}],["simplest",{"2":{"82":1,"139":1,"658":1}}],["similarly",{"2":{"196":1,"220":1,"234":1,"466":1,"479":1,"508":1,"560":1}}],["similar",{"2":{"89":1,"91":1,"116":1,"117":1,"120":1,"121":2,"153":2,"169":1,"170":2,"171":2,"172":2,"195":1,"203":1,"211":1,"219":1,"281":1,"282":1,"285":1,"286":2,"336":1,"376":1,"379":1,"396":1,"397":1,"428":1,"468":1,"549":1,"617":1,"619":1,"669":1,"670":1,"700":2,"797":2,"803":1}}],["since",{"2":{"88":1,"89":1,"107":1,"128":1,"153":2,"170":2,"172":2,"178":1,"195":1,"208":1,"219":6,"335":1,"412":2,"413":2,"415":2,"428":1,"430":1,"448":1,"452":1,"462":1,"463":1,"470":1,"495":1,"559":1,"583":1,"692":1,"733":1}}],["single",{"2":{"14":1,"86":1,"129":1,"135":1,"146":1,"181":1,"189":3,"363":1,"454":1,"457":1,"467":1,"561":4,"568":3,"569":2,"722":1,"771":1}}],["sizeofdatainbytes",{"2":{"431":2}}],["sizes",{"2":{"156":2,"206":1,"430":1}}],["size",{"0":{"426":1},"2":{"7":1,"42":2,"89":4,"131":3,"166":1,"178":1,"180":1,"183":5,"369":1,"377":1,"395":2,"426":2,"429":4,"430":3,"431":1,"451":2,"456":1,"462":1,"468":1,"469":2,"488":1,"489":1,"494":1,"695":8,"738":9}}],["s",{"0":{"84":1,"86":1,"90":1,"170":1,"301":1,"460":1},"1":{"461":1,"462":1,"463":1,"464":1,"465":1,"466":1},"2":{"5":1,"8":1,"17":1,"19":1,"21":2,"22":1,"23":1,"24":2,"25":2,"27":1,"28":1,"31":3,"33":2,"34":12,"41":1,"42":3,"44":1,"46":1,"48":1,"53":1,"56":1,"65":1,"75":2,"79":1,"80":1,"81":1,"84":9,"85":9,"86":4,"88":4,"89":1,"90":1,"91":3,"92":1,"101":1,"105":1,"108":1,"109":2,"116":1,"117":1,"120":1,"131":4,"134":1,"137":28,"139":3,"146":1,"148":1,"174":1,"183":1,"188":1,"196":3,"208":1,"211":3,"214":1,"219":4,"220":1,"223":2,"225":1,"227":1,"230":2,"235":2,"236":4,"242":2,"246":1,"261":1,"262":1,"266":3,"281":1,"282":1,"284":1,"288":1,"290":2,"292":2,"297":1,"301":1,"303":1,"306":3,"308":2,"309":2,"310":2,"312":1,"316":1,"318":2,"324":2,"330":1,"333":1,"338":1,"344":1,"347":1,"352":1,"361":1,"365":1,"366":1,"368":1,"369":1,"371":1,"379":1,"380":1,"381":1,"382":1,"383":1,"386":1,"387":1,"396":2,"397":2,"399":1,"405":6,"407":1,"412":1,"413":2,"415":5,"417":1,"419":2,"424":1,"429":2,"430":2,"436":2,"437":2,"441":1,"443":1,"445":1,"454":1,"456":1,"457":1,"460":1,"461":1,"462":1,"469":1,"470":1,"488":1,"498":1,"500":2,"502":1,"503":1,"507":1,"509":1,"510":1,"516":1,"519":1,"523":1,"524":2,"526":1,"538":1,"542":2,"543":1,"548":1,"553":4,"556":3,"557":3,"558":2,"559":1,"563":1,"583":1,"585":2,"595":1,"598":1,"601":1,"606":1,"611":1,"614":1,"617":2,"623":1,"627":1,"639":14,"650":12,"655":2,"656":2,"658":1,"673":1,"685":2,"692":1,"693":1,"695":2,"697":1,"720":1,"726":2,"733":2,"734":1,"739":1,"747":1,"748":2,"752":1,"754":1,"759":1,"760":2,"761":2,"765":1,"774":1,"777":1,"788":2}}],["style",{"2":{"673":1}}],["style=",{"2":{"313":2,"314":26}}],["styles",{"2":{"313":2,"443":6}}],["stuck",{"2":{"288":1}}],["stub",{"2":{"127":1}}],["stick",{"2":{"181":1}}],["sticking",{"2":{"84":1}}],["still",{"2":{"175":1,"177":2,"220":2,"403":1,"407":1,"443":1,"462":1,"466":1,"516":1,"608":1,"628":1,"646":1,"661":1,"685":1,"734":1,"808":1}}],["stopbroadcast",{"2":{"308":2}}],["stops",{"2":{"288":1}}],["stop",{"0":{"689":1},"2":{"145":2,"548":1,"609":1,"689":1}}],["storing",{"2":{"110":1,"454":1,"455":1,"457":1,"459":1,"492":2,"791":1}}],["stories",{"2":{"48":1}}],["storecd",{"2":{"668":1}}],["storecelestia",{"2":{"372":1}}],["storesudo",{"2":{"668":1}}],["stores",{"2":{"466":1,"677":1,"769":1}}],["store=$home",{"2":{"372":2}}],["store",{"0":{"372":1,"458":1,"607":1,"615":1,"669":1},"1":{"373":1,"608":1,"609":1,"610":1,"611":1,"612":1,"613":1},"2":{"86":1,"107":1,"110":1,"365":1,"369":4,"370":7,"372":9,"373":8,"374":4,"376":2,"401":1,"407":4,"429":1,"453":1,"457":2,"458":1,"459":1,"462":1,"466":1,"490":1,"492":1,"531":1,"608":3,"609":9,"615":5,"616":4,"618":1,"659":3,"668":4,"669":9,"670":8,"678":1,"695":8,"725":2,"749":1}}],["stored",{"2":{"84":3,"107":1,"148":1,"169":1,"171":1,"228":1,"236":1,"365":1,"451":1,"452":1,"454":1,"490":1,"491":2,"543":1,"585":2,"659":2}}],["storage",{"0":{"453":1,"454":1,"455":1,"457":1,"640":1,"646":1,"668":1,"677":1,"678":1,"680":1,"683":1,"684":1,"685":1,"686":1,"688":1,"689":1,"790":1},"1":{"641":1,"642":1,"643":1,"644":1,"645":1,"646":1,"669":1,"670":1,"678":1,"679":1,"680":1,"681":2,"682":1,"683":1,"684":2,"685":2,"686":1,"687":2,"688":1,"689":1},"2":{"48":1,"110":1,"227":1,"306":6,"363":1,"453":2,"454":2,"455":1,"457":2,"459":2,"491":1,"532":1,"557":2,"635":1,"645":1,"646":1,"658":1,"659":1,"670":1,"677":1,"678":2,"679":2,"685":3,"686":2,"687":1,"688":2,"689":1,"722":1,"746":1,"749":1,"754":1,"769":1,"771":1,"783":1,"790":2,"794":1}}],["std",{"2":{"117":2,"282":2,"306":2,"308":2}}],["steal",{"2":{"448":1}}],["steady",{"2":{"19":1,"23":1}}],["step",{"0":{"68":1,"69":1,"71":1,"72":1,"82":1,"83":1,"84":1,"85":1,"86":1,"87":1,"88":1,"89":1,"90":1,"91":1},"2":{"60":2,"71":1,"83":1,"84":1,"85":2,"88":1,"134":1,"137":1,"139":1,"172":1,"184":1,"210":1,"213":1,"224":1,"367":1,"413":1,"479":1,"562":2,"698":1,"709":1,"714":1,"715":1,"734":1}}],["steps",{"0":{"111":1,"122":1,"255":1,"270":1,"271":1,"272":1,"287":1,"321":1,"341":1,"416":1,"571":1,"623":1},"2":{"35":1,"88":1,"102":1,"103":1,"208":1,"210":1,"224":1,"424":1,"530":1,"593":2,"594":1,"621":1,"622":1,"661":1,"694":1,"696":1,"705":1,"709":1,"787":1,"803":3,"808":1}}],["stronger",{"0":{"459":1}}],["strong",{"2":{"457":1}}],["str",{"2":{"419":4,"420":4,"421":4}}],["strike",{"2":{"235":1}}],["string",{"2":{"76":2,"152":2,"211":2,"223":1,"306":30,"309":4,"310":4,"318":2,"323":1,"324":4,"325":4,"326":4,"327":4,"370":3,"371":1,"374":2,"391":1,"412":2,"413":17,"414":4,"415":8,"418":1,"436":4,"437":2,"521":1,"523":1,"524":1,"537":1,"595":2,"605":2,"606":2,"685":1,"747":1,"748":1,"759":1,"760":1}}],["straight",{"2":{"750":1}}],["straightforward",{"2":{"202":1}}],["strategy",{"2":{"616":1}}],["strange",{"2":{"30":1}}],["struct",{"2":{"107":1,"134":10,"135":6,"163":4,"165":9,"166":2,"168":5,"169":4,"306":2}}],["structures",{"0":{"128":1},"2":{"108":1,"134":2,"146":1,"169":2,"437":2}}],["structure",{"0":{"3":1},"2":{"23":1,"134":2,"165":2,"168":2}}],["streaming",{"0":{"229":1},"1":{"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1},"2":{"46":4}}],["stress",{"2":{"41":1}}],["strengthen",{"2":{"38":1}}],["stands",{"2":{"513":1}}],["standard",{"2":{"47":1,"306":1,"331":2,"333":1,"425":1,"427":1,"463":4,"489":1,"621":1,"693":1}}],["standards",{"0":{"8":1},"2":{"9":1,"15":1,"16":1}}],["stage",{"2":{"230":1,"734":1}}],["stack=",{"2":{"661":2,"808":2}}],["stack",{"0":{"246":1,"302":1,"337":1,"399":1},"1":{"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1,"338":1,"339":1,"340":1,"341":1,"400":1,"401":1,"402":1,"403":1,"404":1},"2":{"105":1,"245":1,"247":1,"255":1,"264":2,"266":1,"302":1,"321":2,"337":1,"338":1,"340":3,"341":1,"399":1,"404":1,"467":2,"661":4,"808":4}}],["stakin",{"2":{"742":1,"743":1,"744":1}}],["staking",{"0":{"493":1,"501":1,"513":1,"514":1},"1":{"494":1,"495":1,"496":1,"497":1,"498":1,"499":1,"500":1,"502":1,"503":1},"2":{"84":1,"85":1,"331":1,"471":1,"494":3,"500":1,"501":2,"502":1,"503":1,"509":1,"510":1,"513":2,"548":6,"551":4,"554":1,"797":2,"803":2}}],["stakeflow",{"2":{"742":1,"743":1,"744":1,"751":1,"761":1,"762":1,"763":1,"767":1}}],["staked",{"2":{"474":1,"500":1}}],["stakecurrency",{"2":{"443":2}}],["stakers",{"2":{"497":1,"498":1}}],["staker",{"2":{"91":3,"742":1,"743":1,"744":1}}],["stakes",{"2":{"84":2}}],["stake",{"0":{"471":1,"473":1,"476":1,"478":1,"480":1,"482":1,"485":1,"494":1,"509":1,"797":1},"1":{"472":1,"473":1,"474":2,"475":2,"476":2,"477":2,"478":1,"479":2,"480":2,"481":2,"482":1,"483":2,"484":2,"485":2,"486":2},"2":{"19":1,"22":1,"24":1,"84":6,"233":1,"471":3,"474":1,"476":1,"477":1,"479":1,"480":1,"481":1,"483":1,"486":1,"494":4,"501":1,"502":1,"509":2,"531":1,"548":1,"563":4,"797":1}}],["static",{"2":{"429":4,"430":2,"557":2}}],["statscelestia",{"2":{"385":1}}],["stats",{"0":{"385":1},"2":{"385":1}}],["stateroot",{"2":{"395":2}}],["stated",{"2":{"219":1}}],["stateless",{"2":{"131":1}}],["state",{"0":{"456":1,"524":1,"645":1,"649":1,"748":1,"760":1},"2":{"34":6,"84":4,"121":1,"136":2,"139":1,"172":4,"188":3,"192":1,"196":1,"200":1,"203":1,"211":1,"219":3,"236":1,"262":1,"286":1,"295":2,"296":2,"297":2,"298":2,"335":1,"336":1,"338":1,"351":2,"366":2,"369":2,"379":2,"380":4,"382":2,"386":6,"407":2,"428":1,"429":1,"430":1,"432":1,"438":1,"448":1,"456":4,"466":3,"467":8,"469":2,"490":2,"492":2,"524":3,"531":2,"537":2,"542":6,"584":1,"645":1,"646":1,"647":2,"649":5,"650":1,"659":3,"661":29,"685":3,"703":1,"726":1,"748":2,"760":2,"761":1,"763":1,"808":29}}],["statesync",{"2":{"649":3}}],["states",{"2":{"34":9}}],["statements",{"0":{"411":1},"2":{"411":2}}],["statement",{"2":{"27":1}}],["status",{"0":{"215":1,"254":1},"2":{"7":1,"69":1,"121":2,"214":2,"215":6,"254":2,"276":2,"277":2,"286":2,"440":1,"521":1,"542":4,"564":1,"611":2,"748":2,"788":4,"792":2}}],["stable",{"2":{"23":1,"734":1,"774":1}}],["stability",{"0":{"516":1,"734":1},"2":{"19":1}}],["startcelestia",{"2":{"651":1,"719":1,"801":1,"803":1}}],["startbroadcast",{"2":{"308":2}}],["startblock",{"2":{"153":6,"170":4,"217":1}}],["startprank",{"2":{"306":2}}],["starts",{"2":{"219":1,"226":1,"495":1}}],["startshare=0",{"2":{"161":1}}],["startindex",{"2":{"181":2,"183":2}}],["starting",{"2":{"21":1,"50":1,"134":1,"150":1,"160":1,"323":1,"402":1,"418":1,"467":1,"498":1,"538":1,"609":1,"619":1,"715":1,"804":1}}],["start=10",{"2":{"151":1}}],["start",{"0":{"541":1,"651":1,"667":1,"670":1,"685":1,"688":1,"702":1,"726":1,"731":1,"782":1,"788":1,"802":1},"1":{"727":1,"728":1,"729":1,"730":1,"731":1,"783":1,"784":1,"785":1},"2":{"75":1,"89":3,"90":1,"134":2,"135":1,"145":2,"152":2,"153":4,"156":5,"161":2,"165":3,"172":4,"181":1,"225":1,"255":1,"258":1,"264":1,"276":2,"277":3,"284":1,"295":3,"296":3,"303":1,"309":1,"310":1,"314":4,"318":1,"323":1,"340":1,"341":1,"344":3,"366":12,"367":8,"369":1,"407":4,"412":1,"418":1,"494":1,"520":1,"524":6,"537":1,"538":8,"539":7,"540":1,"542":4,"561":2,"577":2,"589":1,"591":2,"596":3,"598":3,"599":2,"600":2,"601":4,"604":2,"609":3,"614":3,"618":2,"649":1,"651":9,"653":1,"661":1,"662":1,"667":6,"669":1,"670":10,"685":5,"686":7,"687":1,"692":1,"694":1,"695":6,"702":2,"719":2,"726":7,"727":8,"729":7,"730":1,"740":1,"748":3,"758":1,"785":1,"788":5,"790":5,"791":6,"792":7,"801":1,"803":9,"808":1}}],["startup",{"2":{"40":1,"791":1}}],["started",{"0":{"124":1,"303":1,"330":1,"785":1},"1":{"125":1,"126":1,"127":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1},"2":{"1":1,"27":1,"39":1,"47":1,"90":1,"276":1,"293":1,"305":1,"309":1,"314":2,"316":1,"330":1,"356":1,"403":1,"405":1,"502":1,"503":1,"594":1,"609":1,"622":1,"663":2,"668":1,"782":1,"783":1,"784":1,"785":1,"788":1,"792":1}}],["stay",{"2":{"5":1,"559":1,"753":1,"768":1,"781":1}}],["gprc",{"2":{"744":1}}],["gpt3dot5turbo",{"2":{"414":2}}],["gpt3",{"2":{"414":4,"415":2}}],["gpt",{"2":{"405":2,"406":1,"414":4,"415":4,"416":2}}],["gg",{"2":{"696":2}}],["gz",{"2":{"676":24}}],["global",{"2":{"557":3,"695":2}}],["glance",{"0":{"505":1}}],["gcpbb",{"2":{"430":1}}],["gbps",{"2":{"532":2,"635":2,"679":2,"771":2,"772":2,"794":2}}],["gb",{"2":{"363":1,"532":1,"635":1,"679":1,"722":1,"771":3,"772":2,"794":1}}],["ghcr",{"2":{"276":2,"667":6,"669":6,"670":6}}],["gnark",{"2":{"223":1}}],["gklcgflcsrm9caqasaapsckykhy9jb3ntb3muy3j5chrvlnnly3ayntzrms5qdwjlzxksiwohaqdvbvupglandgtlocgsoherbafsfbb5l0wdvbjjesehegqkaggbgjjcariscgwkbhv0awesbdixotiqto9cgkcjrjcoyijj81bttfb2gudg7o8auawf0bscbhw9ppd99xpq1slpemfyq0y1joj",{"2":{"156":4}}],["gmid",{"2":{"314":2}}],["gms",{"2":{"76":3,"318":3}}],["gmportalscript",{"2":{"75":2,"318":2}}],["gmportal",{"2":{"75":2,"77":7,"318":2,"319":7}}],["gm",{"2":{"75":8,"76":5,"77":8,"78":2,"287":1,"296":2,"318":13,"319":8,"320":2,"340":1,"346":2,"347":2,"369":4,"374":3,"376":6,"377":2}}],["gt",{"2":{"69":1,"75":2,"76":2,"89":8,"137":2,"145":3,"149":8,"151":1,"156":1,"157":2,"159":7,"161":1,"212":8,"213":30,"215":4,"216":4,"218":6,"224":2,"242":1,"270":13,"271":12,"272":12,"276":5,"277":8,"293":4,"300":4,"306":4,"309":2,"310":2,"311":2,"313":14,"314":118,"318":4,"366":6,"367":21,"369":6,"371":6,"372":4,"374":8,"376":8,"380":2,"383":4,"386":6,"388":4,"395":1,"412":6,"413":6,"415":12,"420":8,"421":2,"434":4,"435":4,"443":14,"524":6,"526":3,"537":8,"538":4,"539":12,"544":8,"545":6,"546":8,"547":18,"548":20,"549":4,"550":6,"551":16,"552":4,"553":12,"554":2,"557":2,"561":2,"569":2,"585":4,"596":10,"598":10,"599":4,"600":4,"601":16,"604":10,"609":10,"614":8,"615":4,"616":8,"618":9,"650":12,"651":1,"670":2,"676":8,"685":4,"686":12,"692":2,"696":4,"727":6,"728":3,"729":12,"748":6,"765":3,"788":2,"790":2,"791":4,"792":4,"797":4,"800":2,"803":3}}],["go$ver",{"2":{"676":24}}],["goroutine",{"2":{"661":4,"808":4}}],["gone",{"2":{"589":1}}],["google",{"2":{"437":4}}],["good",{"2":{"321":1,"557":1,"668":2}}],["govcelestia",{"2":{"548":1}}],["gov",{"2":{"331":1,"548":12,"549":2}}],["governing",{"2":{"510":1}}],["governance",{"0":{"493":1,"496":1,"510":1,"548":1},"1":{"494":1,"495":1,"496":1,"497":2,"498":2,"499":1,"500":1,"549":1},"2":{"426":1,"429":1,"430":2,"466":1,"471":1,"497":2,"498":1,"500":1,"510":3,"548":3,"549":1,"738":3}}],["governs",{"2":{"244":1}}],["governmental",{"2":{"34":1}}],["government",{"2":{"33":1}}],["governed",{"2":{"31":1}}],["govern",{"2":{"30":1}}],["gobin",{"2":{"269":2}}],["go\\t",{"2":{"170":1}}],["go\\tsharesproof",{"2":{"162":1}}],["goimport",{"2":{"159":1,"324":1,"431":1,"436":1,"437":1}}],["going",{"2":{"71":1,"122":1,"571":1,"628":1,"769":1,"788":1}}],["gopackage",{"2":{"152":1,"153":1,"172":1,"411":1}}],["goleveldb",{"2":{"149":4}}],["golangnodearabica",{"2":{"676":2}}],["golangnodemocha",{"2":{"676":2}}],["golangnodemainnet",{"2":{"676":2}}],["golang",{"0":{"152":1,"157":1,"159":1,"162":1,"322":1,"436":1,"676":1},"1":{"323":1,"324":1,"325":1,"326":1,"327":1,"328":1},"2":{"145":2,"152":1,"157":1,"158":1,"159":1,"162":1,"165":1,"167":1,"168":1,"169":1,"172":1,"237":1,"242":1,"322":1,"354":1,"405":2,"406":1,"415":1,"436":2,"437":4,"621":1,"676":11}}],["gogo",{"2":{"149":2}}],["gohttps",{"2":{"145":2}}],["gotten",{"2":{"164":1,"184":1}}],["got",{"2":{"139":2,"376":1,"661":2,"808":2}}],["gotype",{"2":{"134":2,"135":1}}],["gossiped",{"2":{"428":1,"439":1,"461":1}}],["gossiping",{"2":{"139":2,"440":1}}],["gossip",{"2":{"139":1,"678":1}}],["gofunc",{"2":{"137":2,"139":1,"165":1,"166":1,"167":1,"168":1,"169":1,"325":1,"413":1,"415":1}}],["goals",{"2":{"264":1}}],["goal",{"2":{"134":1}}],["goes",{"2":{"60":1,"72":1,"188":3,"208":1,"333":1,"618":1,"621":1}}],["go",{"0":{"410":1},"2":{"50":1,"107":1,"134":1,"135":1,"143":1,"145":3,"149":5,"153":7,"157":1,"159":2,"170":1,"171":2,"172":7,"175":1,"209":1,"223":4,"237":1,"252":1,"253":1,"267":2,"317":1,"326":1,"327":1,"369":1,"407":4,"410":10,"411":3,"412":5,"413":6,"414":1,"415":10,"467":1,"530":1,"543":1,"557":1,"569":2,"588":1,"593":1,"598":1,"611":1,"612":1,"616":2,"661":36,"668":2,"674":1,"676":18,"693":4,"698":1,"785":1,"808":36}}],["gather",{"2":{"598":1}}],["gateways",{"2":{"211":1}}],["gateway",{"0":{"357":1,"358":1},"1":{"358":1},"2":{"89":2,"91":2,"210":1,"211":3,"213":7,"214":1,"219":3,"220":4,"244":1,"352":1,"353":1,"357":3,"358":1,"362":1,"606":3,"762":1}}],["game",{"2":{"405":2}}],["gaming",{"2":{"43":1,"265":1,"321":1}}],["gaining",{"2":{"448":1}}],["gain",{"2":{"48":1,"56":1,"65":1,"405":1,"454":1}}],["gained",{"2":{"38":1}}],["gap",{"2":{"42":1}}],["gauge",{"2":{"42":1}}],["gas=220000",{"2":{"803":1}}],["gas=220000moniker=",{"2":{"803":1}}],["gasperblobbyte",{"2":{"429":1}}],["gasperbyte",{"2":{"429":1,"430":2}}],["gaspricestep",{"2":{"443":2}}],["gasprice",{"2":{"396":2,"419":5,"428":1}}],["gastoconsume",{"2":{"429":2,"430":1}}],["gaslimit",{"2":{"374":4,"386":1,"395":2,"428":1,"431":2,"437":4}}],["gasused",{"2":{"121":2,"286":2,"395":2}}],["gas",{"0":{"377":1,"428":1,"429":1,"430":1,"431":1},"1":{"429":1,"430":1,"431":1},"2":{"31":1,"80":1,"82":1,"84":3,"85":2,"89":4,"117":2,"156":4,"228":1,"235":1,"282":2,"324":3,"351":1,"374":2,"377":12,"386":7,"396":2,"413":2,"419":3,"426":1,"427":2,"428":9,"429":9,"430":18,"431":5,"437":6,"445":3,"489":1,"508":1,"550":2,"552":2,"576":12,"583":2,"695":16,"797":4,"803":4}}],["grid",{"2":{"426":1}}],["grpcaddr",{"2":{"437":4}}],["grpc",{"0":{"437":1,"524":1,"744":1,"748":1,"760":1,"763":1},"2":{"366":3,"391":1,"437":10,"521":3,"524":4,"537":2,"538":1,"557":3,"595":2,"685":2,"695":12,"726":2,"744":21,"748":12,"760":8,"762":3,"763":19}}],["grzxooejihch93+g3mldibq6ff+nroakrbgupfu8muo=",{"2":{"156":2}}],["groundbreaking",{"2":{"734":1}}],["groupname",{"2":{"313":2}}],["group",{"2":{"42":2,"45":1,"46":1,"47":13,"48":7}}],["groups",{"2":{"40":1,"42":2,"45":5,"47":2}}],["grove",{"0":{"750":1},"2":{"520":2,"740":2,"750":2,"758":2}}],["growth",{"2":{"65":1}}],["grow",{"2":{"50":1}}],["growing",{"2":{"50":1}}],["grep",{"2":{"398":1}}],["grepping",{"2":{"398":1}}],["green",{"2":{"146":1}}],["greet",{"2":{"37":1}}],["greater",{"2":{"206":1,"649":1}}],["greatly",{"2":{"46":1}}],["great",{"2":{"41":1,"341":1}}],["grafana",{"2":{"557":3,"559":3,"602":1,"748":1}}],["graphical",{"2":{"560":1}}],["graphics",{"2":{"36":1}}],["graph",{"2":{"306":2}}],["gravity",{"2":{"230":1}}],["gradients",{"2":{"146":1}}],["grading",{"2":{"23":1}}],["grassroots",{"2":{"49":1}}],["gratitude",{"2":{"43":1,"44":1}}],["grantee",{"0":{"296":1},"2":{"291":1,"292":2,"293":5,"295":3,"300":6}}],["granter",{"0":{"295":1,"298":1,"301":1},"1":{"299":1},"2":{"291":1,"292":2,"293":5,"296":2,"300":6,"301":1,"576":2}}],["granted",{"2":{"53":1,"301":1}}],["grant",{"0":{"295":1},"2":{"34":1,"294":1,"295":3,"298":2,"300":3}}],["granting",{"0":{"293":1,"300":1},"1":{"294":1,"295":1,"301":1},"2":{"34":1,"290":1,"293":1}}],["gracefully",{"2":{"8":1,"689":1}}],["guru",{"2":{"751":1,"761":2,"762":2,"763":2,"767":1}}],["guardian",{"2":{"211":1,"219":1}}],["guardian=",{"2":{"211":2}}],["guaranteeing",{"2":{"468":1}}],["guaranteed",{"2":{"334":1,"470":1,"492":2}}],["guarantees",{"2":{"230":2,"244":1,"492":1}}],["guarantee",{"2":{"27":1,"457":1,"458":1,"461":1,"463":1,"490":1,"524":1,"748":1,"760":1}}],["guidance",{"0":{"39":1},"1":{"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1}}],["guide",{"0":{"35":1,"302":1,"368":1,"625":1,"693":1,"705":1,"782":1},"1":{"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":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,"384":1,"385":1,"386":1,"387":1,"388":1,"389":1,"626":1,"627":1,"628":1,"629":1,"630":1,"631":1,"632":1,"633":1,"694":1,"695":1,"696":1,"697":1,"698":1,"699":1,"700":1,"701":1,"702":1,"703":1,"704":1,"706":1,"707":1,"708":1,"709":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"783":1,"784":1,"785":1},"2":{"49":1,"56":1,"60":1,"66":2,"79":3,"83":1,"91":1,"113":1,"226":1,"269":1,"275":1,"290":1,"293":1,"302":2,"322":1,"323":1,"340":1,"362":1,"399":1,"416":1,"417":1,"418":1,"519":2,"558":1,"562":2,"565":1,"588":1,"592":1,"602":1,"609":1,"618":1,"634":1,"659":1,"677":1,"693":1,"705":2,"707":1,"708":1,"720":1,"733":1,"739":2,"754":2,"769":1,"785":1,"793":1}}],["guidelines",{"0":{"2":1,"12":1,"58":1},"1":{"13":1,"14":1,"15":1,"16":1},"2":{"2":1,"12":1,"17":1,"39":2}}],["guides",{"2":{"0":1,"3":1,"24":2,"39":1,"92":1,"256":1,"658":1,"754":1,"772":1}}],["gi",{"2":{"151":2}}],["gitgit",{"2":{"87":1}}],["git",{"2":{"75":6,"87":1,"126":1,"212":2,"217":2,"220":2,"223":2,"224":4,"269":3,"318":4,"593":7,"621":7,"675":4}}],["githubusercontent",{"2":{"445":1,"639":10,"675":2}}],["github",{"0":{"339":1},"2":{"27":2,"75":3,"87":2,"145":4,"149":18,"152":2,"153":16,"159":6,"165":2,"166":2,"169":2,"170":2,"171":2,"172":24,"211":2,"212":2,"217":2,"220":2,"223":2,"224":2,"269":2,"318":3,"323":2,"324":6,"339":1,"357":1,"362":1,"410":4,"411":8,"424":2,"431":2,"436":6,"437":16,"562":2,"585":2,"593":2,"606":1,"621":2,"661":16,"772":1,"808":16}}],["given",{"0":{"616":1},"2":{"107":1,"155":1,"180":1,"206":1,"211":1,"218":1,"324":1,"327":3,"391":1,"413":1,"414":2,"419":1,"421":1,"451":1,"464":1,"516":1,"614":2,"616":2,"645":1,"738":1,"777":1,"779":1}}],["gives",{"2":{"45":1,"65":1,"109":1,"193":1,"494":1,"738":1}}],["give",{"0":{"317":1},"2":{"44":1,"256":1,"294":1,"306":2,"309":1,"668":1,"692":1}}],["giving",{"2":{"8":1,"40":1,"109":1}}],["gifts",{"2":{"43":1}}],["g",{"2":{"23":1,"31":1,"33":1,"38":1,"48":2,"291":1,"369":1,"424":1,"426":1,"450":1,"464":1,"470":1,"557":1,"618":1,"651":1,"655":2,"803":1}}],["gem",{"0":{"482":1,"483":1},"1":{"483":1,"484":1,"485":1,"486":1},"2":{"471":1}}],["geoblock",{"2":{"31":1}}],["geolocation",{"2":{"24":1}}],["gentx",{"2":{"542":2,"554":4,"715":5,"716":7}}],["gentxscelestia",{"2":{"716":1}}],["gentxs",{"2":{"542":2,"716":1}}],["gentle",{"2":{"79":1,"80":1,"101":1}}],["genutil",{"2":{"331":1}}],["genuine",{"2":{"53":1,"65":1}}],["genuinely",{"2":{"52":1}}],["genesis",{"0":{"499":1,"554":1,"713":1,"715":1,"716":1},"1":{"500":1},"2":{"169":2,"218":2,"219":4,"454":1,"491":1,"498":1,"499":2,"500":1,"505":1,"542":20,"554":3,"586":1,"596":10,"633":1,"639":7,"647":1,"661":1,"692":1,"713":2,"714":3,"715":2,"716":5,"808":1}}],["generic",{"2":{"117":1,"282":1}}],["generator",{"2":{"311":1}}],["generating",{"0":{"270":1},"2":{"177":1,"183":1,"212":1,"226":1,"407":2}}],["generation",{"2":{"149":1,"182":1,"468":1}}],["generate",{"2":{"177":1,"208":1,"211":1,"212":1,"220":2,"222":2,"223":4,"224":3,"226":1,"236":1,"242":1,"244":1,"267":1,"270":1,"376":1,"405":1,"408":2,"452":2,"463":1,"542":2,"554":1,"561":4,"588":1}}],["generates",{"2":{"150":1}}],["generated",{"2":{"84":4,"133":1,"145":1,"160":1,"184":1,"208":1,"220":1,"223":1,"224":4,"228":2,"310":1,"324":2,"367":2,"374":1,"379":1,"407":2,"413":1,"419":2,"463":1,"526":1,"538":1,"685":1,"712":1,"715":1,"727":1,"728":1,"765":1}}],["generally",{"2":{"429":1}}],["generalized",{"2":{"181":1}}],["general",{"0":{"31":1,"691":1},"1":{"692":1},"2":{"27":1,"34":1,"206":1,"262":1,"268":1,"429":1,"461":1,"500":1,"691":1}}],["gender",{"2":{"7":1}}],["getaddress",{"2":{"437":2}}],["getall",{"2":{"324":3,"326":2,"413":1,"419":1,"436":2,"492":2}}],["getallgms",{"2":{"76":2,"318":2}}],["getbyheight",{"2":{"327":2,"383":1}}],["getblockdata",{"2":{"135":2,"139":2}}],["getenv",{"2":{"414":2}}],["geteds",{"2":{"327":7,"421":1}}],["getelementbyid",{"2":{"313":2}}],["getlatestblock",{"2":{"139":2}}],["getlatestrollupheight",{"2":{"135":2}}],["getheader",{"2":{"135":4,"139":2}}],["geth",{"2":{"119":1,"338":1}}],["getsigner",{"2":{"314":2}}],["gets",{"2":{"107":1,"108":1,"146":1,"148":2,"181":1,"223":1,"563":1}}],["gettotalgms",{"2":{"76":2,"318":2}}],["getting",{"0":{"124":1,"303":1,"330":1,"785":1},"1":{"125":1,"126":1,"127":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1},"2":{"25":2,"91":2,"93":1,"212":1,"218":1,"314":2,"330":1,"406":1,"447":1,"563":1}}],["get",{"0":{"381":1,"382":1,"383":1,"385":1},"2":{"1":1,"27":1,"39":1,"42":1,"47":1,"107":1,"108":2,"153":8,"156":1,"170":2,"172":4,"184":2,"213":2,"227":1,"261":1,"262":1,"265":1,"288":1,"293":1,"305":1,"323":3,"327":2,"356":1,"374":1,"376":15,"381":1,"382":1,"383":6,"384":4,"388":1,"389":7,"397":2,"403":1,"405":1,"410":4,"412":2,"413":5,"415":4,"416":1,"418":1,"419":2,"420":2,"421":8,"426":1,"430":1,"432":1,"437":2,"447":1,"502":1,"503":1,"538":1,"547":1,"548":1,"558":1,"563":1,"591":1,"594":1,"611":2,"612":2,"613":2,"618":2,"622":1,"639":1,"663":2,"685":2,"696":1,"726":1,"728":1,"782":1,"783":1,"784":1,"785":1,"797":1}}],["oil",{"2":{"573":2}}],["o",{"2":{"223":2,"462":1,"463":2,"650":12}}],["old",{"2":{"161":1,"162":1,"455":1,"604":1,"614":1}}],["older",{"2":{"31":1,"217":1,"491":1,"690":1}}],["ostrich",{"2":{"573":2}}],["os|file|kwallet|pass|test|memory",{"2":{"543":1,"585":2}}],["oss",{"2":{"334":1}}],["os",{"2":{"152":2,"153":2,"172":2,"411":2,"412":8,"413":8,"414":2,"415":8,"556":2,"675":1}}],["occupied",{"2":{"738":1}}],["occurs",{"2":{"448":1}}],["occurring",{"2":{"336":1}}],["occur",{"2":{"139":1,"548":1}}],["occasional",{"2":{"734":1,"774":1}}],["october",{"2":{"28":1}}],["omitempty",{"2":{"134":2}}],["okpajw+kyhnqkq5vch",{"2":{"156":2}}],["ok",{"2":{"117":2,"282":2,"420":4}}],["owners",{"2":{"91":6}}],["ownership",{"2":{"34":1,"91":2,"306":2}}],["owner",{"2":{"84":1,"91":5,"211":3,"213":4,"219":1,"306":12}}],["own",{"2":{"34":2,"84":1,"89":1,"226":1,"230":1,"264":1,"266":1,"304":1,"312":1,"324":1,"337":1,"340":1,"353":1,"392":1,"399":1,"408":1,"424":1,"464":1,"467":1,"468":1,"492":1,"494":1,"508":1,"509":1,"521":1,"524":1,"537":1,"579":1,"583":1,"591":1,"593":1,"630":1,"685":1,"705":1,"711":1,"740":1,"748":1,"750":1,"758":1,"797":1}}],["ovh",{"2":{"24":1}}],["override",{"2":{"557":2}}],["overpaying",{"2":{"430":1}}],["overpay",{"2":{"428":1}}],["overhead",{"2":{"337":1,"338":1}}],["over",{"0":{"700":1},"2":{"59":1,"60":1,"122":1,"134":4,"136":1,"137":1,"148":3,"175":1,"176":1,"208":1,"209":1,"220":1,"237":1,"262":1,"267":2,"302":1,"314":2,"357":1,"367":1,"369":1,"492":1,"510":1,"530":1,"588":1,"598":1,"618":1,"621":1,"674":1,"700":2,"785":1}}],["overview",{"0":{"64":1,"105":1,"113":1,"146":1,"290":1,"343":1,"489":1,"504":1,"531":1,"678":1,"721":1,"769":1},"1":{"147":1,"148":1,"505":1,"506":1,"507":1,"508":1,"509":1,"510":1,"511":1,"512":1,"513":1,"514":1,"770":1,"771":1,"772":1},"2":{"22":1,"37":1,"47":1,"59":1,"60":1,"61":1,"69":1,"71":1,"79":1,"80":1,"94":1,"101":1,"131":2,"303":1,"330":1,"477":1,"481":1,"489":1,"520":2,"602":1,"623":1,"740":2,"758":2}}],["overall",{"2":{"8":1,"41":1,"94":1}}],["otel",{"2":{"24":1,"599":2,"600":2,"602":3}}],["otherwise",{"2":{"11":1,"34":4,"89":1,"107":1,"109":1,"158":1,"192":1,"211":1,"217":1,"219":1,"222":1,"374":1,"391":1,"413":1,"548":1,"709":1,"788":1}}],["others",{"2":{"8":1,"219":1,"718":1}}],["other",{"0":{"336":1,"714":1},"2":{"3":1,"8":2,"9":1,"13":1,"24":2,"25":1,"27":1,"30":2,"31":10,"32":1,"34":12,"40":1,"42":5,"43":2,"45":2,"47":1,"48":3,"52":1,"64":1,"84":1,"105":1,"107":1,"119":1,"129":1,"134":2,"143":1,"145":1,"173":1,"187":1,"206":1,"224":1,"225":1,"235":1,"248":1,"265":1,"270":1,"294":1,"334":2,"336":1,"351":1,"353":1,"362":1,"366":1,"426":2,"427":1,"430":1,"447":1,"454":1,"457":1,"464":1,"467":2,"492":3,"498":1,"509":1,"525":1,"531":1,"537":1,"608":1,"618":1,"655":1,"685":1,"703":1,"714":2,"715":1,"716":2,"717":2,"718":2,"765":1,"783":1}}],["observe",{"2":{"616":1}}],["observer",{"2":{"599":2}}],["observed",{"2":{"208":1}}],["observance",{"2":{"34":1}}],["objects",{"2":{"314":2}}],["object",{"2":{"88":2}}],["objective",{"2":{"27":1}}],["objectives",{"0":{"19":1},"2":{"19":1,"36":1}}],["obligation",{"2":{"34":1}}],["obligations",{"2":{"33":1}}],["obligated",{"2":{"11":1}}],["obtained",{"2":{"34":2,"218":1,"219":1,"406":1}}],["obtaining",{"2":{"34":2}}],["obtain",{"2":{"32":1,"33":1,"44":1,"88":1}}],["onstart",{"2":{"661":2,"808":2}}],["onto",{"2":{"285":1,"459":1}}],["oncall",{"2":{"559":2}}],["onchange=",{"2":{"314":4}}],["onchain",{"0":{"228":1},"2":{"109":1,"110":1,"211":1,"212":2,"220":1,"222":1,"224":2,"230":2,"238":1,"243":1,"265":1,"321":1,"338":1,"448":1,"500":1,"803":1}}],["onclick=",{"2":{"314":8,"443":2}}],["once",{"2":{"25":1,"85":1,"88":1,"107":1,"120":1,"137":1,"196":1,"203":1,"219":1,"261":1,"267":1,"285":1,"292":1,"309":3,"310":1,"314":2,"367":1,"369":1,"408":1,"450":1,"457":1,"469":1,"490":1,"491":2,"492":1,"538":1,"557":2,"576":1,"649":1,"685":1,"689":1,"714":1,"716":2,"727":1}}],["onboarding",{"0":{"48":1}}],["ones",{"2":{"178":1,"196":1,"222":1,"698":1,"701":1}}],["onestepproofentry",{"2":{"98":1,"99":1}}],["onestepproverhostio",{"2":{"98":1,"99":1}}],["onestepprovermath",{"2":{"98":1,"99":1}}],["onestepprovermemory",{"2":{"98":1,"99":1}}],["onestepprover0",{"2":{"98":1,"99":1}}],["one",{"0":{"432":1},"2":{"34":5,"45":1,"46":1,"47":1,"48":1,"66":2,"76":1,"88":1,"89":1,"102":1,"105":1,"107":1,"108":1,"116":1,"117":1,"143":1,"161":1,"162":1,"175":1,"178":1,"187":1,"193":1,"196":1,"200":3,"208":1,"217":1,"219":1,"221":1,"223":1,"225":2,"237":1,"240":1,"262":1,"264":1,"265":1,"266":1,"270":1,"276":2,"277":2,"281":1,"282":1,"291":2,"292":1,"293":1,"309":1,"318":1,"362":1,"366":3,"411":2,"414":1,"416":1,"425":1,"426":1,"429":1,"432":1,"445":2,"451":1,"463":2,"464":1,"467":2,"469":2,"470":2,"537":1,"538":2,"542":4,"547":5,"548":3,"557":3,"569":1,"571":1,"572":2,"581":1,"583":2,"585":2,"608":1,"609":2,"616":1,"633":2,"678":1,"685":1,"693":2,"695":2,"716":1,"726":4,"727":2,"738":2,"742":1,"743":1,"744":1,"748":1,"760":1,"762":1,"763":1,"798":1}}],["onlyowner",{"2":{"306":8}}],["only",{"2":{"34":2,"89":3,"94":2,"107":2,"108":3,"109":1,"139":2,"158":1,"175":1,"178":1,"181":1,"184":1,"189":1,"214":1,"215":2,"223":1,"236":1,"265":1,"266":1,"270":1,"306":2,"331":1,"333":1,"357":1,"362":1,"372":1,"413":1,"426":1,"430":1,"437":2,"452":1,"454":1,"457":1,"460":1,"461":1,"462":1,"463":2,"464":2,"466":1,"467":3,"468":2,"469":2,"491":2,"492":1,"549":1,"561":2,"573":2,"590":1,"595":1,"608":1,"639":1,"651":1,"673":1,"689":1,"705":1,"748":1,"764":1,"785":1,"803":2}}],["online",{"2":{"10":1,"37":1,"44":1,"45":1,"788":2,"790":2,"791":2,"792":2}}],["onwards",{"2":{"23":1,"172":2}}],["on",{"0":{"73":1,"149":1,"247":1,"257":1,"278":1,"316":1,"318":1,"373":1,"397":1,"494":1,"501":1,"563":1,"572":1,"583":1,"646":1,"656":1,"769":1},"1":{"74":1,"75":1,"76":1,"77":1,"78":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,"248":1,"249":1,"250":1,"251":1,"252":1,"253":1,"254":1,"258":1,"259":1,"260":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"287":1,"319":1,"320":1,"321":1,"502":1,"503":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"770":1,"771":1,"772":1},"2":{"8":2,"23":1,"24":5,"27":5,"30":3,"31":3,"32":1,"33":1,"34":5,"36":1,"39":1,"40":3,"41":2,"43":2,"44":1,"45":4,"46":5,"47":1,"48":1,"53":1,"59":1,"60":1,"61":2,"65":1,"68":1,"69":2,"71":3,"76":1,"77":3,"78":1,"79":1,"80":2,"82":1,"84":10,"85":2,"86":1,"88":1,"89":5,"90":1,"91":51,"95":1,"105":1,"107":3,"108":1,"109":4,"110":3,"113":1,"114":1,"117":1,"119":2,"129":1,"133":2,"135":6,"137":1,"145":1,"146":1,"148":2,"174":1,"176":1,"177":3,"178":1,"179":1,"180":2,"183":2,"184":2,"187":1,"189":1,"191":1,"211":2,"213":1,"223":3,"224":4,"225":2,"227":1,"228":1,"230":2,"233":2,"234":4,"235":2,"236":5,"237":2,"239":1,"240":8,"243":1,"245":1,"246":2,"247":1,"256":2,"258":1,"260":1,"262":2,"266":1,"267":1,"270":1,"275":2,"276":4,"277":1,"279":1,"282":1,"284":1,"288":4,"290":1,"291":1,"294":1,"300":1,"302":1,"313":2,"314":5,"315":1,"316":1,"317":1,"318":1,"319":3,"320":1,"321":3,"324":2,"330":1,"332":1,"334":1,"336":1,"337":1,"338":6,"339":1,"340":2,"350":1,"353":2,"357":1,"362":1,"365":1,"366":2,"367":3,"371":3,"372":1,"376":1,"377":1,"391":1,"394":1,"395":1,"396":1,"401":1,"402":3,"403":1,"405":2,"407":1,"411":1,"424":1,"426":3,"429":3,"430":6,"436":2,"437":2,"441":1,"448":1,"450":1,"451":1,"459":1,"460":1,"461":1,"462":1,"464":1,"466":2,"467":3,"470":1,"471":2,"476":1,"480":1,"488":1,"489":3,"491":2,"492":6,"494":3,"495":1,"497":2,"507":2,"508":2,"510":1,"515":3,"516":2,"519":1,"521":2,"524":1,"526":2,"531":2,"533":1,"537":4,"538":4,"541":1,"543":1,"548":3,"549":1,"554":1,"556":2,"557":9,"558":1,"559":2,"562":1,"563":1,"564":2,"565":1,"571":3,"579":2,"580":2,"583":2,"584":1,"587":2,"591":2,"593":2,"594":2,"595":4,"597":1,"602":3,"604":2,"606":5,"609":1,"611":1,"621":1,"622":1,"634":1,"636":1,"637":1,"638":1,"644":1,"646":1,"647":1,"648":1,"649":2,"651":1,"655":3,"658":4,"659":1,"661":1,"665":1,"667":3,"668":5,"673":1,"675":1,"680":1,"685":6,"690":2,"691":2,"692":3,"693":3,"695":2,"704":1,"719":2,"720":1,"721":1,"723":2,"726":3,"731":1,"732":1,"738":3,"739":1,"740":2,"742":2,"748":1,"749":1,"750":2,"753":1,"754":7,"758":2,"761":1,"765":2,"768":1,"769":3,"772":1,"777":3,"779":3,"782":1,"785":2,"793":1,"795":2,"796":1,"800":4,"802":1,"803":2,"808":1}}],["opqym",{"2":{"574":2,"578":2}}],["oprexqlg9er1oey1de4mkwvmjlfnqoocg==",{"2":{"383":2}}],["op",{"0":{"246":1,"337":1,"399":1},"1":{"338":1,"339":1,"340":1,"341":1,"400":1,"401":1,"402":1,"403":1,"404":1},"2":{"245":1,"247":1,"255":1,"321":1,"337":1,"338":10,"340":3,"341":1,"394":1,"398":1,"399":3,"400":1,"402":3,"404":1}}],["ops",{"2":{"221":1}}],["opt",{"2":{"220":1,"508":1,"617":4}}],["opted",{"2":{"211":2}}],["optimal",{"2":{"621":1}}],["optimally",{"2":{"467":1}}],["optimized",{"2":{"467":1}}],["optimize",{"2":{"336":1}}],["optimism",{"0":{"394":1},"1":{"395":1,"396":1,"397":1,"398":1},"2":{"246":2,"321":1,"337":1,"338":2,"339":1,"340":1,"394":1,"404":1,"500":1}}],["optimised",{"2":{"230":1}}],["optimistically",{"2":{"187":1,"188":1}}],["optimistic",{"0":{"187":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1},"1":{"188":1,"189":2,"190":2,"191":2,"192":1,"193":2,"194":2},"2":{"136":1,"139":1,"174":1,"180":1,"187":4,"188":1,"191":1,"195":1,"206":1,"236":1}}],["option",{"0":{"346":1,"347":1,"648":1,"649":1,"650":1},"2":{"105":1,"531":1,"548":2,"557":1,"621":2,"628":1,"658":4,"659":1,"785":1,"803":1}}],["options",{"0":{"273":1,"658":1,"805":1},"2":{"40":2,"41":1,"46":1,"83":1,"225":1,"256":1,"258":1,"264":1,"266":1,"314":4,"324":1,"347":1,"437":6,"542":1,"543":1,"546":1,"547":1,"548":2,"556":2,"576":4,"649":2,"658":1,"739":1,"754":1,"769":1,"785":1,"805":1}}],["optionally",{"2":{"69":1,"71":2,"374":1,"639":1}}],["optional",{"0":{"222":1,"298":1,"299":1,"300":1,"301":1,"351":1,"375":1,"539":1,"540":1,"541":1,"584":1,"585":1,"641":1,"645":1,"653":1,"654":1,"658":1,"659":1,"686":1,"687":1,"688":1,"710":1,"714":1,"729":1,"730":1,"731":1,"798":1,"802":1,"805":1},"1":{"223":1,"224":1,"299":1,"301":1,"642":1,"643":1,"655":1,"656":1,"657":1,"687":1,"730":1,"799":1,"800":1,"801":1,"802":1},"2":{"24":1,"40":1,"45":1,"76":1,"351":1,"374":10,"444":1,"445":2,"470":1,"576":1,"621":1,"639":1,"651":1}}],["opportunities",{"2":{"48":1,"65":1}}],["opportunity",{"2":{"19":1,"30":1,"32":1}}],["operating",{"2":{"594":1,"617":1,"622":1,"665":1}}],["operations",{"2":{"309":1,"310":1,"429":1,"469":1,"513":1,"515":1,"538":1,"685":1}}],["operation",{"2":{"30":1,"86":1,"117":1,"282":1}}],["operators",{"0":{"619":1},"2":{"338":1,"499":1,"602":1,"692":1,"734":1,"769":1}}],["operator",{"2":{"220":1,"224":1,"226":1,"227":3,"228":1,"555":1,"621":1,"658":1,"692":2}}],["operates",{"2":{"235":1}}],["operate",{"2":{"107":1,"467":1}}],["operated",{"2":{"24":1,"30":1}}],["opened",{"2":{"701":1}}],["opentelemetry",{"2":{"601":1,"602":1}}],["openaikey",{"2":{"414":6}}],["openaimkdir",{"2":{"410":1}}],["openai",{"0":{"408":1},"2":{"405":2,"406":1,"408":5,"410":1,"411":4,"414":15,"415":1}}],["openrpcgo",{"2":{"323":1}}],["openrpc",{"2":{"94":1,"323":2,"324":6,"355":1,"410":2,"411":6,"436":6}}],["openssl",{"2":{"89":1}}],["opening",{"2":{"34":1,"617":2}}],["open",{"0":{"474":1,"479":1,"483":1,"617":1,"700":1},"2":{"7":1,"23":1,"26":1,"28":3,"117":1,"276":1,"282":1,"306":1,"314":2,"315":2,"339":1,"366":1,"474":1,"521":3,"524":1,"537":1,"549":2,"556":2,"557":2,"591":1,"595":3,"602":1,"604":1,"606":2,"617":9,"618":1,"667":1,"685":1,"694":1,"717":1,"719":1,"726":1,"763":1,"800":1}}],["opinions",{"2":{"8":1}}],["our",{"0":{"7":1,"8":1,"120":1},"2":{"7":1,"8":2,"9":1,"10":1,"30":1,"31":1,"33":3,"48":1,"52":2,"53":2,"55":1,"64":1,"65":2,"122":1,"284":1,"307":2,"308":1,"310":2,"315":2,"317":1,"374":1,"379":1,"380":1,"407":4,"411":2,"412":2,"413":5,"415":4,"529":1,"571":1,"583":2,"590":1,"623":1,"669":1,"676":1,"696":1,"712":1}}],["outbound",{"2":{"693":1}}],["outbox",{"2":{"98":1,"99":1}}],["outcome",{"2":{"469":1}}],["outercontainerstyle",{"2":{"314":4}}],["outsource",{"2":{"264":1}}],["outsourcing",{"2":{"264":1}}],["outside",{"2":{"34":2,"205":1,"429":1,"457":1,"491":1}}],["outline",{"2":{"133":2,"139":1,"174":1}}],["outlined",{"2":{"23":1,"102":1,"103":1,"139":1,"192":1,"208":1}}],["outputs",{"2":{"223":1,"553":2}}],["output",{"2":{"75":3,"116":1,"117":1,"120":1,"121":1,"281":1,"282":1,"285":1,"286":1,"297":1,"301":1,"310":1,"318":3,"374":3,"376":4,"383":2,"389":1,"395":1,"396":1,"407":1,"415":1,"542":2,"561":6,"569":2,"573":1,"574":1,"576":1,"577":1,"578":1,"579":2,"585":4,"590":1,"593":1,"594":2,"621":1,"622":2,"675":2,"676":1,"697":1,"700":2,"712":1,"718":2,"725":1,"797":2,"803":1}}],["outputinfo",{"2":{"68":1,"92":1}}],["out",{"0":{"66":1,"70":1,"316":1},"1":{"67":1,"68":1,"69":1,"70":1,"71":2,"72":2},"2":{"0":1,"36":3,"43":1,"44":1,"45":1,"46":1,"66":2,"77":3,"92":1,"107":1,"127":2,"130":1,"135":1,"178":1,"183":2,"188":1,"200":1,"203":1,"230":1,"262":1,"266":1,"284":1,"287":1,"309":1,"311":2,"315":1,"317":1,"319":3,"330":1,"358":1,"366":1,"369":1,"392":1,"432":1,"450":1,"538":1,"556":2,"557":1,"593":1,"602":1,"621":1,"676":1,"705":1,"732":1,"748":1,"754":2,"779":1,"783":1}}],["oracle",{"0":{"108":1},"2":{"106":1,"108":3,"129":1}}],["oral",{"2":{"34":1}}],["originate",{"2":{"439":1}}],["originally",{"2":{"428":1,"609":1}}],["original",{"2":{"79":1,"183":1,"230":1,"432":1,"461":1,"463":3,"464":1,"469":2,"470":1,"577":2}}],["origin",{"2":{"71":1,"441":1,"581":4,"582":1}}],["orientation",{"2":{"7":1}}],["orbitsetupscriptconfig",{"2":{"86":1,"87":1}}],["orbit",{"0":{"66":1,"69":1,"79":1,"84":1,"85":1},"1":{"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"80":1,"81":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},"2":{"66":2,"68":2,"73":1,"79":5,"80":2,"81":1,"82":2,"83":1,"84":8,"85":7,"87":5,"89":1,"90":1,"91":28,"92":1,"94":4,"95":1,"101":3,"105":4,"106":1,"108":1}}],["ordered",{"2":{"464":1,"467":2,"608":2}}],["ordering",{"2":{"41":1,"262":1,"468":1,"700":2}}],["order",{"0":{"616":1},"2":{"30":1,"31":1,"41":1,"43":1,"76":1,"88":1,"107":1,"108":2,"145":1,"148":1,"183":1,"184":1,"261":1,"302":1,"318":1,"370":1,"371":1,"372":1,"381":1,"382":1,"391":1,"401":1,"408":1,"426":1,"428":1,"462":1,"467":1,"490":1,"492":1,"519":1,"521":1,"539":1,"616":2,"663":1,"669":1,"685":1,"686":1,"689":1,"690":1,"691":2,"714":1,"726":1,"729":1,"739":2,"760":1,"785":1,"803":1}}],["organizing",{"2":{"39":1,"42":2,"47":2,"52":1,"56":1,"63":1}}],["organizers",{"2":{"40":1,"43":1,"44":1,"48":2,"49":1,"50":2,"52":1,"53":1,"55":1,"56":2,"65":1}}],["organizer",{"2":{"39":1,"43":1,"47":4,"56":1,"63":1,"65":1}}],["organize",{"2":{"35":2,"42":1,"43":1}}],["organization",{"2":{"27":1}}],["org",{"0":{"6":1,"52":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1},"2":{"7":1,"11":1,"17":3,"25":1,"46":1,"47":2,"52":1,"63":1,"84":1,"437":4,"594":2,"622":2,"676":8,"742":2,"743":2,"744":2,"761":1,"762":1,"763":1}}],["or",{"0":{"100":1,"373":1,"403":1,"584":1},"1":{"101":1,"102":1,"103":1},"2":{"2":1,"4":1,"7":2,"8":8,"9":2,"10":2,"11":1,"13":2,"14":2,"15":2,"16":2,"23":1,"24":7,"25":4,"27":3,"30":9,"31":33,"32":3,"33":6,"34":50,"36":3,"37":4,"38":1,"40":4,"41":3,"42":3,"43":5,"44":4,"45":3,"46":2,"47":1,"48":2,"65":1,"82":1,"83":1,"84":3,"89":2,"91":5,"92":1,"94":1,"102":1,"105":1,"110":2,"131":1,"133":1,"135":1,"136":1,"139":2,"143":2,"145":1,"146":2,"148":1,"169":1,"174":1,"178":1,"183":1,"195":1,"212":2,"213":1,"214":1,"217":1,"220":3,"222":1,"224":1,"233":2,"234":1,"236":1,"262":2,"264":1,"265":1,"266":3,"268":1,"269":1,"270":3,"277":1,"279":1,"288":5,"302":1,"308":1,"311":1,"312":1,"313":2,"314":2,"315":1,"333":1,"357":2,"365":1,"366":2,"367":2,"369":1,"370":1,"373":2,"374":1,"391":2,"406":1,"425":1,"428":1,"429":1,"432":1,"437":4,"439":1,"440":1,"441":1,"448":2,"454":1,"458":1,"463":1,"467":1,"470":1,"477":1,"481":1,"486":1,"488":1,"492":2,"494":1,"500":2,"508":1,"513":1,"515":1,"521":1,"523":1,"524":3,"525":1,"531":1,"537":3,"542":4,"543":1,"554":1,"557":6,"559":3,"560":1,"563":2,"583":1,"584":2,"591":1,"601":2,"614":2,"618":4,"639":1,"646":1,"649":1,"655":1,"665":1,"666":1,"667":2,"669":1,"685":3,"690":1,"692":1,"701":1,"705":1,"715":1,"718":1,"726":2,"727":1,"734":2,"738":1,"740":1,"747":1,"748":3,"750":1,"758":1,"759":1,"760":1,"762":1,"765":1,"772":2,"774":1,"787":1,"800":1}}],["often",{"2":{"40":1,"42":1,"43":1,"45":1,"428":1,"430":1,"690":1}}],["offloads",{"2":{"261":1}}],["offline",{"2":{"10":1,"563":1,"692":1}}],["off",{"2":{"228":1,"413":1,"557":1}}],["offchain",{"2":{"79":2,"91":1,"235":1,"238":1,"448":1}}],["offshore",{"2":{"34":1}}],["offense",{"2":{"563":1}}],["offensive",{"2":{"9":1}}],["offers",{"2":{"57":1,"83":1,"230":1,"235":1,"247":1,"785":1}}],["offered",{"2":{"34":1,"42":1}}],["offer",{"2":{"34":5,"40":4,"41":1,"43":1,"44":2,"235":1}}],["offering",{"2":{"34":1,"41":1,"105":1}}],["officially",{"2":{"10":1}}],["official",{"2":{"0":1,"10":2,"89":1}}],["of",{"0":{"6":1,"19":1,"52":1,"66":1,"146":1,"153":1,"181":1,"182":1,"183":1,"184":2,"185":1,"186":1,"188":1,"189":1,"190":1,"191":1,"196":1,"197":1,"198":1,"231":1,"234":1,"241":1,"263":1,"264":1,"380":1,"386":1,"451":1,"457":1,"459":1,"463":1,"469":1,"484":1,"494":1,"504":1,"506":1,"509":1,"531":1,"570":1,"579":1,"607":1,"678":1,"721":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"67":1,"68":1,"69":1,"70":1,"71":1,"72":1,"147":1,"148":1,"182":1,"183":1,"184":1,"185":1,"186":1,"189":1,"190":1,"191":1,"197":1,"198":1,"242":1,"243":1,"244":1,"264":1,"265":1,"266":1,"470":1,"505":1,"506":1,"507":2,"508":2,"509":2,"510":2,"511":2,"512":2,"513":2,"514":2,"608":1,"609":1,"610":1,"611":1,"612":1,"613":1},"2":{"0":1,"2":1,"7":2,"8":6,"9":2,"10":2,"11":3,"12":2,"13":3,"14":3,"15":4,"16":6,"17":4,"19":3,"21":1,"22":3,"23":5,"24":7,"25":1,"26":2,"27":3,"28":1,"30":9,"31":14,"32":5,"33":10,"34":47,"36":2,"37":1,"38":1,"39":3,"40":3,"41":1,"42":8,"43":5,"44":6,"45":1,"46":2,"47":5,"48":4,"49":1,"50":1,"52":5,"53":2,"55":1,"56":2,"59":2,"60":1,"61":1,"62":1,"64":1,"65":7,"66":3,"68":1,"69":3,"71":1,"72":1,"75":1,"76":1,"77":1,"79":3,"82":2,"84":6,"85":3,"87":2,"88":1,"89":3,"90":1,"91":5,"92":3,"94":1,"102":1,"105":1,"106":2,"107":8,"108":2,"109":2,"110":2,"114":2,"116":1,"117":3,"121":1,"128":3,"131":5,"134":28,"135":10,"136":3,"137":2,"139":8,"143":2,"145":1,"146":4,"148":11,"149":2,"150":2,"151":1,"154":3,"158":1,"159":3,"160":4,"161":3,"162":2,"163":8,"164":1,"165":12,"166":2,"167":1,"168":10,"169":10,"170":4,"171":2,"172":10,"173":1,"174":1,"175":1,"177":2,"178":4,"179":2,"180":1,"181":9,"182":1,"183":10,"184":20,"185":2,"187":2,"188":6,"189":1,"191":2,"192":10,"194":2,"195":1,"196":9,"197":1,"200":4,"203":4,"205":1,"206":3,"208":6,"210":1,"211":12,"212":2,"213":13,"214":2,"215":2,"217":3,"219":6,"220":8,"223":2,"224":2,"225":1,"226":1,"227":1,"228":1,"230":6,"231":1,"233":2,"234":1,"235":3,"236":5,"237":1,"242":1,"246":2,"251":1,"255":2,"256":1,"261":1,"262":6,"264":7,"265":6,"266":3,"267":1,"269":2,"270":1,"275":1,"276":1,"279":2,"281":1,"282":3,"285":1,"286":1,"288":3,"293":1,"296":2,"303":1,"306":5,"309":4,"310":2,"311":1,"313":2,"314":2,"318":2,"319":1,"321":1,"323":1,"324":3,"326":5,"327":2,"328":1,"331":1,"334":1,"336":2,"338":2,"340":1,"341":1,"351":1,"353":3,"355":1,"362":1,"366":1,"368":1,"369":1,"370":2,"371":2,"373":1,"374":8,"376":3,"377":3,"379":1,"380":4,"383":2,"386":3,"389":1,"395":1,"403":2,"405":2,"407":1,"415":2,"418":1,"419":3,"420":3,"421":2,"422":1,"423":1,"424":2,"425":1,"427":2,"428":5,"429":10,"430":8,"431":3,"432":3,"437":4,"439":2,"440":1,"441":1,"444":1,"445":1,"447":2,"448":4,"450":3,"451":3,"452":1,"453":1,"454":2,"456":2,"457":4,"458":2,"459":1,"460":2,"461":5,"462":5,"463":8,"464":7,"466":7,"467":11,"468":4,"469":15,"470":4,"471":1,"475":1,"476":1,"480":1,"484":1,"488":3,"489":2,"490":3,"491":6,"492":4,"494":5,"495":3,"497":2,"498":1,"499":4,"500":5,"501":2,"505":1,"507":1,"508":2,"509":3,"510":2,"519":1,"521":2,"524":1,"525":2,"526":1,"531":3,"537":3,"538":1,"539":7,"548":3,"549":1,"555":1,"556":4,"557":2,"558":1,"559":1,"560":1,"561":2,"563":7,"564":1,"569":2,"570":1,"571":1,"576":1,"579":3,"580":2,"581":4,"584":2,"591":1,"593":2,"601":1,"602":2,"604":1,"608":3,"609":1,"616":1,"617":1,"618":3,"621":2,"623":1,"627":2,"630":1,"631":1,"633":1,"639":2,"643":1,"645":1,"646":3,"647":1,"648":2,"649":1,"659":4,"661":1,"665":1,"666":2,"667":1,"673":1,"676":2,"685":3,"686":7,"690":1,"691":3,"692":1,"693":2,"694":2,"696":1,"712":3,"716":2,"717":2,"719":1,"721":1,"725":1,"726":2,"729":7,"733":3,"737":1,"738":2,"739":4,"748":2,"749":1,"754":5,"760":1,"765":3,"769":1,"774":2,"783":1,"785":1,"790":1,"791":1,"797":2,"798":1,"800":2,"803":5,"806":1,"808":1}}],["mzonder",{"2":{"742":1,"743":1,"744":1}}],["m",{"2":{"402":2,"502":1,"752":1}}],["mb",{"2":{"363":1,"722":1,"771":1}}],["mbidstyle",{"2":{"314":4}}],["mykey",{"2":{"310":3,"316":2}}],["my",{"2":{"277":4,"306":14,"309":2,"310":2,"343":1,"401":1,"407":2,"668":5,"669":8,"670":8,"727":6}}],["myrollup",{"2":{"127":2}}],["mnemonic",{"2":{"272":2,"407":2,"573":3,"590":1,"696":4}}],["mv",{"2":{"224":2}}],["md013",{"2":{"383":2}}],["md",{"2":{"169":2}}],["mtgbzqhrqol61okkzmhrfyq5bk6goklgwrvparpyxve=",{"2":{"156":2}}],["msgcreatevestingaccount",{"2":{"576":2}}],["msgsubmitproposal",{"2":{"548":2}}],["msgsend",{"2":{"300":2}}],["msgpayforblobs",{"2":{"156":2,"176":1,"300":2,"361":2,"425":1,"430":2}}],["msg",{"2":{"156":2,"306":4,"414":4,"469":1,"548":1,"695":4}}],["mkdir",{"2":{"115":2,"223":2,"224":2,"280":2,"650":6,"668":2}}],["mutual",{"0":{"631":1}}],["mutually",{"2":{"42":1}}],["mut",{"2":{"420":2}}],["multiaddress",{"2":{"791":1}}],["multiaddresses",{"2":{"630":1}}],["multiaccounts",{"0":{"342":1},"1":{"343":1,"344":1,"345":1,"346":1,"347":1,"348":1,"349":1,"350":1,"351":1}}],["multi",{"2":{"562":1}}],["multiplier",{"2":{"695":4}}],["multiplies",{"2":{"430":1}}],["multiple",{"0":{"432":1},"2":{"43":1,"103":1,"131":1,"148":1,"159":1,"160":3,"163":8,"165":4,"181":2,"265":1,"362":1,"450":1,"453":1,"458":1,"461":1,"464":1,"467":2,"469":1,"528":1,"557":1,"608":1,"619":1,"751":1}}],["multiproof",{"2":{"165":2}}],["multisign",{"2":{"561":2}}],["multisig",{"0":{"560":1},"1":{"561":1,"562":1},"2":{"84":1,"244":1,"560":3,"561":18,"562":3}}],["much",{"2":{"41":1,"89":1,"262":1,"264":1,"265":1,"715":1}}],["mustnewv0",{"2":{"437":2}}],["must",{"2":{"30":1,"31":2,"84":2,"89":1,"302":1,"323":1,"348":1,"401":2,"403":1,"418":1,"428":1,"432":3,"460":1,"462":1,"464":3,"467":2,"539":2,"548":1,"614":4,"644":1,"649":1,"664":1,"676":1,"685":1,"686":2,"709":1,"710":1,"711":1,"716":2,"726":1,"729":2,"738":1,"803":1}}],["milestone",{"2":{"754":1}}],["million",{"2":{"553":2}}],["middleware",{"2":{"704":1}}],["migrate",{"0":{"540":1,"687":1,"730":1},"2":{"540":1,"542":4,"687":1,"730":1}}],["might",{"2":{"40":3,"180":1,"262":1,"366":1,"369":1,"463":1,"548":1,"617":1,"639":1,"645":1,"748":1,"777":1}}],["microtia",{"0":{"514":1},"2":{"514":1}}],["micro",{"2":{"513":1}}],["microphone",{"2":{"40":2}}],["microphones",{"2":{"36":1,"40":1}}],["mib",{"2":{"426":3,"738":1}}],["mixhash",{"2":{"395":2}}],["mit",{"2":{"306":4,"308":2}}],["mirrors",{"2":{"247":1}}],["miner",{"2":{"395":2}}],["mined",{"2":{"91":4}}],["mintscan",{"2":{"445":1,"751":1,"767":1}}],["mint",{"2":{"331":1}}],["minority",{"2":{"548":1}}],["minor",{"2":{"331":1}}],["mins",{"2":{"220":1}}],["minns",{"2":{"165":2,"172":2}}],["minnamespace",{"2":{"165":4,"172":4}}],["min",{"2":{"165":4,"554":2,"643":1,"646":4,"695":4,"803":3}}],["minimized",{"2":{"460":1}}],["minimal",{"2":{"127":1,"189":1,"331":1,"337":1,"621":1,"734":1}}],["minimum",{"0":{"635":1},"2":{"24":1,"84":1,"91":4,"126":1,"165":2,"261":1,"363":2,"428":1,"451":1,"532":2,"635":1,"679":2,"722":2,"794":1}}],["minutes",{"2":{"43":1,"107":1,"220":1,"223":1,"224":1,"226":1,"649":1}}],["minute",{"0":{"672":1},"2":{"41":1,"48":1,"432":1,"563":1}}],["mind",{"2":{"41":1,"270":2,"639":1,"803":1}}],["mindful",{"2":{"41":1}}],["misbehaviour",{"2":{"695":2}}],["mismatch",{"2":{"463":1}}],["misuse",{"2":{"89":1}}],["mission",{"2":{"19":1}}],["mistakes",{"2":{"8":1}}],["moonli",{"2":{"742":1,"743":1}}],["mock",{"2":{"402":1}}],["mocha4",{"2":{"760":1,"761":1,"763":1}}],["mocharesturl",{"2":{"443":2}}],["mocharpcurl",{"2":{"443":2}}],["mochamainnet",{"2":{"401":1}}],["mochachainid",{"2":{"372":3,"401":2,"443":2,"605":1,"639":8,"650":2,"797":2,"803":2}}],["mochacelestia",{"2":{"89":1,"365":1,"366":2,"367":1,"537":1,"538":1,"539":1,"547":1,"600":1,"609":1,"615":1,"684":1,"686":1,"725":1,"726":1,"727":1,"729":1}}],["mochadocker",{"2":{"276":1}}],["mochaversions",{"2":{"276":2,"593":2,"621":2,"667":2,"669":2,"670":2}}],["mocha",{"0":{"89":1,"402":1,"403":1,"503":1,"580":1,"583":1,"600":1,"611":1,"612":1,"754":1,"765":1,"779":1,"780":1},"1":{"581":1,"582":1,"583":1,"584":1,"585":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1,"768":1},"2":{"24":3,"27":1,"28":1,"79":1,"80":2,"89":7,"95":1,"107":1,"145":2,"240":3,"246":2,"270":3,"276":4,"277":8,"290":1,"291":3,"293":2,"295":2,"300":5,"301":2,"365":1,"366":5,"367":3,"399":1,"401":2,"402":1,"443":6,"445":5,"503":3,"515":2,"516":2,"537":2,"538":6,"539":1,"547":5,"565":1,"571":1,"579":1,"580":2,"583":7,"585":4,"587":1,"591":1,"600":4,"605":2,"608":1,"609":7,"611":2,"612":2,"615":1,"618":1,"639":1,"667":1,"684":1,"685":3,"686":1,"691":1,"692":3,"693":1,"695":9,"696":2,"698":1,"699":6,"700":6,"701":3,"725":1,"726":4,"727":3,"728":1,"729":1,"754":7,"760":6,"761":8,"762":8,"763":13,"764":16,"765":2,"766":1,"767":2,"768":2,"779":4,"781":1,"785":2,"800":1,"803":1}}],["mounted",{"2":{"277":1}}],["mounting",{"0":{"277":1},"2":{"277":1,"668":1}}],["mount",{"2":{"276":1,"277":1,"401":1,"668":2,"669":1,"673":1}}],["moment",{"2":{"189":1,"192":1,"309":1,"602":1}}],["moved",{"2":{"467":1,"716":1}}],["move",{"2":{"69":2,"71":1,"87":1,"367":1}}],["moniker",{"2":{"803":3}}],["moniker=$moniker",{"2":{"554":2,"803":2}}],["moniker=validator",{"2":{"554":2}}],["monitors",{"2":{"564":1}}],["monitor",{"0":{"564":1},"2":{"440":1,"441":1,"557":4,"564":1,"602":1}}],["monitoring",{"0":{"440":1},"2":{"24":1,"27":1,"555":1,"559":1,"675":1}}],["monolithic",{"0":{"467":1},"2":{"59":1,"262":2,"330":1,"338":1,"467":3}}],["monthly",{"2":{"42":1,"54":1}}],["month",{"2":{"24":1,"26":1}}],["months",{"2":{"22":1,"23":6,"24":1,"26":1,"27":1,"175":1,"177":1}}],["modifiable",{"2":{"548":1}}],["modifications",{"2":{"331":1}}],["modifier",{"2":{"306":4}}],["modified",{"2":{"246":1,"336":1,"340":1,"464":1,"466":1,"531":1}}],["modifying",{"2":{"717":1}}],["modify",{"0":{"717":1},"2":{"310":1,"369":1,"403":1,"617":1,"717":1}}],["module=consensus",{"2":{"661":2,"808":2}}],["moduleencodingregisters",{"2":{"437":2}}],["modules",{"2":{"311":1,"331":2,"410":1,"429":1}}],["module",{"0":{"289":1,"294":1},"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},"2":{"290":1,"292":1,"301":1,"351":2,"369":5,"372":2,"388":2,"431":1,"443":2,"548":4,"563":1,"703":1,"704":1}}],["modularity",{"0":{"59":1},"2":{"48":1,"59":1}}],["modular",{"0":{"35":1,"48":1,"49":1,"57":1,"62":1,"229":1,"262":1,"263":1,"302":1,"467":1},"1":{"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1,"58":1,"59":1,"60":1,"61":1,"62":1,"63":1,"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"264":1,"265":1,"266":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1},"2":{"19":1,"35":2,"39":1,"40":1,"41":2,"42":3,"43":4,"45":1,"46":1,"47":2,"48":2,"49":2,"50":2,"53":3,"54":1,"56":2,"57":2,"59":4,"62":3,"63":1,"65":9,"236":1,"256":2,"262":4,"264":2,"265":2,"266":1,"302":3,"314":2,"330":2,"337":1,"415":2,"447":1,"467":3,"468":2,"507":1,"508":1,"751":1}}],["mod",{"2":{"149":3,"410":2,"569":2,"661":14,"693":1,"808":14}}],["mode=",{"2":{"561":2}}],["model",{"2":{"414":2,"430":1,"510":1}}],["modern",{"2":{"311":1,"763":1}}],["moderation",{"2":{"9":1}}],["mode",{"2":{"68":2,"220":2,"300":2,"314":2,"508":1,"561":4,"585":4,"647":1,"695":12}}],["mozilla",{"2":{"17":1}}],["more",{"0":{"140":1},"1":{"141":1,"142":1,"143":1},"2":{"5":1,"21":1,"25":1,"33":1,"40":1,"41":1,"42":1,"44":1,"71":1,"79":3,"84":3,"85":1,"90":1,"92":1,"105":1,"108":1,"110":1,"116":1,"117":1,"134":2,"135":2,"136":2,"145":1,"146":2,"148":1,"151":1,"156":1,"161":1,"172":1,"177":1,"178":1,"183":1,"184":2,"191":1,"199":1,"203":1,"205":1,"208":2,"219":1,"221":1,"235":2,"236":1,"239":1,"242":1,"243":2,"244":1,"246":1,"247":1,"262":1,"265":3,"266":1,"270":1,"276":1,"281":1,"282":1,"292":1,"302":1,"314":2,"332":1,"338":1,"350":1,"357":1,"358":1,"361":1,"362":2,"367":1,"369":2,"376":1,"377":1,"403":1,"404":1,"414":1,"416":1,"425":1,"426":1,"430":1,"431":1,"435":1,"436":1,"438":1,"447":1,"450":1,"451":1,"461":1,"462":3,"464":1,"466":3,"468":1,"470":1,"497":1,"510":1,"529":1,"538":1,"543":1,"548":1,"559":1,"563":3,"572":1,"573":1,"583":1,"585":2,"586":1,"593":1,"594":2,"606":1,"617":1,"621":1,"622":1,"649":1,"665":1,"685":1,"749":1,"750":1,"753":1,"768":1,"769":1,"781":1,"797":2}}],["mostly",{"2":{"685":1}}],["most",{"2":{"0":1,"43":1,"48":5,"50":1,"88":1,"208":1,"322":1,"334":1,"417":1,"449":1,"457":1,"627":1,"648":1,"665":1,"721":1}}],["mesa",{"2":{"742":1,"743":1,"744":1,"748":1,"760":1,"761":1,"763":1}}],["messages",{"2":{"36":1,"38":1,"199":1,"300":2,"331":1,"405":1,"414":2,"548":2,"576":2}}],["message",{"2":{"2":1,"47":3,"107":1,"110":1,"156":2,"376":1,"414":4,"415":2,"416":1,"430":1,"469":2,"586":1,"591":1}}],["me",{"2":{"312":2,"313":8,"314":2,"656":2,"718":2,"742":1,"743":1,"761":1,"762":1,"763":1}}],["mechanisms",{"2":{"85":1,"110":1,"139":1,"429":1,"430":1}}],["mechanism",{"0":{"110":1,"234":1},"2":{"85":1,"106":1,"110":4,"173":1,"208":1,"236":1,"288":2,"449":1,"450":1,"460":1,"492":1,"494":1,"501":1,"559":1,"563":1,"648":1}}],["measured",{"2":{"84":1}}],["meant",{"2":{"357":1,"520":1,"740":1,"758":1}}],["mean",{"2":{"135":2}}],["meaningful",{"2":{"336":1}}],["meaning",{"2":{"30":1,"177":2,"336":1,"531":1,"650":1}}],["means",{"2":{"22":1,"148":1,"208":1,"214":1,"265":2,"306":2,"331":1,"351":1,"365":1,"426":1,"428":1,"432":1,"462":2,"467":2,"471":1,"489":1,"491":1,"618":1,"655":2,"664":1,"665":1}}],["metric",{"2":{"598":1}}],["metricscurl",{"2":{"556":1}}],["metrics",{"0":{"555":1,"597":1,"598":1,"602":1},"1":{"556":1,"557":1,"558":1,"559":1,"598":1,"599":2,"600":2,"601":2,"602":1},"2":{"33":1,"555":3,"556":8,"557":3,"558":2,"597":2,"598":12,"599":6,"600":6,"601":15,"602":2,"694":1}}],["met",{"2":{"428":1}}],["meta",{"2":{"314":4}}],["metadata",{"2":{"169":2,"265":1,"470":1,"721":1}}],["metamaskwallet",{"2":{"313":4}}],["metamask",{"0":{"315":1},"2":{"80":1,"304":1,"315":2,"316":3}}],["methods",{"2":{"323":2,"328":1,"369":1,"418":2,"422":1,"438":1,"492":1}}],["method",{"2":{"129":1,"131":2,"162":2,"166":1,"175":1,"183":1,"219":1,"242":1,"324":2,"325":2,"326":2,"327":2,"335":1,"338":1,"369":5,"372":2,"388":3,"389":1,"391":2,"397":2,"419":2,"420":2,"421":2,"443":2,"492":3}}],["menu",{"2":{"68":1,"388":2,"399":1,"445":1,"583":1,"593":1,"594":1,"622":1}}],["mentioned",{"2":{"102":1,"760":1}}],["mention",{"2":{"44":2}}],["memo",{"2":{"576":2,"695":4}}],["memory",{"2":{"136":1,"172":2,"306":26,"363":1,"532":1,"558":1,"635":1,"679":1,"722":1,"771":1,"772":1,"794":1}}],["memorable",{"2":{"65":1,"84":1}}],["mempool",{"0":{"427":1},"1":{"428":1,"429":1,"430":1,"431":1,"432":1},"2":{"288":1,"426":1,"427":2,"428":2,"432":2,"437":2,"489":1}}],["member",{"2":{"47":1}}],["members",{"0":{"48":1},"2":{"7":1,"23":1,"36":1,"45":3,"47":2,"48":2,"234":1,"432":1,"499":1,"549":1}}],["mev",{"2":{"48":1}}],["merge",{"2":{"614":1}}],["merkelized",{"2":{"488":1}}],["merkelizes",{"2":{"236":1}}],["merkleized",{"2":{"128":1,"148":1}}],["merkle",{"0":{"203":1,"204":1,"205":1,"464":1},"1":{"204":1,"205":1},"2":{"108":1,"128":4,"129":1,"131":1,"136":1,"148":3,"150":2,"153":4,"154":3,"160":1,"163":2,"165":4,"168":4,"169":4,"172":8,"177":6,"183":2,"184":5,"197":1,"199":1,"205":1,"234":1,"236":2,"362":1,"460":1,"461":6,"462":1,"463":2,"464":2,"466":2,"469":4,"470":3}}],["merchandise",{"2":{"63":2}}],["merits",{"2":{"34":1}}],["merely",{"2":{"27":1}}],["meetups",{"2":{"38":1,"40":4,"42":5,"43":1,"44":1,"45":1,"46":4,"47":6,"48":2,"49":1,"57":3,"63":2,"65":1}}],["meetup",{"0":{"35":1,"36":1,"37":1,"38":1,"47":1,"48":1,"49":1,"57":1,"62":1},"1":{"36":1,"37":1,"38":1,"39":1,"40":1,"41":1,"42":1,"43":1,"44":1,"45":1,"46":1,"47":1,"48":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1,"58":1,"59":1,"60":1,"61":1,"62":1,"63":1},"2":{"35":2,"36":2,"38":1,"39":3,"40":4,"41":2,"42":7,"43":9,"44":5,"45":8,"46":4,"47":10,"48":5,"49":1,"50":4,"52":1,"53":2,"54":1,"56":4,"62":2,"63":1,"65":6}}],["meet",{"2":{"22":1}}],["media",{"2":{"3":1,"10":1,"14":1,"36":1,"38":1,"45":4,"46":1,"321":1}}],["mac",{"2":{"666":1,"668":1,"676":2}}],["macos",{"2":{"402":2}}],["machines",{"2":{"467":1,"557":1,"655":1}}],["machine",{"2":{"2":1,"80":1,"114":1,"220":2,"223":1,"224":1,"226":1,"247":1,"275":1,"276":1,"279":1,"365":1,"366":1,"407":1,"428":1,"430":1,"466":3,"467":1,"469":2,"531":1,"533":1,"537":1,"557":1,"571":2,"591":1,"595":1,"604":1,"606":1,"636":1,"665":1,"667":1,"668":3,"680":1,"685":1,"703":1,"719":1,"723":1,"726":1,"795":1,"800":1}}],["magnitude",{"2":{"336":1}}],["map",{"2":{"314":8}}],["mappings",{"2":{"306":2}}],["mapping",{"2":{"108":1,"165":2,"168":1,"306":4,"424":1}}],["marginright",{"2":{"314":4}}],["margintop",{"2":{"314":4}}],["marginbottom",{"2":{"314":2}}],["margin",{"2":{"313":2,"314":4}}],["marking",{"2":{"491":1}}],["markdownlint",{"2":{"383":2}}],["markdown",{"2":{"312":1}}],["markdownnpm",{"2":{"312":1}}],["marks",{"2":{"105":1,"733":1,"774":1}}],["marketing",{"0":{"45":1},"2":{"45":1}}],["market",{"0":{"427":1,"489":1},"1":{"428":1,"429":1,"430":1,"431":1,"432":1},"2":{"34":3}}],["mark",{"2":{"27":1}}],["mass",{"2":{"302":1}}],["master",{"2":{"169":2,"445":1,"639":10}}],["majority",{"2":{"463":1}}],["major",{"2":{"184":1,"466":1}}],["malicious",{"2":{"139":1,"217":2,"463":1,"563":1}}],["math",{"2":{"153":2,"172":2}}],["matrix",{"0":{"94":1},"2":{"89":1,"461":4,"463":1,"469":5,"470":1}}],["matching",{"2":{"424":1}}],["matches",{"2":{"89":1,"208":1,"277":1}}],["match",{"2":{"77":1,"134":1,"149":1,"319":1,"420":4}}],["matters",{"2":{"34":1,"183":1}}],["materials",{"0":{"56":1},"2":{"0":1,"3":1,"36":2,"37":1,"57":1}}],["made",{"2":{"34":6,"79":1,"109":1,"236":1,"266":1,"340":1,"352":1,"451":1,"466":1,"469":2,"470":1,"488":2,"492":1,"571":1,"579":1,"608":1}}],["manual",{"2":{"351":1,"492":1}}],["manually",{"2":{"311":1,"315":1,"369":1,"432":1,"437":2,"440":1,"492":1,"608":1,"630":1,"633":1,"639":2}}],["managing",{"2":{"292":1}}],["manager",{"2":{"557":1}}],["management",{"0":{"332":1,"348":1,"544":1,"547":1},"1":{"349":1,"350":1,"545":1},"2":{"332":1,"665":1}}],["manages",{"2":{"211":1}}],["managed",{"2":{"177":1,"338":1,"491":1}}],["manage",{"0":{"477":1,"481":1,"486":1},"2":{"31":1,"36":1,"42":1,"268":1,"437":2,"542":2,"659":1}}],["many",{"0":{"617":1},"2":{"45":1,"134":1,"143":1,"265":1,"321":1,"332":1,"429":1,"431":1,"467":1,"495":1,"498":1,"516":1,"557":1,"617":2,"675":1,"769":1}}],["manner",{"2":{"25":1,"31":1,"34":1,"673":1}}],["maxvalidators",{"2":{"548":4}}],["maxwidth",{"2":{"314":4}}],["maximize",{"2":{"266":1}}],["maximum",{"0":{"426":1,"738":1},"2":{"165":2,"369":1,"426":2,"430":1,"556":2,"738":8}}],["maxns",{"2":{"165":2,"172":2}}],["maxnamespace",{"2":{"165":4,"172":4}}],["max",{"2":{"27":1,"165":4,"242":1,"548":3,"554":4,"556":2,"695":20,"737":1,"803":4}}],["may",{"0":{"458":1},"2":{"11":1,"13":1,"14":1,"15":1,"23":1,"24":1,"30":3,"31":6,"32":1,"33":4,"34":11,"40":2,"44":2,"45":3,"76":1,"83":1,"85":1,"89":1,"173":1,"318":1,"411":1,"429":1,"439":1,"440":1,"458":1,"470":2,"491":1,"492":1,"498":1,"500":1,"508":1,"584":1,"595":1,"606":1,"617":1,"649":1,"658":1,"668":1,"734":1,"774":1}}],["mail",{"2":{"10":1,"34":1}}],["maintenance",{"2":{"499":1}}],["maintained",{"2":{"237":1}}],["maintaining",{"2":{"52":1,"60":1,"84":1,"230":1,"432":1}}],["maintains",{"2":{"23":1}}],["maintain",{"2":{"19":1,"23":1,"24":2,"28":1,"34":2,"38":1,"42":1,"43":1,"45":1,"244":1,"608":1}}],["mainly",{"2":{"224":2}}],["mainnetversions",{"2":{"593":2,"621":2,"667":2,"669":2,"670":2}}],["mainnetresturl",{"2":{"443":2}}],["mainnetrpcurl",{"2":{"443":2}}],["mainnetchainid",{"2":{"443":2,"605":2,"639":8,"650":2}}],["mainnet",{"0":{"502":1,"599":1,"611":1,"733":1,"774":1,"775":1},"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,"775":1},"2":{"24":4,"25":1,"27":4,"28":1,"30":2,"110":1,"145":2,"237":2,"240":4,"270":3,"276":1,"277":1,"288":1,"315":1,"365":1,"366":2,"367":2,"391":1,"426":1,"443":5,"502":1,"525":2,"537":1,"538":1,"539":1,"593":1,"599":1,"604":1,"605":3,"608":1,"611":3,"618":1,"621":1,"639":5,"647":1,"650":1,"651":1,"667":3,"669":1,"670":1,"676":1,"684":1,"685":1,"686":1,"691":1,"692":3,"725":1,"726":2,"727":1,"729":1,"733":3,"734":2,"739":2,"742":3,"743":3,"744":3,"745":2,"748":4,"751":4,"752":3,"753":2,"765":2,"774":2,"781":1,"803":1}}],["main",{"0":{"412":1},"2":{"2":1,"77":1,"92":1,"145":4,"152":4,"153":4,"172":4,"223":16,"224":2,"313":2,"319":1,"369":1,"411":6,"412":5,"413":5,"415":9,"466":1,"562":1}}],["making",{"2":{"2":1,"47":1,"48":1,"91":1,"236":1,"247":1,"370":1,"467":1,"468":1,"611":1,"612":1,"655":1,"656":1,"657":1,"658":1,"659":1}}],["makeconfig",{"2":{"437":2}}],["makes",{"0":{"451":1},"2":{"34":1,"196":1,"246":1,"427":1}}],["make",{"2":{"0":1,"2":1,"7":1,"31":1,"50":1,"88":1,"89":1,"107":1,"121":1,"125":1,"126":1,"130":1,"149":3,"153":2,"165":5,"167":2,"168":4,"169":2,"171":2,"172":12,"177":1,"192":1,"211":3,"213":1,"220":3,"223":1,"224":2,"236":1,"264":1,"265":2,"269":5,"270":1,"286":1,"307":1,"314":2,"407":1,"461":1,"469":1,"492":1,"555":1,"556":2,"565":1,"576":1,"587":1,"595":3,"606":3,"626":1,"655":1,"675":4,"772":1,"788":1}}],["ccv",{"2":{"695":4}}],["cycle",{"2":{"488":1}}],["cte",{"2":{"313":2,"315":1}}],["ctx",{"2":{"152":2,"153":10,"162":2,"170":4,"171":6,"172":4,"324":8,"325":8,"326":8,"327":8,"412":2,"413":9,"414":2,"415":8,"436":8}}],["css",{"2":{"313":4,"443":2}}],["c4ibesqxgzc5zxj3vtugbiadqamienbyjkegcac=",{"2":{"296":2}}],["cgo",{"2":{"223":2,"621":1}}],["cmd",{"2":{"157":2}}],["cqebcp4bciavy2vszxn0aweuymxvyi52ms5nc2dqyxlgb3jcbg9icxj6ci9jzwxlc3rpytf2ogvzy3u3znu5bhy4nzlrenu1dwvndwv1cnrxnxn3nmhzbtnuzridaaaaaaaaaaaaaaaaaaaaaaaaaaaabytlu4hlouuaa8cpbyigsvxwya9toi+aytu3jja2wki5zlkm72",{"2":{"156":2}}],["cfg",{"2":{"88":1,"89":2,"102":1}}],["cpu",{"2":{"363":1,"532":1,"635":1,"679":1,"722":1,"771":1,"772":1,"794":1}}],["cp",{"2":{"77":2,"212":2,"219":2,"220":2,"224":2,"311":1,"319":2}}],["cd",{"2":{"75":4,"115":2,"211":2,"212":2,"217":2,"220":2,"223":4,"224":2,"269":2,"280":2,"305":2,"318":2,"410":2,"424":2,"593":2,"621":3,"650":3,"676":4}}],["cips",{"2":{"692":1}}],["cip",{"2":{"491":1,"692":1,"737":2}}],["ciruit",{"2":{"212":1}}],["circulation",{"2":{"500":1}}],["circulating",{"2":{"500":4}}],["circulated",{"2":{"34":1}}],["circuits",{"0":{"224":1},"2":{"199":1,"212":2,"213":3,"220":2,"222":1,"223":2,"224":5,"242":3}}],["circuit",{"0":{"200":1},"2":{"178":1,"196":1,"197":1,"200":3,"202":1,"203":4,"205":1,"211":1,"213":1,"219":3,"220":2,"223":13,"224":23,"243":1}}],["circumvention",{"2":{"31":1}}],["circumvent",{"2":{"31":1}}],["city",{"2":{"42":1,"44":1,"45":1,"520":1,"740":1,"758":1}}],["cherry",{"2":{"559":1}}],["cheap",{"2":{"223":1}}],["cheaper",{"2":{"221":1}}],["checking",{"0":{"297":1,"301":1,"470":1},"2":{"330":1,"464":1}}],["checks",{"2":{"127":2,"131":3,"412":1}}],["checkout",{"2":{"75":2,"172":1,"224":2,"593":6,"621":6}}],["check",{"0":{"379":1,"380":1,"570":1},"2":{"37":1,"71":1,"110":1,"127":1,"130":1,"131":1,"135":1,"139":2,"148":1,"151":1,"156":1,"161":1,"169":1,"172":5,"183":2,"203":1,"212":1,"221":1,"224":1,"234":1,"244":2,"261":1,"276":1,"277":1,"287":1,"296":1,"297":1,"358":1,"366":1,"370":1,"392":1,"395":1,"407":1,"413":1,"437":4,"450":1,"460":1,"464":1,"556":3,"570":1,"576":1,"577":1,"578":1,"579":1,"590":1,"591":1,"593":2,"601":1,"602":1,"614":1,"621":2,"693":1,"697":4,"732":1,"748":1,"788":3,"792":2,"797":1}}],["checklist",{"2":{"35":1}}],["chown",{"2":{"668":2}}],["chose",{"2":{"516":1}}],["chosen",{"2":{"32":1,"43":1,"85":1,"658":2}}],["choice",{"2":{"475":1,"480":1,"803":2}}],["choices",{"2":{"414":2}}],["choosing",{"2":{"217":1,"285":1,"712":1}}],["chooses",{"2":{"461":1}}],["choose",{"0":{"71":1,"258":1,"484":1},"2":{"69":1,"71":1,"84":1,"175":1,"212":1,"480":1,"484":1,"492":1,"557":1,"576":1,"584":1,"594":2,"601":1,"609":1,"622":2,"658":1,"711":1}}],["chart",{"2":{"499":1}}],["charge",{"2":{"494":1}}],["charged",{"2":{"430":1}}],["characters",{"2":{"27":1}}],["characteristics",{"2":{"7":1}}],["chatmessageroleuser",{"2":{"414":2}}],["chatcompletion",{"2":{"414":2}}],["chatcompletionmessage",{"2":{"414":2}}],["chatcompletionrequest",{"2":{"414":2}}],["chatgpt",{"0":{"414":1},"2":{"411":2,"412":2,"413":3,"415":1}}],["chainode",{"2":{"742":1,"743":1,"744":1,"745":1}}],["chain=celestia",{"2":{"502":1}}],["chainname",{"2":{"443":12}}],["chainid",{"2":{"211":2,"443":16,"700":8}}],["chainlist",{"2":{"84":1}}],["chain",{"0":{"68":1,"84":1,"85":1,"86":2,"90":1,"91":1,"134":1,"264":1,"315":1,"444":1,"445":1,"605":1,"715":1},"2":{"68":2,"71":2,"77":2,"79":1,"82":1,"83":1,"84":26,"85":12,"86":7,"88":2,"89":3,"90":1,"91":56,"92":2,"105":1,"107":6,"108":1,"110":1,"129":1,"134":3,"135":1,"145":1,"180":1,"181":1,"189":1,"209":1,"210":2,"211":12,"213":1,"219":2,"220":5,"223":1,"224":1,"227":2,"228":2,"230":1,"236":2,"243":1,"262":1,"270":1,"276":1,"290":1,"300":2,"310":2,"313":6,"314":1,"315":1,"316":1,"319":2,"331":1,"333":1,"335":1,"336":1,"367":1,"383":2,"402":1,"403":8,"423":1,"424":2,"443":2,"444":5,"445":4,"447":2,"448":1,"468":1,"490":1,"508":1,"524":1,"538":1,"547":6,"548":12,"550":4,"551":8,"552":4,"554":6,"559":1,"561":12,"576":6,"583":3,"584":1,"585":7,"596":2,"605":3,"618":2,"639":11,"649":1,"661":1,"685":1,"692":2,"693":3,"694":1,"695":4,"696":6,"699":12,"700":22,"703":1,"704":1,"711":4,"715":3,"748":1,"749":1,"760":1,"797":2,"803":2,"808":1}}],["chains=",{"2":{"313":2}}],["chains",{"0":{"698":1},"2":{"27":1,"68":1,"79":1,"80":2,"84":3,"91":1,"95":2,"101":1,"105":1,"139":1,"174":1,"211":1,"237":1,"240":1,"313":8,"315":1,"336":1,"338":1,"403":1,"445":1,"494":1,"498":1,"502":1,"503":1,"520":1,"693":1,"694":1,"695":30,"696":1,"697":2,"698":1,"701":4,"740":1,"758":1}}],["challengemanager",{"2":{"98":1,"99":1}}],["challenge",{"2":{"84":1,"85":1,"109":1,"416":1}}],["challenges",{"2":{"48":1,"302":2}}],["challenging",{"2":{"44":1}}],["changing",{"0":{"607":1},"1":{"608":1,"609":1,"610":1,"611":1,"612":1,"613":1},"2":{"266":1,"646":1}}],["changeable",{"2":{"497":2}}],["changed",{"2":{"77":1,"91":2,"117":2,"120":2,"282":2,"285":2,"319":1,"369":1,"401":1}}],["change",{"0":{"585":1},"2":{"75":1,"77":1,"211":2,"220":2,"310":1,"311":1,"318":1,"319":1,"331":1,"333":1,"336":1,"344":1,"401":1,"426":1,"429":1,"491":1,"497":1,"548":6,"554":2,"557":1,"568":1,"593":1,"609":1,"621":1,"631":1,"639":1,"692":1,"803":2}}],["changes",{"2":{"2":4,"19":1,"43":1,"45":1,"94":2,"432":1,"440":1,"466":2,"516":2,"531":1,"548":4,"657":1,"658":1,"659":1,"685":1,"734":1,"777":1}}],["chan",{"2":{"171":2,"325":2,"326":2}}],["channelid",{"2":{"700":4}}],["channel",{"2":{"40":1,"53":2,"54":1,"89":4,"325":3,"326":3,"526":1,"529":1,"591":1,"695":4,"700":13,"701":4,"753":1,"765":1,"768":1,"781":1}}],["channelside",{"2":{"700":4}}],["channels",{"0":{"701":1},"2":{"14":1,"36":1,"46":2,"48":1,"367":1,"695":2,"698":1,"701":2}}],["chances",{"2":{"44":1}}],["chance",{"2":{"27":1,"649":1}}],["c",{"2":{"31":2,"32":1,"34":2,"594":2,"609":1,"622":2,"650":6,"675":2,"676":8,"689":1}}],["cumulo",{"2":{"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["cumulativegasused",{"2":{"121":2,"286":2}}],["culmination",{"2":{"733":1,"774":1}}],["custody",{"0":{"332":1}}],["custodians",{"2":{"329":1}}],["custodian",{"2":{"24":1}}],["custom=",{"2":{"596":4}}],["custom=robusta",{"2":{"373":2}}],["custom=private",{"2":{"373":2}}],["customtargetblock",{"2":{"242":3}}],["customizable",{"2":{"313":1}}],["customizability",{"0":{"266":1},"2":{"266":1}}],["customizations",{"2":{"266":1}}],["customization",{"2":{"266":1}}],["customizing",{"2":{"84":1}}],["customized",{"2":{"266":1}}],["customize",{"2":{"47":2,"84":1,"270":1}}],["custom",{"0":{"68":1,"216":1,"373":1,"444":1,"445":1,"539":1,"596":1,"613":1,"686":1,"729":1},"1":{"687":1,"730":1},"2":{"47":3,"68":1,"80":1,"82":1,"84":1,"89":1,"214":1,"215":3,"216":3,"242":1,"266":1,"270":1,"315":1,"372":3,"373":9,"424":1,"442":1,"444":1,"445":3,"539":9,"596":3,"608":1,"613":2,"614":2,"618":1,"667":1,"686":9,"729":9}}],["curl",{"0":{"375":1,"391":1},"2":{"375":1,"391":1,"594":2,"622":2,"639":10,"650":6,"675":6,"718":2}}],["currencies",{"2":{"443":2}}],["currency",{"2":{"315":1,"445":1,"508":1}}],["currentitem",{"2":{"306":4}}],["currentid",{"2":{"306":4}}],["current",{"2":{"43":1,"95":1,"224":1,"236":2,"269":2,"302":1,"429":1,"456":1,"544":2,"738":1}}],["currently",{"2":{"23":1,"48":1,"158":1,"175":1,"224":1,"240":1,"258":1,"288":1,"296":1,"333":1,"334":1,"338":1,"357":1,"428":1,"433":1,"502":1,"503":1,"616":1,"693":1,"694":1,"776":1}}],["curated",{"2":{"43":1,"65":1}}],["cups",{"2":{"41":1}}],["ce1e5714",{"2":{"415":2,"416":1}}],["celopstia",{"2":{"321":1}}],["cel",{"0":{"268":1,"273":1,"274":1},"1":{"269":1,"270":1,"271":1,"272":1,"273":1,"275":1,"276":1,"277":1},"2":{"267":2,"268":1,"269":5,"270":7,"271":6,"272":6,"273":2,"276":3,"277":3,"292":1,"348":1,"349":2,"350":2,"367":4,"538":3,"608":1,"609":3,"621":3,"665":1,"685":3,"727":5}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hd",{"2":{"797":1}}],["celesvaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u43cv6hdenter",{"2":{"797":1}}],["celesvaloper",{"2":{"797":2}}],["celes",{"2":{"277":4,"343":1,"401":1,"407":2,"727":6}}],["celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p",{"2":{"797":2}}],["celestiavaloper",{"2":{"797":1}}],["celestiacelestia",{"2":{"726":1}}],["celestiacommunity",{"2":{"696":1}}],["celestiascan",{"2":{"528":1,"767":1}}],["celestiatestnet",{"2":{"445":1}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxcelestia",{"2":{"591":1}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",{"2":{"591":2}}],["celestia1xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx$request",{"2":{"591":1}}],["celestia1adgkqcmzuxvg7x5avx8a8rjwpmxgzex3ztef6j",{"2":{"574":2,"576":2,"578":2}}],["celestia127fpaygehlsgjdknwvlr2mux7h5uvhkxktgkc5",{"2":{"573":2,"574":2,"576":2,"577":2}}],["celestia17adsjkuecgjheugrdrwdqv9uh3qkrfmj9xzawx",{"2":{"549":2}}],["celestia10d07y265gmmuvt4z0w9aw880jnsr700jtgz4v7",{"2":{"548":2}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umard",{"2":{"380":1}}],["celestia10rtd9lhel2cuh6c659l25yncl6atcyt37umardcelestia",{"2":{"380":1}}],["celestia1czpgn3hdh9sodm06d5qk23xzgpq2uyc8ggdqgw",{"2":{"547":2}}],["celestia1hn25k7gkfq0fy5a0vmphs6mjma2de74gsn36ef",{"2":{"407":2}}],["celestia1krkle0n547u0znz3unnln8paft2dq4z3rznv86",{"2":{"393":2}}],["celestia1znk24rh52pgcd9z5x2x42jztjh6raaaphuvrt3",{"2":{"382":2}}],["celestia1",{"2":{"367":1,"526":1,"728":1,"765":1}}],["celestia1wkhyhr7ngf0ayqlpnsnxg4d72hfs5453dvunm9",{"2":{"277":2}}],["celestia1vdjkcetnw35kzvtk8pjhxcm4xan82wtvwcurwwtt0f6n2at9va6k2atjw3cn2umhxe58xmfndejs40vqs9",{"2":{"156":2}}],["celestialightnodeclient",{"2":{"135":6,"137":2,"139":2}}],["celestiaheight",{"2":{"134":4}}],["celestiaorg",{"2":{"87":2,"110":1,"126":2,"149":6,"153":2,"159":4,"165":2,"166":2,"169":2,"172":4,"246":1,"269":2,"276":2,"323":2,"324":6,"339":1,"394":1,"410":2,"411":6,"431":2,"436":6,"437":12,"440":1,"593":2,"621":2,"639":9,"661":14,"667":6,"669":6,"670":6,"808":14}}],["celestia",{"0":{"0":1,"6":1,"18":1,"49":1,"52":1,"58":1,"60":1,"92":1,"104":1,"142":1,"147":1,"153":1,"208":1,"246":1,"257":1,"267":1,"293":1,"294":1,"296":1,"300":1,"329":1,"331":1,"359":1,"365":1,"397":1,"399":1,"407":1,"425":1,"434":1,"435":1,"436":1,"438":1,"442":1,"443":1,"449":1,"451":1,"457":1,"460":1,"469":1,"475":1,"484":1,"491":1,"494":1,"501":1,"530":1,"535":1,"536":1,"563":1,"565":1,"588":1,"592":1,"597":1,"620":1,"638":1,"677":1,"682":1,"690":1,"705":1,"708":1,"709":1,"720":1,"724":1,"769":1,"770":1,"773":1,"783":1,"784":1,"788":1,"790":1,"791":1,"792":1,"793":1,"798":1,"799":1},"1":{"1":1,"2":1,"3":1,"4":1,"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1,"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"29":1,"50":1,"51":1,"52":1,"53":1,"54":1,"55":1,"56":1,"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"258":1,"259":1,"260":1,"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"277":1,"294":1,"295":1,"301":1,"330":1,"331":1,"332":2,"333":2,"334":2,"335":2,"336":2,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"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,"384":1,"385":1,"386":1,"387":1,"388":1,"389":1,"390":1,"391":1,"392":1,"393":1,"400":1,"401":1,"402":1,"403":1,"404":1,"426":1,"427":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1,"443":1,"444":1,"445":1,"461":1,"462":1,"463":1,"464":1,"465":1,"466":1,"470":1,"502":1,"503":1,"531":1,"532":1,"533":1,"534":1,"535":1,"536":2,"537":2,"538":2,"539":2,"540":2,"541":2,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1,"589":1,"590":1,"591":1,"593":1,"594":1,"595":1,"598":1,"599":1,"600":1,"601":1,"602":1,"621":1,"622":1,"623":1,"624":1,"678":1,"679":1,"680":1,"681":1,"682":1,"683":2,"684":2,"685":2,"686":2,"687":2,"688":2,"689":2,"691":1,"692":1,"706":1,"707":1,"708":1,"709":1,"710":2,"711":2,"712":2,"713":2,"714":2,"715":2,"716":2,"717":2,"718":2,"719":2,"721":1,"722":1,"723":1,"724":1,"725":1,"726":1,"727":1,"728":1,"729":1,"730":1,"731":1,"732":1,"770":1,"771":1,"772":1,"774":1,"775":1,"776":1,"777":1,"778":1,"779":1,"780":1,"781":1,"794":1,"795":1,"796":1,"797":1,"798":1,"799":2,"800":2,"801":2,"802":2,"803":1,"804":1,"805":1,"806":1,"807":1,"808":1},"2":{"0":2,"3":3,"5":2,"7":1,"8":1,"11":1,"19":3,"21":3,"22":1,"24":3,"25":2,"27":5,"30":8,"33":3,"40":2,"41":2,"42":1,"43":4,"44":2,"45":2,"46":6,"47":15,"48":5,"49":1,"50":1,"52":2,"54":1,"56":1,"57":2,"59":2,"60":4,"61":2,"62":1,"63":2,"64":1,"65":4,"79":3,"80":1,"83":5,"88":1,"89":12,"94":5,"101":1,"102":4,"105":2,"106":1,"107":12,"108":6,"109":4,"110":3,"111":1,"127":1,"128":1,"129":1,"130":2,"131":6,"133":4,"134":20,"135":11,"136":4,"137":3,"139":4,"142":2,"145":3,"146":4,"148":4,"149":3,"153":2,"156":4,"159":2,"161":1,"162":1,"163":2,"164":1,"165":4,"166":5,"169":8,"172":6,"173":2,"174":2,"176":1,"177":5,"180":1,"181":4,"183":3,"184":2,"187":2,"188":1,"189":1,"192":2,"193":1,"195":1,"196":2,"200":1,"203":1,"208":3,"218":3,"220":1,"225":2,"227":1,"230":5,"233":2,"234":2,"235":1,"236":12,"240":1,"242":2,"245":2,"246":3,"247":1,"255":1,"256":1,"258":1,"261":1,"265":1,"266":1,"267":1,"268":1,"269":5,"270":3,"275":1,"276":11,"277":17,"288":5,"290":1,"291":3,"292":2,"293":2,"294":1,"300":5,"301":2,"302":3,"303":1,"304":1,"305":4,"306":2,"308":2,"310":1,"321":1,"322":1,"323":3,"324":7,"329":1,"330":4,"331":2,"332":1,"333":3,"336":2,"337":2,"338":7,"340":4,"341":1,"343":1,"344":3,"350":1,"352":2,"353":1,"356":1,"359":1,"361":1,"362":1,"364":1,"365":2,"366":5,"367":7,"368":2,"369":5,"370":1,"371":4,"372":2,"373":13,"374":4,"376":2,"379":1,"380":1,"383":2,"384":2,"386":1,"389":4,"391":6,"392":1,"394":1,"399":2,"400":1,"401":7,"402":2,"403":1,"404":1,"405":3,"406":1,"407":5,"410":2,"411":6,"415":1,"416":3,"417":1,"418":6,"419":7,"425":1,"427":1,"428":2,"431":3,"432":2,"434":1,"435":1,"436":7,"437":16,"438":1,"439":2,"440":1,"442":1,"443":22,"444":4,"445":5,"447":1,"449":1,"451":1,"452":2,"457":1,"460":3,"461":3,"462":4,"463":1,"464":2,"466":12,"468":4,"469":3,"470":7,"471":2,"475":1,"479":1,"483":1,"484":1,"488":3,"489":2,"490":2,"491":2,"492":5,"494":3,"495":1,"498":2,"499":6,"500":1,"501":1,"502":2,"503":3,"507":2,"508":1,"509":2,"510":2,"515":1,"516":1,"520":1,"521":11,"523":1,"524":5,"525":2,"526":4,"527":1,"528":1,"530":1,"531":11,"536":2,"537":3,"538":3,"539":3,"540":2,"542":6,"544":8,"545":2,"546":3,"547":2,"548":4,"549":1,"551":2,"554":10,"555":2,"556":3,"557":5,"558":1,"560":1,"561":18,"563":2,"564":1,"565":1,"566":1,"568":3,"569":10,"570":4,"571":1,"573":4,"574":2,"576":6,"577":2,"578":2,"579":4,"580":1,"581":2,"588":2,"589":2,"591":4,"592":1,"593":10,"594":12,"595":1,"596":6,"597":2,"598":2,"599":3,"600":2,"601":4,"602":2,"604":3,"605":2,"606":2,"609":9,"611":2,"612":2,"613":2,"614":2,"615":1,"616":10,"617":15,"618":4,"621":11,"622":12,"623":1,"626":1,"627":3,"628":1,"631":1,"633":6,"634":2,"638":1,"639":19,"641":1,"645":1,"649":1,"650":42,"651":4,"653":2,"655":2,"656":2,"657":1,"658":2,"659":2,"661":15,"665":6,"667":15,"669":22,"670":22,"673":1,"674":1,"676":1,"677":3,"678":1,"682":1,"685":2,"686":3,"687":2,"688":1,"690":1,"691":1,"692":4,"693":2,"694":1,"695":9,"696":1,"703":3,"704":2,"705":2,"708":1,"710":3,"711":2,"712":2,"713":2,"714":1,"715":3,"716":4,"717":1,"718":2,"719":2,"720":2,"721":2,"724":2,"726":6,"727":4,"728":3,"729":3,"730":2,"733":3,"734":1,"737":1,"738":2,"740":1,"742":26,"743":25,"744":23,"745":3,"747":1,"748":11,"750":2,"751":8,"752":6,"754":1,"758":1,"759":1,"760":10,"761":16,"762":12,"763":16,"764":8,"765":6,"766":1,"767":7,"769":3,"774":1,"776":1,"777":1,"782":2,"783":3,"784":4,"785":4,"787":1,"788":16,"790":14,"791":18,"792":16,"793":2,"798":4,"799":1,"800":2,"803":7,"808":15}}],["cele",{"2":{"276":2,"277":2}}],["celenium",{"2":{"91":1,"240":7,"391":1,"413":2,"528":1,"618":2,"751":1,"767":1}}],["centric",{"2":{"235":1}}],["centralized",{"2":{"135":1,"233":2,"235":1,"314":2}}],["center",{"2":{"27":1,"314":4,"443":2}}],["certificate",{"2":{"34":1}}],["certainty",{"2":{"108":1,"109":1}}],["certain",{"0":{"34":1},"2":{"22":1,"30":2,"31":1,"33":1,"183":1,"217":1,"458":1,"548":1}}],["cryptech",{"2":{"760":2,"761":1,"762":1,"763":1,"767":1}}],["cryptography",{"2":{"334":1}}],["crypto",{"2":{"153":2,"172":2,"277":2,"437":2,"573":2,"574":4,"578":2}}],["cross",{"2":{"693":1}}],["crate",{"2":{"694":1}}],["crashed",{"2":{"559":1}}],["craft",{"2":{"321":1}}],["crisis",{"2":{"331":1}}],["critical",{"2":{"45":1,"447":1,"510":1,"555":1,"576":2,"798":1}}],["criteria",{"0":{"24":1,"25":1},"2":{"21":1,"22":1,"23":1,"24":3}}],["crs",{"2":{"223":1}}],["crucial",{"2":{"42":1,"44":1,"84":2,"86":2,"89":1,"734":1}}],["credibility",{"2":{"44":1}}],["credentials",{"2":{"31":1,"312":1,"437":2}}],["creation",{"2":{"413":1,"419":2}}],["creating",{"0":{"137":1,"314":1,"349":1,"543":1,"716":1},"2":{"40":1,"88":1,"91":2,"135":1,"136":2,"137":1,"173":1,"177":1,"313":1,"419":2,"420":2,"421":2,"508":1,"571":2,"617":2,"698":1,"796":1}}],["creator",{"2":{"306":2}}],["creators",{"2":{"79":1}}],["createpayforblob",{"2":{"437":2}}],["createpost",{"2":{"306":10,"309":2,"310":2,"314":6}}],["createchatcompletion",{"2":{"414":2}}],["createclient",{"2":{"313":4}}],["createandsubmitblob",{"2":{"413":6,"415":2}}],["createnamespaceid",{"2":{"413":7,"415":2}}],["createroot",{"2":{"313":2}}],["creates",{"2":{"306":2,"343":1,"413":2}}],["create2",{"2":{"211":5,"219":2}}],["createdblob",{"2":{"413":6,"415":2}}],["created",{"2":{"65":1,"117":1,"150":1,"171":1,"184":1,"276":2,"277":2,"282":1,"305":1,"311":1,"312":1,"367":2,"408":1,"413":3,"560":1,"571":1,"577":1,"586":1,"591":1,"695":1,"700":1,"701":2,"714":1,"716":1,"727":1,"728":1,"788":1,"790":1,"791":1,"792":1}}],["create",{"0":{"116":1,"267":1,"281":1,"565":1,"573":1,"576":1,"581":1,"583":1,"588":1,"590":1,"698":1,"699":1,"712":1,"715":1},"1":{"268":1,"269":1,"270":1,"271":1,"272":1,"273":1,"274":1,"275":1,"276":1,"277":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1,"589":1,"590":1,"591":1,"700":1,"701":1},"2":{"2":3,"34":2,"36":1,"44":2,"46":2,"47":2,"65":2,"88":1,"120":2,"135":1,"137":1,"148":1,"169":1,"172":2,"178":1,"183":1,"187":1,"192":1,"212":2,"219":1,"220":2,"223":1,"242":2,"244":1,"284":2,"285":3,"292":1,"305":1,"306":6,"311":3,"312":2,"313":2,"314":20,"324":2,"325":2,"326":2,"337":1,"348":1,"350":1,"367":1,"370":1,"392":1,"411":5,"412":7,"413":15,"414":1,"415":4,"419":2,"433":1,"436":2,"437":4,"443":1,"538":1,"542":2,"549":1,"554":2,"557":2,"561":4,"565":1,"572":1,"573":1,"576":9,"579":1,"580":1,"583":3,"587":2,"590":1,"593":1,"668":2,"669":1,"685":1,"693":1,"698":1,"699":7,"700":6,"712":1,"715":1,"716":1,"727":1,"737":1,"788":1,"790":1,"791":1,"797":1,"803":3}}],["cake",{"2":{"559":1}}],["cautious",{"2":{"617":1}}],["caution",{"2":{"309":1}}],["cause",{"2":{"454":1,"495":1,"738":1}}],["caused",{"2":{"31":2}}],["cadence",{"2":{"225":2,"226":1,"227":1}}],["car",{"2":{"573":2}}],["carrying",{"2":{"542":2}}],["carry",{"2":{"262":1}}],["carries",{"2":{"146":1}}],["cargo",{"2":{"218":2,"220":2,"223":2,"224":2}}],["care",{"2":{"107":1}}],["carefully",{"2":{"30":1}}],["catching",{"2":{"788":1}}],["catch",{"2":{"54":1,"443":2}}],["categories",{"2":{"499":1}}],["category",{"0":{"340":1},"2":{"3":3,"340":1,"399":1,"499":1,"500":2}}],["cater",{"2":{"48":1}}],["catering",{"0":{"41":1},"2":{"41":1,"44":1}}],["cafes",{"2":{"42":1}}],["capacities",{"2":{"331":1}}],["capacity",{"2":{"265":3,"462":1}}],["capability",{"2":{"331":1,"693":1}}],["capabilities",{"2":{"255":1,"353":1,"617":1}}],["capable",{"2":{"31":1,"79":1}}],["capture",{"2":{"37":1}}],["cast",{"2":{"76":2,"121":3,"213":5,"215":1,"216":1,"286":3,"309":3,"310":2,"318":2}}],["caste",{"2":{"7":1}}],["casual",{"2":{"42":2,"48":1}}],["cases",{"2":{"188":1,"439":1,"466":1}}],["case",{"2":{"34":1,"69":1,"82":1,"109":1,"145":1,"165":1,"171":2,"180":1,"184":1,"192":1,"194":1,"195":1,"197":1,"206":1,"217":3,"220":2,"222":1,"288":1,"338":1,"411":1,"429":3,"459":1,"590":1,"631":1,"698":1,"797":1}}],["cancel",{"2":{"412":4,"413":4,"415":4}}],["canceling",{"2":{"45":1}}],["canonical",{"2":{"108":1,"424":1,"432":1,"692":1}}],["cannot",{"2":{"25":1,"34":1,"46":1,"225":1,"448":2,"454":1,"467":1}}],["can",{"0":{"459":1},"2":{"8":1,"24":2,"29":1,"35":2,"36":1,"40":3,"41":5,"43":3,"44":5,"45":3,"46":5,"47":3,"48":2,"54":1,"60":1,"61":1,"65":3,"69":2,"72":1,"76":1,"77":2,"84":4,"88":1,"90":1,"95":1,"102":3,"107":6,"108":5,"109":4,"110":1,"116":1,"119":1,"121":1,"131":1,"133":1,"134":5,"135":5,"137":3,"145":4,"146":3,"148":3,"150":1,"152":1,"155":1,"158":1,"159":1,"160":2,"162":1,"164":2,"165":4,"166":2,"167":1,"168":1,"169":4,"170":2,"171":2,"172":2,"173":2,"175":3,"177":1,"178":1,"181":4,"183":2,"184":5,"187":3,"188":4,"189":2,"191":2,"192":2,"195":2,"196":2,"197":1,"200":1,"203":1,"206":1,"211":1,"212":3,"214":3,"215":2,"217":3,"218":2,"219":2,"220":3,"223":1,"224":5,"225":1,"226":2,"227":1,"230":1,"234":1,"237":2,"239":1,"240":1,"242":5,"243":1,"244":1,"246":1,"248":1,"250":1,"255":1,"264":4,"265":1,"266":4,"267":1,"268":1,"269":1,"270":1,"271":1,"276":1,"281":1,"286":1,"288":5,"294":2,"297":1,"306":7,"307":1,"308":1,"309":4,"310":5,"311":1,"313":1,"314":1,"315":1,"318":1,"319":2,"323":1,"324":3,"325":1,"326":1,"327":1,"335":1,"338":1,"341":1,"346":1,"347":1,"351":1,"352":1,"354":1,"357":2,"362":2,"366":1,"367":5,"369":2,"370":2,"371":1,"372":2,"374":3,"376":1,"377":1,"386":1,"387":1,"391":1,"392":1,"398":2,"404":1,"407":2,"413":7,"415":2,"416":1,"418":1,"419":3,"420":1,"421":1,"429":1,"431":3,"432":1,"433":1,"437":6,"440":1,"442":1,"443":2,"444":2,"445":1,"447":3,"448":1,"451":3,"454":2,"461":1,"462":2,"464":3,"467":2,"468":1,"469":1,"470":2,"471":1,"477":1,"481":1,"486":1,"488":1,"490":1,"492":2,"495":2,"497":1,"501":1,"508":1,"509":1,"516":3,"521":2,"524":1,"526":1,"528":1,"531":1,"537":1,"538":3,"543":1,"548":10,"549":4,"550":1,"551":2,"552":1,"553":1,"554":2,"555":2,"556":2,"557":4,"558":1,"559":2,"560":1,"563":2,"570":1,"576":1,"579":2,"583":1,"584":1,"585":1,"586":2,"588":1,"590":2,"591":1,"593":1,"594":1,"596":1,"598":1,"602":1,"606":1,"614":1,"617":1,"622":1,"624":1,"628":1,"633":2,"639":4,"641":1,"646":1,"647":1,"649":2,"651":1,"653":1,"654":1,"655":2,"658":1,"659":2,"661":1,"662":1,"663":2,"665":2,"667":1,"668":3,"669":1,"673":1,"674":1,"681":1,"682":1,"685":5,"691":2,"693":2,"696":1,"698":1,"699":1,"703":2,"709":1,"710":1,"714":1,"718":5,"719":1,"726":1,"727":3,"728":1,"732":1,"737":1,"738":3,"739":1,"748":2,"749":1,"750":2,"751":1,"754":1,"762":1,"764":1,"765":1,"767":1,"769":3,"776":1,"779":1,"785":1,"791":1,"797":3,"798":1,"799":1,"800":1,"808":1}}],["caldera",{"2":{"245":1,"246":1,"247":1,"249":1,"250":1,"252":1,"253":1,"285":2,"318":2}}],["calculation",{"0":{"430":1}}],["calculating",{"2":{"131":1,"183":1,"428":1,"431":1}}],["calculates",{"2":{"429":1,"430":1}}],["calculated",{"2":{"377":1,"428":1,"430":3,"489":1,"495":1,"738":1}}],["calculate",{"2":{"165":2,"168":2,"183":1,"430":1,"495":1}}],["callopts",{"2":{"153":2}}],["calling",{"2":{"117":2,"213":1,"215":1,"282":2}}],["called",{"2":{"116":1,"117":1,"134":1,"224":1,"230":1,"268":1,"277":1,"281":1,"282":1,"284":1,"425":1,"431":1,"448":1,"449":1,"470":1,"690":1}}],["calldata",{"2":{"110":1,"127":8,"215":2,"216":2,"288":2,"338":4}}],["calls",{"2":{"54":1,"121":1,"211":1,"243":1,"286":1,"762":1}}],["call",{"0":{"396":1},"2":{"5":2,"43":1,"53":1,"54":1,"76":4,"110":1,"121":4,"213":5,"228":1,"248":1,"286":4,"309":3,"310":3,"314":2,"318":4,"368":1,"381":1,"382":1,"396":1,"413":1}}],["calendar",{"0":{"5":1},"2":{"5":3,"45":1,"54":1,"64":1,"71":1}}],["clean",{"2":{"710":1}}],["clearing",{"0":{"615":1}}],["clears",{"2":{"439":1}}],["clear",{"2":{"2":1,"43":1,"695":4}}],["clock",{"2":{"695":4}}],["cloud",{"2":{"226":1,"557":1,"595":1,"601":1,"606":1,"751":1}}],["closely",{"2":{"247":1}}],["close",{"2":{"153":4,"170":4,"171":2,"172":2,"412":2,"413":2,"415":2,"437":2}}],["closer",{"2":{"131":1}}],["cloned",{"2":{"87":1}}],["clone",{"0":{"87":1},"2":{"1":1,"2":2,"75":3,"87":3,"211":3,"212":2,"217":3,"220":4,"223":2,"224":2,"269":2,"318":3,"419":2,"424":3,"593":3,"621":3}}],["cli",{"0":{"359":1,"368":1,"434":1,"435":1,"542":1},"1":{"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"366":1,"367":1,"368":1,"369":2,"370":2,"371":2,"372":2,"373":2,"374":2,"375":2,"376":2,"377":2,"378":2,"379":2,"380":2,"381":2,"382":2,"383":2,"384":2,"385":2,"386":2,"387":2,"388":2,"389":2,"390":1,"391":1,"392":1,"393":1,"543":1,"544":1,"545":1,"546":1,"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1},"2":{"121":1,"286":1,"310":1,"356":1,"362":1,"368":1,"369":2,"370":3,"371":1,"372":1,"388":1,"542":2,"585":2,"590":1,"593":1,"594":1,"596":1,"613":1,"623":1,"694":2,"703":1,"727":1}}],["clientid",{"2":{"700":8}}],["client=",{"2":{"313":2}}],["clients",{"0":{"699":1,"700":1},"1":{"700":1,"701":1},"2":{"135":1,"336":1,"695":2,"698":2,"699":2,"700":2,"769":1,"785":1}}],["client",{"0":{"132":1,"152":1,"157":1,"159":1,"162":1,"322":1,"417":1,"436":1,"585":1},"1":{"133":1,"134":1,"135":1,"136":1,"137":1,"138":1,"139":1,"140":1,"141":1,"142":1,"143":1,"323":1,"324":1,"325":1,"326":1,"327":1,"328":1,"418":1,"419":1,"420":1,"421":1,"422":1},"2":{"89":1,"109":1,"135":2,"143":1,"145":1,"149":1,"152":3,"153":4,"157":1,"158":1,"159":3,"162":1,"165":20,"166":4,"167":4,"168":6,"169":8,"172":50,"230":2,"236":2,"238":2,"306":2,"312":2,"313":2,"314":8,"322":1,"324":6,"325":4,"326":6,"327":6,"333":1,"411":2,"412":7,"413":16,"414":5,"415":8,"416":1,"417":1,"419":12,"420":10,"421":10,"431":1,"436":7,"585":4,"611":2,"613":2,"649":1,"699":8,"700":8,"762":1,"783":1}}],["clicking",{"2":{"264":1,"444":2}}],["click",{"2":{"68":1,"69":3,"71":4,"72":1,"83":1,"85":1,"86":1,"252":1,"315":1,"444":1,"445":3,"480":1,"557":3}}],["clubs",{"2":{"40":2}}],["clang",{"2":{"675":4}}],["classname=",{"2":{"443":4}}],["classes",{"2":{"16":1}}],["claim",{"0":{"72":1,"550":1},"2":{"30":1,"31":5,"71":1,"72":3,"477":1,"481":1,"486":1,"550":1}}],["claiming",{"2":{"30":1,"31":1}}],["clarifying",{"2":{"9":1}}],["clarity",{"2":{"2":1,"13":1}}],["coin",{"2":{"444":1,"445":1,"450":1}}],["coingeckoid",{"2":{"443":6}}],["coindecimals",{"2":{"443":6}}],["coindenom",{"2":{"443":6}}],["coinminimaldenom",{"2":{"443":6}}],["cointype",{"2":{"443":2}}],["copied",{"2":{"650":1}}],["copies",{"2":{"224":2}}],["copy",{"2":{"89":1,"133":1,"212":3,"311":2,"395":1,"407":1,"454":1,"593":1,"621":1}}],["cosmovisor",{"2":{"692":1}}],["cosmoslist",{"2":{"752":1,"766":1}}],["cosmosnetwork",{"2":{"696":1}}],["cosmossdk",{"2":{"695":4}}],["cosmostation",{"0":{"445":1},"2":{"442":1,"445":2}}],["cosmos",{"2":{"149":7,"266":1,"268":1,"277":2,"300":2,"331":4,"332":2,"333":1,"335":1,"336":1,"425":1,"429":1,"437":4,"444":1,"445":1,"466":1,"471":1,"494":3,"498":1,"502":1,"509":3,"519":1,"531":1,"542":2,"543":1,"548":5,"557":3,"560":1,"562":2,"563":1,"573":2,"574":4,"576":2,"577":2,"578":4,"586":1,"639":3,"693":1,"694":1,"695":9,"696":1,"739":1,"762":1,"763":1,"788":2,"790":2,"791":2}}],["costly",{"2":{"178":1}}],["cost",{"2":{"40":1,"82":1,"192":1,"194":1,"264":1,"337":1,"429":6,"430":5,"468":1}}],["costs",{"2":{"40":2,"41":1,"44":3,"46":1,"179":1,"202":1,"235":1,"429":3,"431":1}}],["coral",{"2":{"573":2}}],["corner",{"2":{"444":1,"445":1}}],["cors",{"2":{"314":2}}],["correspond",{"2":{"217":1}}],["corresponds",{"2":{"203":1,"374":1}}],["corresponding",{"0":{"158":1},"1":{"159":1},"2":{"145":1,"146":1,"148":2,"150":1,"153":2,"158":2,"169":1,"170":2,"172":2,"176":1,"177":3,"181":1,"210":1,"211":2,"212":1,"213":2,"218":1,"219":1,"220":2,"223":1,"242":1,"461":1,"470":2,"566":1,"693":1}}],["correctly",{"2":{"117":2,"196":1,"200":1,"203":1,"211":1,"282":2,"467":1,"676":1,"694":1,"697":1,"788":1,"792":1}}],["correct",{"2":{"108":1,"196":1,"224":1,"270":1,"461":1,"539":1,"540":1,"593":1,"595":2,"606":2,"676":1,"686":1,"687":1,"705":1,"729":1,"730":1,"754":1}}],["correction",{"0":{"13":1}}],["corrective",{"2":{"9":1}}],["cores",{"2":{"532":1,"679":1,"771":1,"772":1,"794":1}}],["core",{"0":{"366":1,"628":1},"2":{"59":1,"89":3,"107":1,"149":3,"262":1,"276":2,"277":2,"295":2,"296":2,"333":1,"344":2,"361":1,"363":1,"366":16,"367":6,"391":2,"407":2,"440":1,"466":4,"499":3,"500":1,"508":1,"521":1,"523":1,"524":7,"531":8,"537":12,"538":6,"539":6,"598":2,"599":2,"600":2,"601":4,"604":2,"609":2,"614":2,"618":2,"628":2,"633":1,"635":1,"661":14,"667":6,"670":6,"685":5,"686":6,"705":1,"722":1,"726":8,"727":6,"729":6,"747":1,"748":5,"754":1,"759":1,"760":1,"771":2,"772":1,"792":2,"800":2,"808":14}}],["cooperation",{"2":{"52":1}}],["coordinating",{"2":{"690":1}}],["coordination",{"2":{"36":1,"516":1,"690":1,"779":1}}],["coordinated",{"2":{"692":1,"734":1}}],["coordinates",{"2":{"461":2}}],["coordinate",{"2":{"36":1,"46":2}}],["coworking",{"2":{"44":1}}],["coding",{"2":{"43":1,"452":2,"466":1,"488":1}}],["codelab",{"2":{"557":2}}],["coded",{"2":{"451":1,"452":1,"531":1,"738":1}}],["codespace",{"2":{"156":2,"437":4,"576":2,"797":2,"803":2}}],["codebase",{"2":{"107":1,"777":1}}],["code",{"0":{"6":1,"52":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1},"2":{"9":2,"10":1,"12":1,"14":1,"15":1,"17":4,"25":1,"52":4,"64":1,"107":2,"108":1,"117":1,"133":1,"156":2,"237":1,"242":1,"246":1,"282":1,"306":2,"308":1,"314":1,"393":2,"405":1,"411":1,"437":18,"443":1,"531":1,"557":1,"576":2,"691":1,"738":1,"797":1,"803":1}}],["covers",{"2":{"59":1,"60":1,"61":1,"62":1,"66":1,"79":1,"237":1,"442":1,"634":1,"784":2}}],["cover",{"2":{"44":1,"46":1,"47":1,"66":1,"82":1,"238":1,"256":1,"290":1,"302":1,"359":1,"369":1,"580":1,"596":1}}],["covering",{"2":{"44":1,"47":2}}],["covered",{"2":{"42":1,"664":1,"783":1,"785":1}}],["covenant",{"2":{"17":4}}],["co",{"2":{"40":2,"44":2,"45":1,"47":1,"56":1,"752":1,"766":1}}],["course",{"2":{"265":1}}],["counterparty",{"2":{"695":2}}],["counterforge",{"2":{"120":1,"284":1,"285":1}}],["countertest",{"2":{"117":4,"282":4}}],["counter",{"2":{"115":6,"116":7,"117":31,"120":3,"280":6,"281":7,"282":31,"284":3,"285":3}}],["count",{"2":{"93":1}}],["country",{"2":{"24":1,"34":1}}],["couldn",{"2":{"46":2,"153":2,"170":2}}],["could",{"2":{"8":1,"133":1,"134":1,"136":1,"139":3,"154":1,"183":1,"184":1,"266":1,"321":1,"333":1,"369":1,"413":1,"415":1,"429":1,"430":1,"452":2,"463":1,"470":1,"492":3,"559":1}}],["columns",{"2":{"131":1,"148":1,"183":1,"461":1}}],["column",{"2":{"108":1,"131":3,"146":1,"148":2,"183":1,"314":4,"383":2,"463":1,"469":3}}],["collide",{"2":{"557":1}}],["collaboration",{"2":{"44":1,"50":1}}],["collaborate",{"2":{"40":1}}],["collectively",{"2":{"462":1}}],["collection",{"2":{"30":2,"49":1,"56":1,"134":1}}],["collect",{"2":{"33":5,"37":1,"542":4,"716":2}}],["collector",{"2":{"24":1,"91":4,"556":2,"601":2,"602":3}}],["color",{"2":{"7":1,"58":1}}],["cohorts",{"2":{"22":1,"23":3,"26":1}}],["cohort",{"0":{"22":1,"28":1},"2":{"22":3,"23":12,"24":1,"25":1,"26":1,"28":5}}],["conjured",{"2":{"557":1}}],["conn",{"2":{"437":6}}],["connects",{"2":{"602":1}}],["connectbutton",{"2":{"314":4}}],["connectors",{"2":{"313":4}}],["connectorsforwallets",{"2":{"313":4}}],["connectivity",{"2":{"470":1}}],["connecting",{"2":{"135":2,"304":1,"366":1,"537":1,"685":1,"748":1,"785":1,"803":1}}],["connectionid",{"2":{"700":8}}],["connectionside",{"2":{"700":4}}],["connections",{"0":{"601":1},"2":{"40":1,"42":1,"43":1,"65":1,"88":1,"556":6,"595":3,"606":3,"654":1,"693":2,"695":2,"698":2,"701":1,"717":2,"791":1}}],["connection",{"0":{"698":1,"700":1},"2":{"31":1,"32":1,"34":3,"44":1,"88":5,"103":1,"107":1,"135":6,"366":1,"437":2,"531":1,"538":1,"601":5,"685":1,"698":1,"700":30,"726":1}}],["connect",{"0":{"366":1,"641":1},"1":{"642":1,"643":1},"2":{"38":1,"42":1,"43":1,"55":1,"83":1,"107":1,"153":2,"170":2,"172":2,"248":1,"250":1,"311":1,"313":3,"314":4,"391":1,"443":2,"470":1,"502":1,"503":1,"519":2,"530":1,"531":1,"613":2,"639":4,"677":1,"739":2,"754":4,"769":1,"800":1,"803":2}}],["connected",{"2":{"24":1,"316":1,"444":1,"445":1,"451":2,"466":1,"641":1,"779":1}}],["congrats",{"2":{"402":1,"404":1}}],["congratulations",{"0":{"92":1,"404":1},"2":{"122":1,"287":1,"571":1,"579":1,"587":1,"667":1,"670":1,"700":1}}],["congested",{"2":{"288":1}}],["congests",{"2":{"265":1}}],["congestion",{"2":{"265":1,"439":1,"470":1}}],["concerned",{"2":{"453":1}}],["concepts",{"0":{"175":1},"1":{"176":1,"177":1,"178":1,"179":1,"180":1,"181":1,"182":1,"183":1,"184":1,"185":1,"186":1}}],["concept",{"2":{"59":1,"491":1}}],["concrete",{"2":{"413":2,"415":2}}],["conclusion",{"0":{"173":1,"206":1,"587":1}}],["concise",{"2":{"2":1}}],["conf",{"2":{"102":2}}],["confidence",{"2":{"109":1,"450":2}}],["configs",{"2":{"102":2,"557":4}}],["configurable",{"2":{"110":1}}],["configurations",{"0":{"640":1},"1":{"641":1,"642":1,"643":1,"644":1,"645":1,"646":1},"2":{"86":1,"370":1,"608":1,"657":1,"695":1,"697":1}}],["configuration",{"0":{"86":1,"87":1,"658":1,"659":1,"695":1,"697":1,"805":1},"2":{"84":4,"85":1,"86":3,"312":1,"313":4,"314":1,"351":3,"401":1,"403":1,"542":4,"556":2,"557":3,"585":3,"590":1,"596":1,"608":2,"614":2,"645":1,"649":2,"656":1,"658":2,"659":1,"695":1,"697":2,"805":1}}],["configuring",{"0":{"312":1,"313":1},"2":{"84":2,"86":1,"665":1,"694":1}}],["configures",{"2":{"543":1}}],["configurechains",{"2":{"313":4}}],["configured",{"2":{"89":1,"316":1,"398":1,"428":1,"696":1}}],["configure",{"0":{"84":1,"654":1,"701":1},"1":{"655":1,"656":1,"657":1},"2":{"83":1,"84":2,"89":1,"91":3,"312":1,"314":2,"315":1,"654":1,"658":1,"659":1,"698":1,"805":1}}],["config",{"0":{"68":1,"613":1,"614":1,"625":1,"627":1,"717":1},"1":{"626":1,"627":1,"628":2,"629":2,"630":2,"631":2,"632":2,"633":2},"2":{"68":1,"77":1,"86":4,"87":1,"88":1,"89":3,"102":5,"319":1,"403":1,"437":2,"542":2,"543":2,"556":1,"557":8,"581":2,"585":2,"590":2,"604":2,"613":1,"614":7,"616":1,"618":3,"627":4,"631":1,"633":1,"639":27,"641":1,"644":1,"649":2,"655":5,"656":4,"658":2,"659":2,"675":4,"694":1,"695":3,"697":5,"701":1,"714":1,"715":1,"716":4,"717":2,"725":1,"805":1}}],["confirming",{"2":{"301":1}}],["confirmed",{"2":{"108":1,"109":1,"437":2,"477":1,"481":1,"486":1,"695":2}}],["confirmations",{"2":{"234":1}}],["confirmation",{"2":{"53":1,"137":1,"591":1,"695":2,"725":1}}],["confirm",{"0":{"477":1,"481":1},"2":{"33":1,"34":2,"36":1,"131":1,"234":1,"301":1,"485":1,"557":1,"576":2,"803":1}}],["conferences",{"2":{"45":1}}],["conference",{"2":{"45":1}}],["conventions",{"2":{"608":1}}],["convenient",{"2":{"36":1}}],["conversion",{"2":{"165":1,"505":1}}],["conversations",{"2":{"8":1,"34":1,"37":1}}],["converts",{"2":{"413":2}}],["converting",{"0":{"163":1},"1":{"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":1}}],["converted",{"2":{"151":1,"156":1,"161":1,"164":1,"167":1,"374":1}}],["convert",{"2":{"121":1,"164":1,"165":1,"166":1,"168":1,"286":1,"413":3,"415":2}}],["conditioned",{"2":{"34":1}}],["conditions",{"2":{"31":1,"200":1,"563":1}}],["conducting",{"2":{"451":1}}],["conducted",{"2":{"34":1}}],["conduct",{"0":{"6":1,"52":1},"1":{"7":1,"8":1,"9":1,"10":1,"11":1,"12":1,"13":1,"14":1,"15":1,"16":1,"17":1},"2":{"8":1,"9":1,"10":1,"12":1,"14":1,"15":1,"17":4,"25":1,"36":1,"52":3,"64":1,"450":1,"769":1}}],["consoleconfirm",{"2":{"803":1}}],["consolecode",{"2":{"797":1,"803":1}}],["console$request",{"2":{"728":1}}],["console$",{"2":{"542":1}}],["console",{"2":{"397":1}}],["consoleblockhash",{"2":{"396":1}}],["consolebasefeepergas",{"2":{"395":1}}],["cons",{"0":{"180":1,"186":1,"190":1,"194":1,"198":1,"202":1,"205":1},"2":{"175":1}}],["consumer",{"2":{"695":4}}],["consume",{"2":{"430":1,"659":1}}],["consumes",{"2":{"430":1}}],["consumed",{"2":{"149":1,"429":2}}],["consuming",{"2":{"107":1}}],["consulted",{"2":{"32":1}}],["consist",{"2":{"135":1,"431":1}}],["consists",{"2":{"134":1,"466":1,"467":1,"469":3,"488":1}}],["consistency",{"2":{"47":1}}],["consistent",{"2":{"47":2}}],["considerable",{"2":{"659":1}}],["considerations",{"0":{"602":1},"2":{"107":2,"598":1,"602":1}}],["consider",{"2":{"40":1,"42":2,"43":1,"46":3,"374":1,"450":1,"646":1,"661":1,"808":1}}],["considered",{"2":{"8":1}}],["consensus",{"0":{"434":1,"437":1,"522":1,"584":1,"634":1,"636":1,"641":1,"651":1,"652":1,"741":1,"742":1,"772":1,"787":1},"1":{"523":1,"524":1,"635":1,"636":1,"637":2,"638":2,"639":2,"640":1,"641":1,"642":2,"643":2,"644":1,"645":1,"646":1,"647":1,"648":1,"649":1,"650":1,"651":1,"652":1,"653":2,"654":2,"655":2,"656":2,"657":2,"658":2,"659":2,"660":1,"661":1,"742":1,"743":1,"744":1,"745":1,"788":1},"2":{"89":2,"107":1,"130":1,"133":1,"135":1,"145":1,"146":1,"236":3,"242":1,"262":1,"265":1,"266":1,"331":1,"336":1,"337":1,"366":2,"383":2,"391":2,"428":1,"437":4,"463":1,"466":1,"467":6,"468":2,"494":1,"509":1,"515":1,"521":2,"523":1,"524":2,"530":1,"531":3,"548":1,"557":1,"571":1,"580":1,"584":2,"594":1,"595":1,"618":4,"634":3,"635":1,"641":1,"648":1,"654":1,"661":31,"664":2,"677":1,"692":2,"726":1,"727":2,"741":1,"747":1,"748":7,"754":2,"759":1,"760":8,"761":2,"763":4,"769":5,"772":1,"784":2,"787":1,"793":1,"795":1,"798":1,"803":1,"806":2,"808":31}}],["consents",{"2":{"34":1}}],["consent",{"2":{"33":1}}],["consequence",{"2":{"13":1,"14":1,"15":1,"16":1,"463":1}}],["consequences",{"2":{"12":1,"14":1,"32":1,"34":1,"448":2}}],["const",{"2":{"313":10,"314":54,"316":2,"443":8}}],["construction",{"2":{"180":1,"183":1,"192":2}}],["constructions",{"2":{"173":1,"187":1,"195":1}}],["constructing",{"2":{"169":2}}],["constructive",{"2":{"8":1}}],["constructed",{"2":{"166":1,"242":1,"451":1}}],["construct",{"2":{"163":1,"165":4,"168":1,"416":1}}],["constructs",{"2":{"146":1,"175":1,"191":1,"413":1}}],["constructor",{"2":{"127":2,"306":2}}],["constants",{"2":{"372":3,"376":1,"401":4,"443":18,"444":1,"605":4,"639":22,"650":6,"676":6,"797":2,"803":2}}],["constantly",{"2":{"290":1,"693":1}}],["constant",{"2":{"89":1,"430":1,"738":2}}],["constitute",{"2":{"30":1,"34":1}}],["context",{"2":{"152":4,"153":10,"157":2,"159":6,"172":8,"324":6,"325":4,"326":6,"327":4,"411":2,"412":4,"413":8,"414":4,"415":4,"436":6,"437":8}}],["contents",{"0":{"340":1},"2":{"416":1}}],["content",{"2":{"2":1,"31":1,"46":2,"65":1,"306":8,"314":17,"391":2,"397":2,"414":4,"548":2,"788":1,"790":1,"791":1,"792":1}}],["containerization",{"2":{"665":1}}],["container",{"0":{"277":1},"2":{"276":9,"277":11,"668":5,"669":4,"670":2}}],["containerstyle",{"2":{"313":4}}],["containers",{"2":{"276":1,"277":1}}],["contained",{"2":{"171":1,"176":1}}],["containing",{"2":{"148":1,"153":4,"154":1,"159":1,"165":1,"167":1,"169":3,"170":2,"172":4,"181":3,"189":1,"192":1,"208":1,"211":1,"219":1,"324":2,"436":2,"469":1,"557":2}}],["contain",{"2":{"86":1,"146":1,"148":1,"154":1,"159":1,"160":1,"165":1,"184":1,"292":1,"425":1,"461":1,"469":1,"492":1,"549":1}}],["contains",{"2":{"86":1,"89":1,"92":1,"116":1,"134":2,"153":4,"156":1,"158":1,"163":4,"169":3,"170":2,"172":2,"281":1,"292":1,"395":1,"426":1,"519":1,"549":1,"616":1,"739":1,"754":1}}],["contacts",{"2":{"45":1,"46":1}}],["contact",{"2":{"41":1,"48":1}}],["contrastingly",{"2":{"463":1}}],["contrast",{"2":{"233":1,"455":1}}],["contracttest",{"2":{"306":2}}],["contractaddress",{"2":{"121":2,"286":2,"314":6,"316":3}}],["contractforge",{"2":{"115":1,"280":1}}],["contractscript",{"2":{"308":2,"309":2,"310":2}}],["contracts",{"0":{"123":1,"126":1,"210":1,"240":1,"260":1,"424":1},"1":{"124":1,"125":1,"126":1,"127":1,"128":1,"129":1,"130":1,"131":1,"211":1,"212":1,"213":1,"214":1,"215":1,"216":1,"217":1,"218":1,"219":1,"220":1,"221":1},"2":{"75":3,"77":3,"79":1,"82":1,"84":4,"85":4,"86":2,"89":2,"91":4,"92":1,"94":3,"95":1,"126":4,"127":6,"129":1,"131":1,"136":2,"137":4,"141":1,"143":2,"163":1,"189":1,"211":5,"212":4,"219":3,"230":1,"238":1,"240":2,"250":1,"260":1,"262":1,"266":1,"306":3,"311":1,"318":3,"319":3,"424":2}}],["contract",{"0":{"75":1,"76":1,"95":1,"112":1,"116":1,"117":1,"118":1,"121":1,"153":1,"217":1,"278":1,"281":1,"282":1,"283":1,"286":1,"306":1},"1":{"76":1,"96":1,"97":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":2,"120":2,"121":1,"122":1,"218":1,"219":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":2,"285":2,"286":1,"287":1},"2":{"31":1,"34":1,"73":1,"74":1,"75":6,"76":5,"77":4,"84":1,"85":2,"88":1,"89":4,"91":4,"98":1,"99":1,"107":2,"109":1,"113":2,"115":1,"116":8,"117":11,"120":5,"121":1,"122":1,"127":6,"129":1,"130":1,"131":7,"133":1,"135":4,"145":3,"146":1,"148":4,"149":1,"150":2,"151":1,"153":12,"156":1,"161":1,"163":6,"169":5,"170":8,"171":6,"172":14,"173":1,"174":1,"178":2,"180":1,"181":1,"183":1,"184":2,"188":1,"192":2,"194":1,"195":2,"196":3,"199":1,"200":1,"203":1,"208":2,"210":1,"211":7,"212":3,"213":8,"214":1,"217":2,"219":9,"220":5,"221":2,"222":1,"223":4,"224":1,"225":3,"226":2,"227":4,"228":2,"234":1,"236":2,"237":5,"238":1,"240":2,"242":5,"243":5,"244":3,"264":1,"278":1,"280":1,"281":8,"282":11,"284":3,"285":4,"286":1,"287":1,"302":1,"304":1,"305":2,"306":15,"307":1,"308":7,"309":13,"310":11,"311":2,"314":16,"316":3,"318":13,"319":4,"340":1,"403":4,"424":1,"456":1,"508":1}}],["controlled",{"2":{"84":1}}],["control",{"2":{"30":1,"31":1,"34":1,"211":1,"486":1,"609":1,"659":1,"689":1}}],["contributor",{"2":{"17":4,"499":1}}],["contributors",{"2":{"7":1,"499":1,"500":1}}],["contributing",{"2":{"8":1}}],["contributiondao",{"2":{"742":1,"743":1,"744":1}}],["contributions",{"2":{"2":1,"9":1,"21":1,"27":3}}],["contribution",{"0":{"2":1},"2":{"2":2,"43":1,"105":1}}],["contributes",{"2":{"8":1,"429":1}}],["contribute",{"2":{"7":1,"24":1,"27":2,"44":1}}],["continuing",{"2":{"803":1}}],["continuousvestingaccount",{"2":{"577":3}}],["continuous",{"2":{"565":1,"576":1}}],["continuously",{"2":{"500":4,"516":1}}],["continues",{"2":{"555":1,"774":1}}],["continue",{"2":{"71":1,"85":1,"288":1,"420":2,"491":1,"492":1,"690":1}}],["continued",{"2":{"14":1,"34":1,"44":1}}],["continually",{"2":{"29":1}}],["comfortable",{"2":{"621":1}}],["comcelestia",{"2":{"524":1}}],["coming",{"2":{"304":1,"790":1,"791":1}}],["comexport",{"2":{"293":1,"667":1}}],["cometbft",{"2":{"233":1,"236":1,"494":1,"738":1}}],["come",{"2":{"133":1,"236":1,"256":1,"411":2,"733":1}}],["comes",{"2":{"107":1}}],["com",{"0":{"47":1},"2":{"45":2,"47":6,"75":2,"82":1,"87":2,"89":2,"145":4,"149":18,"152":2,"153":16,"159":6,"169":2,"170":2,"171":2,"172":24,"211":2,"212":2,"217":2,"220":2,"223":18,"224":2,"269":2,"291":1,"293":1,"300":2,"301":2,"318":2,"323":2,"324":6,"339":1,"344":2,"366":2,"403":2,"407":2,"410":4,"411":8,"424":2,"431":2,"436":6,"437":16,"444":3,"445":1,"503":1,"521":11,"524":1,"527":1,"528":2,"538":2,"562":2,"585":2,"593":2,"600":2,"621":2,"639":10,"661":28,"667":1,"675":2,"695":4,"726":2,"727":2,"742":10,"743":9,"744":8,"752":1,"760":4,"761":7,"762":7,"763":9,"764":8,"767":2,"808":28}}],["combines",{"2":{"405":1}}],["combined",{"0":{"384":1},"2":{"265":1}}],["combine",{"2":{"33":1}}],["computing",{"2":{"336":1}}],["computation",{"2":{"235":1}}],["computed",{"2":{"184":1,"429":1,"461":1}}],["computesquaresizefromshareproof",{"2":{"131":1}}],["computesquaresizefromrowproof",{"2":{"131":1,"183":1}}],["computes",{"2":{"131":2,"429":1,"469":1}}],["compute",{"2":{"108":1,"469":1}}],["comprised",{"2":{"489":1}}],["comprises",{"2":{"169":1}}],["comprising",{"2":{"208":1}}],["comprehensive",{"2":{"0":1}}],["compilation",{"2":{"117":2,"120":2,"282":2,"285":2}}],["compiling",{"2":{"116":4,"117":2,"120":2,"281":4,"282":2,"285":2,"675":1}}],["compiler",{"2":{"116":2,"126":1,"281":2}}],["compile",{"2":{"116":1,"223":6,"281":1}}],["compatmode",{"2":{"694":2}}],["compatibility",{"0":{"94":1,"334":1},"2":{"89":1}}],["compatible",{"0":{"775":1,"778":1,"780":1},"2":{"79":1,"94":1,"245":1,"247":1,"260":1,"303":1,"334":1,"690":1,"692":2,"694":1}}],["compared",{"2":{"235":1}}],["compare",{"2":{"184":1}}],["comparing",{"2":{"178":1}}],["compact",{"0":{"178":1},"2":{"178":4,"179":1,"192":1}}],["companion",{"2":{"56":1}}],["companies",{"2":{"44":3}}],["company",{"2":{"30":5,"31":8,"32":3,"34":8,"44":1}}],["compelling",{"2":{"44":1}}],["component",{"2":{"94":1,"266":1,"314":2,"443":2}}],["components",{"0":{"106":1},"1":{"107":1,"108":1,"109":1,"110":1},"2":{"27":1,"39":1,"106":1,"208":1,"210":1,"238":1,"425":1,"431":2,"443":8,"466":1,"691":1,"733":1}}],["compose",{"2":{"80":1,"89":1,"90":1,"276":2,"277":6,"398":2}}],["composition",{"2":{"28":1}}],["complex",{"2":{"658":1}}],["completing",{"2":{"79":1,"803":1}}],["completion",{"2":{"30":1,"34":3}}],["completes",{"2":{"450":1}}],["completely",{"2":{"373":1}}],["completed",{"2":{"33":1,"267":1,"593":1,"621":1}}],["complete",{"2":{"24":1,"31":3,"32":1,"53":1,"85":1,"91":2,"223":1,"224":1,"267":1,"310":2,"464":1,"497":1}}],["compliant",{"2":{"128":1}}],["compliance",{"2":{"24":1,"34":3}}],["comply",{"2":{"25":1,"33":1}}],["complaints",{"2":{"11":1}}],["comma",{"2":{"220":1,"639":2,"717":2}}],["commands",{"0":{"384":1,"542":1},"1":{"543":1,"544":1,"545":1,"546":1,"547":1,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1},"2":{"269":1,"300":1,"370":2,"410":1,"437":2,"542":2,"548":1,"554":1,"593":1,"594":1,"614":1,"618":1,"621":1,"639":1,"675":2}}],["command",{"0":{"369":1,"561":1},"2":{"76":2,"89":2,"91":1,"115":1,"116":1,"121":2,"126":1,"181":1,"269":1,"272":1,"276":2,"277":5,"280":1,"281":1,"285":1,"286":2,"296":1,"316":1,"318":2,"344":1,"351":1,"366":2,"367":4,"368":1,"369":3,"371":1,"372":1,"373":1,"374":1,"376":3,"380":1,"383":1,"387":1,"388":2,"389":1,"407":2,"408":1,"415":1,"524":1,"526":1,"537":1,"538":1,"542":4,"546":4,"548":4,"549":2,"550":1,"551":2,"552":1,"553":3,"560":1,"576":4,"581":1,"583":2,"585":1,"591":1,"594":1,"598":2,"604":1,"609":1,"614":2,"615":1,"621":1,"622":1,"628":1,"650":1,"655":1,"659":1,"667":1,"669":2,"670":2,"675":2,"684":1,"685":1,"699":2,"700":1,"710":1,"711":1,"712":2,"713":1,"714":1,"715":2,"716":2,"718":2,"719":1,"725":1,"727":3,"728":1,"765":1,"797":1}}],["commission",{"2":{"24":1,"34":2,"485":1,"550":2,"554":6,"803":6}}],["commitment",{"0":{"148":1,"176":1,"177":1,"178":1,"179":1,"180":1,"225":1},"1":{"177":1,"178":1,"179":1,"180":1,"226":1,"227":1,"228":1},"2":{"148":5,"151":1,"163":2,"169":3,"171":1,"175":1,"176":3,"177":9,"178":2,"179":2,"182":2,"184":3,"185":1,"192":6,"193":1,"195":1,"196":2,"197":1,"200":5,"203":7,"208":3,"228":1,"237":1,"242":1,"296":1,"324":4,"338":5,"374":5,"376":10,"377":3,"391":2,"413":4,"415":2,"419":4,"436":4,"461":1,"463":1,"469":6,"488":2,"612":2}}],["commitments",{"0":{"171":1,"192":1,"193":1,"194":1,"199":1,"201":1,"202":1},"1":{"193":1,"194":1,"200":1,"201":1,"202":1},"2":{"109":1,"134":6,"136":1,"137":1,"171":1,"178":1,"189":1,"192":2,"195":1,"196":1,"199":1,"230":1,"296":2,"461":1,"470":1}}],["committing",{"0":{"136":1},"2":{"153":2,"170":2,"172":2}}],["committees",{"0":{"232":1},"1":{"233":1,"234":1,"235":1},"2":{"233":1}}],["committee",{"2":{"83":1}}],["committedto",{"2":{"172":4}}],["committed",{"0":{"153":1,"661":1,"808":1},"2":{"47":1,"128":1,"131":9,"134":1,"139":1,"146":2,"148":4,"150":2,"153":8,"163":8,"169":6,"172":4,"173":1,"177":1,"180":1,"181":1,"183":1,"184":2,"225":1,"242":1,"437":4,"469":1,"661":2,"808":2}}],["commitforge",{"2":{"126":1}}],["commits",{"2":{"9":1,"131":1,"136":1,"163":2,"169":2,"187":1,"203":1}}],["commit",{"2":{"2":3,"94":1,"126":1,"131":1,"136":1,"148":1,"192":1,"224":2,"383":4,"621":1}}],["commonly",{"2":{"448":1,"557":1}}],["common",{"2":{"17":1,"60":1,"153":2,"172":2,"322":1,"417":1,"467":2,"601":1,"721":1}}],["communities",{"2":{"65":1}}],["community",{"0":{"5":1,"48":1,"52":1,"64":1,"498":1,"521":1,"549":1,"742":1,"743":1,"744":1,"745":1,"747":1,"748":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1},"2":{"2":1,"3":2,"4":1,"5":5,"7":2,"8":2,"9":2,"10":3,"11":2,"12":2,"13":3,"14":2,"15":3,"16":3,"17":1,"25":1,"27":1,"36":1,"38":1,"39":1,"40":4,"43":2,"45":2,"47":1,"50":1,"52":3,"53":1,"55":1,"57":1,"63":1,"64":3,"65":1,"366":1,"432":1,"494":1,"498":2,"510":2,"521":1,"524":1,"548":1,"549":11,"733":1,"734":1,"740":1,"742":1,"748":1,"758":1,"774":1,"779":1}}],["communicating",{"2":{"557":2}}],["communications",{"0":{"45":1}}],["communication",{"2":{"15":1,"34":1,"45":1,"55":1,"306":2,"595":1,"601":1,"606":1,"631":1,"693":1,"762":1,"791":1}}],["communicate",{"2":{"9":1,"42":1,"89":1,"408":1,"798":1}}],["comments",{"2":{"8":1,"9":1}}],["fsudo",{"2":{"788":1,"790":1,"791":1,"792":1}}],["fssl",{"2":{"675":2}}],["f5nodes",{"2":{"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["fc",{"2":{"430":2}}],["fn",{"2":{"419":2,"420":2,"421":2}}],["fmt",{"2":{"139":4,"152":2,"153":4,"170":2,"171":2,"172":2,"324":2,"411":2,"413":6,"414":4,"436":2,"437":8}}],["f",{"2":{"139":22,"398":1,"788":1,"790":1,"791":1,"792":1}}],["floor",{"2":{"505":1}}],["flow",{"2":{"23":1,"43":1}}],["flipping",{"2":{"450":1}}],["flat",{"2":{"428":3,"431":1,"489":1}}],["flag",{"2":{"107":1,"223":1,"295":1,"323":1,"366":1,"369":2,"370":1,"371":1,"372":1,"376":1,"377":3,"383":2,"391":2,"412":2,"413":2,"415":2,"418":1,"537":1,"565":1,"576":2,"581":1,"585":1,"593":1,"595":1,"598":1,"601":3,"605":1,"606":1,"608":1,"609":1,"618":1,"628":1,"651":2,"669":1,"803":2}}],["flags",{"0":{"351":1,"370":1,"598":1},"1":{"371":1,"372":1,"373":1,"599":1,"600":1,"601":1},"2":{"89":1,"102":2,"270":2,"351":1,"369":4,"370":2,"434":2,"546":4,"583":2,"596":2,"598":2,"608":2,"667":1}}],["flexdirection",{"2":{"314":4}}],["flex",{"2":{"314":6}}],["flexibility",{"0":{"235":1},"2":{"206":1,"235":1,"266":1,"467":1}}],["flexible",{"2":{"41":1}}],["fun",{"2":{"405":1}}],["func2",{"2":{"661":2,"808":2}}],["func",{"2":{"137":2,"139":3,"145":2,"152":2,"153":6,"159":2,"165":7,"166":1,"167":1,"168":1,"169":1,"172":22,"324":2,"325":1,"326":2,"327":2,"411":2,"412":2,"413":5,"414":2,"415":1,"436":2,"437":2}}],["functionalities",{"2":{"754":1}}],["functionality",{"2":{"36":1,"94":1,"135":2,"294":1,"306":1,"333":1,"357":1}}],["functional",{"2":{"734":1}}],["functionids",{"2":{"219":1}}],["functionid",{"2":{"213":3,"215":2,"216":1,"219":1,"220":2,"227":1}}],["functionverifier",{"2":{"212":5,"224":4}}],["function",{"0":{"212":1,"213":1,"224":1,"412":1},"1":{"214":1,"215":1,"216":1},"2":{"110":1,"116":6,"117":13,"127":4,"131":5,"172":2,"211":3,"212":10,"213":16,"214":3,"215":4,"216":2,"219":8,"220":12,"223":1,"224":4,"227":2,"244":2,"281":6,"282":13,"306":24,"308":4,"314":10,"411":2,"412":1,"413":2,"414":1,"415":1,"429":2,"430":7,"431":3,"437":8,"443":5,"464":1,"467":1}}],["functions",{"0":{"413":1},"2":{"108":1,"116":1,"117":1,"131":4,"211":2,"262":3,"264":1,"281":1,"282":1,"306":1,"412":1,"413":1,"467":5,"563":1}}],["fund",{"0":{"582":1,"591":1},"2":{"76":1,"91":1,"119":1,"318":1,"367":2,"401":1,"407":1,"498":1,"538":1,"549":2,"582":1,"591":1,"685":1,"727":1}}],["funded",{"0":{"119":1},"2":{"74":1,"78":1,"80":1,"119":1,"285":1,"318":1,"320":1,"362":1,"367":1,"393":1,"401":2,"403":1,"407":2,"696":1}}],["funds",{"2":{"46":1,"69":2,"71":1,"82":1,"288":1,"291":2,"292":1,"296":1,"367":1,"448":1,"498":1,"548":1,"549":3,"561":4,"563":1,"728":1}}],["funding",{"2":{"44":1,"91":3,"290":1,"407":1}}],["fullfill",{"2":{"211":2}}],["fullnodes",{"2":{"139":1}}],["fullnode",{"2":{"135":6,"139":4}}],["full",{"0":{"100":1,"102":1,"103":1,"138":1,"153":1,"302":1,"611":1,"612":1,"677":1,"678":1,"680":1,"683":1,"684":1,"685":1,"686":1,"688":1,"689":1,"757":1,"764":1,"790":1},"1":{"101":1,"102":1,"103":1,"139":1,"140":1,"141":1,"142":1,"143":1,"303":1,"304":1,"305":1,"306":1,"307":1,"308":1,"309":1,"310":1,"311":1,"312":1,"313":1,"314":1,"315":1,"316":1,"317":1,"678":1,"679":1,"680":1,"681":2,"682":1,"683":1,"684":2,"685":2,"686":1,"687":2,"688":1,"689":1,"758":1,"759":1,"760":1},"2":{"34":1,"55":1,"88":1,"89":3,"92":2,"102":1,"103":1,"107":1,"108":1,"135":4,"139":1,"145":2,"188":1,"192":1,"211":1,"268":1,"270":2,"271":2,"272":2,"302":1,"328":1,"336":1,"365":1,"422":1,"451":3,"452":4,"461":3,"470":1,"521":2,"524":1,"542":2,"581":1,"583":1,"608":1,"609":4,"611":1,"612":2,"615":1,"627":2,"670":1,"677":1,"678":2,"679":1,"684":6,"685":7,"686":9,"687":3,"688":2,"689":1,"737":1,"742":1,"743":1,"744":1,"746":1,"748":2,"754":1,"760":4,"761":1,"762":1,"763":3,"764":7,"769":2,"771":1,"783":1,"790":17}}],["fully",{"2":{"24":1,"28":1,"80":1,"401":1,"491":2,"500":1,"750":1}}],["further",{"2":{"34":2,"270":1}}],["furthermore",{"2":{"27":1,"53":1,"464":1,"467":1}}],["future",{"2":{"22":1,"37":1,"38":2,"42":1,"43":1,"48":1,"94":1,"266":1,"333":1,"357":1,"362":1,"492":1,"499":1,"500":1,"602":1,"606":1,"651":1,"691":1,"791":1,"803":1}}],["feasible",{"2":{"462":1}}],["feature",{"0":{"342":1},"1":{"343":1,"344":1,"345":1,"346":1,"347":1,"348":1,"349":1,"350":1,"351":1},"2":{"84":1,"106":1,"266":1,"288":1}}],["features",{"2":{"65":1,"265":1,"353":1,"355":1,"416":1,"460":2,"621":1,"690":1,"691":6,"705":1}}],["federation",{"2":{"557":2}}],["federal",{"2":{"34":1}}],["fed",{"2":{"223":1}}],["fek44boeswewectexicgqiabelorfjcagrqagqhaqqeaqogl2nlbgvzdglhlmjsb2iudjeutxnnugf5rm9yqmxvynmsegovy2vszxn0awexdjhlc2n1n2z1owx2odc5a3p1nxvlz3vldxj0ctvzdzzoc20zbmushqaaaaaaaaaaaaaaaaaaaaaaaaaaaawey1oiszk=",{"2":{"156":2}}],["fetchposts",{"2":{"306":8,"309":2,"310":2,"314":8}}],["fetchpost",{"2":{"306":4}}],["fetches",{"2":{"306":4,"326":2,"327":2,"413":1}}],["fetchedblob",{"2":{"413":2,"415":4}}],["fetched",{"2":{"108":1,"413":3,"415":3,"608":1}}],["fetcher",{"2":{"107":1}}],["fetch",{"2":{"107":1,"211":1,"314":4,"324":2,"325":1,"326":3,"327":5,"405":1,"413":5,"415":4,"419":2,"420":3,"421":3,"436":2}}],["fetching",{"0":{"327":1,"421":1},"2":{"88":1,"326":2,"420":2,"421":2}}],["few",{"2":{"77":1,"139":1,"174":1,"180":1,"258":1,"264":2,"265":1,"319":1,"338":1,"407":1,"583":1,"649":1,"753":1,"768":1,"781":1}}],["fellow",{"2":{"40":1,"50":1,"55":1}}],["feecurrencies",{"2":{"443":2}}],["fee=gas",{"2":{"430":1}}],["feegrant",{"0":{"289":1,"294":1,"296":1,"298":1},"1":{"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":2,"300":1,"301":1},"2":{"290":1,"292":1,"293":2,"294":1,"296":1,"298":1,"300":4,"301":1,"331":1,"429":1}}],["feel",{"2":{"210":1,"772":1}}],["fee",{"0":{"293":1,"300":1,"427":1,"430":1,"489":1},"1":{"294":1,"295":1,"301":1,"428":1,"429":1,"430":1,"431":1,"432":1},"2":{"84":1,"85":1,"91":20,"211":4,"292":1,"293":1,"295":3,"298":2,"300":1,"301":1,"351":1,"374":5,"386":6,"428":5,"430":3,"489":2,"494":1,"507":1,"576":2}}],["fees=21000utia",{"2":{"797":1,"803":2}}],["fees=21000utiacelestia",{"2":{"797":1}}],["fees",{"0":{"428":1},"1":{"429":1,"430":1,"431":1},"2":{"31":1,"290":1,"292":1,"297":2,"300":3,"301":2,"377":1,"428":3,"432":1,"439":1,"441":1,"489":3,"561":4,"576":6,"583":2,"695":4}}],["feedback",{"0":{"4":1,"29":1},"2":{"4":1,"8":1,"29":1,"36":1,"37":1,"38":2,"733":1,"772":1}}],["february",{"2":{"21":1,"28":1}}],["fatalf",{"2":{"412":2,"413":6,"415":8}}],["fatal",{"0":{"616":1},"2":{"412":2,"413":4,"415":4,"616":2}}],["faster",{"2":{"630":1}}],["fastest",{"2":{"594":1,"622":1}}],["fast",{"2":{"335":1,"337":1}}],["favourite",{"2":{"212":1}}],["favor",{"2":{"161":1,"162":1}}],["falsediscard",{"2":{"659":1}}],["false",{"2":{"153":2,"219":4,"470":3,"576":2,"595":1,"601":2,"606":1,"628":1,"630":1,"631":1,"659":3,"695":24,"788":1}}],["falls",{"2":{"694":1}}],["fallback",{"0":{"110":1,"288":1},"2":{"106":1,"110":6,"288":5}}],["fall",{"2":{"88":1,"110":1,"139":1,"288":1}}],["faults",{"2":{"135":1}}],["faulty",{"2":{"109":1,"189":1}}],["faucets",{"2":{"696":1}}],["faucet",{"0":{"252":1,"525":1,"765":1},"1":{"526":1,"527":1},"2":{"75":1,"80":1,"82":1,"119":1,"252":2,"279":1,"318":1,"367":2,"393":1,"407":1,"525":1,"526":3,"527":2,"582":1,"591":2,"765":4}}],["familiarity",{"2":{"80":1,"101":1}}],["family",{"2":{"45":2}}],["face",{"2":{"302":1}}],["fact",{"2":{"108":1,"146":1,"159":1,"178":1,"184":1}}],["factories",{"2":{"89":1}}],["factory",{"2":{"85":1}}],["factors",{"2":{"34":1,"42":1,"738":2}}],["facilitating",{"2":{"85":1}}],["facilitated",{"2":{"65":1}}],["facilitate",{"2":{"37":1,"306":2,"466":1}}],["failure",{"2":{"139":4,"661":2,"788":2,"790":2,"791":2,"792":2,"808":2}}],["failed",{"2":{"117":2,"282":2,"412":2,"413":10,"415":8,"419":8,"420":4,"421":6,"443":2,"611":2,"613":2}}],["fails",{"2":{"110":1,"470":1,"613":1}}],["fail",{"2":{"31":1,"220":1,"371":1}}],["failing",{"2":{"25":1}}],["fairly",{"2":{"11":1,"331":1}}],["fair",{"2":{"9":1,"19":1,"516":1}}],["faq",{"0":{"207":1,"446":1,"660":1,"807":1},"1":{"208":1,"447":1,"448":1,"449":1,"450":1,"451":1,"452":1,"453":1,"454":1,"455":1,"456":1,"457":1,"458":1,"459":1,"661":1,"808":1},"2":{"17":2}}],["frequently",{"2":{"777":1}}],["frequency",{"2":{"220":1,"224":3}}],["fresh",{"2":{"653":1}}],["freeze",{"2":{"219":1}}],["free",{"2":{"7":1,"31":1,"40":1,"210":1,"492":2,"521":1,"577":2,"740":1,"742":1,"758":1,"772":1}}],["frameworks",{"2":{"266":2,"311":1}}],["framework",{"0":{"258":1},"2":{"311":2,"494":1,"763":1}}],["frame",{"2":{"84":1}}],["fraudulent",{"2":{"139":1,"649":1}}],["fraud",{"0":{"131":1,"463":1},"2":{"33":1,"108":2,"131":1,"136":1,"139":3,"172":5,"173":1,"187":1,"188":4,"189":1,"192":2,"195":1,"265":2,"451":1,"452":3,"463":1,"467":1,"678":2}}],["frontendcd",{"2":{"77":1,"319":1}}],["frontend",{"0":{"77":1,"78":1,"311":1,"319":1,"320":1},"1":{"312":1},"2":{"75":3,"76":1,"77":5,"304":1,"309":1,"310":1,"311":10,"312":1,"318":4,"319":5}}],["from=$validator",{"2":{"797":2,"803":2}}],["from=",{"2":{"550":2}}],["from",{"0":{"70":1,"71":1,"221":1,"227":1,"299":1,"432":1,"593":1,"618":1,"621":1},"1":{"71":1,"72":1,"619":1},"2":{"2":1,"4":1,"8":1,"13":1,"15":1,"16":1,"17":1,"27":2,"30":1,"31":5,"33":4,"34":9,"36":1,"37":1,"38":1,"43":1,"46":1,"47":1,"49":1,"50":1,"52":1,"54":1,"65":3,"66":1,"68":1,"69":1,"75":3,"76":2,"77":1,"81":1,"84":2,"85":1,"87":1,"88":2,"89":1,"90":1,"91":8,"95":1,"107":3,"108":1,"109":1,"116":1,"120":1,"121":1,"126":1,"130":1,"131":4,"135":8,"137":1,"139":8,"145":1,"155":1,"164":2,"165":2,"166":2,"169":2,"172":4,"181":1,"182":1,"183":1,"188":1,"195":1,"208":1,"211":2,"212":1,"213":1,"217":3,"220":2,"221":1,"223":1,"225":1,"227":4,"230":1,"234":1,"236":1,"237":1,"245":1,"264":2,"265":1,"266":2,"271":1,"272":1,"276":1,"279":2,"281":1,"284":1,"285":1,"286":1,"299":1,"301":1,"302":1,"304":1,"308":2,"310":3,"313":14,"314":23,"316":1,"318":5,"319":1,"324":2,"327":2,"333":1,"338":6,"359":1,"367":1,"370":3,"372":1,"373":1,"374":1,"376":3,"381":1,"383":1,"393":1,"395":1,"396":2,"405":1,"407":1,"411":2,"412":4,"413":7,"415":5,"416":1,"419":2,"421":4,"424":1,"428":3,"432":2,"436":2,"437":6,"439":1,"443":4,"448":1,"451":1,"452":1,"454":1,"455":1,"456":2,"464":1,"467":1,"468":2,"470":2,"484":1,"491":2,"492":2,"494":1,"500":5,"515":1,"516":1,"523":2,"524":1,"526":1,"531":2,"537":1,"538":1,"545":1,"547":5,"548":7,"549":2,"551":4,"552":2,"557":7,"560":2,"561":14,"563":2,"569":1,"575":3,"576":8,"578":1,"581":2,"583":2,"584":1,"585":1,"592":1,"608":1,"614":1,"616":1,"618":3,"624":1,"631":1,"639":1,"647":2,"649":2,"650":3,"651":1,"654":1,"655":1,"661":1,"667":1,"675":2,"685":2,"696":1,"704":2,"726":1,"728":1,"747":2,"748":1,"759":2,"760":3,"765":1,"777":1,"791":2,"792":1,"803":3,"808":1}}],["friends",{"2":{"44":1,"45":2,"709":1}}],["friendly",{"2":{"41":2}}],["firewall",{"2":{"595":2,"606":2}}],["first",{"2":{"23":4,"43":1,"50":1,"57":1,"59":1,"73":1,"84":1,"89":2,"91":1,"105":1,"115":1,"120":2,"134":3,"135":1,"136":1,"137":1,"139":1,"153":2,"165":2,"166":1,"169":2,"170":2,"172":6,"174":1,"181":1,"192":1,"213":1,"224":2,"230":2,"237":1,"244":1,"245":1,"267":1,"269":1,"280":1,"284":2,"285":2,"295":1,"302":1,"306":8,"309":2,"310":4,"312":1,"314":2,"316":3,"318":2,"327":2,"330":1,"338":2,"340":1,"386":1,"396":1,"407":1,"413":5,"414":1,"421":2,"429":2,"432":1,"499":1,"505":1,"507":1,"519":1,"548":3,"549":1,"554":1,"557":1,"566":1,"573":1,"580":1,"590":1,"609":1,"623":1,"668":1,"675":1,"691":1,"692":1,"738":1,"739":1,"754":1,"795":1}}],["figment",{"2":{"562":1}}],["figure",{"2":{"464":1,"466":1,"469":2,"676":1}}],["figures",{"2":{"65":1}}],["five",{"2":{"499":1}}],["fit",{"0":{"456":1}}],["fits",{"2":{"265":1}}],["fields",{"2":{"649":1}}],["field",{"2":{"156":1,"164":2,"165":1,"169":1,"218":1,"413":1,"631":1,"656":2}}],["fide",{"2":{"34":1}}],["fine",{"2":{"470":1}}],["finished",{"2":{"116":2,"117":2,"281":2,"282":2,"792":1}}],["finish",{"0":{"91":1},"2":{"415":1}}],["finger",{"2":{"41":1}}],["finality",{"2":{"262":1}}],["finalizecommit",{"2":{"661":2,"808":2}}],["finalize",{"2":{"36":1,"480":1}}],["finally",{"2":{"103":1,"109":1,"169":1,"180":1,"184":1,"429":1,"557":1}}],["final",{"2":{"36":1,"223":1,"415":1,"467":3,"559":1,"561":2,"716":2}}],["financial",{"2":{"34":1,"44":1}}],["finding",{"2":{"5":1,"40":1,"44":1,"46":1,"48":2}}],["find",{"0":{"395":1,"397":1},"2":{"0":1,"4":1,"43":1,"44":1,"47":1,"60":1,"61":1,"64":1,"75":1,"88":2,"91":1,"96":1,"97":1,"107":3,"131":1,"136":2,"153":2,"170":2,"179":1,"224":2,"237":1,"242":1,"243":1,"318":1,"339":1,"357":1,"362":1,"366":1,"367":1,"521":1,"524":1,"538":1,"559":1,"569":1,"583":1,"606":1,"617":1,"627":1,"630":1,"673":1,"685":1,"714":1,"715":1,"727":1,"748":2,"750":1,"764":1,"785":1,"800":1}}],["fix",{"2":{"432":1,"617":1,"661":1,"808":1}}],["fixed",{"2":{"429":2,"430":2}}],["fixes",{"2":{"24":1}}],["fixing",{"2":{"2":1}}],["fill",{"2":{"219":2,"557":1}}],["filled",{"2":{"23":1}}],["filter",{"0":{"704":1},"2":{"325":2,"326":2,"420":2,"695":8,"701":4,"704":1}}],["filteropts",{"2":{"153":2,"170":2}}],["filterdatacommitmentstored",{"2":{"153":2,"170":2}}],["file=",{"2":{"557":2}}],["filecoin",{"2":{"459":1}}],["file",{"0":{"299":1,"716":1,"717":1},"2":{"84":3,"86":3,"92":1,"102":3,"116":1,"117":2,"211":1,"219":2,"220":2,"224":1,"227":1,"281":1,"282":2,"299":3,"306":1,"311":1,"312":1,"398":1,"411":2,"424":1,"437":2,"542":6,"545":2,"548":5,"549":4,"554":1,"556":1,"557":1,"558":1,"585":2,"590":1,"593":1,"594":1,"614":1,"616":2,"617":9,"622":1,"633":1,"639":5,"655":1,"658":1,"659":1,"696":9,"714":1,"715":2,"716":4,"717":2,"788":2,"790":2,"791":2,"792":1,"805":1}}],["filesystem",{"2":{"673":1}}],["fileserror",{"2":{"617":1}}],["files",{"0":{"86":1,"87":1,"617":1,"697":1},"2":{"3":1,"58":1,"85":1,"86":3,"87":1,"116":2,"117":2,"120":2,"281":2,"282":2,"285":2,"304":1,"540":2,"542":2,"617":2,"675":1,"687":2,"716":4,"730":2}}],["fontsize",{"2":{"314":4}}],["four",{"2":{"177":1,"262":1,"433":1,"467":3,"548":1}}],["found",{"2":{"84":2,"95":1,"102":1,"108":1,"110":1,"131":1,"135":1,"145":1,"146":1,"165":1,"166":1,"168":1,"169":1,"177":1,"178":1,"181":1,"184":2,"191":2,"217":1,"219":1,"226":1,"239":1,"242":1,"246":1,"324":1,"325":2,"326":2,"371":1,"391":1,"393":2,"405":1,"407":2,"419":1,"420":2,"431":2,"495":1,"524":1,"548":2,"649":3,"703":1,"737":1}}],["foundry",{"2":{"75":1,"114":1,"115":1,"121":1,"125":1,"211":2,"213":1,"217":2,"279":1,"280":1,"286":1,"302":1,"304":1,"305":2,"306":1,"311":2,"318":1}}],["foundation",{"0":{"18":1,"20":1},"1":{"19":1,"20":1,"21":2,"22":2,"23":2,"24":2,"25":2,"26":1,"27":1,"28":1,"29":1},"2":{"19":2,"21":1,"22":2,"24":2,"25":1,"27":2,"28":1,"499":1}}],["folders",{"2":{"569":4,"653":1,"695":1}}],["folder",{"2":{"92":1,"108":1,"115":1,"223":2,"224":4,"280":1,"593":1}}],["followed",{"2":{"136":1,"210":1,"221":1}}],["follows",{"2":{"24":1,"135":1,"163":1,"165":2,"166":2,"167":1,"168":1,"171":1,"172":1,"178":1,"184":1,"200":1,"203":1,"369":1,"557":1,"608":1,"703":1,"738":1}}],["follow",{"2":{"12":1,"35":2,"38":1,"48":1,"88":1,"102":1,"208":1,"222":1,"226":1,"227":1,"310":1,"424":2,"467":1,"534":1,"536":1,"541":1,"558":1,"594":1,"622":1,"637":1,"638":1,"651":1,"664":1,"665":1,"675":2,"681":1,"682":1,"688":1,"694":1,"696":1,"705":1,"706":1,"709":1,"731":1,"754":1,"795":1,"796":1,"799":1,"802":1,"803":1,"805":1}}],["following",{"2":{"1":1,"27":1,"34":3,"41":1,"42":1,"52":1,"53":1,"54":1,"83":1,"91":2,"95":1,"107":2,"115":1,"116":2,"117":1,"125":1,"134":1,"145":1,"149":1,"163":1,"165":2,"168":1,"177":1,"181":1,"187":1,"188":1,"196":1,"200":1,"208":1,"210":1,"211":2,"220":3,"223":1,"225":1,"237":2,"240":1,"248":1,"267":1,"269":1,"270":1,"272":1,"277":1,"280":1,"281":2,"282":1,"296":1,"300":1,"306":2,"308":1,"310":1,"311":1,"312":1,"314":1,"315":1,"316":1,"323":1,"344":1,"363":1,"367":4,"370":1,"371":1,"372":1,"373":1,"374":3,"376":3,"387":1,"388":2,"406":1,"407":1,"408":1,"410":1,"415":1,"418":1,"438":1,"443":1,"444":1,"445":1,"464":1,"466":1,"467":1,"469":1,"476":1,"477":1,"480":2,"481":1,"502":1,"503":1,"526":1,"531":1,"532":1,"533":1,"537":1,"538":2,"548":1,"549":1,"550":1,"551":1,"552":1,"553":1,"554":1,"557":1,"563":1,"576":1,"595":1,"597":1,"598":1,"602":1,"606":1,"609":1,"614":2,"621":1,"627":1,"635":1,"636":1,"639":1,"641":1,"650":1,"670":1,"679":1,"680":1,"684":1,"685":2,"693":1,"695":1,"697":1,"699":1,"700":1,"705":1,"707":1,"708":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":3,"717":2,"718":3,"719":1,"721":1,"722":1,"725":1,"727":3,"728":1,"738":1,"752":1,"765":1,"766":1,"794":1,"795":1,"800":1,"801":1,"803":1}}],["foster",{"2":{"52":1,"65":1}}],["fosters",{"2":{"43":1}}],["fostering",{"2":{"19":1,"41":1,"49":1}}],["focus",{"2":{"508":1,"515":1,"597":1}}],["focuses",{"2":{"353":1}}],["focused",{"2":{"42":2,"235":1,"515":1,"777":1,"779":1}}],["focusing",{"2":{"8":2,"43":1}}],["foods",{"2":{"41":1}}],["food",{"2":{"41":2}}],["fortunately",{"2":{"557":1}}],["forth",{"2":{"30":1}}],["forward",{"2":{"211":1,"788":1}}],["forget",{"2":{"71":1,"573":2}}],["forge",{"2":{"42":1,"75":2,"116":1,"117":2,"211":2,"212":6,"219":2,"281":1,"282":2,"285":1,"306":3,"308":2,"318":2}}],["forces",{"2":{"42":1}}],["forest",{"2":{"469":1}}],["forever",{"2":{"457":1}}],["foreign",{"2":{"34":1}}],["foregoing",{"2":{"33":1}}],["formula",{"2":{"431":1}}],["formcontainerstyle",{"2":{"314":4}}],["former",{"2":{"468":1}}],["formerly",{"2":{"230":1}}],["formed",{"2":{"34":1}}],["formatting",{"0":{"369":1}}],["format",{"2":{"163":1,"164":1,"211":2,"271":1,"314":2,"369":1,"374":3,"376":1,"380":1,"383":1,"386":1,"413":1,"545":1,"548":1,"585":2}}],["formation",{"2":{"33":1}}],["formal",{"2":{"42":1}}],["forms",{"2":{"32":1,"36":1,"37":1,"134":1}}],["forming",{"2":{"31":1}}],["form",{"0":{"53":1},"2":{"27":1,"29":1,"34":1,"53":1,"84":1,"227":1,"500":1}}],["fork",{"2":{"2":3,"309":2,"432":1}}],["for",{"0":{"48":1,"88":1,"89":1,"131":1,"171":1,"270":1,"271":1,"272":1,"273":1,"289":1,"295":1,"298":1,"329":1,"342":1,"351":1,"451":1,"452":1,"465":1,"475":1,"484":1,"487":1,"492":1,"507":1,"523":1,"524":1,"554":1,"619":1,"652":1,"715":1,"747":1,"748":1,"757":1,"759":1,"760":1,"775":1,"778":1,"780":1},"1":{"290":1,"291":1,"292":1,"293":1,"294":1,"295":1,"296":1,"297":1,"298":1,"299":2,"300":1,"301":1,"330":1,"331":1,"332":1,"333":1,"334":1,"335":1,"336":1,"343":1,"344":1,"345":1,"346":1,"347":1,"348":1,"349":1,"350":1,"351":1,"466":1,"488":1,"489":1,"653":1,"654":1,"655":1,"656":1,"657":1,"658":1,"659":1,"758":1,"759":1,"760":1},"2":{"0":1,"2":1,"3":4,"4":1,"5":2,"7":1,"8":3,"9":2,"11":1,"12":1,"14":2,"15":1,"17":1,"19":1,"22":2,"23":3,"24":5,"25":2,"26":3,"27":3,"28":2,"30":3,"31":6,"32":2,"33":4,"34":12,"36":3,"37":1,"38":4,"39":1,"40":13,"41":6,"42":4,"43":6,"44":4,"45":2,"46":5,"47":8,"48":3,"49":2,"50":1,"52":2,"53":2,"56":1,"57":1,"60":2,"61":1,"63":3,"64":1,"65":1,"69":3,"75":1,"79":1,"80":1,"82":2,"84":15,"85":1,"86":5,"88":6,"89":13,"90":1,"91":14,"94":4,"102":1,"105":2,"107":11,"108":5,"110":3,"113":1,"115":1,"116":1,"117":2,"119":1,"121":1,"126":1,"127":1,"129":1,"131":1,"133":1,"134":2,"135":12,"136":4,"137":3,"139":3,"143":2,"145":8,"146":1,"148":2,"149":1,"151":2,"153":2,"156":2,"160":1,"161":3,"162":1,"164":1,"169":2,"170":4,"171":4,"172":13,"174":1,"179":1,"180":2,"181":1,"183":1,"185":1,"188":1,"189":1,"196":1,"203":1,"206":1,"211":17,"213":2,"214":2,"215":1,"216":1,"217":1,"219":3,"220":10,"221":1,"223":1,"224":7,"225":2,"227":2,"228":2,"230":3,"233":1,"235":1,"236":2,"237":2,"238":1,"242":3,"243":3,"244":2,"246":1,"247":2,"248":2,"254":1,"256":3,"258":1,"265":1,"266":2,"268":1,"269":1,"270":5,"276":5,"277":1,"280":1,"281":1,"282":2,"286":1,"288":2,"290":1,"292":2,"293":2,"294":1,"295":1,"300":2,"302":1,"303":1,"304":3,"306":7,"310":1,"311":4,"312":2,"313":4,"314":4,"318":1,"329":1,"331":2,"332":1,"333":2,"334":1,"338":4,"339":1,"351":4,"352":1,"354":1,"355":1,"357":1,"358":1,"362":1,"363":3,"366":3,"367":5,"369":3,"370":1,"372":1,"373":1,"374":1,"376":2,"377":2,"379":1,"380":6,"388":1,"391":1,"394":1,"395":1,"396":1,"398":1,"401":1,"402":2,"403":2,"405":1,"406":1,"407":3,"408":2,"411":2,"413":1,"415":1,"416":2,"423":1,"424":4,"426":3,"428":2,"429":3,"430":12,"431":4,"432":1,"436":1,"437":4,"443":2,"447":2,"448":1,"449":3,"450":4,"451":3,"453":1,"454":1,"455":1,"457":2,"458":2,"459":2,"460":1,"461":4,"462":3,"463":2,"464":7,"466":2,"467":4,"468":2,"469":3,"470":5,"476":1,"480":1,"490":1,"491":1,"492":8,"495":2,"499":2,"500":2,"502":1,"503":1,"507":2,"508":1,"509":1,"513":1,"514":1,"515":2,"519":1,"520":2,"521":1,"523":1,"524":5,"528":1,"529":1,"532":3,"534":1,"536":1,"537":1,"538":6,"542":4,"545":2,"548":1,"555":2,"556":4,"557":1,"559":1,"560":1,"563":5,"564":1,"565":3,"569":1,"571":1,"576":3,"580":2,"581":3,"583":1,"584":1,"585":5,"588":1,"589":1,"590":1,"591":2,"593":2,"594":2,"595":3,"596":1,"597":3,"599":1,"600":1,"601":2,"602":2,"604":1,"605":3,"606":3,"608":2,"615":1,"616":1,"617":2,"618":1,"619":2,"621":1,"622":2,"627":4,"628":2,"631":1,"633":3,"635":3,"639":5,"645":1,"646":1,"647":1,"648":1,"649":1,"651":1,"654":1,"656":2,"658":2,"659":3,"661":2,"663":1,"664":1,"665":3,"666":2,"667":2,"668":3,"669":1,"673":3,"674":1,"675":2,"676":1,"679":3,"681":1,"682":1,"685":11,"690":1,"691":2,"693":2,"694":1,"695":2,"696":4,"697":2,"701":2,"703":1,"705":1,"710":1,"711":3,"712":1,"714":2,"715":1,"716":1,"719":1,"721":1,"722":3,"726":3,"727":3,"733":2,"737":1,"738":1,"739":1,"740":3,"742":1,"747":1,"748":5,"750":1,"751":1,"752":1,"754":3,"758":3,"759":1,"760":3,"762":1,"764":1,"766":1,"767":1,"774":1,"777":1,"786":1,"788":1,"791":1,"794":3,"797":1,"798":1,"799":1,"800":1,"803":1,"806":2,"808":2}}],["tls",{"0":{"601":1},"2":{"601":7}}],["tls=false",{"2":{"601":2}}],["tls=true",{"2":{"599":2,"600":2,"601":2}}],["tls=",{"2":{"598":2}}],["tld",{"2":{"391":1}}],["tb",{"2":{"532":1,"635":1,"647":1,"679":1,"771":2,"772":2,"794":1}}],["tbd",{"2":{"331":1}}],["tcp",{"2":{"152":2,"153":2,"276":2,"277":2,"381":6,"521":4,"585":2,"595":2,"596":4,"606":1,"613":2,"655":4,"791":2}}],["tj9wswcyhm0r0i8t+p3hpftdieuyr9wspvkl1r2s=",{"2":{"151":2}}],["tmproto",{"2":{"165":2,"172":2,"437":6}}],["tm",{"2":{"149":2,"331":1,"661":14,"808":14}}],["txtsudo",{"2":{"553":1}}],["txt",{"2":{"545":1,"553":5,"639":8}}],["txtcelestia",{"2":{"545":1}}],["txtvite",{"2":{"312":1}}],["txoption",{"2":{"437":2}}],["txhashcelestia",{"2":{"386":1}}],["txhash",{"2":{"157":4,"159":2,"386":1,"576":2,"797":3,"803":2}}],["txsizecost",{"2":{"430":1}}],["txsizecostperbyte",{"2":{"429":1}}],["txsharerange",{"2":{"181":1}}],["txs",{"2":{"134":4,"137":6,"159":2,"542":2}}],["tx",{"2":{"91":6,"153":14,"156":5,"157":5,"159":6,"170":4,"172":2,"300":2,"314":4,"395":2,"396":2,"426":1,"428":1,"429":1,"434":2,"469":1,"542":4,"547":6,"548":6,"549":2,"550":2,"551":4,"552":2,"561":10,"576":8,"583":4,"658":4,"695":10,"703":2,"797":7,"803":6}}],["ts",{"2":{"89":1}}],["tsx",{"2":{"77":2,"319":2}}],["tuning",{"2":{"470":1}}],["tuplerootnonce",{"0":{"170":1},"2":{"163":2,"169":5}}],["tuple",{"2":{"127":10,"128":1,"136":1,"137":1,"148":4,"150":3,"153":2,"163":14,"169":17,"173":1,"177":3,"178":1,"183":1,"184":4,"208":1}}],["tutorial",{"0":{"322":1,"356":1,"358":1,"359":1,"417":1},"1":{"323":1,"324":1,"325":1,"326":1,"327":1,"328":1,"360":1,"361":1,"362":1,"363":1,"364":1,"365":1,"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,"384":1,"385":1,"386":1,"387":1,"388":1,"389":1,"390":1,"391":1,"392":1,"393":1,"418":1,"419":1,"420":1,"421":1,"422":1},"2":{"79":1,"113":1,"115":1,"122":1,"267":3,"278":1,"280":1,"287":1,"302":1,"303":1,"304":1,"310":3,"317":1,"318":1,"322":1,"333":1,"356":1,"358":1,"359":1,"368":1,"392":1,"405":2,"407":2,"416":1,"417":1,"435":1,"436":1,"471":1,"530":1,"533":1,"534":1,"536":1,"541":1,"565":1,"580":2,"584":1,"589":1,"592":1,"593":1,"597":5,"621":1,"623":1,"636":1,"638":1,"651":1,"663":1,"664":1,"667":1,"677":1,"680":1,"681":1,"682":1,"688":1,"695":1,"720":1,"723":1,"731":1,"732":1,"769":1,"793":1,"795":1,"796":1,"799":1,"802":1,"803":1}}],["tutorials",{"2":{"0":1,"3":1,"24":1,"256":1,"772":1}}],["turned",{"2":{"644":1}}],["turn",{"2":{"48":1,"68":1,"208":1}}],["twitch",{"2":{"46":1}}],["twitter",{"2":{"27":1,"45":2,"46":1}}],["two",{"2":{"45":1,"66":1,"71":1,"116":1,"117":1,"146":2,"154":1,"160":1,"175":1,"177":1,"178":1,"184":1,"213":2,"224":2,"238":1,"262":1,"281":1,"282":1,"293":1,"338":1,"352":1,"425":1,"460":1,"464":1,"469":1,"488":1,"531":1,"540":1,"548":1,"648":1,"649":1,"687":1,"691":1,"693":1,"700":1,"728":1,"730":1,"776":1,"785":1}}],["tar",{"2":{"650":24,"675":4,"676":32}}],["targets",{"2":{"557":6}}],["targetblock",{"2":{"228":1}}],["target",{"2":{"149":1,"210":1,"211":1,"213":1,"219":1,"220":3,"224":3,"225":2,"230":1,"314":4,"495":1,"542":2,"616":1,"788":4,"790":4,"791":4,"792":4}}],["targeting",{"2":{"88":1}}],["tasked",{"2":{"452":1}}],["tasks",{"2":{"30":1,"91":1,"467":1,"675":1}}],["taking",{"2":{"107":1,"165":1,"166":1,"169":1,"178":1,"648":1}}],["taken",{"2":{"223":1}}],["takes",{"2":{"107":1,"117":1,"150":1,"160":1,"223":2,"224":1,"226":1,"282":1,"324":2,"327":1,"374":1,"413":1,"419":2,"421":1}}],["takeaways",{"2":{"38":1}}],["take",{"2":{"9":1,"53":1,"107":1,"116":1,"131":1,"134":1,"163":1,"164":1,"168":1,"184":1,"200":1,"203":1,"208":1,"212":1,"281":1,"309":2,"461":1,"466":1,"470":1,"584":1,"605":1,"608":1,"633":1,"649":1,"692":1}}],["tab=staking",{"2":{"502":1}}],["tables",{"2":{"306":2}}],["table",{"2":{"84":1,"499":1,"500":1,"524":1}}],["tab",{"2":{"69":2,"71":2,"217":1,"252":1,"270":1}}],["tag",{"2":{"45":1,"276":2,"593":6,"621":6,"667":6,"669":6,"670":6}}],["tags",{"2":{"36":1,"593":6,"621":6}}],["talented",{"2":{"43":1}}],["talks",{"2":{"40":1,"43":1,"46":1,"48":5}}],["talk",{"2":{"40":1,"43":1}}],["tailored",{"2":{"53":1,"65":1}}],["tailor",{"2":{"42":1,"44":1,"48":1}}],["tax",{"2":{"32":6,"34":2}}],["taxes",{"0":{"32":1},"2":{"31":1,"32":1}}],["t",{"0":{"457":1},"2":{"27":1,"35":1,"40":1,"43":1,"45":1,"46":3,"71":1,"88":1,"89":1,"107":2,"117":3,"139":1,"145":1,"153":2,"164":1,"165":1,"166":1,"168":1,"169":1,"170":2,"183":1,"192":1,"208":1,"211":3,"217":1,"242":2,"264":1,"265":1,"266":2,"282":3,"306":1,"351":1,"357":2,"370":1,"393":1,"399":1,"401":1,"424":1,"437":2,"443":2,"451":1,"452":2,"457":2,"503":1,"569":4,"581":1,"583":1,"623":1,"651":1,"655":1,"658":1,"661":19,"677":1,"694":1,"698":1,"738":1,"761":1,"762":1,"777":1,"785":1,"803":1,"808":19}}],["tiny",{"2":{"445":1}}],["tia",{"0":{"471":1,"473":1,"476":1,"477":1,"478":1,"480":1,"481":1,"482":1,"485":1,"486":1,"499":1,"504":1,"505":1,"506":1,"512":1},"1":{"472":1,"473":1,"474":2,"475":2,"476":2,"477":2,"478":1,"479":2,"480":2,"481":2,"482":1,"483":2,"484":2,"485":2,"486":2,"500":1,"505":1,"506":1,"507":2,"508":2,"509":2,"510":2,"511":2,"512":2,"513":2,"514":2},"2":{"386":2,"443":6,"445":1,"471":3,"476":1,"494":1,"495":3,"497":1,"498":1,"499":1,"500":3,"505":2,"507":2,"508":1,"509":1,"510":1,"512":1,"513":2}}],["ticketing",{"2":{"321":1}}],["title",{"2":{"306":24,"314":12,"548":6,"549":2}}],["ti",{"2":{"276":2,"277":2}}],["tips",{"2":{"490":1}}],["tip",{"2":{"76":1,"89":1,"225":1,"270":1,"276":1,"362":1,"365":1,"366":1,"367":1,"369":1,"373":1,"396":2,"401":1,"402":1,"403":1,"407":1,"411":1,"413":1,"538":1,"576":2,"591":1,"604":1,"614":2,"647":2,"661":1,"676":1,"685":1,"694":1,"719":1,"726":1,"748":1,"800":1,"808":1}}],["timing",{"2":{"65":1,"432":1}}],["timeout",{"2":{"437":2,"576":2,"695":4}}],["timeseries",{"2":{"557":2}}],["timestamp",{"2":{"383":2,"395":2,"495":1,"576":3,"797":2,"803":2}}],["times",{"2":{"34":1,"461":1,"690":1,"777":1}}],["timely",{"2":{"25":1}}],["time",{"2":{"14":1,"15":1,"31":2,"34":2,"36":1,"45":1,"84":2,"88":1,"116":1,"139":1,"220":2,"226":1,"242":1,"264":1,"281":1,"302":1,"336":1,"351":1,"383":2,"398":1,"411":1,"415":1,"429":1,"432":2,"437":2,"454":1,"469":1,"495":1,"557":2,"563":1,"569":1,"576":2,"577":4,"584":1,"623":1,"647":2,"691":1,"692":2,"695":4,"697":1,"788":1,"792":1}}],["tiers",{"2":{"23":1}}],["tier",{"2":{"23":1,"65":1}}],["tr",{"2":{"639":10,"650":6}}],["tryfinalizecommit",{"2":{"661":2,"808":2}}],["try",{"2":{"308":1,"369":1,"393":1,"407":1,"416":1,"443":2,"639":1,"704":1}}],["trying",{"2":{"107":1,"393":1,"616":1,"617":1}}],["trpc",{"2":{"145":11,"152":4,"153":8,"157":2,"159":4,"162":2,"172":2}}],["trees",{"0":{"464":1},"2":{"362":1,"460":1,"464":1}}],["tree",{"2":{"108":2,"127":2,"128":1,"148":2,"165":6,"168":6,"197":1,"464":2,"466":2,"469":1}}],["treated",{"2":{"33":1,"219":1,"429":1}}],["tries",{"2":{"470":1}}],["triggered",{"2":{"288":3}}],["triggering",{"2":{"188":1}}],["trigger",{"2":{"188":1}}],["trick",{"2":{"108":1}}],["tripods",{"2":{"40":1}}],["truth",{"2":{"148":1}}],["true",{"2":{"89":6,"127":2,"153":2,"156":1,"157":2,"159":2,"219":1,"220":2,"306":6,"313":4,"376":1,"403":3,"556":4,"595":2,"601":1,"606":2,"630":1,"631":1,"649":3,"659":1,"695":10}}],["trusts",{"2":{"633":1}}],["trustedpeers",{"2":{"633":1}}],["trustedpeer",{"0":{"633":1}}],["trustedhash",{"0":{"633":1},"2":{"633":1}}],["trusted",{"0":{"218":1,"618":1},"1":{"619":1},"2":{"56":1,"217":3,"218":6,"219":6,"223":1,"531":2,"608":1,"618":8,"633":5,"649":2,"695":4,"742":1,"743":1,"744":1,"761":1,"762":1,"763":1}}],["trust",{"2":{"45":1,"460":1,"470":1,"618":3,"649":4,"695":4}}],["trustworthy",{"2":{"19":1}}],["troubles",{"2":{"748":1}}],["troubleshooting",{"0":{"393":1,"603":1,"673":1},"1":{"604":1,"605":1,"606":1,"607":1,"608":1,"609":1,"610":1,"611":1,"612":1,"613":1,"614":1,"615":1,"616":1,"617":1},"2":{"60":1,"93":1,"270":1,"276":2,"366":1,"367":1,"369":1,"537":1,"538":1,"591":1,"624":1,"667":1,"685":2,"719":1,"726":1,"800":1}}],["trolling",{"2":{"8":1}}],["traditional",{"2":{"197":1,"338":1,"467":1}}],["tracking",{"2":{"619":1}}],["trackers",{"2":{"558":1}}],["track",{"2":{"36":1,"108":1,"136":1,"598":1}}],["transform",{"2":{"314":2}}],["transferred",{"2":{"703":1}}],["transferring",{"2":{"34":1,"91":2}}],["transferhermes",{"2":{"700":1}}],["transferownership",{"2":{"306":2}}],["transfers",{"2":{"306":2}}],["transfer",{"0":{"386":1,"703":1},"1":{"704":1},"2":{"34":6,"76":1,"84":1,"251":1,"318":1,"386":7,"500":1,"547":1,"693":1,"695":4,"700":7,"701":4,"703":6,"704":1}}],["transcript15",{"2":{"223":4}}],["transcript14",{"2":{"223":4}}],["transcript13",{"2":{"223":4}}],["transcript12",{"2":{"223":4}}],["transcript11",{"2":{"223":4}}],["transcript06",{"2":{"223":4}}],["transcript05",{"2":{"223":4}}],["transcript04",{"2":{"223":4}}],["transact",{"2":{"288":1,"502":1}}],["transactopts",{"2":{"172":2}}],["transactionindex",{"2":{"121":2,"286":2,"396":2}}],["transactionhash",{"2":{"121":2,"286":2}}],["transactions",{"0":{"351":1,"432":1,"488":1,"644":1},"2":{"33":2,"34":2,"66":1,"69":2,"71":1,"72":1,"79":1,"85":2,"86":1,"90":1,"136":1,"139":1,"143":1,"146":1,"159":1,"236":1,"248":1,"261":3,"262":2,"265":1,"288":1,"294":1,"309":1,"310":1,"311":1,"331":1,"332":1,"351":3,"361":1,"366":1,"367":1,"395":3,"405":1,"425":2,"426":2,"427":2,"432":1,"437":4,"439":3,"440":1,"441":2,"444":1,"445":1,"447":1,"454":1,"460":1,"461":1,"462":1,"466":1,"467":6,"468":1,"469":6,"470":2,"488":2,"489":2,"507":1,"513":1,"524":1,"537":1,"538":1,"542":2,"562":1,"644":1,"658":5,"659":1,"685":3,"726":1,"727":1,"732":1,"748":1,"760":1,"761":1,"763":1,"805":1}}],["transaction",{"0":{"154":1,"155":2,"158":1,"208":1,"395":1,"396":1,"439":1,"469":1,"642":1,"658":1,"715":1,"805":1},"1":{"156":2,"157":2,"159":1,"440":1,"441":1,"470":1},"2":{"33":1,"34":2,"69":4,"71":3,"72":3,"83":3,"84":3,"85":4,"91":14,"120":2,"136":1,"139":1,"146":3,"153":8,"154":4,"155":3,"156":3,"157":2,"158":1,"159":4,"164":1,"165":1,"170":2,"172":4,"173":1,"176":1,"181":2,"184":1,"189":2,"200":1,"208":13,"211":3,"213":2,"262":2,"265":2,"266":1,"285":2,"288":1,"290":1,"300":2,"346":1,"351":1,"374":3,"376":3,"377":1,"386":1,"391":1,"395":4,"396":2,"425":1,"426":5,"428":2,"429":3,"430":10,"431":1,"432":8,"437":14,"440":2,"447":2,"448":3,"449":1,"453":3,"454":3,"455":2,"456":2,"458":2,"459":2,"460":1,"467":1,"469":3,"476":1,"477":1,"480":2,"481":1,"486":1,"488":4,"489":2,"560":1,"561":4,"565":1,"576":3,"583":1,"585":2,"641":1,"644":1,"715":1,"738":4,"803":3,"805":1}}],["transitions",{"2":{"139":1,"188":1,"196":1,"200":1,"203":1,"467":1}}],["transition",{"2":{"19":1,"172":4,"188":2,"192":1}}],["translations",{"2":{"17":2}}],["tee",{"2":{"788":2,"790":2,"791":2,"792":2}}],["territories",{"2":{"734":1}}],["terminal",{"2":{"75":2,"76":2,"211":1,"318":4,"391":1,"407":1,"594":2,"622":2,"689":1,"725":1}}],["termination",{"2":{"34":1}}],["term",{"2":{"34":1,"495":1}}],["terms",{"0":{"30":1,"31":1},"1":{"31":1,"32":1,"33":1,"34":1},"2":{"14":1,"15":1,"30":15,"31":1,"33":2,"34":7,"485":1}}],["teach",{"2":{"368":1}}],["team",{"2":{"27":1,"36":1,"41":1,"43":1,"45":1,"52":1,"79":1,"91":1,"179":1,"200":1,"203":1,"206":1,"226":1,"227":1,"531":1,"690":1,"691":1}}],["text|json",{"2":{"585":2}}],["text$request",{"2":{"367":1,"526":1,"591":1,"765":1}}],["textarea",{"2":{"314":2}}],["textalign",{"2":{"314":4}}],["text",{"2":{"314":2,"374":2,"376":1,"548":1,"549":1,"585":2,"717":1}}],["texthttps",{"2":{"145":2}}],["testtia",{"2":{"713":1}}],["test3",{"2":{"561":4}}],["test2sig",{"2":{"561":4}}],["test2",{"2":{"561":8}}],["test1sig",{"2":{"561":4}}],["test1",{"2":{"561":8}}],["testcelestia",{"2":{"543":1,"581":1,"590":1}}],["testcreatepost",{"2":{"306":2}}],["testkey2",{"2":{"346":2,"347":1}}],["testkey2celestia",{"2":{"346":1}}],["testkey",{"2":{"344":2,"349":2,"712":1}}],["testkeycelestia",{"2":{"344":1}}],["testonlyowner",{"2":{"306":2}}],["testfetchposts",{"2":{"306":2}}],["testforge",{"2":{"117":1,"282":1}}],["testupdatepost",{"2":{"306":2}}],["teststaking",{"2":{"715":1}}],["tests",{"0":{"306":1},"2":{"117":4,"282":4,"307":1}}],["testsetnumber",{"2":{"117":6,"282":6}}],["testincrement",{"2":{"117":6,"282":6}}],["testing",{"0":{"316":1},"2":{"113":1,"117":1,"119":1,"250":1,"282":1,"515":3,"516":1,"691":1,"733":1,"750":1,"774":1}}],["test",{"0":{"117":1,"282":1,"307":1},"2":{"117":14,"120":1,"165":1,"166":1,"168":1,"169":1,"223":4,"247":2,"270":6,"271":6,"272":6,"276":4,"277":4,"282":14,"284":2,"300":2,"306":7,"307":2,"308":1,"309":2,"310":3,"315":1,"316":3,"317":1,"341":1,"349":2,"367":4,"410":4,"538":3,"539":1,"543":1,"557":1,"561":6,"571":1,"581":1,"585":2,"590":1,"685":3,"686":1,"695":4,"697":1,"705":2,"712":1,"713":1,"715":1,"727":4,"729":1,"754":2,"779":1,"783":1,"785":1}}],["tested",{"2":{"94":1,"308":1,"310":1,"334":1,"398":1}}],["testnetwork",{"2":{"705":1}}],["testnets",{"0":{"776":1},"1":{"777":1,"778":1,"779":1,"780":1},"2":{"30":1,"80":1,"101":1,"266":1,"443":1,"445":1,"691":2,"696":1,"776":1}}],["testnet",{"0":{"30":1,"89":1,"245":1,"278":1,"318":1,"403":1,"503":1,"600":1,"709":1,"728":1,"754":1,"765":1,"779":1,"780":1},"1":{"31":1,"32":1,"33":1,"34":1,"246":1,"247":1,"248":1,"249":1,"250":1,"251":1,"252":1,"253":1,"254":1,"255":1,"279":1,"280":1,"281":1,"282":1,"283":1,"284":1,"285":1,"286":1,"287":1,"319":1,"320":1,"321":1,"710":1,"711":1,"712":1,"713":1,"714":1,"715":1,"716":1,"717":1,"718":1,"719":1,"755":1,"756":1,"757":1,"758":1,"759":1,"760":1,"761":1,"762":1,"763":1,"764":1,"765":1,"766":1,"767":1,"768":1},"2":{"24":3,"27":1,"30":5,"68":1,"79":2,"80":3,"82":5,"85":5,"88":1,"95":1,"145":1,"240":3,"245":2,"246":5,"247":1,"248":1,"250":3,"251":2,"252":1,"255":1,"276":1,"278":1,"279":1,"287":1,"290":1,"291":1,"303":1,"309":1,"313":4,"318":2,"340":4,"341":2,"366":1,"367":2,"393":2,"399":2,"401":1,"403":2,"407":1,"443":2,"445":5,"499":1,"503":4,"515":3,"516":1,"537":1,"538":4,"565":1,"571":1,"579":1,"580":2,"583":1,"587":1,"600":1,"639":1,"685":4,"691":1,"693":2,"695":11,"696":3,"698":1,"699":6,"700":8,"701":3,"705":1,"709":2,"711":1,"714":2,"719":1,"727":1,"728":2,"754":1,"760":6,"761":8,"762":8,"763":8,"765":1,"766":2,"767":8,"768":1,"779":2,"785":1,"800":1}}],["temp",{"2":{"594":1,"622":1}}],["temporarily",{"2":{"563":1}}],["temporary",{"0":{"15":1},"2":{"14":1,"15":1,"288":1,"571":1}}],["template",{"2":{"222":1,"223":2,"398":1}}],["templates",{"2":{"89":1}}],["tendermintrpc",{"2":{"107":1}}],["tendermint",{"2":{"89":3,"145":1,"149":4,"151":1,"152":4,"153":10,"156":1,"159":4,"161":1,"172":22,"218":1,"220":1,"227":1,"331":2,"332":1,"333":1,"335":1,"336":2,"383":4,"437":6,"466":6,"531":1,"542":8,"554":2,"585":2,"653":2,"661":29,"694":2,"700":8,"710":2,"718":2,"803":2,"808":29}}],["tell",{"2":{"48":1}}],["telegram",{"2":{"45":2,"529":1,"559":1,"753":1,"768":1,"781":1}}],["television",{"2":{"34":1}}],["telemetry",{"2":{"33":1,"695":6}}],["tech",{"2":{"42":2,"44":1,"105":1,"742":2,"743":2,"744":2,"745":2,"748":1,"751":1,"760":2,"761":1,"762":1,"763":1,"767":1}}],["technologies",{"2":{"48":1,"59":1,"265":1,"734":1}}],["technology",{"2":{"8":1,"42":1,"405":1}}],["technical",{"2":{"3":1,"27":1,"31":1,"36":1,"48":1}}],["typically",{"2":{"233":1,"512":1}}],["typical",{"2":{"136":1,"262":1,"336":2}}],["type=$node",{"2":{"667":6,"669":6,"670":6}}],["type=full",{"2":{"667":1}}],["type=fullexport",{"2":{"667":1}}],["type=bridge",{"2":{"667":1}}],["type=bridgeexport",{"2":{"667":1}}],["type=1",{"2":{"398":1}}],["type=spanbatch",{"2":{"398":1}}],["type=lightexport",{"2":{"667":1}}],["type=light",{"2":{"276":2,"277":2,"667":1}}],["type=ledger`",{"2":{"211":2}}],["type=private",{"2":{"211":4}}],["type",{"0":{"83":1},"2":{"117":1,"121":2,"134":8,"135":7,"156":4,"165":2,"168":2,"187":1,"211":4,"261":1,"268":1,"270":7,"271":6,"272":6,"276":2,"277":6,"282":1,"286":2,"349":2,"367":4,"371":4,"383":4,"391":2,"397":2,"398":2,"413":3,"415":2,"444":1,"445":1,"448":2,"519":1,"521":2,"524":2,"538":2,"548":4,"573":4,"574":8,"576":2,"577":3,"578":5,"596":2,"598":2,"599":2,"600":2,"601":4,"604":4,"608":2,"609":12,"614":4,"615":2,"616":4,"623":1,"627":1,"667":13,"669":8,"670":8,"676":1,"685":2,"695":12,"727":4,"739":1,"748":2,"754":3,"769":1,"771":1,"772":1}}],["typescargo",{"2":{"418":1}}],["types",{"0":{"647":1},"1":{"648":1,"649":1,"650":1},"2":{"3":1,"42":1,"172":6,"182":1,"192":1,"265":1,"324":4,"365":1,"411":4,"418":2,"419":4,"431":2,"436":4,"437":4,"458":1,"519":1,"521":1,"595":1,"606":1,"608":1,"623":1,"673":1,"739":2,"754":1,"783":1}}],["typography",{"2":{"58":1}}],["typos",{"2":{"2":1}}],["though",{"2":{"467":1,"469":1}}],["thought",{"2":{"134":2}}],["thorough",{"2":{"194":1}}],["those",{"2":{"8":1,"14":1,"15":1,"39":1,"40":1,"46":3,"49":1,"134":1,"135":1,"148":1,"177":1,"208":1,"213":2,"261":2,"262":1,"331":1,"335":1,"351":1,"394":1,"456":1,"458":1,"461":1,"548":1,"690":1,"691":3,"716":1,"754":1}}],["thus",{"2":{"88":1,"89":1,"107":1,"109":1,"463":1,"467":3,"469":2}}],["thank",{"2":{"44":1,"79":1}}],["thanks",{"2":{"39":1,"106":1}}],["thanking",{"2":{"38":1}}],["than",{"2":{"25":1,"31":1,"34":2,"76":1,"208":1,"235":1,"262":1,"270":1,"318":1,"336":1,"338":1,"426":2,"427":1,"456":1,"491":1,"492":1,"495":2,"556":2,"563":1,"583":1,"609":1,"617":1,"738":1}}],["that",{"0":{"153":1,"172":1,"188":1,"189":1,"190":1,"191":1,"192":1,"193":1,"194":1,"196":1,"197":1,"198":1,"199":1,"201":1,"202":1,"451":1},"1":{"189":1,"190":1,"191":1,"193":1,"194":1,"197":1,"198":1,"200":1,"201":1,"202":1},"2":{"7":1,"8":1,"9":2,"19":1,"22":1,"24":4,"30":2,"31":9,"32":3,"33":1,"34":21,"35":1,"36":1,"37":1,"40":2,"41":1,"42":1,"44":1,"48":1,"53":2,"65":3,"76":2,"78":1,"84":3,"85":2,"87":1,"89":6,"91":2,"94":1,"102":2,"103":1,"105":1,"107":3,"108":4,"109":4,"117":3,"126":2,"127":4,"129":2,"130":1,"131":13,"133":2,"134":18,"135":18,"136":4,"137":2,"139":6,"145":3,"146":3,"148":14,"150":1,"153":6,"154":2,"158":1,"163":13,"164":2,"165":1,"166":1,"169":9,"170":2,"172":12,"173":2,"174":3,"175":2,"176":1,"177":7,"178":1,"179":1,"181":1,"183":7,"184":8,"187":6,"188":6,"189":2,"191":1,"192":4,"194":1,"195":1,"196":4,"197":2,"200":3,"203":6,"206":2,"208":1,"211":6,"212":1,"213":3,"214":3,"215":1,"217":1,"218":1,"219":3,"220":1,"221":1,"223":1,"224":7,"225":1,"226":1,"227":1,"228":1,"230":1,"234":1,"236":4,"237":2,"242":3,"243":1,"244":1,"246":1,"247":1,"248":1,"251":1,"255":1,"256":1,"258":1,"261":2,"262":2,"264":1,"265":3,"266":3,"267":1,"268":1,"270":3,"276":1,"282":3,"285":1,"288":1,"292":3,"295":1,"296":1,"297":1,"301":3,"303":3,"308":1,"309":1,"310":2,"311":2,"312":1,"313":1,"314":2,"316":2,"317":1,"318":2,"320":1,"325":1,"326":1,"331":1,"333":1,"335":1,"336":4,"337":1,"338":1,"340":1,"341":1,"366":1,"367":1,"369":5,"370":1,"371":1,"376":1,"386":1,"393":1,"395":1,"398":1,"399":1,"401":2,"405":2,"411":2,"412":1,"413":2,"415":1,"420":1,"426":1,"427":1,"428":3,"429":1,"430":5,"432":2,"437":6,"443":5,"444":1,"445":1,"447":4,"449":1,"450":1,"451":8,"452":2,"454":1,"455":1,"456":1,"457":1,"458":6,"459":1,"460":2,"461":3,"462":2,"463":1,"464":6,"466":4,"467":9,"468":4,"469":5,"470":4,"471":1,"480":1,"489":1,"490":5,"491":2,"492":2,"500":1,"508":1,"512":1,"515":2,"523":1,"524":1,"531":1,"537":1,"538":1,"541":1,"548":5,"549":2,"557":5,"560":1,"563":3,"564":2,"566":1,"569":1,"571":2,"577":2,"580":1,"583":1,"585":1,"591":1,"594":1,"595":4,"596":1,"598":1,"602":1,"606":4,"611":1,"614":2,"616":1,"617":2,"618":4,"621":1,"622":1,"623":1,"626":1,"633":1,"639":2,"645":1,"647":1,"651":1,"659":1,"661":1,"662":1,"664":1,"665":2,"668":1,"675":1,"676":1,"677":1,"678":1,"685":2,"688":1,"690":1,"692":1,"693":2,"694":2,"696":3,"698":2,"700":1,"701":1,"716":1,"718":2,"721":1,"725":1,"727":1,"733":1,"734":1,"738":3,"747":1,"748":1,"754":1,"759":1,"760":3,"776":1,"784":1,"785":1,"788":1,"797":1,"802":1,"803":4,"808":1}}],["think",{"2":{"134":1}}],["things",{"0":{"415":1,"459":1},"2":{"34":1,"77":1,"91":2,"313":1,"319":1,"374":1}}],["third",{"2":{"23":4,"31":10,"33":5,"34":1,"290":1,"292":1,"300":1,"329":1,"650":1}}],["this",{"0":{"456":1},"2":{"1":1,"2":2,"4":1,"9":1,"10":1,"12":1,"14":1,"15":1,"17":2,"23":4,"24":1,"27":1,"33":2,"42":2,"43":3,"44":2,"45":1,"46":2,"47":1,"48":7,"49":1,"50":1,"52":1,"53":1,"55":1,"56":2,"57":2,"59":1,"60":2,"61":2,"63":1,"64":1,"65":1,"66":2,"69":1,"76":2,"77":1,"79":4,"81":1,"82":2,"83":4,"84":7,"85":4,"86":2,"88":3,"89":1,"90":2,"91":2,"92":1,"94":3,"102":2,"103":1,"107":3,"108":3,"109":1,"113":1,"115":1,"116":1,"117":3,"126":1,"131":5,"133":4,"134":8,"135":6,"136":3,"137":3,"139":1,"148":4,"149":1,"150":2,"154":1,"156":1,"160":1,"164":3,"165":3,"169":3,"172":4,"174":1,"175":1,"176":1,"178":1,"180":2,"183":5,"184":3,"188":3,"192":2,"195":1,"196":2,"202":1,"208":3,"209":1,"211":2,"213":1,"214":1,"217":2,"222":1,"223":5,"224":5,"226":1,"227":1,"228":1,"230":2,"236":2,"246":1,"250":1,"256":2,"265":1,"266":1,"267":3,"269":1,"270":1,"276":1,"277":3,"278":1,"280":1,"281":1,"282":3,"288":2,"290":1,"296":1,"301":1,"302":3,"303":1,"306":3,"308":1,"309":1,"314":4,"317":1,"318":2,"319":1,"321":2,"322":1,"323":2,"325":2,"326":2,"327":1,"329":1,"331":1,"333":2,"335":1,"336":1,"338":3,"339":2,"340":1,"341":2,"343":1,"344":1,"346":1,"351":2,"359":1,"362":1,"365":1,"366":2,"368":1,"369":2,"372":2,"373":2,"374":1,"376":3,"381":1,"382":1,"383":2,"386":1,"389":1,"391":1,"394":1,"395":1,"398":2,"399":1,"401":2,"405":2,"407":5,"410":1,"411":2,"413":1,"416":1,"417":1,"418":2,"420":2,"421":1,"423":1,"426":2,"428":1,"429":3,"430":3,"431":3,"432":4,"437":10,"439":1,"440":1,"442":1,"443":4,"447":1,"448":1,"449":1,"450":1,"451":2,"459":1,"462":2,"463":2,"464":2,"466":1,"467":4,"468":1,"469":2,"470":2,"471":2,"474":1,"489":1,"490":1,"491":2,"492":4,"500":1,"508":1,"513":1,"519":1,"524":1,"525":1,"530":1,"531":2,"538":1,"548":3,"553":2,"557":7,"558":1,"561":4,"563":2,"565":2,"569":2,"571":1,"573":2,"576":1,"580":2,"584":1,"585":5,"588":1,"589":1,"590":1,"591":1,"592":1,"593":1,"594":1,"596":2,"597":3,"601":2,"602":2,"604":2,"609":2,"611":3,"612":1,"614":1,"615":1,"617":5,"618":3,"621":4,"622":1,"628":2,"631":2,"634":1,"639":2,"641":1,"643":2,"645":1,"646":3,"648":1,"649":2,"651":1,"653":1,"654":1,"655":2,"656":1,"658":7,"659":3,"661":1,"663":1,"664":1,"665":2,"668":4,"669":1,"673":1,"674":2,"675":2,"677":1,"689":1,"690":1,"693":2,"695":1,"698":2,"700":2,"705":2,"709":1,"711":1,"712":2,"715":1,"716":5,"720":1,"721":1,"723":1,"732":1,"733":1,"734":1,"738":1,"739":1,"748":1,"754":2,"762":1,"765":1,"769":3,"774":1,"782":1,"785":1,"791":1,"793":1,"798":1,"803":2,"808":1}}],["thread",{"2":{"450":1}}],["threatening",{"2":{"9":1}}],["threshold",{"2":{"428":1,"560":1,"561":2,"695":4}}],["three",{"2":{"217":1,"238":1,"377":1,"464":2,"467":1}}],["throughput",{"2":{"230":1,"235":1,"236":1,"462":1,"467":2}}],["throughout",{"2":{"34":1,"52":1,"405":1}}],["through",{"2":{"14":1,"33":1,"34":1,"38":1,"45":1,"72":1,"89":1,"91":2,"211":1,"243":1,"322":1,"340":1,"405":1,"417":1,"429":1,"430":1,"440":1,"501":1,"510":1,"556":1,"557":1,"589":1,"592":1,"609":1,"677":1,"703":1,"720":1,"769":1,"790":1,"791":1,"793":1,"797":1}}],["theta",{"2":{"695":9,"696":2,"698":1,"699":6,"700":8,"701":3}}],["then",{"2":{"68":1,"69":1,"84":1,"85":1,"90":1,"107":1,"108":1,"117":1,"133":2,"134":1,"136":2,"139":1,"148":5,"150":1,"157":1,"160":3,"165":1,"166":1,"171":1,"172":1,"173":1,"177":1,"183":1,"184":1,"188":2,"192":1,"200":3,"203":1,"206":1,"208":2,"211":3,"214":1,"217":1,"219":1,"220":2,"221":1,"223":1,"224":2,"225":1,"243":1,"244":2,"261":1,"272":1,"282":1,"295":1,"300":1,"309":2,"310":1,"314":4,"315":1,"338":2,"340":1,"372":1,"376":1,"386":1,"393":1,"412":1,"413":3,"415":2,"416":1,"426":1,"429":2,"430":1,"431":1,"432":1,"437":2,"444":1,"445":1,"447":1,"461":2,"470":3,"480":1,"485":1,"488":1,"489":1,"545":2,"548":2,"554":3,"557":3,"596":1,"602":2,"609":1,"614":1,"616":1,"630":1,"647":1,"649":1,"651":1,"661":1,"675":2,"692":2,"716":1,"803":1,"808":1}}],["therefore",{"2":{"135":1,"437":2,"447":1,"462":1,"516":1}}],["therefor",{"2":{"34":1}}],["therefrom",{"2":{"34":1}}],["thereof",{"2":{"34":2}}],["thereto",{"2":{"31":1,"34":2}}],["there",{"0":{"458":1},"2":{"23":1,"42":1,"45":1,"50":1,"84":1,"116":1,"117":1,"139":1,"178":1,"192":1,"195":1,"208":1,"213":1,"224":1,"250":1,"262":1,"264":1,"265":1,"281":1,"282":1,"321":1,"333":1,"338":1,"352":1,"366":1,"374":1,"424":1,"426":1,"428":1,"451":1,"452":2,"457":1,"458":1,"461":1,"462":1,"467":1,"525":1,"528":1,"548":3,"605":1,"648":1,"693":1,"738":2,"750":1,"751":1,"753":1,"765":1,"767":1,"768":1,"769":1,"781":1}}],["these",{"2":{"12":1,"14":1,"15":1,"30":7,"33":2,"34":9,"35":1,"39":1,"40":1,"41":1,"45":1,"50":1,"85":1,"86":1,"88":1,"89":1,"131":2,"134":1,"135":2,"146":1,"148":1,"151":2,"156":1,"161":1,"165":1,"168":1,"177":1,"178":2,"180":1,"184":2,"191":1,"196":2,"203":1,"217":1,"220":2,"224":1,"227":1,"238":1,"242":1,"262":1,"265":1,"302":2,"321":1,"330":1,"336":1,"370":2,"377":1,"413":1,"424":1,"429":2,"431":1,"461":1,"467":2,"469":2,"492":1,"520":1,"521":1,"523":1,"524":1,"549":1,"557":2,"583":1,"594":1,"596":1,"622":1,"639":1,"649":1,"657":1,"659":1,"673":1,"675":2,"693":1,"709":1,"737":1,"738":1,"740":1,"747":1,"748":2,"758":1,"759":1,"760":1,"803":1}}],["they",{"2":{"8":1,"9":1,"12":1,"23":1,"30":1,"31":2,"34":2,"40":1,"44":4,"45":2,"46":1,"47":1,"65":1,"84":2,"86":1,"139":1,"151":1,"156":1,"161":1,"168":1,"178":1,"187":2,"188":2,"192":2,"225":1,"226":1,"248":1,"261":2,"262":1,"264":1,"266":1,"325":1,"326":1,"334":1,"337":1,"369":1,"411":1,"420":1,"428":1,"430":1,"432":3,"439":1,"441":1,"443":2,"449":2,"451":2,"452":1,"458":1,"459":2,"462":1,"467":1,"492":1,"516":1,"523":1,"524":1,"549":1,"563":3,"690":1,"698":1,"715":1,"716":1,"718":1,"721":2,"747":1,"748":1,"759":1,"760":1,"764":1,"779":1}}],["their",{"2":{"8":1,"28":1,"31":1,"34":1,"36":1,"38":1,"40":2,"42":2,"43":2,"44":6,"45":3,"46":2,"47":2,"48":1,"53":1,"65":1,"84":2,"133":1,"148":1,"173":1,"174":3,"175":1,"182":1,"187":1,"188":1,"211":1,"226":1,"230":1,"245":1,"247":1,"256":1,"264":2,"265":2,"266":3,"302":1,"306":2,"313":1,"337":1,"338":1,"353":1,"355":1,"359":1,"362":1,"394":1,"428":1,"432":1,"441":1,"454":1,"458":1,"467":1,"468":2,"490":1,"492":4,"497":1,"508":3,"509":2,"515":1,"516":1,"523":1,"524":1,"557":2,"563":3,"602":1,"608":1,"644":1,"649":1,"690":1,"691":2,"714":1,"716":3,"747":1,"748":1,"754":2,"759":1,"760":1,"779":1}}],["theme",{"2":{"43":2}}],["them",{"2":{"2":1,"34":1,"38":1,"40":1,"44":4,"45":1,"46":3,"47":3,"102":1,"107":1,"130":1,"148":1,"165":3,"168":1,"173":1,"177":1,"181":1,"191":2,"212":2,"217":1,"220":2,"224":1,"226":1,"244":1,"262":1,"306":2,"338":2,"357":1,"362":1,"411":1,"460":1,"494":1,"519":1,"563":1,"606":1,"614":1,"619":1,"649":1,"715":1,"716":1,"739":1,"754":1,"760":1}}],["the",{"0":{"1":1,"18":1,"19":1,"36":1,"37":1,"38":1,"76":1,"77":1,"78":1,"87":1,"88":1,"130":1,"139":1,"146":1,"147":1,"148":1,"155":1,"158":1,"163":2,"170":1,"172":1,"208":2,"210":1,"212":1,"213":2,"217":1,"218":1,"222":1,"223":1,"224":1,"227":1,"241":1,"246":1,"268":1,"301":1,"306":1,"307":1,"308":1,"310":1,"311":1,"313":1,"319":1,"320":1,"338":1,"377":1,"380":1,"396":1,"397":1,"409":1,"424":1,"432":1,"434":1,"435":1,"436":1,"437":1,"448":1,"451":1,"454":1,"455":1,"469":1,"484":1,"534":1,"535":1,"537":1,"538":1,"539":1,"541":1,"552":1,"567":1,"568":1,"569":1,"570":2,"577":1,"578":1,"579":2,"607":1,"615":1,"616":2,"637":1,"639":1,"651":1,"657":1,"669":1,"670":1,"681":1,"683":1,"684":1,"685":1,"686":1,"688":1,"689":1,"702":1,"715":1,"716":1,"719":1,"725":1,"726":1,"729":1,"773":1,"788":1,"798":1,"800":1,"801":1,"802":1,"803":1},"1":{"19":1,"20":1,"21":1,"22":1,"23":1,"24":1,"25":1,"26":1,"27":1,"28":1,"29":1,"147":1,"148":1,"156":1,"157":1,"159":1,"164":2,"165":2,"166":2,"167":2,"168":2,"169":2,"170":2,"171":2,"172":2,"211":1,"212":1,"213":1,"214":3,"215":3,"216":3,"217":1,"218":2,"219":2,"220":1,"221":1,"223":1,"224":1,"242":1,"243":1,"244":1,"269":1,"270":1,"271":1,"272":1,"273":1,"312":1,"339":1,"410":1,"411":1,"412":1,"413":1,"414":1,"415":1,"470":1,"536":1,"537":1,"538":1,"539":2,"540":2,"541":1,"568":1,"569":1,"570":1,"571":1,"608":1,"609":1,"610":1,"611":1,"612":1,"613":1,"684":1,"685":1,"687":1,"727":1,"728":1,"729":1,"730":2,"731":1,"774":1,"775":1,"776":1,"777":1,"778":1,"779":1,"780":1,"781":1,"799":1,"800":1,"801":1,"802":2},"2":{"0":2,"1":2,"2":3,"3":2,"4":2,"5":4,"8":4,"9":1,"10":1,"11":3,"12":1,"13":4,"14":2,"15":3,"16":1,"17":2,"19":5,"21":7,"22":3,"23":9,"24":17,"25":4,"26":3,"27":12,"28":3,"29":2,"30":24,"31":25,"32":7,"33":15,"34":105,"35":1,"36":8,"37":4,"38":6,"39":2,"40":12,"41":4,"42":13,"43":15,"44":14,"45":9,"46":8,"47":7,"48":15,"49":2,"50":5,"52":5,"53":5,"54":2,"55":1,"56":2,"57":3,"59":4,"60":3,"61":3,"62":4,"63":1,"64":2,"65":15,"68":5,"69":7,"71":9,"72":6,"73":1,"75":12,"76":9,"77":7,"79":8,"82":6,"83":6,"84":40,"85":13,"86":7,"87":6,"88":12,"89":31,"90":2,"91":46,"92":3,"94":8,"95":5,"102":10,"103":2,"105":5,"106":3,"107":31,"108":18,"109":5,"110":14,"111":1,"113":3,"115":2,"116":10,"117":27,"119":3,"120":4,"121":7,"125":1,"126":6,"127":7,"128":2,"129":4,"130":4,"131":34,"133":2,"134":54,"135":37,"136":25,"137":17,"139":34,"141":1,"142":2,"143":4,"145":11,"146":15,"148":27,"149":9,"150":8,"151":6,"152":2,"153":40,"154":10,"155":2,"156":10,"157":2,"158":5,"159":12,"160":9,"161":8,"162":6,"163":58,"164":9,"165":46,"166":12,"167":5,"168":24,"169":58,"170":26,"171":11,"172":64,"173":6,"174":3,"175":4,"176":4,"177":23,"178":15,"179":6,"180":8,"181":23,"182":3,"183":30,"184":47,"185":1,"187":4,"188":12,"189":6,"191":3,"192":23,"193":2,"194":5,"195":10,"196":29,"197":3,"199":2,"200":28,"202":1,"203":24,"205":1,"206":8,"208":31,"209":1,"210":4,"211":75,"212":23,"213":25,"214":9,"215":5,"217":16,"218":3,"219":51,"220":58,"221":6,"222":6,"223":24,"224":37,"225":9,"226":3,"227":13,"228":9,"230":11,"233":1,"234":4,"235":3,"236":20,"237":12,"238":2,"239":2,"240":3,"242":14,"243":9,"244":9,"245":1,"246":8,"248":4,"250":4,"251":2,"252":2,"253":1,"254":2,"255":1,"256":3,"262":4,"264":6,"265":5,"266":6,"267":3,"268":4,"269":4,"270":13,"271":1,"272":1,"275":1,"276":13,"277":11,"278":1,"279":2,"280":2,"281":10,"282":27,"284":3,"285":4,"286":7,"287":1,"288":6,"290":4,"291":2,"292":9,"293":8,"294":4,"295":6,"296":7,"297":2,"298":1,"300":4,"301":5,"302":2,"303":1,"306":29,"308":3,"309":10,"310":21,"311":9,"312":6,"313":4,"314":29,"315":3,"316":14,"318":23,"319":7,"322":2,"323":5,"324":23,"325":2,"326":14,"327":15,"328":2,"329":1,"331":5,"332":2,"333":7,"334":2,"335":2,"336":5,"337":1,"338":15,"339":1,"340":1,"341":3,"344":3,"346":1,"347":4,"348":2,"350":1,"351":6,"352":5,"353":6,"354":1,"355":4,"356":3,"357":5,"358":1,"359":2,"361":1,"362":5,"363":1,"365":2,"366":11,"367":16,"368":2,"369":18,"370":10,"371":8,"372":6,"373":4,"374":21,"375":1,"376":19,"377":13,"379":4,"380":6,"381":3,"383":4,"386":4,"387":1,"388":4,"389":4,"391":8,"392":1,"393":2,"395":2,"396":8,"397":2,"398":1,"399":2,"401":5,"402":1,"403":3,"405":7,"406":1,"407":11,"408":2,"410":2,"411":14,"412":15,"413":53,"414":6,"415":21,"416":4,"417":1,"418":5,"419":19,"420":12,"421":9,"422":2,"423":2,"424":10,"426":5,"427":1,"428":10,"429":26,"430":43,"431":6,"432":13,"435":1,"436":15,"437":48,"438":3,"439":2,"440":1,"441":1,"443":19,"444":3,"445":3,"447":14,"448":9,"449":2,"450":2,"451":4,"452":7,"453":2,"454":3,"456":5,"457":6,"459":2,"460":4,"461":18,"462":9,"463":17,"464":32,"466":26,"467":24,"468":10,"469":47,"470":32,"471":3,"474":1,"475":2,"476":2,"477":2,"479":1,"480":4,"481":2,"484":2,"485":1,"488":16,"489":3,"490":4,"491":6,"492":10,"494":3,"495":9,"497":1,"499":3,"500":10,"501":2,"502":2,"503":2,"505":1,"507":2,"508":2,"509":1,"510":2,"512":1,"513":2,"514":1,"515":2,"516":3,"519":5,"521":2,"523":1,"524":7,"526":2,"527":1,"529":2,"530":3,"531":13,"532":2,"533":1,"534":2,"536":3,"537":13,"538":9,"539":5,"540":5,"541":3,"542":10,"543":3,"545":6,"548":22,"549":9,"550":1,"551":2,"552":1,"553":3,"554":3,"555":1,"556":7,"557":26,"558":4,"559":5,"560":3,"561":14,"563":20,"564":2,"565":2,"566":1,"568":2,"569":10,"570":1,"571":5,"573":4,"575":5,"576":15,"577":4,"578":3,"579":7,"580":3,"581":3,"582":1,"583":7,"584":4,"585":8,"586":1,"587":1,"590":3,"591":9,"593":16,"594":10,"595":6,"596":2,"597":2,"598":6,"601":5,"602":11,"604":3,"605":2,"606":8,"608":8,"609":4,"611":5,"612":3,"613":2,"614":4,"615":1,"616":8,"617":12,"618":13,"619":3,"621":15,"622":9,"623":2,"624":3,"627":2,"628":3,"630":5,"631":3,"633":5,"634":2,"635":1,"636":1,"637":1,"638":1,"639":9,"641":1,"643":1,"644":1,"645":3,"646":5,"647":5,"648":6,"649":10,"650":5,"651":7,"654":1,"655":5,"656":3,"657":1,"658":6,"659":10,"661":9,"662":1,"663":2,"664":1,"665":8,"667":9,"668":7,"669":9,"670":2,"673":3,"675":5,"676":4,"677":1,"678":2,"679":2,"680":1,"681":1,"682":1,"684":1,"685":17,"686":5,"687":5,"688":2,"689":4,"690":7,"691":8,"692":13,"693":5,"694":3,"695":5,"696":4,"697":5,"698":2,"699":2,"700":3,"701":2,"702":1,"703":5,"704":3,"705":1,"707":1,"708":1,"710":2,"711":5,"712":4,"713":2,"714":6,"715":6,"716":10,"717":4,"718":6,"719":3,"721":3,"722":1,"723":1,"724":1,"725":4,"726":7,"727":10,"728":3,"729":5,"730":5,"731":2,"733":6,"734":2,"737":2,"738":17,"739":6,"740":1,"742":1,"747":1,"748":6,"749":2,"750":1,"752":1,"753":2,"754":10,"758":1,"759":1,"760":3,"761":4,"762":5,"763":3,"764":2,"765":2,"766":1,"768":2,"769":6,"772":1,"774":3,"777":1,"779":2,"781":2,"782":1,"783":1,"784":3,"785":4,"787":1,"788":1,"790":2,"791":4,"792":5,"793":1,"794":1,"795":2,"796":1,"797":10,"798":3,"799":1,"800":6,"801":1,"802":3,"803":17,"804":1,"805":1,"806":2,"808":9}}],["tomlvim",{"2":{"695":1}}],["tomldiscard",{"2":{"659":1}}],["tomlexternal",{"2":{"656":1}}],["tomlsed",{"2":{"655":1}}],["tomlseeds=$",{"2":{"639":2}}],["tomlrpc",{"2":{"649":1}}],["tomlpruning",{"2":{"645":1,"646":1}}],["tomlpersistent",{"2":{"639":3}}],["tomlmin",{"2":{"643":1}}],["tomlindexer",{"2":{"642":1,"644":1,"658":1}}],["toml`",{"2":{"639":2}}],["toml",{"0":{"585":1,"625":1,"627":1},"1":{"626":1,"627":1,"628":2,"629":2,"630":2,"631":2,"632":2,"633":2},"2":{"403":2,"556":1,"557":1,"585":8,"618":3,"627":4,"639":7,"641":1,"643":1,"644":1,"645":1,"646":2,"649":2,"655":2,"656":1,"658":2,"659":2,"695":3,"697":1,"701":1,"717":1,"805":1}}],["tombstoned",{"2":{"25":1}}],["todo",{"2":{"326":2,"411":2,"412":3,"413":3,"415":1,"437":6}}],["today",{"2":{"240":1,"303":1,"553":2}}],["toggleview",{"2":{"314":6}}],["together",{"2":{"52":1,"337":1,"461":1,"467":1,"469":1,"470":1,"557":1}}],["tostring",{"2":{"314":4}}],["tosliceofbytes",{"2":{"159":2}}],["toattestationproof",{"2":{"169":2,"172":4}}],["torowproofs",{"2":{"168":2,"172":4}}],["torowroots",{"2":{"167":2,"172":4}}],["tonamespacenode",{"2":{"165":4,"167":2,"172":6}}],["tonamespacemerklemultiproofs",{"2":{"165":2,"172":4}}],["token=$",{"2":{"371":4,"373":2,"391":2}}],["tokencelestia",{"2":{"369":1}}],["tokenbridgeretryablesender",{"2":{"96":1,"97":1}}],["tokenbridgecreator",{"2":{"96":1,"97":1}}],["tokenbridgedeployment",{"2":{"91":2}}],["token",{"0":{"371":1,"373":1,"512":1,"547":1,"704":1},"2":{"80":1,"82":2,"84":8,"86":1,"89":8,"91":13,"93":1,"323":4,"324":4,"325":4,"326":4,"327":4,"369":7,"370":9,"371":6,"372":3,"373":2,"374":4,"379":1,"391":3,"397":2,"412":2,"413":2,"415":2,"418":4,"419":4,"420":4,"421":4,"436":4,"471":1,"508":3,"547":1,"549":1,"608":1,"703":1,"704":3}}],["tokens",{"0":{"476":1,"485":1,"551":1,"728":1},"2":{"8":1,"30":2,"33":1,"43":1,"80":1,"84":1,"85":1,"367":2,"386":1,"393":2,"407":2,"471":1,"476":1,"477":1,"481":1,"484":1,"486":1,"499":1,"500":6,"525":2,"526":1,"538":3,"547":1,"551":2,"576":1,"591":2,"685":3,"693":1,"696":2,"704":1,"727":1,"728":1,"765":3,"797":1,"803":1}}],["touch",{"2":{"65":1}}],["too",{"0":{"617":1},"2":{"617":3,"715":2}}],["tools",{"2":{"338":1}}],["toolset",{"2":{"213":1}}],["toolkit",{"0":{"57":1},"1":{"58":1,"59":1,"60":1,"61":1,"62":1,"63":1},"2":{"56":1,"57":1}}],["tool",{"2":{"31":1,"55":1,"213":1,"311":1,"542":2,"555":1,"659":1,"692":1}}],["toolings",{"2":{"602":1}}],["tooling",{"2":{"24":1,"175":1,"177":1,"193":1}}],["took",{"2":{"31":1}}],["topology",{"2":{"649":1}}],["topic",{"2":{"36":1,"42":1,"43":1,"456":1,"548":1}}],["topics",{"2":{"2":1,"36":1,"43":2,"48":2,"238":1}}],["top",{"2":{"24":2,"65":1,"68":1,"353":1,"444":1,"445":1,"466":1,"467":1,"479":1,"569":1,"742":1,"743":1,"744":1,"751":1,"767":1}}],["totaldifficulty",{"2":{"395":2}}],["total",{"2":{"21":1,"22":1,"76":1,"151":2,"153":2,"156":2,"161":2,"168":3,"169":2,"172":4,"183":1,"318":1,"383":4,"426":2,"428":1,"429":2,"430":6,"495":1,"499":1,"505":1,"579":4,"738":5}}],["towards",{"2":{"19":1,"25":1,"44":1,"563":1}}],["toward",{"2":{"8":1,"16":1}}],["to",{"0":{"59":1,"67":1,"69":1,"71":1,"104":1,"112":1,"136":1,"142":1,"143":1,"153":1,"163":1,"174":1,"208":1,"229":1,"238":1,"277":1,"310":1,"315":1,"325":1,"326":1,"336":1,"337":1,"366":1,"386":1,"402":1,"403":1,"420":1,"425":1,"437":1,"438":1,"443":1,"444":1,"445":1,"459":1,"471":1,"540":1,"553":1,"565":1,"616":1,"641":1,"662":1,"687":1,"730":1,"769":1,"797":1},"1":{"68":1,"69":1,"105":1,"106":1,"107":1,"108":1,"109":1,"110":1,"111":1,"113":1,"114":1,"115":1,"116":1,"117":1,"118":1,"119":1,"120":1,"121":1,"122":1,"164":1,"165":1,"166":1,"167":1,"168":1,"169":1,"170":1,"171":1,"172":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,"200":1,"201":1,"202":1,"203":1,"204":1,"205":1,"206":1,"207":1,"208":1,"230":1,"231":1,"232":1,"233":1,"234":1,"235":1,"236":1,"237":1,"238":1,"239":1,"240":1,"338":1,"339":1,"340":1,"341":1,"426":1,"427":1,"428":1,"429":1,"430":1,"431":1,"432":1,"433":1,"434":1,"435":1,"436":1,"437":1,"438":1,"472":1,"473":1,"474":1,"475":1,"476":1,"477":1,"478":1,"479":1,"480":1,"481":1,"482":1,"483":1,"484":1,"485":1,"486":1,"566":1,"567":1,"568":1,"569":1,"570":1,"571":1,"572":1,"573":1,"574":1,"575":1,"576":1,"577":1,"578":1,"579":1,"580":1,"581":1,"582":1,"583":1,"584":1,"585":1,"586":1,"587":1,"642":1,"643":1,"663":1,"664":1,"770":1,"771":1,"772":1},"2":{"0":2,"1":1,"2":4,"5":2,"7":3,"8":3,"9":3,"11":2,"14":1,"15":1,"17":1,"19":5,"21":5,"22":1,"23":1,"24":7,"25":3,"26":4,"27":5,"28":1,"30":9,"31":20,"32":5,"33":12,"34":51,"35":3,"36":7,"37":1,"38":3,"39":2,"40":7,"41":4,"42":8,"43":14,"44":14,"45":10,"46":7,"47":14,"48":13,"49":1,"50":3,"52":4,"53":4,"54":2,"55":2,"56":2,"57":4,"59":2,"60":1,"61":1,"62":2,"63":1,"64":1,"65":6,"66":1,"69":3,"71":7,"72":3,"73":1,"74":1,"76":7,"77":2,"79":3,"82":5,"83":7,"84":19,"85":10,"86":5,"88":15,"89":21,"90":2,"91":21,"92":1,"94":1,"95":1,"102":2,"103":3,"105":2,"106":1,"107":15,"108":6,"109":4,"110":8,"111":1,"113":3,"116":3,"117":4,"119":1,"120":5,"121":4,"122":4,"125":1,"126":1,"127":6,"128":2,"129":1,"130":4,"131":21,"133":8,"134":23,"135":21,"136":8,"137":8,"139":13,"142":2,"143":1,"145":8,"146":5,"148":17,"149":5,"150":8,"151":4,"153":16,"154":5,"156":5,"160":8,"161":3,"163":27,"164":3,"165":12,"166":4,"168":7,"169":19,"170":10,"171":2,"172":22,"173":3,"174":4,"175":1,"177":24,"178":6,"179":3,"180":4,"181":5,"183":10,"184":18,"187":6,"188":6,"189":5,"191":2,"192":14,"193":1,"194":2,"195":3,"196":8,"197":1,"199":5,"200":5,"202":3,"203":8,"208":8,"209":2,"210":4,"211":44,"212":9,"213":11,"214":3,"215":4,"217":7,"219":14,"220":17,"221":3,"222":3,"223":7,"224":9,"225":5,"226":5,"227":1,"228":2,"230":5,"233":1,"234":1,"235":4,"236":17,"237":1,"239":1,"240":1,"242":3,"243":3,"244":5,"245":2,"246":2,"247":2,"248":2,"250":3,"251":1,"252":2,"253":2,"254":1,"256":2,"258":1,"261":3,"262":5,"264":6,"265":6,"266":4,"267":1,"268":1,"269":1,"270":6,"272":1,"275":1,"276":7,"277":4,"278":1,"281":3,"282":4,"284":2,"285":5,"286":4,"287":3,"288":7,"290":3,"291":1,"292":4,"293":4,"294":3,"295":1,"296":1,"297":1,"298":1,"299":1,"300":2,"301":1,"302":7,"304":3,"305":1,"306":5,"307":1,"308":3,"309":3,"310":12,"311":1,"312":1,"313":6,"314":15,"315":2,"316":11,"317":1,"318":9,"319":2,"321":1,"323":7,"324":7,"325":5,"326":7,"327":2,"328":1,"330":2,"331":3,"333":2,"334":1,"336":3,"337":4,"338":9,"340":1,"341":1,"343":2,"344":1,"347":1,"348":2,"351":2,"353":2,"355":3,"356":1,"357":4,"359":2,"361":2,"362":3,"366":9,"367":8,"368":2,"369":10,"370":3,"371":5,"372":6,"373":1,"374":8,"375":1,"376":9,"377":4,"379":1,"381":1,"382":1,"386":1,"387":1,"388":2,"389":2,"391":4,"392":2,"393":1,"396":5,"397":1,"398":1,"399":3,"401":7,"402":2,"403":7,"405":7,"406":1,"407":5,"408":3,"410":1,"411":2,"412":6,"413":25,"414":3,"415":12,"416":8,"418":7,"419":7,"420":3,"421":4,"422":1,"423":1,"424":7,"425":2,"426":3,"428":3,"429":4,"430":9,"432":8,"436":7,"437":26,"441":2,"442":4,"443":14,"444":4,"445":3,"447":7,"448":3,"449":4,"450":2,"451":3,"452":7,"453":1,"454":5,"457":7,"458":4,"460":7,"461":4,"462":3,"463":6,"464":6,"466":9,"467":8,"468":8,"469":11,"470":8,"471":2,"474":1,"479":2,"480":1,"483":1,"485":1,"486":1,"488":6,"490":2,"491":3,"492":18,"494":3,"495":4,"497":3,"498":3,"499":2,"500":8,"501":2,"502":1,"503":1,"507":1,"508":5,"509":2,"510":1,"516":3,"519":9,"520":1,"521":2,"523":3,"524":6,"525":1,"529":1,"530":1,"531":5,"536":1,"537":7,"538":7,"539":1,"540":3,"542":6,"545":4,"546":1,"547":6,"548":12,"549":10,"551":2,"555":2,"556":6,"557":23,"558":3,"559":4,"560":2,"561":8,"562":2,"563":10,"564":1,"565":3,"566":1,"569":1,"570":1,"571":3,"572":1,"573":2,"575":3,"576":8,"577":1,"579":1,"580":2,"581":3,"582":1,"583":6,"584":2,"585":3,"586":1,"587":2,"589":1,"590":2,"591":6,"593":5,"594":4,"595":6,"596":1,"598":4,"601":10,"602":6,"604":4,"605":2,"606":6,"608":2,"609":3,"611":2,"612":1,"613":3,"614":3,"616":4,"617":6,"618":5,"619":1,"621":1,"622":4,"623":2,"624":2,"628":1,"630":4,"631":3,"633":1,"634":2,"639":9,"641":2,"644":2,"645":2,"646":3,"647":2,"648":2,"649":4,"650":1,"651":4,"654":2,"655":3,"656":2,"657":1,"658":12,"659":9,"661":6,"662":1,"663":3,"664":1,"665":10,"667":5,"668":9,"669":6,"670":2,"673":3,"674":1,"675":1,"676":4,"677":1,"678":1,"685":14,"686":1,"687":3,"688":1,"689":2,"690":5,"691":6,"692":10,"693":3,"694":2,"695":2,"696":7,"697":1,"698":2,"699":2,"700":4,"701":1,"703":2,"704":4,"705":4,"706":1,"707":1,"708":1,"709":2,"712":1,"714":3,"715":1,"716":4,"717":6,"718":2,"719":3,"720":1,"721":1,"726":6,"727":2,"728":2,"729":1,"730":3,"733":2,"734":2,"737":1,"738":2,"739":10,"740":1,"747":3,"748":7,"749":1,"753":2,"754":21,"758":1,"759":3,"760":4,"761":2,"762":2,"763":3,"764":1,"765":1,"768":2,"769":3,"772":1,"774":1,"777":3,"779":3,"781":2,"782":2,"783":4,"784":2,"785":9,"787":1,"788":2,"790":1,"791":1,"792":1,"793":1,"797":7,"798":4,"800":4,"803":13,"804":1,"805":3,"806":1,"808":6}}]],"serializationVersion":2}';export{e as default}; diff --git a/pr-1680/assets/chunks/ArabicaVersionTags.e01dd824.js b/pr-1680/assets/chunks/ArabicaVersionTags.20a10f87.js similarity index 86% rename from pr-1680/assets/chunks/ArabicaVersionTags.e01dd824.js rename to pr-1680/assets/chunks/ArabicaVersionTags.20a10f87.js index caea7f5ce3..ab4b62b1be 100644 --- a/pr-1680/assets/chunks/ArabicaVersionTags.e01dd824.js +++ b/pr-1680/assets/chunks/ArabicaVersionTags.20a10f87.js @@ -1 +1 @@ -import{a as r}from"./arabica_versions.6d89be6e.js";import{c as s}from"./constants.0e6df566.js";import{_ as o,o as n,c as l,k as e,t as a}from"./framework.a504a440.js";const c={name:"ArabicaVersionTags",data(){return{arabicaVersions:r,constants:s}}},i=e("tr",null,[e("th",null,"Software"),e("th",null,"Version")],-1),p=e("td",null,"celestia-node",-1),_=["href"],h=e("td",null,"celestia-app",-1),u=["href"];function g(d,f,b,m,t,V){return n(),l("table",null,[i,e("tr",null,[p,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-node/releases/tag/${t.arabicaVersions["node-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},a(t.arabicaVersions["node-latest-tag"]),9,_)])]),e("tr",null,[h,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-app/releases/tag/${t.arabicaVersions["app-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},a(t.arabicaVersions["app-latest-tag"]),9,u)])])])}const B=o(c,[["render",g]]);export{B as A}; +import{a as r}from"./arabica_versions.1930378b.js";import{c as s}from"./constants.295fc0ab.js";import{_ as o,o as n,c as l,k as e,t as a}from"./framework.a504a440.js";const c={name:"ArabicaVersionTags",data(){return{arabicaVersions:r,constants:s}}},i=e("tr",null,[e("th",null,"Software"),e("th",null,"Version")],-1),p=e("td",null,"celestia-node",-1),_=["href"],h=e("td",null,"celestia-app",-1),u=["href"];function g(d,f,b,m,t,V){return n(),l("table",null,[i,e("tr",null,[p,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-node/releases/tag/${t.arabicaVersions["node-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},a(t.arabicaVersions["node-latest-tag"]),9,_)])]),e("tr",null,[h,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-app/releases/tag/${t.arabicaVersions["app-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},a(t.arabicaVersions["app-latest-tag"]),9,u)])])])}const B=o(c,[["render",g]]);export{B as A}; diff --git a/pr-1680/assets/chunks/MainnetVersionTags.1cb0f3c9.js b/pr-1680/assets/chunks/MainnetVersionTags.8346f766.js similarity index 93% rename from pr-1680/assets/chunks/MainnetVersionTags.1cb0f3c9.js rename to pr-1680/assets/chunks/MainnetVersionTags.8346f766.js index 9f334dcb93..33c24049fb 100644 --- a/pr-1680/assets/chunks/MainnetVersionTags.1cb0f3c9.js +++ b/pr-1680/assets/chunks/MainnetVersionTags.8346f766.js @@ -1 +1 @@ -import{m as s}from"./mainnet_versions.1d5e6ed9.js";import{c as o}from"./constants.0e6df566.js";import{_ as r,o as a,c as l,k as e,t as n}from"./framework.a504a440.js";const i={name:"MainnetVersionTags",data(){return{mainnetVersions:s,constants:o}}},c=e("tr",null,[e("th",null,"Software"),e("th",null,"Version")],-1),p=e("td",null,"celestia-node",-1),_=["href"],m=e("td",null,"celestia-app",-1),h=["href"];function u(g,d,f,V,t,b){return a(),l("table",null,[c,e("tr",null,[p,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-node/releases/tag/${t.mainnetVersions["node-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},n(t.mainnetVersions["node-latest-tag"]),9,_)])]),e("tr",null,[m,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-app/releases/tag/${t.mainnetVersions["app-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},n(t.mainnetVersions["app-latest-tag"]),9,h)])])])}const M=r(i,[["render",u]]);export{M}; +import{m as s}from"./mainnet_versions.1d5e6ed9.js";import{c as o}from"./constants.295fc0ab.js";import{_ as r,o as a,c as l,k as e,t as n}from"./framework.a504a440.js";const i={name:"MainnetVersionTags",data(){return{mainnetVersions:s,constants:o}}},c=e("tr",null,[e("th",null,"Software"),e("th",null,"Version")],-1),p=e("td",null,"celestia-node",-1),_=["href"],m=e("td",null,"celestia-app",-1),h=["href"];function u(g,d,f,V,t,b){return a(),l("table",null,[c,e("tr",null,[p,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-node/releases/tag/${t.mainnetVersions["node-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},n(t.mainnetVersions["node-latest-tag"]),9,_)])]),e("tr",null,[m,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-app/releases/tag/${t.mainnetVersions["app-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},n(t.mainnetVersions["app-latest-tag"]),9,h)])])])}const M=r(i,[["render",u]]);export{M}; diff --git a/pr-1680/assets/chunks/MochaVersionTags.83273d07.js b/pr-1680/assets/chunks/MochaVersionTags.78e5b38e.js similarity index 86% rename from pr-1680/assets/chunks/MochaVersionTags.83273d07.js rename to pr-1680/assets/chunks/MochaVersionTags.78e5b38e.js index 2852e08163..ca0452d26c 100644 --- a/pr-1680/assets/chunks/MochaVersionTags.83273d07.js +++ b/pr-1680/assets/chunks/MochaVersionTags.78e5b38e.js @@ -1 +1 @@ -import{m as s}from"./mocha_versions.ffd4ea25.js";import{c as r}from"./constants.0e6df566.js";import{_ as a,o as n,c as l,k as e,t as o}from"./framework.a504a440.js";const c={name:"MochaVersionTags",data(){return{mochaVersions:s,constants:r}}},i=e("tr",null,[e("th",null,"Software"),e("th",null,"Version")],-1),h=e("td",null,"celestia-node",-1),p=["href"],_=e("td",null,"celestia-app",-1),m=["href"];function u(g,d,f,V,t,b){return n(),l("table",null,[i,e("tr",null,[h,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-node/releases/tag/${t.mochaVersions["node-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},o(t.mochaVersions["node-latest-tag"]),9,p)])]),e("tr",null,[_,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-app/releases/tag/${t.mochaVersions["app-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},o(t.mochaVersions["app-latest-tag"]),9,m)])])])}const M=a(c,[["render",u]]);export{M}; +import{m as s}from"./mocha_versions.7704b055.js";import{c as r}from"./constants.295fc0ab.js";import{_ as a,o as n,c as l,k as e,t as o}from"./framework.a504a440.js";const c={name:"MochaVersionTags",data(){return{mochaVersions:s,constants:r}}},i=e("tr",null,[e("th",null,"Software"),e("th",null,"Version")],-1),h=e("td",null,"celestia-node",-1),p=["href"],_=e("td",null,"celestia-app",-1),m=["href"];function u(g,d,f,V,t,b){return n(),l("table",null,[i,e("tr",null,[h,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-node/releases/tag/${t.mochaVersions["node-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},o(t.mochaVersions["node-latest-tag"]),9,p)])]),e("tr",null,[_,e("td",null,[e("a",{href:`https://github.com/celestiaorg/celestia-app/releases/tag/${t.mochaVersions["app-latest-tag"]}`,target:"_blank",rel:"noopener noreferrer"},o(t.mochaVersions["app-latest-tag"]),9,m)])])])}const M=a(c,[["render",u]]);export{M}; diff --git a/pr-1680/assets/chunks/VPLocalSearchBox.c92a90f5.js b/pr-1680/assets/chunks/VPLocalSearchBox.640545fb.js similarity index 99% rename from pr-1680/assets/chunks/VPLocalSearchBox.c92a90f5.js rename to pr-1680/assets/chunks/VPLocalSearchBox.640545fb.js index 8d80db3f8f..21fd3e8816 100644 --- a/pr-1680/assets/chunks/VPLocalSearchBox.c92a90f5.js +++ b/pr-1680/assets/chunks/VPLocalSearchBox.640545fb.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.a504a440.js";import{u as er,c as tr}from"./theme.c177f54e.js";const rr={root:()=>pt(()=>import("./@localSearchIndexroot.a2a5e800.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.a504a440.js";import{u as er,c as tr}from"./theme.cfd5f84b.js";const rr={root:()=>pt(()=>import("./@localSearchIndexroot.f0900312.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-1680/assets/chunks/mocha_versions.ffd4ea25.js b/pr-1680/assets/chunks/arabica_versions.1930378b.js similarity index 59% rename from pr-1680/assets/chunks/mocha_versions.ffd4ea25.js rename to pr-1680/assets/chunks/arabica_versions.1930378b.js index b22095d082..f1a9d0e16f 100644 --- a/pr-1680/assets/chunks/mocha_versions.ffd4ea25.js +++ b/pr-1680/assets/chunks/arabica_versions.1930378b.js @@ -1 +1 @@ -const e=Object.freeze({"app-latest-tag":"v2.1.2","app-latest-sha":"48173df3dc78f9348eedb3796f29ef9e9e5dc584","core-latest-tag":"v1.40.1-tm-v0.34.29-rc0","core-latest-sha":"0d2b63836d0f4587e162bfded58f53fba238e69c","node-latest-tag":"v0.16.0-rc0","node-latest-sha":"603288597fbd82c44aaa0a0ac8d187cac1860431"});export{e as m}; +const e=Object.freeze({"app-latest-tag":"v2.1.2","app-latest-sha":"48173df3dc78f9348eedb3796f29ef9e9e5dc584","core-latest-tag":"v1.40.1-tm-v0.34.29-rc0","core-latest-sha":"0d2b63836d0f4587e162bfded58f53fba238e69c","node-latest-tag":"v0.16.0","node-latest-sha":"6744f648649ebb5fee1b27faf7aca96ecf4519b2"});export{e as a}; diff --git a/pr-1680/assets/chunks/arabica_versions.6d89be6e.js b/pr-1680/assets/chunks/arabica_versions.6d89be6e.js deleted file mode 100644 index e140151978..0000000000 --- a/pr-1680/assets/chunks/arabica_versions.6d89be6e.js +++ /dev/null @@ -1 +0,0 @@ -const a=Object.freeze({"app-latest-tag":"v2.1.2","app-latest-sha":"48173df3dc78f9348eedb3796f29ef9e9e5dc584","core-latest-tag":"v1.40.1-tm-v0.34.29-rc0","core-latest-sha":"0d2b63836d0f4587e162bfded58f53fba238e69c","node-latest-tag":"v0.16.0-rc0","node-latest-sha":"603288597fbd82c44aaa0a0ac8d187cac1860431"});export{a}; diff --git a/pr-1680/assets/chunks/constants.0e6df566.js b/pr-1680/assets/chunks/constants.295fc0ab.js similarity index 82% rename from pr-1680/assets/chunks/constants.0e6df566.js rename to pr-1680/assets/chunks/constants.295fc0ab.js index 7c87048a95..38863d0d6c 100644 --- a/pr-1680/assets/chunks/constants.0e6df566.js +++ b/pr-1680/assets/chunks/constants.295fc0ab.js @@ -1 +1 @@ -const a=Object.freeze({golangNodeMainnet:"1.22.0",golangNodeMocha:"1.22.0",golangNodeArabica:"1.22.0",golangApp:"1.22.0",golangCore:"1.22.0",golang:"1.22.0",arabicaChainId:"arabica-11",mainnetChainId:"celestia",mochaChainId:"mocha-4",arabicaRollkitVersion:"v0.10.5",mochaRollkitVersion:"v0.10.5",mainnetRollkitVersion:"v0.10.5",localCelestiaDevnetVersion:"v0.8.2",golangBlobstream:"1.21.4",orchrelayVersion:"v1.0.1",mochaRpcUrl:"https://rpc-mocha.pops.one/",mochaRestUrl:"https://api-mocha.pops.one/",arabicaRpcUrl:"https://rpc.celestia-arabica-11.com/",arabicaRestUrl:"https://api.celestia-arabica-11.com",mainnetRpcUrl:"https://rpc.lunaroasis.net/",mainnetRestUrl:"https://api.lunaroasis.net/"});export{a as c}; +const a=Object.freeze({golangNodeMainnet:"1.22.0",golangNodeMocha:"1.23.0",golangNodeArabica:"1.23.0",golangApp:"1.22.6",golangCore:"1.22.6",golang:"1.22.0",arabicaChainId:"arabica-11",mainnetChainId:"celestia",mochaChainId:"mocha-4",arabicaRollkitVersion:"v0.10.5",mochaRollkitVersion:"v0.10.5",mainnetRollkitVersion:"v0.10.5",localCelestiaDevnetVersion:"v0.8.2",golangBlobstream:"1.21.4",orchrelayVersion:"v1.0.1",mochaRpcUrl:"https://rpc-mocha.pops.one/",mochaRestUrl:"https://api-mocha.pops.one/",arabicaRpcUrl:"https://rpc.celestia-arabica-11.com/",arabicaRestUrl:"https://api.celestia-arabica-11.com",mainnetRpcUrl:"https://rpc.lunaroasis.net/",mainnetRestUrl:"https://api.lunaroasis.net/"});export{a as c}; diff --git a/pr-1680/assets/chunks/mocha_versions.7704b055.js b/pr-1680/assets/chunks/mocha_versions.7704b055.js new file mode 100644 index 0000000000..c73494bf47 --- /dev/null +++ b/pr-1680/assets/chunks/mocha_versions.7704b055.js @@ -0,0 +1 @@ +const e=Object.freeze({"app-latest-tag":"v2.1.2","app-latest-sha":"48173df3dc78f9348eedb3796f29ef9e9e5dc584","core-latest-tag":"v1.40.1-tm-v0.34.29-rc0","core-latest-sha":"0d2b63836d0f4587e162bfded58f53fba238e69c","node-latest-tag":"v0.16.0","node-latest-sha":"6744f648649ebb5fee1b27faf7aca96ecf4519b2"});export{e as m}; diff --git a/pr-1680/assets/chunks/theme.c177f54e.js b/pr-1680/assets/chunks/theme.cfd5f84b.js similarity index 99% rename from pr-1680/assets/chunks/theme.c177f54e.js rename to pr-1680/assets/chunks/theme.cfd5f84b.js index 2d6d039a89..7d72400ae3 100644 --- a/pr-1680/assets/chunks/theme.c177f54e.js +++ b/pr-1680/assets/chunks/theme.cfd5f84b.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.a504a440.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.c92a90f5.js"),["assets/chunks/VPLocalSearchBox.c92a90f5.js","assets/chunks/framework.a504a440.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.a504a440.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.640545fb.js"),["assets/chunks/VPLocalSearchBox.640545fb.js","assets/chunks/framework.a504a440.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-1680/assets/community_calendar.md.cec7b00a.js b/pr-1680/assets/community_calendar.md.97a43115.js similarity index 95% rename from pr-1680/assets/community_calendar.md.cec7b00a.js rename to pr-1680/assets/community_calendar.md.97a43115.js index 617c44114d..987965cffb 100644 --- a/pr-1680/assets/community_calendar.md.cec7b00a.js +++ b/pr-1680/assets/community_calendar.md.97a43115.js @@ -1 +1 @@ -import{_ as t,o as n,c as o,k as e,a}from"./chunks/framework.a504a440.js";const b=JSON.parse(`{"title":"Community calendar","description":"Find all the different community call events happening in Celestia's community.","frontmatter":{"description":"Find all the different community call events happening in Celestia's community.","head":[["meta",{"name":"og:title","content":"Community calendar | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/calendar.md","filePath":"community/calendar.md","lastUpdated":1724867275000}`),l={name:"community/calendar.md"},c=e("h1",{id:"community-calendar",tabindex:"-1"},[a("Community calendar "),e("a",{class:"header-anchor",href:"#community-calendar","aria-label":'Permalink to "Community calendar"'},"​")],-1),i=e("p",null,"The Celestia community calendar is available for finding all the different community call events happening in Celestia's community.",-1),r=e("p",null,[e("a",{href:"https://calendar.google.com/calendar/u/0?cid=Y19za2JzbjIzNWszYmlzdHNoZ3RvNmw5ODYyNEBncm91cC5jYWxlbmRhci5nb29nbGUuY29t",target:"_blank",rel:"noreferrer"},"Add the community calendar to your personal calendar"),a(" to stay updated with all the events.")],-1),s=e("p",null,[a("Explore "),e("a",{href:"https://github.com/celestiaorg/community-calls/blob/main/README.md",target:"_blank",rel:"noreferrer"},"past community call agendas, notes, and recordings"),a(" for more insights.")],-1),m=[c,i,r,s];function d(u,h,p,f,_,y){return n(),o("div",null,m)}const C=t(l,[["render",d]]);export{b as __pageData,C as default}; +import{_ as t,o as n,c as o,k as e,a}from"./chunks/framework.a504a440.js";const b=JSON.parse(`{"title":"Community calendar","description":"Find all the different community call events happening in Celestia's community.","frontmatter":{"description":"Find all the different community call events happening in Celestia's community.","head":[["meta",{"name":"og:title","content":"Community calendar | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/calendar.md","filePath":"community/calendar.md","lastUpdated":1725955670000}`),l={name:"community/calendar.md"},c=e("h1",{id:"community-calendar",tabindex:"-1"},[a("Community calendar "),e("a",{class:"header-anchor",href:"#community-calendar","aria-label":'Permalink to "Community calendar"'},"​")],-1),i=e("p",null,"The Celestia community calendar is available for finding all the different community call events happening in Celestia's community.",-1),r=e("p",null,[e("a",{href:"https://calendar.google.com/calendar/u/0?cid=Y19za2JzbjIzNWszYmlzdHNoZ3RvNmw5ODYyNEBncm91cC5jYWxlbmRhci5nb29nbGUuY29t",target:"_blank",rel:"noreferrer"},"Add the community calendar to your personal calendar"),a(" to stay updated with all the events.")],-1),s=e("p",null,[a("Explore "),e("a",{href:"https://github.com/celestiaorg/community-calls/blob/main/README.md",target:"_blank",rel:"noreferrer"},"past community call agendas, notes, and recordings"),a(" for more insights.")],-1),m=[c,i,r,s];function d(u,h,p,f,_,y){return n(),o("div",null,m)}const C=t(l,[["render",d]]);export{b as __pageData,C as default}; diff --git a/pr-1680/assets/community_calendar.md.cec7b00a.lean.js b/pr-1680/assets/community_calendar.md.97a43115.lean.js similarity index 95% rename from pr-1680/assets/community_calendar.md.cec7b00a.lean.js rename to pr-1680/assets/community_calendar.md.97a43115.lean.js index 617c44114d..987965cffb 100644 --- a/pr-1680/assets/community_calendar.md.cec7b00a.lean.js +++ b/pr-1680/assets/community_calendar.md.97a43115.lean.js @@ -1 +1 @@ -import{_ as t,o as n,c as o,k as e,a}from"./chunks/framework.a504a440.js";const b=JSON.parse(`{"title":"Community calendar","description":"Find all the different community call events happening in Celestia's community.","frontmatter":{"description":"Find all the different community call events happening in Celestia's community.","head":[["meta",{"name":"og:title","content":"Community calendar | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/calendar.md","filePath":"community/calendar.md","lastUpdated":1724867275000}`),l={name:"community/calendar.md"},c=e("h1",{id:"community-calendar",tabindex:"-1"},[a("Community calendar "),e("a",{class:"header-anchor",href:"#community-calendar","aria-label":'Permalink to "Community calendar"'},"​")],-1),i=e("p",null,"The Celestia community calendar is available for finding all the different community call events happening in Celestia's community.",-1),r=e("p",null,[e("a",{href:"https://calendar.google.com/calendar/u/0?cid=Y19za2JzbjIzNWszYmlzdHNoZ3RvNmw5ODYyNEBncm91cC5jYWxlbmRhci5nb29nbGUuY29t",target:"_blank",rel:"noreferrer"},"Add the community calendar to your personal calendar"),a(" to stay updated with all the events.")],-1),s=e("p",null,[a("Explore "),e("a",{href:"https://github.com/celestiaorg/community-calls/blob/main/README.md",target:"_blank",rel:"noreferrer"},"past community call agendas, notes, and recordings"),a(" for more insights.")],-1),m=[c,i,r,s];function d(u,h,p,f,_,y){return n(),o("div",null,m)}const C=t(l,[["render",d]]);export{b as __pageData,C as default}; +import{_ as t,o as n,c as o,k as e,a}from"./chunks/framework.a504a440.js";const b=JSON.parse(`{"title":"Community calendar","description":"Find all the different community call events happening in Celestia's community.","frontmatter":{"description":"Find all the different community call events happening in Celestia's community.","head":[["meta",{"name":"og:title","content":"Community calendar | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/calendar.md","filePath":"community/calendar.md","lastUpdated":1725955670000}`),l={name:"community/calendar.md"},c=e("h1",{id:"community-calendar",tabindex:"-1"},[a("Community calendar "),e("a",{class:"header-anchor",href:"#community-calendar","aria-label":'Permalink to "Community calendar"'},"​")],-1),i=e("p",null,"The Celestia community calendar is available for finding all the different community call events happening in Celestia's community.",-1),r=e("p",null,[e("a",{href:"https://calendar.google.com/calendar/u/0?cid=Y19za2JzbjIzNWszYmlzdHNoZ3RvNmw5ODYyNEBncm91cC5jYWxlbmRhci5nb29nbGUuY29t",target:"_blank",rel:"noreferrer"},"Add the community calendar to your personal calendar"),a(" to stay updated with all the events.")],-1),s=e("p",null,[a("Explore "),e("a",{href:"https://github.com/celestiaorg/community-calls/blob/main/README.md",target:"_blank",rel:"noreferrer"},"past community call agendas, notes, and recordings"),a(" for more insights.")],-1),m=[c,i,r,s];function d(u,h,p,f,_,y){return n(),o("div",null,m)}const C=t(l,[["render",d]]);export{b as __pageData,C as default}; diff --git a/pr-1680/assets/community_coc.md.3b3f881c.js b/pr-1680/assets/community_coc.md.532aa249.js similarity index 98% rename from pr-1680/assets/community_coc.md.3b3f881c.js rename to pr-1680/assets/community_coc.md.532aa249.js index f80916aa44..e74dbae416 100644 --- a/pr-1680/assets/community_coc.md.3b3f881c.js +++ b/pr-1680/assets/community_coc.md.532aa249.js @@ -1 +1 @@ -import{_ as e,o,c as a,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1724867275000}`),n={name:"community/coc.md"},i=t('

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(),a("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; +import{_ as e,o,c as a,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1725955670000}`),n={name:"community/coc.md"},i=t('

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(),a("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; diff --git a/pr-1680/assets/community_coc.md.3b3f881c.lean.js b/pr-1680/assets/community_coc.md.532aa249.lean.js similarity index 82% rename from pr-1680/assets/community_coc.md.3b3f881c.lean.js rename to pr-1680/assets/community_coc.md.532aa249.lean.js index 61bba52a31..9a045e5fcb 100644 --- a/pr-1680/assets/community_coc.md.3b3f881c.lean.js +++ b/pr-1680/assets/community_coc.md.532aa249.lean.js @@ -1 +1 @@ -import{_ as e,o,c as a,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1724867275000}`),n={name:"community/coc.md"},i=t("",35),r=[i];function s(c,l,d,p,u,h){return o(),a("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; +import{_ as e,o,c as a,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Celestia.org Code of Conduct | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/coc.md","filePath":"community/coc.md","lastUpdated":1725955670000}`),n={name:"community/coc.md"},i=t("",35),r=[i];function s(c,l,d,p,u,h){return o(),a("div",null,r)}const g=e(n,[["render",s]]);export{f as __pageData,g as default}; diff --git a/pr-1680/assets/community_foundation-delegation-program.md.d130506e.js b/pr-1680/assets/community_foundation-delegation-program.md.ef8a9b75.js similarity index 99% rename from pr-1680/assets/community_foundation-delegation-program.md.d130506e.js rename to pr-1680/assets/community_foundation-delegation-program.md.ef8a9b75.js index e727ccb34f..7c37e9fe07 100644 --- a/pr-1680/assets/community_foundation-delegation-program.md.d130506e.js +++ b/pr-1680/assets/community_foundation-delegation-program.md.ef8a9b75.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1680/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1724867275000}'),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 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 validator or an active Mocha testnet validator for at least 1 month before application deadline
  • Run a bridge node (on mainnet if you are already an active mainnet 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 + 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
    • If you don't run an active mainnet 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 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.a504a440.js";const o="/docs-preview/pr-1680/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1680/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1725955670000}'),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 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 validator or an active Mocha testnet validator for at least 1 month before application deadline
  • Run a bridge node (on mainnet if you are already an active mainnet 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 + 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
    • If you don't run an active mainnet 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 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-1680/assets/community_foundation-delegation-program.md.d130506e.lean.js b/pr-1680/assets/community_foundation-delegation-program.md.ef8a9b75.lean.js similarity index 91% rename from pr-1680/assets/community_foundation-delegation-program.md.d130506e.lean.js rename to pr-1680/assets/community_foundation-delegation-program.md.ef8a9b75.lean.js index 5dda23b198..1a9a04dd49 100644 --- a/pr-1680/assets/community_foundation-delegation-program.md.d130506e.lean.js +++ b/pr-1680/assets/community_foundation-delegation-program.md.ef8a9b75.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1680/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1724867275000}'),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.a504a440.js";const o="/docs-preview/pr-1680/img/foundation-delegation-program.jpg",r="/docs-preview/pr-1680/img/cohort-timeline.jpg",b=JSON.parse('{"title":"The Celestia Foundation Delegation Program","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"The Celestia Foundation Delegation Program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/foundation-delegation-program.md","filePath":"community/foundation-delegation-program.md","lastUpdated":1725955670000}'),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-1680/assets/community_itn-tos.md.c448efcc.js b/pr-1680/assets/community_itn-tos.md.89c55442.js similarity index 99% rename from pr-1680/assets/community_itn-tos.md.c448efcc.js rename to pr-1680/assets/community_itn-tos.md.89c55442.js index 7738d7e161..ae4d7f4e4f 100644 --- a/pr-1680/assets/community_itn-tos.md.c448efcc.js +++ b/pr-1680/assets/community_itn-tos.md.89c55442.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const m=JSON.parse('{"title":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS","description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","frontmatter":{"description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","lastUpdated":false,"editLink":false,"head":[["meta",{"name":"og:title","content":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/itn-tos.md","filePath":"community/itn-tos.md","lastUpdated":1724867275000}'),r={name:"community/itn-tos.md"},n=a('

SUPPLEMENTAL INCENTIVIZED TESTNET TERMS

Last Revised on 1/16/2023

Welcome to the Supplemental Terms (these "ITN Award Program Terms" or "Terms") for the Incentivized Testnet Award Program (the "ITN Award Program" or the "Program") as operated on behalf of Strange Loop Labs AG ("Company", "we" or "us"). The ITN Award Program provides eligible users of a Testnet designated by the Company the opportunity to earn rewards, which may include Celestia tokens. These Terms are supplemental to, and incorporate by reference, the broader Celestia Terms of Service ("Services Terms") available at Celestia Terms of Service.

Defined terms used but not defined herein have the meaning set forth in the Services Terms. The Program and your participation in it is a Service as defined under the Services Terms.

These Terms govern your ability to participate in the Program and any awards you receive from that participation, which may include Celestia tokens ("ITN Rewards").

Please read these Terms carefully, as they include important information about your legal rights. By participating in the Program or claiming ITN Rewards, you are agreeing to these Terms. If you do not understand or agree to these Terms, please do not participate in the Program or claim ITN Rewards.

In order to participate in the Program you must provide certain information about you. Our collection of such information, your rights with respect to such collection, and other relevant information is described in the Celestia Privacy Policy available at Celestia Privacy Policy, and is supplemented by Section 3 of these Terms.

The Program is a discretionary Service provided by the Company, pursuant to which the Company may, in its sole discretion, provide you ITN Rewards for your successful completion of certain tasks on a Testnet designated by the Company. Please note that any such Testnet itself (as well as any other Testnets or any mainnet deployment of the Celestia Protocol) is not a Service and does not constitute an element of the Services. We do not control the Celestia Protocol and accept no liability for its operation or its deployment in any testnet or mainnet environment.

1. General Terms

1.1 You must be eighteen (18) years of age or older and capable of forming a binding contract with the Company in order to participate in the Program or receive ITN Rewards.

1.2 You agree and acknowledge that you (a) may receive ITN Rewards for free (other than applicable taxes, if any) from your participation in the Program, (b) were not previously promised ITN Rewards, unless pursuant to a separate written agreement, and (c) took no action in anticipation of or in reliance on receiving any ITN Rewards, unless pursuant to a separate written agreement.

1.3 Your eligibility to participate in or receive ITN Rewards from the Program is subject to our sole discretion. The complete list of actions you must complete to earn ITN Rewards may not have been described in the documentation released by us from time to time, you may not receive ITN Rewards even if you successfully complete such actions, and no documentation related to the Program entitles you to any ITN Rewards or to participate in the Program.

1.4 You agree and acknowledge that (a) you are not a Prohibited Person, (b) you are not a U.S. Person as defined in Rule 902(k) of Regulation S under the U.S. Securities Act of 1933, as amended (the "1933 Act" or "Act"), (c) you will not use a VPN or other tool to circumvent any geoblock or other restrictions that we may have implemented for participants in the Program, and (d) you are not participating in, and have not become eligible to participate in, the Program by receiving credentials from any other person or entity. Any circumvention or violation of the above will permanently disqualify you from participation in the Program.

1.5 You agree and acknowledge that if you are unable to claim ITN Rewards due to technical bugs, gas fees, loss of access to a Wallet or the keys thereto, or for any other reason, you will have no recourse or claim against us or any other Company Entity and that neither we nor any other Company Entity will bear any liability.

1.6 You agree and acknowledge that claiming an ITN Reward may require reliance on or an integration with third party products (e.g., a Wallet or an unaffiliated network or blockchain) that we do not control. In the event that you are unable to access such products or integrations, or if they fail for any reason, and you are unable to participate in the Program or claim ITN Rewards, you will have no recourse or claim against us or any other Company Entity and neither we nor any other Company Entity will bear any liability.

1.7 The Company may share identifying information and documentation with certain vendors or third-party providers who provide such identity verification and sanctions and watchlist screening services (the "Third-Party Services"). You agree that your access and use of such Third-Party Services is governed solely by the terms and conditions of such Third-Party Services, and the Company is not responsible or liable for, and make no representations as to any aspect of such Third-Party Services, including, without limitation, their content or the manner in which they handle, protect, manage or process data or any interaction between you and the provider of such Third-Party Services. You irrevocably waive any claim against the Company with respect to such Third-Party Services. We are not liable for any damage or loss caused or alleged to be caused by or in connection with your enablement, access or use of any such Third-Party Services, or your reliance on the privacy practices, data security processes or other policies of such Third-Party Services.

2. Taxes

2.1 You are responsible for the payment of all taxes associated with your participation in the Program and your receipt of ITN Rewards. You agree to provide the Company with any additional information and complete any required tax or other forms relating to your receipt of ITN Rewards. You may suffer adverse tax consequences as a result of your participation in the Program or your receipt of ITN Rewards. You hereby represent that (a) you have consulted with a tax adviser that you deem advisable in connection with your participation, or that you have had the opportunity to obtain tax advice but have chosen not to do so, (b) the Company has not provided you with any tax advice with respect to your participation, and (c) you are not relying on the Company for any tax advice.

3. Supplemental Privacy Information

We may collect information to help us determine the reliability or uptime of your activities within the Program, including through the use of telemetry or metrics endpoints to collect and analyse such information, and link this information to a unique identifier to represent your activities within the Program. We may display all of the foregoing information on a public dashboard.

Additionally, we may collect certain information about you from Third-Party Services and may combine information we receive from you with information we obtain from Third-Party Services, including but not limited to:

  • Transaction information. Information related to transactions in your Wallet, your Wallet address, activities performed using your Wallet, tokens received by your Wallet, or transactions initiated or completed.
  • Identification information. We collect your government identification (e.g., driver’s license, passport, etc.), proof of address, biometric information, and entity formation information if applicable. By agreeing to these Terms, you consent to our use of your biometric information, and understand and agree that our use of the biometric information is necessary for the performance of these Terms and the implementation of the Services.

We collect this information to confirm your eligibility to participate in the Program and receive ITN Rewards, comply with our legal obligations, detect and prevent fraud, and to provide you with the Program.

Any information we receive from third-party sources will be treated in accordance with the Celestia Privacy Policy, available at Celestia Privacy Policy. We are not responsible or liable for the accuracy of the information provided to us by third parties and are not responsible for any third party’s policies or practices. See Section 9 of the Celestia Privacy Policy for more information.

4. Certain Additional Representations

4.1 Receipt of Rewards Entirely for Own Account. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that any ITN Rewards you receive will be for your own account, not as a nominee or agent, and not with a view to the resale or distribution of any part thereof, and that you have no present intention of selling, granting any participation in, or otherwise distributing the same. By agreeing to these Terms, you further represent that you do not presently have any contract, undertaking, agreement or arrangement with any person to sell, transfer or grant participations to such person or to any third person, with respect to any ITN Rewards. If you are agreeing to these terms on behalf of an entity, that entity has not been formed for the specific purpose of obtaining the ITN Rewards.

4.2 Disclosure of Information. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that you have sufficient knowledge of and experience in business and financial matters to be able to evaluate the risks and merits of your participation in the Program and of any ITN Rewards and are able to bear the risks thereof. You hereby affirm that you have not relied on any representations or warranties made by the Company related to the Program, including, but not limited to, conversations of any kind, whether through oral or electronic communication, or any white paper.

4.3 Compliance with United States Securities Laws. You understand that the ITN Rewards have not been, and will not be, registered under the 1933 Act or any applicable state securities laws. You acknowledge that the availability of an exemption from the registration provisions of the Securities Act and other applicable state securities laws depends upon, among other things, the bona fide nature of your intent as described in Section 4.1 above and with respect to the accuracy of your representations as expressed throughout these Terms. You understand that the ITN Rewards may be deemed "restricted securities" under applicable United States federal and state securities laws and that, pursuant to these laws, you may be restricted from transferring any ITN Rewards unless they are registered with the Securities and Exchange Commission and qualified by state authorities, or an exemption from such registration and qualification requirements is available. You acknowledge that the Company does not undertake any obligation to register or qualify the ITN Rewards for resale, and exemptions from registration and qualification may not be available or may not permit you to transfer all or any of the ITN Rewards in the amounts or at the times proposed by you. You further acknowledge that if an exemption from registration or qualification is available, such exemption may be conditioned on various requirements including, but not limited to, the time and manner of sale, the holding period for the ITN Rewards, and on other factors outside of your control, for which the Company makes no assurances and may not be able to satisfy.

4.4 Compliance with Liechtenstein Security Law. You understand that nothing in these Terms will be deemed to constitute a prospectus of any sort in Liechtenstein or in any jurisdiction in the EU; nor does it in any way pertain to a public offering or a solicitation of an offer to buy any securities in Liechtenstein or in any jurisdiction in the EU.

4.5 No Public Market. You understand that no public market now exists for the ITN Rewards, and that the Company has not made any assurances that a public market will ever exist for the ITN Rewards.

4.6 No Solicitation. At no time were you presented with or solicited by any publicly issued or circulated newspaper, mail, radio, television or other form of general advertising or solicitation in connection with any invitation to participate in the Program or offer of the ITN Rewards.

4.7 Other Applicable Laws. You hereby represent that you have satisfied yourself as to the full observance of the laws of your jurisdiction in connection with any invitation to participate in the Program, receipt of ITN Awards, and other use of these Terms, including (a) the legal requirements within your jurisdiction for participating in the Program and receiving ITN Rewards, (b) any foreign exchange restrictions applicable to such participation or receipt, (c) any governmental or other consents that may need to be obtained, and (d) the income tax and other tax consequences, if any, that may be relevant to the receipt, holding, sale, or transfer of the ITN Rewards. Your participation in the Program and continued beneficial ownership of ITN Rewards will not violate any applicable securities or other laws of your jurisdiction.

4.8 Non-US Transaction. You are not a U.S. Person as defined in Rule 902(k) of Regulation S under the 1933 Act. The offer of the ITN Rewards to you was made in an offshore transaction (as defined in Rule 902(h) of Regulation S), no directed selling efforts (as defined in Rule 902(c) of Regulation S) were made in the United States, and you are not obtaining the ITN Rewards for the account or benefit of any U.S. Person.

4.9 Transfer Restrictions. You will not, during the Restricted Period (as defined below) offer or sell any of the ITN Rewards (or create or maintain any derivative position equivalent thereto) in the United States, to or for the account or benefit of a U.S. Person or other than in accordance with Regulation S. The Company reserves the right to impose additional transfer restrictions with respect to the ITN Rewards in its sole discretion.

4.10 Subsequent Sales. You will, after the expiration of the applicable Restricted Period, only offer, sell, pledge or otherwise transfer the ITN Rewards (or create or maintain any derivative position equivalent thereto) pursuant to registration under the 1933 Act or any available exemption therefrom and, in any case, in accordance with applicable state securities laws.

4.11 Legends. You acknowledge and agree that the ITN Rewards will be deemed to bear the following legends: (a) any legend required by the securities laws of any state or country to the extent such laws are applicable to the ITN Rewards represented by the certificate so legended, and (b): the following legend (and even without such legend the following restrictions apply):

THE ITN REWARDS HAVE NOT BEEN REGISTERED UNDER THE ACT WITH THE UNITED STATES SECURITIES AND EXCHANGE COMMISSION, AND THE COMPANY DOES NOT INTEND TO REGISTER THEM. THE ITN REWARDS HAVE BEEN OBTAINED TO HOLD FOR THE LONG TERM AND NOT WITH A VIEW TO, OR IN CONNECTION WITH, THE SALE OR DISTRIBUTION THEREFOR. PRIOR TO THE ONE YEAR ANNIVERSARY FROM THE TERMINATION OF THE ITN REWARD PROGRAM (THE "PROGRAM COMPLETION DATE" AND SUCH ONE YEAR PERIOD, THE "RESTRICTED PERIOD"), THE ITN REWARDS MAY NOT BE OFFERED OR SOLD (INCLUDING OPENING A SHORT POSITION IN SUCH ITN REWARDS) IN THE UNITED STATES OR TO U.S. PERSONS AS DEFINED BY RULE 902(k) ADOPTED UNDER THE ACT, OTHER THAN TO DISTRIBUTORS, UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT, OR AN EXEMPTION FROM THE REGISTRATION REQUIREMENTS OF THE ACT IS AVAILABLE. RECIPIENTS OF ITN REWARDS PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE MAY SELL SUCH ITN REWARDS ONLY PURSUANT TO AN EXEMPTION FROM REGISTRATION UNDER THE ACT OR OTHERWISE IN ACCORDANCE WITH THE PROVISIONS OF REGULATION S OF THE ACT, OR IN TRANSACTIONS EFFECTED OUTSIDE OF THE UNITED STATES PROVIDED THEY DO NOT SOLICIT (AND NO ONE ACTING ON THEIR BEHALF SOLICITS) PURCHASERS IN THE UNITED STATES OR OTHERWISE ENGAGE(S) IN SELLING EFFORTS IN THE UNITED STATES AND PROVIDED THAT HEDGING TRANSACTIONS INVOLVING THESE ITN REWARDS MAY NOT BE CONDUCTED UNLESS IN COMPLIANCE WITH THE ACT. A HOLDER OF THE ITN REWARDS WHO IS A DISTRIBUTOR, DEALER, SUB-UNDERWRITER OR OTHER SECURITIES PROFESSIONAL, IN ADDITION, CANNOT PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE SELL THE ITN REWARDS TO A U.S. PERSON AS DEFINED BY RULE 902(k) OF REGULATION S UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT OR AN EXEMPTION FROM REGISTRATION UNDER THE ACT IS AVAILABLE.

',37),i=[n];function s(c,l,d,h,u,p){return t(),o("div",null,i)}const T=e(r,[["render",s]]);export{m as __pageData,T as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const m=JSON.parse('{"title":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS","description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","frontmatter":{"description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","lastUpdated":false,"editLink":false,"head":[["meta",{"name":"og:title","content":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/itn-tos.md","filePath":"community/itn-tos.md","lastUpdated":1725955670000}'),r={name:"community/itn-tos.md"},n=a('

SUPPLEMENTAL INCENTIVIZED TESTNET TERMS

Last Revised on 1/16/2023

Welcome to the Supplemental Terms (these "ITN Award Program Terms" or "Terms") for the Incentivized Testnet Award Program (the "ITN Award Program" or the "Program") as operated on behalf of Strange Loop Labs AG ("Company", "we" or "us"). The ITN Award Program provides eligible users of a Testnet designated by the Company the opportunity to earn rewards, which may include Celestia tokens. These Terms are supplemental to, and incorporate by reference, the broader Celestia Terms of Service ("Services Terms") available at Celestia Terms of Service.

Defined terms used but not defined herein have the meaning set forth in the Services Terms. The Program and your participation in it is a Service as defined under the Services Terms.

These Terms govern your ability to participate in the Program and any awards you receive from that participation, which may include Celestia tokens ("ITN Rewards").

Please read these Terms carefully, as they include important information about your legal rights. By participating in the Program or claiming ITN Rewards, you are agreeing to these Terms. If you do not understand or agree to these Terms, please do not participate in the Program or claim ITN Rewards.

In order to participate in the Program you must provide certain information about you. Our collection of such information, your rights with respect to such collection, and other relevant information is described in the Celestia Privacy Policy available at Celestia Privacy Policy, and is supplemented by Section 3 of these Terms.

The Program is a discretionary Service provided by the Company, pursuant to which the Company may, in its sole discretion, provide you ITN Rewards for your successful completion of certain tasks on a Testnet designated by the Company. Please note that any such Testnet itself (as well as any other Testnets or any mainnet deployment of the Celestia Protocol) is not a Service and does not constitute an element of the Services. We do not control the Celestia Protocol and accept no liability for its operation or its deployment in any testnet or mainnet environment.

1. General Terms

1.1 You must be eighteen (18) years of age or older and capable of forming a binding contract with the Company in order to participate in the Program or receive ITN Rewards.

1.2 You agree and acknowledge that you (a) may receive ITN Rewards for free (other than applicable taxes, if any) from your participation in the Program, (b) were not previously promised ITN Rewards, unless pursuant to a separate written agreement, and (c) took no action in anticipation of or in reliance on receiving any ITN Rewards, unless pursuant to a separate written agreement.

1.3 Your eligibility to participate in or receive ITN Rewards from the Program is subject to our sole discretion. The complete list of actions you must complete to earn ITN Rewards may not have been described in the documentation released by us from time to time, you may not receive ITN Rewards even if you successfully complete such actions, and no documentation related to the Program entitles you to any ITN Rewards or to participate in the Program.

1.4 You agree and acknowledge that (a) you are not a Prohibited Person, (b) you are not a U.S. Person as defined in Rule 902(k) of Regulation S under the U.S. Securities Act of 1933, as amended (the "1933 Act" or "Act"), (c) you will not use a VPN or other tool to circumvent any geoblock or other restrictions that we may have implemented for participants in the Program, and (d) you are not participating in, and have not become eligible to participate in, the Program by receiving credentials from any other person or entity. Any circumvention or violation of the above will permanently disqualify you from participation in the Program.

1.5 You agree and acknowledge that if you are unable to claim ITN Rewards due to technical bugs, gas fees, loss of access to a Wallet or the keys thereto, or for any other reason, you will have no recourse or claim against us or any other Company Entity and that neither we nor any other Company Entity will bear any liability.

1.6 You agree and acknowledge that claiming an ITN Reward may require reliance on or an integration with third party products (e.g., a Wallet or an unaffiliated network or blockchain) that we do not control. In the event that you are unable to access such products or integrations, or if they fail for any reason, and you are unable to participate in the Program or claim ITN Rewards, you will have no recourse or claim against us or any other Company Entity and neither we nor any other Company Entity will bear any liability.

1.7 The Company may share identifying information and documentation with certain vendors or third-party providers who provide such identity verification and sanctions and watchlist screening services (the "Third-Party Services"). You agree that your access and use of such Third-Party Services is governed solely by the terms and conditions of such Third-Party Services, and the Company is not responsible or liable for, and make no representations as to any aspect of such Third-Party Services, including, without limitation, their content or the manner in which they handle, protect, manage or process data or any interaction between you and the provider of such Third-Party Services. You irrevocably waive any claim against the Company with respect to such Third-Party Services. We are not liable for any damage or loss caused or alleged to be caused by or in connection with your enablement, access or use of any such Third-Party Services, or your reliance on the privacy practices, data security processes or other policies of such Third-Party Services.

2. Taxes

2.1 You are responsible for the payment of all taxes associated with your participation in the Program and your receipt of ITN Rewards. You agree to provide the Company with any additional information and complete any required tax or other forms relating to your receipt of ITN Rewards. You may suffer adverse tax consequences as a result of your participation in the Program or your receipt of ITN Rewards. You hereby represent that (a) you have consulted with a tax adviser that you deem advisable in connection with your participation, or that you have had the opportunity to obtain tax advice but have chosen not to do so, (b) the Company has not provided you with any tax advice with respect to your participation, and (c) you are not relying on the Company for any tax advice.

3. Supplemental Privacy Information

We may collect information to help us determine the reliability or uptime of your activities within the Program, including through the use of telemetry or metrics endpoints to collect and analyse such information, and link this information to a unique identifier to represent your activities within the Program. We may display all of the foregoing information on a public dashboard.

Additionally, we may collect certain information about you from Third-Party Services and may combine information we receive from you with information we obtain from Third-Party Services, including but not limited to:

  • Transaction information. Information related to transactions in your Wallet, your Wallet address, activities performed using your Wallet, tokens received by your Wallet, or transactions initiated or completed.
  • Identification information. We collect your government identification (e.g., driver’s license, passport, etc.), proof of address, biometric information, and entity formation information if applicable. By agreeing to these Terms, you consent to our use of your biometric information, and understand and agree that our use of the biometric information is necessary for the performance of these Terms and the implementation of the Services.

We collect this information to confirm your eligibility to participate in the Program and receive ITN Rewards, comply with our legal obligations, detect and prevent fraud, and to provide you with the Program.

Any information we receive from third-party sources will be treated in accordance with the Celestia Privacy Policy, available at Celestia Privacy Policy. We are not responsible or liable for the accuracy of the information provided to us by third parties and are not responsible for any third party’s policies or practices. See Section 9 of the Celestia Privacy Policy for more information.

4. Certain Additional Representations

4.1 Receipt of Rewards Entirely for Own Account. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that any ITN Rewards you receive will be for your own account, not as a nominee or agent, and not with a view to the resale or distribution of any part thereof, and that you have no present intention of selling, granting any participation in, or otherwise distributing the same. By agreeing to these Terms, you further represent that you do not presently have any contract, undertaking, agreement or arrangement with any person to sell, transfer or grant participations to such person or to any third person, with respect to any ITN Rewards. If you are agreeing to these terms on behalf of an entity, that entity has not been formed for the specific purpose of obtaining the ITN Rewards.

4.2 Disclosure of Information. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that you have sufficient knowledge of and experience in business and financial matters to be able to evaluate the risks and merits of your participation in the Program and of any ITN Rewards and are able to bear the risks thereof. You hereby affirm that you have not relied on any representations or warranties made by the Company related to the Program, including, but not limited to, conversations of any kind, whether through oral or electronic communication, or any white paper.

4.3 Compliance with United States Securities Laws. You understand that the ITN Rewards have not been, and will not be, registered under the 1933 Act or any applicable state securities laws. You acknowledge that the availability of an exemption from the registration provisions of the Securities Act and other applicable state securities laws depends upon, among other things, the bona fide nature of your intent as described in Section 4.1 above and with respect to the accuracy of your representations as expressed throughout these Terms. You understand that the ITN Rewards may be deemed "restricted securities" under applicable United States federal and state securities laws and that, pursuant to these laws, you may be restricted from transferring any ITN Rewards unless they are registered with the Securities and Exchange Commission and qualified by state authorities, or an exemption from such registration and qualification requirements is available. You acknowledge that the Company does not undertake any obligation to register or qualify the ITN Rewards for resale, and exemptions from registration and qualification may not be available or may not permit you to transfer all or any of the ITN Rewards in the amounts or at the times proposed by you. You further acknowledge that if an exemption from registration or qualification is available, such exemption may be conditioned on various requirements including, but not limited to, the time and manner of sale, the holding period for the ITN Rewards, and on other factors outside of your control, for which the Company makes no assurances and may not be able to satisfy.

4.4 Compliance with Liechtenstein Security Law. You understand that nothing in these Terms will be deemed to constitute a prospectus of any sort in Liechtenstein or in any jurisdiction in the EU; nor does it in any way pertain to a public offering or a solicitation of an offer to buy any securities in Liechtenstein or in any jurisdiction in the EU.

4.5 No Public Market. You understand that no public market now exists for the ITN Rewards, and that the Company has not made any assurances that a public market will ever exist for the ITN Rewards.

4.6 No Solicitation. At no time were you presented with or solicited by any publicly issued or circulated newspaper, mail, radio, television or other form of general advertising or solicitation in connection with any invitation to participate in the Program or offer of the ITN Rewards.

4.7 Other Applicable Laws. You hereby represent that you have satisfied yourself as to the full observance of the laws of your jurisdiction in connection with any invitation to participate in the Program, receipt of ITN Awards, and other use of these Terms, including (a) the legal requirements within your jurisdiction for participating in the Program and receiving ITN Rewards, (b) any foreign exchange restrictions applicable to such participation or receipt, (c) any governmental or other consents that may need to be obtained, and (d) the income tax and other tax consequences, if any, that may be relevant to the receipt, holding, sale, or transfer of the ITN Rewards. Your participation in the Program and continued beneficial ownership of ITN Rewards will not violate any applicable securities or other laws of your jurisdiction.

4.8 Non-US Transaction. You are not a U.S. Person as defined in Rule 902(k) of Regulation S under the 1933 Act. The offer of the ITN Rewards to you was made in an offshore transaction (as defined in Rule 902(h) of Regulation S), no directed selling efforts (as defined in Rule 902(c) of Regulation S) were made in the United States, and you are not obtaining the ITN Rewards for the account or benefit of any U.S. Person.

4.9 Transfer Restrictions. You will not, during the Restricted Period (as defined below) offer or sell any of the ITN Rewards (or create or maintain any derivative position equivalent thereto) in the United States, to or for the account or benefit of a U.S. Person or other than in accordance with Regulation S. The Company reserves the right to impose additional transfer restrictions with respect to the ITN Rewards in its sole discretion.

4.10 Subsequent Sales. You will, after the expiration of the applicable Restricted Period, only offer, sell, pledge or otherwise transfer the ITN Rewards (or create or maintain any derivative position equivalent thereto) pursuant to registration under the 1933 Act or any available exemption therefrom and, in any case, in accordance with applicable state securities laws.

4.11 Legends. You acknowledge and agree that the ITN Rewards will be deemed to bear the following legends: (a) any legend required by the securities laws of any state or country to the extent such laws are applicable to the ITN Rewards represented by the certificate so legended, and (b): the following legend (and even without such legend the following restrictions apply):

THE ITN REWARDS HAVE NOT BEEN REGISTERED UNDER THE ACT WITH THE UNITED STATES SECURITIES AND EXCHANGE COMMISSION, AND THE COMPANY DOES NOT INTEND TO REGISTER THEM. THE ITN REWARDS HAVE BEEN OBTAINED TO HOLD FOR THE LONG TERM AND NOT WITH A VIEW TO, OR IN CONNECTION WITH, THE SALE OR DISTRIBUTION THEREFOR. PRIOR TO THE ONE YEAR ANNIVERSARY FROM THE TERMINATION OF THE ITN REWARD PROGRAM (THE "PROGRAM COMPLETION DATE" AND SUCH ONE YEAR PERIOD, THE "RESTRICTED PERIOD"), THE ITN REWARDS MAY NOT BE OFFERED OR SOLD (INCLUDING OPENING A SHORT POSITION IN SUCH ITN REWARDS) IN THE UNITED STATES OR TO U.S. PERSONS AS DEFINED BY RULE 902(k) ADOPTED UNDER THE ACT, OTHER THAN TO DISTRIBUTORS, UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT, OR AN EXEMPTION FROM THE REGISTRATION REQUIREMENTS OF THE ACT IS AVAILABLE. RECIPIENTS OF ITN REWARDS PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE MAY SELL SUCH ITN REWARDS ONLY PURSUANT TO AN EXEMPTION FROM REGISTRATION UNDER THE ACT OR OTHERWISE IN ACCORDANCE WITH THE PROVISIONS OF REGULATION S OF THE ACT, OR IN TRANSACTIONS EFFECTED OUTSIDE OF THE UNITED STATES PROVIDED THEY DO NOT SOLICIT (AND NO ONE ACTING ON THEIR BEHALF SOLICITS) PURCHASERS IN THE UNITED STATES OR OTHERWISE ENGAGE(S) IN SELLING EFFORTS IN THE UNITED STATES AND PROVIDED THAT HEDGING TRANSACTIONS INVOLVING THESE ITN REWARDS MAY NOT BE CONDUCTED UNLESS IN COMPLIANCE WITH THE ACT. A HOLDER OF THE ITN REWARDS WHO IS A DISTRIBUTOR, DEALER, SUB-UNDERWRITER OR OTHER SECURITIES PROFESSIONAL, IN ADDITION, CANNOT PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE SELL THE ITN REWARDS TO A U.S. PERSON AS DEFINED BY RULE 902(k) OF REGULATION S UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT OR AN EXEMPTION FROM REGISTRATION UNDER THE ACT IS AVAILABLE.

',37),i=[n];function s(c,l,d,h,u,p){return t(),o("div",null,i)}const T=e(r,[["render",s]]);export{m as __pageData,T as default}; diff --git a/pr-1680/assets/community_itn-tos.md.c448efcc.lean.js b/pr-1680/assets/community_itn-tos.md.89c55442.lean.js similarity index 92% rename from pr-1680/assets/community_itn-tos.md.c448efcc.lean.js rename to pr-1680/assets/community_itn-tos.md.89c55442.lean.js index 6c540d5f97..872572ba47 100644 --- a/pr-1680/assets/community_itn-tos.md.c448efcc.lean.js +++ b/pr-1680/assets/community_itn-tos.md.89c55442.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const m=JSON.parse('{"title":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS","description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","frontmatter":{"description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","lastUpdated":false,"editLink":false,"head":[["meta",{"name":"og:title","content":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/itn-tos.md","filePath":"community/itn-tos.md","lastUpdated":1724867275000}'),r={name:"community/itn-tos.md"},n=a("",37),i=[n];function s(c,l,d,h,u,p){return t(),o("div",null,i)}const T=e(r,[["render",s]]);export{m as __pageData,T as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const m=JSON.parse('{"title":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS","description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","frontmatter":{"description":"These Terms govern your ability to participate in the Incentivized Testnet Award Program.","lastUpdated":false,"editLink":false,"head":[["meta",{"name":"og:title","content":"SUPPLEMENTAL INCENTIVIZED TESTNET TERMS | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/itn-tos.md","filePath":"community/itn-tos.md","lastUpdated":1725955670000}'),r={name:"community/itn-tos.md"},n=a("",37),i=[n];function s(c,l,d,h,u,p){return t(),o("div",null,i)}const T=e(r,[["render",s]]);export{m as __pageData,T as default}; diff --git a/pr-1680/assets/community_modular-meetup-guide.md.83bd3c81.js b/pr-1680/assets/community_modular-meetup-guide.md.3997fb81.js similarity index 99% rename from pr-1680/assets/community_modular-meetup-guide.md.83bd3c81.js rename to pr-1680/assets/community_modular-meetup-guide.md.3997fb81.js index bf684765cc..bb859487ef 100644 --- a/pr-1680/assets/community_modular-meetup-guide.md.83bd3c81.js +++ b/pr-1680/assets/community_modular-meetup-guide.md.3997fb81.js @@ -1 +1 @@ -import{_ as e,o as t,c as i,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Modular Meetup guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1724867275000}'),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,h,p){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.a504a440.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",{"name":"og:title","content":"Modular Meetup guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1725955670000}'),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,h,p){return t(),i("div",null,r)}const f=e(a,[["render",s]]);export{g as __pageData,f as default}; diff --git a/pr-1680/assets/community_modular-meetup-guide.md.83bd3c81.lean.js b/pr-1680/assets/community_modular-meetup-guide.md.3997fb81.lean.js similarity index 91% rename from pr-1680/assets/community_modular-meetup-guide.md.83bd3c81.lean.js rename to pr-1680/assets/community_modular-meetup-guide.md.3997fb81.lean.js index 7cc6f7e5c6..3c63318690 100644 --- a/pr-1680/assets/community_modular-meetup-guide.md.83bd3c81.lean.js +++ b/pr-1680/assets/community_modular-meetup-guide.md.3997fb81.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as i,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Modular Meetup guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1724867275000}'),a={name:"community/modular-meetup-guide.md"},n=o("",42),r=[n];function s(l,u,c,d,h,p){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.a504a440.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",{"name":"og:title","content":"Modular Meetup guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-guide.md","filePath":"community/modular-meetup-guide.md","lastUpdated":1725955670000}'),a={name:"community/modular-meetup-guide.md"},n=o("",42),r=[n];function s(l,u,c,d,h,p){return t(),i("div",null,r)}const f=e(a,[["render",s]]);export{g as __pageData,f as default}; diff --git a/pr-1680/assets/community_modular-meetup-intro.md.15c20508.js b/pr-1680/assets/community_modular-meetup-intro.md.8430b9a3.js similarity index 98% rename from pr-1680/assets/community_modular-meetup-intro.md.15c20508.js rename to pr-1680/assets/community_modular-meetup-intro.md.8430b9a3.js index d191657951..096320f0a4 100644 --- a/pr-1680/assets/community_modular-meetup-intro.md.15c20508.js +++ b/pr-1680/assets/community_modular-meetup-intro.md.8430b9a3.js @@ -1 +1 @@ -import{_ as e,o,c as a,Q as t}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1724867275000}'),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.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1725955670000}'),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-1680/assets/community_modular-meetup-intro.md.15c20508.lean.js b/pr-1680/assets/community_modular-meetup-intro.md.8430b9a3.lean.js similarity index 91% rename from pr-1680/assets/community_modular-meetup-intro.md.15c20508.lean.js rename to pr-1680/assets/community_modular-meetup-intro.md.8430b9a3.lean.js index 0db53c9f9a..bad80c9697 100644 --- a/pr-1680/assets/community_modular-meetup-intro.md.15c20508.lean.js +++ b/pr-1680/assets/community_modular-meetup-intro.md.8430b9a3.lean.js @@ -1 +1 @@ -import{_ as e,o,c as a,Q as t}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1724867275000}'),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.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia Modular Meetup program | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-intro.md","filePath":"community/modular-meetup-intro.md","lastUpdated":1725955670000}'),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-1680/assets/community_modular-meetup-toolkit.md.c0a464fb.js b/pr-1680/assets/community_modular-meetup-toolkit.md.676a0a2a.js similarity index 98% rename from pr-1680/assets/community_modular-meetup-toolkit.md.c0a464fb.js rename to pr-1680/assets/community_modular-meetup-toolkit.md.676a0a2a.js index a179ec747c..1e22d8d9ef 100644 --- a/pr-1680/assets/community_modular-meetup-toolkit.md.c0a464fb.js +++ b/pr-1680/assets/community_modular-meetup-toolkit.md.676a0a2a.js @@ -1 +1 @@ -import{_ as e,o,c as i,Q as t}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"name":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1724867275000}'),l={name:"community/modular-meetup-toolkit.md"},a=t('

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(),i("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; +import{_ as e,o,c as i,Q as t}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"name":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1725955670000}'),l={name:"community/modular-meetup-toolkit.md"},a=t('

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(),i("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; diff --git a/pr-1680/assets/community_modular-meetup-toolkit.md.c0a464fb.lean.js b/pr-1680/assets/community_modular-meetup-toolkit.md.676a0a2a.lean.js similarity index 90% rename from pr-1680/assets/community_modular-meetup-toolkit.md.c0a464fb.lean.js rename to pr-1680/assets/community_modular-meetup-toolkit.md.676a0a2a.lean.js index 270b962125..a2105b5273 100644 --- a/pr-1680/assets/community_modular-meetup-toolkit.md.c0a464fb.lean.js +++ b/pr-1680/assets/community_modular-meetup-toolkit.md.676a0a2a.lean.js @@ -1 +1 @@ -import{_ as e,o,c as i,Q as t}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"name":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1724867275000}'),l={name:"community/modular-meetup-toolkit.md"},a=t("",15),r=[a];function n(s,p,u,d,h,c){return o(),i("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; +import{_ as e,o,c as i,Q as t}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Modular Meetup Toolkit","description":"A toolkit for Modular Meetups.","frontmatter":{"description":"A toolkit for Modular Meetups.","head":[["meta",{"name":"og:title","content":"Modular Meetup Toolkit | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/modular-meetup-toolkit.md","filePath":"community/modular-meetup-toolkit.md","lastUpdated":1725955670000}'),l={name:"community/modular-meetup-toolkit.md"},a=t("",15),r=[a];function n(s,p,u,d,h,c){return o(),i("div",null,r)}const f=e(l,[["render",n]]);export{g as __pageData,f as default}; diff --git a/pr-1680/assets/community_overview.md.5d3cdb35.js b/pr-1680/assets/community_overview.md.237c0746.js similarity index 94% rename from pr-1680/assets/community_overview.md.5d3cdb35.js rename to pr-1680/assets/community_overview.md.237c0746.js index e3f0bd88ef..5a532e444d 100644 --- a/pr-1680/assets/community_overview.md.5d3cdb35.js +++ b/pr-1680/assets/community_overview.md.237c0746.js @@ -1 +1 @@ -import{_ as o,o as i,c as a,k as e,a as t}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"Community overview","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Community overview | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/overview.md","filePath":"community/overview.md","lastUpdated":1724867275000}'),n={name:"community/overview.md"},r=e("h1",{id:"community-overview",tabindex:"-1"},[t("Community overview "),e("a",{class:"header-anchor",href:"#community-overview","aria-label":'Permalink to "Community overview"'},"​")],-1),c=e("p",null,"This section will highlight all the different resources and activities for the Celestia community.",-1),s=e("p",null,[t("Here you will find links to our "),e("a",{href:"./calendar"},"community calendar"),t(", "),e("a",{href:"./coc"},"Code of Conduct"),t(" and other community-related resources.")],-1),m=[r,c,s];function l(d,u,v,h,_,f){return i(),a("div",null,m)}const w=o(n,[["render",l]]);export{y as __pageData,w as default}; +import{_ as o,o as i,c as a,k as e,a as t}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"Community overview","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Community overview | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/overview.md","filePath":"community/overview.md","lastUpdated":1725955670000}'),n={name:"community/overview.md"},r=e("h1",{id:"community-overview",tabindex:"-1"},[t("Community overview "),e("a",{class:"header-anchor",href:"#community-overview","aria-label":'Permalink to "Community overview"'},"​")],-1),c=e("p",null,"This section will highlight all the different resources and activities for the Celestia community.",-1),s=e("p",null,[t("Here you will find links to our "),e("a",{href:"./calendar"},"community calendar"),t(", "),e("a",{href:"./coc"},"Code of Conduct"),t(" and other community-related resources.")],-1),m=[r,c,s];function l(d,u,v,h,_,f){return i(),a("div",null,m)}const w=o(n,[["render",l]]);export{y as __pageData,w as default}; diff --git a/pr-1680/assets/community_overview.md.5d3cdb35.lean.js b/pr-1680/assets/community_overview.md.237c0746.lean.js similarity index 94% rename from pr-1680/assets/community_overview.md.5d3cdb35.lean.js rename to pr-1680/assets/community_overview.md.237c0746.lean.js index e3f0bd88ef..5a532e444d 100644 --- a/pr-1680/assets/community_overview.md.5d3cdb35.lean.js +++ b/pr-1680/assets/community_overview.md.237c0746.lean.js @@ -1 +1 @@ -import{_ as o,o as i,c as a,k as e,a as t}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"Community overview","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Community overview | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/overview.md","filePath":"community/overview.md","lastUpdated":1724867275000}'),n={name:"community/overview.md"},r=e("h1",{id:"community-overview",tabindex:"-1"},[t("Community overview "),e("a",{class:"header-anchor",href:"#community-overview","aria-label":'Permalink to "Community overview"'},"​")],-1),c=e("p",null,"This section will highlight all the different resources and activities for the Celestia community.",-1),s=e("p",null,[t("Here you will find links to our "),e("a",{href:"./calendar"},"community calendar"),t(", "),e("a",{href:"./coc"},"Code of Conduct"),t(" and other community-related resources.")],-1),m=[r,c,s];function l(d,u,v,h,_,f){return i(),a("div",null,m)}const w=o(n,[["render",l]]);export{y as __pageData,w as default}; +import{_ as o,o as i,c as a,k as e,a as t}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"Community overview","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Community overview | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/overview.md","filePath":"community/overview.md","lastUpdated":1725955670000}'),n={name:"community/overview.md"},r=e("h1",{id:"community-overview",tabindex:"-1"},[t("Community overview "),e("a",{class:"header-anchor",href:"#community-overview","aria-label":'Permalink to "Community overview"'},"​")],-1),c=e("p",null,"This section will highlight all the different resources and activities for the Celestia community.",-1),s=e("p",null,[t("Here you will find links to our "),e("a",{href:"./calendar"},"community calendar"),t(", "),e("a",{href:"./coc"},"Code of Conduct"),t(" and other community-related resources.")],-1),m=[r,c,s];function l(d,u,v,h,_,f){return i(),a("div",null,m)}const w=o(n,[["render",l]]);export{y as __pageData,w as default}; diff --git a/pr-1680/assets/community_speaker-list.md.dd7785cb.js b/pr-1680/assets/community_speaker-list.md.b66230db.js similarity index 97% rename from pr-1680/assets/community_speaker-list.md.dd7785cb.js rename to pr-1680/assets/community_speaker-list.md.b66230db.js index 5d5e1dab46..ef09f74b9f 100644 --- a/pr-1680/assets/community_speaker-list.md.dd7785cb.js +++ b/pr-1680/assets/community_speaker-list.md.b66230db.js @@ -1 +1 @@ -import{_ as t,o as a,c as s,k as e,a as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Speaker list | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1724867275000}'),o={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[i("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),c=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),p=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),d=[r,n,l,c,p];function u(h,m,f,g,y,k){return a(),s("div",null,d)}const v=t(o,[["render",u]]);export{b as __pageData,v as default}; +import{_ as t,o as a,c as s,k as e,a as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Speaker list | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1725955670000}'),o={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[i("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),c=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),p=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),d=[r,n,l,c,p];function u(h,m,f,g,y,k){return a(),s("div",null,d)}const v=t(o,[["render",u]]);export{b as __pageData,v as default}; diff --git a/pr-1680/assets/community_speaker-list.md.dd7785cb.lean.js b/pr-1680/assets/community_speaker-list.md.b66230db.lean.js similarity index 97% rename from pr-1680/assets/community_speaker-list.md.dd7785cb.lean.js rename to pr-1680/assets/community_speaker-list.md.b66230db.lean.js index 5d5e1dab46..ef09f74b9f 100644 --- a/pr-1680/assets/community_speaker-list.md.dd7785cb.lean.js +++ b/pr-1680/assets/community_speaker-list.md.b66230db.lean.js @@ -1 +1 @@ -import{_ as t,o as a,c as s,k as e,a as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Speaker list | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1724867275000}'),o={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[i("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),c=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),p=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),d=[r,n,l,c,p];function u(h,m,f,g,y,k){return a(),s("div",null,d)}const v=t(o,[["render",u]]);export{b as __pageData,v as default}; +import{_ as t,o as a,c as s,k as e,a as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Speaker list | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"community/speaker-list.md","filePath":"community/speaker-list.md","lastUpdated":1725955670000}'),o={name:"community/speaker-list.md"},r=e("h1",{id:"speaker-list",tabindex:"-1"},[i("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),c=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),p=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),d=[r,n,l,c,p];function u(h,m,f,g,y,k){return a(),s("div",null,d)}const v=t(o,[["render",u]]);export{b as __pageData,v as default}; diff --git a/pr-1680/assets/developers_arbitrum-bridge.md.1305b088.js b/pr-1680/assets/developers_arbitrum-bridge.md.96018be7.js similarity index 99% rename from pr-1680/assets/developers_arbitrum-bridge.md.1305b088.js rename to pr-1680/assets/developers_arbitrum-bridge.md.96018be7.js index 0ea9bf97a0..f680fed3fa 100644 --- a/pr-1680/assets/developers_arbitrum-bridge.md.1305b088.js +++ b/pr-1680/assets/developers_arbitrum-bridge.md.96018be7.js @@ -1 +1 @@ -import{_ as r,o,c as t,Q as e}from"./chunks/framework.a504a440.js";const i="/docs-preview/pr-1680/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1680/arbitrum/bridge-settings.png",n="/docs-preview/pr-1680/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1680/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1680/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1680/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1680/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1680/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1680/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1680/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1680/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1680/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1680/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1680/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1680/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1680/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1680/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1680/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1680/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.","head":[["meta",{"name":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-bridge.md","filePath":"developers/arbitrum-bridge.md","lastUpdated":1724867275000}'),A={name:"developers/arbitrum-bridge.md"},S=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),k=[S];function C(O,B,q,P,T,I){return o(),t("div",null,k)}const L=r(A,[["render",C]]);export{D as __pageData,L as default}; +import{_ as r,o,c as t,Q as e}from"./chunks/framework.a504a440.js";const i="/docs-preview/pr-1680/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1680/arbitrum/bridge-settings.png",n="/docs-preview/pr-1680/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1680/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1680/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1680/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1680/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1680/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1680/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1680/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1680/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1680/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1680/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1680/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1680/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1680/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1680/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1680/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1680/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.","head":[["meta",{"name":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-bridge.md","filePath":"developers/arbitrum-bridge.md","lastUpdated":1725955670000}'),A={name:"developers/arbitrum-bridge.md"},S=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),k=[S];function C(O,B,q,P,T,I){return o(),t("div",null,k)}const L=r(A,[["render",C]]);export{D as __pageData,L as default}; diff --git a/pr-1680/assets/developers_arbitrum-bridge.md.1305b088.lean.js b/pr-1680/assets/developers_arbitrum-bridge.md.96018be7.lean.js similarity index 96% rename from pr-1680/assets/developers_arbitrum-bridge.md.1305b088.lean.js rename to pr-1680/assets/developers_arbitrum-bridge.md.96018be7.lean.js index 25dcf805b0..42d15f8372 100644 --- a/pr-1680/assets/developers_arbitrum-bridge.md.1305b088.lean.js +++ b/pr-1680/assets/developers_arbitrum-bridge.md.96018be7.lean.js @@ -1 +1 @@ -import{_ as r,o,c as t,Q as e}from"./chunks/framework.a504a440.js";const i="/docs-preview/pr-1680/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1680/arbitrum/bridge-settings.png",n="/docs-preview/pr-1680/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1680/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1680/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1680/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1680/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1680/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1680/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1680/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1680/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1680/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1680/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1680/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1680/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1680/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1680/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1680/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1680/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.","head":[["meta",{"name":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-bridge.md","filePath":"developers/arbitrum-bridge.md","lastUpdated":1724867275000}'),A={name:"developers/arbitrum-bridge.md"},S=e("",50),k=[S];function C(O,B,q,P,T,I){return o(),t("div",null,k)}const L=r(A,[["render",C]]);export{D as __pageData,L as default}; +import{_ as r,o,c as t,Q as e}from"./chunks/framework.a504a440.js";const i="/docs-preview/pr-1680/arbitrum/bridge-overview-deposit-and-withdrawal-l3.png",a="/docs-preview/pr-1680/arbitrum/bridge-settings.png",n="/docs-preview/pr-1680/arbitrum/add-custom-chain-to-bridge.png",s="/docs-preview/pr-1680/arbitrum/live-orbit-chains.png",p="/docs-preview/pr-1680/arbitrum/bridge-in-start.png",l="/docs-preview/pr-1680/arbitrum/bridge-in-pending-txs.png",d="/docs-preview/pr-1680/arbitrum/bridge-in-settled-txs.png",g="/docs-preview/pr-1680/arbitrum/bridge-in-explorer-rollup-tx.png",u="/docs-preview/pr-1680/arbitrum/bridge-in-success.png",c="/docs-preview/pr-1680/arbitrum/bridge-in-sepolia-tx-explorer.png",b="/docs-preview/pr-1680/arbitrum/bridge-out-small-screenshot.png",h="/docs-preview/pr-1680/arbitrum/bridge-out-begin.png",m="/docs-preview/pr-1680/arbitrum/bridge-out-pending.png",w="/docs-preview/pr-1680/arbitrum/bridge-out-begin-overview.png",f="/docs-preview/pr-1680/arbitrum/bridge-out-rollup-tx-details.png",y="/docs-preview/pr-1680/arbitrum/bridge-out-logs-details-1.png",_="/docs-preview/pr-1680/arbitrum/bridge-out-logs-explorer-2.png",v="/docs-preview/pr-1680/arbitrum/bridge-out-claim-withdrawal.png",x="/docs-preview/pr-1680/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.","head":[["meta",{"name":"og:title","content":"Bridging in and out of your Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-bridge.md","filePath":"developers/arbitrum-bridge.md","lastUpdated":1725955670000}'),A={name:"developers/arbitrum-bridge.md"},S=e("",50),k=[S];function C(O,B,q,P,T,I){return o(),t("div",null,k)}const L=r(A,[["render",C]]);export{D as __pageData,L as default}; diff --git a/pr-1680/assets/developers_arbitrum-dapp-deploy.md.94c9ebd9.js b/pr-1680/assets/developers_arbitrum-dapp-deploy.md.f7dfbfa7.js similarity index 99% rename from pr-1680/assets/developers_arbitrum-dapp-deploy.md.94c9ebd9.js rename to pr-1680/assets/developers_arbitrum-dapp-deploy.md.f7dfbfa7.js index 7df9c57c00..95c9978d70 100644 --- a/pr-1680/assets/developers_arbitrum-dapp-deploy.md.94c9ebd9.js +++ b/pr-1680/assets/developers_arbitrum-dapp-deploy.md.f7dfbfa7.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/img/gm-arb.png",F=JSON.parse('{"title":"Deploy a dapp on your Arbitrum rollup devnet","description":"Make your own GM Portal dapp on your Arbitrum rollup.","frontmatter":{"description":"Make your own GM Portal dapp on your Arbitrum rollup.","next":{"text":"Intro to OP Stack integration","link":"/developers/intro-to-op-stack"},"head":[["meta",{"name":"og:title","content":"Deploy a dapp on your Arbitrum rollup devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-dapp-deploy.md","filePath":"developers/arbitrum-dapp-deploy.md","lastUpdated":1724867275000}'),p={name:"developers/arbitrum-dapp-deploy.md"},t=n(`

Deploy a dapp on your Arbitrum rollup devnet

First, review the Arbitrum integration, Quickstart: Deploy an Arbitrum Orbit rollup, and Deploy a smart contract to your Arbitrum rollup pages.

Dependencies

Setup and contract deployment

  1. Clone the gm-portal from GitHub and start the frontend:

    bash
    cd $HOME
    +import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/img/gm-arb.png",F=JSON.parse('{"title":"Deploy a dapp on your Arbitrum rollup devnet","description":"Make your own GM Portal dapp on your Arbitrum rollup.","frontmatter":{"description":"Make your own GM Portal dapp on your Arbitrum rollup.","next":{"text":"Intro to OP Stack integration","link":"/developers/intro-to-op-stack"},"head":[["meta",{"name":"og:title","content":"Deploy a dapp on your Arbitrum rollup devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-dapp-deploy.md","filePath":"developers/arbitrum-dapp-deploy.md","lastUpdated":1725955670000}'),p={name:"developers/arbitrum-dapp-deploy.md"},t=n(`

    Deploy a dapp on your Arbitrum rollup devnet

    First, review the Arbitrum integration, Quickstart: Deploy an Arbitrum Orbit rollup, and Deploy a smart contract to your Arbitrum rollup pages.

    Dependencies

    Setup and contract deployment

    1. Clone the gm-portal from GitHub and start the frontend:

      bash
      cd $HOME
       git clone https://github.com/jcstein/gm-portal.git
       cd gm-portal && git checkout arbitrum
       cd frontend && yarn && yarn dev
      cd $HOME
      diff --git a/pr-1680/assets/developers_arbitrum-dapp-deploy.md.94c9ebd9.lean.js b/pr-1680/assets/developers_arbitrum-dapp-deploy.md.f7dfbfa7.lean.js
      similarity index 92%
      rename from pr-1680/assets/developers_arbitrum-dapp-deploy.md.94c9ebd9.lean.js
      rename to pr-1680/assets/developers_arbitrum-dapp-deploy.md.f7dfbfa7.lean.js
      index 0fa355aff9..fc492073b1 100644
      --- a/pr-1680/assets/developers_arbitrum-dapp-deploy.md.94c9ebd9.lean.js
      +++ b/pr-1680/assets/developers_arbitrum-dapp-deploy.md.f7dfbfa7.lean.js
      @@ -1 +1 @@
      -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/img/gm-arb.png",F=JSON.parse('{"title":"Deploy a dapp on your Arbitrum rollup devnet","description":"Make your own GM Portal dapp on your Arbitrum rollup.","frontmatter":{"description":"Make your own GM Portal dapp on your Arbitrum rollup.","next":{"text":"Intro to OP Stack integration","link":"/developers/intro-to-op-stack"},"head":[["meta",{"name":"og:title","content":"Deploy a dapp on your Arbitrum rollup devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-dapp-deploy.md","filePath":"developers/arbitrum-dapp-deploy.md","lastUpdated":1724867275000}'),p={name:"developers/arbitrum-dapp-deploy.md"},t=n("",16),e=[t];function r(c,i,y,d,E,h){return a(),o("div",null,e)}const m=s(p,[["render",r]]);export{F as __pageData,m as default};
      +import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/img/gm-arb.png",F=JSON.parse('{"title":"Deploy a dapp on your Arbitrum rollup devnet","description":"Make your own GM Portal dapp on your Arbitrum rollup.","frontmatter":{"description":"Make your own GM Portal dapp on your Arbitrum rollup.","next":{"text":"Intro to OP Stack integration","link":"/developers/intro-to-op-stack"},"head":[["meta",{"name":"og:title","content":"Deploy a dapp on your Arbitrum rollup devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-dapp-deploy.md","filePath":"developers/arbitrum-dapp-deploy.md","lastUpdated":1725955670000}'),p={name:"developers/arbitrum-dapp-deploy.md"},t=n("",16),e=[t];function r(c,i,y,d,E,h){return a(),o("div",null,e)}const m=s(p,[["render",r]]);export{F as __pageData,m as default};
      diff --git a/pr-1680/assets/developers_arbitrum-deploy.md.839b7894.js b/pr-1680/assets/developers_arbitrum-deploy.md.70ab5228.js
      similarity index 99%
      rename from pr-1680/assets/developers_arbitrum-deploy.md.839b7894.js
      rename to pr-1680/assets/developers_arbitrum-deploy.md.70ab5228.js
      index 9654a5280d..702792e50a 100644
      --- a/pr-1680/assets/developers_arbitrum-deploy.md.839b7894.js
      +++ b/pr-1680/assets/developers_arbitrum-deploy.md.70ab5228.js
      @@ -1,4 +1,4 @@
      -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const e="/docs-preview/pr-1680/arbitrum/choose_da.png",t="/docs-preview/pr-1680/arbitrum/configuration.png",l="/docs-preview/pr-1680/arbitrum/download-config.png",p="/docs-preview/pr-1680/arbitrum/blockscout.png",r="/docs-preview/pr-1680/arbitrum/explorer-view.png",B=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",{"name":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-deploy.md","filePath":"developers/arbitrum-deploy.md","lastUpdated":1724867275000}'),c={name:"developers/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 3: 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 4: 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 5: 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 6: 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 7: 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.a504a440.js";const e="/docs-preview/pr-1680/arbitrum/choose_da.png",t="/docs-preview/pr-1680/arbitrum/configuration.png",l="/docs-preview/pr-1680/arbitrum/download-config.png",p="/docs-preview/pr-1680/arbitrum/blockscout.png",r="/docs-preview/pr-1680/arbitrum/explorer-view.png",B=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",{"name":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-deploy.md","filePath":"developers/arbitrum-deploy.md","lastUpdated":1725955670000}'),c={name:"developers/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 3: 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 4: 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 5: 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 6: 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 7: 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-1680/assets/developers_arbitrum-deploy.md.839b7894.lean.js b/pr-1680/assets/developers_arbitrum-deploy.md.70ab5228.lean.js
      similarity index 94%
      rename from pr-1680/assets/developers_arbitrum-deploy.md.839b7894.lean.js
      rename to pr-1680/assets/developers_arbitrum-deploy.md.70ab5228.lean.js
      index 011a35ffda..9d90b8118e 100644
      --- a/pr-1680/assets/developers_arbitrum-deploy.md.839b7894.lean.js
      +++ b/pr-1680/assets/developers_arbitrum-deploy.md.70ab5228.lean.js
      @@ -1 +1 @@
      -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const e="/docs-preview/pr-1680/arbitrum/choose_da.png",t="/docs-preview/pr-1680/arbitrum/configuration.png",l="/docs-preview/pr-1680/arbitrum/download-config.png",p="/docs-preview/pr-1680/arbitrum/blockscout.png",r="/docs-preview/pr-1680/arbitrum/explorer-view.png",B=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",{"name":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-deploy.md","filePath":"developers/arbitrum-deploy.md","lastUpdated":1724867275000}'),c={name:"developers/arbitrum-deploy.md"},i=n("",95),y=[i];function E(d,F,h,u,b,C){return a(),o("div",null,y)}const g=s(c,[["render",E]]);export{B as __pageData,g as default};
      +import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.js";const e="/docs-preview/pr-1680/arbitrum/choose_da.png",t="/docs-preview/pr-1680/arbitrum/configuration.png",l="/docs-preview/pr-1680/arbitrum/download-config.png",p="/docs-preview/pr-1680/arbitrum/blockscout.png",r="/docs-preview/pr-1680/arbitrum/explorer-view.png",B=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",{"name":"og:title","content":"Quickstart: Deploy an Arbitrum Orbit rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-deploy.md","filePath":"developers/arbitrum-deploy.md","lastUpdated":1725955670000}'),c={name:"developers/arbitrum-deploy.md"},i=n("",95),y=[i];function E(d,F,h,u,b,C){return a(),o("div",null,y)}const g=s(c,[["render",E]]);export{B as __pageData,g as default};
      diff --git a/pr-1680/assets/developers_arbitrum-full-node.md.1806878f.js b/pr-1680/assets/developers_arbitrum-full-node.md.3cfe6aa9.js
      similarity index 98%
      rename from pr-1680/assets/developers_arbitrum-full-node.md.1806878f.js
      rename to pr-1680/assets/developers_arbitrum-full-node.md.3cfe6aa9.js
      index 1194b56d1d..472d517702 100644
      --- a/pr-1680/assets/developers_arbitrum-full-node.md.1806878f.js
      +++ b/pr-1680/assets/developers_arbitrum-full-node.md.3cfe6aa9.js
      @@ -1,3 +1,3 @@
      -import{_ as n,o as e,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Running a full node and/or validator | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-full-node.md","filePath":"developers/arbitrum-full-node.md","lastUpdated":1724867275000}'),t={name:"developers/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 as e,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Running a full node and/or validator | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-full-node.md","filePath":"developers/arbitrum-full-node.md","lastUpdated":1725955670000}'),t={name:"developers/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 e(),o("div",null,i)}const m=n(t,[["render",l]]);export{g as __pageData,m as default}; diff --git a/pr-1680/assets/developers_arbitrum-full-node.md.1806878f.lean.js b/pr-1680/assets/developers_arbitrum-full-node.md.3cfe6aa9.lean.js similarity index 92% rename from pr-1680/assets/developers_arbitrum-full-node.md.1806878f.lean.js rename to pr-1680/assets/developers_arbitrum-full-node.md.3cfe6aa9.lean.js index d23b81d09c..975ea5ea68 100644 --- a/pr-1680/assets/developers_arbitrum-full-node.md.1806878f.lean.js +++ b/pr-1680/assets/developers_arbitrum-full-node.md.3cfe6aa9.lean.js @@ -1 +1 @@ -import{_ as n,o as e,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Running a full node and/or validator | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-full-node.md","filePath":"developers/arbitrum-full-node.md","lastUpdated":1724867275000}'),t={name:"developers/arbitrum-full-node.md"},r=a("",10),i=[r];function l(s,d,u,c,p,h){return e(),o("div",null,i)}const m=n(t,[["render",l]]);export{g as __pageData,m as default}; +import{_ as n,o as e,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Running a full node and/or validator | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-full-node.md","filePath":"developers/arbitrum-full-node.md","lastUpdated":1725955670000}'),t={name:"developers/arbitrum-full-node.md"},r=a("",10),i=[r];function l(s,d,u,c,p,h){return e(),o("div",null,i)}const m=n(t,[["render",l]]);export{g as __pageData,m as default}; diff --git a/pr-1680/assets/developers_arbitrum-integration.md.9e0aee21.js b/pr-1680/assets/developers_arbitrum-integration.md.8282c127.js similarity index 99% rename from pr-1680/assets/developers_arbitrum-integration.md.9e0aee21.js rename to pr-1680/assets/developers_arbitrum-integration.md.8282c127.js index 9049a759a4..f020c27791 100644 --- a/pr-1680/assets/developers_arbitrum-integration.md.9e0aee21.js +++ b/pr-1680/assets/developers_arbitrum-integration.md.8282c127.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-integration.md","filePath":"developers/arbitrum-integration.md","lastUpdated":1724867275000}'),o={name:"developers/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 "unpealed" 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 unpealed 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),s=[n];function l(h,c,d,m,b,u){return t(),a("div",null,s)}const g=e(o,[["render",l]]);export{f as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-integration.md","filePath":"developers/arbitrum-integration.md","lastUpdated":1725955670000}'),o={name:"developers/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 "unpealed" 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 unpealed 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),s=[n];function l(h,c,d,m,b,u){return t(),a("div",null,s)}const g=e(o,[["render",l]]);export{f as __pageData,g as default}; diff --git a/pr-1680/assets/developers_arbitrum-integration.md.9e0aee21.lean.js b/pr-1680/assets/developers_arbitrum-integration.md.8282c127.lean.js similarity index 93% rename from pr-1680/assets/developers_arbitrum-integration.md.9e0aee21.lean.js rename to pr-1680/assets/developers_arbitrum-integration.md.8282c127.lean.js index ebc80a3346..644c795662 100644 --- a/pr-1680/assets/developers_arbitrum-integration.md.9e0aee21.lean.js +++ b/pr-1680/assets/developers_arbitrum-integration.md.8282c127.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-integration.md","filePath":"developers/arbitrum-integration.md","lastUpdated":1724867275000}'),o={name:"developers/arbitrum-integration.md"},n=i("",34),s=[n];function l(h,c,d,m,b,u){return t(),a("div",null,s)}const g=e(o,[["render",l]]);export{f as __pageData,g as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Introduction to Arbitrum rollups with Celestia as DA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-integration.md","filePath":"developers/arbitrum-integration.md","lastUpdated":1725955670000}'),o={name:"developers/arbitrum-integration.md"},n=i("",34),s=[n];function l(h,c,d,m,b,u){return t(),a("div",null,s)}const g=e(o,[["render",l]]);export{f as __pageData,g as default}; diff --git a/pr-1680/assets/developers_arbitrum-smart-contract.md.26545321.js b/pr-1680/assets/developers_arbitrum-smart-contract.md.cc5d7a73.js similarity index 99% rename from pr-1680/assets/developers_arbitrum-smart-contract.md.26545321.js rename to pr-1680/assets/developers_arbitrum-smart-contract.md.cc5d7a73.js index ac09ab961b..f5c7d7380d 100644 --- a/pr-1680/assets/developers_arbitrum-smart-contract.md.26545321.js +++ b/pr-1680/assets/developers_arbitrum-smart-contract.md.cc5d7a73.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract to your Arbitrum rollup","description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","frontmatter":{"description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","head":[["meta",{"name":"og:title","content":"Deploy a smart contract to your Arbitrum rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-smart-contract.md","filePath":"developers/arbitrum-smart-contract.md","lastUpdated":1724867275000}'),l={name:"developers/arbitrum-smart-contract.md"},p=o(`

      Deploy a smart contract to your Arbitrum rollup

      Overview

      Welcome to the guide on deploying a smart contract to your Arbitrum rollup. In this tutorial, you will learn how to deploy a smart contract using the L2 Nitro devnet and the provided public and private keys for testing purposes.

      Prerequisites

      Setup

      First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

      bash
      cd $HOME
      +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract to your Arbitrum rollup","description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","frontmatter":{"description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","head":[["meta",{"name":"og:title","content":"Deploy a smart contract to your Arbitrum rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-smart-contract.md","filePath":"developers/arbitrum-smart-contract.md","lastUpdated":1725955670000}'),l={name:"developers/arbitrum-smart-contract.md"},p=o(`

      Deploy a smart contract to your Arbitrum rollup

      Overview

      Welcome to the guide on deploying a smart contract to your Arbitrum rollup. In this tutorial, you will learn how to deploy a smart contract using the L2 Nitro devnet and the provided public and private keys for testing purposes.

      Prerequisites

      Setup

      First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

      bash
      cd $HOME
       mkdir counter-project && cd counter-project && npm init -y
      cd $HOME
       mkdir counter-project && cd counter-project && npm init -y

      Next, initialize a Foundry project with the following command:

      bash
      forge init counter_contract
      forge init counter_contract

      Create your smart contract

      Take a look at the Counter.sol file in your counter-project/counter_contract/src directory:

      solidity
      // SPDX-License-Identifier: UNLICENSED
       pragma solidity ^0.8.13;
      diff --git a/pr-1680/assets/developers_arbitrum-smart-contract.md.26545321.lean.js b/pr-1680/assets/developers_arbitrum-smart-contract.md.cc5d7a73.lean.js
      similarity index 94%
      rename from pr-1680/assets/developers_arbitrum-smart-contract.md.26545321.lean.js
      rename to pr-1680/assets/developers_arbitrum-smart-contract.md.cc5d7a73.lean.js
      index d27fb8c8a4..47b404e75e 100644
      --- a/pr-1680/assets/developers_arbitrum-smart-contract.md.26545321.lean.js
      +++ b/pr-1680/assets/developers_arbitrum-smart-contract.md.cc5d7a73.lean.js
      @@ -1 +1 @@
      -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract to your Arbitrum rollup","description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","frontmatter":{"description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","head":[["meta",{"name":"og:title","content":"Deploy a smart contract to your Arbitrum rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-smart-contract.md","filePath":"developers/arbitrum-smart-contract.md","lastUpdated":1724867275000}'),l={name:"developers/arbitrum-smart-contract.md"},p=o("",60),e=[p];function t(c,r,i,y,E,u){return a(),n("div",null,e)}const h=s(l,[["render",t]]);export{F as __pageData,h as default};
      +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract to your Arbitrum rollup","description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","frontmatter":{"description":"A tutorial that guides you through the process of deploying a smart contract to your Arbitrum rollup using a L2 Nitro devnet, including setting up the environment, creating and testing the smart contract, and interacting with the deployed contract.","head":[["meta",{"name":"og:title","content":"Deploy a smart contract to your Arbitrum rollup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/arbitrum-smart-contract.md","filePath":"developers/arbitrum-smart-contract.md","lastUpdated":1725955670000}'),l={name:"developers/arbitrum-smart-contract.md"},p=o("",60),e=[p];function t(c,r,i,y,E,u){return a(),n("div",null,e)}const h=s(l,[["render",t]]);export{F as __pageData,h as default};
      diff --git a/pr-1680/assets/developers_blobstream-contracts.md.a96f5b10.js b/pr-1680/assets/developers_blobstream-contracts.md.94e59fda.js
      similarity index 84%
      rename from pr-1680/assets/developers_blobstream-contracts.md.a96f5b10.js
      rename to pr-1680/assets/developers_blobstream-contracts.md.94e59fda.js
      index 67db1b38a2..9fab285358 100644
      --- a/pr-1680/assets/developers_blobstream-contracts.md.a96f5b10.js
      +++ b/pr-1680/assets/developers_blobstream-contracts.md.94e59fda.js
      @@ -1,30 +1,29 @@
      -import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.a504a440.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":"New SP1 Blobstream deployments","link":"/developers/sp1-blobstream-deploy"},"head":[["meta",{"name":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-contracts.md","filePath":"developers/blobstream-contracts.md","lastUpdated":1724867275000}`),n={name:"developers/blobstream-contracts.md"},l=e(`

      Integrate with Blobstream contracts

      Getting started

      Prerequisites

      Make sure to have the following installed:

      Installing Blobstream X contracts

      We will be using the Blobstream X implementation of Blobstream, so we can install its repo as a dependency:

      Install the Blobstream X contracts repo as a dependency:

      sh
      forge install succinctlabs/blobstreamx --no-commit
      forge install succinctlabs/blobstreamx --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.a504a440.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":"New SP1 Blobstream deployments","link":"/developers/sp1-blobstream-deploy"},"head":[["meta",{"name":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-contracts.md","filePath":"developers/blobstream-contracts.md","lastUpdated":1725955670000}`),n={name:"developers/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;
       
      -TBD
       import "blobstream-contracts/IDAOracle.sol";
       import "blobstream-contracts/DataRootTuple.sol";
       import "blobstream-contracts/lib/tree/binary/BinaryMerkleProof.sol";
       
       contract MyRollup {
      -    IDAOracle immutable blobstreamX;
      +    IDAOracle immutable blobstream;
           bytes32[] public rollup_block_hashes;
       
      -    constructor(IDAOracle _blobstreamX) {
      -        blobstreamX = _blobstreamX;
      +    constructor(IDAOracle _blobstream) {
      +        blobstream = _blobstream;
           }
       
           function submitRollupBlock(
               bytes32 _rollup_block_hash,
               bytes calldata _zk_proof,
      -        uint256 _blobstreamX_nonce,
      +        uint256 _blobstream_nonce,
               DataRootTuple calldata _tuple,
               BinaryMerkleProof calldata _proof
           ) public {
               // Verify that the data root tuple (analog. block header) has been
               // attested to by the Blobstream contract.
               require(
      -            blobstreamX.verifyAttestation(_blobstreamX_nonce, _tuple, _proof)
      +            blobstream.verifyAttestation(_blobstream_nonce, _tuple, _proof)
               );
       
               // Verify the ZKP (zero-knowledge proof).
      @@ -45,30 +44,29 @@ import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.a504a440.js";const d=
       }
      // SPDX-License-Identifier: Apache-2.0
       pragma solidity ^0.8.19;
       
      -TBD
       import "blobstream-contracts/IDAOracle.sol";
       import "blobstream-contracts/DataRootTuple.sol";
       import "blobstream-contracts/lib/tree/binary/BinaryMerkleProof.sol";
       
       contract MyRollup {
      -    IDAOracle immutable blobstreamX;
      +    IDAOracle immutable blobstream;
           bytes32[] public rollup_block_hashes;
       
      -    constructor(IDAOracle _blobstreamX) {
      -        blobstreamX = _blobstreamX;
      +    constructor(IDAOracle _blobstream) {
      +        blobstream = _blobstream;
           }
       
           function submitRollupBlock(
               bytes32 _rollup_block_hash,
               bytes calldata _zk_proof,
      -        uint256 _blobstreamX_nonce,
      +        uint256 _blobstream_nonce,
               DataRootTuple calldata _tuple,
               BinaryMerkleProof calldata _proof
           ) public {
               // Verify that the data root tuple (analog. block header) has been
               // attested to by the Blobstream contract.
               require(
      -            blobstreamX.verifyAttestation(_blobstreamX_nonce, _tuple, _proof)
      +            blobstream.verifyAttestation(_blobstream_nonce, _tuple, _proof)
               );
       
               // Verify the ZKP (zero-knowledge proof).
      @@ -86,4 +84,4 @@ import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.a504a440.js";const d=
           ) 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.

      `,28),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}; +}

      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.

      `,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-1680/assets/developers_blobstream-contracts.md.a96f5b10.lean.js b/pr-1680/assets/developers_blobstream-contracts.md.94e59fda.lean.js similarity index 86% rename from pr-1680/assets/developers_blobstream-contracts.md.a96f5b10.lean.js rename to pr-1680/assets/developers_blobstream-contracts.md.94e59fda.lean.js index 4e408269d6..64ecd02f7b 100644 --- a/pr-1680/assets/developers_blobstream-contracts.md.a96f5b10.lean.js +++ b/pr-1680/assets/developers_blobstream-contracts.md.94e59fda.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.a504a440.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":"New SP1 Blobstream deployments","link":"/developers/sp1-blobstream-deploy"},"head":[["meta",{"name":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-contracts.md","filePath":"developers/blobstream-contracts.md","lastUpdated":1724867275000}`),n={name:"developers/blobstream-contracts.md"},l=e("",28),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.a504a440.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":"New SP1 Blobstream deployments","link":"/developers/sp1-blobstream-deploy"},"head":[["meta",{"name":"og:title","content":"Integrate with Blobstream contracts | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-contracts.md","filePath":"developers/blobstream-contracts.md","lastUpdated":1725955670000}`),n={name:"developers/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-1680/assets/developers_blobstream-offchain.md.714e874f.js b/pr-1680/assets/developers_blobstream-offchain.md.628432c8.js similarity index 98% rename from pr-1680/assets/developers_blobstream-offchain.md.714e874f.js rename to pr-1680/assets/developers_blobstream-offchain.md.628432c8.js index bc5d269074..dad251386c 100644 --- a/pr-1680/assets/developers_blobstream-offchain.md.714e874f.js +++ b/pr-1680/assets/developers_blobstream-offchain.md.628432c8.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Integrate with Blobstream client | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-offchain.md","filePath":"developers/blobstream-offchain.md","lastUpdated":1724867275000}`),e={name:"developers/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 X 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.a504a440.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",{"name":"og:title","content":"Integrate with Blobstream client | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-offchain.md","filePath":"developers/blobstream-offchain.md","lastUpdated":1725955670000}`),e={name:"developers/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-1680/assets/developers_blobstream-offchain.md.714e874f.lean.js b/pr-1680/assets/developers_blobstream-offchain.md.628432c8.lean.js
      similarity index 91%
      rename from pr-1680/assets/developers_blobstream-offchain.md.714e874f.lean.js
      rename to pr-1680/assets/developers_blobstream-offchain.md.628432c8.lean.js
      index c595dbd8be..5b195f1c20 100644
      --- a/pr-1680/assets/developers_blobstream-offchain.md.714e874f.lean.js
      +++ b/pr-1680/assets/developers_blobstream-offchain.md.628432c8.lean.js
      @@ -1 +1 @@
      -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Integrate with Blobstream client | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-offchain.md","filePath":"developers/blobstream-offchain.md","lastUpdated":1724867275000}`),e={name:"developers/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.a504a440.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",{"name":"og:title","content":"Integrate with Blobstream client | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-offchain.md","filePath":"developers/blobstream-offchain.md","lastUpdated":1725955670000}`),e={name:"developers/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-1680/assets/developers_blobstream-proof-queries.md.8321ccb1.js b/pr-1680/assets/developers_blobstream-proof-queries.md.cf3a9152.js
      similarity index 93%
      rename from pr-1680/assets/developers_blobstream-proof-queries.md.8321ccb1.js
      rename to pr-1680/assets/developers_blobstream-proof-queries.md.cf3a9152.js
      index 2282006fc8..86214f279a 100644
      --- a/pr-1680/assets/developers_blobstream-proof-queries.md.8321ccb1.js
      +++ b/pr-1680/assets/developers_blobstream-proof-queries.md.cf3a9152.js
      @@ -1,4 +1,4 @@
      -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1680/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","next":{"text":"Requesting data commitment ranges","link":"/developers/blobstream-x-requesting-data-commitment-ranges"},"head":[["meta",{"name":"og:title","content":"Blobstream proofs queries | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-proof-queries.md","filePath":"developers/blobstream-proof-queries.md","lastUpdated":1724867275000}'),e={name:"developers/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.a504a440.js";const o="/docs-preview/pr-1680/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1680/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","next":{"text":"Requesting data commitment ranges","link":"/developers/blobstream-x-requesting-data-commitment-ranges"},"head":[["meta",{"name":"og:title","content":"Blobstream proofs queries | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-proof-queries.md","filePath":"developers/blobstream-proof-queries.md","lastUpdated":1725955670000}'),e={name:"developers/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.a504a440.js";const o=
       		if err != nil {
       			...
       		}
      -	}(trpc)

      The <rpc_endpoint> can be retrieved from mainnet for Celestia mainnet beta, 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 Blobstream X repository. 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. Currently, we will be using the Blobstream X implementation of Blobstream, more information on Blobstream X can be found in the overview. In a nutshell, Blobstream X attests to the data posted to Celestia in the Blobstream X 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 X 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 X 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 for Celestia mainnet beta, 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
      @@ -36,7 +36,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
           github.com/syndtr/goleveldb => github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7
           github.com/tendermint/tendermint => github.com/celestiaorg/celestia-core v1.32.0-tm-v0.34.29
       
      -)

      Also, make sure to update the versions to match the latest github.com/celestiaorg/cosmos-sdk and github.com/celestiaorg/celestia-core versions.

      1. Data root inclusion proof

      To prove the data root is committed to by the Blobstream X 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.

      This endpoint allows querying a data root to data root tuple root proof. It takes a block height, a starting block, and an end block, then it generates the binary Merkle proof of the DataRootTuple, corresponding to that height, to the DataRootTupleRoot which is committed to in the Blobstream X contract.

      HTTP query

      Example HTTP request: <tendermint_rpc_endpoint>/data_root_inclusion_proof?height=15&start=10&end=20

      Which queries the proof of the height 15 to the data commitment defined by the range [10, 20).

      Example response:

      json
      {
      +)

      Also, make sure to update the versions to match the latest github.com/celestiaorg/cosmos-sdk and github.com/celestiaorg/celestia-core versions.

      1. Data root inclusion proof

      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.

      This endpoint allows querying a data root to data root tuple root proof. It takes a block height, a starting block, and an end block, then it generates the binary Merkle proof of the DataRootTuple, corresponding to that height, to the DataRootTupleRoot which is committed to in the Blobstream contract.

      HTTP query

      Example HTTP request: <tendermint_rpc_endpoint>/data_root_inclusion_proof?height=15&start=10&end=20

      Which queries the proof of the height 15 to the data commitment defined by the range [10, 20).

      Example response:

      json
      {
         "jsonrpc": "2.0",
         "id": -1,
         "result": {
      @@ -122,7 +122,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       		os.Exit(1)
       	}
       	fmt.Println(dcProof.Proof.String())
      -}

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

      go
      package main
      +}

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

      go
      package main
       
       import (
       	"context"
      @@ -249,7 +249,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       		fmt.Println("data root was not committed to by the BlobstreamX contract")
       		return nil
       	}
      -    return nil
      +	return nil
       }
       
       func VerifyDataRootInclusion(
      @@ -412,7 +412,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       		fmt.Println("data root was not committed to by the BlobstreamX contract")
       		return nil
       	}
      -    return nil
      +	return nil
       }
       
       func VerifyDataRootInclusion(
      @@ -448,7 +448,13 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       		return false, err
       	}
       	return valid, nil
      -}

      2. Transaction inclusion proof

      To prove that a rollup transaction, the PFB transaction and not the blob containing the Rollup blocks data, is part of the data root, we will need to provide two proofs: (1) a namespace Merkle proof of the transaction to a row root. This could be done via proving the shares that contain the transaction to the row root using a namespace Merkle proof. (2) And a binary Merkle proof of the row root to the data root.

      Transaction inclusion proof using the transaction hash

      Given a transaction hash, the transaction inclusion proof can be queried from the transaction query.

      HTTP request

      Example request: <tendermint_rpc_endpoint>/tx?hash=0xEF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8&prove=true

      Which queries the transaction whose hash is EF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8 and sets the prove parameter as true to also get its inclusion proof.

      Example response:

      json
      {
      +}
      go
      // Similar to Blobstream, except replace the BlobstreamX contract with SP1 Blobstream:
      +import {
      +  sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
      +}
      // Similar to Blobstream, except replace the BlobstreamX contract with SP1 Blobstream:
      +import {
      +  sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
      +}

      2. Transaction inclusion proof

      To prove that a rollup transaction, the PFB transaction and not the blob containing the Rollup blocks data, is part of the data root, we will need to provide two proofs: (1) a namespace Merkle proof of the transaction to a row root. This could be done via proving the shares that contain the transaction to the row root using a namespace Merkle proof. (2) And a binary Merkle proof of the row root to the data root.

      Transaction inclusion proof using the transaction hash

      Given a transaction hash, the transaction inclusion proof can be queried from the transaction query.

      HTTP request

      Example request: <tendermint_rpc_endpoint>/tx?hash=0xEF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8&prove=true

      Which queries the transaction whose hash is EF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8 and sets the prove parameter as true to also get its inclusion proof.

      Example response:

      json
      {
         "jsonrpc": "2.0",
         "id": -1,
         "result": {
      @@ -761,12 +767,12 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
           NamespaceNode[] rowRoots;
           // The proofs of the rowRoots to the data root.
           BinaryMerkleProof[] rowProofs;
      -    // The proof of the data root tuple to the data root tuple root that was posted to the BlobstreamX contract.
      +    // The proof of the data root tuple to the data root tuple root that was posted to the Blobstream contract.
           AttestationProof attestationProof;
       }
       
       /// @notice Contains the necessary parameters needed to verify that a data root tuple
      -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
      +/// was committed to, by the Blobstream smart contract, at some specif nonce.
       struct AttestationProof {
           // the attestation nonce that commits to the data root tuple.
           uint256 tupleRootNonce;
      @@ -787,12 +793,12 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
           NamespaceNode[] rowRoots;
           // The proofs of the rowRoots to the data root.
           BinaryMerkleProof[] rowProofs;
      -    // The proof of the data root tuple to the data root tuple root that was posted to the BlobstreamX contract.
      +    // The proof of the data root tuple to the data root tuple root that was posted to the Blobstream contract.
           AttestationProof attestationProof;
       }
       
       /// @notice Contains the necessary parameters needed to verify that a data root tuple
      -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
      +/// was committed to, by the Blobstream smart contract, at some specif nonce.
       struct AttestationProof {
           // the attestation nonce that commits to the data root tuple.
           uint256 tupleRootNonce;
      @@ -1026,8 +1032,8 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       		}
       	}
       	return rowProofs
      -}

      with proofs being sharesProof.RowProof.Proofs.

      attestationProof

      This is the proof of the data root to the data root tuple root, which is committed to in the Blobstream X contract:

      solidity
      /// @notice Contains the necessary parameters needed to verify that a data root tuple
      -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
      +}

      with proofs being sharesProof.RowProof.Proofs.

      attestationProof

      This is the proof of the data root to the data root tuple root, which is committed to in the Blobstream contract:

      solidity
      /// @notice Contains the necessary parameters needed to verify that a data root tuple
      +/// was committed to, by the Blobstream smart contract, at some specif nonce.
       struct AttestationProof {
           // the attestation nonce that commits to the data root tuple.
           uint256 tupleRootNonce;
      @@ -1036,7 +1042,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
           // the binary Merkle proof of the tuple to the commitment.
           BinaryMerkleProof proof;
       }
      /// @notice Contains the necessary parameters needed to verify that a data root tuple
      -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
      +/// was committed to, by the Blobstream smart contract, at some specif nonce.
       struct AttestationProof {
           // the attestation nonce that commits to the data root tuple.
           uint256 tupleRootNonce;
      @@ -1044,7 +1050,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
           DataRootTuple tuple;
           // the binary Merkle proof of the tuple to the commitment.
           BinaryMerkleProof proof;
      -}
      • tupleRootNonce: the nonce at which Blobstream X committed to the batch containing the block containing the data.
      • tuple: the DataRootTuple of the block:
      solidity
      /// @notice A tuple of data root with metadata. Each data root is associated
      +}
      • tupleRootNonce: the nonce at which Blobstream committed to the batch containing the block containing the data.
      • tuple: the DataRootTuple of the block:
      solidity
      /// @notice A tuple of data root with metadata. Each data root is associated
       ///  with a Celestia block height.
       /// @dev \`availableDataRoot\` in
       ///  https://github.com/celestiaorg/celestia-specs/blob/master/src/specs/data_structures.md#header
      @@ -1116,7 +1122,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       			NumLeaves: big.NewInt(dataRootInclusionProof.Total),
       		},
       	}
      -}

      With the nonce being the attestation nonce, which can be retrieved using BlobstreamX 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 BlobstreamXDataCommitmentStored events from the BlobstreamX contract and looking for the nonce attesting to the corresponding data. An example:

      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
      @@ -1230,7 +1236,17 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       	}
       	if event == nil {
       		return fmt.Errorf("couldn't find range containing the block height")
      -	}

      Listening for new data commitments

      For listening for new BlobstreamXDataCommitmentStored events, sequencers can use the WatchDataCommitmentStored as follows:

      go
          ethClient, err := ethclient.Dial("evm_rpc")
      +	}
      go
      // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
      +// import the SP1 Blobstream contract:
      +import {
      +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
      +} 
      +// and use the \`BlobstreamDataCommitmentStored\` event instead.
      // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
      +// import the SP1 Blobstream contract:
      +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")
           if err != nil {
       	    return err
           }
      @@ -1300,7 +1316,17 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       			// process the event
       		    fmt.Println(event)
       	    }
      -    }

      Then, new proofs can be created as documented above using the new data commitments contained in the received events.

      Example rollup that uses the DAVerifier

      An example rollup that uses the DAVerifier can be as simple as:

      solidity
      pragma solidity ^0.8.22;
      +    }
      go
      // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
      +// import the SP1 Blobstream contract:
      +import {
      +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
      +} 
      +// and use the \`BlobstreamDataCommitmentStored\` event instead.
      // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
      +// import the SP1 Blobstream contract:
      +import {
      +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
      +} 
      +// and use the \`BlobstreamDataCommitmentStored\` event instead.

      Then, new proofs can be created as documented above using the new data commitments contained in the received events.

      Example rollup that uses the DAVerifier

      An example rollup that uses the DAVerifier can be as simple as:

      solidity
      pragma solidity ^0.8.22;
       
       import {DAVerifier} from "@blobstream/lib/verifier/DAVerifier.sol";
       import {IDAOracle} from "@blobstream/IDAOracle.sol";
      @@ -1338,7 +1364,7 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.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"
      @@ -1802,4 +1828,14 @@ import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o=
       		Version: [1]byte{version},
       		Id:      id,
       	}
      -}

      For the step (2), check the rollup inclusion proofs documentation for more information.

      For an example project that uses the above proof queries, checkout the blobstreamx-example sample project.

      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.

      `,154),c=[t];function r(E,y,i,A,F,u){return n(),a("div",null,c)}const C=s(e,[["render",r]]);export{h as __pageData,C as default}; +}
      go
      // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
      +// import the SP1 Blobstream contract:
      +import {
      +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
      +} 
      +// and use the \`BlobstreamDataCommitmentStored\` event instead.
      // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
      +// import the SP1 Blobstream contract:
      +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.

      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.

      `,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-1680/assets/developers_blobstream-proof-queries.md.8321ccb1.lean.js b/pr-1680/assets/developers_blobstream-proof-queries.md.cf3a9152.lean.js similarity index 81% rename from pr-1680/assets/developers_blobstream-proof-queries.md.8321ccb1.lean.js rename to pr-1680/assets/developers_blobstream-proof-queries.md.cf3a9152.lean.js index e20dc35747..9302e69456 100644 --- a/pr-1680/assets/developers_blobstream-proof-queries.md.8321ccb1.lean.js +++ b/pr-1680/assets/developers_blobstream-proof-queries.md.cf3a9152.lean.js @@ -1 +1 @@ -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1680/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","next":{"text":"Requesting data commitment ranges","link":"/developers/blobstream-x-requesting-data-commitment-ranges"},"head":[["meta",{"name":"og:title","content":"Blobstream proofs queries | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-proof-queries.md","filePath":"developers/blobstream-proof-queries.md","lastUpdated":1724867275000}'),e={name:"developers/blobstream-proof-queries.md"},t=l("",154),c=[t];function r(E,y,i,A,F,u){return n(),a("div",null,c)}const C=s(e,[["render",r]]);export{h as __pageData,C as default}; +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/blobstream/blobstream-square.png",p="/docs-preview/pr-1680/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","next":{"text":"Requesting data commitment ranges","link":"/developers/blobstream-x-requesting-data-commitment-ranges"},"head":[["meta",{"name":"og:title","content":"Blobstream proofs queries | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-proof-queries.md","filePath":"developers/blobstream-proof-queries.md","lastUpdated":1725955670000}'),e={name:"developers/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-1680/assets/developers_blobstream-rollups.md.67f5cc25.js b/pr-1680/assets/developers_blobstream-rollups.md.41e4a8bc.js similarity index 99% rename from pr-1680/assets/developers_blobstream-rollups.md.67f5cc25.js rename to pr-1680/assets/developers_blobstream-rollups.md.41e4a8bc.js index e171063d29..ccade55185 100644 --- a/pr-1680/assets/developers_blobstream-rollups.md.67f5cc25.js +++ b/pr-1680/assets/developers_blobstream-rollups.md.41e4a8bc.js @@ -1,3 +1,3 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.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":"/developers/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/developers/submit-data"},"head":[["meta",{"name":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-rollups.md","filePath":"developers/blobstream-rollups.md","lastUpdated":1724867275000}'),s={name:"developers/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.a504a440.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":"/developers/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/developers/submit-data"},"head":[["meta",{"name":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-rollups.md","filePath":"developers/blobstream-rollups.md","lastUpdated":1725955670000}'),s={name:"developers/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-1680/assets/developers_blobstream-rollups.md.67f5cc25.lean.js b/pr-1680/assets/developers_blobstream-rollups.md.41e4a8bc.lean.js similarity index 92% rename from pr-1680/assets/developers_blobstream-rollups.md.67f5cc25.lean.js rename to pr-1680/assets/developers_blobstream-rollups.md.41e4a8bc.lean.js index 2c1e9d2e22..bb0e0ea668 100644 --- a/pr-1680/assets/developers_blobstream-rollups.md.67f5cc25.lean.js +++ b/pr-1680/assets/developers_blobstream-rollups.md.41e4a8bc.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.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":"/developers/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/developers/submit-data"},"head":[["meta",{"name":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-rollups.md","filePath":"developers/blobstream-rollups.md","lastUpdated":1724867275000}'),s={name:"developers/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.a504a440.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":"/developers/ethereum-fallback"},"next":{"text":"Submitting data blobs to Celestia","link":"/developers/submit-data"},"head":[["meta",{"name":"og:title","content":"Introduction to Blobstream rollups | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-rollups.md","filePath":"developers/blobstream-rollups.md","lastUpdated":1725955670000}'),s={name:"developers/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-1680/assets/developers_blobstream-x-deploy.md.16c5ae12.js b/pr-1680/assets/developers_blobstream-x-deploy.md.3886b5a3.js similarity index 99% rename from pr-1680/assets/developers_blobstream-x-deploy.md.16c5ae12.js rename to pr-1680/assets/developers_blobstream-x-deploy.md.3886b5a3.js index e2895c5b8e..bbe2c81c2b 100644 --- a/pr-1680/assets/developers_blobstream-x-deploy.md.16c5ae12.js +++ b/pr-1680/assets/developers_blobstream-x-deploy.md.3886b5a3.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/developers/celestia-node-key"},"head":[["meta",{"name":"og:title","content":"New Blobstream X deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-deploy.md","filePath":"developers/blobstream-x-deploy.md","lastUpdated":1724867275000}'),o={name:"developers/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.a504a440.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/developers/celestia-node-key"},"head":[["meta",{"name":"og:title","content":"New Blobstream X deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-deploy.md","filePath":"developers/blobstream-x-deploy.md","lastUpdated":1725955670000}'),o={name:"developers/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-1680/assets/developers_blobstream-x-deploy.md.16c5ae12.lean.js b/pr-1680/assets/developers_blobstream-x-deploy.md.3886b5a3.lean.js
        similarity index 90%
        rename from pr-1680/assets/developers_blobstream-x-deploy.md.16c5ae12.lean.js
        rename to pr-1680/assets/developers_blobstream-x-deploy.md.3886b5a3.lean.js
        index 9d334a77c8..b0ac4ab7be 100644
        --- a/pr-1680/assets/developers_blobstream-x-deploy.md.16c5ae12.lean.js
        +++ b/pr-1680/assets/developers_blobstream-x-deploy.md.3886b5a3.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/developers/celestia-node-key"},"head":[["meta",{"name":"og:title","content":"New Blobstream X deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-deploy.md","filePath":"developers/blobstream-x-deploy.md","lastUpdated":1724867275000}'),o={name:"developers/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.a504a440.js";const u=JSON.parse('{"title":"New Blobstream X deployments","description":"","frontmatter":{"next":{"text":"Celestia-node key","link":"/developers/celestia-node-key"},"head":[["meta",{"name":"og:title","content":"New Blobstream X deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-deploy.md","filePath":"developers/blobstream-x-deploy.md","lastUpdated":1725955670000}'),o={name:"developers/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-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.js b/pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.js
        similarity index 98%
        rename from pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.js
        rename to pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.js
        index 0f3e66d6c9..74c169d39a 100644
        --- a/pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.js
        +++ b/pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.js
        @@ -1 +1 @@
        -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Querying the Blobstream proofs","link":"/developers/blobstream-proof-queries"},"head":[["meta",{"name":"og:title","content":"Requesting data commitment ranges | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","filePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1724867275000}'),r={name:"developers/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.

        ::: Note 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.a504a440.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Querying the Blobstream proofs","link":"/developers/blobstream-proof-queries"},"head":[["meta",{"name":"og:title","content":"Requesting data commitment ranges | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","filePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1725955670000}'),r={name:"developers/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.

        ::: Note 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-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.lean.js b/pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.lean.js similarity index 92% rename from pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.lean.js rename to pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.lean.js index c25a766a51..9e1949df09 100644 --- a/pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.0ac98150.lean.js +++ b/pr-1680/assets/developers_blobstream-x-requesting-data-commitment-ranges.md.4aa3e66e.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Querying the Blobstream proofs","link":"/developers/blobstream-proof-queries"},"head":[["meta",{"name":"og:title","content":"Requesting data commitment ranges | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","filePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1724867275000}'),r={name:"developers/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.a504a440.js";const f=JSON.parse('{"title":"Requesting data commitment ranges","description":"","frontmatter":{"prev":{"text":"Querying the Blobstream proofs","link":"/developers/blobstream-proof-queries"},"head":[["meta",{"name":"og:title","content":"Requesting data commitment ranges | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","filePath":"developers/blobstream-x-requesting-data-commitment-ranges.md","lastUpdated":1725955670000}'),r={name:"developers/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-1680/assets/developers_blobstream.md.5a20f3f8.js b/pr-1680/assets/developers_blobstream.md.5a20f3f8.js deleted file mode 100644 index 2115ba6462..0000000000 --- a/pr-1680/assets/developers_blobstream.md.5a20f3f8.js +++ /dev/null @@ -1 +0,0 @@ -import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/blobstream/blobstream_logo.png",s="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X1b.png",l="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X2b.png",y=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",{"name":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream.md","filePath":"developers/blobstream.md","lastUpdated":1724867275000}'),i={name:"developers/blobstream.md"},n=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.

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

        Learn more at the sp1-blobstream repo.

        What is Blobstream X?

        Blobstream X is an 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. Blobstream X utilizes 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 Blobstream X Ethereum smart contract to update it with the latest Celestia header.

        The Blobstream X 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.

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

        blobstream x draft diagram

        Integrate with Blobstream X

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

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

        The first deployments of Blobstream X 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 X contract that will include a new data commitment range that covers a 1-hour block range from the latestBlock in the Blobstream X contract. On Ethereum Mainnet, the Blobstream X contract will be updated every 4 hours.

        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.

        How to integrate with Blobstream X

        Integrating your L2 with Blobstream X 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 Blobstream X contracts today. The Blobstream X Solidity smart contracts are currently deployed on the following chains:

        WARNING

        Blobstream X is in beta and slashing is not enabled yet.

        ContractEVM networkContract addressAttested data on CelestiaLink to Celenium
        Blobstream XEthereum Mainnet0x7Cf3876F681Dbb6EdA8f6FfC45D66B996Df08fAeMainnet BetaDeployment on Celenium
        Blobstream XArbitrum One0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
        Blobstream XBase0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
        Blobstream XSepolia0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1eMocha testnetDeployment on Celenium
        Blobstream XArbitrum Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
        Blobstream XBase Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium

        Deploy Blobstream X

        If your target chain is still not supported, 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.

        ',52),c=[n];function h(b,m,d,p,u,f){return t(),a("div",null,c)}const B=e(i,[["render",h]]);export{y as __pageData,B as default}; diff --git a/pr-1680/assets/developers_blobstream.md.5a20f3f8.lean.js b/pr-1680/assets/developers_blobstream.md.5a20f3f8.lean.js deleted file mode 100644 index 251f35f446..0000000000 --- a/pr-1680/assets/developers_blobstream.md.5a20f3f8.lean.js +++ /dev/null @@ -1 +0,0 @@ -import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/blobstream/blobstream_logo.png",s="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X1b.png",l="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X2b.png",y=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",{"name":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream.md","filePath":"developers/blobstream.md","lastUpdated":1724867275000}'),i={name:"developers/blobstream.md"},n=r("",52),c=[n];function h(b,m,d,p,u,f){return t(),a("div",null,c)}const B=e(i,[["render",h]]);export{y as __pageData,B as default}; diff --git a/pr-1680/assets/developers_blobstream.md.7c6b29b0.js b/pr-1680/assets/developers_blobstream.md.7c6b29b0.js new file mode 100644 index 0000000000..6e613101fe --- /dev/null +++ b/pr-1680/assets/developers_blobstream.md.7c6b29b0.js @@ -0,0 +1 @@ +import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/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",{"name":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream.md","filePath":"developers/blobstream.md","lastUpdated":1725955670000}'),s={name:"developers/blobstream.md"},l=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),i=[l];function n(h,c,m,b,d,p){return t(),a("div",null,i)}const g=e(s,[["render",n]]);export{f as __pageData,g as default}; diff --git a/pr-1680/assets/developers_blobstream.md.7c6b29b0.lean.js b/pr-1680/assets/developers_blobstream.md.7c6b29b0.lean.js new file mode 100644 index 0000000000..abf43f3b96 --- /dev/null +++ b/pr-1680/assets/developers_blobstream.md.7c6b29b0.lean.js @@ -0,0 +1 @@ +import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/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",{"name":"og:title","content":"Blobstream: Streaming modular DA to Ethereum | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstream.md","filePath":"developers/blobstream.md","lastUpdated":1725955670000}'),s={name:"developers/blobstream.md"},l=r("",39),i=[l];function n(h,c,m,b,d,p){return t(),a("div",null,i)}const g=e(s,[["render",n]]);export{f as __pageData,g as default}; diff --git a/pr-1680/assets/developers_blobstreamx.md.7d123eea.js b/pr-1680/assets/developers_blobstreamx.md.7d123eea.js new file mode 100644 index 0000000000..7f1a3831ee --- /dev/null +++ b/pr-1680/assets/developers_blobstreamx.md.7d123eea.js @@ -0,0 +1 @@ +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X1b.png",s="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X2b.png",g=JSON.parse('{"title":"BlobstreamX: the previous zk implementation of Blobstream","description":"What is BlobstreamX","frontmatter":{"description":"What is BlobstreamX","head":[["meta",{"name":"og:title","content":"BlobstreamX: the previous zk implementation of Blobstream | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstreamx.md","filePath":"developers/blobstreamx.md","lastUpdated":1725955670000}'),c={name:"developers/blobstreamx.md"},l=a('

        BlobstreamX: 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.

        ',18),n=[l];function i(b,m,d,h,p,u){return t(),o("div",null,n)}const B=e(c,[["render",i]]);export{g as __pageData,B as default}; diff --git a/pr-1680/assets/developers_blobstreamx.md.7d123eea.lean.js b/pr-1680/assets/developers_blobstreamx.md.7d123eea.lean.js new file mode 100644 index 0000000000..a157c6ea23 --- /dev/null +++ b/pr-1680/assets/developers_blobstreamx.md.7d123eea.lean.js @@ -0,0 +1 @@ +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X1b.png",s="/docs-preview/pr-1680/img/blobstream/Celestia_Blobstream_X2b.png",g=JSON.parse('{"title":"BlobstreamX: the previous zk implementation of Blobstream","description":"What is BlobstreamX","frontmatter":{"description":"What is BlobstreamX","head":[["meta",{"name":"og:title","content":"BlobstreamX: the previous zk implementation of Blobstream | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/blobstreamx.md","filePath":"developers/blobstreamx.md","lastUpdated":1725955670000}'),c={name:"developers/blobstreamx.md"},l=a("",18),n=[l];function i(b,m,d,h,p,u){return t(),o("div",null,n)}const B=e(c,[["render",i]]);export{g as __pageData,B as default}; diff --git a/pr-1680/assets/developers_bubs-testnet.md.e6fe9bf8.js b/pr-1680/assets/developers_bubs-testnet.md.6fd541b2.js similarity index 98% rename from pr-1680/assets/developers_bubs-testnet.md.e6fe9bf8.js rename to pr-1680/assets/developers_bubs-testnet.md.6fd541b2.js index dda63770f2..967a774855 100644 --- a/pr-1680/assets/developers_bubs-testnet.md.e6fe9bf8.js +++ b/pr-1680/assets/developers_bubs-testnet.md.6fd541b2.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as s}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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":"Deploy a smart contract on Bubs testnet","link":"/developers/deploy-on-bubs"},"head":[["meta",{"name":"og:title","content":"Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/bubs-testnet.md","filePath":"developers/bubs-testnet.md","lastUpdated":1724867275000}'),o={name:"developers/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,p,d,u,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.a504a440.js";const r="/docs-preview/pr-1680/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":"Deploy a smart contract on Bubs testnet","link":"/developers/deploy-on-bubs"},"head":[["meta",{"name":"og:title","content":"Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/bubs-testnet.md","filePath":"developers/bubs-testnet.md","lastUpdated":1725955670000}'),o={name:"developers/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,p,d,u,b){return t(),a("div",null,n)}const g=e(o,[["render",l]]);export{m as __pageData,g as default}; diff --git a/pr-1680/assets/developers_bubs-testnet.md.e6fe9bf8.lean.js b/pr-1680/assets/developers_bubs-testnet.md.6fd541b2.lean.js similarity index 92% rename from pr-1680/assets/developers_bubs-testnet.md.e6fe9bf8.lean.js rename to pr-1680/assets/developers_bubs-testnet.md.6fd541b2.lean.js index 6e27372f4a..c2859263b1 100644 --- a/pr-1680/assets/developers_bubs-testnet.md.e6fe9bf8.lean.js +++ b/pr-1680/assets/developers_bubs-testnet.md.6fd541b2.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as s}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/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":"Deploy a smart contract on Bubs testnet","link":"/developers/deploy-on-bubs"},"head":[["meta",{"name":"og:title","content":"Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/bubs-testnet.md","filePath":"developers/bubs-testnet.md","lastUpdated":1724867275000}'),o={name:"developers/bubs-testnet.md"},i=s("",29),n=[i];function l(h,c,p,d,u,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.a504a440.js";const r="/docs-preview/pr-1680/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":"Deploy a smart contract on Bubs testnet","link":"/developers/deploy-on-bubs"},"head":[["meta",{"name":"og:title","content":"Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/bubs-testnet.md","filePath":"developers/bubs-testnet.md","lastUpdated":1725955670000}'),o={name:"developers/bubs-testnet.md"},i=s("",29),n=[i];function l(h,c,p,d,u,b){return t(),a("div",null,n)}const g=e(o,[["render",l]]);export{m as __pageData,g as default}; diff --git a/pr-1680/assets/developers_build-whatever.md.a1d2e5ba.js b/pr-1680/assets/developers_build-whatever.md.30271c51.js similarity index 99% rename from pr-1680/assets/developers_build-whatever.md.a1d2e5ba.js rename to pr-1680/assets/developers_build-whatever.md.30271c51.js index 1146d78779..1866f072e9 100644 --- a/pr-1680/assets/developers_build-whatever.md.a1d2e5ba.js +++ b/pr-1680/assets/developers_build-whatever.md.30271c51.js @@ -1 +1 @@ -import{_ as d,o as l,c as r,k as t,t as i,e as p,H as e,Q as s,a as n}from"./chunks/framework.a504a440.js";const h="/docs-preview/pr-1680/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},b=["href"],g={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function w(c,u,o,B,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",g,[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)):p("",!0)])],8,b)}const a=d(m,[["render",w],["__scopeId","data-v-21baf7e3"]]),_=s('

        Build whatever

        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),v={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},x=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),q=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),A={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),R=JSON.parse('{"title":"Build whatever","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"name":"og:title","content":"Build whatever | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/build-whatever.md","filePath":"developers/build-whatever.md","lastUpdated":1724867275000}'),O={name:"developers/build-whatever.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[_,t("div",v,[e(a,{url:"/developers/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:"/developers/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/build/overview/",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"})]),x,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,q,t("div",A,[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{R as __pageData,I as default}; +import{_ as d,o as l,c as r,k as t,t as i,e as p,H as e,Q as s,a as n}from"./chunks/framework.a504a440.js";const h="/docs-preview/pr-1680/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},b=["href"],g={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function w(c,u,o,B,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",g,[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)):p("",!0)])],8,b)}const a=d(m,[["render",w],["__scopeId","data-v-21baf7e3"]]),_=s('

        Build whatever

        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),v={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},x=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),q=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),A={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),R=JSON.parse('{"title":"Build whatever","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"name":"og:title","content":"Build whatever | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/build-whatever.md","filePath":"developers/build-whatever.md","lastUpdated":1725955670000}'),O={name:"developers/build-whatever.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[_,t("div",v,[e(a,{url:"/developers/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:"/developers/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/build/overview/",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"})]),x,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,q,t("div",A,[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{R as __pageData,I as default}; diff --git a/pr-1680/assets/developers_build-whatever.md.a1d2e5ba.lean.js b/pr-1680/assets/developers_build-whatever.md.30271c51.lean.js similarity index 98% rename from pr-1680/assets/developers_build-whatever.md.a1d2e5ba.lean.js rename to pr-1680/assets/developers_build-whatever.md.30271c51.lean.js index 89ac70ec7f..59ea0b75bb 100644 --- a/pr-1680/assets/developers_build-whatever.md.a1d2e5ba.lean.js +++ b/pr-1680/assets/developers_build-whatever.md.30271c51.lean.js @@ -1 +1 @@ -import{_ as d,o as l,c as r,k as t,t as i,e as p,H as e,Q as s,a as n}from"./chunks/framework.a504a440.js";const h="/docs-preview/pr-1680/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},b=["href"],g={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function w(c,u,o,B,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",g,[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)):p("",!0)])],8,b)}const a=d(m,[["render",w],["__scopeId","data-v-21baf7e3"]]),_=s("",6),v={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},x=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),q=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),A={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),R=JSON.parse('{"title":"Build whatever","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"name":"og:title","content":"Build whatever | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/build-whatever.md","filePath":"developers/build-whatever.md","lastUpdated":1724867275000}'),O={name:"developers/build-whatever.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[_,t("div",v,[e(a,{url:"/developers/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:"/developers/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/build/overview/",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"})]),x,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,q,t("div",A,[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{R as __pageData,I as default}; +import{_ as d,o as l,c as r,k as t,t as i,e as p,H as e,Q as s,a as n}from"./chunks/framework.a504a440.js";const h="/docs-preview/pr-1680/img/da-and-validity.png";const m={name:"UrlImageButton",props:{url:String,imageSrc:String,text:String,notes:{type:String,default:""}}},b=["href"],g={class:"url-image-button"},f=["src"],y={class:"button-text"},k={key:0,class:"notes-text"};function w(c,u,o,B,T,z){return l(),r("a",{href:o.url,target:"_blank",rel:"noopener noreferrer",class:"button-link"},[t("button",g,[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)):p("",!0)])],8,b)}const a=d(m,[["render",w],["__scopeId","data-v-21baf7e3"]]),_=s("",6),v={style:{display:"flex","flex-wrap":"wrap","justify-content":"center","align-items":"center","grid-template-columns":"repeat(auto-fill, minmax(150px, 1fr))",gap:"20px"}},x=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),q=t("p",null,"Deploy your smart contracts on dedicated EVM-compatible rollups.",-1),A={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),R=JSON.parse('{"title":"Build whatever","description":"Advantages of building on modular blockchains like Celestia.","frontmatter":{"description":"Advantages of building on modular blockchains like Celestia.","head":[["meta",{"name":"og:title","content":"Build whatever | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/build-whatever.md","filePath":"developers/build-whatever.md","lastUpdated":1725955670000}'),O={name:"developers/build-whatever.md"},I=Object.assign(O,{setup(c){return(u,o)=>(l(),r("div",null,[_,t("div",v,[e(a,{url:"/developers/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:"/developers/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/build/overview/",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"})]),x,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,q,t("div",A,[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{R as __pageData,I as default}; diff --git a/pr-1680/assets/developers_celestia-node-key.md.b25623f9.js b/pr-1680/assets/developers_celestia-node-key.md.88cf4b78.js similarity index 98% rename from pr-1680/assets/developers_celestia-node-key.md.b25623f9.js rename to pr-1680/assets/developers_celestia-node-key.md.88cf4b78.js index 45f7993a6e..4f391cc0ee 100644 --- a/pr-1680/assets/developers_celestia-node-key.md.b25623f9.js +++ b/pr-1680/assets/developers_celestia-node-key.md.88cf4b78.js @@ -1,22 +1,22 @@ -import{m as o}from"./chunks/mocha_versions.ffd4ea25.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.a504a440.js";const c=a(`

        Create a wallet with celestia-node

        This tutorial will go over using the cel-key utility to generate a wallet on celestia-node.

        While this tutorial will go over installation process of cel-key, it is recommended that you complete the following prerequisites first:

        Once you completed the prerequisite, you can proceed with this tutorial.

        Using the cel-key utility

        Inside the celestia-node repository is a utility called cel-key that uses the key utility provided by Cosmos-SDK under the hood. The utility can be used to add, delete, and manage keys for any DA node type (bridge || full || light), or just keys in general.

        Installation

        You need to first pull down the celestia-node repository:

        sh
        git clone https://github.com/celestiaorg/celestia-node.git
        +import{m as o}from"./chunks/mocha_versions.7704b055.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.a504a440.js";const c=a(`

        Create a wallet with celestia-node

        This tutorial will go over using the cel-key utility to generate a wallet on celestia-node.

        While this tutorial will go over installation process of cel-key, it is recommended that you complete the following prerequisites first:

        Once you completed the prerequisite, you can proceed with this tutorial.

        Using the cel-key utility

        Inside the celestia-node repository is a utility called cel-key that uses the key utility provided by Cosmos-SDK under the hood. The utility can be used to add, delete, and manage keys for any DA node type (bridge || full || light), or just keys in general.

        Installation

        You need to first pull down the celestia-node repository:

        sh
        git clone https://github.com/celestiaorg/celestia-node.git
         cd celestia-node/
        git clone https://github.com/celestiaorg/celestia-node.git
         cd celestia-node/

        It can be built using either of the following commands:

        sh
        # dumps binary in current working directory, accessible via \`./cel-key\`
         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.ffd4ea25.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":"/developers/blobstream-x-deploy"},"head":[["meta",{"name":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/celestia-node-key.md","filePath":"developers/celestia-node-key.md","lastUpdated":1724867275000}'),w={name:"developers/celestia-node-key.md"},P=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":"/developers/blobstream-x-deploy"},"head":[["meta",{"name":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/celestia-node-key.md","filePath":"developers/celestia-node-key.md","lastUpdated":1725955670000}'),w={name:"developers/celestia-node-key.md"},P=Object.assign(w,{setup(f){return(A,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-1680/assets/developers_celestia-node-key.md.b25623f9.lean.js b/pr-1680/assets/developers_celestia-node-key.md.88cf4b78.lean.js similarity index 88% rename from pr-1680/assets/developers_celestia-node-key.md.b25623f9.lean.js rename to pr-1680/assets/developers_celestia-node-key.md.88cf4b78.lean.js index c336c9e585..bc4e2c6acb 100644 --- a/pr-1680/assets/developers_celestia-node-key.md.b25623f9.lean.js +++ b/pr-1680/assets/developers_celestia-node-key.md.88cf4b78.lean.js @@ -1,4 +1,4 @@ -import{m as o}from"./chunks/mocha_versions.ffd4ea25.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.a504a440.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":"/developers/blobstream-x-deploy"},"head":[["meta",{"name":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/celestia-node-key.md","filePath":"developers/celestia-node-key.md","lastUpdated":1724867275000}'),w={name:"developers/celestia-node-key.md"},P=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.7704b055.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.a504a440.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":"/developers/blobstream-x-deploy"},"head":[["meta",{"name":"og:title","content":"Create a wallet with celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/celestia-node-key.md","filePath":"developers/celestia-node-key.md","lastUpdated":1725955670000}'),w={name:"developers/celestia-node-key.md"},P=Object.assign(w,{setup(f){return(A,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-1680/assets/developers_deploy-on-bubs.md.d43095f8.js b/pr-1680/assets/developers_deploy-on-bubs.md.1057b5ac.js similarity index 99% rename from pr-1680/assets/developers_deploy-on-bubs.md.d43095f8.js rename to pr-1680/assets/developers_deploy-on-bubs.md.1057b5ac.js index e20cf5edbf..7fce7c0b24 100644 --- a/pr-1680/assets/developers_deploy-on-bubs.md.d43095f8.js +++ b/pr-1680/assets/developers_deploy-on-bubs.md.1057b5ac.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract on Bubs testnet","description":"","frontmatter":{"prev":{"text":"Bubs testnet","link":"/developers/bubs-testnet"},"head":[["meta",{"name":"og:title","content":"Deploy a smart contract on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/deploy-on-bubs.md","filePath":"developers/deploy-on-bubs.md","lastUpdated":1724867275000}'),p={name:"developers/deploy-on-bubs.md"},o=l(`

        Deploy a smart contract on Bubs testnet

        In this tutorial, we will deploy a smart contract to the Bubs testnet.

        Dependencies

        Setup

        First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

        bash
        cd $HOME
        +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract on Bubs testnet","description":"","frontmatter":{"prev":{"text":"Bubs testnet","link":"/developers/bubs-testnet"},"head":[["meta",{"name":"og:title","content":"Deploy a smart contract on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/deploy-on-bubs.md","filePath":"developers/deploy-on-bubs.md","lastUpdated":1725955670000}'),p={name:"developers/deploy-on-bubs.md"},o=l(`

        Deploy a smart contract on Bubs testnet

        In this tutorial, we will deploy a smart contract to the Bubs testnet.

        Dependencies

        Setup

        First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

        bash
        cd $HOME
         mkdir counter-project && cd counter-project && npm init -y
        cd $HOME
         mkdir counter-project && cd counter-project && npm init -y

        Next, initialize a Foundry project with the following command:

        bash
        forge init counter_contract
        forge init counter_contract

        Create your smart contract

        Take a look at the Counter.sol file in your counter-project/counter_contract/src directory:

        solidity
        // SPDX-License-Identifier: UNLICENSED
         pragma solidity ^0.8.13;
        diff --git a/pr-1680/assets/developers_deploy-on-bubs.md.d43095f8.lean.js b/pr-1680/assets/developers_deploy-on-bubs.md.1057b5ac.lean.js
        similarity index 81%
        rename from pr-1680/assets/developers_deploy-on-bubs.md.d43095f8.lean.js
        rename to pr-1680/assets/developers_deploy-on-bubs.md.1057b5ac.lean.js
        index 1faea31c64..c6b12050ee 100644
        --- a/pr-1680/assets/developers_deploy-on-bubs.md.d43095f8.lean.js
        +++ b/pr-1680/assets/developers_deploy-on-bubs.md.1057b5ac.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract on Bubs testnet","description":"","frontmatter":{"prev":{"text":"Bubs testnet","link":"/developers/bubs-testnet"},"head":[["meta",{"name":"og:title","content":"Deploy a smart contract on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/deploy-on-bubs.md","filePath":"developers/deploy-on-bubs.md","lastUpdated":1724867275000}'),p={name:"developers/deploy-on-bubs.md"},o=l("",61),e=[o];function t(c,r,i,y,E,d){return a(),n("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default};
        +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.js";const F=JSON.parse('{"title":"Deploy a smart contract on Bubs testnet","description":"","frontmatter":{"prev":{"text":"Bubs testnet","link":"/developers/bubs-testnet"},"head":[["meta",{"name":"og:title","content":"Deploy a smart contract on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/deploy-on-bubs.md","filePath":"developers/deploy-on-bubs.md","lastUpdated":1725955670000}'),p={name:"developers/deploy-on-bubs.md"},o=l("",61),e=[o];function t(c,r,i,y,E,d){return a(),n("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default};
        diff --git a/pr-1680/assets/developers_ethereum-fallback.md.8387bd5e.js b/pr-1680/assets/developers_ethereum-fallback.md.cd2adaa4.js
        similarity index 97%
        rename from pr-1680/assets/developers_ethereum-fallback.md.8387bd5e.js
        rename to pr-1680/assets/developers_ethereum-fallback.md.cd2adaa4.js
        index 33751e6d34..6b80d1bfeb 100644
        --- a/pr-1680/assets/developers_ethereum-fallback.md.8387bd5e.js
        +++ b/pr-1680/assets/developers_ethereum-fallback.md.cd2adaa4.js
        @@ -1 +1 @@
        -import{_ as a,o as l,c as r,k as e,a as t}from"./chunks/framework.a504a440.js";const s="/docs-preview/pr-1680/img/Celestia_ethereum-fallback.jpg",y=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":"/developers/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/developers/optimism"},"head":[["meta",{"name":"og:title","content":"Ethereum fallback | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/ethereum-fallback.md","filePath":"developers/ethereum-fallback.md","lastUpdated":1724867275000}'),n={name:"developers/ethereum-fallback.md"},o=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 “fall back” 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),m=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),u=e("p",null,[e("img",{src:s,alt:"Ethereum fallback"})],-1),d=[o,i,c,h,m,u];function p(b,f,k,_,g,v){return l(),r("div",null,d)}const x=a(n,[["render",p]]);export{y as __pageData,x as default};
        +import{_ as a,o as l,c as r,k as e,a as t}from"./chunks/framework.a504a440.js";const s="/docs-preview/pr-1680/img/Celestia_ethereum-fallback.jpg",y=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":"/developers/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/developers/optimism"},"head":[["meta",{"name":"og:title","content":"Ethereum fallback | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/ethereum-fallback.md","filePath":"developers/ethereum-fallback.md","lastUpdated":1725955670000}'),n={name:"developers/ethereum-fallback.md"},o=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 “fall back” 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),m=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),u=e("p",null,[e("img",{src:s,alt:"Ethereum fallback"})],-1),d=[o,i,c,h,m,u];function p(b,f,k,_,g,v){return l(),r("div",null,d)}const x=a(n,[["render",p]]);export{y as __pageData,x as default};
        diff --git a/pr-1680/assets/developers_ethereum-fallback.md.8387bd5e.lean.js b/pr-1680/assets/developers_ethereum-fallback.md.cd2adaa4.lean.js
        similarity index 97%
        rename from pr-1680/assets/developers_ethereum-fallback.md.8387bd5e.lean.js
        rename to pr-1680/assets/developers_ethereum-fallback.md.cd2adaa4.lean.js
        index 33751e6d34..6b80d1bfeb 100644
        --- a/pr-1680/assets/developers_ethereum-fallback.md.8387bd5e.lean.js
        +++ b/pr-1680/assets/developers_ethereum-fallback.md.cd2adaa4.lean.js
        @@ -1 +1 @@
        -import{_ as a,o as l,c as r,k as e,a as t}from"./chunks/framework.a504a440.js";const s="/docs-preview/pr-1680/img/Celestia_ethereum-fallback.jpg",y=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":"/developers/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/developers/optimism"},"head":[["meta",{"name":"og:title","content":"Ethereum fallback | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/ethereum-fallback.md","filePath":"developers/ethereum-fallback.md","lastUpdated":1724867275000}'),n={name:"developers/ethereum-fallback.md"},o=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 “fall back” 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),m=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),u=e("p",null,[e("img",{src:s,alt:"Ethereum fallback"})],-1),d=[o,i,c,h,m,u];function p(b,f,k,_,g,v){return l(),r("div",null,d)}const x=a(n,[["render",p]]);export{y as __pageData,x as default};
        +import{_ as a,o as l,c as r,k as e,a as t}from"./chunks/framework.a504a440.js";const s="/docs-preview/pr-1680/img/Celestia_ethereum-fallback.jpg",y=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":"/developers/blobstream-rollups"},"prev":{"text":"Run an OP Stack devnet posting Celestia","link":"/developers/optimism"},"head":[["meta",{"name":"og:title","content":"Ethereum fallback | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/ethereum-fallback.md","filePath":"developers/ethereum-fallback.md","lastUpdated":1725955670000}'),n={name:"developers/ethereum-fallback.md"},o=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 “fall back” 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),m=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),u=e("p",null,[e("img",{src:s,alt:"Ethereum fallback"})],-1),d=[o,i,c,h,m,u];function p(b,f,k,_,g,v){return l(),r("div",null,d)}const x=a(n,[["render",p]]);export{y as __pageData,x as default};
        diff --git a/pr-1680/assets/developers_feegrant-for-blobs.md.fb084a8d.js b/pr-1680/assets/developers_feegrant-for-blobs.md.77fb195e.js
        similarity index 55%
        rename from pr-1680/assets/developers_feegrant-for-blobs.md.fb084a8d.js
        rename to pr-1680/assets/developers_feegrant-for-blobs.md.77fb195e.js
        index 7409f5b6f6..b883616904 100644
        --- a/pr-1680/assets/developers_feegrant-for-blobs.md.fb084a8d.js
        +++ b/pr-1680/assets/developers_feegrant-for-blobs.md.77fb195e.js
        @@ -1,14 +1,8 @@
        -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/feegrant-for-blobs.md","filePath":"developers/feegrant-for-blobs.md","lastUpdated":1724867275000}'),o={name:"developers/feegrant-for-blobs.md"},l=e(`

        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.celestia-mocha.com: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 e}from"./chunks/framework.a504a440.js";const h=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/feegrant-for-blobs.md","filePath":"developers/feegrant-for-blobs.md","lastUpdated":1725955670000}'),o={name:"developers/feegrant-for-blobs.md"},l=e(`

        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.celestia-mocha.com: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.celestia-mocha.com
        export GRANTER_ADDRESS=<your-granter-account-address>
         export GRANTEE_ADDRESS=<your-grantee-account-address>
        -export RPC_URL=rpc.celestia-mocha.com

        FeeGrant module implementation in celestia-node

        Using celestia-node, you now can easily give permission for other nodes to submit transactions on your behalf. It is also possible to revoke the grant.

        The node that receives the grant has to run a node with the --granter.address=$GRANTER_ADDRESS> flag to use FeeGrant functionality.

        The granter address will be stored until the next run of your local node. So, in case the granter revokes permission, you will have to restart the node without this flag.

        TIP

        Transactions paid for by the the FeeGrant module will consume more gas than regular PayForBlobs transactions.

        Fee and transaction typeTransaction 1Transaction 2
        0.000176 fee with feegrant on Mocha testnetLinkLink
        0.00016 fee without feegrant on Mocha testnetLinkLink

        Grant permission for an allowance as a granter

        First, your node will need to be running with a command similar to:

        bash
        celestia light start --p2p.network mocha --core.ip $RPC_URL \\
        -  --keyring.keyname granter_key
        celestia light start --p2p.network mocha --core.ip $RPC_URL \\
        -  --keyring.keyname granter_key

        Then, grant the fee to the grantee:

        bash
        celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000
        celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000

        Note that the --amount uint flag specifies the spend limit (in utia) for the grantee. The default value is 0 which means the grantee does not have a spend limit.

        To set a limit of 42069 utia, use the following command:

        bash
        celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000 \\
        -  --amount 42069
        celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000 \\
        -  --amount 42069

        Find the example transaction on Celenium.

        Using a FeeGrant allowance as a grantee in celestia-node

        First, start your node with the grantee account:

        bash
        celestia light start --core.ip $RPC_URL --p2p.network=mocha
        -  --granter.address=$GRANTER_ADDRESS
        celestia light start --core.ip $RPC_URL --p2p.network=mocha
        -  --granter.address=$GRANTER_ADDRESS

        To check the balance of a light node, use the following command:

        bash
        celestia state balance
        celestia state balance

        Example response when the account balance does not exist:

        json
        {
        +export RPC_URL=rpc.celestia-mocha.com

        FeeGrant module implementation in celestia-node

        Using celestia-node, you can now easily give permission for other nodes to submit transactions on your behalf. It is also possible to revoke the grant.

        The FeeGrant functionality can now be used during runtime without the need to restart the node.

        Grant permission for an allowance as a granter

        First, start your node:

        bash
        celestia light start --p2p.network mocha --core.ip $RPC_URL
        celestia light start --p2p.network mocha --core.ip $RPC_URL

        Then, grant the fee to the grantee:

        bash
        celestia state grant-fee $GRANTEE_ADDRESS --amount 2000
        celestia state grant-fee $GRANTEE_ADDRESS --amount 2000

        Note that the --amount flag specifies the spend limit (in utia) for the grantee. If not specified, the grantee does not have a spend limit.

        Using a FeeGrant allowance as a grantee in celestia-node

        Start your node:

        bash
        celestia light start --core.ip $RPC_URL --p2p.network=mocha
        celestia light start --core.ip $RPC_URL --p2p.network=mocha

        To check the balance of a light node, use the following command:

        bash
        celestia state balance
        celestia state balance

        Example response when the account balance does not exist:

        json
        {
           "result": {
             "denom": "utia",
             "amount": "0"
        @@ -18,7 +12,7 @@ import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=
             "denom": "utia",
             "amount": "0"
           }
        -}

        This indicates that the light node currently does not have any funds.

        Now submit a blob:

        bash
        celestia blob submit 0x42690c204d39600fddd3 0x6665656772616e74
        celestia blob submit 0x42690c204d39600fddd3 0x6665656772616e74

        You'll see the height and the commitment of your blob:

        json
        {
        +}

        This indicates that the light node currently does not have any funds.

        Now submit a blob using the FeeGrant:

        bash
        celestia blob submit 0x42690c204d39600fddd3 'gm' --granter.address $GRANTER_ADDRESS
        celestia blob submit 0x42690c204d39600fddd3 'gm' --granter.address $GRANTER_ADDRESS

        You'll see the height and the commitment of your blob:

        json
        {
           "result": {
             "height": 1639397,
             "commitments": [
        @@ -32,7 +26,7 @@ import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=
               "19L/C4iBEsqXGzC5ZxJ3vtuGBiAdQAMIEnbYjKEGcac="
             ]
           }
        -}

        After the transactions made making this guide, see that the account balance is still 0 utia.

        Checking account balances after submission

        Light node account: After submitting a blob, you can check the light node account's balance to verify that the fees have been deducted:

        bash
        celestia state balance
        celestia state balance

        Example output showing fees are not deducted:

        json
        {
        +}

        Checking account balances after submission

        Light node account: After submitting a blob, you can check the light node account's balance to verify that the fees have been deducted:

        bash
        celestia state balance
        celestia state balance

        Example output showing fees are not deducted:

        json
        {
           "result": {
             "denom": "utia",
             "amount": "0"
        @@ -42,7 +36,7 @@ import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=
             "denom": "utia",
             "amount": "0"
           }
        -}

        Optional: Revoke permission for a FeeGrant allowance as a granter

        To revoke the feegrant, run your light node as the granter and run:

        bash
        celestia state revoke-grant-fee $GRANTEE_ADDRESS 2000 1000000
        celestia state revoke-grant-fee $GRANTEE_ADDRESS 2000 1000000

        There is also a specific error for the case when you run your node as a grantee, but the granter revokes their permission. In this case, your transaction will fail with the error: granter has revoked the grant This will mean that you have to restart the node without the granter.address flag.

        Optional: Submitting a blob from file input

        To submit a blob from file input:

        bash
        celestia blob submit --input-file blob.json
        celestia blob submit --input-file blob.json

        Optional: Granting fee allowances using celestia-appd

        To grant fee allowances, allowing a third-party (granter) account to pay for the fees incurred by a Celestia data availability node (grantee) account, use the following commands.

        Set your account addresses for grantee and granter, and the RPC URL:

        bash
        export GRANTER_ADDRESS=<your-granter-account-address>
        +}

        Optional: Revoke permission for a FeeGrant allowance as a granter

        To revoke the feegrant, run:

        bash
        celestia state revoke-grant-fee $GRANTEE_ADDRESS
        celestia state revoke-grant-fee $GRANTEE_ADDRESS

        Optional: Submitting a blob from file input

        To submit a blob from file input:

        bash
        celestia blob submit --input-file blob.json
        celestia blob submit --input-file blob.json

        Optional: Granting fee allowances using celestia-appd

        To grant fee allowances, allowing a third-party (granter) account to pay for the fees incurred by a Celestia data availability node (grantee) account, use the following commands.

        Set your account addresses for grantee and granter, and the RPC URL:

        bash
        export GRANTER_ADDRESS=<your-granter-account-address>
         export GRANTEE_ADDRESS=<your-grantee-account-address>
         export RPC_URL=https://rpc.celestia-mocha.com:443
        export GRANTER_ADDRESS=<your-granter-account-address>
         export GRANTEE_ADDRESS=<your-grantee-account-address>
        @@ -66,4 +60,4 @@ import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=
           --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.celestia-mocha.com:443 --denom utia
        celestia-appd query bank balances $GRANTER_ADDRESS \\
        ---node https://rpc.celestia-mocha.com:443 --denom utia

        This output will show the remaining balance after fees have been deducted, confirming that the FeeGrant module is working as intended.

        `,61),t=[l];function p(c,r,i,E,y,d){return a(),n("div",null,t)}const g=s(o,[["render",p]]);export{u as __pageData,g as default}; +--node https://rpc.celestia-mocha.com:443 --denom utia

        This output will show the remaining balance after fees have been deducted, confirming that the FeeGrant module is working as intended.

        `,54),p=[l];function t(c,r,i,E,y,d){return a(),n("div",null,p)}const g=s(o,[["render",t]]);export{h as __pageData,g as default}; diff --git a/pr-1680/assets/developers_feegrant-for-blobs.md.fb084a8d.lean.js b/pr-1680/assets/developers_feegrant-for-blobs.md.77fb195e.lean.js similarity index 50% rename from pr-1680/assets/developers_feegrant-for-blobs.md.fb084a8d.lean.js rename to pr-1680/assets/developers_feegrant-for-blobs.md.77fb195e.lean.js index 3bf9eb86f0..1cf8232023 100644 --- a/pr-1680/assets/developers_feegrant-for-blobs.md.fb084a8d.lean.js +++ b/pr-1680/assets/developers_feegrant-for-blobs.md.77fb195e.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/feegrant-for-blobs.md","filePath":"developers/feegrant-for-blobs.md","lastUpdated":1724867275000}'),o={name:"developers/feegrant-for-blobs.md"},l=e("",61),t=[l];function p(c,r,i,E,y,d){return a(),n("div",null,t)}const g=s(o,[["render",p]]);export{u as __pageData,g as default}; +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const h=JSON.parse('{"title":"FeeGrant module for blobs submission","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"FeeGrant module for blobs submission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/feegrant-for-blobs.md","filePath":"developers/feegrant-for-blobs.md","lastUpdated":1725955670000}'),o={name:"developers/feegrant-for-blobs.md"},l=e("",54),p=[l];function t(c,r,i,E,y,d){return a(),n("div",null,p)}const g=s(o,[["render",t]]);export{h as __pageData,g as default}; diff --git a/pr-1680/assets/developers_full-stack-modular-development-guide.md.ca053aa5.js b/pr-1680/assets/developers_full-stack-modular-development-guide.md.0c71091e.js similarity index 99% rename from pr-1680/assets/developers_full-stack-modular-development-guide.md.ca053aa5.js rename to pr-1680/assets/developers_full-stack-modular-development-guide.md.0c71091e.js index 9b82f4428b..e16b19d540 100644 --- a/pr-1680/assets/developers_full-stack-modular-development-guide.md.ca053aa5.js +++ b/pr-1680/assets/developers_full-stack-modular-development-guide.md.0c71091e.js @@ -1,4 +1,4 @@ -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Full stack modular blockchain development guide","description":"Learn to build a full stack modular dapp.","frontmatter":{"description":"Learn to build a full stack modular dapp.","head":[["meta",{"name":"og:title","content":"Full stack modular blockchain development guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/full-stack-modular-development-guide.md","filePath":"developers/full-stack-modular-development-guide.md","lastUpdated":1724867275000}'),p={name:"developers/full-stack-modular-development-guide.md"},o=l(`

        Full stack modular blockchain development guide

        Note

        This tutorial needs to be updated

        This guide will introduce you to modular blockchains like Celestia, explain their benefits, and show you how to build a full stack modular dapp with React, Vite, RainbowKit, Celestia, and Foundry.

        Current blockchain architectures are not scalable and face challenges around accessibility. In order for blockchains and web3 to reach mass adoption, these challenges must be addressed.

        Blockchains have evolved over time from application-specific networks like Bitcoin to shared smart contract platforms like Ethereum. This guide will cover how to build dapps on these newer, shared platforms.

        If you're interested in learning more about modular blockchains, or are new to the Celestia ecosystem, we recommend you read the build whatever page first.

        Getting started

        Now that you’ve had an overview of what Celestia is, let’s start building!

        The execution environment that we’ll be leveraging today is Ethermint, an EVM-compatible testnet that you will run locally for this tutorial.

        Pre-requisites

        Project setup

        To get started, create a new Foundry project:

        bash
        forge init celestia-dapp
        +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Full stack modular blockchain development guide","description":"Learn to build a full stack modular dapp.","frontmatter":{"description":"Learn to build a full stack modular dapp.","head":[["meta",{"name":"og:title","content":"Full stack modular blockchain development guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/full-stack-modular-development-guide.md","filePath":"developers/full-stack-modular-development-guide.md","lastUpdated":1725955670000}'),p={name:"developers/full-stack-modular-development-guide.md"},o=l(`

        Full stack modular blockchain development guide

        Note

        This tutorial needs to be updated

        This guide will introduce you to modular blockchains like Celestia, explain their benefits, and show you how to build a full stack modular dapp with React, Vite, RainbowKit, Celestia, and Foundry.

        Current blockchain architectures are not scalable and face challenges around accessibility. In order for blockchains and web3 to reach mass adoption, these challenges must be addressed.

        Blockchains have evolved over time from application-specific networks like Bitcoin to shared smart contract platforms like Ethereum. This guide will cover how to build dapps on these newer, shared platforms.

        If you're interested in learning more about modular blockchains, or are new to the Celestia ecosystem, we recommend you read the build whatever page first.

        Getting started

        Now that you’ve had an overview of what Celestia is, let’s start building!

        The execution environment that we’ll be leveraging today is Ethermint, an EVM-compatible testnet that you will run locally for this tutorial.

        Pre-requisites

        Project setup

        To get started, create a new Foundry project:

        bash
        forge init celestia-dapp
         cd celestia-dapp
        forge init celestia-dapp
         cd celestia-dapp

        Foundry has created an example smart contract located at src/Contract.sol.

        Updating the contract and tests

        Let's update the contracts to include a basic blog example. Create a new file in the src directory named Contract.sol with the following code:

        solidity
        // SPDX-License-Identifier: MIT
         pragma solidity ^0.8.13;
        diff --git a/pr-1680/assets/developers_full-stack-modular-development-guide.md.ca053aa5.lean.js b/pr-1680/assets/developers_full-stack-modular-development-guide.md.0c71091e.lean.js
        similarity index 92%
        rename from pr-1680/assets/developers_full-stack-modular-development-guide.md.ca053aa5.lean.js
        rename to pr-1680/assets/developers_full-stack-modular-development-guide.md.0c71091e.lean.js
        index e9f4335e9f..fc9a45f3f1 100644
        --- a/pr-1680/assets/developers_full-stack-modular-development-guide.md.ca053aa5.lean.js
        +++ b/pr-1680/assets/developers_full-stack-modular-development-guide.md.0c71091e.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Full stack modular blockchain development guide","description":"Learn to build a full stack modular dapp.","frontmatter":{"description":"Learn to build a full stack modular dapp.","head":[["meta",{"name":"og:title","content":"Full stack modular blockchain development guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/full-stack-modular-development-guide.md","filePath":"developers/full-stack-modular-development-guide.md","lastUpdated":1724867275000}'),p={name:"developers/full-stack-modular-development-guide.md"},o=l("",113),e=[o];function t(c,r,E,y,i,F){return n(),a("div",null,e)}const h=s(p,[["render",t]]);export{u as __pageData,h as default};
        +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Full stack modular blockchain development guide","description":"Learn to build a full stack modular dapp.","frontmatter":{"description":"Learn to build a full stack modular dapp.","head":[["meta",{"name":"og:title","content":"Full stack modular blockchain development guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/full-stack-modular-development-guide.md","filePath":"developers/full-stack-modular-development-guide.md","lastUpdated":1725955670000}'),p={name:"developers/full-stack-modular-development-guide.md"},o=l("",113),e=[o];function t(c,r,E,y,i,F){return n(),a("div",null,e)}const h=s(p,[["render",t]]);export{u as __pageData,h as default};
        diff --git a/pr-1680/assets/developers_gm-portal-bubs.md.69f6963b.js b/pr-1680/assets/developers_gm-portal-bubs.md.df82ad53.js
        similarity index 99%
        rename from pr-1680/assets/developers_gm-portal-bubs.md.69f6963b.js
        rename to pr-1680/assets/developers_gm-portal-bubs.md.df82ad53.js
        index 12da02f57a..0d49285963 100644
        --- a/pr-1680/assets/developers_gm-portal-bubs.md.69f6963b.js
        +++ b/pr-1680/assets/developers_gm-portal-bubs.md.df82ad53.js
        @@ -1,4 +1,4 @@
        -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const p="/docs-preview/pr-1680/img/gm_contract.png",t="/docs-preview/pr-1680/img/gm_bubs.png",F=JSON.parse('{"title":"Deploying a dapp on Bubs testnet","description":"Make your own GM Portal dapp on the OP Stack.","frontmatter":{"description":"Make your own GM Portal dapp on the OP Stack.","head":[["meta",{"name":"og:title","content":"Deploying a dapp on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/gm-portal-bubs.md","filePath":"developers/gm-portal-bubs.md","lastUpdated":1724867275000}'),e={name:"developers/gm-portal-bubs.md"},l=o(`

        Deploying a dapp on Bubs testnet

        First, review the Bubs testnet page and the Deploy a smart contract to Bubs testnet tutorial.

        You will need a funded account to deploy your smart contract.

        Next, clone the gm-portal from Github and start the frontend:

        bash
        cd $HOME
        +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const p="/docs-preview/pr-1680/img/gm_contract.png",t="/docs-preview/pr-1680/img/gm_bubs.png",F=JSON.parse('{"title":"Deploying a dapp on Bubs testnet","description":"Make your own GM Portal dapp on the OP Stack.","frontmatter":{"description":"Make your own GM Portal dapp on the OP Stack.","head":[["meta",{"name":"og:title","content":"Deploying a dapp on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/gm-portal-bubs.md","filePath":"developers/gm-portal-bubs.md","lastUpdated":1725955670000}'),e={name:"developers/gm-portal-bubs.md"},l=o(`

        Deploying a dapp on Bubs testnet

        First, review the Bubs testnet page and the Deploy a smart contract to Bubs testnet tutorial.

        You will need a funded account to deploy your smart contract.

        Next, clone the gm-portal from Github and start the frontend:

        bash
        cd $HOME
         git clone https://github.com/jcstein/gm-portal.git
         cd gm-portal/frontend
         yarn && yarn dev
        cd $HOME
        diff --git a/pr-1680/assets/developers_gm-portal-bubs.md.69f6963b.lean.js b/pr-1680/assets/developers_gm-portal-bubs.md.df82ad53.lean.js
        similarity index 92%
        rename from pr-1680/assets/developers_gm-portal-bubs.md.69f6963b.lean.js
        rename to pr-1680/assets/developers_gm-portal-bubs.md.df82ad53.lean.js
        index 88e2175408..947b04b556 100644
        --- a/pr-1680/assets/developers_gm-portal-bubs.md.69f6963b.lean.js
        +++ b/pr-1680/assets/developers_gm-portal-bubs.md.df82ad53.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const p="/docs-preview/pr-1680/img/gm_contract.png",t="/docs-preview/pr-1680/img/gm_bubs.png",F=JSON.parse('{"title":"Deploying a dapp on Bubs testnet","description":"Make your own GM Portal dapp on the OP Stack.","frontmatter":{"description":"Make your own GM Portal dapp on the OP Stack.","head":[["meta",{"name":"og:title","content":"Deploying a dapp on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/gm-portal-bubs.md","filePath":"developers/gm-portal-bubs.md","lastUpdated":1724867275000}'),e={name:"developers/gm-portal-bubs.md"},l=o("",32),c=[l];function r(i,y,d,E,h,u){return a(),n("div",null,c)}const b=s(e,[["render",r]]);export{F as __pageData,b as default};
        +import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const p="/docs-preview/pr-1680/img/gm_contract.png",t="/docs-preview/pr-1680/img/gm_bubs.png",F=JSON.parse('{"title":"Deploying a dapp on Bubs testnet","description":"Make your own GM Portal dapp on the OP Stack.","frontmatter":{"description":"Make your own GM Portal dapp on the OP Stack.","head":[["meta",{"name":"og:title","content":"Deploying a dapp on Bubs testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/gm-portal-bubs.md","filePath":"developers/gm-portal-bubs.md","lastUpdated":1725955670000}'),e={name:"developers/gm-portal-bubs.md"},l=o("",32),c=[l];function r(i,y,d,E,h,u){return a(),n("div",null,c)}const b=s(e,[["render",r]]);export{F as __pageData,b as default};
        diff --git a/pr-1680/assets/developers_golang-client-tutorial.md.1734d91e.js b/pr-1680/assets/developers_golang-client-tutorial.md.3f31b896.js
        similarity index 99%
        rename from pr-1680/assets/developers_golang-client-tutorial.md.1734d91e.js
        rename to pr-1680/assets/developers_golang-client-tutorial.md.3f31b896.js
        index b4ff32911a..dd37895ea5 100644
        --- a/pr-1680/assets/developers_golang-client-tutorial.md.1734d91e.js
        +++ b/pr-1680/assets/developers_golang-client-tutorial.md.3f31b896.js
        @@ -1,4 +1,4 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Golang client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/golang-client-tutorial.md","filePath":"developers/golang-client-tutorial.md","lastUpdated":1724867275000}'),p={name:"developers/golang-client-tutorial.md"},o=l(`

        Golang client library tutorial

        This section tutorial 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.a504a440.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Golang client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/golang-client-tutorial.md","filePath":"developers/golang-client-tutorial.md","lastUpdated":1725955670000}'),p={name:"developers/golang-client-tutorial.md"},o=l(`

        Golang client library tutorial

        This section tutorial 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-1680/assets/developers_golang-client-tutorial.md.1734d91e.lean.js b/pr-1680/assets/developers_golang-client-tutorial.md.3f31b896.lean.js
        similarity index 89%
        rename from pr-1680/assets/developers_golang-client-tutorial.md.1734d91e.lean.js
        rename to pr-1680/assets/developers_golang-client-tutorial.md.3f31b896.lean.js
        index 89dd01e0d8..d8582020bd 100644
        --- a/pr-1680/assets/developers_golang-client-tutorial.md.1734d91e.lean.js
        +++ b/pr-1680/assets/developers_golang-client-tutorial.md.3f31b896.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Golang client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/golang-client-tutorial.md","filePath":"developers/golang-client-tutorial.md","lastUpdated":1724867275000}'),p={name:"developers/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.a504a440.js";const b=JSON.parse('{"title":"Golang client library tutorial","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Golang client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/golang-client-tutorial.md","filePath":"developers/golang-client-tutorial.md","lastUpdated":1725955670000}'),p={name:"developers/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-1680/assets/developers_integrate-celestia.md.a09ad5ff.js b/pr-1680/assets/developers_integrate-celestia.md.3f8ccd2c.js
        similarity index 98%
        rename from pr-1680/assets/developers_integrate-celestia.md.a09ad5ff.js
        rename to pr-1680/assets/developers_integrate-celestia.md.3f8ccd2c.js
        index 67855bd49c..e904b45e8f 100644
        --- a/pr-1680/assets/developers_integrate-celestia.md.a09ad5ff.js
        +++ b/pr-1680/assets/developers_integrate-celestia.md.3f8ccd2c.js
        @@ -1 +1 @@
        -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.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 Cosmostation for developers","link":"/developers/cosmostation"},"head":[["meta",{"name":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/integrate-celestia.md","filePath":"developers/integrate-celestia.md","lastUpdated":1724867275000}'),r={name:"developers/integrate-celestia.md"},n=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 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),s=[n];function o(l,d,c,h,u,m){return t(),a("div",null,s)}const b=e(r,[["render",o]]);export{g as __pageData,b as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.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 Cosmostation for developers","link":"/developers/cosmostation"},"head":[["meta",{"name":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/integrate-celestia.md","filePath":"developers/integrate-celestia.md","lastUpdated":1725955670000}'),r={name:"developers/integrate-celestia.md"},n=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 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),s=[n];function o(l,d,c,h,u,m){return t(),a("div",null,s)}const b=e(r,[["render",o]]);export{g as __pageData,b as default}; diff --git a/pr-1680/assets/developers_integrate-celestia.md.a09ad5ff.lean.js b/pr-1680/assets/developers_integrate-celestia.md.3f8ccd2c.lean.js similarity index 92% rename from pr-1680/assets/developers_integrate-celestia.md.a09ad5ff.lean.js rename to pr-1680/assets/developers_integrate-celestia.md.3f8ccd2c.lean.js index 85b320bac0..b911f8b7f8 100644 --- a/pr-1680/assets/developers_integrate-celestia.md.a09ad5ff.lean.js +++ b/pr-1680/assets/developers_integrate-celestia.md.3f8ccd2c.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.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 Cosmostation for developers","link":"/developers/cosmostation"},"head":[["meta",{"name":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/integrate-celestia.md","filePath":"developers/integrate-celestia.md","lastUpdated":1724867275000}'),r={name:"developers/integrate-celestia.md"},n=i("",21),s=[n];function o(l,d,c,h,u,m){return t(),a("div",null,s)}const b=e(r,[["render",o]]);export{g as __pageData,b as default}; +import{_ as e,o as t,c as a,Q as i}from"./chunks/framework.a504a440.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 Cosmostation for developers","link":"/developers/cosmostation"},"head":[["meta",{"name":"og:title","content":"Integrate Celestia for service providers | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/integrate-celestia.md","filePath":"developers/integrate-celestia.md","lastUpdated":1725955670000}'),r={name:"developers/integrate-celestia.md"},n=i("",21),s=[n];function o(l,d,c,h,u,m){return t(),a("div",null,s)}const b=e(r,[["render",o]]);export{g as __pageData,b as default}; diff --git a/pr-1680/assets/developers_intro-to-op-stack.md.fa5d636c.js b/pr-1680/assets/developers_intro-to-op-stack.md.07bb6aa7.js similarity index 98% rename from pr-1680/assets/developers_intro-to-op-stack.md.fa5d636c.js rename to pr-1680/assets/developers_intro-to-op-stack.md.07bb6aa7.js index 121167957b..ebcd8a47c4 100644 --- a/pr-1680/assets/developers_intro-to-op-stack.md.fa5d636c.js +++ b/pr-1680/assets/developers_intro-to-op-stack.md.07bb6aa7.js @@ -1 +1 @@ -import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.a504a440.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":"Deploy a dapp on your Arbitrum rollup devnet","link":"/developers/arbitrum-dapp-deploy"},"head":[["meta",{"name":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/intro-to-op-stack.md","filePath":"developers/intro-to-op-stack.md","lastUpdated":1724867275000}'),i={name:"developers/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.

        Category contents

        This category will guide you through interacting with existing OP Stack rollups with Celestia underneath, then how to start your own devnet with a modified version of optimism-bedrock that uses Celestia as a DA layer.

        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.

        ',18),n=[r];function s(l,h,c,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.a504a440.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":"Deploy a dapp on your Arbitrum rollup devnet","link":"/developers/arbitrum-dapp-deploy"},"head":[["meta",{"name":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/intro-to-op-stack.md","filePath":"developers/intro-to-op-stack.md","lastUpdated":1725955670000}'),i={name:"developers/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.

        Category contents

        This category will guide you through interacting with existing OP Stack rollups with Celestia underneath, then how to start your own devnet with a modified version of optimism-bedrock that uses Celestia as a DA layer.

        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.

        ',18),n=[r];function s(l,h,c,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-1680/assets/developers_intro-to-op-stack.md.fa5d636c.lean.js b/pr-1680/assets/developers_intro-to-op-stack.md.07bb6aa7.lean.js similarity index 92% rename from pr-1680/assets/developers_intro-to-op-stack.md.fa5d636c.lean.js rename to pr-1680/assets/developers_intro-to-op-stack.md.07bb6aa7.lean.js index a2e391f151..5ec4ed4402 100644 --- a/pr-1680/assets/developers_intro-to-op-stack.md.fa5d636c.lean.js +++ b/pr-1680/assets/developers_intro-to-op-stack.md.07bb6aa7.lean.js @@ -1 +1 @@ -import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.a504a440.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":"Deploy a dapp on your Arbitrum rollup devnet","link":"/developers/arbitrum-dapp-deploy"},"head":[["meta",{"name":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/intro-to-op-stack.md","filePath":"developers/intro-to-op-stack.md","lastUpdated":1724867275000}'),i={name:"developers/intro-to-op-stack.md"},r=o("",18),n=[r];function s(l,h,c,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.a504a440.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":"Deploy a dapp on your Arbitrum rollup devnet","link":"/developers/arbitrum-dapp-deploy"},"head":[["meta",{"name":"og:title","content":"Introduction to OP Stack integration | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/intro-to-op-stack.md","filePath":"developers/intro-to-op-stack.md","lastUpdated":1725955670000}'),i={name:"developers/intro-to-op-stack.md"},r=o("",18),n=[r];function s(l,h,c,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-1680/assets/developers_multiaccounts.md.a7a3ebe9.js b/pr-1680/assets/developers_multiaccounts.md.a7a3ebe9.js new file mode 100644 index 0000000000..40eaf835bf --- /dev/null +++ b/pr-1680/assets/developers_multiaccounts.md.a7a3ebe9.js @@ -0,0 +1,5 @@ +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.a504a440.js";const b=JSON.parse('{"title":"MultiAccounts feature for blobs submission","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"MultiAccounts feature for blobs submission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/multiaccounts.md","filePath":"developers/multiaccounts.md","lastUpdated":1725955670000}'),o={name:"developers/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 \\
        +    --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:

        `,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-1680/assets/developers_multiaccounts.md.a7a3ebe9.lean.js b/pr-1680/assets/developers_multiaccounts.md.a7a3ebe9.lean.js new file mode 100644 index 0000000000..2e0731229d --- /dev/null +++ b/pr-1680/assets/developers_multiaccounts.md.a7a3ebe9.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.a504a440.js";const b=JSON.parse('{"title":"MultiAccounts feature for blobs submission","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"MultiAccounts feature for blobs submission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/multiaccounts.md","filePath":"developers/multiaccounts.md","lastUpdated":1725955670000}'),o={name:"developers/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-1680/assets/developers_node-api.md.e5a7b4d3.js b/pr-1680/assets/developers_node-api.md.793cfe04.js similarity index 98% rename from pr-1680/assets/developers_node-api.md.e5a7b4d3.js rename to pr-1680/assets/developers_node-api.md.793cfe04.js index fb92b7e068..800ddc9086 100644 --- a/pr-1680/assets/developers_node-api.md.e5a7b4d3.js +++ b/pr-1680/assets/developers_node-api.md.793cfe04.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Node API | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-api.md","filePath":"developers/node-api.md","lastUpdated":1724867275000}'),o={name:"developers/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 node tutorial, which uses the RPC CLI, is the recommended way to get started interacting with your Celestia node.

        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.

        ',15),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.a504a440.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",{"name":"og:title","content":"Node API | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-api.md","filePath":"developers/node-api.md","lastUpdated":1725955670000}'),o={name:"developers/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 node tutorial, which uses the RPC CLI, is the recommended way to get started interacting with your Celestia node.

        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.

        ',15),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-1680/assets/developers_node-api.md.e5a7b4d3.lean.js b/pr-1680/assets/developers_node-api.md.793cfe04.lean.js similarity index 90% rename from pr-1680/assets/developers_node-api.md.e5a7b4d3.lean.js rename to pr-1680/assets/developers_node-api.md.793cfe04.lean.js index db138f60c4..2d36dbf4cc 100644 --- a/pr-1680/assets/developers_node-api.md.e5a7b4d3.lean.js +++ b/pr-1680/assets/developers_node-api.md.793cfe04.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Node API | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-api.md","filePath":"developers/node-api.md","lastUpdated":1724867275000}'),o={name:"developers/node-api.md"},i=r("",15),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.a504a440.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",{"name":"og:title","content":"Node API | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-api.md","filePath":"developers/node-api.md","lastUpdated":1725955670000}'),o={name:"developers/node-api.md"},i=r("",15),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-1680/assets/developers_node-tutorial.md.185dc136.js b/pr-1680/assets/developers_node-tutorial.md.797233e2.js similarity index 99% rename from pr-1680/assets/developers_node-tutorial.md.185dc136.js rename to pr-1680/assets/developers_node-tutorial.md.797233e2.js index 3b29cbb816..b97f767808 100644 --- a/pr-1680/assets/developers_node-tutorial.md.185dc136.js +++ b/pr-1680/assets/developers_node-tutorial.md.797233e2.js @@ -1,8 +1,8 @@ -import{c as a}from"./chunks/constants.0e6df566.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.a504a440.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.

        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 a community-run API endpoint and there are several in the Discord. This one is used for demonstration purposes. Check out the Mocha testnet page, or Arabica devnet page.

        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.295fc0ab.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.a504a440.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.

        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 a community-run API endpoint and there are several in the Discord. This one is used for demonstration purposes. Check out the Mocha testnet page, or Arabica devnet page.

        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.0e6df566.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",{"name":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-tutorial.md","filePath":"developers/node-tutorial.md","lastUpdated":1724867275000}'),D={name:"developers/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",{"name":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-tutorial.md","filePath":"developers/node-tutorial.md","lastUpdated":1725955670000}'),D={name:"developers/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}; diff --git a/pr-1680/assets/developers_node-tutorial.md.185dc136.lean.js b/pr-1680/assets/developers_node-tutorial.md.797233e2.lean.js similarity index 93% rename from pr-1680/assets/developers_node-tutorial.md.185dc136.lean.js rename to pr-1680/assets/developers_node-tutorial.md.797233e2.lean.js index 8631bef208..c4dd9e358b 100644 --- a/pr-1680/assets/developers_node-tutorial.md.185dc136.lean.js +++ b/pr-1680/assets/developers_node-tutorial.md.797233e2.lean.js @@ -1 +1 @@ -import{c as a}from"./chunks/constants.0e6df566.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.a504a440.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",{"name":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-tutorial.md","filePath":"developers/node-tutorial.md","lastUpdated":1724867275000}'),D={name:"developers/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.295fc0ab.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.a504a440.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",{"name":"og:title","content":"Celestia-node RPC CLI tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/node-tutorial.md","filePath":"developers/node-tutorial.md","lastUpdated":1725955670000}'),D={name:"developers/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}; diff --git a/pr-1680/assets/developers_optimism-devnet.md.a9e0c5a6.js b/pr-1680/assets/developers_optimism-devnet.md.5de00bc6.js similarity index 99% rename from pr-1680/assets/developers_optimism-devnet.md.a9e0c5a6.js rename to pr-1680/assets/developers_optimism-devnet.md.5de00bc6.js index f2191415ac..a17c8fee99 100644 --- a/pr-1680/assets/developers_optimism-devnet.md.a9e0c5a6.js +++ b/pr-1680/assets/developers_optimism-devnet.md.5de00bc6.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Optimism devnet deep dive | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism-devnet.md","filePath":"developers/optimism-devnet.md","lastUpdated":1724867275000}'),l={name:"developers/optimism-devnet.md"},o=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.a504a440.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Optimism devnet deep dive | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism-devnet.md","filePath":"developers/optimism-devnet.md","lastUpdated":1725955670000}'),l={name:"developers/optimism-devnet.md"},o=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-1680/assets/developers_optimism-devnet.md.a9e0c5a6.lean.js b/pr-1680/assets/developers_optimism-devnet.md.5de00bc6.lean.js
        similarity index 89%
        rename from pr-1680/assets/developers_optimism-devnet.md.a9e0c5a6.lean.js
        rename to pr-1680/assets/developers_optimism-devnet.md.5de00bc6.lean.js
        index 82d9f0b4c5..2587f879d4 100644
        --- a/pr-1680/assets/developers_optimism-devnet.md.a9e0c5a6.lean.js
        +++ b/pr-1680/assets/developers_optimism-devnet.md.5de00bc6.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Optimism devnet deep dive | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism-devnet.md","filePath":"developers/optimism-devnet.md","lastUpdated":1724867275000}'),l={name:"developers/optimism-devnet.md"},o=e("",26),p=[o];function c(t,r,d,i,y,b){return a(),n("div",null,p)}const h=s(l,[["render",c]]);export{f as __pageData,h as default};
        +import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Optimism devnet deep dive","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Optimism devnet deep dive | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism-devnet.md","filePath":"developers/optimism-devnet.md","lastUpdated":1725955670000}'),l={name:"developers/optimism-devnet.md"},o=e("",26),p=[o];function c(t,r,d,i,y,b){return a(),n("div",null,p)}const h=s(l,[["render",c]]);export{f as __pageData,h as default};
        diff --git a/pr-1680/assets/developers_optimism.md.6b557910.js b/pr-1680/assets/developers_optimism.md.f09e526a.js
        similarity index 93%
        rename from pr-1680/assets/developers_optimism.md.6b557910.js
        rename to pr-1680/assets/developers_optimism.md.f09e526a.js
        index a3c87c32e4..bd445cc3a2 100644
        --- a/pr-1680/assets/developers_optimism.md.6b557910.js
        +++ b/pr-1680/assets/developers_optimism.md.f09e526a.js
        @@ -1,4 +1,4 @@
        -import{c as a}from"./chunks/constants.0e6df566.js";import{o as t,c as l,k as s,t as e,l as n,Q as o}from"./chunks/framework.a504a440.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.

        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.

        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:

        ',8),c={class:"vp-code-group vp-adaptive-theme"},r=o('
        ',1),i={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("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=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),f={class:"shiki github-dark vp-code-dark"},F={class:"line"},w={style:{color:"#E1E4E8"}},S={class:"shiki github-light vp-code-light"},A={class:"line"},T={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 a}from"./chunks/constants.295fc0ab.js";import{o as t,c as l,k as s,t as e,l as n,Q as o}from"./chunks/framework.a504a440.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.

        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.

        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:

        ',8),c={class:"vp-code-group vp-adaptive-theme"},r=o('
        ',1),i={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("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=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},f={class:"line"},S={style:{color:"#E1E4E8"}},w={class:"shiki github-light vp-code-light"},A={class:"line"},T={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 a}from"./chunks/constants.0e6df566.js";import{o as t,c as l,k as s,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.","next":{"text":"Ethereum fallback mechanism","link":"/developers/ethereum-fallback"},"head":[["meta",{"name":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism.md","filePath":"developers/optimism.md","lastUpdated":1724867275000}'),P={name:"developers/optimism.md"},V=Object.assign(P,{setup(M){return(B,x)=>(t(),l("div",null,[p,s("div",c,[r,s("div",i,[s("div",d,[u,h,s("pre",y,[s("code",null,[s("span",_,[s("span",E,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])]),s("pre",g,[s("code",null,[s("span",m,[s("span",b,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])])]),v,s("div",k,[C,q,s("pre",f,[s("code",null,[s("span",F,[s("span",w,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])]),s("pre",S,[s("code",null,[s("span",A,[s("span",T,"$HOME/.celestia-light-"+e(n(a).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),O=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.","next":{"text":"Ethereum fallback mechanism","link":"/developers/ethereum-fallback"},"head":[["meta",{"name":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism.md","filePath":"developers/optimism.md","lastUpdated":1725955670000}'),M={name:"developers/optimism.md"},V=Object.assign(M,{setup(P){return(B,x)=>(t(),l("div",null,[p,s("div",c,[r,s("div",i,[s("div",d,[u,h,s("pre",y,[s("code",null,[s("span",_,[s("span",E,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])]),s("pre",g,[s("code",null,[s("span",m,[s("span",b,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])])]),v,s("div",k,[C,q,s("pre",F,[s("code",null,[s("span",f,[s("span",S,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])]),s("pre",w,[s("code",null,[s("span",A,[s("span",T,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])])])])]),D]))}});export{O as __pageData,V as default}; diff --git a/pr-1680/assets/developers_optimism.md.6b557910.lean.js b/pr-1680/assets/developers_optimism.md.f09e526a.lean.js similarity index 63% rename from pr-1680/assets/developers_optimism.md.6b557910.lean.js rename to pr-1680/assets/developers_optimism.md.f09e526a.lean.js index 7cf1caedef..ae9276e2d8 100644 --- a/pr-1680/assets/developers_optimism.md.6b557910.lean.js +++ b/pr-1680/assets/developers_optimism.md.f09e526a.lean.js @@ -1 +1 @@ -import{c as a}from"./chunks/constants.0e6df566.js";import{o as t,c as l,k as s,t as e,l as n,Q as o}from"./chunks/framework.a504a440.js";const p=o("",8),c={class:"vp-code-group vp-adaptive-theme"},r=o("",1),i={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("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=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),f={class:"shiki github-dark vp-code-dark"},F={class:"line"},w={style:{color:"#E1E4E8"}},S={class:"shiki github-light vp-code-light"},A={class:"line"},T={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.","next":{"text":"Ethereum fallback mechanism","link":"/developers/ethereum-fallback"},"head":[["meta",{"name":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism.md","filePath":"developers/optimism.md","lastUpdated":1724867275000}'),P={name:"developers/optimism.md"},V=Object.assign(P,{setup(M){return(B,x)=>(t(),l("div",null,[p,s("div",c,[r,s("div",i,[s("div",d,[u,h,s("pre",y,[s("code",null,[s("span",_,[s("span",E,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])]),s("pre",g,[s("code",null,[s("span",m,[s("span",b,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])])]),v,s("div",k,[C,q,s("pre",f,[s("code",null,[s("span",F,[s("span",w,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])]),s("pre",S,[s("code",null,[s("span",A,[s("span",T,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])])])])]),D]))}});export{R as __pageData,V as default}; +import{c as a}from"./chunks/constants.295fc0ab.js";import{o as t,c as l,k as s,t as e,l as n,Q as o}from"./chunks/framework.a504a440.js";const p=o("",8),c={class:"vp-code-group vp-adaptive-theme"},r=o("",1),i={class:"blocks"},d={class:"language-bash vp-adaptive-theme active"},u=s("button",{title:"Copy Code",class:"copy"},null,-1),h=s("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=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),F={class:"shiki github-dark vp-code-dark"},f={class:"line"},S={style:{color:"#E1E4E8"}},w={class:"shiki github-light vp-code-light"},A={class:"line"},T={style:{color:"#24292E"}},D=o("",16),O=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.","next":{"text":"Ethereum fallback mechanism","link":"/developers/ethereum-fallback"},"head":[["meta",{"name":"og:title","content":"Run an OP Stack rollup with Celestia underneath | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/optimism.md","filePath":"developers/optimism.md","lastUpdated":1725955670000}'),M={name:"developers/optimism.md"},V=Object.assign(M,{setup(P){return(B,x)=>(t(),l("div",null,[p,s("div",c,[r,s("div",i,[s("div",d,[u,h,s("pre",y,[s("code",null,[s("span",_,[s("span",E,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])]),s("pre",g,[s("code",null,[s("span",m,[s("span",b,"$HOME/.celestia-light-"+e(n(a).mochaChainId),1)])])])]),v,s("div",k,[C,q,s("pre",F,[s("code",null,[s("span",f,[s("span",S,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])]),s("pre",w,[s("code",null,[s("span",A,[s("span",T,"$HOME/.celestia-light-"+e(n(a).arabicaChainId),1)])])])])])]),D]))}});export{O as __pageData,V as default}; diff --git a/pr-1680/assets/developers_prompt-scavenger.md.70ab1baf.js b/pr-1680/assets/developers_prompt-scavenger.md.8af0d32d.js similarity index 99% rename from pr-1680/assets/developers_prompt-scavenger.md.70ab1baf.js rename to pr-1680/assets/developers_prompt-scavenger.md.8af0d32d.js index 3284d505d4..685cd45d9f 100644 --- a/pr-1680/assets/developers_prompt-scavenger.md.70ab1baf.js +++ b/pr-1680/assets/developers_prompt-scavenger.md.8af0d32d.js @@ -1,4 +1,4 @@ -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.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":"/developers/rust-client-tutorial"},"head":[["meta",{"name":"og:title","content":"Prompt scavenger | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/prompt-scavenger.md","filePath":"developers/prompt-scavenger.md","lastUpdated":1724867275000}'),p={name:"developers/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.a504a440.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":"/developers/rust-client-tutorial"},"head":[["meta",{"name":"og:title","content":"Prompt scavenger | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/prompt-scavenger.md","filePath":"developers/prompt-scavenger.md","lastUpdated":1725955670000}'),p={name:"developers/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-1680/assets/developers_prompt-scavenger.md.70ab1baf.lean.js b/pr-1680/assets/developers_prompt-scavenger.md.8af0d32d.lean.js
        similarity index 84%
        rename from pr-1680/assets/developers_prompt-scavenger.md.70ab1baf.lean.js
        rename to pr-1680/assets/developers_prompt-scavenger.md.8af0d32d.lean.js
        index 4842fd3ade..ff72b53c08 100644
        --- a/pr-1680/assets/developers_prompt-scavenger.md.70ab1baf.lean.js
        +++ b/pr-1680/assets/developers_prompt-scavenger.md.8af0d32d.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.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":"/developers/rust-client-tutorial"},"head":[["meta",{"name":"og:title","content":"Prompt scavenger | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/prompt-scavenger.md","filePath":"developers/prompt-scavenger.md","lastUpdated":1724867275000}'),p={name:"developers/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.a504a440.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":"/developers/rust-client-tutorial"},"head":[["meta",{"name":"og:title","content":"Prompt scavenger | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/prompt-scavenger.md","filePath":"developers/prompt-scavenger.md","lastUpdated":1725955670000}'),p={name:"developers/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-1680/assets/developers_rust-client-tutorial.md.1649c175.js b/pr-1680/assets/developers_rust-client-tutorial.md.892b74cf.js
        similarity index 99%
        rename from pr-1680/assets/developers_rust-client-tutorial.md.1649c175.js
        rename to pr-1680/assets/developers_rust-client-tutorial.md.892b74cf.js
        index fafc8fbf62..dbdedc22f2 100644
        --- a/pr-1680/assets/developers_rust-client-tutorial.md.1649c175.js
        +++ b/pr-1680/assets/developers_rust-client-tutorial.md.892b74cf.js
        @@ -1,4 +1,4 @@
        -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/developers/prompt-scavenger"},"head":[["meta",{"name":"og:title","content":"Rust client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/rust-client-tutorial.md","filePath":"developers/rust-client-tutorial.md","lastUpdated":1724867275000}'),p={name:"developers/rust-client-tutorial.md"},o=l(`

        Rust client library tutorial

        This section tutorial 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.a504a440.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/developers/prompt-scavenger"},"head":[["meta",{"name":"og:title","content":"Rust client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/rust-client-tutorial.md","filePath":"developers/rust-client-tutorial.md","lastUpdated":1725955670000}'),p={name:"developers/rust-client-tutorial.md"},o=l(`

        Rust client library tutorial

        This section tutorial 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::blob::GasPrice;
         use celestia_types::{nmt::Namespace, Blob, ExtendedDataSquare};
         
        diff --git a/pr-1680/assets/developers_rust-client-tutorial.md.1649c175.lean.js b/pr-1680/assets/developers_rust-client-tutorial.md.892b74cf.lean.js
        similarity index 90%
        rename from pr-1680/assets/developers_rust-client-tutorial.md.1649c175.lean.js
        rename to pr-1680/assets/developers_rust-client-tutorial.md.892b74cf.lean.js
        index 278594e5c5..2b25d3ed54 100644
        --- a/pr-1680/assets/developers_rust-client-tutorial.md.1649c175.lean.js
        +++ b/pr-1680/assets/developers_rust-client-tutorial.md.892b74cf.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/developers/prompt-scavenger"},"head":[["meta",{"name":"og:title","content":"Rust client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/rust-client-tutorial.md","filePath":"developers/rust-client-tutorial.md","lastUpdated":1724867275000}'),p={name:"developers/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.a504a440.js";const h=JSON.parse('{"title":"Rust client library tutorial","description":"","frontmatter":{"next":{"text":"Prompt Scavenger","link":"/developers/prompt-scavenger"},"head":[["meta",{"name":"og:title","content":"Rust client library tutorial | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/rust-client-tutorial.md","filePath":"developers/rust-client-tutorial.md","lastUpdated":1725955670000}'),p={name:"developers/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-1680/assets/developers_sp1-blobstream-deploy.md.2340bea7.js b/pr-1680/assets/developers_sp1-blobstream-deploy.md.6a1de8c6.js
        similarity index 98%
        rename from pr-1680/assets/developers_sp1-blobstream-deploy.md.2340bea7.js
        rename to pr-1680/assets/developers_sp1-blobstream-deploy.md.6a1de8c6.js
        index 28a499bd4a..f1f00a2057 100644
        --- a/pr-1680/assets/developers_sp1-blobstream-deploy.md.2340bea7.js
        +++ b/pr-1680/assets/developers_sp1-blobstream-deploy.md.6a1de8c6.js
        @@ -1,3 +1,3 @@
        -import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Integrate with Blobstream X contracts","link":"/developers/blobstream-contracts"},"head":[["meta",{"name":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/sp1-blobstream-deploy.md","filePath":"developers/sp1-blobstream-deploy.md","lastUpdated":1724867275000}'),a={name:"developers/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 as t,c as o,Q as s}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Integrate with Blobstream X contracts","link":"/developers/blobstream-contracts"},"head":[["meta",{"name":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/sp1-blobstream-deploy.md","filePath":"developers/sp1-blobstream-deploy.md","lastUpdated":1725955670000}'),a={name:"developers/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 t(),o("div",null,n)}const u=e(a,[["render",r]]);export{y as __pageData,u as default}; diff --git a/pr-1680/assets/developers_sp1-blobstream-deploy.md.2340bea7.lean.js b/pr-1680/assets/developers_sp1-blobstream-deploy.md.6a1de8c6.lean.js similarity index 91% rename from pr-1680/assets/developers_sp1-blobstream-deploy.md.2340bea7.lean.js rename to pr-1680/assets/developers_sp1-blobstream-deploy.md.6a1de8c6.lean.js index f659897791..17fa3aa239 100644 --- a/pr-1680/assets/developers_sp1-blobstream-deploy.md.2340bea7.lean.js +++ b/pr-1680/assets/developers_sp1-blobstream-deploy.md.6a1de8c6.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Integrate with Blobstream X contracts","link":"/developers/blobstream-contracts"},"head":[["meta",{"name":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/sp1-blobstream-deploy.md","filePath":"developers/sp1-blobstream-deploy.md","lastUpdated":1724867275000}'),a={name:"developers/sp1-blobstream-deploy.md"},l=s("",9),n=[l];function r(p,c,i,d,h,b){return t(),o("div",null,n)}const u=e(a,[["render",r]]);export{y as __pageData,u as default}; +import{_ as e,o as t,c as o,Q as s}from"./chunks/framework.a504a440.js";const y=JSON.parse('{"title":"New SP1 Blobstream deployments","description":"","frontmatter":{"next":{"text":"Integrate with Blobstream X contracts","link":"/developers/blobstream-contracts"},"head":[["meta",{"name":"og:title","content":"New SP1 Blobstream deployments | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/sp1-blobstream-deploy.md","filePath":"developers/sp1-blobstream-deploy.md","lastUpdated":1725955670000}'),a={name:"developers/sp1-blobstream-deploy.md"},l=s("",9),n=[l];function r(p,c,i,d,h,b){return t(),o("div",null,n)}const u=e(a,[["render",r]]);export{y as __pageData,u as default}; diff --git a/pr-1680/assets/developers_submit-data.md.c8780ba2.js b/pr-1680/assets/developers_submit-data.md.84194c6f.js similarity index 99% rename from pr-1680/assets/developers_submit-data.md.c8780ba2.js rename to pr-1680/assets/developers_submit-data.md.84194c6f.js index 48c6ee3f5a..d49a88d55d 100644 --- a/pr-1680/assets/developers_submit-data.md.c8780ba2.js +++ b/pr-1680/assets/developers_submit-data.md.84194c6f.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.a504a440.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/developers/blobstream-rollups"},"head":[["meta",{"name":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/submit-data.md","filePath":"developers/submit-data.md","lastUpdated":1724867275000}'),o={name:"developers/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],C=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),x={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},w={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],z=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),O={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.a504a440.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/developers/blobstream-rollups"},"head":[["meta",{"name":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/submit-data.md","filePath":"developers/submit-data.md","lastUpdated":1725955670000}'),o={name:"developers/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],C=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),x={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},w={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],z=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),O={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-1680/assets/developers_submit-data.md.c8780ba2.lean.js b/pr-1680/assets/developers_submit-data.md.84194c6f.lean.js
        similarity index 99%
        rename from pr-1680/assets/developers_submit-data.md.c8780ba2.lean.js
        rename to pr-1680/assets/developers_submit-data.md.84194c6f.lean.js
        index c2589e87c0..307bffa70e 100644
        --- a/pr-1680/assets/developers_submit-data.md.c8780ba2.lean.js
        +++ b/pr-1680/assets/developers_submit-data.md.84194c6f.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.a504a440.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/developers/blobstream-rollups"},"head":[["meta",{"name":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/submit-data.md","filePath":"developers/submit-data.md","lastUpdated":1724867275000}'),o={name:"developers/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],C=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),x={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},w={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],z=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),O={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("",28);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)),C]),l(" = Fixed Cost, is a static value (65,000 gas)")]),s("li",null,[s("mjx-container",x,[(a(),n("svg",w,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)),z]),l(" = Share Size, is the size of each share")]),s("li",null,[s("mjx-container",O,[(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.a504a440.js";const ts=JSON.parse('{"title":"Submitting data blobs to Celestia","description":"","frontmatter":{"prev":{"text":"Blobstream rollups","link":"/developers/blobstream-rollups"},"head":[["meta",{"name":"og:title","content":"Submitting data blobs to Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/submit-data.md","filePath":"developers/submit-data.md","lastUpdated":1725955670000}'),o={name:"developers/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],C=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),x={class:"MathJax",jax:"SVG",style:{direction:"ltr",position:"relative"}},w={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],z=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),O={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("",28);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)),C]),l(" = Fixed Cost, is a static value (65,000 gas)")]),s("li",null,[s("mjx-container",x,[(a(),n("svg",w,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)),z]),l(" = Share Size, is the size of each share")]),s("li",null,[s("mjx-container",O,[(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-1680/assets/developers_transaction-resubmission.md.2dfb34a4.js b/pr-1680/assets/developers_transaction-resubmission.md.a7ae5c83.js
        similarity index 97%
        rename from pr-1680/assets/developers_transaction-resubmission.md.2dfb34a4.js
        rename to pr-1680/assets/developers_transaction-resubmission.md.a7ae5c83.js
        index 9257c2b337..4c01dacc77 100644
        --- a/pr-1680/assets/developers_transaction-resubmission.md.2dfb34a4.js
        +++ b/pr-1680/assets/developers_transaction-resubmission.md.a7ae5c83.js
        @@ -1 +1 @@
        -import{_ as e,o as s,c as n,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Transaction resubmission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/transaction-resubmission.md","filePath":"developers/transaction-resubmission.md","lastUpdated":1724867275000}'),t={name:"developers/transaction-resubmission.md"},a=i('

        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.

        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.
        ',8),o=[a];function r(c,d,l,u,h,m){return s(),n("div",null,o)}const _=e(t,[["render",r]]);export{b as __pageData,_ as default}; +import{_ as e,o as s,c as n,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Transaction resubmission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/transaction-resubmission.md","filePath":"developers/transaction-resubmission.md","lastUpdated":1725955670000}'),t={name:"developers/transaction-resubmission.md"},a=i('

        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.

        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.
        ',8),o=[a];function r(c,d,l,u,h,m){return s(),n("div",null,o)}const _=e(t,[["render",r]]);export{b as __pageData,_ as default}; diff --git a/pr-1680/assets/developers_transaction-resubmission.md.2dfb34a4.lean.js b/pr-1680/assets/developers_transaction-resubmission.md.a7ae5c83.lean.js similarity index 91% rename from pr-1680/assets/developers_transaction-resubmission.md.2dfb34a4.lean.js rename to pr-1680/assets/developers_transaction-resubmission.md.a7ae5c83.lean.js index 9baa43736c..7a7cb65e29 100644 --- a/pr-1680/assets/developers_transaction-resubmission.md.2dfb34a4.lean.js +++ b/pr-1680/assets/developers_transaction-resubmission.md.a7ae5c83.lean.js @@ -1 +1 @@ -import{_ as e,o as s,c as n,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Transaction resubmission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/transaction-resubmission.md","filePath":"developers/transaction-resubmission.md","lastUpdated":1724867275000}'),t={name:"developers/transaction-resubmission.md"},a=i("",8),o=[a];function r(c,d,l,u,h,m){return s(),n("div",null,o)}const _=e(t,[["render",r]]);export{b as __pageData,_ as default}; +import{_ as e,o as s,c as n,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Transaction resubmission | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/transaction-resubmission.md","filePath":"developers/transaction-resubmission.md","lastUpdated":1725955670000}'),t={name:"developers/transaction-resubmission.md"},a=i("",8),o=[a];function r(c,d,l,u,h,m){return s(),n("div",null,o)}const _=e(t,[["render",r]]);export{b as __pageData,_ as default}; diff --git a/pr-1680/assets/developers_wallets.md.1fc181f4.js b/pr-1680/assets/developers_wallets.md.91a1722d.js similarity index 95% rename from pr-1680/assets/developers_wallets.md.1fc181f4.js rename to pr-1680/assets/developers_wallets.md.91a1722d.js index 346515f5bd..dc82188730 100644 --- a/pr-1680/assets/developers_wallets.md.1fc181f4.js +++ b/pr-1680/assets/developers_wallets.md.91a1722d.js @@ -1,4 +1,4 @@ -import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/wallets.md","filePath":"developers/wallets.md","lastUpdated":1724867275000}'),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.295fc0ab.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/wallets.md","filePath":"developers/wallets.md","lastUpdated":1725955670000}'),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,9 +146,9 @@ import{c as p}from"./chunks/constants.0e6df566.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),m=s("span",{class:"line"},null,-1),C=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"}},U={class:"line"},L={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),H=o('{<AddNetworkKeplr params={MAINNET_PARAMS}/>}',1),O={class:"language-js vp-adaptive-theme"},W=s("button",{title:"Copy Code",class:"copy"},null,-1),J=s("span",{class:"lang"},"js",-1),Y={class:"shiki github-dark vp-code-dark"},X=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),Q=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"}},ms=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Cs=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"},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),js=o('export const ARABICA_PARAMS = {`{',1),Gs={class:"line"},Hs={style:{color:"#032F62"}},Os=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Ws={class:"line"},Js={style:{color:"#032F62"}},Ys={class:"line"},Xs={style:{color:"#032F62"}},Zs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Qs=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("
      4. Chain Name: Arabica devnet
      5. New RPC URL: https://rpc.celestia-arabica-11.com/
      6. New REST URL: https://api.celestia-arabica-11.com
      7. Address Prefix: celestia
      8. Native Denom: utia
      9. Coin Type: 118
      10. Decimals: 6
      11. Block explorer URL (optional): https://explorer.celestia-arabica-10.com
      12. ",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(` -`),m,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"}},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"}},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),W=o('{<AddNetworkKeplr params={MAINNET_PARAMS}/>}',1),H={class:"language-js vp-adaptive-theme"},O=s("button",{title:"Copy Code",class:"copy"},null,-1),z=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),X=s("span",{class:"line"},null,-1),Q=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"},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"},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"},Ws={style:{color:"#032F62"}},Hs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Os={class:"line"},zs={style:{color:"#032F62"}},Ys={class:"line"},Js={style:{color:"#032F62"}},Xs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Qs=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("
      13. Chain Name: Arabica devnet
      14. New RPC URL: https://rpc.celestia-arabica-11.com/
      15. New REST URL: https://api.celestia-arabica-11.com
      16. Address Prefix: celestia
      17. Native Denom: utia
      18. Coin Type: 118
      19. Decimals: 6
      20. Block explorer URL (optional): https://explorer.celestia-arabica-10.com
      21. ",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(` @@ -162,12 +162,12 @@ import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s `),V,n(` `),s("span",M,[s("span",K," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` `),s("span",U,[s("span",L," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` -`),j,n(` `),G,n(` -`),H])])]),s("div",O,[W,J,s("pre",Y,[s("code",null,[X,n(` -`),Z,n(` +`),j,n(` +`),W])])]),s("div",H,[O,z,s("pre",Y,[s("code",null,[J,n(` +`),X,n(` `),Q,n(` -`),s("span",z,[s("span",$," chainId: '"+l(a.constants.mochaChainId)+"',",1)]),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(` @@ -180,8 +180,8 @@ import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s `),_s,n(` `),s("span",hs,[s("span",us," rpc: '"+l(a.constants.mochaRpcUrl)+"',",1)]),n(` `),s("span",Fs,[s("span",As," rest: '"+l(a.constants.mochaRestUrl)+"'",1)]),n(` -`),ms,n(` `),Cs,n(` +`),ms,n(` `),ws])])]),s("div",Ts,[qs,bs,s("pre",gs,[s("code",null,[ks,n(` `),Ds,n(` `),Bs,n(` @@ -193,11 +193,11 @@ import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s `),Vs,n(` `),Ms])]),s("pre",Ks,[s("code",null,[Us,n(` `),Ls,n(` -`),js,n(` -`),s("span",Gs,[s("span",Hs," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` -`),Os,n(` -`),s("span",Ws,[s("span",Js," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` -`),s("span",Ys,[s("span",Xs," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` -`),Zs,n(` +`),Gs,n(` +`),s("span",js,[s("span",Ws," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` +`),Hs,n(` +`),s("span",Os,[s("span",zs," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` +`),s("span",Ys,[s("span",Js," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` +`),Xs,n(` `),Qs,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}; +`),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-1680/assets/developers_wallets.md.1fc181f4.lean.js b/pr-1680/assets/developers_wallets.md.91a1722d.lean.js similarity index 81% rename from pr-1680/assets/developers_wallets.md.1fc181f4.lean.js rename to pr-1680/assets/developers_wallets.md.91a1722d.lean.js index ea8fc75067..094ad87c43 100644 --- a/pr-1680/assets/developers_wallets.md.1fc181f4.lean.js +++ b/pr-1680/assets/developers_wallets.md.91a1722d.lean.js @@ -1,6 +1,6 @@ -import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/wallets.md","filePath":"developers/wallets.md","lastUpdated":1724867275000}'),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),m=s("span",{class:"line"},null,-1),C=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"}},U={class:"line"},L={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),H=o("",1),O={class:"language-js vp-adaptive-theme"},W=s("button",{title:"Copy Code",class:"copy"},null,-1),J=s("span",{class:"lang"},"js",-1),Y={class:"shiki github-dark vp-code-dark"},X=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),Q=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"}},ms=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Cs=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"},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),js=o("",1),Gs={class:"line"},Hs={style:{color:"#032F62"}},Os=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Ws={class:"line"},Js={style:{color:"#032F62"}},Ys={class:"line"},Xs={style:{color:"#032F62"}},Zs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Qs=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(` -`),m,n(` +import{c as p}from"./chunks/constants.295fc0ab.js";import{_ as e,o as t,c,k as s,a as n,t as l,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Wallet integrations with Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"developers/wallets.md","filePath":"developers/wallets.md","lastUpdated":1725955670000}'),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"}},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),W=o("",1),H={class:"language-js vp-adaptive-theme"},O=s("button",{title:"Copy Code",class:"copy"},null,-1),z=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),X=s("span",{class:"line"},null,-1),Q=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"},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"},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"},Ws={style:{color:"#032F62"}},Hs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}}," chainName: 'Arabica devnet',")],-1),Os={class:"line"},zs={style:{color:"#032F62"}},Ys={class:"line"},Js={style:{color:"#032F62"}},Xs=s("span",{class:"line"},[s("span",{style:{color:"#032F62"}},"}`"),s("span",{style:{color:"#24292E"}},"}")],-1),Qs=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(` @@ -14,12 +14,12 @@ import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s `),V,n(` `),s("span",M,[s("span",K," rpc: '"+l(a.constants.mainnetRpcUrl)+"',",1)]),n(` `),s("span",U,[s("span",L," rest: '"+l(a.constants.mainnetRestUrl)+"'",1)]),n(` -`),j,n(` `),G,n(` -`),H])])]),s("div",O,[W,J,s("pre",Y,[s("code",null,[X,n(` -`),Z,n(` +`),j,n(` +`),W])])]),s("div",H,[O,z,s("pre",Y,[s("code",null,[J,n(` +`),X,n(` `),Q,n(` -`),s("span",z,[s("span",$," chainId: '"+l(a.constants.mochaChainId)+"',",1)]),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(` @@ -32,8 +32,8 @@ import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s `),_s,n(` `),s("span",hs,[s("span",us," rpc: '"+l(a.constants.mochaRpcUrl)+"',",1)]),n(` `),s("span",Fs,[s("span",As," rest: '"+l(a.constants.mochaRestUrl)+"'",1)]),n(` -`),ms,n(` `),Cs,n(` +`),ms,n(` `),ws])])]),s("div",Ts,[qs,bs,s("pre",gs,[s("code",null,[ks,n(` `),Ds,n(` `),Bs,n(` @@ -45,11 +45,11 @@ import{c as p}from"./chunks/constants.0e6df566.js";import{_ as e,o as t,c,k as s `),Vs,n(` `),Ms])]),s("pre",Ks,[s("code",null,[Us,n(` `),Ls,n(` -`),js,n(` -`),s("span",Gs,[s("span",Hs," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` -`),Os,n(` -`),s("span",Ws,[s("span",Js," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` -`),s("span",Ys,[s("span",Xs," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` -`),Zs,n(` +`),Gs,n(` +`),s("span",js,[s("span",Ws," chainId: '"+l(a.constants.arabicaChainId)+"',",1)]),n(` +`),Hs,n(` +`),s("span",Os,[s("span",zs," rpc: '"+l(a.constants.arabicaRpcUrl)+"',",1)]),n(` +`),s("span",Ys,[s("span",Js," rest: '"+l(a.constants.arabicaRestUrl)+"'",1)]),n(` +`),Xs,n(` `),Qs,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}; +`),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-1680/assets/index.md.0f32fb36.js b/pr-1680/assets/index.md.c62fad43.js similarity index 96% rename from pr-1680/assets/index.md.0f32fb36.js rename to pr-1680/assets/index.md.c62fad43.js index 791915457c..ad852481e3 100644 --- a/pr-1680/assets/index.md.0f32fb36.js +++ b/pr-1680/assets/index.md.c62fad43.js @@ -1 +1 @@ -import{_ as e,o as t,c as a}from"./chunks/framework.a504a440.js";const u=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":"Build whatever","link":"/developers/build-whatever"},{"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":"Run a node","details":"Access the dynamic scaling unlocked by data availability sampling, where scale increases with the number of users.","link":"/nodes/overview","icon":"📈"},{"title":"Developers","details":"Create applications using your favorite VM or define your own. Build sovereign rollups, a new type of self-governing blockchain with minimal platform risk.","link":"/developers/build-whatever","icon":"⚙️"},{"title":"Community","details":"Join the Celestia community to connect, collaborate, and contribute to the future of modular blockchains.","link":"/community/overview","icon":"🏰"}],"head":[["meta",{"name":"og:title","content":"Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1724867275000}'),i={name:"index.md"};function o(n,l,s,r,c,d){return t(),a("div")}const h=e(i,[["render",o]]);export{u as __pageData,h as default}; +import{_ as e,o as t,c as a}from"./chunks/framework.a504a440.js";const u=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":"Build whatever","link":"/developers/build-whatever"},{"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":"Run a node","details":"Access the dynamic scaling unlocked by data availability sampling, where scale increases with the number of users.","link":"/nodes/overview","icon":"📈"},{"title":"Developers","details":"Create applications using your favorite VM or define your own. Build sovereign rollups, a new type of self-governing blockchain with minimal platform risk.","link":"/developers/build-whatever","icon":"⚙️"},{"title":"Community","details":"Join the Celestia community to connect, collaborate, and contribute to the future of modular blockchains.","link":"/community/overview","icon":"🏰"}],"head":[["meta",{"name":"og:title","content":"Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1725955670000}'),i={name:"index.md"};function o(n,l,s,r,c,d){return t(),a("div")}const h=e(i,[["render",o]]);export{u as __pageData,h as default}; diff --git a/pr-1680/assets/index.md.0f32fb36.lean.js b/pr-1680/assets/index.md.c62fad43.lean.js similarity index 96% rename from pr-1680/assets/index.md.0f32fb36.lean.js rename to pr-1680/assets/index.md.c62fad43.lean.js index 791915457c..ad852481e3 100644 --- a/pr-1680/assets/index.md.0f32fb36.lean.js +++ b/pr-1680/assets/index.md.c62fad43.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a}from"./chunks/framework.a504a440.js";const u=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":"Build whatever","link":"/developers/build-whatever"},{"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":"Run a node","details":"Access the dynamic scaling unlocked by data availability sampling, where scale increases with the number of users.","link":"/nodes/overview","icon":"📈"},{"title":"Developers","details":"Create applications using your favorite VM or define your own. Build sovereign rollups, a new type of self-governing blockchain with minimal platform risk.","link":"/developers/build-whatever","icon":"⚙️"},{"title":"Community","details":"Join the Celestia community to connect, collaborate, and contribute to the future of modular blockchains.","link":"/community/overview","icon":"🏰"}],"head":[["meta",{"name":"og:title","content":"Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1724867275000}'),i={name:"index.md"};function o(n,l,s,r,c,d){return t(),a("div")}const h=e(i,[["render",o]]);export{u as __pageData,h as default}; +import{_ as e,o as t,c as a}from"./chunks/framework.a504a440.js";const u=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":"Build whatever","link":"/developers/build-whatever"},{"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":"Run a node","details":"Access the dynamic scaling unlocked by data availability sampling, where scale increases with the number of users.","link":"/nodes/overview","icon":"📈"},{"title":"Developers","details":"Create applications using your favorite VM or define your own. Build sovereign rollups, a new type of self-governing blockchain with minimal platform risk.","link":"/developers/build-whatever","icon":"⚙️"},{"title":"Community","details":"Join the Celestia community to connect, collaborate, and contribute to the future of modular blockchains.","link":"/community/overview","icon":"🏰"}],"head":[["meta",{"name":"og:title","content":"Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"index.md","filePath":"index.md","lastUpdated":1725955670000}'),i={name:"index.md"};function o(n,l,s,r,c,d){return t(),a("div")}const h=e(i,[["render",o]]);export{u as __pageData,h as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.c77d8ed2.js b/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.4f8ba756.js similarity index 99% rename from pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.c77d8ed2.js rename to pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.4f8ba756.js index bf354296d5..402da55ebf 100644 --- a/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.c77d8ed2.js +++ b/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.4f8ba756.js @@ -1 +1 @@ -import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-storage.png",m=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",{"name":"og:title","content":"Data availability FAQ | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1724867275000}'),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 v=a(r,[["render",d]]);export{m as __pageData,v as default}; +import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-storage.png",m=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",{"name":"og:title","content":"Data availability FAQ | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1725955670000}'),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 v=a(r,[["render",d]]);export{m as __pageData,v as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.c77d8ed2.lean.js b/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.4f8ba756.lean.js similarity index 93% rename from pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.c77d8ed2.lean.js rename to pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.4f8ba756.lean.js index 3ff9344a0e..e32f2eb4f4 100644 --- a/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.c77d8ed2.lean.js +++ b/pr-1680/assets/learn_how-celestia-works_data-availability-faq.md.4f8ba756.lean.js @@ -1 +1 @@ -import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-storage.png",m=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",{"name":"og:title","content":"Data availability FAQ | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1724867275000}'),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 v=a(r,[["render",d]]);export{m as __pageData,v as default}; +import{_ as a,o as t,c as e,Q as i}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-availability.png",s="/docs-preview/pr-1680/img/learn/data-availability-faq/Data-storage.png",m=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",{"name":"og:title","content":"Data availability FAQ | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-faq.md","filePath":"learn/how-celestia-works/data-availability-faq.md","lastUpdated":1725955670000}'),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 v=a(r,[["render",d]]);export{m as __pageData,v as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.js b/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.js similarity index 99% rename from pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.js rename to pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.js index e0d82bd512..6dd275dca7 100644 --- a/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.js +++ b/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.js @@ -1 +1 @@ -import{_ as l,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.a504a440.js";const i="/docs-preview/pr-1680/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1680/img/learn/nmt.png",r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia's data availability layer | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1724867275000}`),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.a504a440.js";const i="/docs-preview/pr-1680/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1680/img/learn/nmt.png",r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia's data availability layer | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1725955670000}`),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-1680/assets/learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.lean.js b/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.lean.js similarity index 99% rename from pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.lean.js rename to pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.lean.js index db9420a6a0..5a9ef61e65 100644 --- a/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.3ecbc0a8.lean.js +++ b/pr-1680/assets/learn_how-celestia-works_data-availability-layer.md.fe8c1e7c.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.a504a440.js";const i="/docs-preview/pr-1680/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1680/img/learn/nmt.png",r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia's data availability layer | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1724867275000}`),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.a504a440.js";const i="/docs-preview/pr-1680/img/learn/reed-solomon-encoding.png",n="/docs-preview/pr-1680/img/learn/nmt.png",r="/docs-preview/pr-1680/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",{"name":"og:title","content":"Celestia's data availability layer | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/data-availability-layer.md","filePath":"learn/how-celestia-works/data-availability-layer.md","lastUpdated":1725955670000}`),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-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.494025b0.js b/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.js similarity index 98% rename from pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.494025b0.js rename to pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.js index 4be35f4b21..ecfde7aca3 100644 --- a/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.494025b0.js +++ b/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/img/learn/monolithic-modular.png",g=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"name":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1724867275000}'),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 b=e(i,[["render",l]]);export{g as __pageData,b as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/img/learn/monolithic-modular.png",g=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"name":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1725955670000}'),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 b=e(i,[["render",l]]);export{g as __pageData,b as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.494025b0.lean.js b/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.lean.js similarity index 92% rename from pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.494025b0.lean.js rename to pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.lean.js index 4803eafbec..44e4fc0bd5 100644 --- a/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.494025b0.lean.js +++ b/pr-1680/assets/learn_how-celestia-works_monolithic-vs-modular.md.b9f1f45d.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/img/learn/monolithic-modular.png",g=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"name":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1724867275000}'),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 b=e(i,[["render",l]]);export{g as __pageData,b as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/img/learn/monolithic-modular.png",g=JSON.parse('{"title":"Monolithic vs. modular blockchains","description":"Comparison between monolithic and modular blockchains.","frontmatter":{"description":"Comparison between monolithic and modular blockchains.","head":[["meta",{"name":"og:title","content":"Monolithic vs. modular blockchains | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/monolithic-vs-modular.md","filePath":"learn/how-celestia-works/monolithic-vs-modular.md","lastUpdated":1725955670000}'),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 b=e(i,[["render",l]]);export{g as __pageData,b as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_overview.md.d0862172.js b/pr-1680/assets/learn_how-celestia-works_overview.md.c1a281d5.js similarity index 97% rename from pr-1680/assets/learn_how-celestia-works_overview.md.d0862172.js rename to pr-1680/assets/learn_how-celestia-works_overview.md.c1a281d5.js index aa3f9f2781..4c466ea3fe 100644 --- a/pr-1680/assets/learn_how-celestia-works_overview.md.d0862172.js +++ b/pr-1680/assets/learn_how-celestia-works_overview.md.c1a281d5.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Introduction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1724867275000}'),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,m){return a(),t("div",null,n)}const _=e(i,[["render",s]]);export{f as __pageData,_ as default}; +import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Introduction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1725955670000}'),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,m){return a(),t("div",null,n)}const _=e(i,[["render",s]]);export{f as __pageData,_ as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_overview.md.d0862172.lean.js b/pr-1680/assets/learn_how-celestia-works_overview.md.c1a281d5.lean.js similarity index 89% rename from pr-1680/assets/learn_how-celestia-works_overview.md.d0862172.lean.js rename to pr-1680/assets/learn_how-celestia-works_overview.md.c1a281d5.lean.js index 24e47a4dd2..ca06ab62be 100644 --- a/pr-1680/assets/learn_how-celestia-works_overview.md.d0862172.lean.js +++ b/pr-1680/assets/learn_how-celestia-works_overview.md.c1a281d5.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Introduction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1724867275000}'),i={name:"learn/how-celestia-works/overview.md"},o=r("",6),n=[o];function s(l,c,h,d,p,m){return a(),t("div",null,n)}const _=e(i,[["render",s]]);export{f as __pageData,_ as default}; +import{_ as e,o as a,c as t,Q as r}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Introduction","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Introduction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/overview.md","filePath":"learn/how-celestia-works/overview.md","lastUpdated":1725955670000}'),i={name:"learn/how-celestia-works/overview.md"},o=r("",6),n=[o];function s(l,c,h,d,p,m){return a(),t("div",null,n)}const _=e(i,[["render",s]]);export{f as __pageData,_ as default}; diff --git a/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.a039d39a.js b/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.js similarity index 99% rename from pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.a039d39a.js rename to pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.js index bfc6a8c6ec..4640578997 100644 --- a/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.a039d39a.js +++ b/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.js @@ -1 +1 @@ -import{_ as i}from"./chunks/tx-lifecycle.b1041bc0.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1724867275000}'),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),d=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),h={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 "),d,t(", the commitment is the Merkle root of the "),e("mjx-container",h,[(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.b1041bc0.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1725955670000}'),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),d=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),h={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 "),d,t(", the commitment is the Merkle root of the "),e("mjx-container",h,[(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-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.a039d39a.lean.js b/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.lean.js similarity index 99% rename from pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.a039d39a.lean.js rename to pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.lean.js index 06a3650c60..68c000f4ac 100644 --- a/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.a039d39a.lean.js +++ b/pr-1680/assets/learn_how-celestia-works_transaction-lifecycle.md.2dbdde2f.lean.js @@ -1 +1 @@ -import{_ as i}from"./chunks/tx-lifecycle.b1041bc0.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1724867275000}'),r={name:"learn/how-celestia-works/transaction-lifecycle.md"},c=s("",5),d=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),h={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 "),d,t(", the commitment is the Merkle root of the "),e("mjx-container",h,[(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.b1041bc0.js";import{_ as n,o as a,c as o,k as e,a as t,Q as s}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"The lifecycle of a celestia-app transaction | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-celestia-works/transaction-lifecycle.md","filePath":"learn/how-celestia-works/transaction-lifecycle.md","lastUpdated":1725955670000}'),r={name:"learn/how-celestia-works/transaction-lifecycle.md"},c=s("",5),d=e("a",{href:"./data-availability-layer"},`described in the "Celestia's data availability layer" page`,-1),h={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 "),d,t(", the commitment is the Merkle root of the "),e("mjx-container",h,[(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-1680/assets/learn_how-to-stake-tia.md.eca4d77a.js b/pr-1680/assets/learn_how-to-stake-tia.md.8cd56e12.js similarity index 99% rename from pr-1680/assets/learn_how-to-stake-tia.md.eca4d77a.js rename to pr-1680/assets/learn_how-to-stake-tia.md.8cd56e12.js index 565d3649a7..a14d5c2b95 100644 --- a/pr-1680/assets/learn_how-to-stake-tia.md.eca4d77a.js +++ b/pr-1680/assets/learn_how-to-stake-tia.md.8cd56e12.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/keplr.png",i="/docs-preview/pr-1680/img/leap.png",l="/docs-preview/pr-1680/img/gem.png",s="/docs-preview/pr-1680/img/keplr/keplr1.gif",n="/docs-preview/pr-1680/img/keplr/keplr2.gif",p="/docs-preview/pr-1680/img/keplr/keplr3.gif",c="/docs-preview/pr-1680/img/keplr/keplr4.gif",d="/docs-preview/pr-1680/img/leap/leap1.gif",h="/docs-preview/pr-1680/img/leap/leap2.gif",m="/docs-preview/pr-1680/img/leap/leap3.gif",w="/docs-preview/pr-1680/img/gem/gem1.gif",k="/docs-preview/pr-1680/img/gem/gem2.gif",u="/docs-preview/pr-1680/img/gem/gem3.gif",f="/docs-preview/pr-1680/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",{"name":"og:title","content":"How to stake TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1724867275000}'),g={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),b=[_];function v(y,T,A,I,S,q){return a(),t("div",null,b)}const K=e(g,[["render",v]]);export{C as __pageData,K as default}; +import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/keplr.png",i="/docs-preview/pr-1680/img/leap.png",l="/docs-preview/pr-1680/img/gem.png",s="/docs-preview/pr-1680/img/keplr/keplr1.gif",n="/docs-preview/pr-1680/img/keplr/keplr2.gif",p="/docs-preview/pr-1680/img/keplr/keplr3.gif",c="/docs-preview/pr-1680/img/keplr/keplr4.gif",d="/docs-preview/pr-1680/img/leap/leap1.gif",h="/docs-preview/pr-1680/img/leap/leap2.gif",m="/docs-preview/pr-1680/img/leap/leap3.gif",w="/docs-preview/pr-1680/img/gem/gem1.gif",k="/docs-preview/pr-1680/img/gem/gem2.gif",u="/docs-preview/pr-1680/img/gem/gem3.gif",f="/docs-preview/pr-1680/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",{"name":"og:title","content":"How to stake TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1725955670000}'),g={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),b=[_];function v(y,T,A,I,S,q){return a(),t("div",null,b)}const K=e(g,[["render",v]]);export{C as __pageData,K as default}; diff --git a/pr-1680/assets/learn_how-to-stake-tia.md.eca4d77a.lean.js b/pr-1680/assets/learn_how-to-stake-tia.md.8cd56e12.lean.js similarity index 95% rename from pr-1680/assets/learn_how-to-stake-tia.md.eca4d77a.lean.js rename to pr-1680/assets/learn_how-to-stake-tia.md.8cd56e12.lean.js index 4af46bd5c0..1fb6580594 100644 --- a/pr-1680/assets/learn_how-to-stake-tia.md.eca4d77a.lean.js +++ b/pr-1680/assets/learn_how-to-stake-tia.md.8cd56e12.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/keplr.png",i="/docs-preview/pr-1680/img/leap.png",l="/docs-preview/pr-1680/img/gem.png",s="/docs-preview/pr-1680/img/keplr/keplr1.gif",n="/docs-preview/pr-1680/img/keplr/keplr2.gif",p="/docs-preview/pr-1680/img/keplr/keplr3.gif",c="/docs-preview/pr-1680/img/keplr/keplr4.gif",d="/docs-preview/pr-1680/img/leap/leap1.gif",h="/docs-preview/pr-1680/img/leap/leap2.gif",m="/docs-preview/pr-1680/img/leap/leap3.gif",w="/docs-preview/pr-1680/img/gem/gem1.gif",k="/docs-preview/pr-1680/img/gem/gem2.gif",u="/docs-preview/pr-1680/img/gem/gem3.gif",f="/docs-preview/pr-1680/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",{"name":"og:title","content":"How to stake TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1724867275000}'),g={name:"learn/how-to-stake-tia.md"},_=o("",48),b=[_];function v(y,T,A,I,S,q){return a(),t("div",null,b)}const K=e(g,[["render",v]]);export{C as __pageData,K as default}; +import{_ as e,o as a,c as t,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/keplr.png",i="/docs-preview/pr-1680/img/leap.png",l="/docs-preview/pr-1680/img/gem.png",s="/docs-preview/pr-1680/img/keplr/keplr1.gif",n="/docs-preview/pr-1680/img/keplr/keplr2.gif",p="/docs-preview/pr-1680/img/keplr/keplr3.gif",c="/docs-preview/pr-1680/img/keplr/keplr4.gif",d="/docs-preview/pr-1680/img/leap/leap1.gif",h="/docs-preview/pr-1680/img/leap/leap2.gif",m="/docs-preview/pr-1680/img/leap/leap3.gif",w="/docs-preview/pr-1680/img/gem/gem1.gif",k="/docs-preview/pr-1680/img/gem/gem2.gif",u="/docs-preview/pr-1680/img/gem/gem3.gif",f="/docs-preview/pr-1680/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",{"name":"og:title","content":"How to stake TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/how-to-stake-tia.md","filePath":"learn/how-to-stake-tia.md","lastUpdated":1725955670000}'),g={name:"learn/how-to-stake-tia.md"},_=o("",48),b=[_];function v(y,T,A,I,S,q){return a(),t("div",null,b)}const K=e(g,[["render",v]]);export{C as __pageData,K as default}; diff --git a/pr-1680/assets/learn_paying-for-blobspace.md.1a14801b.js b/pr-1680/assets/learn_paying-for-blobspace.md.bf3ce96f.js similarity index 97% rename from pr-1680/assets/learn_paying-for-blobspace.md.1a14801b.js rename to pr-1680/assets/learn_paying-for-blobspace.md.bf3ce96f.js index 18ad8c4eb1..c0f8db61a7 100644 --- a/pr-1680/assets/learn_paying-for-blobspace.md.1a14801b.js +++ b/pr-1680/assets/learn_paying-for-blobspace.md.bf3ce96f.js @@ -1 +1 @@ -import{_ as e}from"./chunks/tx-lifecycle.b1041bc0.js";import{_ as a,o as t,c as o,Q as i}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Paying for blobspace | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1724867275000}'),s={name:"learn/paying-for-blobspace.md"},n=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),r=[n];function c(l,d,p,h,b,m){return t(),o("div",null,r)}const y=a(s,[["render",c]]);export{u as __pageData,y as default}; +import{_ as e}from"./chunks/tx-lifecycle.b1041bc0.js";import{_ as a,o as t,c as o,Q as i}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Paying for blobspace | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1725955670000}'),s={name:"learn/paying-for-blobspace.md"},n=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),r=[n];function c(l,d,p,h,b,m){return t(),o("div",null,r)}const y=a(s,[["render",c]]);export{u as __pageData,y as default}; diff --git a/pr-1680/assets/learn_paying-for-blobspace.md.1a14801b.lean.js b/pr-1680/assets/learn_paying-for-blobspace.md.bf3ce96f.lean.js similarity index 90% rename from pr-1680/assets/learn_paying-for-blobspace.md.1a14801b.lean.js rename to pr-1680/assets/learn_paying-for-blobspace.md.bf3ce96f.lean.js index 8f8910bf0b..ae0d616946 100644 --- a/pr-1680/assets/learn_paying-for-blobspace.md.1a14801b.lean.js +++ b/pr-1680/assets/learn_paying-for-blobspace.md.bf3ce96f.lean.js @@ -1 +1 @@ -import{_ as e}from"./chunks/tx-lifecycle.b1041bc0.js";import{_ as a,o as t,c as o,Q as i}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Paying for blobspace | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1724867275000}'),s={name:"learn/paying-for-blobspace.md"},n=i("",11),r=[n];function c(l,d,p,h,b,m){return t(),o("div",null,r)}const y=a(s,[["render",c]]);export{u as __pageData,y as default}; +import{_ as e}from"./chunks/tx-lifecycle.b1041bc0.js";import{_ as a,o as t,c as o,Q as i}from"./chunks/framework.a504a440.js";const u=JSON.parse('{"title":"Paying for blobspace","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Paying for blobspace | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/paying-for-blobspace.md","filePath":"learn/paying-for-blobspace.md","lastUpdated":1725955670000}'),s={name:"learn/paying-for-blobspace.md"},n=i("",11),r=[n];function c(l,d,p,h,b,m){return t(),o("div",null,r)}const y=a(s,[["render",c]]);export{u as __pageData,y as default}; diff --git a/pr-1680/assets/learn_retrievability.md.624d5724.js b/pr-1680/assets/learn_retrievability.md.502536f6.js similarity index 98% rename from pr-1680/assets/learn_retrievability.md.624d5724.js rename to pr-1680/assets/learn_retrievability.md.502536f6.js index dea3a2f729..cb30ed963f 100644 --- a/pr-1680/assets/learn_retrievability.md.624d5724.js +++ b/pr-1680/assets/learn_retrievability.md.502536f6.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Data retrievability and pruning | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1724867275000}'),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 historic 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),s=[r];function n(l,d,c,h,p,u){return a(),t("div",null,s)}const f=e(o,[["render",n]]);export{g as __pageData,f as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Data retrievability and pruning | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1725955670000}'),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 historic 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),s=[r];function n(l,d,c,h,p,u){return a(),t("div",null,s)}const f=e(o,[["render",n]]);export{g as __pageData,f as default}; diff --git a/pr-1680/assets/learn_retrievability.md.624d5724.lean.js b/pr-1680/assets/learn_retrievability.md.502536f6.lean.js similarity index 92% rename from pr-1680/assets/learn_retrievability.md.624d5724.lean.js rename to pr-1680/assets/learn_retrievability.md.502536f6.lean.js index c8a00f92a8..35f0189255 100644 --- a/pr-1680/assets/learn_retrievability.md.624d5724.lean.js +++ b/pr-1680/assets/learn_retrievability.md.502536f6.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Data retrievability and pruning | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1724867275000}'),o={name:"learn/retrievability.md"},r=i("",11),s=[r];function n(l,d,c,h,p,u){return a(),t("div",null,s)}const f=e(o,[["render",n]]);export{g as __pageData,f as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Data retrievability and pruning | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/retrievability.md","filePath":"learn/retrievability.md","lastUpdated":1725955670000}'),o={name:"learn/retrievability.md"},r=i("",11),s=[r];function n(l,d,c,h,p,u){return a(),t("div",null,s)}const f=e(o,[["render",n]]);export{g as __pageData,f as default}; diff --git a/pr-1680/assets/learn_staking-governance-supply.md.f12d24a2.js b/pr-1680/assets/learn_staking-governance-supply.md.d4993c82.js similarity index 99% rename from pr-1680/assets/learn_staking-governance-supply.md.f12d24a2.js rename to pr-1680/assets/learn_staking-governance-supply.md.d4993c82.js index 88efcba2f7..491a012125 100644 --- a/pr-1680/assets/learn_staking-governance-supply.md.f12d24a2.js +++ b/pr-1680/assets/learn_staking-governance-supply.md.d4993c82.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1680/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1680/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",{"name":"og:title","content":"Staking, governance, & supply | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1724867275000}'),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.4%
        Future initiatives: 12.6%
        20%
        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.8%
        Early Backers: Series A&BEarly supporters of Celestia19.7%
        Early Backers: SeedEarly supporters of Celestia15.9%
        Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.6%

        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.

        CategoryUnlock Schedule
        Public AllocationFully unlocked at launch.
        R&D & Ecosystem25% unlocked at launch.
        Remaining 75% unlocks continuously from year 1 to year 4.
        Initial Core Contributors33% unlocked at year 1.
        Remaining 67% unlocks continuously from year 1 to year 3.
        Early Backers: Seed33% unlocked at year 1.
        Remaining 67% unlocks continuously from year 1 to year 2.
        Early Backers: Series A&B33% unlocked at year 1.
        Remaining 67% unlocks continuously from year 1 to year 2.
        ',30),d=[l];function c(p,h,u,m,f,g){return t(),a("div",null,d)}const y=e(i,[["render",c]]);export{k as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1680/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1680/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",{"name":"og:title","content":"Staking, governance, & supply | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1725955670000}'),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.4%
        Future initiatives: 12.6%
        20%
        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.8%
        Early Backers: Series A&BEarly supporters of Celestia19.7%
        Early Backers: SeedEarly supporters of Celestia15.9%
        Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.6%

        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.

        CategoryUnlock Schedule
        Public AllocationFully unlocked at launch.
        R&D & Ecosystem25% unlocked at launch.
        Remaining 75% unlocks continuously from year 1 to year 4.
        Initial Core Contributors33% unlocked at year 1.
        Remaining 67% unlocks continuously from year 1 to year 3.
        Early Backers: Seed33% unlocked at year 1.
        Remaining 67% unlocks continuously from year 1 to year 2.
        Early Backers: Series A&B33% unlocked at year 1.
        Remaining 67% unlocks continuously from year 1 to year 2.
        ',30),d=[l];function c(p,h,u,m,f,g){return t(),a("div",null,d)}const y=e(i,[["render",c]]);export{k as __pageData,y as default}; diff --git a/pr-1680/assets/learn_staking-governance-supply.md.f12d24a2.lean.js b/pr-1680/assets/learn_staking-governance-supply.md.d4993c82.lean.js similarity index 93% rename from pr-1680/assets/learn_staking-governance-supply.md.f12d24a2.lean.js rename to pr-1680/assets/learn_staking-governance-supply.md.d4993c82.lean.js index 368acb0b8e..0373402707 100644 --- a/pr-1680/assets/learn_staking-governance-supply.md.f12d24a2.lean.js +++ b/pr-1680/assets/learn_staking-governance-supply.md.d4993c82.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1680/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1680/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",{"name":"og:title","content":"Staking, governance, & supply | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1724867275000}'),i={name:"learn/staking-governance-supply.md"},l=o("",30),d=[l];function c(p,h,u,m,f,g){return t(),a("div",null,d)}const y=e(i,[["render",c]]);export{k as __pageData,y as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const r="/docs-preview/pr-1680/img/learn/Celestia_TIA_Inflation.png",n="/docs-preview/pr-1680/img/learn/Celestia_TIA_Allocation_at_Genesis.png",s="/docs-preview/pr-1680/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",{"name":"og:title","content":"Staking, governance, & supply | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking-governance-supply.md","filePath":"learn/staking-governance-supply.md","lastUpdated":1725955670000}'),i={name:"learn/staking-governance-supply.md"},l=o("",30),d=[l];function c(p,h,u,m,f,g){return t(),a("div",null,d)}const y=e(i,[["render",c]]);export{k as __pageData,y as default}; diff --git a/pr-1680/assets/learn_staking.md.41f598de.js b/pr-1680/assets/learn_staking.md.5f314f9c.js similarity index 97% rename from pr-1680/assets/learn_staking.md.41f598de.js rename to pr-1680/assets/learn_staking.md.5f314f9c.js index 7e42fc1b3c..9edd6aaa05 100644 --- a/pr-1680/assets/learn_staking.md.41f598de.js +++ b/pr-1680/assets/learn_staking.md.5f314f9c.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.a504a440.js";const g=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",{"name":"og:title","content":"Staking on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1724867275000}'),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),l=[r];function i(o,h,c,p,k,d){return t(),a("div",null,l)}const m=e(s,[["render",i]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.a504a440.js";const g=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",{"name":"og:title","content":"Staking on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1725955670000}'),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),l=[r];function i(o,h,c,p,k,d){return t(),a("div",null,l)}const m=e(s,[["render",i]]);export{g as __pageData,m as default}; diff --git a/pr-1680/assets/learn_staking.md.41f598de.lean.js b/pr-1680/assets/learn_staking.md.5f314f9c.lean.js similarity index 90% rename from pr-1680/assets/learn_staking.md.41f598de.lean.js rename to pr-1680/assets/learn_staking.md.5f314f9c.lean.js index aa6849a8a7..bc05471a83 100644 --- a/pr-1680/assets/learn_staking.md.41f598de.lean.js +++ b/pr-1680/assets/learn_staking.md.5f314f9c.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.a504a440.js";const g=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",{"name":"og:title","content":"Staking on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1724867275000}'),s={name:"learn/staking.md"},r=n("",10),l=[r];function i(o,h,c,p,k,d){return t(),a("div",null,l)}const m=e(s,[["render",i]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as a,Q as n}from"./chunks/framework.a504a440.js";const g=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",{"name":"og:title","content":"Staking on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/staking.md","filePath":"learn/staking.md","lastUpdated":1725955670000}'),s={name:"learn/staking.md"},r=n("",10),l=[r];function i(o,h,c,p,k,d){return t(),a("div",null,l)}const m=e(s,[["render",i]]);export{g as __pageData,m as default}; diff --git a/pr-1680/assets/learn_tia.md.4c7134d5.js b/pr-1680/assets/learn_tia.md.50908c0d.js similarity index 99% rename from pr-1680/assets/learn_tia.md.4c7134d5.js rename to pr-1680/assets/learn_tia.md.50908c0d.js index 56ebb69bdb..852973542a 100644 --- a/pr-1680/assets/learn_tia.md.4c7134d5.js +++ b/pr-1680/assets/learn_tia.md.50908c0d.js @@ -1 +1 @@ -import{_ as s,o as t,c as e,k as a,a as o,Q as n}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Overview of TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1724867275000}'),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),Q=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),p=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,Q,p,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.a504a440.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",{"name":"og:title","content":"Overview of TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1725955670000}'),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),Q=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),p=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,Q,p,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-1680/assets/learn_tia.md.4c7134d5.lean.js b/pr-1680/assets/learn_tia.md.50908c0d.lean.js similarity index 97% rename from pr-1680/assets/learn_tia.md.4c7134d5.lean.js rename to pr-1680/assets/learn_tia.md.50908c0d.lean.js index d9dce5eef3..4c655d92b7 100644 --- a/pr-1680/assets/learn_tia.md.4c7134d5.lean.js +++ b/pr-1680/assets/learn_tia.md.50908c0d.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.a504a440.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",{"name":"og:title","content":"Overview of TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1724867275000}'),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),Q=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),p=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,Q,p,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.a504a440.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",{"name":"og:title","content":"Overview of TIA | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"learn/tia.md","filePath":"learn/tia.md","lastUpdated":1725955670000}'),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),Q=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),p=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,Q,p,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-1680/assets/nodes_arabica-devnet.md.1e272478.js b/pr-1680/assets/nodes_arabica-devnet.md.c4919f1d.js similarity index 98% rename from pr-1680/assets/nodes_arabica-devnet.md.1e272478.js rename to pr-1680/assets/nodes_arabica-devnet.md.c4919f1d.js index e7968a7259..f2081cde6d 100644 --- a/pr-1680/assets/nodes_arabica-devnet.md.1e272478.js +++ b/pr-1680/assets/nodes_arabica-devnet.md.c4919f1d.js @@ -1,3 +1,3 @@ -import{A as d}from"./chunks/ArabicaVersionTags.e01dd824.js";import{c as p}from"./chunks/constants.0e6df566.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.a504a440.js";import"./chunks/arabica_versions.6d89be6e.js";const b="/docs-preview/pr-1680/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),f=e("td",null,"Chain ID",-1),m=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),E=e("td",null,"Genesis file",-1),v=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(l,i,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[f,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),m,e("tr",null,[E,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,v)])]),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 Hardfork 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 \\
        +import{A as d}from"./chunks/ArabicaVersionTags.20a10f87.js";import{c as p}from"./chunks/constants.295fc0ab.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.a504a440.js";import"./chunks/arabica_versions.1930378b.js";const b="/docs-preview/pr-1680/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),f=e("td",null,"Chain ID",-1),m=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),E=e("td",null,"Genesis file",-1),v=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(l,i,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[f,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),m,e("tr",null,[E,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,v)])]),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 Hardfork 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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        `,35),B=JSON.parse('{"title":"Arabica devnet","description":"A guide to Arabica devnet.","frontmatter":{"description":"A guide to Arabica devnet.","head":[["meta",{"name":"og:title","content":"Arabica devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/arabica-devnet.md","filePath":"nodes/arabica-devnet.md","lastUpdated":1724867275000}'),T={name:"nodes/arabica-devnet.md"},L=Object.assign(T,{setup(l){return(i,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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        `,35),B=JSON.parse('{"title":"Arabica devnet","description":"A guide to Arabica devnet.","frontmatter":{"description":"A guide to Arabica devnet.","head":[["meta",{"name":"og:title","content":"Arabica devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/arabica-devnet.md","filePath":"nodes/arabica-devnet.md","lastUpdated":1725955670000}'),T={name:"nodes/arabica-devnet.md"},L=Object.assign(T,{setup(l){return(i,c)=>(o(),r("div",null,[D,s(A),F,s(d),P]))}});export{B as __pageData,L as default}; diff --git a/pr-1680/assets/nodes_arabica-devnet.md.1e272478.lean.js b/pr-1680/assets/nodes_arabica-devnet.md.c4919f1d.lean.js similarity index 85% rename from pr-1680/assets/nodes_arabica-devnet.md.1e272478.lean.js rename to pr-1680/assets/nodes_arabica-devnet.md.c4919f1d.lean.js index bc97575c80..f936333857 100644 --- a/pr-1680/assets/nodes_arabica-devnet.md.1e272478.lean.js +++ b/pr-1680/assets/nodes_arabica-devnet.md.c4919f1d.lean.js @@ -1 +1 @@ -import{A as d}from"./chunks/ArabicaVersionTags.e01dd824.js";import{c as p}from"./chunks/constants.0e6df566.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.a504a440.js";import"./chunks/arabica_versions.6d89be6e.js";const b="/docs-preview/pr-1680/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),f=e("td",null,"Chain ID",-1),m=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),E=e("td",null,"Genesis file",-1),v=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(l,i,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[f,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),m,e("tr",null,[E,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,v)])]),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",{"name":"og:title","content":"Arabica devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/arabica-devnet.md","filePath":"nodes/arabica-devnet.md","lastUpdated":1724867275000}'),T={name:"nodes/arabica-devnet.md"},L=Object.assign(T,{setup(l){return(i,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.20a10f87.js";import{c as p}from"./chunks/constants.295fc0ab.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.a504a440.js";import"./chunks/arabica_versions.1930378b.js";const b="/docs-preview/pr-1680/img/arabica-devnet.png",g={name:"ArabicaDevnetDetails",data(){return{constants:p}}},y=e("tr",null,[e("th",null,"Detail"),e("th",null,"Value")],-1),f=e("td",null,"Chain ID",-1),m=e("tr",null,[e("td",null,"Genesis hash"),e("td",null,[e("code",null,"27122593765E07329BC348E8D16E92DCB4C75B34CCCB35C640FD7A4484D4C711")])],-1),E=e("td",null,"Genesis file",-1),v=["href"],k=e("td",null,"Peers file",-1),w=["href"],_=e("tr",null,[e("td",null,"Validators"),e("td",null," 4 ")],-1);function C(l,i,c,q,t,x){return o(),r("table",null,[y,e("tr",null,[f,e("td",null,[e("code",null,a(t.constants.arabicaChainId),1)])]),m,e("tr",null,[E,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,v)])]),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",{"name":"og:title","content":"Arabica devnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/arabica-devnet.md","filePath":"nodes/arabica-devnet.md","lastUpdated":1725955670000}'),T={name:"nodes/arabica-devnet.md"},L=Object.assign(T,{setup(l){return(i,c)=>(o(),r("div",null,[D,s(A),F,s(d),P]))}});export{B as __pageData,L as default}; diff --git a/pr-1680/assets/nodes_bridge-node.md.a669cc48.js b/pr-1680/assets/nodes_bridge-node.md.74cb097b.js similarity index 93% rename from pr-1680/assets/nodes_bridge-node.md.a669cc48.js rename to pr-1680/assets/nodes_bridge-node.md.74cb097b.js index 3146f5c38f..2ef1b29603 100644 --- a/pr-1680/assets/nodes_bridge-node.md.a669cc48.js +++ b/pr-1680/assets/nodes_bridge-node.md.74cb097b.js @@ -1,7 +1,7 @@ -import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/bridge-node.md","filePath":"nodes/bridge-node.md","lastUpdated":1724867275000}'),l={name:"nodes/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: 10 TB SSD 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.a504a440.js";const n="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/bridge-node.md","filePath":"nodes/bridge-node.md","lastUpdated":1725955670000}'),l={name:"nodes/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: 10 TB SSD 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: 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.

        `,50),p=[t];function r(c,i,d,y,E,h){return e(),a("div",null,p)}const F=s(l,[["render",r]]);export{u as __pageData,F 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,E,h){return e(),a("div",null,p)}const b=s(l,[["render",r]]);export{u as __pageData,b as default}; diff --git a/pr-1680/assets/nodes_bridge-node.md.a669cc48.lean.js b/pr-1680/assets/nodes_bridge-node.md.74cb097b.lean.js similarity index 73% rename from pr-1680/assets/nodes_bridge-node.md.a669cc48.lean.js rename to pr-1680/assets/nodes_bridge-node.md.74cb097b.lean.js index 9b4b59fab3..df37ba5630 100644 --- a/pr-1680/assets/nodes_bridge-node.md.a669cc48.lean.js +++ b/pr-1680/assets/nodes_bridge-node.md.74cb097b.lean.js @@ -1 +1 @@ -import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/bridge-node.md","filePath":"nodes/bridge-node.md","lastUpdated":1724867275000}'),l={name:"nodes/bridge-node.md"},t=o("",50),p=[t];function r(c,i,d,y,E,h){return e(),a("div",null,p)}const F=s(l,[["render",r]]);export{u as __pageData,F as default}; +import{_ as s,o as e,c as a,Q as o}from"./chunks/framework.a504a440.js";const n="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia bridge node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/bridge-node.md","filePath":"nodes/bridge-node.md","lastUpdated":1725955670000}'),l={name:"nodes/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}; diff --git a/pr-1680/assets/nodes_celestia-app-commands.md.da9e2012.js b/pr-1680/assets/nodes_celestia-app-commands.md.c7ad4df8.js similarity index 99% rename from pr-1680/assets/nodes_celestia-app-commands.md.da9e2012.js rename to pr-1680/assets/nodes_celestia-app-commands.md.c7ad4df8.js index 73d4d9da88..48e1f5527b 100644 --- a/pr-1680/assets/nodes_celestia-app-commands.md.da9e2012.js +++ b/pr-1680/assets/nodes_celestia-app-commands.md.c7ad4df8.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.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.","next":{"text":"SystemD","link":"/nodes/systemd"},"head":[["meta",{"name":"og:title","content":"Helpful CLI commands | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-commands.md","filePath":"nodes/celestia-app-commands.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.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.","next":{"text":"SystemD","link":"/nodes/systemd"},"head":[["meta",{"name":"og:title","content":"Helpful CLI commands | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-commands.md","filePath":"nodes/celestia-app-commands.md","lastUpdated":1725955670000}'),p={name:"nodes/celestia-app-commands.md"},o=l(`

        Helpful CLI commands

        View all options:

        console
        $ celestia-appd --help
         Start celestia-app
         
         Usage:
        diff --git a/pr-1680/assets/nodes_celestia-app-commands.md.da9e2012.lean.js b/pr-1680/assets/nodes_celestia-app-commands.md.c7ad4df8.lean.js
        similarity index 91%
        rename from pr-1680/assets/nodes_celestia-app-commands.md.da9e2012.lean.js
        rename to pr-1680/assets/nodes_celestia-app-commands.md.c7ad4df8.lean.js
        index 09e1826518..8de64da976 100644
        --- a/pr-1680/assets/nodes_celestia-app-commands.md.da9e2012.lean.js
        +++ b/pr-1680/assets/nodes_celestia-app-commands.md.c7ad4df8.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.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.","next":{"text":"SystemD","link":"/nodes/systemd"},"head":[["meta",{"name":"og:title","content":"Helpful CLI commands | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-commands.md","filePath":"nodes/celestia-app-commands.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.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.","next":{"text":"SystemD","link":"/nodes/systemd"},"head":[["meta",{"name":"og:title","content":"Helpful CLI commands | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-commands.md","filePath":"nodes/celestia-app-commands.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_celestia-app-metrics.md.1d5a64b1.js b/pr-1680/assets/nodes_celestia-app-metrics.md.29cc5cc2.js
        similarity index 99%
        rename from pr-1680/assets/nodes_celestia-app-metrics.md.1d5a64b1.js
        rename to pr-1680/assets/nodes_celestia-app-metrics.md.29cc5cc2.js
        index 5a58ceb97a..649b9a221e 100644
        --- a/pr-1680/assets/nodes_celestia-app-metrics.md.1d5a64b1.js
        +++ b/pr-1680/assets/nodes_celestia-app-metrics.md.29cc5cc2.js
        @@ -1,4 +1,4 @@
        -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.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":"/nodes/celestia-node-troubleshooting"},"head":[["meta",{"name":"og:title","content":"Metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-metrics.md","filePath":"nodes/celestia-app-metrics.md","lastUpdated":1724867275000}'),o={name:"nodes/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.a504a440.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":"/nodes/celestia-node-troubleshooting"},"head":[["meta",{"name":"og:title","content":"Metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-metrics.md","filePath":"nodes/celestia-app-metrics.md","lastUpdated":1725955670000}'),o={name:"nodes/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-1680/assets/nodes_celestia-app-metrics.md.1d5a64b1.lean.js b/pr-1680/assets/nodes_celestia-app-metrics.md.29cc5cc2.lean.js
        similarity index 92%
        rename from pr-1680/assets/nodes_celestia-app-metrics.md.1d5a64b1.lean.js
        rename to pr-1680/assets/nodes_celestia-app-metrics.md.29cc5cc2.lean.js
        index bb2ab7cae1..86606db7cb 100644
        --- a/pr-1680/assets/nodes_celestia-app-metrics.md.1d5a64b1.lean.js
        +++ b/pr-1680/assets/nodes_celestia-app-metrics.md.29cc5cc2.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as e}from"./chunks/framework.a504a440.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":"/nodes/celestia-node-troubleshooting"},"head":[["meta",{"name":"og:title","content":"Metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-metrics.md","filePath":"nodes/celestia-app-metrics.md","lastUpdated":1724867275000}'),o={name:"nodes/celestia-app-metrics.md"},l=e("",27),t=[l];function p(r,c,i,y,u,h){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.a504a440.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":"/nodes/celestia-node-troubleshooting"},"head":[["meta",{"name":"og:title","content":"Metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-metrics.md","filePath":"nodes/celestia-app-metrics.md","lastUpdated":1725955670000}'),o={name:"nodes/celestia-app-metrics.md"},l=e("",27),t=[l];function p(r,c,i,y,u,h){return a(),n("div",null,t)}const E=s(o,[["render",p]]);export{m as __pageData,E as default};
        diff --git a/pr-1680/assets/nodes_celestia-app-multisig.md.9965f0f0.js b/pr-1680/assets/nodes_celestia-app-multisig.md.ddb08823.js
        similarity index 99%
        rename from pr-1680/assets/nodes_celestia-app-multisig.md.9965f0f0.js
        rename to pr-1680/assets/nodes_celestia-app-multisig.md.ddb08823.js
        index a52e96d4d2..72bfa7fdce 100644
        --- a/pr-1680/assets/nodes_celestia-app-multisig.md.9965f0f0.js
        +++ b/pr-1680/assets/nodes_celestia-app-multisig.md.ddb08823.js
        @@ -1,4 +1,4 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Multisig | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-multisig.md","filePath":"nodes/celestia-app-multisig.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Multisig | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-multisig.md","filePath":"nodes/celestia-app-multisig.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_celestia-app-multisig.md.9965f0f0.lean.js b/pr-1680/assets/nodes_celestia-app-multisig.md.ddb08823.lean.js
        similarity index 88%
        rename from pr-1680/assets/nodes_celestia-app-multisig.md.9965f0f0.lean.js
        rename to pr-1680/assets/nodes_celestia-app-multisig.md.ddb08823.lean.js
        index 0fdb5c3bd4..087b1fde2e 100644
        --- a/pr-1680/assets/nodes_celestia-app-multisig.md.9965f0f0.lean.js
        +++ b/pr-1680/assets/nodes_celestia-app-multisig.md.ddb08823.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Multisig | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-multisig.md","filePath":"nodes/celestia-app-multisig.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.js";const d=JSON.parse('{"title":"Multisig","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Multisig | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-multisig.md","filePath":"nodes/celestia-app-multisig.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_celestia-app-slashing.md.90798e11.js b/pr-1680/assets/nodes_celestia-app-slashing.md.f566e698.js
        similarity index 97%
        rename from pr-1680/assets/nodes_celestia-app-slashing.md.90798e11.js
        rename to pr-1680/assets/nodes_celestia-app-slashing.md.f566e698.js
        index daa96e34bf..b8901995a5 100644
        --- a/pr-1680/assets/nodes_celestia-app-slashing.md.90798e11.js
        +++ b/pr-1680/assets/nodes_celestia-app-slashing.md.f566e698.js
        @@ -1 +1 @@
        -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Jailing and Slashing on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-slashing.md","filePath":"nodes/celestia-app-slashing.md","lastUpdated":1724867275000}'),o={name:"nodes/celestia-app-slashing.md"},s=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=[s];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(o,[["render",l]]);export{f as __pageData,u as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Jailing and Slashing on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-slashing.md","filePath":"nodes/celestia-app-slashing.md","lastUpdated":1725955670000}'),o={name:"nodes/celestia-app-slashing.md"},s=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=[s];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(o,[["render",l]]);export{f as __pageData,u as default}; diff --git a/pr-1680/assets/nodes_celestia-app-slashing.md.90798e11.lean.js b/pr-1680/assets/nodes_celestia-app-slashing.md.f566e698.lean.js similarity index 92% rename from pr-1680/assets/nodes_celestia-app-slashing.md.90798e11.lean.js rename to pr-1680/assets/nodes_celestia-app-slashing.md.f566e698.lean.js index 2c05fde74d..b6375bb085 100644 --- a/pr-1680/assets/nodes_celestia-app-slashing.md.90798e11.lean.js +++ b/pr-1680/assets/nodes_celestia-app-slashing.md.f566e698.lean.js @@ -1 +1 @@ -import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Jailing and Slashing on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-slashing.md","filePath":"nodes/celestia-app-slashing.md","lastUpdated":1724867275000}'),o={name:"nodes/celestia-app-slashing.md"},s=i("",7),n=[s];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(o,[["render",l]]);export{f as __pageData,u as default}; +import{_ as e,o as a,c as t,Q as i}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Jailing and Slashing on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-slashing.md","filePath":"nodes/celestia-app-slashing.md","lastUpdated":1725955670000}'),o={name:"nodes/celestia-app-slashing.md"},s=i("",7),n=[s];function l(r,d,h,c,p,g){return a(),t("div",null,n)}const u=e(o,[["render",l]]);export{f as __pageData,u as default}; diff --git a/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.a7f594fd.js b/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.7f8357e1.js similarity index 89% rename from pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.a7f594fd.js rename to pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.7f8357e1.js index 087a3eabf5..5d2b61fbfd 100644 --- a/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.a7f594fd.js +++ b/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.7f8357e1.js @@ -1 +1 @@ -import{_ as o,o as a,c as r,k as e,a as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Upgrade Monitor | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-upgrade-monitor.md","filePath":"nodes/celestia-app-upgrade-monitor.md","lastUpdated":1724867275000}'),n={name:"nodes/celestia-app-upgrade-monitor.md"},s=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),i=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),d=[s,i];function p(c,l,m,g,u,h){return a(),r("div",null,d)}const k=o(n,[["render",p]]);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.a504a440.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",{"name":"og:title","content":"Upgrade Monitor | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-upgrade-monitor.md","filePath":"nodes/celestia-app-upgrade-monitor.md","lastUpdated":1725955670000}'),n={name:"nodes/celestia-app-upgrade-monitor.md"},s=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),i=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),d=[s,i];function p(c,l,m,g,u,h){return a(),r("div",null,d)}const k=o(n,[["render",p]]);export{f as __pageData,k as default}; diff --git a/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.a7f594fd.lean.js b/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.7f8357e1.lean.js similarity index 89% rename from pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.a7f594fd.lean.js rename to pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.7f8357e1.lean.js index 087a3eabf5..5d2b61fbfd 100644 --- a/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.a7f594fd.lean.js +++ b/pr-1680/assets/nodes_celestia-app-upgrade-monitor.md.7f8357e1.lean.js @@ -1 +1 @@ -import{_ as o,o as a,c as r,k as e,a as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Upgrade Monitor | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-upgrade-monitor.md","filePath":"nodes/celestia-app-upgrade-monitor.md","lastUpdated":1724867275000}'),n={name:"nodes/celestia-app-upgrade-monitor.md"},s=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),i=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),d=[s,i];function p(c,l,m,g,u,h){return a(),r("div",null,d)}const k=o(n,[["render",p]]);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.a504a440.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",{"name":"og:title","content":"Upgrade Monitor | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-upgrade-monitor.md","filePath":"nodes/celestia-app-upgrade-monitor.md","lastUpdated":1725955670000}'),n={name:"nodes/celestia-app-upgrade-monitor.md"},s=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),i=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),d=[s,i];function p(c,l,m,g,u,h){return a(),r("div",null,d)}const k=o(n,[["render",p]]);export{f as __pageData,k as default}; diff --git a/pr-1680/assets/nodes_celestia-app-vesting.md.f93598b1.js b/pr-1680/assets/nodes_celestia-app-vesting.md.dd0ddeb3.js similarity index 99% rename from pr-1680/assets/nodes_celestia-app-vesting.md.f93598b1.js rename to pr-1680/assets/nodes_celestia-app-vesting.md.dd0ddeb3.js index e994482ec9..4b7f2ee9f6 100644 --- a/pr-1680/assets/nodes_celestia-app-vesting.md.f93598b1.js +++ b/pr-1680/assets/nodes_celestia-app-vesting.md.dd0ddeb3.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-vesting.md","filePath":"nodes/celestia-app-vesting.md","lastUpdated":1724867275000}'),l={name:"nodes/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.a504a440.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",{"name":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-vesting.md","filePath":"nodes/celestia-app-vesting.md","lastUpdated":1725955670000}'),l={name:"nodes/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-1680/assets/nodes_celestia-app-vesting.md.f93598b1.lean.js b/pr-1680/assets/nodes_celestia-app-vesting.md.dd0ddeb3.lean.js
        similarity index 91%
        rename from pr-1680/assets/nodes_celestia-app-vesting.md.f93598b1.lean.js
        rename to pr-1680/assets/nodes_celestia-app-vesting.md.dd0ddeb3.lean.js
        index ef6773a435..f2a21a7385 100644
        --- a/pr-1680/assets/nodes_celestia-app-vesting.md.f93598b1.lean.js
        +++ b/pr-1680/assets/nodes_celestia-app-vesting.md.dd0ddeb3.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-vesting.md","filePath":"nodes/celestia-app-vesting.md","lastUpdated":1724867275000}'),l={name:"nodes/celestia-app-vesting.md"},p=o("",98),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.a504a440.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",{"name":"og:title","content":"How to create a vesting account with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-vesting.md","filePath":"nodes/celestia-app-vesting.md","lastUpdated":1725955670000}'),l={name:"nodes/celestia-app-vesting.md"},p=o("",98),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-1680/assets/nodes_celestia-app-wallet.md.3b09d1dc.js b/pr-1680/assets/nodes_celestia-app-wallet.md.634f19b0.js
        similarity index 99%
        rename from pr-1680/assets/nodes_celestia-app-wallet.md.3b09d1dc.js
        rename to pr-1680/assets/nodes_celestia-app-wallet.md.634f19b0.js
        index 3e39694def..b5a1b3c6de 100644
        --- a/pr-1680/assets/nodes_celestia-app-wallet.md.3b09d1dc.js
        +++ b/pr-1680/assets/nodes_celestia-app-wallet.md.634f19b0.js
        @@ -1,3 +1,3 @@
        -import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-wallet.md","filePath":"nodes/celestia-app-wallet.md","lastUpdated":1724867275000}'),l={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-wallet.md","filePath":"nodes/celestia-app-wallet.md","lastUpdated":1725955670000}'),l={name:"nodes/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),n=[o];function p(c,r,i,x,d,h){return e(),s("div",null,n)}const E=a(l,[["render",p]]);export{u as __pageData,E as default}; diff --git a/pr-1680/assets/nodes_celestia-app-wallet.md.3b09d1dc.lean.js b/pr-1680/assets/nodes_celestia-app-wallet.md.634f19b0.lean.js similarity index 91% rename from pr-1680/assets/nodes_celestia-app-wallet.md.3b09d1dc.lean.js rename to pr-1680/assets/nodes_celestia-app-wallet.md.634f19b0.lean.js index 966b012ccd..8acc07d758 100644 --- a/pr-1680/assets/nodes_celestia-app-wallet.md.3b09d1dc.lean.js +++ b/pr-1680/assets/nodes_celestia-app-wallet.md.634f19b0.lean.js @@ -1 +1 @@ -import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-wallet.md","filePath":"nodes/celestia-app-wallet.md","lastUpdated":1724867275000}'),l={name:"nodes/celestia-app-wallet.md"},o=t("",19),n=[o];function p(c,r,i,x,d,h){return e(),s("div",null,n)}const E=a(l,[["render",p]]);export{u as __pageData,E as default}; +import{_ as a,o as e,c as s,Q as t}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Create a wallet with celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app-wallet.md","filePath":"nodes/celestia-app-wallet.md","lastUpdated":1725955670000}'),l={name:"nodes/celestia-app-wallet.md"},o=t("",19),n=[o];function p(c,r,i,x,d,h){return e(),s("div",null,n)}const E=a(l,[["render",p]]);export{u as __pageData,E as default}; diff --git a/pr-1680/assets/nodes_celestia-app.md.4ff1b2af.js b/pr-1680/assets/nodes_celestia-app.md.4ff1b2af.js deleted file mode 100644 index 859b45a949..0000000000 --- a/pr-1680/assets/nodes_celestia-app.md.4ff1b2af.js +++ /dev/null @@ -1,7 +0,0 @@ -import{a as o}from"./chunks/arabica_versions.6d89be6e.js";import{m as l}from"./chunks/mocha_versions.ffd4ea25.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as p,c,k as s,t,l as e,Q as a}from"./chunks/framework.a504a440.js";const i=a('

        Install celestia-app

        This tutorial will guide you through installing celestia-app, both from source and with a pre-built binary

        Building binary from source

        This section of the tutorial presumes you completed the steps in setting up your own environment.

        The steps below will create a binary file named celestia-appd inside $HOME/go/bin folder which will be used later to run the node. Be sure to select the correct network to install the binary for.

        ',5),r=a(`
      22. Remove any existing copy of celestia-app, clone the repository, and change into the directory:

        bash
        cd $HOME
        -rm -rf celestia-app
        -git clone https://github.com/celestiaorg/celestia-app.git
        -cd celestia-app
        cd $HOME
        -rm -rf celestia-app
        -git clone https://github.com/celestiaorg/celestia-app.git
        -cd celestia-app
      23. `,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),y={class:"blocks"},u={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"},F={class:"line"},m=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=s("span",{style:{color:"#E1E4E8"}}," ",-1),T=s("span",{style:{color:"#79B8FF"}},"-b",-1),w=s("span",{style:{color:"#E1E4E8"}}," ",-1),P={style:{color:"#9ECBFF"}},A={class:"shiki github-light vp-code-light"},I={class:"line"},S=s("span",{style:{color:"#6F42C1"}},"git",-1),q=s("span",{style:{color:"#24292E"}}," ",-1),V=s("span",{style:{color:"#032F62"}},"checkout",-1),x=s("span",{style:{color:"#24292E"}}," ",-1),D={style:{color:"#032F62"}},L=s("span",{style:{color:"#24292E"}}," ",-1),M=s("span",{style:{color:"#005CC5"}},"-b",-1),N=s("span",{style:{color:"#24292E"}}," ",-1),R={style:{color:"#032F62"}},O={class:"language-bash vp-adaptive-theme"},z=s("button",{title:"Copy Code",class:"copy"},null,-1),$=s("span",{class:"lang"},"bash",-1),H={class:"shiki github-dark vp-code-dark"},W={class:"line"},U=s("span",{style:{color:"#B392F0"}},"git",-1),Z=s("span",{style:{color:"#E1E4E8"}}," ",-1),j=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),J={style:{color:"#9ECBFF"}},Q=s("span",{style:{color:"#E1E4E8"}}," ",-1),G=s("span",{style:{color:"#79B8FF"}},"-b",-1),K=s("span",{style:{color:"#E1E4E8"}}," ",-1),X={style:{color:"#9ECBFF"}},ss={class:"shiki github-light vp-code-light"},ts={class:"line"},es=s("span",{style:{color:"#6F42C1"}},"git",-1),as=s("span",{style:{color:"#24292E"}}," ",-1),os=s("span",{style:{color:"#032F62"}},"checkout",-1),ls=s("span",{style:{color:"#24292E"}}," ",-1),ns={style:{color:"#032F62"}},ps=s("span",{style:{color:"#24292E"}}," ",-1),cs=s("span",{style:{color:"#005CC5"}},"-b",-1),is=s("span",{style:{color:"#24292E"}}," ",-1),rs={style:{color:"#032F62"}},ds={class:"language-bash vp-adaptive-theme"},hs=s("button",{title:"Copy Code",class:"copy"},null,-1),_s=s("span",{class:"lang"},"bash",-1),ys={class:"shiki github-dark vp-code-dark"},us={class:"line"},bs=s("span",{style:{color:"#B392F0"}},"git",-1),gs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Es=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),Fs=s("span",{style:{color:"#E1E4E8"}}," ",-1),ms={style:{color:"#9ECBFF"}},Cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),vs=s("span",{style:{color:"#79B8FF"}},"-b",-1),fs=s("span",{style:{color:"#E1E4E8"}}," ",-1),ks={style:{color:"#9ECBFF"}},Bs={class:"shiki github-light vp-code-light"},Ts={class:"line"},ws=s("span",{style:{color:"#6F42C1"}},"git",-1),Ps=s("span",{style:{color:"#24292E"}}," ",-1),As=s("span",{style:{color:"#032F62"}},"checkout",-1),Is=s("span",{style:{color:"#24292E"}}," ",-1),Ss={style:{color:"#032F62"}},qs=s("span",{style:{color:"#24292E"}}," ",-1),Vs=s("span",{style:{color:"#005CC5"}},"-b",-1),xs=s("span",{style:{color:"#24292E"}}," ",-1),Ds={style:{color:"#032F62"}},Ls=a('
      24. Build and install the celestia-appd binary:

        bash
        make install
        make install
      25. To check if the binary was successfully installed you can run the binary using the --help flag:

        sh
        celestia-appd --help
        celestia-appd --help
      26. ',2),Ms=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),Zs=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",{"name":"og:title","content":"Install celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app.md","filePath":"nodes/celestia-app.md","lastUpdated":1724867275000}'),Ns={name:"nodes/celestia-app.md"},js=Object.assign(Ns,{setup(Rs){return(Os,zs)=>(p(),c("div",null,[i,s("ol",null,[r,s("li",null,[d,s("div",h,[_,s("div",y,[s("div",u,[b,g,s("pre",E,[s("code",null,[s("span",F,[m,C,v,f,s("span",k,"tags/"+t(e(n)["app-latest-tag"]),1),B,T,w,s("span",P,t(e(n)["app-latest-tag"]),1)])])]),s("pre",A,[s("code",null,[s("span",I,[S,q,V,x,s("span",D,"tags/"+t(e(n)["app-latest-tag"]),1),L,M,N,s("span",R,t(e(n)["app-latest-tag"]),1)])])])]),s("div",O,[z,$,s("pre",H,[s("code",null,[s("span",W,[U,Z,j,Y,s("span",J,"tags/"+t(e(l)["app-latest-tag"]),1),Q,G,K,s("span",X,t(e(l)["app-latest-tag"]),1)])])]),s("pre",ss,[s("code",null,[s("span",ts,[es,as,os,ls,s("span",ns,"tags/"+t(e(l)["app-latest-tag"]),1),ps,cs,is,s("span",rs,t(e(l)["app-latest-tag"]),1)])])])]),s("div",ds,[hs,_s,s("pre",ys,[s("code",null,[s("span",us,[bs,gs,Es,Fs,s("span",ms,"tags/"+t(e(o)["app-latest-tag"]),1),Cs,vs,fs,s("span",ks,t(e(o)["app-latest-tag"]),1)])])]),s("pre",Bs,[s("code",null,[s("span",Ts,[ws,Ps,As,Is,s("span",Ss,"tags/"+t(e(o)["app-latest-tag"]),1),qs,Vs,xs,s("span",Ds,t(e(o)["app-latest-tag"]),1)])])])])])])]),Ls]),Ms]))}});export{Zs as __pageData,js as default}; diff --git a/pr-1680/assets/nodes_celestia-app.md.4ff1b2af.lean.js b/pr-1680/assets/nodes_celestia-app.md.4ff1b2af.lean.js deleted file mode 100644 index e5fe139263..0000000000 --- a/pr-1680/assets/nodes_celestia-app.md.4ff1b2af.lean.js +++ /dev/null @@ -1 +0,0 @@ -import{a as o}from"./chunks/arabica_versions.6d89be6e.js";import{m as l}from"./chunks/mocha_versions.ffd4ea25.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as p,c,k as s,t,l as e,Q as a}from"./chunks/framework.a504a440.js";const i=a("",5),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),y={class:"blocks"},u={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"},F={class:"line"},m=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=s("span",{style:{color:"#E1E4E8"}}," ",-1),T=s("span",{style:{color:"#79B8FF"}},"-b",-1),w=s("span",{style:{color:"#E1E4E8"}}," ",-1),P={style:{color:"#9ECBFF"}},A={class:"shiki github-light vp-code-light"},I={class:"line"},S=s("span",{style:{color:"#6F42C1"}},"git",-1),q=s("span",{style:{color:"#24292E"}}," ",-1),V=s("span",{style:{color:"#032F62"}},"checkout",-1),x=s("span",{style:{color:"#24292E"}}," ",-1),D={style:{color:"#032F62"}},L=s("span",{style:{color:"#24292E"}}," ",-1),M=s("span",{style:{color:"#005CC5"}},"-b",-1),N=s("span",{style:{color:"#24292E"}}," ",-1),R={style:{color:"#032F62"}},O={class:"language-bash vp-adaptive-theme"},z=s("button",{title:"Copy Code",class:"copy"},null,-1),$=s("span",{class:"lang"},"bash",-1),H={class:"shiki github-dark vp-code-dark"},W={class:"line"},U=s("span",{style:{color:"#B392F0"}},"git",-1),Z=s("span",{style:{color:"#E1E4E8"}}," ",-1),j=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),J={style:{color:"#9ECBFF"}},Q=s("span",{style:{color:"#E1E4E8"}}," ",-1),G=s("span",{style:{color:"#79B8FF"}},"-b",-1),K=s("span",{style:{color:"#E1E4E8"}}," ",-1),X={style:{color:"#9ECBFF"}},ss={class:"shiki github-light vp-code-light"},ts={class:"line"},es=s("span",{style:{color:"#6F42C1"}},"git",-1),as=s("span",{style:{color:"#24292E"}}," ",-1),os=s("span",{style:{color:"#032F62"}},"checkout",-1),ls=s("span",{style:{color:"#24292E"}}," ",-1),ns={style:{color:"#032F62"}},ps=s("span",{style:{color:"#24292E"}}," ",-1),cs=s("span",{style:{color:"#005CC5"}},"-b",-1),is=s("span",{style:{color:"#24292E"}}," ",-1),rs={style:{color:"#032F62"}},ds={class:"language-bash vp-adaptive-theme"},hs=s("button",{title:"Copy Code",class:"copy"},null,-1),_s=s("span",{class:"lang"},"bash",-1),ys={class:"shiki github-dark vp-code-dark"},us={class:"line"},bs=s("span",{style:{color:"#B392F0"}},"git",-1),gs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Es=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),Fs=s("span",{style:{color:"#E1E4E8"}}," ",-1),ms={style:{color:"#9ECBFF"}},Cs=s("span",{style:{color:"#E1E4E8"}}," ",-1),vs=s("span",{style:{color:"#79B8FF"}},"-b",-1),fs=s("span",{style:{color:"#E1E4E8"}}," ",-1),ks={style:{color:"#9ECBFF"}},Bs={class:"shiki github-light vp-code-light"},Ts={class:"line"},ws=s("span",{style:{color:"#6F42C1"}},"git",-1),Ps=s("span",{style:{color:"#24292E"}}," ",-1),As=s("span",{style:{color:"#032F62"}},"checkout",-1),Is=s("span",{style:{color:"#24292E"}}," ",-1),Ss={style:{color:"#032F62"}},qs=s("span",{style:{color:"#24292E"}}," ",-1),Vs=s("span",{style:{color:"#005CC5"}},"-b",-1),xs=s("span",{style:{color:"#24292E"}}," ",-1),Ds={style:{color:"#032F62"}},Ls=a("",2),Ms=a("",18),Zs=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",{"name":"og:title","content":"Install celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app.md","filePath":"nodes/celestia-app.md","lastUpdated":1724867275000}'),Ns={name:"nodes/celestia-app.md"},js=Object.assign(Ns,{setup(Rs){return(Os,zs)=>(p(),c("div",null,[i,s("ol",null,[r,s("li",null,[d,s("div",h,[_,s("div",y,[s("div",u,[b,g,s("pre",E,[s("code",null,[s("span",F,[m,C,v,f,s("span",k,"tags/"+t(e(n)["app-latest-tag"]),1),B,T,w,s("span",P,t(e(n)["app-latest-tag"]),1)])])]),s("pre",A,[s("code",null,[s("span",I,[S,q,V,x,s("span",D,"tags/"+t(e(n)["app-latest-tag"]),1),L,M,N,s("span",R,t(e(n)["app-latest-tag"]),1)])])])]),s("div",O,[z,$,s("pre",H,[s("code",null,[s("span",W,[U,Z,j,Y,s("span",J,"tags/"+t(e(l)["app-latest-tag"]),1),Q,G,K,s("span",X,t(e(l)["app-latest-tag"]),1)])])]),s("pre",ss,[s("code",null,[s("span",ts,[es,as,os,ls,s("span",ns,"tags/"+t(e(l)["app-latest-tag"]),1),ps,cs,is,s("span",rs,t(e(l)["app-latest-tag"]),1)])])])]),s("div",ds,[hs,_s,s("pre",ys,[s("code",null,[s("span",us,[bs,gs,Es,Fs,s("span",ms,"tags/"+t(e(o)["app-latest-tag"]),1),Cs,vs,fs,s("span",ks,t(e(o)["app-latest-tag"]),1)])])]),s("pre",Bs,[s("code",null,[s("span",Ts,[ws,Ps,As,Is,s("span",Ss,"tags/"+t(e(o)["app-latest-tag"]),1),qs,Vs,xs,s("span",Ds,t(e(o)["app-latest-tag"]),1)])])])])])])]),Ls]),Ms]))}});export{Zs as __pageData,js as default}; diff --git a/pr-1680/assets/nodes_celestia-app.md.e40766f7.js b/pr-1680/assets/nodes_celestia-app.md.e40766f7.js new file mode 100644 index 0000000000..3d81bef470 --- /dev/null +++ b/pr-1680/assets/nodes_celestia-app.md.e40766f7.js @@ -0,0 +1,7 @@ +import{a as o}from"./chunks/arabica_versions.1930378b.js";import{m as l}from"./chunks/mocha_versions.7704b055.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as p,c,k as s,t as e,l as t,Q as a}from"./chunks/framework.a504a440.js";const i=a('

        Install celestia-app

        This tutorial will guide you through installing celestia-app, both from source and with a pre-built binary

        Building binary from source

        This section of the tutorial presumes you completed the steps in setting up your own environment.

        The steps below will create a binary file named celestia-appd inside $HOME/go/bin folder which will be used later to run the node. Be sure to select the correct network to install the binary for.

        ',5),r=a(`
      27. Remove any existing copy of celestia-app, clone the repository, and change into the directory:

        bash
        cd $HOME
        +rm -rf celestia-app
        +git clone https://github.com/celestiaorg/celestia-app.git
        +cd celestia-app
        cd $HOME
        +rm -rf celestia-app
        +git clone https://github.com/celestiaorg/celestia-app.git
        +cd celestia-app
      28. `,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"}},T={class:"shiki github-light vp-code-light"},B={class:"line"},w=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),A=s("span",{style:{color:"#032F62"}},"checkout",-1),I=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),x=s("span",{class:"lang"},"bash",-1),D={class:"shiki github-dark vp-code-dark"},N={class:"line"},L=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),O=s("span",{style:{color:"#E1E4E8"}}," ",-1),Z={style:{color:"#9ECBFF"}},Y={class:"shiki github-light vp-code-light"},$={class:"line"},H=s("span",{style:{color:"#6F42C1"}},"git",-1),Q=s("span",{style:{color:"#24292E"}}," ",-1),J=s("span",{style:{color:"#032F62"}},"checkout",-1),z=s("span",{style:{color:"#24292E"}}," ",-1),U={style:{color:"#032F62"}},X={class:"language-bash vp-adaptive-theme"},j=s("button",{title:"Copy Code",class:"copy"},null,-1),W=s("span",{class:"lang"},"bash",-1),G={class:"shiki github-dark vp-code-dark"},K={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),cs=s("span",{style:{color:"#24292E"}}," ",-1),is=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=a('
      29. Build and install the celestia-appd binary:

        bash
        make install
        make install
      30. To check if the binary was successfully installed you can run the binary using the --help flag:

        sh
        celestia-appd --help
        celestia-appd --help
      31. ',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",{"name":"og:title","content":"Install celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app.md","filePath":"nodes/celestia-app.md","lastUpdated":1725955670000}'),us={name:"nodes/celestia-app.md"},fs=Object.assign(us,{setup(ys){return(bs,gs)=>(p(),c("div",null,[i,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",T,[s("code",null,[s("span",B,[w,P,A,I,s("span",S,"tags/"+e(t(n)["app-latest-tag"]),1)])])])]),s("div",V,[q,x,s("pre",D,[s("code",null,[s("span",N,[L,R,M,O,s("span",Z,"tags/"+e(t(l)["app-latest-tag"]),1)])])]),s("pre",Y,[s("code",null,[s("span",$,[H,Q,J,z,s("span",U,"tags/"+e(t(l)["app-latest-tag"]),1)])])])]),s("div",X,[j,W,s("pre",G,[s("code",null,[s("span",K,[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,cs,is,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-1680/assets/nodes_celestia-app.md.e40766f7.lean.js b/pr-1680/assets/nodes_celestia-app.md.e40766f7.lean.js new file mode 100644 index 0000000000..754a4044b0 --- /dev/null +++ b/pr-1680/assets/nodes_celestia-app.md.e40766f7.lean.js @@ -0,0 +1 @@ +import{a as o}from"./chunks/arabica_versions.1930378b.js";import{m as l}from"./chunks/mocha_versions.7704b055.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as p,c,k as s,t as e,l as t,Q as a}from"./chunks/framework.a504a440.js";const i=a("",5),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"}},T={class:"shiki github-light vp-code-light"},B={class:"line"},w=s("span",{style:{color:"#6F42C1"}},"git",-1),P=s("span",{style:{color:"#24292E"}}," ",-1),A=s("span",{style:{color:"#032F62"}},"checkout",-1),I=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),x=s("span",{class:"lang"},"bash",-1),D={class:"shiki github-dark vp-code-dark"},N={class:"line"},L=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),O=s("span",{style:{color:"#E1E4E8"}}," ",-1),Z={style:{color:"#9ECBFF"}},Y={class:"shiki github-light vp-code-light"},$={class:"line"},H=s("span",{style:{color:"#6F42C1"}},"git",-1),Q=s("span",{style:{color:"#24292E"}}," ",-1),J=s("span",{style:{color:"#032F62"}},"checkout",-1),z=s("span",{style:{color:"#24292E"}}," ",-1),U={style:{color:"#032F62"}},X={class:"language-bash vp-adaptive-theme"},j=s("button",{title:"Copy Code",class:"copy"},null,-1),W=s("span",{class:"lang"},"bash",-1),G={class:"shiki github-dark vp-code-dark"},K={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),cs=s("span",{style:{color:"#24292E"}}," ",-1),is=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",{"name":"og:title","content":"Install celestia-app | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-app.md","filePath":"nodes/celestia-app.md","lastUpdated":1725955670000}'),us={name:"nodes/celestia-app.md"},fs=Object.assign(us,{setup(ys){return(bs,gs)=>(p(),c("div",null,[i,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",T,[s("code",null,[s("span",B,[w,P,A,I,s("span",S,"tags/"+e(t(n)["app-latest-tag"]),1)])])])]),s("div",V,[q,x,s("pre",D,[s("code",null,[s("span",N,[L,R,M,O,s("span",Z,"tags/"+e(t(l)["app-latest-tag"]),1)])])]),s("pre",Y,[s("code",null,[s("span",$,[H,Q,J,z,s("span",U,"tags/"+e(t(l)["app-latest-tag"]),1)])])])]),s("div",X,[j,W,s("pre",G,[s("code",null,[s("span",K,[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,cs,is,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-1680/assets/nodes_celestia-node-custom-networks.md.20aba34e.js b/pr-1680/assets/nodes_celestia-node-custom-networks.md.18993406.js similarity index 99% rename from pr-1680/assets/nodes_celestia-node-custom-networks.md.20aba34e.js rename to pr-1680/assets/nodes_celestia-node-custom-networks.md.18993406.js index 24a7b495c6..6b02638055 100644 --- a/pr-1680/assets/nodes_celestia-node-custom-networks.md.20aba34e.js +++ b/pr-1680/assets/nodes_celestia-node-custom-networks.md.18993406.js @@ -1 +1 @@ -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Custom networks and values | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-custom-networks.md","filePath":"nodes/celestia-node-custom-networks.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Custom networks and values | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-custom-networks.md","filePath":"nodes/celestia-node-custom-networks.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_celestia-node-custom-networks.md.20aba34e.lean.js b/pr-1680/assets/nodes_celestia-node-custom-networks.md.18993406.lean.js similarity index 91% rename from pr-1680/assets/nodes_celestia-node-custom-networks.md.20aba34e.lean.js rename to pr-1680/assets/nodes_celestia-node-custom-networks.md.18993406.lean.js index 98fb255d1f..7784ce56ff 100644 --- a/pr-1680/assets/nodes_celestia-node-custom-networks.md.20aba34e.lean.js +++ b/pr-1680/assets/nodes_celestia-node-custom-networks.md.18993406.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as o,Q as n}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Custom networks and values | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-custom-networks.md","filePath":"nodes/celestia-node-custom-networks.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Custom networks and values | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-custom-networks.md","filePath":"nodes/celestia-node-custom-networks.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_celestia-node-metrics.md.216eb211.js b/pr-1680/assets/nodes_celestia-node-metrics.md.ebcb2743.js similarity index 99% rename from pr-1680/assets/nodes_celestia-node-metrics.md.216eb211.js rename to pr-1680/assets/nodes_celestia-node-metrics.md.ebcb2743.js index f9474ca179..4315102b22 100644 --- a/pr-1680/assets/nodes_celestia-node-metrics.md.216eb211.js +++ b/pr-1680/assets/nodes_celestia-node-metrics.md.ebcb2743.js @@ -1,4 +1,4 @@ -import{_ as s,o as n,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"celestia-node metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-metrics.md","filePath":"nodes/celestia-node-metrics.md","lastUpdated":1724867275000}'),l={name:"nodes/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 n,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"celestia-node metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-metrics.md","filePath":"nodes/celestia-node-metrics.md","lastUpdated":1725955670000}'),l={name:"nodes/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-1680/assets/nodes_celestia-node-metrics.md.216eb211.lean.js b/pr-1680/assets/nodes_celestia-node-metrics.md.ebcb2743.lean.js
        similarity index 91%
        rename from pr-1680/assets/nodes_celestia-node-metrics.md.216eb211.lean.js
        rename to pr-1680/assets/nodes_celestia-node-metrics.md.ebcb2743.lean.js
        index d4c63c190b..ebbb9b041b 100644
        --- a/pr-1680/assets/nodes_celestia-node-metrics.md.216eb211.lean.js
        +++ b/pr-1680/assets/nodes_celestia-node-metrics.md.ebcb2743.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as n,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"celestia-node metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-metrics.md","filePath":"nodes/celestia-node-metrics.md","lastUpdated":1724867275000}'),l={name:"nodes/celestia-node-metrics.md"},e=o("",27),p=[e];function t(c,r,y,i,E,d){return n(),a("div",null,p)}const m=s(l,[["render",t]]);export{h as __pageData,m as default};
        +import{_ as s,o as n,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"celestia-node metrics | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-metrics.md","filePath":"nodes/celestia-node-metrics.md","lastUpdated":1725955670000}'),l={name:"nodes/celestia-node-metrics.md"},e=o("",27),p=[e];function t(c,r,y,i,E,d){return n(),a("div",null,p)}const m=s(l,[["render",t]]);export{h as __pageData,m as default};
        diff --git a/pr-1680/assets/nodes_celestia-node-troubleshooting.md.821659c6.js b/pr-1680/assets/nodes_celestia-node-troubleshooting.md.f834eff5.js
        similarity index 99%
        rename from pr-1680/assets/nodes_celestia-node-troubleshooting.md.821659c6.js
        rename to pr-1680/assets/nodes_celestia-node-troubleshooting.md.f834eff5.js
        index a6ac392966..6df35de2f7 100644
        --- a/pr-1680/assets/nodes_celestia-node-troubleshooting.md.821659c6.js
        +++ b/pr-1680/assets/nodes_celestia-node-troubleshooting.md.f834eff5.js
        @@ -1,4 +1,4 @@
        -import{c as n}from"./chunks/constants.0e6df566.js";import{o as p,c as t,k as s,a,t as o,l,Q as e}from"./chunks/framework.a504a440.js";const r=e(`

        Troubleshooting

        Network selection

        Note: If you do not select a network, the default network will be Mainnet Beta.

        sh
        celestia <node-type> init --p2p.network <network>
        +import{c as n}from"./chunks/constants.295fc0ab.js";import{o as p,c as t,k as s,a,t as o,l,Q as e}from"./chunks/framework.a504a440.js";const r=e(`

        Troubleshooting

        Network selection

        Note: If you do not select a network, the default network will be Mainnet Beta.

        sh
        celestia <node-type> init --p2p.network <network>
         celestia <node-type> start --p2p.network <network> --core.ip <URI>
        celestia <node-type> init --p2p.network <network>
         celestia <node-type> start --p2p.network <network> --core.ip <URI>

        TIP

        Refer to the ports section of this page for information on which ports are required to be open on your machine.

        NOTE

        It is advised before switching networks to reinitialize your node via init command. This is due to an old config being present. Re-initialisation will reset the config.

        Chain ID

        `,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(`

        Ports

        When interacting with a Celestia 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 nodes:

        PortProtocolAddressDescriptionEnabled by default on nodeFlag
        2121TCP/UDPlocalhostP2PtrueN/A
        26658HTTPlocalhostRPCtrue--rpc.port string
        26659HTTPlocalhostREST Gatewayfalse--gateway.port string

        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.

        Changing the location of your node store

        Background

        An enhancement has been made in v0.14.0+ to automate the detection of the running node, eliminating the need to manually specify the --node.store flag for each RPC request.

        Assumptions:

        • The presence of a lock signifies a running node.
        • Networks are ordered as Mainnet, Mocha, Arabica, private, custom.
        • Node types are ordered as bridge, full, and light.
        • Each network has only one running node type.
        • Multiple nodes of the same network and type are prohibited (resulting in an Error: node: store is in use).

        Key Points:

        • Authentication token and other flags maintain their previous behavior and take precedence.
        • Address and port details are fetched from the configuration.
        • skipAuth allows bypassing authentication for trusted setups and follows Unix daemon conventions.
        • Non-default node store and cel-key configurations still require specific flags in the configuration settings.

        Demonstration

        In this section, we'll guide you through starting your node using a node store in a different location than you originally started with.

        First, stop your node safely using control + C.

        Then, init your node again with a new node store:

        bash
        celestia <node-type> init --node.store /home/user/celestia-<node-type>-location/ \\
             --p2p.network mocha
        celestia <node-type> init --node.store /home/user/celestia-<node-type>-location/ \\
        @@ -58,4 +58,4 @@ import{c as n}from"./chunks/constants.0e6df566.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":"nodes/celestia-app-metrics"},"head":[["meta",{"name":"og:title","content":"Troubleshooting | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-troubleshooting.md","filePath":"nodes/celestia-node-troubleshooting.md","lastUpdated":1724867275000}'),b={name:"nodes/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":"nodes/celestia-app-metrics"},"head":[["meta",{"name":"og:title","content":"Troubleshooting | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-troubleshooting.md","filePath":"nodes/celestia-node-troubleshooting.md","lastUpdated":1725955670000}'),b={name:"nodes/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-1680/assets/nodes_celestia-node-troubleshooting.md.821659c6.lean.js b/pr-1680/assets/nodes_celestia-node-troubleshooting.md.f834eff5.lean.js similarity index 93% rename from pr-1680/assets/nodes_celestia-node-troubleshooting.md.821659c6.lean.js rename to pr-1680/assets/nodes_celestia-node-troubleshooting.md.f834eff5.lean.js index 60ca5ec179..b1f864b45b 100644 --- a/pr-1680/assets/nodes_celestia-node-troubleshooting.md.821659c6.lean.js +++ b/pr-1680/assets/nodes_celestia-node-troubleshooting.md.f834eff5.lean.js @@ -1 +1 @@ -import{c as n}from"./chunks/constants.0e6df566.js";import{o as p,c as t,k as s,a,t as o,l,Q as e}from"./chunks/framework.a504a440.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":"nodes/celestia-app-metrics"},"head":[["meta",{"name":"og:title","content":"Troubleshooting | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-troubleshooting.md","filePath":"nodes/celestia-node-troubleshooting.md","lastUpdated":1724867275000}'),b={name:"nodes/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.295fc0ab.js";import{o as p,c as t,k as s,a,t as o,l,Q as e}from"./chunks/framework.a504a440.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":"nodes/celestia-app-metrics"},"head":[["meta",{"name":"og:title","content":"Troubleshooting | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-troubleshooting.md","filePath":"nodes/celestia-node-troubleshooting.md","lastUpdated":1725955670000}'),b={name:"nodes/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-1680/assets/nodes_celestia-node-trusted-hash.md.f83aaf6b.js b/pr-1680/assets/nodes_celestia-node-trusted-hash.md.09a35d4c.js similarity index 99% rename from pr-1680/assets/nodes_celestia-node-trusted-hash.md.f83aaf6b.js rename to pr-1680/assets/nodes_celestia-node-trusted-hash.md.09a35d4c.js index 973f1af78a..580f6ceef5 100644 --- a/pr-1680/assets/nodes_celestia-node-trusted-hash.md.f83aaf6b.js +++ b/pr-1680/assets/nodes_celestia-node-trusted-hash.md.09a35d4c.js @@ -1,3 +1,3 @@ -import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-trusted-hash.md","filePath":"nodes/celestia-node-trusted-hash.md","lastUpdated":1724867275000}'),t={name:"nodes/celestia-node-trusted-hash.md"},n=o(`

        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 e,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-trusted-hash.md","filePath":"nodes/celestia-node-trusted-hash.md","lastUpdated":1725955670000}'),t={name:"nodes/celestia-node-trusted-hash.md"},n=o(`

        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(),e("div",null,l)}const u=s(t,[["render",p]]);export{g as __pageData,u as default}; diff --git a/pr-1680/assets/nodes_celestia-node-trusted-hash.md.f83aaf6b.lean.js b/pr-1680/assets/nodes_celestia-node-trusted-hash.md.09a35d4c.lean.js similarity index 91% rename from pr-1680/assets/nodes_celestia-node-trusted-hash.md.f83aaf6b.lean.js rename to pr-1680/assets/nodes_celestia-node-trusted-hash.md.09a35d4c.lean.js index 1a76c70c4b..7aa85864d9 100644 --- a/pr-1680/assets/nodes_celestia-node-trusted-hash.md.f83aaf6b.lean.js +++ b/pr-1680/assets/nodes_celestia-node-trusted-hash.md.09a35d4c.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-trusted-hash.md","filePath":"nodes/celestia-node-trusted-hash.md","lastUpdated":1724867275000}'),t={name:"nodes/celestia-node-trusted-hash.md"},n=o("",7),l=[n];function p(r,c,i,h,d,y){return a(),e("div",null,l)}const u=s(t,[["render",p]]);export{g as __pageData,u as default}; +import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Syncing a light node from a trusted hash | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node-trusted-hash.md","filePath":"nodes/celestia-node-trusted-hash.md","lastUpdated":1725955670000}'),t={name:"nodes/celestia-node-trusted-hash.md"},n=o("",7),l=[n];function p(r,c,i,h,d,y){return a(),e("div",null,l)}const u=s(t,[["render",p]]);export{g as __pageData,u as default}; diff --git a/pr-1680/assets/nodes_celestia-node.md.a266ee0e.js b/pr-1680/assets/nodes_celestia-node.md.1aba6dda.js similarity index 85% rename from pr-1680/assets/nodes_celestia-node.md.a266ee0e.js rename to pr-1680/assets/nodes_celestia-node.md.1aba6dda.js index d0559c555a..78e0f4a9ea 100644 --- a/pr-1680/assets/nodes_celestia-node.md.a266ee0e.js +++ b/pr-1680/assets/nodes_celestia-node.md.1aba6dda.js @@ -1,7 +1,7 @@ -import{a as t}from"./chunks/arabica_versions.6d89be6e.js";import{m as l}from"./chunks/mocha_versions.ffd4ea25.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as i,c,k as s,t as e,l as a,Q as o}from"./chunks/framework.a504a440.js";const p=o('

        Install celestia-node

        Installing from source

        This section goes over building and installing celestia-node. This tutorial assumes you completed the steps in setting up your development environment.

        Install the celestia-node binary by running the following commands:

        ',4),r=o(`
      32. Remove any existing copy of celestia-node, clone the repository, and change into the directory:

        bash
        cd $HOME
        +import{a as t}from"./chunks/arabica_versions.1930378b.js";import{m as l}from"./chunks/mocha_versions.7704b055.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as i,c,k as s,t as e,l as a,Q as o}from"./chunks/framework.a504a440.js";const p=o('

        Install celestia-node

        Installing from source

        This section goes over building and installing celestia-node. This tutorial assumes you completed the steps in setting up your development environment.

        Install the celestia-node binary by running the following commands:

        ',4),r=o(`
      33. Remove any existing copy of celestia-node, clone the repository, and change into the directory:

        bash
        cd $HOME
         rm -rf celestia-node
         git clone https://github.com/celestiaorg/celestia-node.git
         cd celestia-node/
        cd $HOME
         rm -rf celestia-node
         git clone https://github.com/celestiaorg/celestia-node.git
        -cd celestia-node/
      34. `,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"},u=o('
        ',1),_={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},g=s("button",{title:"Copy Code",class:"copy"},null,-1),b=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},m={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),F=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},T={class:"line"},w=s("span",{style:{color:"#6F42C1"}},"git",-1),I=s("span",{style:{color:"#24292E"}}," ",-1),A=s("span",{style:{color:"#032F62"}},"checkout",-1),S=s("span",{style:{color:"#24292E"}}," ",-1),P={style:{color:"#032F62"}},x={class:"language-bash vp-adaptive-theme"},V=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},D={class:"line"},O=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),L=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),M=s("span",{style:{color:"#E1E4E8"}}," ",-1),G={style:{color:"#9ECBFF"}},j={class:"shiki github-light vp-code-light"},H={class:"line"},$=s("span",{style:{color:"#6F42C1"}},"git",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),Y=s("span",{style:{color:"#032F62"}},"checkout",-1),K=s("span",{style:{color:"#24292E"}}," ",-1),W={style:{color:"#032F62"}},X={class:"language-bash vp-adaptive-theme"},J=s("button",{title:"Copy Code",class:"copy"},null,-1),Q=s("span",{class:"lang"},"bash",-1),z={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),as=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),os=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},is=s("span",{style:{color:"#6F42C1"}},"git",-1),cs=s("span",{style:{color:"#24292E"}}," ",-1),ps=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=o('
      35. 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.

      36. Install the binary:

        bash
        make install
        make install
      37. Build the cel-key utility:

        bash
        make cel-key
        make cel-key
      38. Verify that the binary is working and check the version:

        bash
        celestia version
        celestia version
      39. ',4),us=o('

        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 should have these binaries available.

        The steps below will download a binary file named celestia. Depending on the setup that you choose during installation, the celestia binary will be available at either:

        • $HOME/celestia-node-temp/celestia
        • /usr/local/bin/celestia

        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-node.sh)"
        bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"

        Follow the instructions in the terminal output to choose your installation preferences.

        You will see an output with the menu for celestia.

        View the script to learn more about what it is doing.

        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.

        ',18),ks=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",{"name":"og:title","content":"Install celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node.md","filePath":"nodes/celestia-node.md","lastUpdated":1724867275000}'),_s={name:"nodes/celestia-node.md"},Cs=Object.assign(_s,{setup(ys){return(gs,bs)=>(i(),c("div",null,[p,s("ol",null,[r,s("li",null,[d,s("div",h,[u,s("div",_,[s("div",y,[g,b,s("pre",E,[s("code",null,[s("span",m,[v,F,k,C,s("span",f,"tags/"+e(a(n)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",T,[w,I,A,S,s("span",P,"tags/"+e(a(n)["node-latest-tag"]),1)])])])]),s("div",x,[V,q,s("pre",N,[s("code",null,[s("span",D,[O,R,L,M,s("span",G,"tags/"+e(a(l)["node-latest-tag"]),1)])])]),s("pre",j,[s("code",null,[s("span",H,[$,U,Y,K,s("span",W,"tags/"+e(a(l)["node-latest-tag"]),1)])])])]),s("div",X,[J,Q,s("pre",z,[s("code",null,[s("span",Z,[ss,es,as,os,s("span",ts,"tags/"+e(a(t)["node-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[is,cs,ps,rs,s("span",ds,"tags/"+e(a(t)["node-latest-tag"]),1)])])])])])])]),hs]),us]))}});export{ks as __pageData,Cs as default}; +cd celestia-node/
      40. `,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"},u=o('
        ',1),_={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},g=s("button",{title:"Copy Code",class:"copy"},null,-1),b=s("span",{class:"lang"},"bash",-1),m={class:"shiki github-dark vp-code-dark"},E={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),F=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},T={class:"line"},w=s("span",{style:{color:"#6F42C1"}},"git",-1),I=s("span",{style:{color:"#24292E"}}," ",-1),S=s("span",{style:{color:"#032F62"}},"checkout",-1),A=s("span",{style:{color:"#24292E"}}," ",-1),P={style:{color:"#032F62"}},V={class:"language-bash vp-adaptive-theme"},x=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},O={class:"line"},D=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),L=s("span",{style:{color:"#E1E4E8"}}," ",-1),j={style:{color:"#9ECBFF"}},$={class:"shiki github-light vp-code-light"},H={class:"line"},J=s("span",{style:{color:"#6F42C1"}},"git",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),Y=s("span",{style:{color:"#032F62"}},"checkout",-1),G=s("span",{style:{color:"#24292E"}}," ",-1),Q={style:{color:"#032F62"}},z={class:"language-bash vp-adaptive-theme"},K=s("button",{title:"Copy Code",class:"copy"},null,-1),W=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),as=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),os=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},is=s("span",{style:{color:"#6F42C1"}},"git",-1),cs=s("span",{style:{color:"#24292E"}}," ",-1),ps=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=o('
      41. 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.

      42. Install the binary:

        bash
        make install
        make install
      43. Build the cel-key utility:

        bash
        make cel-key
        make cel-key
      44. Verify that the binary is working and check the version:

        bash
        celestia version
        celestia version
      45. ',4),us=o('

        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 should have these binaries available.

        The steps below will download a binary file named celestia. Depending on the setup that you choose during installation, the celestia binary will be available at either:

        • $HOME/celestia-node-temp/celestia
        • /usr/local/bin/celestia

        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-node.sh)"
        bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"

        Follow the instructions in the terminal output to choose your installation preferences.

        You will see an output with the menu for celestia.

        View the script to learn more about what it is doing.

        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.

        ',18),ks=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",{"name":"og:title","content":"Install celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node.md","filePath":"nodes/celestia-node.md","lastUpdated":1725955670000}'),_s={name:"nodes/celestia-node.md"},Cs=Object.assign(_s,{setup(ys){return(gs,bs)=>(i(),c("div",null,[p,s("ol",null,[r,s("li",null,[d,s("div",h,[u,s("div",_,[s("div",y,[g,b,s("pre",m,[s("code",null,[s("span",E,[v,F,k,C,s("span",f,"tags/"+e(a(n)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",T,[w,I,S,A,s("span",P,"tags/"+e(a(n)["node-latest-tag"]),1)])])])]),s("div",V,[x,q,s("pre",N,[s("code",null,[s("span",O,[D,R,M,L,s("span",j,"tags/"+e(a(l)["node-latest-tag"]),1)])])]),s("pre",$,[s("code",null,[s("span",H,[J,U,Y,G,s("span",Q,"tags/"+e(a(l)["node-latest-tag"]),1)])])])]),s("div",z,[K,W,s("pre",X,[s("code",null,[s("span",Z,[ss,es,as,os,s("span",ts,"tags/"+e(a(t)["node-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[is,cs,ps,rs,s("span",ds,"tags/"+e(a(t)["node-latest-tag"]),1)])])])])])])]),hs]),us]))}});export{ks as __pageData,Cs as default}; diff --git a/pr-1680/assets/nodes_celestia-node.md.a266ee0e.lean.js b/pr-1680/assets/nodes_celestia-node.md.1aba6dda.lean.js similarity index 60% rename from pr-1680/assets/nodes_celestia-node.md.a266ee0e.lean.js rename to pr-1680/assets/nodes_celestia-node.md.1aba6dda.lean.js index 9f7649f63d..5ca1bf2097 100644 --- a/pr-1680/assets/nodes_celestia-node.md.a266ee0e.lean.js +++ b/pr-1680/assets/nodes_celestia-node.md.1aba6dda.lean.js @@ -1 +1 @@ -import{a as t}from"./chunks/arabica_versions.6d89be6e.js";import{m as l}from"./chunks/mocha_versions.ffd4ea25.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as i,c,k as s,t as e,l as a,Q as o}from"./chunks/framework.a504a440.js";const p=o("",4),r=o("",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"},u=o("",1),_={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},g=s("button",{title:"Copy Code",class:"copy"},null,-1),b=s("span",{class:"lang"},"bash",-1),E={class:"shiki github-dark vp-code-dark"},m={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),F=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},T={class:"line"},w=s("span",{style:{color:"#6F42C1"}},"git",-1),I=s("span",{style:{color:"#24292E"}}," ",-1),A=s("span",{style:{color:"#032F62"}},"checkout",-1),S=s("span",{style:{color:"#24292E"}}," ",-1),P={style:{color:"#032F62"}},x={class:"language-bash vp-adaptive-theme"},V=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},D={class:"line"},O=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),L=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),M=s("span",{style:{color:"#E1E4E8"}}," ",-1),G={style:{color:"#9ECBFF"}},j={class:"shiki github-light vp-code-light"},H={class:"line"},$=s("span",{style:{color:"#6F42C1"}},"git",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),Y=s("span",{style:{color:"#032F62"}},"checkout",-1),K=s("span",{style:{color:"#24292E"}}," ",-1),W={style:{color:"#032F62"}},X={class:"language-bash vp-adaptive-theme"},J=s("button",{title:"Copy Code",class:"copy"},null,-1),Q=s("span",{class:"lang"},"bash",-1),z={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),as=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),os=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},is=s("span",{style:{color:"#6F42C1"}},"git",-1),cs=s("span",{style:{color:"#24292E"}}," ",-1),ps=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=o("",4),us=o("",18),ks=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",{"name":"og:title","content":"Install celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node.md","filePath":"nodes/celestia-node.md","lastUpdated":1724867275000}'),_s={name:"nodes/celestia-node.md"},Cs=Object.assign(_s,{setup(ys){return(gs,bs)=>(i(),c("div",null,[p,s("ol",null,[r,s("li",null,[d,s("div",h,[u,s("div",_,[s("div",y,[g,b,s("pre",E,[s("code",null,[s("span",m,[v,F,k,C,s("span",f,"tags/"+e(a(n)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",T,[w,I,A,S,s("span",P,"tags/"+e(a(n)["node-latest-tag"]),1)])])])]),s("div",x,[V,q,s("pre",N,[s("code",null,[s("span",D,[O,R,L,M,s("span",G,"tags/"+e(a(l)["node-latest-tag"]),1)])])]),s("pre",j,[s("code",null,[s("span",H,[$,U,Y,K,s("span",W,"tags/"+e(a(l)["node-latest-tag"]),1)])])])]),s("div",X,[J,Q,s("pre",z,[s("code",null,[s("span",Z,[ss,es,as,os,s("span",ts,"tags/"+e(a(t)["node-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[is,cs,ps,rs,s("span",ds,"tags/"+e(a(t)["node-latest-tag"]),1)])])])])])])]),hs]),us]))}});export{ks as __pageData,Cs as default}; +import{a as t}from"./chunks/arabica_versions.1930378b.js";import{m as l}from"./chunks/mocha_versions.7704b055.js";import{m as n}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as i,c,k as s,t as e,l as a,Q as o}from"./chunks/framework.a504a440.js";const p=o("",4),r=o("",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"},u=o("",1),_={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},g=s("button",{title:"Copy Code",class:"copy"},null,-1),b=s("span",{class:"lang"},"bash",-1),m={class:"shiki github-dark vp-code-dark"},E={class:"line"},v=s("span",{style:{color:"#B392F0"}},"git",-1),F=s("span",{style:{color:"#E1E4E8"}}," ",-1),k=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),C=s("span",{style:{color:"#E1E4E8"}}," ",-1),f={style:{color:"#9ECBFF"}},B={class:"shiki github-light vp-code-light"},T={class:"line"},w=s("span",{style:{color:"#6F42C1"}},"git",-1),I=s("span",{style:{color:"#24292E"}}," ",-1),S=s("span",{style:{color:"#032F62"}},"checkout",-1),A=s("span",{style:{color:"#24292E"}}," ",-1),P={style:{color:"#032F62"}},V={class:"language-bash vp-adaptive-theme"},x=s("button",{title:"Copy Code",class:"copy"},null,-1),q=s("span",{class:"lang"},"bash",-1),N={class:"shiki github-dark vp-code-dark"},O={class:"line"},D=s("span",{style:{color:"#B392F0"}},"git",-1),R=s("span",{style:{color:"#E1E4E8"}}," ",-1),M=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),L=s("span",{style:{color:"#E1E4E8"}}," ",-1),j={style:{color:"#9ECBFF"}},$={class:"shiki github-light vp-code-light"},H={class:"line"},J=s("span",{style:{color:"#6F42C1"}},"git",-1),U=s("span",{style:{color:"#24292E"}}," ",-1),Y=s("span",{style:{color:"#032F62"}},"checkout",-1),G=s("span",{style:{color:"#24292E"}}," ",-1),Q={style:{color:"#032F62"}},z={class:"language-bash vp-adaptive-theme"},K=s("button",{title:"Copy Code",class:"copy"},null,-1),W=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),as=s("span",{style:{color:"#9ECBFF"}},"checkout",-1),os=s("span",{style:{color:"#E1E4E8"}}," ",-1),ts={style:{color:"#9ECBFF"}},ls={class:"shiki github-light vp-code-light"},ns={class:"line"},is=s("span",{style:{color:"#6F42C1"}},"git",-1),cs=s("span",{style:{color:"#24292E"}}," ",-1),ps=s("span",{style:{color:"#032F62"}},"checkout",-1),rs=s("span",{style:{color:"#24292E"}}," ",-1),ds={style:{color:"#032F62"}},hs=o("",4),us=o("",18),ks=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",{"name":"og:title","content":"Install celestia-node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/celestia-node.md","filePath":"nodes/celestia-node.md","lastUpdated":1725955670000}'),_s={name:"nodes/celestia-node.md"},Cs=Object.assign(_s,{setup(ys){return(gs,bs)=>(i(),c("div",null,[p,s("ol",null,[r,s("li",null,[d,s("div",h,[u,s("div",_,[s("div",y,[g,b,s("pre",m,[s("code",null,[s("span",E,[v,F,k,C,s("span",f,"tags/"+e(a(n)["node-latest-tag"]),1)])])]),s("pre",B,[s("code",null,[s("span",T,[w,I,S,A,s("span",P,"tags/"+e(a(n)["node-latest-tag"]),1)])])])]),s("div",V,[x,q,s("pre",N,[s("code",null,[s("span",O,[D,R,M,L,s("span",j,"tags/"+e(a(l)["node-latest-tag"]),1)])])]),s("pre",$,[s("code",null,[s("span",H,[J,U,Y,G,s("span",Q,"tags/"+e(a(l)["node-latest-tag"]),1)])])])]),s("div",z,[K,W,s("pre",X,[s("code",null,[s("span",Z,[ss,es,as,os,s("span",ts,"tags/"+e(a(t)["node-latest-tag"]),1)])])]),s("pre",ls,[s("code",null,[s("span",ns,[is,cs,ps,rs,s("span",ds,"tags/"+e(a(t)["node-latest-tag"]),1)])])])])])])]),hs]),us]))}});export{ks as __pageData,Cs as default}; diff --git a/pr-1680/assets/nodes_config-toml.md.7c6ec5cd.js b/pr-1680/assets/nodes_config-toml.md.baac8bd9.js similarity index 98% rename from pr-1680/assets/nodes_config-toml.md.7c6ec5cd.js rename to pr-1680/assets/nodes_config-toml.md.baac8bd9.js index 24c87599f7..04b3e8809e 100644 --- a/pr-1680/assets/nodes_config-toml.md.7c6ec5cd.js +++ b/pr-1680/assets/nodes_config-toml.md.baac8bd9.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"config.toml guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/config-toml.md","filePath":"nodes/config-toml.md","lastUpdated":1724867275000}'),i={name:"nodes/config-toml.md"},r=a('

        config.toml guide

        Pre-requisites

        Please, make sure that you have installed and initialized celestia-node

        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.

        ',19),n=[r];function d(s,l,c,h,u,f){return t(),o("div",null,n)}const m=e(i,[["render",d]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"config.toml guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/config-toml.md","filePath":"nodes/config-toml.md","lastUpdated":1725955670000}'),i={name:"nodes/config-toml.md"},r=a('

        config.toml guide

        Pre-requisites

        Please, make sure that you have installed and initialized celestia-node

        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.

        ',19),n=[r];function d(s,l,c,h,u,f){return t(),o("div",null,n)}const m=e(i,[["render",d]]);export{g as __pageData,m as default}; diff --git a/pr-1680/assets/nodes_config-toml.md.7c6ec5cd.lean.js b/pr-1680/assets/nodes_config-toml.md.baac8bd9.lean.js similarity index 90% rename from pr-1680/assets/nodes_config-toml.md.7c6ec5cd.lean.js rename to pr-1680/assets/nodes_config-toml.md.baac8bd9.lean.js index 1e456f5a56..1cd1eb0eea 100644 --- a/pr-1680/assets/nodes_config-toml.md.7c6ec5cd.lean.js +++ b/pr-1680/assets/nodes_config-toml.md.baac8bd9.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"config.toml guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/config-toml.md","filePath":"nodes/config-toml.md","lastUpdated":1724867275000}'),i={name:"nodes/config-toml.md"},r=a("",19),n=[r];function d(s,l,c,h,u,f){return t(),o("div",null,n)}const m=e(i,[["render",d]]);export{g as __pageData,m as default}; +import{_ as e,o as t,c as o,Q as a}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"config.toml guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/config-toml.md","filePath":"nodes/config-toml.md","lastUpdated":1725955670000}'),i={name:"nodes/config-toml.md"},r=a("",19),n=[r];function d(s,l,c,h,u,f){return t(),o("div",null,n)}const m=e(i,[["render",d]]);export{g as __pageData,m as default}; diff --git a/pr-1680/assets/nodes_consensus-node.md.01077dd8.js b/pr-1680/assets/nodes_consensus-node.md.21f5a1d7.js similarity index 64% rename from pr-1680/assets/nodes_consensus-node.md.01077dd8.js rename to pr-1680/assets/nodes_consensus-node.md.21f5a1d7.js index 7102d33f82..73cd7d4277 100644 --- a/pr-1680/assets/nodes_consensus-node.md.01077dd8.js +++ b/pr-1680/assets/nodes_consensus-node.md.21f5a1d7.js @@ -1,10 +1,10 @@ -import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/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"},y={class:"language-bash vp-adaptive-theme active"},h=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"},C=o('celestia-appd init "node-name" --chain-id ',8),g={style:{color:"#9ECBFF"}},T={class:"shiki github-light vp-code-light"},b={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"},P=o('celestia-appd init "node-name" --chain-id ',8),q={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"},O={class:"line"},M=o('celestia-appd init "node-name" --chain-id ',8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},Q={class:"line"},Y=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),U={class:"vp-code-group vp-adaptive-theme"},J=o('
        ',1),K={class:"blocks"},Z={class:"language-bash vp-adaptive-theme active"},G=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"}},ys={class:"language-bash vp-adaptive-theme"},hs=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"},Cs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),gs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ts=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),bs=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),Ps={style:{color:"#032F62"}},qs={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),Os={style:{color:"#9ECBFF"}},Ms={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),Ys=s("span",{style:{color:"#032F62"}},"download-genesis",-1),Xs=s("span",{style:{color:"#24292E"}}," ",-1),js={style:{color:"#032F62"}},Us=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),Zs={class:"blocks"},Gs={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"},yo=o('SEEDS=$(curl -sL',6),ho={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),Co=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),go=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),To=o('sed -i.bak -e "s/^seeds *=.*/seeds = \\"$SEEDS\\"/" $HOME/.celestia-app/config/config.toml',1),bo={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),Po=s("span",{style:{color:"#9ECBFF"}}," ",-1),qo=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),Oo=s("span",{style:{color:"#032F62"}}," ",-1),Mo=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),Yo=o(`
        bash
        # For Arabica, you can set seeds manually in the
        +import{c as e}from"./chunks/constants.295fc0ab.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/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"},y={class:"language-bash vp-adaptive-theme active"},h=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"},C=o('celestia-appd init "node-name" --chain-id ',8),g={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"},O={class:"line"},M=o('celestia-appd init "node-name" --chain-id ',8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},G={class:"line"},j=o('celestia-appd init "node-name" --chain-id ',8),z={style:{color:"#032F62"}},Q=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),U={class:"vp-code-group vp-adaptive-theme"},J=o('
        ',1),X={class:"blocks"},K={class:"language-bash vp-adaptive-theme active"},W=s("button",{title:"Copy Code",class:"copy"},null,-1),Y=s("span",{class:"lang"},"bash",-1),Z={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"}},ys={class:"language-bash vp-adaptive-theme"},hs=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"},Cs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),gs=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),Os={style:{color:"#9ECBFF"}},Ms={class:"shiki github-light vp-code-light"},Hs={class:"line"},Ls=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Gs=s("span",{style:{color:"#24292E"}}," ",-1),js=s("span",{style:{color:"#032F62"}},"download-genesis",-1),zs=s("span",{style:{color:"#24292E"}}," ",-1),Qs={style:{color:"#032F62"}},Us=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"},Xs=o('
        ',1),Ks={class:"blocks"},Ws={class:"language-bash vp-adaptive-theme active"},Ys=s("button",{title:"Copy Code",class:"copy"},null,-1),Zs=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"},yo=o('SEEDS=$(curl -sL',6),ho={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),Co=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),go=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),Oo=s("span",{style:{color:"#032F62"}}," ",-1),Mo=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),Go=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
         # \`$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),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"},Uo=o('
        ',1),Jo={class:"blocks"},Ko={class:"language-bash vp-adaptive-theme active"},Zo=s("button",{title:"Copy Code",class:"copy"},null,-1),Go=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"},ya=s("button",{title:"Copy Code",class:"copy"},null,-1),ha=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o('PERSISTENT_PEERS=$(curl -sL',6),Ca={style:{color:"#9ECBFF"}},ga=s("span",{style:{color:"#F97583"}},"|",-1),Ta=s("span",{style:{color:"#9ECBFF"}}," ",-1),ba=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"}},Pa=s("span",{style:{color:"#D73A49"}},"|",-1),qa=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"},Oa={class:"line"},Ma=o('PERSISTENT_PEERS=$(curl -sL',6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Qa=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ya=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),Ua=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"},Za=o('PERSISTENT_PEERS=$(curl -sL',6),Ga={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),zo=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),Qo={class:"vp-code-group vp-adaptive-theme"},Uo=o('
        ',1),Jo={class:"blocks"},Xo={class:"language-bash vp-adaptive-theme active"},Ko=s("button",{title:"Copy Code",class:"copy"},null,-1),Wo=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},Zo={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"},ya=s("button",{title:"Copy Code",class:"copy"},null,-1),ha=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o('PERSISTENT_PEERS=$(curl -sL',6),Ca={style:{color:"#9ECBFF"}},ga=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"},Oa={class:"line"},Ma=o('PERSISTENT_PEERS=$(curl -sL',6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Ga=s("span",{style:{color:"#9ECBFF"}}," ",-1),ja=s("span",{style:{color:"#B392F0"}},"tr",-1),za=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),Qa=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),Ua=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"},Xa={class:"line"},Ka=o('PERSISTENT_PEERS=$(curl -sL',6),Wa={style:{color:"#032F62"}},Ya=s("span",{style:{color:"#D73A49"}},"|",-1),Za=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,43 +18,43 @@ import{c as e}from"./chunks/constants.0e6df566.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.

        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:

        `,33),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),ye=o('rm -rf ~/.celestia-app/data',1),he=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),Ce=s("span",{style:{color:"#B392F0"}},"egrep",-1),ge=s("span",{style:{color:"#9ECBFF"}}," ",-1),Te=s("span",{style:{color:"#79B8FF"}},"-o",-1),be={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),Pe=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),qe={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),Oe={class:"language-bash vp-adaptive-theme"},Me=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),Ye=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),Ue={class:"line"},Je=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ke=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ze=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ge=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),yn={style:{color:"#032F62"}},hn=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"},Cn=s("button",{title:"Copy Code",class:"copy"},null,-1),gn=s("span",{class:"lang"},"bash",-1),Tn={class:"shiki github-dark vp-code-dark"},bn=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),Pn=s("span",{style:{color:"#79B8FF"}},"-o",-1),qn={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),On={class:"line"},Mn=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),Yn={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),Un=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 <height>
        celestia-appd start --v2-upgrade-height <height>
        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 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 unsafe-reset-all to reset your node and start syncing from the genesis block.

        ',41),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",{"name":"og:title","content":"Consensus node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/consensus-node.md","filePath":"nodes/consensus-node.md","lastUpdated":1724867275000}'),Kn={name:"nodes/consensus-node.md"},at=Object.assign(Kn,{setup(Zn){return(Gn,zn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",y,[h,E,s("pre",u,[s("code",null,[s("span",F,[C,s("span",g,n(t(e).mainnetChainId),1)])])]),s("pre",T,[s("code",null,[s("span",b,[m,s("span",S,n(t(e).mainnetChainId),1)])])])]),s("div",v,[k,B,s("pre",A,[s("code",null,[s("span",f,[P,s("span",q,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",O,[M,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",Q,[Y,s("span",X,n(t(e).arabicaChainId),1)])])])])])]),j,s("div",U,[J,s("div",K,[s("div",Z,[G,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",ys,[hs,Es,s("pre",us,[s("code",null,[s("span",Fs,[Cs,gs,Ts,bs,s("span",ms,n(t(e).mochaChainId),1)])])]),s("pre",Ss,[s("code",null,[s("span",vs,[ks,Bs,As,fs,s("span",Ps,n(t(e).mochaChainId),1)])])])]),s("div",qs,[Is,xs,s("pre",Vs,[s("code",null,[s("span",Rs,[Ds,ws,Ns,$s,s("span",Os,n(t(e).arabicaChainId),1)])])]),s("pre",Ms,[s("code",null,[s("span",Hs,[Ls,Qs,Ys,Xs,s("span",js,n(t(e).arabicaChainId),1)])])])])])]),Us,s("div",Js,[Ks,s("div",Zs,[s("div",Gs,[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.

        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:

        `,33),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),ye=o('rm -rf ~/.celestia-app/data',1),he=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),Ce=s("span",{style:{color:"#B392F0"}},"egrep",-1),ge=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),Oe={class:"language-bash vp-adaptive-theme"},Me=s("button",{title:"Copy Code",class:"copy"},null,-1),He=s("span",{class:"lang"},"bash",-1),Le={class:"shiki github-dark vp-code-dark"},Ge=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),ze=o('mkdir -p ~/.celestia-app/data',1),Qe=o('SNAP_NAME=$(curl -s https://snaps.qubelabs.io/celestia/ | \\',1),Ue={class:"line"},Je=s("span",{style:{color:"#9ECBFF"}}," ",-1),Xe=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ke=s("span",{style:{color:"#9ECBFF"}}," ",-1),We=s("span",{style:{color:"#79B8FF"}},"-o",-1),Ye={style:{color:"#9ECBFF"}},Ze=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),yn={style:{color:"#032F62"}},hn=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"},Cn=s("button",{title:"Copy Code",class:"copy"},null,-1),gn=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),On={class:"line"},Mn=s("span",{style:{color:"#032F62"}}," ",-1),Hn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ln=s("span",{style:{color:"#032F62"}}," ",-1),Gn=s("span",{style:{color:"#005CC5"}},"-o",-1),jn={style:{color:"#032F62"}},zn=o('| tr -d ">")',6),Qn=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),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 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.

        ',41),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",{"name":"og:title","content":"Consensus node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/consensus-node.md","filePath":"nodes/consensus-node.md","lastUpdated":1725955670000}'),Xn={name:"nodes/consensus-node.md"},at=Object.assign(Xn,{setup(Kn){return(Wn,Yn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",y,[h,E,s("pre",u,[s("code",null,[s("span",F,[C,s("span",g,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",O,[M,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",G,[j,s("span",z,n(t(e).arabicaChainId),1)])])])])])]),Q,s("div",U,[J,s("div",X,[s("div",K,[W,Y,s("pre",Z,[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",ys,[hs,Es,s("pre",us,[s("code",null,[s("span",Fs,[Cs,gs,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",Os,n(t(e).arabicaChainId),1)])])]),s("pre",Ms,[s("code",null,[s("span",Hs,[Ls,Gs,js,zs,s("span",Qs,n(t(e).arabicaChainId),1)])])])])])]),Us,s("div",Js,[Xs,s("div",Ks,[s("div",Ws,[Ys,Zs,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,[yo,s("span",ho," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),Eo,uo,Fo,Co]),a(` `),go,a(` -`),To])])]),s("div",bo,[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,Po,qo,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,Oo,Mo,Ho]),a(` `),Lo,a(` -`),Qo])])]),Yo])]),s("details",null,[Xo,s("div",jo,[Uo,s("div",Jo,[s("div",Ko,[Zo,Go,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(` +`),Go])])]),jo])]),s("details",null,[zo,s("div",Qo,[Uo,s("div",Jo,[s("div",Xo,[Ko,Wo,s("pre",Yo,[s("code",null,[s("span",Zo,[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,[ya,ha,s("pre",Ea,[s("code",null,[s("span",ua,[Fa,s("span",Ca," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),ga,Ta,ba,ma]),a(` +`),da])])]),s("div",_a,[ya,ha,s("pre",Ea,[s("code",null,[s("span",ua,[Fa,s("span",Ca," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),ga,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),Pa,qa,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",Oa,[Ma,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Qa,Ya,Xa]),a(` -`),ja,a(` -`),Ua])]),s("pre",Ja,[s("code",null,[s("span",Ka,[Za,s("span",Ga," 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",Oa,[Ma,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Ga,ja,za]),a(` +`),Qa,a(` +`),Ua])]),s("pre",Ja,[s("code",null,[s("span",Xa,[Ka,s("span",Wa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),Ya,Za,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(` `),ye,a(` `),he,a(` `),Ee,a(` -`),s("span",ue,[Fe,Ce,ge,Te,s("span",be,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),me]),a(` +`),s("span",ue,[Fe,Ce,ge,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(` -`),Pe,a(` -`),s("span",qe,[Ie,xe,Ve,Re,s("span",De,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),we]),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",Oe,[Me,He,s("pre",Le,[s("code",null,[Qe,a(` -`),Ye,a(` -`),Xe,a(` +`),$e])])]),s("div",Oe,[Me,He,s("pre",Le,[s("code",null,[Ge,a(` `),je,a(` -`),s("span",Ue,[Je,Ke,Ze,Ge,s("span",ze,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),We]),a(` +`),ze,a(` +`),Qe,a(` +`),s("span",Ue,[Je,Xe,Ke,We,s("span",Ye,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),Ze]),a(` `),sn,a(` `),on])]),s("pre",an,[s("code",null,[en,a(` `),nn,a(` @@ -62,16 +62,16 @@ import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,t `),ln,a(` `),s("span",pn,[cn,rn,dn,_n,s("span",yn,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),hn]),a(` `),En,a(` -`),un])])]),s("div",Fn,[Cn,gn,s("pre",Tn,[s("code",null,[bn,a(` +`),un])])]),s("div",Fn,[Cn,gn,s("pre",bn,[s("code",null,[Tn,a(` `),mn,a(` `),Sn,a(` `),vn,a(` -`),s("span",kn,[Bn,An,fn,Pn,s("span",qn,' ">'+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",On,[Mn,Hn,Ln,Qn,s("span",Yn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),Xn]),a(` -`),jn,a(` +`),s("span",On,[Mn,Hn,Ln,Gn,s("span",jn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),zn]),a(` +`),Qn,a(` `),Un])])])])]),Jn]))}});export{ot as __pageData,at as default}; diff --git a/pr-1680/assets/nodes_consensus-node.md.01077dd8.lean.js b/pr-1680/assets/nodes_consensus-node.md.21f5a1d7.lean.js similarity index 66% rename from pr-1680/assets/nodes_consensus-node.md.01077dd8.lean.js rename to pr-1680/assets/nodes_consensus-node.md.21f5a1d7.lean.js index d2e58e9e96..cdd8f8ec5b 100644 --- a/pr-1680/assets/nodes_consensus-node.md.01077dd8.lean.js +++ b/pr-1680/assets/nodes_consensus-node.md.21f5a1d7.lean.js @@ -1,40 +1,40 @@ -import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/img/nodes/consensus-node.jpg",r=o("",14),i={class:"vp-code-group vp-adaptive-theme"},d=o("",1),_={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},h=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"},C=o("",8),g={style:{color:"#9ECBFF"}},T={class:"shiki github-light vp-code-light"},b={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"},P=o("",8),q={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"},O={class:"line"},M=o("",8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},Q={class:"line"},Y=o("",8),X={style:{color:"#032F62"}},j=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),U={class:"vp-code-group vp-adaptive-theme"},J=o("",1),K={class:"blocks"},Z={class:"language-bash vp-adaptive-theme active"},G=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"}},ys={class:"language-bash vp-adaptive-theme"},hs=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"},Cs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),gs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ts=s("span",{style:{color:"#9ECBFF"}},"download-genesis",-1),bs=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),Ps={style:{color:"#032F62"}},qs={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),Os={style:{color:"#9ECBFF"}},Ms={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),Ys=s("span",{style:{color:"#032F62"}},"download-genesis",-1),Xs=s("span",{style:{color:"#24292E"}}," ",-1),js={style:{color:"#032F62"}},Us=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),Zs={class:"blocks"},Gs={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"},yo=o("",6),ho={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),Co=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),go=s("span",{class:"line"},[s("span",{style:{color:"#005CC5"}},"echo"),s("span",{style:{color:"#24292E"}}," $SEEDS")],-1),To=o("",1),bo={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),Po=s("span",{style:{color:"#9ECBFF"}}," ",-1),qo=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),Oo=s("span",{style:{color:"#032F62"}}," ",-1),Mo=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),Yo=o("",1),Xo=o("",3),jo={class:"vp-code-group vp-adaptive-theme"},Uo=o("",1),Jo={class:"blocks"},Ko={class:"language-bash vp-adaptive-theme active"},Zo=s("button",{title:"Copy Code",class:"copy"},null,-1),Go=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"},ya=s("button",{title:"Copy Code",class:"copy"},null,-1),ha=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o("",6),Ca={style:{color:"#9ECBFF"}},ga=s("span",{style:{color:"#F97583"}},"|",-1),Ta=s("span",{style:{color:"#9ECBFF"}}," ",-1),ba=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"}},Pa=s("span",{style:{color:"#D73A49"}},"|",-1),qa=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"},Oa={class:"line"},Ma=o("",6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Qa=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ya=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),Ua=o("",1),Ja={class:"shiki github-light vp-code-light"},Ka={class:"line"},Za=o("",6),Ga={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("",33),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),ye=o("",1),he=o("",1),Ee=o("",1),ue={class:"line"},Fe=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ce=s("span",{style:{color:"#B392F0"}},"egrep",-1),ge=s("span",{style:{color:"#9ECBFF"}}," ",-1),Te=s("span",{style:{color:"#79B8FF"}},"-o",-1),be={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),Pe=o("",1),qe={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),Oe={class:"language-bash vp-adaptive-theme"},Me=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),Ye=o("",1),Xe=o("",1),je=o("",1),Ue={class:"line"},Je=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ke=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ze=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ge=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),yn={style:{color:"#032F62"}},hn=o("",6),En=o("",1),un=o("",1),Fn={class:"language-bash vp-adaptive-theme"},Cn=s("button",{title:"Copy Code",class:"copy"},null,-1),gn=s("span",{class:"lang"},"bash",-1),Tn={class:"shiki github-dark vp-code-dark"},bn=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),Pn=s("span",{style:{color:"#79B8FF"}},"-o",-1),qn={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),On={class:"line"},Mn=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),Yn={style:{color:"#032F62"}},Xn=o("",6),jn=o("",1),Un=o("",1),Jn=o("",41),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",{"name":"og:title","content":"Consensus node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/consensus-node.md","filePath":"nodes/consensus-node.md","lastUpdated":1724867275000}'),Kn={name:"nodes/consensus-node.md"},at=Object.assign(Kn,{setup(Zn){return(Gn,zn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",y,[h,E,s("pre",u,[s("code",null,[s("span",F,[C,s("span",g,n(t(e).mainnetChainId),1)])])]),s("pre",T,[s("code",null,[s("span",b,[m,s("span",S,n(t(e).mainnetChainId),1)])])])]),s("div",v,[k,B,s("pre",A,[s("code",null,[s("span",f,[P,s("span",q,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",O,[M,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",Q,[Y,s("span",X,n(t(e).arabicaChainId),1)])])])])])]),j,s("div",U,[J,s("div",K,[s("div",Z,[G,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",ys,[hs,Es,s("pre",us,[s("code",null,[s("span",Fs,[Cs,gs,Ts,bs,s("span",ms,n(t(e).mochaChainId),1)])])]),s("pre",Ss,[s("code",null,[s("span",vs,[ks,Bs,As,fs,s("span",Ps,n(t(e).mochaChainId),1)])])])]),s("div",qs,[Is,xs,s("pre",Vs,[s("code",null,[s("span",Rs,[Ds,ws,Ns,$s,s("span",Os,n(t(e).arabicaChainId),1)])])]),s("pre",Ms,[s("code",null,[s("span",Hs,[Ls,Qs,Ys,Xs,s("span",js,n(t(e).arabicaChainId),1)])])])])])]),Us,s("div",Js,[Ks,s("div",Zs,[s("div",Gs,[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.295fc0ab.js";import{o as l,c as p,k as s,t as n,l as t,a,Q as o}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/img/nodes/consensus-node.jpg",r=o("",14),i={class:"vp-code-group vp-adaptive-theme"},d=o("",1),_={class:"blocks"},y={class:"language-bash vp-adaptive-theme active"},h=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"},C=o("",8),g={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"},O={class:"line"},M=o("",8),H={style:{color:"#9ECBFF"}},L={class:"shiki github-light vp-code-light"},G={class:"line"},j=o("",8),z={style:{color:"#032F62"}},Q=s("p",null,[a("Download the "),s("code",null,"genesis.json"),a(" file:")],-1),U={class:"vp-code-group vp-adaptive-theme"},J=o("",1),X={class:"blocks"},K={class:"language-bash vp-adaptive-theme active"},W=s("button",{title:"Copy Code",class:"copy"},null,-1),Y=s("span",{class:"lang"},"bash",-1),Z={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"}},ys={class:"language-bash vp-adaptive-theme"},hs=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"},Cs=s("span",{style:{color:"#B392F0"}},"celestia-appd",-1),gs=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),Os={style:{color:"#9ECBFF"}},Ms={class:"shiki github-light vp-code-light"},Hs={class:"line"},Ls=s("span",{style:{color:"#6F42C1"}},"celestia-appd",-1),Gs=s("span",{style:{color:"#24292E"}}," ",-1),js=s("span",{style:{color:"#032F62"}},"download-genesis",-1),zs=s("span",{style:{color:"#24292E"}}," ",-1),Qs={style:{color:"#032F62"}},Us=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"},Xs=o("",1),Ks={class:"blocks"},Ws={class:"language-bash vp-adaptive-theme active"},Ys=s("button",{title:"Copy Code",class:"copy"},null,-1),Zs=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"},yo=o("",6),ho={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),Co=s("span",{style:{color:"#032F62"}}," '\\n' ',')",-1),go=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),Oo=s("span",{style:{color:"#032F62"}}," ",-1),Mo=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),Go=o("",1),jo=o("",1),zo=o("",3),Qo={class:"vp-code-group vp-adaptive-theme"},Uo=o("",1),Jo={class:"blocks"},Xo={class:"language-bash vp-adaptive-theme active"},Ko=s("button",{title:"Copy Code",class:"copy"},null,-1),Wo=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},Zo={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"},ya=s("button",{title:"Copy Code",class:"copy"},null,-1),ha=s("span",{class:"lang"},"bash",-1),Ea={class:"shiki github-dark vp-code-dark"},ua={class:"line"},Fa=o("",6),Ca={style:{color:"#9ECBFF"}},ga=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"},Oa={class:"line"},Ma=o("",6),Ha={style:{color:"#9ECBFF"}},La=s("span",{style:{color:"#F97583"}},"|",-1),Ga=s("span",{style:{color:"#9ECBFF"}}," ",-1),ja=s("span",{style:{color:"#B392F0"}},"tr",-1),za=s("span",{style:{color:"#9ECBFF"}}," '\\n' ',')",-1),Qa=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"echo"),s("span",{style:{color:"#E1E4E8"}}," $PERSISTENT_PEERS")],-1),Ua=o("",1),Ja={class:"shiki github-light vp-code-light"},Xa={class:"line"},Ka=o("",6),Wa={style:{color:"#032F62"}},Ya=s("span",{style:{color:"#D73A49"}},"|",-1),Za=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("",33),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),ye=o("",1),he=o("",1),Ee=o("",1),ue={class:"line"},Fe=s("span",{style:{color:"#9ECBFF"}}," ",-1),Ce=s("span",{style:{color:"#B392F0"}},"egrep",-1),ge=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),Oe={class:"language-bash vp-adaptive-theme"},Me=s("button",{title:"Copy Code",class:"copy"},null,-1),He=s("span",{class:"lang"},"bash",-1),Le={class:"shiki github-dark vp-code-dark"},Ge=s("span",{class:"line"},[s("span",{style:{color:"#79B8FF"}},"cd"),s("span",{style:{color:"#E1E4E8"}}," $HOME")],-1),je=o("",1),ze=o("",1),Qe=o("",1),Ue={class:"line"},Je=s("span",{style:{color:"#9ECBFF"}}," ",-1),Xe=s("span",{style:{color:"#B392F0"}},"egrep",-1),Ke=s("span",{style:{color:"#9ECBFF"}}," ",-1),We=s("span",{style:{color:"#79B8FF"}},"-o",-1),Ye={style:{color:"#9ECBFF"}},Ze=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),yn={style:{color:"#032F62"}},hn=o("",6),En=o("",1),un=o("",1),Fn={class:"language-bash vp-adaptive-theme"},Cn=s("button",{title:"Copy Code",class:"copy"},null,-1),gn=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),On={class:"line"},Mn=s("span",{style:{color:"#032F62"}}," ",-1),Hn=s("span",{style:{color:"#6F42C1"}},"egrep",-1),Ln=s("span",{style:{color:"#032F62"}}," ",-1),Gn=s("span",{style:{color:"#005CC5"}},"-o",-1),jn={style:{color:"#032F62"}},zn=o("",6),Qn=o("",1),Un=o("",1),Jn=o("",41),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",{"name":"og:title","content":"Consensus node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/consensus-node.md","filePath":"nodes/consensus-node.md","lastUpdated":1725955670000}'),Xn={name:"nodes/consensus-node.md"},at=Object.assign(Xn,{setup(Kn){return(Wn,Yn)=>(l(),p("div",null,[r,s("div",i,[d,s("div",_,[s("div",y,[h,E,s("pre",u,[s("code",null,[s("span",F,[C,s("span",g,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",O,[M,s("span",H,n(t(e).arabicaChainId),1)])])]),s("pre",L,[s("code",null,[s("span",G,[j,s("span",z,n(t(e).arabicaChainId),1)])])])])])]),Q,s("div",U,[J,s("div",X,[s("div",K,[W,Y,s("pre",Z,[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",ys,[hs,Es,s("pre",us,[s("code",null,[s("span",Fs,[Cs,gs,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",Os,n(t(e).arabicaChainId),1)])])]),s("pre",Ms,[s("code",null,[s("span",Hs,[Ls,Gs,js,zs,s("span",Qs,n(t(e).arabicaChainId),1)])])])])])]),Us,s("div",Js,[Xs,s("div",Ks,[s("div",Ws,[Ys,Zs,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,[yo,s("span",ho," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mainnetChainId)+"/seeds.txt ",1),Eo,uo,Fo,Co]),a(` `),go,a(` -`),To])])]),s("div",bo,[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,Po,qo,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,Oo,Mo,Ho]),a(` `),Lo,a(` -`),Qo])])]),Yo])]),s("details",null,[Xo,s("div",jo,[Uo,s("div",Jo,[s("div",Ko,[Zo,Go,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(` +`),Go])])]),jo])]),s("details",null,[zo,s("div",Qo,[Uo,s("div",Jo,[s("div",Xo,[Ko,Wo,s("pre",Yo,[s("code",null,[s("span",Zo,[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,[ya,ha,s("pre",Ea,[s("code",null,[s("span",ua,[Fa,s("span",Ca," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),ga,Ta,ba,ma]),a(` +`),da])])]),s("div",_a,[ya,ha,s("pre",Ea,[s("code",null,[s("span",ua,[Fa,s("span",Ca," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).mochaChainId)+"/peers.txt ",1),ga,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),Pa,qa,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",Oa,[Ma,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Qa,Ya,Xa]),a(` -`),ja,a(` -`),Ua])]),s("pre",Ja,[s("code",null,[s("span",Ka,[Za,s("span",Ga," 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",Oa,[Ma,s("span",Ha," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),La,Ga,ja,za]),a(` +`),Qa,a(` +`),Ua])]),s("pre",Ja,[s("code",null,[s("span",Xa,[Ka,s("span",Wa," https://raw.githubusercontent.com/celestiaorg/networks/master/"+n(t(e).arabicaChainId)+"/peers.txt ",1),Ya,Za,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(` `),ye,a(` `),he,a(` `),Ee,a(` -`),s("span",ue,[Fe,Ce,ge,Te,s("span",be,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),me]),a(` +`),s("span",ue,[Fe,Ce,ge,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(` -`),Pe,a(` -`),s("span",qe,[Ie,xe,Ve,Re,s("span",De,' ">'+n(t(e).mainnetChainId)+'.*tar" ',1),we]),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",Oe,[Me,He,s("pre",Le,[s("code",null,[Qe,a(` -`),Ye,a(` -`),Xe,a(` +`),$e])])]),s("div",Oe,[Me,He,s("pre",Le,[s("code",null,[Ge,a(` `),je,a(` -`),s("span",Ue,[Je,Ke,Ze,Ge,s("span",ze,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),We]),a(` +`),ze,a(` +`),Qe,a(` +`),s("span",Ue,[Je,Xe,Ke,We,s("span",Ye,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),Ze]),a(` `),sn,a(` `),on])]),s("pre",an,[s("code",null,[en,a(` `),nn,a(` @@ -42,16 +42,16 @@ import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,t `),ln,a(` `),s("span",pn,[cn,rn,dn,_n,s("span",yn,' ">'+n(t(e).mochaChainId)+'.*tar" ',1),hn]),a(` `),En,a(` -`),un])])]),s("div",Fn,[Cn,gn,s("pre",Tn,[s("code",null,[bn,a(` +`),un])])]),s("div",Fn,[Cn,gn,s("pre",bn,[s("code",null,[Tn,a(` `),mn,a(` `),Sn,a(` `),vn,a(` -`),s("span",kn,[Bn,An,fn,Pn,s("span",qn,' ">'+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",On,[Mn,Hn,Ln,Qn,s("span",Yn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),Xn]),a(` -`),jn,a(` +`),s("span",On,[Mn,Hn,Ln,Gn,s("span",jn,' ">'+n(t(e).arabicaChainId)+'.*tar" ',1),zn]),a(` +`),Qn,a(` `),Un])])])])]),Jn]))}});export{ot as __pageData,at as default}; diff --git a/pr-1680/assets/nodes_decide-node.md.e2cf48f2.js b/pr-1680/assets/nodes_decide-node.md.1303eb5d.js similarity index 96% rename from pr-1680/assets/nodes_decide-node.md.e2cf48f2.js rename to pr-1680/assets/nodes_decide-node.md.1303eb5d.js index 0ae07112c2..bfc57cbc5f 100644 --- a/pr-1680/assets/nodes_decide-node.md.e2cf48f2.js +++ b/pr-1680/assets/nodes_decide-node.md.1303eb5d.js @@ -1 +1 @@ -import{_ as e,o as n,c as o,Q as a}from"./chunks/framework.a504a440.js";const _=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",{"name":"og:title","content":"Deciding which node to run | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/decide-node.md","filePath":"nodes/decide-node.md","lastUpdated":1724867275000}'),t={name:"nodes/decide-node.md"},i=a('

        Deciding which node to run

        Now that you have installed the basic dependencies, you can start exploring which nodes to run!

        Beginner

        It is highly recommended if you are a beginner to get started with running a Data-Availability light node.

        In order to get started, you can proceed to the light node section.

        You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

        Advanced

        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.

        ',9),d=[i];function r(c,h,s,l,u,p){return n(),o("div",null,d)}const f=e(t,[["render",r]]);export{_ as __pageData,f as default}; +import{_ as e,o as n,c as o,Q as a}from"./chunks/framework.a504a440.js";const _=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",{"name":"og:title","content":"Deciding which node to run | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/decide-node.md","filePath":"nodes/decide-node.md","lastUpdated":1725955670000}'),t={name:"nodes/decide-node.md"},i=a('

        Deciding which node to run

        Now that you have installed the basic dependencies, you can start exploring which nodes to run!

        Beginner

        It is highly recommended if you are a beginner to get started with running a Data-Availability light node.

        In order to get started, you can proceed to the light node section.

        You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

        Advanced

        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.

        ',9),d=[i];function r(c,h,s,l,u,p){return n(),o("div",null,d)}const f=e(t,[["render",r]]);export{_ as __pageData,f as default}; diff --git a/pr-1680/assets/nodes_decide-node.md.e2cf48f2.lean.js b/pr-1680/assets/nodes_decide-node.md.1303eb5d.lean.js similarity index 90% rename from pr-1680/assets/nodes_decide-node.md.e2cf48f2.lean.js rename to pr-1680/assets/nodes_decide-node.md.1303eb5d.lean.js index 5713668cbf..26764bb932 100644 --- a/pr-1680/assets/nodes_decide-node.md.e2cf48f2.lean.js +++ b/pr-1680/assets/nodes_decide-node.md.1303eb5d.lean.js @@ -1 +1 @@ -import{_ as e,o as n,c as o,Q as a}from"./chunks/framework.a504a440.js";const _=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",{"name":"og:title","content":"Deciding which node to run | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/decide-node.md","filePath":"nodes/decide-node.md","lastUpdated":1724867275000}'),t={name:"nodes/decide-node.md"},i=a("",9),d=[i];function r(c,h,s,l,u,p){return n(),o("div",null,d)}const f=e(t,[["render",r]]);export{_ as __pageData,f as default}; +import{_ as e,o as n,c as o,Q as a}from"./chunks/framework.a504a440.js";const _=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",{"name":"og:title","content":"Deciding which node to run | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/decide-node.md","filePath":"nodes/decide-node.md","lastUpdated":1725955670000}'),t={name:"nodes/decide-node.md"},i=a("",9),d=[i];function r(c,h,s,l,u,p){return n(),o("div",null,d)}const f=e(t,[["render",r]]);export{_ as __pageData,f as default}; diff --git a/pr-1680/assets/nodes_docker-images.md.cd1555b9.js b/pr-1680/assets/nodes_docker-images.md.8cee5aaa.js similarity index 88% rename from pr-1680/assets/nodes_docker-images.md.cd1555b9.js rename to pr-1680/assets/nodes_docker-images.md.8cee5aaa.js index 9dec3cbc13..84a2b78f3a 100644 --- a/pr-1680/assets/nodes_docker-images.md.cd1555b9.js +++ b/pr-1680/assets/nodes_docker-images.md.8cee5aaa.js @@ -1,34 +1,34 @@ -import{a as l}from"./chunks/arabica_versions.6d89be6e.js";import{m as t}from"./chunks/mocha_versions.ffd4ea25.js";import{m as p}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.a504a440.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('
      46. 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
      47. 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
      48. 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
      49. ',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"},B=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),N={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),K=s("span",{class:"lang"},"bash",-1),w={class:"shiki github-dark vp-code-dark"},W=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Y={class:"line"},x=s("span",{style:{color:"#E1E4E8"}}," ",-1),M={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"},G=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Q={class:"line"},j=s("span",{style:{color:"#24292E"}}," ",-1),z={style:{color:"#032F62"}},X=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.1930378b.js";import{m as t}from"./chunks/mocha_versions.7704b055.js";import{m as p}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.a504a440.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('
      50. 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
      51. 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
      52. 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
      53. ',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),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),K=s("span",{class:"lang"},"bash",-1),w={class:"shiki github-dark vp-code-dark"},W=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Y={class:"line"},x=s("span",{style:{color:"#E1E4E8"}}," ",-1),M={style:{color:"#9ECBFF"}},L=s("span",{style:{color:"#E1E4E8"}}," ",-1),H=s("span",{style:{color:"#79B8FF"}},"\\",-1),q=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),Q={class:"line"},j=s("span",{style:{color:"#24292E"}}," ",-1),J={style:{color:"#032F62"}},Z=s("span",{style:{color:"#24292E"}}," ",-1),X=s("span",{style:{color:"#005CC5"}},"\\",-1),G=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),Bs=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ns={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),Ks=o(' -v $HOME/my-node-store:/home/celestia \\',1),ws={class:"line"},Ws=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},xs=s("span",{style:{color:"#24292E"}}," ",-1),Ms=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),Gs={class:"shiki github-dark vp-code-dark"},Qs=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),js=o(' -v $HOME/my-node-store:/home/celestia \\',1),zs={class:"line"},Xs=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"},Bo=s("span",{style:{color:"#24292E"}}," ",-1),No={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"},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),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),Ks=o(' -v $HOME/my-node-store:/home/celestia \\',1),ws={class:"line"},Ws=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},xs=s("span",{style:{color:"#24292E"}}," ",-1),Ms=s("span",{style:{color:"#005CC5"}},"\\",-1),Ls=o(' celestia light init --p2p.network $NETWORK',1),Hs={class:"language-bash vp-adaptive-theme"},qs=s("button",{title:"Copy Code",class:"copy"},null,-1),Us=s("span",{class:"lang"},"bash",-1),zs={class:"shiki github-dark vp-code-dark"},Qs=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),js=o(' -v $HOME/my-node-store:/home/celestia \\',1),Js={class:"line"},Zs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Xs={style:{color:"#9ECBFF"}},Gs=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),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"},Ko={class:"language-bash vp-adaptive-theme active"},wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Wo=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},xo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Mo=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),Go=s("span",{style:{color:"#79B8FF"}},"\\",-1),Qo=o(' celestia light start --core.ip $RPC_URL',1),jo={class:"shiki github-light vp-code-light"},zo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Xo=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',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',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',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),Ba={class:"shiki github-dark vp-code-dark"},Na=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',1),Ka={class:"shiki github-light vp-code-light"},wa=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Wa=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ya={class:"line"},xa=s("span",{style:{color:"#24292E"}}," ",-1),Ma={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',1),Ua=s("p",null,"Congratulations! You now have a node running with persistent storage.",-1),Ga=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),ja=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),Xa=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 the 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",{"name":"og:title","content":"🐳 Docker setup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/docker-images.md","filePath":"nodes/docker-images.md","lastUpdated":1724867275000}'),Za={name:"nodes/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(` + 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"},Ko={class:"language-bash vp-adaptive-theme active"},wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Wo=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},xo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Mo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Lo={class:"line"},Ho=s("span",{style:{color:"#E1E4E8"}}," ",-1),qo={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),zo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Qo=o(' celestia light start --core.ip $RPC_URL',1),jo={class:"shiki github-light vp-code-light"},Jo=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Zo=o(' -v $HOME/my-node-store:/home/celestia \\',1),Xo={class:"line"},Go=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',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',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',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),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',1),Ka={class:"shiki github-light vp-code-light"},wa=o('docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \\',1),Wa=o(' -v $HOME/my-node-store:/home/celestia \\',1),Ya={class:"line"},xa=s("span",{style:{color:"#24292E"}}," ",-1),Ma={style:{color:"#032F62"}},La=s("span",{style:{color:"#24292E"}}," ",-1),Ha=s("span",{style:{color:"#005CC5"}},"\\",-1),qa=o(' celestia light start --core.ip $RPC_URL',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),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),ja=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),Ja=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/ROZv871Q7RM",allowfullscreen:""})],-1),Za=s("h2",{id:"troubleshooting",tabindex:"-1"},[a("Troubleshooting "),s("a",{class:"header-anchor",href:"#troubleshooting","aria-label":'Permalink to "Troubleshooting"'},"​")],-1),Xa=s("p",null,[a("For security purposes Celestia expects to interact with the 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",{"name":"og:title","content":"🐳 Docker setup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/docker-images.md","filePath":"nodes/docker-images.md","lastUpdated":1725955670000}'),Ga={name:"nodes/docker-images.md"},cn=Object.assign(Ga,{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(` -`),A])]),s("pre",S,[s("code",null,[B,a(` -`),s("span",N,[D,s("span",R,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),O,V]),a(` -`),I])])]),s("div",f,[$,K,s("pre",w,[s("code",null,[W,a(` -`),s("span",Y,[x,s("span",M,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),L,q]),a(` -`),H])]),s("pre",U,[s("code",null,[G,a(` -`),s("span",Q,[j,s("span",z,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),X,J]),a(` -`),Z])])]),s("div",ss,[os,as,s("pre",ns,[s("code",null,[es,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,I]),a(` +`),V])])]),s("div",f,[$,K,s("pre",w,[s("code",null,[W,a(` +`),s("span",Y,[x,s("span",M,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),L,H]),a(` +`),q])]),s("pre",U,[s("code",null,[z,a(` +`),s("span",Q,[j,s("span",J,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Z,X]),a(` +`),G])])]),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(` -`),Bs,a(` -`),s("span",Ns,[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(` +`),Ns,a(` +`),s("span",Bs,[Ds,s("span",Rs,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Os,Is]),a(` +`),Vs])]),s("pre",fs,[s("code",null,[$s,a(` `),Ks,a(` `),s("span",ws,[Ws,s("span",Ys,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),xs,Ms]),a(` -`),Ls])])]),s("div",qs,[Hs,Us,s("pre",Gs,[s("code",null,[Qs,a(` +`),Ls])])]),s("div",Hs,[qs,Us,s("pre",zs,[s("code",null,[Qs,a(` `),js,a(` -`),s("span",zs,[Xs,s("span",Js,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Zs,so]),a(` +`),s("span",Js,[Zs,s("span",Xs,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Gs,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(` @@ -37,23 +37,23 @@ import{a as l}from"./chunks/arabica_versions.6d89be6e.js";import{m as t}from"./c `),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(` `),Ao,a(` -`),s("span",So,[Bo,s("span",No,"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",Ko,[wo,Wo,s("pre",Yo,[s("code",null,[xo,a(` +`),s("span",So,[No,s("span",Bo,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Do,Ro]),a(` +`),Oo])])])])]),Io,s("div",Vo,[fo,s("div",$o,[s("div",Ko,[wo,Wo,s("pre",Yo,[s("code",null,[xo,a(` `),Mo,a(` -`),s("span",Lo,[qo,s("span",Ho,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,Go]),a(` -`),Qo])]),s("pre",jo,[s("code",null,[zo,a(` -`),Xo,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,[Ho,s("span",qo,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,zo]),a(` +`),Qo])]),s("pre",jo,[s("code",null,[Jo,a(` +`),Zo,a(` +`),s("span",Xo,[Go,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",Ba,[s("code",null,[Na,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",Ra,[Oa,s("span",Ia,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Va,fa]),a(` `),$a])]),s("pre",Ka,[s("code",null,[wa,a(` `),Wa,a(` -`),s("span",Ya,[xa,s("span",Ma,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),La,qa]),a(` -`),Ha])])])])]),Ua,Ga,Qa,ja,za,Xa,Ja]))}});export{pn as __pageData,cn as default}; +`),s("span",Ya,[xa,s("span",Ma,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),La,Ha]),a(` +`),qa])])])])]),Ua,za,Qa,ja,Ja,Za,Xa]))}});export{pn as __pageData,cn as default}; diff --git a/pr-1680/assets/nodes_docker-images.md.cd1555b9.lean.js b/pr-1680/assets/nodes_docker-images.md.8cee5aaa.lean.js similarity index 67% rename from pr-1680/assets/nodes_docker-images.md.cd1555b9.lean.js rename to pr-1680/assets/nodes_docker-images.md.8cee5aaa.lean.js index bccc1fb8a1..81d5f6e371 100644 --- a/pr-1680/assets/nodes_docker-images.md.cd1555b9.lean.js +++ b/pr-1680/assets/nodes_docker-images.md.8cee5aaa.lean.js @@ -1,24 +1,24 @@ -import{a as l}from"./chunks/arabica_versions.6d89be6e.js";import{m as t}from"./chunks/mocha_versions.ffd4ea25.js";import{m as p}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.a504a440.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"},B=o("",1),N={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),K=s("span",{class:"lang"},"bash",-1),w={class:"shiki github-dark vp-code-dark"},W=o("",1),Y={class:"line"},x=s("span",{style:{color:"#E1E4E8"}}," ",-1),M={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"},G=o("",1),Q={class:"line"},j=s("span",{style:{color:"#24292E"}}," ",-1),z={style:{color:"#032F62"}},X=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),Bs=o("",1),Ns={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),Ks=o("",1),ws={class:"line"},Ws=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},xs=s("span",{style:{color:"#24292E"}}," ",-1),Ms=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),Gs={class:"shiki github-dark vp-code-dark"},Qs=o("",1),js=o("",1),zs={class:"line"},Xs=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"},Bo=s("span",{style:{color:"#24292E"}}," ",-1),No={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"},Ko={class:"language-bash vp-adaptive-theme active"},wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Wo=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},xo=o("",1),Mo=o("",1),Lo={class:"line"},qo=s("span",{style:{color:"#E1E4E8"}}," ",-1),Ho={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),Go=s("span",{style:{color:"#79B8FF"}},"\\",-1),Qo=o("",1),jo={class:"shiki github-light vp-code-light"},zo=o("",1),Xo=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),Ba={class:"shiki github-dark vp-code-dark"},Na=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),Ka={class:"shiki github-light vp-code-light"},wa=o("",1),Wa=o("",1),Ya={class:"line"},xa=s("span",{style:{color:"#24292E"}}," ",-1),Ma={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),Ga=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),ja=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),Xa=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 the 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",{"name":"og:title","content":"🐳 Docker setup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/docker-images.md","filePath":"nodes/docker-images.md","lastUpdated":1724867275000}'),Za={name:"nodes/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(` +import{a as l}from"./chunks/arabica_versions.1930378b.js";import{m as t}from"./chunks/mocha_versions.7704b055.js";import{m as p}from"./chunks/mainnet_versions.1d5e6ed9.js";import{o as c,c as r,k as s,a,t as n,l as e,Q as o}from"./chunks/framework.a504a440.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),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),K=s("span",{class:"lang"},"bash",-1),w={class:"shiki github-dark vp-code-dark"},W=o("",1),Y={class:"line"},x=s("span",{style:{color:"#E1E4E8"}}," ",-1),M={style:{color:"#9ECBFF"}},L=s("span",{style:{color:"#E1E4E8"}}," ",-1),H=s("span",{style:{color:"#79B8FF"}},"\\",-1),q=o("",1),U={class:"shiki github-light vp-code-light"},z=o("",1),Q={class:"line"},j=s("span",{style:{color:"#24292E"}}," ",-1),J={style:{color:"#032F62"}},Z=s("span",{style:{color:"#24292E"}}," ",-1),X=s("span",{style:{color:"#005CC5"}},"\\",-1),G=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),Is=s("span",{style:{color:"#79B8FF"}},"\\",-1),Vs=o("",1),fs={class:"shiki github-light vp-code-light"},$s=o("",1),Ks=o("",1),ws={class:"line"},Ws=s("span",{style:{color:"#24292E"}}," ",-1),Ys={style:{color:"#032F62"}},xs=s("span",{style:{color:"#24292E"}}," ",-1),Ms=s("span",{style:{color:"#005CC5"}},"\\",-1),Ls=o("",1),Hs={class:"language-bash vp-adaptive-theme"},qs=s("button",{title:"Copy Code",class:"copy"},null,-1),Us=s("span",{class:"lang"},"bash",-1),zs={class:"shiki github-dark vp-code-dark"},Qs=o("",1),js=o("",1),Js={class:"line"},Zs=s("span",{style:{color:"#E1E4E8"}}," ",-1),Xs={style:{color:"#9ECBFF"}},Gs=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),Io=o("",4),Vo={class:"vp-code-group vp-adaptive-theme"},fo=o("",1),$o={class:"blocks"},Ko={class:"language-bash vp-adaptive-theme active"},wo=s("button",{title:"Copy Code",class:"copy"},null,-1),Wo=s("span",{class:"lang"},"bash",-1),Yo={class:"shiki github-dark vp-code-dark"},xo=o("",1),Mo=o("",1),Lo={class:"line"},Ho=s("span",{style:{color:"#E1E4E8"}}," ",-1),qo={style:{color:"#9ECBFF"}},Uo=s("span",{style:{color:"#E1E4E8"}}," ",-1),zo=s("span",{style:{color:"#79B8FF"}},"\\",-1),Qo=o("",1),jo={class:"shiki github-light vp-code-light"},Jo=o("",1),Zo=o("",1),Xo={class:"line"},Go=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),Ia={style:{color:"#9ECBFF"}},Va=s("span",{style:{color:"#E1E4E8"}}," ",-1),fa=s("span",{style:{color:"#79B8FF"}},"\\",-1),$a=o("",1),Ka={class:"shiki github-light vp-code-light"},wa=o("",1),Wa=o("",1),Ya={class:"line"},xa=s("span",{style:{color:"#24292E"}}," ",-1),Ma={style:{color:"#032F62"}},La=s("span",{style:{color:"#24292E"}}," ",-1),Ha=s("span",{style:{color:"#005CC5"}},"\\",-1),qa=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),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),ja=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),Ja=s("div",{class:"youtube-wrapper"},[s("iframe",{class:"youtube-video",title:"Running a Celestia light node",src:"https://youtube.com/embed/ROZv871Q7RM",allowfullscreen:""})],-1),Za=s("h2",{id:"troubleshooting",tabindex:"-1"},[a("Troubleshooting "),s("a",{class:"header-anchor",href:"#troubleshooting","aria-label":'Permalink to "Troubleshooting"'},"​")],-1),Xa=s("p",null,[a("For security purposes Celestia expects to interact with the 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",{"name":"og:title","content":"🐳 Docker setup | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/docker-images.md","filePath":"nodes/docker-images.md","lastUpdated":1725955670000}'),Ga={name:"nodes/docker-images.md"},cn=Object.assign(Ga,{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(` -`),A])]),s("pre",S,[s("code",null,[B,a(` -`),s("span",N,[D,s("span",R,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),O,V]),a(` -`),I])])]),s("div",f,[$,K,s("pre",w,[s("code",null,[W,a(` -`),s("span",Y,[x,s("span",M,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),L,q]),a(` -`),H])]),s("pre",U,[s("code",null,[G,a(` -`),s("span",Q,[j,s("span",z,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),X,J]),a(` -`),Z])])]),s("div",ss,[os,as,s("pre",ns,[s("code",null,[es,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,I]),a(` +`),V])])]),s("div",f,[$,K,s("pre",w,[s("code",null,[W,a(` +`),s("span",Y,[x,s("span",M,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),L,H]),a(` +`),q])]),s("pre",U,[s("code",null,[z,a(` +`),s("span",Q,[j,s("span",J,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Z,X]),a(` +`),G])])]),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(` -`),Bs,a(` -`),s("span",Ns,[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(` +`),Ns,a(` +`),s("span",Bs,[Ds,s("span",Rs,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Os,Is]),a(` +`),Vs])]),s("pre",fs,[s("code",null,[$s,a(` `),Ks,a(` `),s("span",ws,[Ws,s("span",Ys,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),xs,Ms]),a(` -`),Ls])])]),s("div",qs,[Hs,Us,s("pre",Gs,[s("code",null,[Qs,a(` +`),Ls])])]),s("div",Hs,[qs,Us,s("pre",zs,[s("code",null,[Qs,a(` `),js,a(` -`),s("span",zs,[Xs,s("span",Js,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Zs,so]),a(` +`),s("span",Js,[Zs,s("span",Xs,"ghcr.io/celestiaorg/celestia-node:"+n(e(t)["node-latest-tag"]),1),Gs,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(` @@ -27,23 +27,23 @@ import{a as l}from"./chunks/arabica_versions.6d89be6e.js";import{m as t}from"./c `),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(` `),Ao,a(` -`),s("span",So,[Bo,s("span",No,"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",Ko,[wo,Wo,s("pre",Yo,[s("code",null,[xo,a(` +`),s("span",So,[No,s("span",Bo,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Do,Ro]),a(` +`),Oo])])])])]),Io,s("div",Vo,[fo,s("div",$o,[s("div",Ko,[wo,Wo,s("pre",Yo,[s("code",null,[xo,a(` `),Mo,a(` -`),s("span",Lo,[qo,s("span",Ho,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,Go]),a(` -`),Qo])]),s("pre",jo,[s("code",null,[zo,a(` -`),Xo,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,[Ho,s("span",qo,"ghcr.io/celestiaorg/celestia-node:"+n(e(p)["node-latest-tag"]),1),Uo,zo]),a(` +`),Qo])]),s("pre",jo,[s("code",null,[Jo,a(` +`),Zo,a(` +`),s("span",Xo,[Go,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",Ba,[s("code",null,[Na,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",Ra,[Oa,s("span",Ia,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),Va,fa]),a(` `),$a])]),s("pre",Ka,[s("code",null,[wa,a(` `),Wa,a(` -`),s("span",Ya,[xa,s("span",Ma,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),La,qa]),a(` -`),Ha])])])])]),Ua,Ga,Qa,ja,za,Xa,Ja]))}});export{pn as __pageData,cn as default}; +`),s("span",Ya,[xa,s("span",Ma,"ghcr.io/celestiaorg/celestia-node:"+n(e(l)["node-latest-tag"]),1),La,Ha]),a(` +`),qa])])])])]),Ua,za,Qa,ja,Ja,Za,Xa]))}});export{pn as __pageData,cn as default}; diff --git a/pr-1680/assets/nodes_environment.md.327a8dbd.lean.js b/pr-1680/assets/nodes_environment.md.327a8dbd.lean.js deleted file mode 100644 index 1412e38cb3..0000000000 --- a/pr-1680/assets/nodes_environment.md.327a8dbd.lean.js +++ /dev/null @@ -1 +0,0 @@ -import{c as a}from"./chunks/constants.0e6df566.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.a504a440.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"},H={class:"line"},A=s("span",{style:{color:"#E1E4E8"}},"ver",-1),M=s("span",{style:{color:"#F97583"}},"=",-1),z={style:{color:"#9ECBFF"}},T={class:"shiki github-light vp-code-light"},x={class:"line"},D=s("span",{style:{color:"#24292E"}},"ver",-1),S=s("span",{style:{color:"#D73A49"}},"=",-1),O={style:{color:"#032F62"}},P={class:"language-bash vp-adaptive-theme"},V=s("button",{title:"Copy Code",class:"copy"},null,-1),L=s("span",{class:"lang"},"bash",-1),G={class:"shiki github-dark vp-code-dark"},I={class:"line"},N=s("span",{style:{color:"#E1E4E8"}},"ver",-1),j=s("span",{style:{color:"#F97583"}},"=",-1),Q={style:{color:"#9ECBFF"}},J={class:"shiki github-light vp-code-light"},U={class:"line"},R=s("span",{style:{color:"#24292E"}},"ver",-1),K=s("span",{style:{color:"#D73A49"}},"=",-1),W={style:{color:"#032F62"}},X=l("",3),Z=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",{"name":"og:title","content":"Development environment | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/environment.md","filePath":"nodes/environment.md","lastUpdated":1724867275000}'),Y={name:"nodes/environment.md"},es=Object.assign(Y,{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",H,[A,M,s("span",z,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",T,[s("code",null,[s("span",x,[D,S,s("span",O,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",P,[V,L,s("pre",G,[s("code",null,[s("span",I,[N,j,s("span",Q,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",J,[s("code",null,[s("span",U,[R,K,s("span",W,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),X]),Z]))}});export{ps as __pageData,es as default}; diff --git a/pr-1680/assets/nodes_environment.md.327a8dbd.js b/pr-1680/assets/nodes_environment.md.3dbd31f9.js similarity index 90% rename from pr-1680/assets/nodes_environment.md.327a8dbd.js rename to pr-1680/assets/nodes_environment.md.3dbd31f9.js index b2cd10d4e9..ae6f3c0188 100644 --- a/pr-1680/assets/nodes_environment.md.327a8dbd.js +++ b/pr-1680/assets/nodes_environment.md.3dbd31f9.js @@ -1,4 +1,4 @@ -import{c as a}from"./chunks/constants.0e6df566.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.a504a440.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.295fc0ab.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.a504a440.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.0e6df566.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"},H={class:"line"},A=s("span",{style:{color:"#E1E4E8"}},"ver",-1),M=s("span",{style:{color:"#F97583"}},"=",-1),z={style:{color:"#9ECBFF"}},T={class:"shiki github-light vp-code-light"},x={class:"line"},D=s("span",{style:{color:"#24292E"}},"ver",-1),S=s("span",{style:{color:"#D73A49"}},"=",-1),O={style:{color:"#032F62"}},P={class:"language-bash vp-adaptive-theme"},V=s("button",{title:"Copy Code",class:"copy"},null,-1),L=s("span",{class:"lang"},"bash",-1),G={class:"shiki github-dark vp-code-dark"},I={class:"line"},N=s("span",{style:{color:"#E1E4E8"}},"ver",-1),j=s("span",{style:{color:"#F97583"}},"=",-1),Q={style:{color:"#9ECBFF"}},J={class:"shiki github-light vp-code-light"},U={class:"line"},R=s("span",{style:{color:"#24292E"}},"ver",-1),K=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"},B={class:"line"},m=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"},z=s("span",{style:{color:"#E1E4E8"}},"ver",-1),H=s("span",{style:{color:"#F97583"}},"=",-1),M={style:{color:"#9ECBFF"}},x={class:"shiki github-light vp-code-light"},T={class:"line"},O=s("span",{style:{color:"#24292E"}},"ver",-1),D=s("span",{style:{color:"#D73A49"}},"=",-1),P={style:{color:"#032F62"}},S={class:"language-bash vp-adaptive-theme"},I=s("button",{title:"Copy Code",class:"copy"},null,-1),N=s("span",{class:"lang"},"bash",-1),U={class:"shiki github-dark vp-code-dark"},j={class:"line"},Q=s("span",{style:{color:"#E1E4E8"}},"ver",-1),L=s("span",{style:{color:"#F97583"}},"=",-1),G={style:{color:"#9ECBFF"}},R={class:"shiki github-light vp-code-light"},V={class:"line"},Y=s("span",{style:{color:"#24292E"}},"ver",-1),J=s("span",{style:{color:"#D73A49"}},"=",-1),W={style:{color:"#032F62"}},Z=l(`
      54. 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.0e6df566.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"
      55. 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"
      56. 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!

      57. To verify that the correct version of Go was installed correctly run:

        bash
        go version
        go version
      58. `,3),Z=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",{"name":"og:title","content":"Development environment | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/environment.md","filePath":"nodes/environment.md","lastUpdated":1724867275000}'),Y={name:"nodes/environment.md"},es=Object.assign(Y,{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",H,[A,M,s("span",z,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",T,[s("code",null,[s("span",x,[D,S,s("span",O,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",P,[V,L,s("pre",G,[s("code",null,[s("span",I,[N,j,s("span",Q,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",J,[s("code",null,[s("span",U,[R,K,s("span",W,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),X]),Z]))}});export{ps as __pageData,es as default}; +source $HOME/.zshrc

        TIP

        Use echo $SHELL to figure out what type of shell you are using!

      59. To verify that the correct version of Go was installed correctly run:

        bash
        go version
        go version
      60. `,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",{"name":"og:title","content":"Development environment | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/environment.md","filePath":"nodes/environment.md","lastUpdated":1725955670000}'),X={name:"nodes/environment.md"},es=Object.assign(X,{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",B,[m,_,s("span",k,'"'+n(o(a).golangNodeMainnet)+'"',1)])])])]),s("div",q,[f,w,s("pre",$,[s("code",null,[s("span",A,[z,H,s("span",M,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",x,[s("code",null,[s("span",T,[O,D,s("span",P,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",S,[I,N,s("pre",U,[s("code",null,[s("span",j,[Q,L,s("span",G,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",R,[s("code",null,[s("span",V,[Y,J,s("span",W,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),Z]),K]))}});export{ps as __pageData,es as default}; diff --git a/pr-1680/assets/nodes_environment.md.3dbd31f9.lean.js b/pr-1680/assets/nodes_environment.md.3dbd31f9.lean.js new file mode 100644 index 0000000000..80671862c7 --- /dev/null +++ b/pr-1680/assets/nodes_environment.md.3dbd31f9.lean.js @@ -0,0 +1 @@ +import{c as a}from"./chunks/constants.295fc0ab.js";import{o as p,c as e,k as s,t as n,l as o,Q as l}from"./chunks/framework.a504a440.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"},B={class:"line"},m=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"},z=s("span",{style:{color:"#E1E4E8"}},"ver",-1),H=s("span",{style:{color:"#F97583"}},"=",-1),M={style:{color:"#9ECBFF"}},x={class:"shiki github-light vp-code-light"},T={class:"line"},O=s("span",{style:{color:"#24292E"}},"ver",-1),D=s("span",{style:{color:"#D73A49"}},"=",-1),P={style:{color:"#032F62"}},S={class:"language-bash vp-adaptive-theme"},I=s("button",{title:"Copy Code",class:"copy"},null,-1),N=s("span",{class:"lang"},"bash",-1),U={class:"shiki github-dark vp-code-dark"},j={class:"line"},Q=s("span",{style:{color:"#E1E4E8"}},"ver",-1),L=s("span",{style:{color:"#F97583"}},"=",-1),G={style:{color:"#9ECBFF"}},R={class:"shiki github-light vp-code-light"},V={class:"line"},Y=s("span",{style:{color:"#24292E"}},"ver",-1),J=s("span",{style:{color:"#D73A49"}},"=",-1),W={style:{color:"#032F62"}},Z=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",{"name":"og:title","content":"Development environment | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/environment.md","filePath":"nodes/environment.md","lastUpdated":1725955670000}'),X={name:"nodes/environment.md"},es=Object.assign(X,{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",B,[m,_,s("span",k,'"'+n(o(a).golangNodeMainnet)+'"',1)])])])]),s("div",q,[f,w,s("pre",$,[s("code",null,[s("span",A,[z,H,s("span",M,'"'+n(o(a).golangNodeMocha)+'"',1)])])]),s("pre",x,[s("code",null,[s("span",T,[O,D,s("span",P,'"'+n(o(a).golangNodeMocha)+'"',1)])])])]),s("div",S,[I,N,s("pre",U,[s("code",null,[s("span",j,[Q,L,s("span",G,'"'+n(o(a).golangNodeArabica)+'"',1)])])]),s("pre",R,[s("code",null,[s("span",V,[Y,J,s("span",W,'"'+n(o(a).golangNodeArabica)+'"',1)])])])])])])]),Z]),K]))}});export{ps as __pageData,es as default}; diff --git a/pr-1680/assets/nodes_full-storage-node.md.07a0c9a4.js b/pr-1680/assets/nodes_full-storage-node.md.b0ec8a5f.js similarity index 89% rename from pr-1680/assets/nodes_full-storage-node.md.07a0c9a4.js rename to pr-1680/assets/nodes_full-storage-node.md.b0ec8a5f.js index f8e968fb0e..39b70f6c33 100644 --- a/pr-1680/assets/nodes_full-storage-node.md.07a0c9a4.js +++ b/pr-1680/assets/nodes_full-storage-node.md.b0ec8a5f.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/full-storage-node.md","filePath":"nodes/full-storage-node.md","lastUpdated":1724867275000}'),n={name:"nodes/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: 10 TB SSD 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 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).

        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.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/full-storage-node.md","filePath":"nodes/full-storage-node.md","lastUpdated":1725955670000}'),n={name:"nodes/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: 10 TB SSD 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 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).

        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> \\
        @@ -8,4 +8,4 @@ import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.a504a440.js";const l=
           --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: 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.

        `,41),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}; + --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.

        `,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-1680/assets/nodes_full-storage-node.md.07a0c9a4.lean.js b/pr-1680/assets/nodes_full-storage-node.md.b0ec8a5f.lean.js similarity index 83% rename from pr-1680/assets/nodes_full-storage-node.md.07a0c9a4.lean.js rename to pr-1680/assets/nodes_full-storage-node.md.b0ec8a5f.lean.js index 7a513fa029..2672a686bf 100644 --- a/pr-1680/assets/nodes_full-storage-node.md.07a0c9a4.lean.js +++ b/pr-1680/assets/nodes_full-storage-node.md.b0ec8a5f.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as e,Q as o}from"./chunks/framework.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/full-storage-node.md","filePath":"nodes/full-storage-node.md","lastUpdated":1724867275000}'),n={name:"nodes/full-storage-node.md"},t=o("",41),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.a504a440.js";const l="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia full storage Node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/full-storage-node.md","filePath":"nodes/full-storage-node.md","lastUpdated":1725955670000}'),n={name:"nodes/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-1680/assets/nodes_hardfork-process.md.9c089234.js b/pr-1680/assets/nodes_hardfork-process.md.c86d1151.js similarity index 85% rename from pr-1680/assets/nodes_hardfork-process.md.9c089234.js rename to pr-1680/assets/nodes_hardfork-process.md.c86d1151.js index beb6a8395a..8b34f1f363 100644 --- a/pr-1680/assets/nodes_hardfork-process.md.9c089234.js +++ b/pr-1680/assets/nodes_hardfork-process.md.c86d1151.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia hardfork process","description":"Overview of the Celestia hardfork process.","frontmatter":{"description":"Overview of the Celestia hardfork process.","head":[["meta",{"name":"og:title","content":"Celestia hardfork process | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/hardfork-process.md","filePath":"nodes/hardfork-process.md","lastUpdated":1724867275000}'),o={name:"nodes/hardfork-process.md"},i=r('

        Celestia hardfork process

        Blockchain networks often times need to upgrade with new features which require coordination work among the validators prior to activating the upgrades.

        This process is called a hardfork or a network upgrade. In those events, the Celestia Labs team will be coordinating with the validators on what they need to do in order to be ready for an upcoming hardfork.

        Hardforks 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 after the network upgrades.

        General process

        The general process can be broken down into several components:

        • Hardfork specifications and features (defined by description of features and code implementation of those features).
        • Binary used to add those features (a new binary release with those features will be provided by Celestia team in order for validators to upgrade their nodes to the new binary).
        • A block number for when the network upgrades (even if validators upgrade their binary to be hardfork ready, the network upgrade does not happen right away, but some short time in the future at a specific block number).
        • Testing of the features (happens on testnets first prior to activating on mainnet in order to ensure the network can upgrade securely).

        The two testnets where hardforks are deployed are:

        Lemongrass hardfork

        The Lemongrass hardfork is the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass hardfork includes all of the CIPs listed in CIP-17. The Lemongrass hardfork will be executed on Arabica, then Mocha, then Mainnet Beta. The hardfork will take place at an "upgrade height" that will be coordinated offline on a per-network basis. The upgrade heights will be announced in advance (see Network upgrades) to give node operators time to download and start a compatible binary prior to the upgrade height.

        • If you are a consensus node or validator operator: you will need to download and run a celestia-app binary >= v2.0.0 prior to the --v2-upgrade-height to remain on the canonical chain. You do not need to use a tool like cosmovisor to upgrade the binary at the upgrade height.
        • If you are a DA node operator, you will need to download and run a compatible celestia-node binary >= v0.16.0-rc0 prior to the upgrade height.
        NetworkChain IDDatetime--v2-upgrade-height
        Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
        Mochamocha-42024/08/28 @ 14:00 UTC2585031
        Mainnet BetacelestiaTBD approximately 2024/09/18 @ 14:00 UTCTBD
        ',13),s=[i];function n(d,h,l,c,p,f){return t(),a("div",null,s)}const k=e(o,[["render",n]]);export{g as __pageData,k as default}; +import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia hardfork process","description":"Overview of the Celestia hardfork process.","frontmatter":{"description":"Overview of the Celestia hardfork process.","head":[["meta",{"name":"og:title","content":"Celestia hardfork process | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/hardfork-process.md","filePath":"nodes/hardfork-process.md","lastUpdated":1725955670000}'),o={name:"nodes/hardfork-process.md"},i=r('

        Celestia hardfork process

        Blockchain networks often times need to upgrade with new features which require coordination work among the validators prior to activating the upgrades.

        This process is called a hardfork or a network upgrade. In those events, the Celestia Labs team will be coordinating with the validators on what they need to do in order to be ready for an upcoming hardfork.

        Hardforks 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 after the network upgrades.

        General process

        The general process can be broken down into several components:

        • Hardfork specifications and features (defined by description of features and code implementation of those features).
        • Binary used to add those features (a new binary release with those features will be provided by Celestia team in order for validators to upgrade their nodes to the new binary).
        • A block number for when the network upgrades (even if validators upgrade their binary to be hardfork ready, the network upgrade does not happen right away, but some short time in the future at a specific block number).
        • Testing of the features (happens on testnets first prior to activating on mainnet in order to ensure the network can upgrade securely).

        The two testnets where hardforks are deployed are:

        Lemongrass hardfork

        The Lemongrass hardfork is the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass hardfork includes all of the CIPs listed in CIP-17. The Lemongrass hardfork will be executed on Arabica, then Mocha, then Mainnet Beta. The hardfork will take place at an "upgrade height" that will be coordinated offline on a per-network basis. The upgrade heights will be announced in advance (see Network upgrades) to give node operators time to download and start a compatible binary prior to the upgrade height.

        • If you are a consensus node or validator operator: you will need to download and run a celestia-app binary >= v2.0.0 prior to the --v2-upgrade-height to remain on the canonical chain. You do not need to use a tool like cosmovisor to upgrade the binary at the upgrade height.
        • If you are a DA node operator, you will need to download and run a compatible celestia-node binary >= v0.16.0-rc0 prior to the upgrade height.
        NetworkChain IDDate and approximate time--v2-upgrade-height
        Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
        Mochamocha-42024/08/28 @ 14:00 UTC2585031
        Mainnet Betacelestia2024/09/18 @ 14:00 UTC2371495
        ',13),s=[i];function n(d,h,l,c,p,f){return t(),a("div",null,s)}const k=e(o,[["render",n]]);export{g as __pageData,k as default}; diff --git a/pr-1680/assets/nodes_hardfork-process.md.9c089234.lean.js b/pr-1680/assets/nodes_hardfork-process.md.c86d1151.lean.js similarity index 81% rename from pr-1680/assets/nodes_hardfork-process.md.9c089234.lean.js rename to pr-1680/assets/nodes_hardfork-process.md.c86d1151.lean.js index f53cf1be1c..2e3d30a1b6 100644 --- a/pr-1680/assets/nodes_hardfork-process.md.9c089234.lean.js +++ b/pr-1680/assets/nodes_hardfork-process.md.c86d1151.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia hardfork process","description":"Overview of the Celestia hardfork process.","frontmatter":{"description":"Overview of the Celestia hardfork process.","head":[["meta",{"name":"og:title","content":"Celestia hardfork process | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/hardfork-process.md","filePath":"nodes/hardfork-process.md","lastUpdated":1724867275000}'),o={name:"nodes/hardfork-process.md"},i=r("",13),s=[i];function n(d,h,l,c,p,f){return t(),a("div",null,s)}const k=e(o,[["render",n]]);export{g as __pageData,k as default}; +import{_ as e,o as t,c as a,Q as r}from"./chunks/framework.a504a440.js";const g=JSON.parse('{"title":"Celestia hardfork process","description":"Overview of the Celestia hardfork process.","frontmatter":{"description":"Overview of the Celestia hardfork process.","head":[["meta",{"name":"og:title","content":"Celestia hardfork process | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/hardfork-process.md","filePath":"nodes/hardfork-process.md","lastUpdated":1725955670000}'),o={name:"nodes/hardfork-process.md"},i=r("",13),s=[i];function n(d,h,l,c,p,f){return t(),a("div",null,s)}const k=e(o,[["render",n]]);export{g as __pageData,k as default}; diff --git a/pr-1680/assets/nodes_ibc-relayer.md.7a3c6a4c.js b/pr-1680/assets/nodes_ibc-relayer.md.a8f27ce5.js similarity index 99% rename from pr-1680/assets/nodes_ibc-relayer.md.7a3c6a4c.js rename to pr-1680/assets/nodes_ibc-relayer.md.a8f27ce5.js index e50528da5d..ce88d09a22 100644 --- a/pr-1680/assets/nodes_ibc-relayer.md.7a3c6a4c.js +++ b/pr-1680/assets/nodes_ibc-relayer.md.a8f27ce5.js @@ -1,4 +1,4 @@ -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.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":"/nodes/celestia-node-metrics"},"head":[["meta",{"name":"og:title","content":"IBC relaying guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/ibc-relayer.md","filePath":"nodes/ibc-relayer.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.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":"/nodes/celestia-node-metrics"},"head":[["meta",{"name":"og:title","content":"IBC relaying guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/ibc-relayer.md","filePath":"nodes/ibc-relayer.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_ibc-relayer.md.7a3c6a4c.lean.js b/pr-1680/assets/nodes_ibc-relayer.md.a8f27ce5.lean.js
        similarity index 91%
        rename from pr-1680/assets/nodes_ibc-relayer.md.7a3c6a4c.lean.js
        rename to pr-1680/assets/nodes_ibc-relayer.md.a8f27ce5.lean.js
        index 9905f5db56..1d1b5032e8 100644
        --- a/pr-1680/assets/nodes_ibc-relayer.md.7a3c6a4c.lean.js
        +++ b/pr-1680/assets/nodes_ibc-relayer.md.a8f27ce5.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.a504a440.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":"/nodes/celestia-node-metrics"},"head":[["meta",{"name":"og:title","content":"IBC relaying guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/ibc-relayer.md","filePath":"nodes/ibc-relayer.md","lastUpdated":1724867275000}'),p={name:"nodes/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.a504a440.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":"/nodes/celestia-node-metrics"},"head":[["meta",{"name":"og:title","content":"IBC relaying guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/ibc-relayer.md","filePath":"nodes/ibc-relayer.md","lastUpdated":1725955670000}'),p={name:"nodes/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-1680/assets/nodes_instantiate-testnet.md.564058ba.js b/pr-1680/assets/nodes_instantiate-testnet.md.4237987d.js
        similarity index 99%
        rename from pr-1680/assets/nodes_instantiate-testnet.md.564058ba.js
        rename to pr-1680/assets/nodes_instantiate-testnet.md.4237987d.js
        index 1aa9bc0591..412141a354 100644
        --- a/pr-1680/assets/nodes_instantiate-testnet.md.564058ba.js
        +++ b/pr-1680/assets/nodes_instantiate-testnet.md.4237987d.js
        @@ -1,4 +1,4 @@
        -import{_ as e,o as s,c as a,Q as n}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/instantiate-testnet.md","filePath":"nodes/instantiate-testnet.md","lastUpdated":1724867275000}'),o={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/instantiate-testnet.md","filePath":"nodes/instantiate-testnet.md","lastUpdated":1725955670000}'),o={name:"nodes/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-1680/assets/nodes_instantiate-testnet.md.564058ba.lean.js b/pr-1680/assets/nodes_instantiate-testnet.md.4237987d.lean.js
        similarity index 91%
        rename from pr-1680/assets/nodes_instantiate-testnet.md.564058ba.lean.js
        rename to pr-1680/assets/nodes_instantiate-testnet.md.4237987d.lean.js
        index 981a43904b..87efb869d5 100644
        --- a/pr-1680/assets/nodes_instantiate-testnet.md.564058ba.lean.js
        +++ b/pr-1680/assets/nodes_instantiate-testnet.md.4237987d.lean.js
        @@ -1 +1 @@
        -import{_ as e,o as s,c as a,Q as n}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/instantiate-testnet.md","filePath":"nodes/instantiate-testnet.md","lastUpdated":1724867275000}'),o={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Celestia App network instantiation guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/instantiate-testnet.md","filePath":"nodes/instantiate-testnet.md","lastUpdated":1725955670000}'),o={name:"nodes/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-1680/assets/nodes_light-node.md.4d805f14.js b/pr-1680/assets/nodes_light-node.md.ebca7fc4.js
        similarity index 90%
        rename from pr-1680/assets/nodes_light-node.md.4d805f14.js
        rename to pr-1680/assets/nodes_light-node.md.ebca7fc4.js
        index 91a752b63c..a9949d08a0 100644
        --- a/pr-1680/assets/nodes_light-node.md.4d805f14.js
        +++ b/pr-1680/assets/nodes_light-node.md.ebca7fc4.js
        @@ -1,6 +1,6 @@
        -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const e="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia light node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/light-node.md","filePath":"nodes/light-node.md","lastUpdated":1724867275000}'),l={name:"nodes/light-node.md"},p=o('

        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

        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, mocha, or arabica.

        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.a504a440.js";const o="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia light node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/light-node.md","filePath":"nodes/light-node.md","lastUpdated":1725955670000}'),l={name:"nodes/light-node.md"},p=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

        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, mocha, or arabica.

        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 n,Q as o}from"./chunks/framework.a504a440.js";const e=
             --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 n,Q as o}from"./chunks/framework.a504a440.js";const e=
             --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: 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.

        `,47),t=[p];function c(r,i,y,d,E,h){return a(),n("div",null,t)}const u=s(l,[["render",c]]);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.

        `,50),t=[p];function c(r,i,y,d,E,h){return a(),e("div",null,t)}const u=s(l,[["render",c]]);export{F as __pageData,u as default}; diff --git a/pr-1680/assets/nodes_light-node.md.4d805f14.lean.js b/pr-1680/assets/nodes_light-node.md.ebca7fc4.lean.js similarity index 59% rename from pr-1680/assets/nodes_light-node.md.4d805f14.lean.js rename to pr-1680/assets/nodes_light-node.md.ebca7fc4.lean.js index 8b8e117740..cb57b733ab 100644 --- a/pr-1680/assets/nodes_light-node.md.4d805f14.lean.js +++ b/pr-1680/assets/nodes_light-node.md.ebca7fc4.lean.js @@ -1 +1 @@ -import{_ as s,o as a,c as n,Q as o}from"./chunks/framework.a504a440.js";const e="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia light node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/light-node.md","filePath":"nodes/light-node.md","lastUpdated":1724867275000}'),l={name:"nodes/light-node.md"},p=o("",47),t=[p];function c(r,i,y,d,E,h){return a(),n("div",null,t)}const u=s(l,[["render",c]]);export{F as __pageData,u as default}; +import{_ as s,o as a,c as e,Q as n}from"./chunks/framework.a504a440.js";const o="/docs-preview/pr-1680/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",{"name":"og:title","content":"Setting up a Celestia light node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/light-node.md","filePath":"nodes/light-node.md","lastUpdated":1725955670000}'),l={name:"nodes/light-node.md"},p=n("",50),t=[p];function c(r,i,y,d,E,h){return a(),e("div",null,t)}const u=s(l,[["render",c]]);export{F as __pageData,u as default}; diff --git a/pr-1680/assets/nodes_mainnet.md.71c4e1fb.js b/pr-1680/assets/nodes_mainnet.md.91c04e4d.js similarity index 99% rename from pr-1680/assets/nodes_mainnet.md.71c4e1fb.js rename to pr-1680/assets/nodes_mainnet.md.91c04e4d.js index 9e2e098bf8..12f0487c2b 100644 --- a/pr-1680/assets/nodes_mainnet.md.71c4e1fb.js +++ b/pr-1680/assets/nodes_mainnet.md.91c04e4d.js @@ -1 +1 @@ -import{M as p}from"./chunks/MainnetVersionTags.1cb0f3c9.js";import{c as h}from"./chunks/constants.0e6df566.js";import{_ as m,o as s,c as r,k as e,t as o,C as n,H as a,w as c,Q as i,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mainnet_versions.1d5e6ed9.js";const f="/docs-preview/pr-1680/img/Mainnet-Beta.png",b="/docs-preview/pr-1680/grove/grove-sandbox.png",y={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 x(d,T,Q,l,t,F){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 M=m(y,[["render",x]]),C=i('

        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 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),P=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),Z=i('

        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),R=i('

        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
        • celestia-rpc.mesa.newmetric.xyz
        • rpc.celestia.pops.one
        • rpc.lunaroasis.net
        • rpc.celestia.nodestake.top
        • celestia-rpc.brightlystake.com
        • celestia-rpc.spidey.services
        • rpc-celestia.contributiondao.com
        • celestia.rpc.stakin-nodes.com
        • celestia.cumulo.org.es
        • rpc-celestia.mzonder.com
        • 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.archives.validao.xyz
        • rpc-archive.celestia.bitszn.com
        • celestia-rpc.f5nodes.com
        • celestia-rpc.chainode.tech:33373
        • rpc-celestia.staker.space
        • celestia-rpc.noders.services
        • celestia.moonli.me
        • celestia-mainnet-rpc.itrocket.net:443
        • rpc.celestia.mainnet.dteam.tech: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-api.spidey.services
        • api-celestia.contributiondao.com
        • celestia.rest.stakin-nodes.com
        • celestia.api.cumulo.org.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.rest.archives.validao.xyz
        • api-archive.celestia.bitszn.com
        • celestia-api.f5nodes.com
        • celestia-api.chainode.tech
        • api-celestia.staker.space
        • celestia-api.noders.services
        • celestia.moonli.me/api
        • celestia-mainnet-api.itrocket.net:443
        • api.celestia.mainnet.dteam.tech: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.spidey.services
        • grpc-celestia.contributiondao.com
        • celestia.grpc.stakin-nodes.com:443
        • celestia.grpc.cumulo.org.es:443
        • grpc-celestia.mzonder.com: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.archives.validao.xyz:9090
        • gprc-archive.celestia.bitszn.com
        • celestia-grpc.f5nodes.com:9390
        • celestia-grpc.chainode.tech:443
        • grpc-celestia.staker.space
        • celestia-grpc.noders.services:11090
        • celestia-mainnet-grpc.itrocket.net:443
        • grpc.celestia.mainnet.dteam.tech:28090

        Community WebSocket endpoints

        • wss://celestia-ws.chainode.tech:33373/websocket
        • wss://celestia-mainnet-ws.itrocket.net:443/websocket
        • wss://rpc.celestia.mainnet.dteam.tech: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
        • celestia-consensus.mesa.newmetric.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
        • rpc.celestia.mainnet.dteam.tech
          • gRPC: port 28090
          • RPC: 28657
        • celestia-consensus-mainnet.noders.services
          • gRPC: port 9080
          • RPC: port 26557

        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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        ',50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Mainnet Beta | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mainnet.md","filePath":"nodes/mainnet.md","lastUpdated":1724867275000}'),B={name:"nodes/mainnet.md"},G=Object.assign(B,{setup(d){return(T,Q)=>{const l=n("mjx-assistive-mml"),t=n("mjx-container");return s(),r("div",null,[C,a(M),P,a(p),Z,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})]),R])}}});export{j as __pageData,G as default}; +import{M as p}from"./chunks/MainnetVersionTags.8346f766.js";import{c as h}from"./chunks/constants.295fc0ab.js";import{_ as m,o as s,c as r,k as e,t as o,C as n,H as a,w as c,Q as i,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mainnet_versions.1d5e6ed9.js";const f="/docs-preview/pr-1680/img/Mainnet-Beta.png",b="/docs-preview/pr-1680/grove/grove-sandbox.png",y={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 x(d,T,Q,l,t,F){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 M=m(y,[["render",x]]),C=i('

        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 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),P=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),Z=i('

        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),R=i('

        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
        • celestia-rpc.mesa.newmetric.xyz
        • rpc.celestia.pops.one
        • rpc.lunaroasis.net
        • rpc.celestia.nodestake.top
        • celestia-rpc.brightlystake.com
        • celestia-rpc.spidey.services
        • rpc-celestia.contributiondao.com
        • celestia.rpc.stakin-nodes.com
        • celestia.cumulo.org.es
        • rpc-celestia.mzonder.com
        • 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.archives.validao.xyz
        • rpc-archive.celestia.bitszn.com
        • celestia-rpc.f5nodes.com
        • celestia-rpc.chainode.tech:33373
        • rpc-celestia.staker.space
        • celestia-rpc.noders.services
        • celestia.moonli.me
        • celestia-mainnet-rpc.itrocket.net:443
        • rpc.celestia.mainnet.dteam.tech: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-api.spidey.services
        • api-celestia.contributiondao.com
        • celestia.rest.stakin-nodes.com
        • celestia.api.cumulo.org.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.rest.archives.validao.xyz
        • api-archive.celestia.bitszn.com
        • celestia-api.f5nodes.com
        • celestia-api.chainode.tech
        • api-celestia.staker.space
        • celestia-api.noders.services
        • celestia.moonli.me/api
        • celestia-mainnet-api.itrocket.net:443
        • api.celestia.mainnet.dteam.tech: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.spidey.services
        • grpc-celestia.contributiondao.com
        • celestia.grpc.stakin-nodes.com:443
        • celestia.grpc.cumulo.org.es:443
        • grpc-celestia.mzonder.com: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.archives.validao.xyz:9090
        • gprc-archive.celestia.bitszn.com
        • celestia-grpc.f5nodes.com:9390
        • celestia-grpc.chainode.tech:443
        • grpc-celestia.staker.space
        • celestia-grpc.noders.services:11090
        • celestia-mainnet-grpc.itrocket.net:443
        • grpc.celestia.mainnet.dteam.tech:28090

        Community WebSocket endpoints

        • wss://celestia-ws.chainode.tech:33373/websocket
        • wss://celestia-mainnet-ws.itrocket.net:443/websocket
        • wss://rpc.celestia.mainnet.dteam.tech: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
        • celestia-consensus.mesa.newmetric.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
        • rpc.celestia.mainnet.dteam.tech
          • gRPC: port 28090
          • RPC: 28657
        • celestia-consensus-mainnet.noders.services
          • gRPC: port 9080
          • RPC: port 26557

        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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        ',50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Mainnet Beta | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mainnet.md","filePath":"nodes/mainnet.md","lastUpdated":1725955670000}'),B={name:"nodes/mainnet.md"},G=Object.assign(B,{setup(d){return(T,Q)=>{const l=n("mjx-assistive-mml"),t=n("mjx-container");return s(),r("div",null,[C,a(M),P,a(p),Z,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})]),R])}}});export{j as __pageData,G as default}; diff --git a/pr-1680/assets/nodes_mainnet.md.71c4e1fb.lean.js b/pr-1680/assets/nodes_mainnet.md.91c04e4d.lean.js similarity index 99% rename from pr-1680/assets/nodes_mainnet.md.71c4e1fb.lean.js rename to pr-1680/assets/nodes_mainnet.md.91c04e4d.lean.js index b644c7eda8..d4328cd29a 100644 --- a/pr-1680/assets/nodes_mainnet.md.71c4e1fb.lean.js +++ b/pr-1680/assets/nodes_mainnet.md.91c04e4d.lean.js @@ -1 +1 @@ -import{M as p}from"./chunks/MainnetVersionTags.1cb0f3c9.js";import{c as h}from"./chunks/constants.0e6df566.js";import{_ as m,o as s,c as r,k as e,t as o,C as n,H as a,w as c,Q as i,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mainnet_versions.1d5e6ed9.js";const f="/docs-preview/pr-1680/img/Mainnet-Beta.png",b="/docs-preview/pr-1680/grove/grove-sandbox.png",y={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 x(d,T,Q,l,t,F){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 M=m(y,[["render",x]]),C=i("",8),P=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),Z=i("",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),R=i("",50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Mainnet Beta | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mainnet.md","filePath":"nodes/mainnet.md","lastUpdated":1724867275000}'),B={name:"nodes/mainnet.md"},G=Object.assign(B,{setup(d){return(T,Q)=>{const l=n("mjx-assistive-mml"),t=n("mjx-container");return s(),r("div",null,[C,a(M),P,a(p),Z,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})]),R])}}});export{j as __pageData,G as default}; +import{M as p}from"./chunks/MainnetVersionTags.8346f766.js";import{c as h}from"./chunks/constants.295fc0ab.js";import{_ as m,o as s,c as r,k as e,t as o,C as n,H as a,w as c,Q as i,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mainnet_versions.1d5e6ed9.js";const f="/docs-preview/pr-1680/img/Mainnet-Beta.png",b="/docs-preview/pr-1680/grove/grove-sandbox.png",y={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 x(d,T,Q,l,t,F){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 M=m(y,[["render",x]]),C=i("",8),P=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),Z=i("",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),R=i("",50),j=JSON.parse('{"title":"Mainnet Beta","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Mainnet Beta | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mainnet.md","filePath":"nodes/mainnet.md","lastUpdated":1725955670000}'),B={name:"nodes/mainnet.md"},G=Object.assign(B,{setup(d){return(T,Q)=>{const l=n("mjx-assistive-mml"),t=n("mjx-container");return s(),r("div",null,[C,a(M),P,a(p),Z,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})]),R])}}});export{j as __pageData,G as default}; diff --git a/pr-1680/assets/nodes_mocha-testnet.md.21cdb959.js b/pr-1680/assets/nodes_mocha-testnet.md.aa2ae9c7.js similarity index 98% rename from pr-1680/assets/nodes_mocha-testnet.md.21cdb959.js rename to pr-1680/assets/nodes_mocha-testnet.md.aa2ae9c7.js index d4c0c9bdac..0afcada02e 100644 --- a/pr-1680/assets/nodes_mocha-testnet.md.21cdb959.js +++ b/pr-1680/assets/nodes_mocha-testnet.md.aa2ae9c7.js @@ -1 +1 @@ -import{M as d}from"./chunks/MochaVersionTags.83273d07.js";import{c as h}from"./chunks/constants.0e6df566.js";import{_ as p,o as s,c as i,k as e,t as o,H as a,Q as r,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mocha_versions.ffd4ea25.js";const m="/docs-preview/pr-1680/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),_=["href"],w=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(l,n,c,S,t,E){return s(),i("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,_)])]),e("tr",null,[w,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=r('

        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=r('

        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
        • rpc.celestia.testnet.dteam.tech:443
          • gRPC: grpc.celestia.testnet.dteam.tech:27090
        • celestia-consensus-testnet.noders.services
          • RPC port: 26357
          • gRPC port: 9070

        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
        • rpc.celestia-mocha.com
        • celestia-testnet-rpc.f5nodes.com
        • celestia-testnet.brightlystake.com
        • rpc-celestia-mocha.architectnodes.com
        • rpc-celestia-mocha.trusted-point.com
        • rpc-celestia-testnet-01.stakeflow.io
        • mocha.celestia.rpc.cumulo.me
        • rpc-mocha-4.spidey.services
        • rpc-mocha-full.avril14th.org
        • rpc.mocha.bitszn.com
        • celestia-t-rpc.noders.services/
        • 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
        • rpc.celestia.testnet.dteam.tech: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-grpc.f5nodes.com
        • celestia-testnet.brightlystake.com:9390
        • grpc-celestia-mocha.architectnodes.com:1443
        • grpc-celestia-mocha.trusted-point.com:9099
        • grpc-celestia-testnet-01.stakeflow.io:16002
        • mocha.grpc.cumulo.me:443
        • grpc-mocha-4.spidey.services
        • grpc-mocha-full.avril14th.org
        • grpc.mocha.bitszn.com
        • celestia-grpc.noders.services:21090
        • 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
        • grpc.celestia.testnet.dteam.tech:27090

        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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        ',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",{"name":"og:title","content":"Mocha testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mocha-testnet.md","filePath":"nodes/mocha-testnet.md","lastUpdated":1724867275000}'),D={name:"nodes/mocha-testnet.md"},B=Object.assign(D,{setup(l){return(n,c)=>(s(),i("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; +import{M as d}from"./chunks/MochaVersionTags.78e5b38e.js";import{c as h}from"./chunks/constants.295fc0ab.js";import{_ as p,o as s,c as i,k as e,t as o,H as a,Q as r,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mocha_versions.7704b055.js";const m="/docs-preview/pr-1680/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),_=["href"],w=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(l,n,c,S,t,E){return s(),i("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,_)])]),e("tr",null,[w,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=r('

        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=r('

        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
        • rpc.celestia.testnet.dteam.tech:443
          • gRPC: grpc.celestia.testnet.dteam.tech:27090
        • celestia-consensus-testnet.noders.services
          • RPC port: 26357
          • gRPC port: 9070

        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
        • rpc.celestia-mocha.com
        • celestia-testnet-rpc.f5nodes.com
        • celestia-testnet.brightlystake.com
        • rpc-celestia-mocha.architectnodes.com
        • rpc-celestia-mocha.trusted-point.com
        • rpc-celestia-testnet-01.stakeflow.io
        • mocha.celestia.rpc.cumulo.me
        • rpc-mocha-4.spidey.services
        • rpc-mocha-full.avril14th.org
        • rpc.mocha.bitszn.com
        • celestia-t-rpc.noders.services/
        • 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
        • rpc.celestia.testnet.dteam.tech: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-grpc.f5nodes.com
        • celestia-testnet.brightlystake.com:9390
        • grpc-celestia-mocha.architectnodes.com:1443
        • grpc-celestia-mocha.trusted-point.com:9099
        • grpc-celestia-testnet-01.stakeflow.io:16002
        • mocha.grpc.cumulo.me:443
        • grpc-mocha-4.spidey.services
        • grpc-mocha-full.avril14th.org
        • grpc.mocha.bitszn.com
        • celestia-grpc.noders.services:21090
        • 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
        • grpc.celestia.testnet.dteam.tech:27090

        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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        ',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",{"name":"og:title","content":"Mocha testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mocha-testnet.md","filePath":"nodes/mocha-testnet.md","lastUpdated":1725955670000}'),D={name:"nodes/mocha-testnet.md"},B=Object.assign(D,{setup(l){return(n,c)=>(s(),i("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; diff --git a/pr-1680/assets/nodes_mocha-testnet.md.21cdb959.lean.js b/pr-1680/assets/nodes_mocha-testnet.md.aa2ae9c7.lean.js similarity index 88% rename from pr-1680/assets/nodes_mocha-testnet.md.21cdb959.lean.js rename to pr-1680/assets/nodes_mocha-testnet.md.aa2ae9c7.lean.js index ea58c803fe..973a9f16dd 100644 --- a/pr-1680/assets/nodes_mocha-testnet.md.21cdb959.lean.js +++ b/pr-1680/assets/nodes_mocha-testnet.md.aa2ae9c7.lean.js @@ -1 +1 @@ -import{M as d}from"./chunks/MochaVersionTags.83273d07.js";import{c as h}from"./chunks/constants.0e6df566.js";import{_ as p,o as s,c as i,k as e,t as o,H as a,Q as r,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mocha_versions.ffd4ea25.js";const m="/docs-preview/pr-1680/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),_=["href"],w=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(l,n,c,S,t,E){return s(),i("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,_)])]),e("tr",null,[w,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=r("",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=r("",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",{"name":"og:title","content":"Mocha testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mocha-testnet.md","filePath":"nodes/mocha-testnet.md","lastUpdated":1724867275000}'),D={name:"nodes/mocha-testnet.md"},B=Object.assign(D,{setup(l){return(n,c)=>(s(),i("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; +import{M as d}from"./chunks/MochaVersionTags.78e5b38e.js";import{c as h}from"./chunks/constants.295fc0ab.js";import{_ as p,o as s,c as i,k as e,t as o,H as a,Q as r,a as u}from"./chunks/framework.a504a440.js";import"./chunks/mocha_versions.7704b055.js";const m="/docs-preview/pr-1680/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),_=["href"],w=e("td",null,"Peers file",-1),v=["href"],C=e("tr",null,[e("td",null,"Validators"),e("td",null," 100 ")],-1);function P(l,n,c,S,t,E){return s(),i("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,_)])]),e("tr",null,[w,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=r("",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=r("",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",{"name":"og:title","content":"Mocha testnet | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/mocha-testnet.md","filePath":"nodes/mocha-testnet.md","lastUpdated":1725955670000}'),D={name:"nodes/mocha-testnet.md"},B=Object.assign(D,{setup(l){return(n,c)=>(s(),i("div",null,[R,a(T),x,a(d),A]))}});export{F as __pageData,B as default}; diff --git a/pr-1680/assets/nodes_overview.md.4fff23da.js b/pr-1680/assets/nodes_overview.md.1b940623.js similarity index 98% rename from pr-1680/assets/nodes_overview.md.4fff23da.js rename to pr-1680/assets/nodes_overview.md.1b940623.js index e6683805ef..7e9ae450c4 100644 --- a/pr-1680/assets/nodes_overview.md.4fff23da.js +++ b/pr-1680/assets/nodes_overview.md.1b940623.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/overview.md","filePath":"nodes/overview.md","lastUpdated":1724867275000}'),n={name:"nodes/overview.md"},d=o('

        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 cores10 TB SSD1 Gbps
        Full storage node16 GB RAMQuad-core10 TB SSD1 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(),a("div",null,i)}const m=e(n,[["render",s]]);export{v as __pageData,m as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/overview.md","filePath":"nodes/overview.md","lastUpdated":1725955670000}'),n={name:"nodes/overview.md"},d=o('

        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 cores10 TB SSD1 Gbps
        Full storage node16 GB RAMQuad-core10 TB SSD1 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(),a("div",null,i)}const m=e(n,[["render",s]]);export{v as __pageData,m as default}; diff --git a/pr-1680/assets/nodes_overview.md.4fff23da.lean.js b/pr-1680/assets/nodes_overview.md.1b940623.lean.js similarity index 91% rename from pr-1680/assets/nodes_overview.md.4fff23da.lean.js rename to pr-1680/assets/nodes_overview.md.1b940623.lean.js index e03714f779..2ca3ecc4e0 100644 --- a/pr-1680/assets/nodes_overview.md.4fff23da.lean.js +++ b/pr-1680/assets/nodes_overview.md.1b940623.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/overview.md","filePath":"nodes/overview.md","lastUpdated":1724867275000}'),n={name:"nodes/overview.md"},d=o("",14),i=[d];function s(r,l,h,c,u,p){return t(),a("div",null,i)}const m=e(n,[["render",s]]);export{v as __pageData,m as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Overview to running nodes on Celestia | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/overview.md","filePath":"nodes/overview.md","lastUpdated":1725955670000}'),n={name:"nodes/overview.md"},d=o("",14),i=[d];function s(r,l,h,c,u,p){return t(),a("div",null,i)}const m=e(n,[["render",s]]);export{v as __pageData,m as default}; diff --git a/pr-1680/assets/nodes_participate.md.be133e40.js b/pr-1680/assets/nodes_participate.md.44f9ae13.js similarity index 92% rename from pr-1680/assets/nodes_participate.md.be133e40.js rename to pr-1680/assets/nodes_participate.md.44f9ae13.js index 4fedc88c4d..7cd13f16f2 100644 --- a/pr-1680/assets/nodes_participate.md.be133e40.js +++ b/pr-1680/assets/nodes_participate.md.44f9ae13.js @@ -1 +1 @@ -import{A as t}from"./chunks/ArabicaVersionTags.e01dd824.js";import{M as o}from"./chunks/MochaVersionTags.83273d07.js";import{M as r}from"./chunks/MainnetVersionTags.1cb0f3c9.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.a504a440.js";import"./chunks/arabica_versions.6d89be6e.js";import"./chunks/constants.0e6df566.js";import"./chunks/mocha_versions.ffd4ea25.js";import"./chunks/mainnet_versions.1d5e6ed9.js";const s=e('

        Participate in the Celestia networks

        Mainnet Beta

        Celestia’s Mainnet Beta is the production network for deploying mainnet 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 hardforks 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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        ',4),A=JSON.parse('{"title":"Participate in the Celestia networks","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Participate in the Celestia networks | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/participate.md","filePath":"nodes/participate.md","lastUpdated":1724867275000}'),d={name:"nodes/participate.md"},P=Object.assign(d,{setup(p){return(m,f)=>(n(),i("div",null,[s,a(r),c,a(t),l,a(o),h]))}});export{A as __pageData,P as default}; +import{A as t}from"./chunks/ArabicaVersionTags.20a10f87.js";import{M as o}from"./chunks/MochaVersionTags.78e5b38e.js";import{M as r}from"./chunks/MainnetVersionTags.8346f766.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.a504a440.js";import"./chunks/arabica_versions.1930378b.js";import"./chunks/constants.295fc0ab.js";import"./chunks/mocha_versions.7704b055.js";import"./chunks/mainnet_versions.1d5e6ed9.js";const s=e('

        Participate in the Celestia networks

        Mainnet Beta

        Celestia’s Mainnet Beta is the production network for deploying mainnet 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 hardforks 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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

        ',4),A=JSON.parse('{"title":"Participate in the Celestia networks","description":"","frontmatter":{"head":[["meta",{"name":"og:title","content":"Participate in the Celestia networks | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/participate.md","filePath":"nodes/participate.md","lastUpdated":1725955670000}'),d={name:"nodes/participate.md"},P=Object.assign(d,{setup(p){return(m,f)=>(n(),i("div",null,[s,a(r),c,a(t),l,a(o),h]))}});export{A as __pageData,P as default}; diff --git a/pr-1680/assets/nodes_participate.md.be133e40.lean.js b/pr-1680/assets/nodes_participate.md.44f9ae13.lean.js similarity index 61% rename from pr-1680/assets/nodes_participate.md.be133e40.lean.js rename to pr-1680/assets/nodes_participate.md.44f9ae13.lean.js index a411856e67..c75eee101a 100644 --- a/pr-1680/assets/nodes_participate.md.be133e40.lean.js +++ b/pr-1680/assets/nodes_participate.md.44f9ae13.lean.js @@ -1 +1 @@ -import{A as t}from"./chunks/ArabicaVersionTags.e01dd824.js";import{M as o}from"./chunks/MochaVersionTags.83273d07.js";import{M as r}from"./chunks/MainnetVersionTags.1cb0f3c9.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.a504a440.js";import"./chunks/arabica_versions.6d89be6e.js";import"./chunks/constants.0e6df566.js";import"./chunks/mocha_versions.ffd4ea25.js";import"./chunks/mainnet_versions.1d5e6ed9.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",{"name":"og:title","content":"Participate in the Celestia networks | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/participate.md","filePath":"nodes/participate.md","lastUpdated":1724867275000}'),d={name:"nodes/participate.md"},P=Object.assign(d,{setup(p){return(m,f)=>(n(),i("div",null,[s,a(r),c,a(t),l,a(o),h]))}});export{A as __pageData,P as default}; +import{A as t}from"./chunks/ArabicaVersionTags.20a10f87.js";import{M as o}from"./chunks/MochaVersionTags.78e5b38e.js";import{M as r}from"./chunks/MainnetVersionTags.8346f766.js";import{o as n,c as i,H as a,Q as e}from"./chunks/framework.a504a440.js";import"./chunks/arabica_versions.1930378b.js";import"./chunks/constants.295fc0ab.js";import"./chunks/mocha_versions.7704b055.js";import"./chunks/mainnet_versions.1d5e6ed9.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",{"name":"og:title","content":"Participate in the Celestia networks | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/participate.md","filePath":"nodes/participate.md","lastUpdated":1725955670000}'),d={name:"nodes/participate.md"},P=Object.assign(d,{setup(p){return(m,f)=>(n(),i("div",null,[s,a(r),c,a(t),l,a(o),h]))}});export{A as __pageData,P as default}; diff --git a/pr-1680/assets/nodes_quick-start.md.87f87708.js b/pr-1680/assets/nodes_quick-start.md.4fe562f2.js similarity index 97% rename from pr-1680/assets/nodes_quick-start.md.87f87708.js rename to pr-1680/assets/nodes_quick-start.md.4fe562f2.js index da934c824c..d55690a89d 100644 --- a/pr-1680/assets/nodes_quick-start.md.87f87708.js +++ b/pr-1680/assets/nodes_quick-start.md.4fe562f2.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Quick start guide","description":"Learn how to get started and run your first node on Celestia.","frontmatter":{"description":"Learn how to get started and run your first node on Celestia.","head":[["meta",{"name":"og:title","content":"Quick start guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/quick-start.md","filePath":"nodes/quick-start.md","lastUpdated":1724867275000}'),i={name:"nodes/quick-start.md"},n=o('

        Quick start guide

        In this section, we show you how to get started with installing the needed libraries and packages in Celestia to help you run a node on Celestia.

        Celestia Node

        Install celestia-node allows you to get started with running a light node and do data availability sampling.

        Light nodes are the best nodes to test out initially if you are new to participating in Celestia.

        celestia-node client also allows you to run other types of data availability (DA) nodes like bridge and full DA storage nodes, which will be covered in later sections.

        Celestia App

        Install celestia-app allows you to get started running a consensus node.

        celestia-app is the software that allows you to run validator nodes and also provide RPC endpoints.

        celestia-app covers the consensus layer, while celestia-node covers the DA layer.

        Getting started

        As covered in the previous section, Celestia offers two different test networks, Arabica devnet and Mocha testnet.

        If you are planning to run a light node, it is recommended to use Arabica, which you will find options to connecting to in the later sections.

        If you plan on running a validator, your only option is to run your node on Mocha.

        In this quick start guide, we will go over installing both of the software clients: celestia-node and celestia-app.

        NOTE

        If you just want to run a light node, you don't need to install celestia-app and can skip that part.

        Proceed to the next section in order to get started.

        ',17),s=[n];function r(l,d,c,p,u,h){return t(),a("div",null,s)}const _=e(i,[["render",r]]);export{f as __pageData,_ as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Quick start guide","description":"Learn how to get started and run your first node on Celestia.","frontmatter":{"description":"Learn how to get started and run your first node on Celestia.","head":[["meta",{"name":"og:title","content":"Quick start guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/quick-start.md","filePath":"nodes/quick-start.md","lastUpdated":1725955670000}'),i={name:"nodes/quick-start.md"},n=o('

        Quick start guide

        In this section, we show you how to get started with installing the needed libraries and packages in Celestia to help you run a node on Celestia.

        Celestia Node

        Install celestia-node allows you to get started with running a light node and do data availability sampling.

        Light nodes are the best nodes to test out initially if you are new to participating in Celestia.

        celestia-node client also allows you to run other types of data availability (DA) nodes like bridge and full DA storage nodes, which will be covered in later sections.

        Celestia App

        Install celestia-app allows you to get started running a consensus node.

        celestia-app is the software that allows you to run validator nodes and also provide RPC endpoints.

        celestia-app covers the consensus layer, while celestia-node covers the DA layer.

        Getting started

        As covered in the previous section, Celestia offers two different test networks, Arabica devnet and Mocha testnet.

        If you are planning to run a light node, it is recommended to use Arabica, which you will find options to connecting to in the later sections.

        If you plan on running a validator, your only option is to run your node on Mocha.

        In this quick start guide, we will go over installing both of the software clients: celestia-node and celestia-app.

        NOTE

        If you just want to run a light node, you don't need to install celestia-app and can skip that part.

        Proceed to the next section in order to get started.

        ',17),s=[n];function r(l,d,c,p,u,h){return t(),a("div",null,s)}const _=e(i,[["render",r]]);export{f as __pageData,_ as default}; diff --git a/pr-1680/assets/nodes_quick-start.md.87f87708.lean.js b/pr-1680/assets/nodes_quick-start.md.4fe562f2.lean.js similarity index 90% rename from pr-1680/assets/nodes_quick-start.md.87f87708.lean.js rename to pr-1680/assets/nodes_quick-start.md.4fe562f2.lean.js index 48af7355bc..fdeaa85780 100644 --- a/pr-1680/assets/nodes_quick-start.md.87f87708.lean.js +++ b/pr-1680/assets/nodes_quick-start.md.4fe562f2.lean.js @@ -1 +1 @@ -import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Quick start guide","description":"Learn how to get started and run your first node on Celestia.","frontmatter":{"description":"Learn how to get started and run your first node on Celestia.","head":[["meta",{"name":"og:title","content":"Quick start guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/quick-start.md","filePath":"nodes/quick-start.md","lastUpdated":1724867275000}'),i={name:"nodes/quick-start.md"},n=o("",17),s=[n];function r(l,d,c,p,u,h){return t(),a("div",null,s)}const _=e(i,[["render",r]]);export{f as __pageData,_ as default}; +import{_ as e,o as t,c as a,Q as o}from"./chunks/framework.a504a440.js";const f=JSON.parse('{"title":"Quick start guide","description":"Learn how to get started and run your first node on Celestia.","frontmatter":{"description":"Learn how to get started and run your first node on Celestia.","head":[["meta",{"name":"og:title","content":"Quick start guide | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/quick-start.md","filePath":"nodes/quick-start.md","lastUpdated":1725955670000}'),i={name:"nodes/quick-start.md"},n=o("",17),s=[n];function r(l,d,c,p,u,h){return t(),a("div",null,s)}const _=e(i,[["render",r]]);export{f as __pageData,_ as default}; diff --git a/pr-1680/assets/nodes_systemd.md.0a76c2e7.js b/pr-1680/assets/nodes_systemd.md.10732002.js similarity index 99% rename from pr-1680/assets/nodes_systemd.md.0a76c2e7.js rename to pr-1680/assets/nodes_systemd.md.10732002.js index 8232ed8a3e..b49b5c73ee 100644 --- a/pr-1680/assets/nodes_systemd.md.0a76c2e7.js +++ b/pr-1680/assets/nodes_systemd.md.10732002.js @@ -1,4 +1,4 @@ -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/systemd.md","filePath":"nodes/systemd.md","lastUpdated":1724867275000}'),e={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/systemd.md","filePath":"nodes/systemd.md","lastUpdated":1725955670000}'),e={name:"nodes/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-1680/assets/nodes_systemd.md.0a76c2e7.lean.js b/pr-1680/assets/nodes_systemd.md.10732002.lean.js
        similarity index 91%
        rename from pr-1680/assets/nodes_systemd.md.0a76c2e7.lean.js
        rename to pr-1680/assets/nodes_systemd.md.10732002.lean.js
        index 08676b41ad..b48edbf58a 100644
        --- a/pr-1680/assets/nodes_systemd.md.0a76c2e7.lean.js
        +++ b/pr-1680/assets/nodes_systemd.md.10732002.lean.js
        @@ -1 +1 @@
        -import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.a504a440.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",{"name":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/systemd.md","filePath":"nodes/systemd.md","lastUpdated":1724867275000}'),e={name:"nodes/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.a504a440.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",{"name":"og:title","content":"Setting up your node as a background process with SystemD | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/systemd.md","filePath":"nodes/systemd.md","lastUpdated":1725955670000}'),e={name:"nodes/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-1680/assets/nodes_validator-node.md.6d429357.js b/pr-1680/assets/nodes_validator-node.md.56905fa6.js
        similarity index 68%
        rename from pr-1680/assets/nodes_validator-node.md.6d429357.js
        rename to pr-1680/assets/nodes_validator-node.md.56905fa6.js
        index 58518baf1e..c383240d28 100644
        --- a/pr-1680/assets/nodes_validator-node.md.6d429357.js
        +++ b/pr-1680/assets/nodes_validator-node.md.56905fa6.js
        @@ -1,6 +1,6 @@
        -import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,a,t as o,l as t,Q as n}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/img/nodes/validator.png",r=n('

        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 e}from"./chunks/constants.295fc0ab.js";import{o as l,c as p,k as s,a,t as o,l as t,Q as n}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/img/nodes/validator.png",r=n('

        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"},_=n('celestia-appd tx staking delegate \\',1),y=n('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),b=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),v={class:"shiki github-light vp-code-light"},T=n('celestia-appd tx staking delegate \\',1),k=n('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),I=n(`

        If successful, you should see a similar output as:

        console
        code: 0
        +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"},_=n('celestia-appd tx staking delegate \\',1),y=n('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),b=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),v={class:"shiki github-light vp-code-light"},T=n('celestia-appd tx staking delegate \\',1),k=n('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),q=s("span",{style:{color:"#005CC5"}},"\\",-1),x=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"--fees=21000utia")],-1),w=n(`

        If successful, you should see a similar output as:

        console
        code: 0
         codespace: ""
         data: ""
         gas_used: "0"
        @@ -22,7 +22,7 @@ import{c as e}from"./chunks/constants.0e6df566.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.

        If you need a list of RPC endpoints to connect to, you can find the list on the Mocha testnet page or list on the Arabica devnet page.

        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 <height>
        celestia-appd start --v2-upgrade-height <height>
        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),w={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=n('celestia-appd tx staking create-validator \\',1),M=n(' --amount=1000000utia \\',1),W=n(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),z=n(' --moniker=$MONIKER \\',1),U={class:"line"},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#79B8FF"}},H=s("span",{style:{color:"#E1E4E8"}}," ",-1),K=s("span",{style:{color:"#79B8FF"}},"\\",-1),G=n(' --commission-rate=0.1 \\',1),Q=n(' --commission-max-rate=0.2 \\',1),X=n(' --commission-max-change-rate=0.01 \\',1),j=n(' --min-self-delegation=1000000 \\',1),J=n(' --from=$VALIDATOR_WALLET \\',1),Z=n(' --keyring-backend=test \\',1),ss=n(' --fees=21000utia \\',1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),ns={class:"shiki github-light vp-code-light"},es=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=n('celestia-appd tx staking create-validator \\',1),ps=n(' --amount=1000000utia \\',1),cs=n(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),rs=n(' --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=n(' --commission-rate=0.1 \\',1),gs=n(' --commission-max-rate=0.2 \\',1),Es=n(' --commission-max-change-rate=0.01 \\',1),Cs=n(' --min-self-delegation=1000000 \\',1),ms=n(' --from=$VALIDATOR_WALLET \\',1),Fs=n(' --keyring-backend=test \\',1),bs=n(' --fees=21000utia \\',1),vs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=n(`

        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.

        If you need a list of RPC endpoints to connect to, you can find the list on the Mocha testnet page or list on the Arabica devnet page.

        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=n('celestia-appd tx staking create-validator \\',1),M=n(' --amount=1000000utia \\',1),U=n(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),W=n(' --moniker=$MONIKER \\',1),z={class:"line"},$=s("span",{style:{color:"#E1E4E8"}}," ",-1),J={style:{color:"#79B8FF"}},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),H=s("span",{style:{color:"#79B8FF"}},"\\",-1),K=n(' --commission-rate=0.1 \\',1),G=n(' --commission-max-rate=0.2 \\',1),Q=n(' --commission-max-change-rate=0.01 \\',1),j=n(' --min-self-delegation=1000000 \\',1),X=n(' --from=$VALIDATOR_WALLET \\',1),Z=n(' --keyring-backend=test \\',1),ss=n(' --fees=21000utia \\',1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),ns={class:"shiki github-light vp-code-light"},es=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=n('celestia-appd tx staking create-validator \\',1),ps=n(' --amount=1000000utia \\',1),cs=n(' --pubkey=$(celestia-appd tendermint show-validator) \\',1),rs=n(' --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=n(' --commission-rate=0.1 \\',1),gs=n(' --commission-max-rate=0.2 \\',1),Es=n(' --commission-max-change-rate=0.01 \\',1),Cs=n(' --min-self-delegation=1000000 \\',1),ms=n(' --from=$VALIDATOR_WALLET \\',1),Fs=n(' --keyring-backend=test \\',1),bs=n(' --fees=21000utia \\',1),vs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=n(`

        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,25 +44,25 @@ import{c as e}from"./chunks/constants.0e6df566.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 unsafe-reset-all to reset your node and start syncing from the genesis block.

        `,16),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",{"name":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/validator-node.md","filePath":"nodes/validator-node.md","lastUpdated":1724867275000}'),ks={name:"nodes/validator-node.md"},Is=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.

        `,16),xs=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",{"name":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/validator-node.md","filePath":"nodes/validator-node.md","lastUpdated":1725955670000}'),ks={name:"nodes/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="+o(t(e).mochaChainId),1),m,F]),a(` `),b])]),s("pre",v,[s("code",null,[T,a(` `),k,a(` -`),s("span",f,[A,s("span",S,"--chain-id="+o(t(e).mochaChainId),1),B,x]),a(` -`),q])])]),I,s("div",w,[P,V,s("pre",R,[s("code",null,[D,a(` +`),s("span",f,[A,s("span",S,"--chain-id="+o(t(e).mochaChainId),1),B,q]),a(` +`),x])])]),w,s("div",I,[P,V,s("pre",R,[s("code",null,[D,a(` `),N,a(` `),L,a(` `),O,a(` `),M,a(` +`),U,a(` `),W,a(` -`),z,a(` -`),s("span",U,[Y,s("span",$,"--chain-id="+o(t(e).mochaChainId),1),H,K]),a(` +`),s("span",z,[$,s("span",J,"--chain-id="+o(t(e).mochaChainId),1),Y,H]),a(` +`),K,a(` `),G,a(` `),Q,a(` -`),X,a(` `),j,a(` -`),J,a(` +`),X,a(` `),Z,a(` `),ss,a(` `),as])]),s("pre",ns,[s("code",null,[es,a(` @@ -80,4 +80,4 @@ import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,a `),ms,a(` `),Fs,a(` `),bs,a(` -`),vs])])]),Ts]))}});export{qs as __pageData,Is as default}; +`),vs])])]),Ts]))}});export{xs as __pageData,ws as default}; diff --git a/pr-1680/assets/nodes_validator-node.md.6d429357.lean.js b/pr-1680/assets/nodes_validator-node.md.56905fa6.lean.js similarity index 78% rename from pr-1680/assets/nodes_validator-node.md.6d429357.lean.js rename to pr-1680/assets/nodes_validator-node.md.56905fa6.lean.js index 4d7e9780df..0862c6535a 100644 --- a/pr-1680/assets/nodes_validator-node.md.6d429357.lean.js +++ b/pr-1680/assets/nodes_validator-node.md.56905fa6.lean.js @@ -1,22 +1,22 @@ -import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,a,t as o,l as t,Q as n}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/img/nodes/validator.png",r=n("",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"},_=n("",1),y=n("",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),b=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),v={class:"shiki github-light vp-code-light"},T=n("",1),k=n("",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),I=n("",30),w={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=n("",1),M=n("",1),W=n("",1),z=n("",1),U={class:"line"},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),$={style:{color:"#79B8FF"}},H=s("span",{style:{color:"#E1E4E8"}}," ",-1),K=s("span",{style:{color:"#79B8FF"}},"\\",-1),G=n("",1),Q=n("",1),X=n("",1),j=n("",1),J=n("",1),Z=n("",1),ss=n("",1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),ns={class:"shiki github-light vp-code-light"},es=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=n("",1),ps=n("",1),cs=n("",1),rs=n("",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=n("",1),gs=n("",1),Es=n("",1),Cs=n("",1),ms=n("",1),Fs=n("",1),bs=n("",1),vs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=n("",16),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",{"name":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/validator-node.md","filePath":"nodes/validator-node.md","lastUpdated":1724867275000}'),ks={name:"nodes/validator-node.md"},Is=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 e}from"./chunks/constants.295fc0ab.js";import{o as l,c as p,k as s,a,t as o,l as t,Q as n}from"./chunks/framework.a504a440.js";const c="/docs-preview/pr-1680/img/nodes/validator.png",r=n("",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"},_=n("",1),y=n("",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),b=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}},"--fees=21000utia")],-1),v={class:"shiki github-light vp-code-light"},T=n("",1),k=n("",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),q=s("span",{style:{color:"#005CC5"}},"\\",-1),x=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}},"--fees=21000utia")],-1),w=n("",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=n("",1),M=n("",1),U=n("",1),W=n("",1),z={class:"line"},$=s("span",{style:{color:"#E1E4E8"}}," ",-1),J={style:{color:"#79B8FF"}},Y=s("span",{style:{color:"#E1E4E8"}}," ",-1),H=s("span",{style:{color:"#79B8FF"}},"\\",-1),K=n("",1),G=n("",1),Q=n("",1),j=n("",1),X=n("",1),Z=n("",1),ss=n("",1),as=s("span",{class:"line"},[s("span",{style:{color:"#E1E4E8"}}," "),s("span",{style:{color:"#79B8FF"}},"--gas=220000")],-1),ns={class:"shiki github-light vp-code-light"},es=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=n("",1),ps=n("",1),cs=n("",1),rs=n("",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=n("",1),gs=n("",1),Es=n("",1),Cs=n("",1),ms=n("",1),Fs=n("",1),bs=n("",1),vs=s("span",{class:"line"},[s("span",{style:{color:"#24292E"}}," "),s("span",{style:{color:"#005CC5"}},"--gas=220000")],-1),Ts=n("",16),xs=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",{"name":"og:title","content":"Setting up a Celestia validator node | Celestia Docs"},{"name":"og:description","content":false}]]},"headers":[],"relativePath":"nodes/validator-node.md","filePath":"nodes/validator-node.md","lastUpdated":1725955670000}'),ks={name:"nodes/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="+o(t(e).mochaChainId),1),m,F]),a(` `),b])]),s("pre",v,[s("code",null,[T,a(` `),k,a(` -`),s("span",f,[A,s("span",S,"--chain-id="+o(t(e).mochaChainId),1),B,x]),a(` -`),q])])]),I,s("div",w,[P,V,s("pre",R,[s("code",null,[D,a(` +`),s("span",f,[A,s("span",S,"--chain-id="+o(t(e).mochaChainId),1),B,q]),a(` +`),x])])]),w,s("div",I,[P,V,s("pre",R,[s("code",null,[D,a(` `),N,a(` `),L,a(` `),O,a(` `),M,a(` +`),U,a(` `),W,a(` -`),z,a(` -`),s("span",U,[Y,s("span",$,"--chain-id="+o(t(e).mochaChainId),1),H,K]),a(` +`),s("span",z,[$,s("span",J,"--chain-id="+o(t(e).mochaChainId),1),Y,H]),a(` +`),K,a(` `),G,a(` `),Q,a(` -`),X,a(` `),j,a(` -`),J,a(` +`),X,a(` `),Z,a(` `),ss,a(` `),as])]),s("pre",ns,[s("code",null,[es,a(` @@ -34,4 +34,4 @@ import{c as e}from"./chunks/constants.0e6df566.js";import{o as l,c as p,k as s,a `),ms,a(` `),Fs,a(` `),bs,a(` -`),vs])])]),Ts]))}});export{qs as __pageData,Is as default}; +`),vs])])]),Ts]))}});export{xs as __pageData,ws as default}; diff --git a/pr-1680/community/calendar.html b/pr-1680/community/calendar.html index c2570556d7..a7df2637ec 100644 --- a/pr-1680/community/calendar.html +++ b/pr-1680/community/calendar.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

      Community calendar

      The Celestia community calendar is available for finding all the different community call events happening in Celestia's community.

      Add the community calendar to your personal calendar to stay updated with all the events.

      Explore past community call agendas, notes, and recordings for more insights.

      - +

    Community calendar

    The Celestia community calendar is available for finding all the different community call events happening in Celestia's community.

    Add the community calendar to your personal calendar to stay updated with all the events.

    Explore past community call agendas, notes, and recordings for more insights.

    + \ No newline at end of file diff --git a/pr-1680/community/coc.html b/pr-1680/community/coc.html index 1292984ab8..2db242787c 100644 --- a/pr-1680/community/coc.html +++ b/pr-1680/community/coc.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/community/foundation-delegation-program.html b/pr-1680/community/foundation-delegation-program.html index 03c30803de..74d5bb00de 100644 --- a/pr-1680/community/foundation-delegation-program.html +++ b/pr-1680/community/foundation-delegation-program.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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 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 validator or an active Mocha testnet validator for at least 1 month before application deadline
    • Run a bridge node (on mainnet if you are already an active mainnet 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 + 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
      • If you don't run an active mainnet 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 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 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 validator or an active Mocha testnet validator for at least 1 month before application deadline
    • Run a bridge node (on mainnet if you are already an active mainnet 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 + 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
      • If you don't run an active mainnet 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 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-1680/community/itn-tos.html b/pr-1680/community/itn-tos.html index 2762051c39..7d83e84ae5 100644 --- a/pr-1680/community/itn-tos.html +++ b/pr-1680/community/itn-tos.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

    SUPPLEMENTAL INCENTIVIZED TESTNET TERMS

    Last Revised on 1/16/2023

    Welcome to the Supplemental Terms (these "ITN Award Program Terms" or "Terms") for the Incentivized Testnet Award Program (the "ITN Award Program" or the "Program") as operated on behalf of Strange Loop Labs AG ("Company", "we" or "us"). The ITN Award Program provides eligible users of a Testnet designated by the Company the opportunity to earn rewards, which may include Celestia tokens. These Terms are supplemental to, and incorporate by reference, the broader Celestia Terms of Service ("Services Terms") available at Celestia Terms of Service.

    Defined terms used but not defined herein have the meaning set forth in the Services Terms. The Program and your participation in it is a Service as defined under the Services Terms.

    These Terms govern your ability to participate in the Program and any awards you receive from that participation, which may include Celestia tokens ("ITN Rewards").

    Please read these Terms carefully, as they include important information about your legal rights. By participating in the Program or claiming ITN Rewards, you are agreeing to these Terms. If you do not understand or agree to these Terms, please do not participate in the Program or claim ITN Rewards.

    In order to participate in the Program you must provide certain information about you. Our collection of such information, your rights with respect to such collection, and other relevant information is described in the Celestia Privacy Policy available at Celestia Privacy Policy, and is supplemented by Section 3 of these Terms.

    The Program is a discretionary Service provided by the Company, pursuant to which the Company may, in its sole discretion, provide you ITN Rewards for your successful completion of certain tasks on a Testnet designated by the Company. Please note that any such Testnet itself (as well as any other Testnets or any mainnet deployment of the Celestia Protocol) is not a Service and does not constitute an element of the Services. We do not control the Celestia Protocol and accept no liability for its operation or its deployment in any testnet or mainnet environment.

    1. General Terms

    1.1 You must be eighteen (18) years of age or older and capable of forming a binding contract with the Company in order to participate in the Program or receive ITN Rewards.

    1.2 You agree and acknowledge that you (a) may receive ITN Rewards for free (other than applicable taxes, if any) from your participation in the Program, (b) were not previously promised ITN Rewards, unless pursuant to a separate written agreement, and (c) took no action in anticipation of or in reliance on receiving any ITN Rewards, unless pursuant to a separate written agreement.

    1.3 Your eligibility to participate in or receive ITN Rewards from the Program is subject to our sole discretion. The complete list of actions you must complete to earn ITN Rewards may not have been described in the documentation released by us from time to time, you may not receive ITN Rewards even if you successfully complete such actions, and no documentation related to the Program entitles you to any ITN Rewards or to participate in the Program.

    1.4 You agree and acknowledge that (a) you are not a Prohibited Person, (b) you are not a U.S. Person as defined in Rule 902(k) of Regulation S under the U.S. Securities Act of 1933, as amended (the "1933 Act" or "Act"), (c) you will not use a VPN or other tool to circumvent any geoblock or other restrictions that we may have implemented for participants in the Program, and (d) you are not participating in, and have not become eligible to participate in, the Program by receiving credentials from any other person or entity. Any circumvention or violation of the above will permanently disqualify you from participation in the Program.

    1.5 You agree and acknowledge that if you are unable to claim ITN Rewards due to technical bugs, gas fees, loss of access to a Wallet or the keys thereto, or for any other reason, you will have no recourse or claim against us or any other Company Entity and that neither we nor any other Company Entity will bear any liability.

    1.6 You agree and acknowledge that claiming an ITN Reward may require reliance on or an integration with third party products (e.g., a Wallet or an unaffiliated network or blockchain) that we do not control. In the event that you are unable to access such products or integrations, or if they fail for any reason, and you are unable to participate in the Program or claim ITN Rewards, you will have no recourse or claim against us or any other Company Entity and neither we nor any other Company Entity will bear any liability.

    1.7 The Company may share identifying information and documentation with certain vendors or third-party providers who provide such identity verification and sanctions and watchlist screening services (the "Third-Party Services"). You agree that your access and use of such Third-Party Services is governed solely by the terms and conditions of such Third-Party Services, and the Company is not responsible or liable for, and make no representations as to any aspect of such Third-Party Services, including, without limitation, their content or the manner in which they handle, protect, manage or process data or any interaction between you and the provider of such Third-Party Services. You irrevocably waive any claim against the Company with respect to such Third-Party Services. We are not liable for any damage or loss caused or alleged to be caused by or in connection with your enablement, access or use of any such Third-Party Services, or your reliance on the privacy practices, data security processes or other policies of such Third-Party Services.

    2. Taxes

    2.1 You are responsible for the payment of all taxes associated with your participation in the Program and your receipt of ITN Rewards. You agree to provide the Company with any additional information and complete any required tax or other forms relating to your receipt of ITN Rewards. You may suffer adverse tax consequences as a result of your participation in the Program or your receipt of ITN Rewards. You hereby represent that (a) you have consulted with a tax adviser that you deem advisable in connection with your participation, or that you have had the opportunity to obtain tax advice but have chosen not to do so, (b) the Company has not provided you with any tax advice with respect to your participation, and (c) you are not relying on the Company for any tax advice.

    3. Supplemental Privacy Information

    We may collect information to help us determine the reliability or uptime of your activities within the Program, including through the use of telemetry or metrics endpoints to collect and analyse such information, and link this information to a unique identifier to represent your activities within the Program. We may display all of the foregoing information on a public dashboard.

    Additionally, we may collect certain information about you from Third-Party Services and may combine information we receive from you with information we obtain from Third-Party Services, including but not limited to:

    • Transaction information. Information related to transactions in your Wallet, your Wallet address, activities performed using your Wallet, tokens received by your Wallet, or transactions initiated or completed.
    • Identification information. We collect your government identification (e.g., driver’s license, passport, etc.), proof of address, biometric information, and entity formation information if applicable. By agreeing to these Terms, you consent to our use of your biometric information, and understand and agree that our use of the biometric information is necessary for the performance of these Terms and the implementation of the Services.

    We collect this information to confirm your eligibility to participate in the Program and receive ITN Rewards, comply with our legal obligations, detect and prevent fraud, and to provide you with the Program.

    Any information we receive from third-party sources will be treated in accordance with the Celestia Privacy Policy, available at Celestia Privacy Policy. We are not responsible or liable for the accuracy of the information provided to us by third parties and are not responsible for any third party’s policies or practices. See Section 9 of the Celestia Privacy Policy for more information.

    4. Certain Additional Representations

    4.1 Receipt of Rewards Entirely for Own Account. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that any ITN Rewards you receive will be for your own account, not as a nominee or agent, and not with a view to the resale or distribution of any part thereof, and that you have no present intention of selling, granting any participation in, or otherwise distributing the same. By agreeing to these Terms, you further represent that you do not presently have any contract, undertaking, agreement or arrangement with any person to sell, transfer or grant participations to such person or to any third person, with respect to any ITN Rewards. If you are agreeing to these terms on behalf of an entity, that entity has not been formed for the specific purpose of obtaining the ITN Rewards.

    4.2 Disclosure of Information. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that you have sufficient knowledge of and experience in business and financial matters to be able to evaluate the risks and merits of your participation in the Program and of any ITN Rewards and are able to bear the risks thereof. You hereby affirm that you have not relied on any representations or warranties made by the Company related to the Program, including, but not limited to, conversations of any kind, whether through oral or electronic communication, or any white paper.

    4.3 Compliance with United States Securities Laws. You understand that the ITN Rewards have not been, and will not be, registered under the 1933 Act or any applicable state securities laws. You acknowledge that the availability of an exemption from the registration provisions of the Securities Act and other applicable state securities laws depends upon, among other things, the bona fide nature of your intent as described in Section 4.1 above and with respect to the accuracy of your representations as expressed throughout these Terms. You understand that the ITN Rewards may be deemed "restricted securities" under applicable United States federal and state securities laws and that, pursuant to these laws, you may be restricted from transferring any ITN Rewards unless they are registered with the Securities and Exchange Commission and qualified by state authorities, or an exemption from such registration and qualification requirements is available. You acknowledge that the Company does not undertake any obligation to register or qualify the ITN Rewards for resale, and exemptions from registration and qualification may not be available or may not permit you to transfer all or any of the ITN Rewards in the amounts or at the times proposed by you. You further acknowledge that if an exemption from registration or qualification is available, such exemption may be conditioned on various requirements including, but not limited to, the time and manner of sale, the holding period for the ITN Rewards, and on other factors outside of your control, for which the Company makes no assurances and may not be able to satisfy.

    4.4 Compliance with Liechtenstein Security Law. You understand that nothing in these Terms will be deemed to constitute a prospectus of any sort in Liechtenstein or in any jurisdiction in the EU; nor does it in any way pertain to a public offering or a solicitation of an offer to buy any securities in Liechtenstein or in any jurisdiction in the EU.

    4.5 No Public Market. You understand that no public market now exists for the ITN Rewards, and that the Company has not made any assurances that a public market will ever exist for the ITN Rewards.

    4.6 No Solicitation. At no time were you presented with or solicited by any publicly issued or circulated newspaper, mail, radio, television or other form of general advertising or solicitation in connection with any invitation to participate in the Program or offer of the ITN Rewards.

    4.7 Other Applicable Laws. You hereby represent that you have satisfied yourself as to the full observance of the laws of your jurisdiction in connection with any invitation to participate in the Program, receipt of ITN Awards, and other use of these Terms, including (a) the legal requirements within your jurisdiction for participating in the Program and receiving ITN Rewards, (b) any foreign exchange restrictions applicable to such participation or receipt, (c) any governmental or other consents that may need to be obtained, and (d) the income tax and other tax consequences, if any, that may be relevant to the receipt, holding, sale, or transfer of the ITN Rewards. Your participation in the Program and continued beneficial ownership of ITN Rewards will not violate any applicable securities or other laws of your jurisdiction.

    4.8 Non-US Transaction. You are not a U.S. Person as defined in Rule 902(k) of Regulation S under the 1933 Act. The offer of the ITN Rewards to you was made in an offshore transaction (as defined in Rule 902(h) of Regulation S), no directed selling efforts (as defined in Rule 902(c) of Regulation S) were made in the United States, and you are not obtaining the ITN Rewards for the account or benefit of any U.S. Person.

    4.9 Transfer Restrictions. You will not, during the Restricted Period (as defined below) offer or sell any of the ITN Rewards (or create or maintain any derivative position equivalent thereto) in the United States, to or for the account or benefit of a U.S. Person or other than in accordance with Regulation S. The Company reserves the right to impose additional transfer restrictions with respect to the ITN Rewards in its sole discretion.

    4.10 Subsequent Sales. You will, after the expiration of the applicable Restricted Period, only offer, sell, pledge or otherwise transfer the ITN Rewards (or create or maintain any derivative position equivalent thereto) pursuant to registration under the 1933 Act or any available exemption therefrom and, in any case, in accordance with applicable state securities laws.

    4.11 Legends. You acknowledge and agree that the ITN Rewards will be deemed to bear the following legends: (a) any legend required by the securities laws of any state or country to the extent such laws are applicable to the ITN Rewards represented by the certificate so legended, and (b): the following legend (and even without such legend the following restrictions apply):

    THE ITN REWARDS HAVE NOT BEEN REGISTERED UNDER THE ACT WITH THE UNITED STATES SECURITIES AND EXCHANGE COMMISSION, AND THE COMPANY DOES NOT INTEND TO REGISTER THEM. THE ITN REWARDS HAVE BEEN OBTAINED TO HOLD FOR THE LONG TERM AND NOT WITH A VIEW TO, OR IN CONNECTION WITH, THE SALE OR DISTRIBUTION THEREFOR. PRIOR TO THE ONE YEAR ANNIVERSARY FROM THE TERMINATION OF THE ITN REWARD PROGRAM (THE "PROGRAM COMPLETION DATE" AND SUCH ONE YEAR PERIOD, THE "RESTRICTED PERIOD"), THE ITN REWARDS MAY NOT BE OFFERED OR SOLD (INCLUDING OPENING A SHORT POSITION IN SUCH ITN REWARDS) IN THE UNITED STATES OR TO U.S. PERSONS AS DEFINED BY RULE 902(k) ADOPTED UNDER THE ACT, OTHER THAN TO DISTRIBUTORS, UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT, OR AN EXEMPTION FROM THE REGISTRATION REQUIREMENTS OF THE ACT IS AVAILABLE. RECIPIENTS OF ITN REWARDS PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE MAY SELL SUCH ITN REWARDS ONLY PURSUANT TO AN EXEMPTION FROM REGISTRATION UNDER THE ACT OR OTHERWISE IN ACCORDANCE WITH THE PROVISIONS OF REGULATION S OF THE ACT, OR IN TRANSACTIONS EFFECTED OUTSIDE OF THE UNITED STATES PROVIDED THEY DO NOT SOLICIT (AND NO ONE ACTING ON THEIR BEHALF SOLICITS) PURCHASERS IN THE UNITED STATES OR OTHERWISE ENGAGE(S) IN SELLING EFFORTS IN THE UNITED STATES AND PROVIDED THAT HEDGING TRANSACTIONS INVOLVING THESE ITN REWARDS MAY NOT BE CONDUCTED UNLESS IN COMPLIANCE WITH THE ACT. A HOLDER OF THE ITN REWARDS WHO IS A DISTRIBUTOR, DEALER, SUB-UNDERWRITER OR OTHER SECURITIES PROFESSIONAL, IN ADDITION, CANNOT PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE SELL THE ITN REWARDS TO A U.S. PERSON AS DEFINED BY RULE 902(k) OF REGULATION S UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT OR AN EXEMPTION FROM REGISTRATION UNDER THE ACT IS AVAILABLE.

    - +

    SUPPLEMENTAL INCENTIVIZED TESTNET TERMS

    Last Revised on 1/16/2023

    Welcome to the Supplemental Terms (these "ITN Award Program Terms" or "Terms") for the Incentivized Testnet Award Program (the "ITN Award Program" or the "Program") as operated on behalf of Strange Loop Labs AG ("Company", "we" or "us"). The ITN Award Program provides eligible users of a Testnet designated by the Company the opportunity to earn rewards, which may include Celestia tokens. These Terms are supplemental to, and incorporate by reference, the broader Celestia Terms of Service ("Services Terms") available at Celestia Terms of Service.

    Defined terms used but not defined herein have the meaning set forth in the Services Terms. The Program and your participation in it is a Service as defined under the Services Terms.

    These Terms govern your ability to participate in the Program and any awards you receive from that participation, which may include Celestia tokens ("ITN Rewards").

    Please read these Terms carefully, as they include important information about your legal rights. By participating in the Program or claiming ITN Rewards, you are agreeing to these Terms. If you do not understand or agree to these Terms, please do not participate in the Program or claim ITN Rewards.

    In order to participate in the Program you must provide certain information about you. Our collection of such information, your rights with respect to such collection, and other relevant information is described in the Celestia Privacy Policy available at Celestia Privacy Policy, and is supplemented by Section 3 of these Terms.

    The Program is a discretionary Service provided by the Company, pursuant to which the Company may, in its sole discretion, provide you ITN Rewards for your successful completion of certain tasks on a Testnet designated by the Company. Please note that any such Testnet itself (as well as any other Testnets or any mainnet deployment of the Celestia Protocol) is not a Service and does not constitute an element of the Services. We do not control the Celestia Protocol and accept no liability for its operation or its deployment in any testnet or mainnet environment.

    1. General Terms

    1.1 You must be eighteen (18) years of age or older and capable of forming a binding contract with the Company in order to participate in the Program or receive ITN Rewards.

    1.2 You agree and acknowledge that you (a) may receive ITN Rewards for free (other than applicable taxes, if any) from your participation in the Program, (b) were not previously promised ITN Rewards, unless pursuant to a separate written agreement, and (c) took no action in anticipation of or in reliance on receiving any ITN Rewards, unless pursuant to a separate written agreement.

    1.3 Your eligibility to participate in or receive ITN Rewards from the Program is subject to our sole discretion. The complete list of actions you must complete to earn ITN Rewards may not have been described in the documentation released by us from time to time, you may not receive ITN Rewards even if you successfully complete such actions, and no documentation related to the Program entitles you to any ITN Rewards or to participate in the Program.

    1.4 You agree and acknowledge that (a) you are not a Prohibited Person, (b) you are not a U.S. Person as defined in Rule 902(k) of Regulation S under the U.S. Securities Act of 1933, as amended (the "1933 Act" or "Act"), (c) you will not use a VPN or other tool to circumvent any geoblock or other restrictions that we may have implemented for participants in the Program, and (d) you are not participating in, and have not become eligible to participate in, the Program by receiving credentials from any other person or entity. Any circumvention or violation of the above will permanently disqualify you from participation in the Program.

    1.5 You agree and acknowledge that if you are unable to claim ITN Rewards due to technical bugs, gas fees, loss of access to a Wallet or the keys thereto, or for any other reason, you will have no recourse or claim against us or any other Company Entity and that neither we nor any other Company Entity will bear any liability.

    1.6 You agree and acknowledge that claiming an ITN Reward may require reliance on or an integration with third party products (e.g., a Wallet or an unaffiliated network or blockchain) that we do not control. In the event that you are unable to access such products or integrations, or if they fail for any reason, and you are unable to participate in the Program or claim ITN Rewards, you will have no recourse or claim against us or any other Company Entity and neither we nor any other Company Entity will bear any liability.

    1.7 The Company may share identifying information and documentation with certain vendors or third-party providers who provide such identity verification and sanctions and watchlist screening services (the "Third-Party Services"). You agree that your access and use of such Third-Party Services is governed solely by the terms and conditions of such Third-Party Services, and the Company is not responsible or liable for, and make no representations as to any aspect of such Third-Party Services, including, without limitation, their content or the manner in which they handle, protect, manage or process data or any interaction between you and the provider of such Third-Party Services. You irrevocably waive any claim against the Company with respect to such Third-Party Services. We are not liable for any damage or loss caused or alleged to be caused by or in connection with your enablement, access or use of any such Third-Party Services, or your reliance on the privacy practices, data security processes or other policies of such Third-Party Services.

    2. Taxes

    2.1 You are responsible for the payment of all taxes associated with your participation in the Program and your receipt of ITN Rewards. You agree to provide the Company with any additional information and complete any required tax or other forms relating to your receipt of ITN Rewards. You may suffer adverse tax consequences as a result of your participation in the Program or your receipt of ITN Rewards. You hereby represent that (a) you have consulted with a tax adviser that you deem advisable in connection with your participation, or that you have had the opportunity to obtain tax advice but have chosen not to do so, (b) the Company has not provided you with any tax advice with respect to your participation, and (c) you are not relying on the Company for any tax advice.

    3. Supplemental Privacy Information

    We may collect information to help us determine the reliability or uptime of your activities within the Program, including through the use of telemetry or metrics endpoints to collect and analyse such information, and link this information to a unique identifier to represent your activities within the Program. We may display all of the foregoing information on a public dashboard.

    Additionally, we may collect certain information about you from Third-Party Services and may combine information we receive from you with information we obtain from Third-Party Services, including but not limited to:

    • Transaction information. Information related to transactions in your Wallet, your Wallet address, activities performed using your Wallet, tokens received by your Wallet, or transactions initiated or completed.
    • Identification information. We collect your government identification (e.g., driver’s license, passport, etc.), proof of address, biometric information, and entity formation information if applicable. By agreeing to these Terms, you consent to our use of your biometric information, and understand and agree that our use of the biometric information is necessary for the performance of these Terms and the implementation of the Services.

    We collect this information to confirm your eligibility to participate in the Program and receive ITN Rewards, comply with our legal obligations, detect and prevent fraud, and to provide you with the Program.

    Any information we receive from third-party sources will be treated in accordance with the Celestia Privacy Policy, available at Celestia Privacy Policy. We are not responsible or liable for the accuracy of the information provided to us by third parties and are not responsible for any third party’s policies or practices. See Section 9 of the Celestia Privacy Policy for more information.

    4. Certain Additional Representations

    4.1 Receipt of Rewards Entirely for Own Account. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that any ITN Rewards you receive will be for your own account, not as a nominee or agent, and not with a view to the resale or distribution of any part thereof, and that you have no present intention of selling, granting any participation in, or otherwise distributing the same. By agreeing to these Terms, you further represent that you do not presently have any contract, undertaking, agreement or arrangement with any person to sell, transfer or grant participations to such person or to any third person, with respect to any ITN Rewards. If you are agreeing to these terms on behalf of an entity, that entity has not been formed for the specific purpose of obtaining the ITN Rewards.

    4.2 Disclosure of Information. Your eligibility to receive ITN Rewards is made in reliance upon your representation to the Company, which by your agreement to these Terms you hereby confirm, that you have sufficient knowledge of and experience in business and financial matters to be able to evaluate the risks and merits of your participation in the Program and of any ITN Rewards and are able to bear the risks thereof. You hereby affirm that you have not relied on any representations or warranties made by the Company related to the Program, including, but not limited to, conversations of any kind, whether through oral or electronic communication, or any white paper.

    4.3 Compliance with United States Securities Laws. You understand that the ITN Rewards have not been, and will not be, registered under the 1933 Act or any applicable state securities laws. You acknowledge that the availability of an exemption from the registration provisions of the Securities Act and other applicable state securities laws depends upon, among other things, the bona fide nature of your intent as described in Section 4.1 above and with respect to the accuracy of your representations as expressed throughout these Terms. You understand that the ITN Rewards may be deemed "restricted securities" under applicable United States federal and state securities laws and that, pursuant to these laws, you may be restricted from transferring any ITN Rewards unless they are registered with the Securities and Exchange Commission and qualified by state authorities, or an exemption from such registration and qualification requirements is available. You acknowledge that the Company does not undertake any obligation to register or qualify the ITN Rewards for resale, and exemptions from registration and qualification may not be available or may not permit you to transfer all or any of the ITN Rewards in the amounts or at the times proposed by you. You further acknowledge that if an exemption from registration or qualification is available, such exemption may be conditioned on various requirements including, but not limited to, the time and manner of sale, the holding period for the ITN Rewards, and on other factors outside of your control, for which the Company makes no assurances and may not be able to satisfy.

    4.4 Compliance with Liechtenstein Security Law. You understand that nothing in these Terms will be deemed to constitute a prospectus of any sort in Liechtenstein or in any jurisdiction in the EU; nor does it in any way pertain to a public offering or a solicitation of an offer to buy any securities in Liechtenstein or in any jurisdiction in the EU.

    4.5 No Public Market. You understand that no public market now exists for the ITN Rewards, and that the Company has not made any assurances that a public market will ever exist for the ITN Rewards.

    4.6 No Solicitation. At no time were you presented with or solicited by any publicly issued or circulated newspaper, mail, radio, television or other form of general advertising or solicitation in connection with any invitation to participate in the Program or offer of the ITN Rewards.

    4.7 Other Applicable Laws. You hereby represent that you have satisfied yourself as to the full observance of the laws of your jurisdiction in connection with any invitation to participate in the Program, receipt of ITN Awards, and other use of these Terms, including (a) the legal requirements within your jurisdiction for participating in the Program and receiving ITN Rewards, (b) any foreign exchange restrictions applicable to such participation or receipt, (c) any governmental or other consents that may need to be obtained, and (d) the income tax and other tax consequences, if any, that may be relevant to the receipt, holding, sale, or transfer of the ITN Rewards. Your participation in the Program and continued beneficial ownership of ITN Rewards will not violate any applicable securities or other laws of your jurisdiction.

    4.8 Non-US Transaction. You are not a U.S. Person as defined in Rule 902(k) of Regulation S under the 1933 Act. The offer of the ITN Rewards to you was made in an offshore transaction (as defined in Rule 902(h) of Regulation S), no directed selling efforts (as defined in Rule 902(c) of Regulation S) were made in the United States, and you are not obtaining the ITN Rewards for the account or benefit of any U.S. Person.

    4.9 Transfer Restrictions. You will not, during the Restricted Period (as defined below) offer or sell any of the ITN Rewards (or create or maintain any derivative position equivalent thereto) in the United States, to or for the account or benefit of a U.S. Person or other than in accordance with Regulation S. The Company reserves the right to impose additional transfer restrictions with respect to the ITN Rewards in its sole discretion.

    4.10 Subsequent Sales. You will, after the expiration of the applicable Restricted Period, only offer, sell, pledge or otherwise transfer the ITN Rewards (or create or maintain any derivative position equivalent thereto) pursuant to registration under the 1933 Act or any available exemption therefrom and, in any case, in accordance with applicable state securities laws.

    4.11 Legends. You acknowledge and agree that the ITN Rewards will be deemed to bear the following legends: (a) any legend required by the securities laws of any state or country to the extent such laws are applicable to the ITN Rewards represented by the certificate so legended, and (b): the following legend (and even without such legend the following restrictions apply):

    THE ITN REWARDS HAVE NOT BEEN REGISTERED UNDER THE ACT WITH THE UNITED STATES SECURITIES AND EXCHANGE COMMISSION, AND THE COMPANY DOES NOT INTEND TO REGISTER THEM. THE ITN REWARDS HAVE BEEN OBTAINED TO HOLD FOR THE LONG TERM AND NOT WITH A VIEW TO, OR IN CONNECTION WITH, THE SALE OR DISTRIBUTION THEREFOR. PRIOR TO THE ONE YEAR ANNIVERSARY FROM THE TERMINATION OF THE ITN REWARD PROGRAM (THE "PROGRAM COMPLETION DATE" AND SUCH ONE YEAR PERIOD, THE "RESTRICTED PERIOD"), THE ITN REWARDS MAY NOT BE OFFERED OR SOLD (INCLUDING OPENING A SHORT POSITION IN SUCH ITN REWARDS) IN THE UNITED STATES OR TO U.S. PERSONS AS DEFINED BY RULE 902(k) ADOPTED UNDER THE ACT, OTHER THAN TO DISTRIBUTORS, UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT, OR AN EXEMPTION FROM THE REGISTRATION REQUIREMENTS OF THE ACT IS AVAILABLE. RECIPIENTS OF ITN REWARDS PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE MAY SELL SUCH ITN REWARDS ONLY PURSUANT TO AN EXEMPTION FROM REGISTRATION UNDER THE ACT OR OTHERWISE IN ACCORDANCE WITH THE PROVISIONS OF REGULATION S OF THE ACT, OR IN TRANSACTIONS EFFECTED OUTSIDE OF THE UNITED STATES PROVIDED THEY DO NOT SOLICIT (AND NO ONE ACTING ON THEIR BEHALF SOLICITS) PURCHASERS IN THE UNITED STATES OR OTHERWISE ENGAGE(S) IN SELLING EFFORTS IN THE UNITED STATES AND PROVIDED THAT HEDGING TRANSACTIONS INVOLVING THESE ITN REWARDS MAY NOT BE CONDUCTED UNLESS IN COMPLIANCE WITH THE ACT. A HOLDER OF THE ITN REWARDS WHO IS A DISTRIBUTOR, DEALER, SUB-UNDERWRITER OR OTHER SECURITIES PROFESSIONAL, IN ADDITION, CANNOT PRIOR TO THE ONE YEAR ANNIVERSARY OF THE PROGRAM COMPLETION DATE SELL THE ITN REWARDS TO A U.S. PERSON AS DEFINED BY RULE 902(k) OF REGULATION S UNLESS THE ITN REWARDS ARE REGISTERED UNDER THE ACT OR AN EXEMPTION FROM REGISTRATION UNDER THE ACT IS AVAILABLE.

    + \ No newline at end of file diff --git a/pr-1680/community/modular-meetup-guide.html b/pr-1680/community/modular-meetup-guide.html index 885c62dd83..7d176f3231 100644 --- a/pr-1680/community/modular-meetup-guide.html +++ b/pr-1680/community/modular-meetup-guide.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/community/modular-meetup-intro.html b/pr-1680/community/modular-meetup-intro.html index 9ef9ce853a..cf046dafeb 100644 --- a/pr-1680/community/modular-meetup-intro.html +++ b/pr-1680/community/modular-meetup-intro.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/community/modular-meetup-toolkit.html b/pr-1680/community/modular-meetup-toolkit.html index d0b92cfbfe..55e7bfbef3 100644 --- a/pr-1680/community/modular-meetup-toolkit.html +++ b/pr-1680/community/modular-meetup-toolkit.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/community/overview.html b/pr-1680/community/overview.html index 81165dac2f..28c7a4e991 100644 --- a/pr-1680/community/overview.html +++ b/pr-1680/community/overview.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

    Community overview

    This section will highlight all the different resources and activities for the Celestia community.

    Here you will find links to our community calendar, Code of Conduct and other community-related resources.

    - +

    Community overview

    This section will highlight all the different resources and activities for the Celestia community.

    Here you will find links to our community calendar, Code of Conduct and other community-related resources.

    + \ No newline at end of file diff --git a/pr-1680/community/speaker-list.html b/pr-1680/community/speaker-list.html index e69882a6fb..ccefac740b 100644 --- a/pr-1680/community/speaker-list.html +++ b/pr-1680/community/speaker-list.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/developers/arbitrum-bridge.html b/pr-1680/developers/arbitrum-bridge.html index 3ae97228b9..b7ed89d157 100644 --- a/pr-1680/developers/arbitrum-bridge.html +++ b/pr-1680/developers/arbitrum-bridge.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/developers/arbitrum-dapp-deploy.html b/pr-1680/developers/arbitrum-dapp-deploy.html index da9597e6e0..7aeba42144 100644 --- a/pr-1680/developers/arbitrum-dapp-deploy.html +++ b/pr-1680/developers/arbitrum-dapp-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    Deploy a dapp on your Arbitrum rollup devnet

    First, review the Arbitrum integration, Quickstart: Deploy an Arbitrum Orbit rollup, and Deploy a smart contract to your Arbitrum rollup pages.

    Dependencies

    Setup and contract deployment

    1. Clone the gm-portal from GitHub and start the frontend:

      bash
      cd $HOME
      +

    Deploy a dapp on your Arbitrum rollup devnet

    First, review the Arbitrum integration, Quickstart: Deploy an Arbitrum Orbit rollup, and Deploy a smart contract to your Arbitrum rollup pages.

    Dependencies

    Setup and contract deployment

    1. Clone the gm-portal from GitHub and start the frontend:

      bash
      cd $HOME
       git clone https://github.com/jcstein/gm-portal.git
       cd gm-portal && git checkout arbitrum
       cd frontend && yarn && yarn dev
      cd $HOME
      @@ -58,8 +58,8 @@
       cast send --private-key $PRIVATE_KEY $RECEIVER --value 1ether --rpc-url $ARB_RPC_URL
      export RECEIVER=<receiver ETH address>
       cast send --private-key $PRIVATE_KEY $RECEIVER --value 1ether --rpc-url $ARB_RPC_URL

      TIP

      If you are in a different terminal than the one you set the private key in, you may need to set it again.

    Update the frontend

    Next, you will need to update a few things before you can interact with the contract on the frontend:

    1. Change the contract address on gm-portal/frontend/src/App.tsx to your contract address
    2. Match the chain info on gm-portal/frontend/src/main.tsx with the chain config of your L2
    3. If you changed the contract, update the ABI in gm-portal/frontend/GmPortal.json from gm-portal/contracts/out/GmPortal.sol/GmPortal.json. This can be done with:
    bash
    cd $HOME
     cp dev/gm-portal/contracts/out/GmPortal.sol/GmPortal.json dev/gm-portal/frontend
    cd $HOME
    -cp dev/gm-portal/contracts/out/GmPortal.sol/GmPortal.json dev/gm-portal/frontend

    Interact with the frontend

    Now, login with your wallet that you funded, and post a GM on your GM portal!

    gm-arb

    - +cp dev/gm-portal/contracts/out/GmPortal.sol/GmPortal.json dev/gm-portal/frontend

    Interact with the frontend

    Now, login with your wallet that you funded, and post a GM on your GM portal!

    gm-arb

    + \ No newline at end of file diff --git a/pr-1680/developers/arbitrum-deploy.html b/pr-1680/developers/arbitrum-deploy.html index 236fe89682..c4bee7be81 100644 --- a/pr-1680/developers/arbitrum-deploy.html +++ b/pr-1680/developers/arbitrum-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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 3: 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 4: 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 5: 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 6: 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 7: 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:
    +

    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 3: 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 4: 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 5: 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 6: 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 7: 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,
    @@ -148,8 +148,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-1680/developers/arbitrum-full-node.html b/pr-1680/developers/arbitrum-full-node.html index ffeff67b5e..a5d29f86b9 100644 --- a/pr-1680/developers/arbitrum-full-node.html +++ b/pr-1680/developers/arbitrum-full-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,10 +38,10 @@

    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" \
    +

    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-1680/developers/arbitrum-integration.html b/pr-1680/developers/arbitrum-integration.html index 6feb6f1a05..cf2795784a 100644 --- a/pr-1680/developers/arbitrum-integration.html +++ b/pr-1680/developers/arbitrum-integration.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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 "unpealed" 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 unpealed 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 "unpealed" 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 unpealed 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-1680/developers/arbitrum-smart-contract.html b/pr-1680/developers/arbitrum-smart-contract.html index e90510196b..3fa9cc26fb 100644 --- a/pr-1680/developers/arbitrum-smart-contract.html +++ b/pr-1680/developers/arbitrum-smart-contract.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    Deploy a smart contract to your Arbitrum rollup

    Overview

    Welcome to the guide on deploying a smart contract to your Arbitrum rollup. In this tutorial, you will learn how to deploy a smart contract using the L2 Nitro devnet and the provided public and private keys for testing purposes.

    Prerequisites

    Setup

    First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

    bash
    cd $HOME
    +

    Deploy a smart contract to your Arbitrum rollup

    Overview

    Welcome to the guide on deploying a smart contract to your Arbitrum rollup. In this tutorial, you will learn how to deploy a smart contract using the L2 Nitro devnet and the provided public and private keys for testing purposes.

    Prerequisites

    Setup

    First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

    bash
    cd $HOME
     mkdir counter-project && cd counter-project && npm init -y
    cd $HOME
     mkdir counter-project && cd counter-project && npm init -y

    Next, initialize a Foundry project with the following command:

    bash
    forge init counter_contract
    forge init counter_contract

    Create your smart contract

    Take a look at the Counter.sol file in your counter-project/counter_contract/src directory:

    solidity
    // SPDX-License-Identifier: UNLICENSED
     pragma solidity ^0.8.13;
    @@ -170,8 +170,8 @@
     status                  1
     transactionHash         0x8f15d6004598f0662dd673a9898dceef77be8cc28408cecc284b28d7be32307d
     transactionIndex        0
    -type                    2

    Now, we can make a read call to view the state of the number variable, using the cast call command:

    bash
    cast call $CONTRACT_ADDRESS "number()" --rpc-url $ARB_RPC_URL
    cast call $CONTRACT_ADDRESS "number()" --rpc-url $ARB_RPC_URL

    The result will look similar:

    bash
    0x000000000000000000000000000000000000000000000000000000000000000a
    0x000000000000000000000000000000000000000000000000000000000000000a

    Convert the result from hexadecimal to a base 10 value with:

    bash
    echo $((0x000000000000000000000000000000000000000000000000000000000000000a))
    echo $((0x000000000000000000000000000000000000000000000000000000000000000a))

    Next steps

    Congratulations! You've learned how to deploy a smart contract to your Arbitrum rollup devnet.

    What will you build next? In our next tutorial, we will be going over how to deploy a dapp to your Arbitrum rollup.

    - +type 2

    Now, we can make a read call to view the state of the number variable, using the cast call command:

    bash
    cast call $CONTRACT_ADDRESS "number()" --rpc-url $ARB_RPC_URL
    cast call $CONTRACT_ADDRESS "number()" --rpc-url $ARB_RPC_URL

    The result will look similar:

    bash
    0x000000000000000000000000000000000000000000000000000000000000000a
    0x000000000000000000000000000000000000000000000000000000000000000a

    Convert the result from hexadecimal to a base 10 value with:

    bash
    echo $((0x000000000000000000000000000000000000000000000000000000000000000a))
    echo $((0x000000000000000000000000000000000000000000000000000000000000000a))

    Next steps

    Congratulations! You've learned how to deploy a smart contract to your Arbitrum rollup devnet.

    What will you build next? In our next tutorial, we will be going over how to deploy a dapp to your Arbitrum rollup.

    + \ No newline at end of file diff --git a/pr-1680/developers/blobstream-contracts.html b/pr-1680/developers/blobstream-contracts.html index f287a42af0..b42660f39c 100644 --- a/pr-1680/developers/blobstream-contracts.html +++ b/pr-1680/developers/blobstream-contracts.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,33 +38,32 @@

    Integrate with Blobstream contracts

    Getting started

    Prerequisites

    Make sure to have the following installed:

    Installing Blobstream X contracts

    We will be using the Blobstream X implementation of Blobstream, so we can install its repo as a dependency:

    Install the Blobstream X contracts repo as a dependency:

    sh
    forge install succinctlabs/blobstreamx --no-commit
    forge install succinctlabs/blobstreamx --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
    +

    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;
     
    -TBD
     import "blobstream-contracts/IDAOracle.sol";
     import "blobstream-contracts/DataRootTuple.sol";
     import "blobstream-contracts/lib/tree/binary/BinaryMerkleProof.sol";
     
     contract MyRollup {
    -    IDAOracle immutable blobstreamX;
    +    IDAOracle immutable blobstream;
         bytes32[] public rollup_block_hashes;
     
    -    constructor(IDAOracle _blobstreamX) {
    -        blobstreamX = _blobstreamX;
    +    constructor(IDAOracle _blobstream) {
    +        blobstream = _blobstream;
         }
     
         function submitRollupBlock(
             bytes32 _rollup_block_hash,
             bytes calldata _zk_proof,
    -        uint256 _blobstreamX_nonce,
    +        uint256 _blobstream_nonce,
             DataRootTuple calldata _tuple,
             BinaryMerkleProof calldata _proof
         ) public {
             // Verify that the data root tuple (analog. block header) has been
             // attested to by the Blobstream contract.
             require(
    -            blobstreamX.verifyAttestation(_blobstreamX_nonce, _tuple, _proof)
    +            blobstream.verifyAttestation(_blobstream_nonce, _tuple, _proof)
             );
     
             // Verify the ZKP (zero-knowledge proof).
    @@ -85,30 +84,29 @@
     }
    // SPDX-License-Identifier: Apache-2.0
     pragma solidity ^0.8.19;
     
    -TBD
     import "blobstream-contracts/IDAOracle.sol";
     import "blobstream-contracts/DataRootTuple.sol";
     import "blobstream-contracts/lib/tree/binary/BinaryMerkleProof.sol";
     
     contract MyRollup {
    -    IDAOracle immutable blobstreamX;
    +    IDAOracle immutable blobstream;
         bytes32[] public rollup_block_hashes;
     
    -    constructor(IDAOracle _blobstreamX) {
    -        blobstreamX = _blobstreamX;
    +    constructor(IDAOracle _blobstream) {
    +        blobstream = _blobstream;
         }
     
         function submitRollupBlock(
             bytes32 _rollup_block_hash,
             bytes calldata _zk_proof,
    -        uint256 _blobstreamX_nonce,
    +        uint256 _blobstream_nonce,
             DataRootTuple calldata _tuple,
             BinaryMerkleProof calldata _proof
         ) public {
             // Verify that the data root tuple (analog. block header) has been
             // attested to by the Blobstream contract.
             require(
    -            blobstreamX.verifyAttestation(_blobstreamX_nonce, _tuple, _proof)
    +            blobstream.verifyAttestation(_blobstream_nonce, _tuple, _proof)
             );
     
             // Verify the ZKP (zero-knowledge proof).
    @@ -126,8 +124,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-1680/developers/blobstream-offchain.html b/pr-1680/developers/blobstream-offchain.html index dbc55c2281..4d1f70fb8b 100644 --- a/pr-1680/developers/blobstream-offchain.html +++ b/pr-1680/developers/blobstream-offchain.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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 X 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 {
    +

    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
    @@ -334,8 +334,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-1680/developers/blobstream-proof-queries.html b/pr-1680/developers/blobstream-proof-queries.html index 913e2159d2..39d81d556c 100644 --- a/pr-1680/developers/blobstream-proof-queries.html +++ b/pr-1680/developers/blobstream-proof-queries.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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")
    +

    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 {
     		...
     	}
    @@ -64,7 +64,7 @@
     		if err != nil {
     			...
     		}
    -	}(trpc)

    The <rpc_endpoint> can be retrieved from mainnet for Celestia mainnet beta, 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 Blobstream X repository. 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. Currently, we will be using the Blobstream X implementation of Blobstream, more information on Blobstream X can be found in the overview. In a nutshell, Blobstream X attests to the data posted to Celestia in the Blobstream X 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 X 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 X 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 for Celestia mainnet beta, 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
    @@ -76,7 +76,7 @@
         github.com/syndtr/goleveldb => github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7
         github.com/tendermint/tendermint => github.com/celestiaorg/celestia-core v1.32.0-tm-v0.34.29
     
    -)

    Also, make sure to update the versions to match the latest github.com/celestiaorg/cosmos-sdk and github.com/celestiaorg/celestia-core versions.

    1. Data root inclusion proof

    To prove the data root is committed to by the Blobstream X 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.

    This endpoint allows querying a data root to data root tuple root proof. It takes a block height, a starting block, and an end block, then it generates the binary Merkle proof of the DataRootTuple, corresponding to that height, to the DataRootTupleRoot which is committed to in the Blobstream X contract.

    HTTP query

    Example HTTP request: <tendermint_rpc_endpoint>/data_root_inclusion_proof?height=15&start=10&end=20

    Which queries the proof of the height 15 to the data commitment defined by the range [10, 20).

    Example response:

    json
    {
    +)

    Also, make sure to update the versions to match the latest github.com/celestiaorg/cosmos-sdk and github.com/celestiaorg/celestia-core versions.

    1. Data root inclusion proof

    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.

    This endpoint allows querying a data root to data root tuple root proof. It takes a block height, a starting block, and an end block, then it generates the binary Merkle proof of the DataRootTuple, corresponding to that height, to the DataRootTupleRoot which is committed to in the Blobstream contract.

    HTTP query

    Example HTTP request: <tendermint_rpc_endpoint>/data_root_inclusion_proof?height=15&start=10&end=20

    Which queries the proof of the height 15 to the data commitment defined by the range [10, 20).

    Example response:

    json
    {
       "jsonrpc": "2.0",
       "id": -1,
       "result": {
    @@ -162,7 +162,7 @@
     		os.Exit(1)
     	}
     	fmt.Println(dcProof.Proof.String())
    -}

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

    go
    package main
    +}

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

    go
    package main
     
     import (
     	"context"
    @@ -289,7 +289,7 @@
     		fmt.Println("data root was not committed to by the BlobstreamX contract")
     		return nil
     	}
    -    return nil
    +	return nil
     }
     
     func VerifyDataRootInclusion(
    @@ -452,7 +452,7 @@
     		fmt.Println("data root was not committed to by the BlobstreamX contract")
     		return nil
     	}
    -    return nil
    +	return nil
     }
     
     func VerifyDataRootInclusion(
    @@ -488,7 +488,13 @@
     		return false, err
     	}
     	return valid, nil
    -}

    2. Transaction inclusion proof

    To prove that a rollup transaction, the PFB transaction and not the blob containing the Rollup blocks data, is part of the data root, we will need to provide two proofs: (1) a namespace Merkle proof of the transaction to a row root. This could be done via proving the shares that contain the transaction to the row root using a namespace Merkle proof. (2) And a binary Merkle proof of the row root to the data root.

    Transaction inclusion proof using the transaction hash

    Given a transaction hash, the transaction inclusion proof can be queried from the transaction query.

    HTTP request

    Example request: <tendermint_rpc_endpoint>/tx?hash=0xEF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8&prove=true

    Which queries the transaction whose hash is EF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8 and sets the prove parameter as true to also get its inclusion proof.

    Example response:

    json
    {
    +}
    go
    // Similar to Blobstream, except replace the BlobstreamX contract with SP1 Blobstream:
    +import {
    +  sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
    +}
    // Similar to Blobstream, except replace the BlobstreamX contract with SP1 Blobstream:
    +import {
    +  sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
    +}

    2. Transaction inclusion proof

    To prove that a rollup transaction, the PFB transaction and not the blob containing the Rollup blocks data, is part of the data root, we will need to provide two proofs: (1) a namespace Merkle proof of the transaction to a row root. This could be done via proving the shares that contain the transaction to the row root using a namespace Merkle proof. (2) And a binary Merkle proof of the row root to the data root.

    Transaction inclusion proof using the transaction hash

    Given a transaction hash, the transaction inclusion proof can be queried from the transaction query.

    HTTP request

    Example request: <tendermint_rpc_endpoint>/tx?hash=0xEF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8&prove=true

    Which queries the transaction whose hash is EF9F50BFB39F11B022A6CD7026574ECCDC6D596689BDCCC7B2C482A1B26B26B8 and sets the prove parameter as true to also get its inclusion proof.

    Example response:

    json
    {
       "jsonrpc": "2.0",
       "id": -1,
       "result": {
    @@ -801,12 +807,12 @@
         NamespaceNode[] rowRoots;
         // The proofs of the rowRoots to the data root.
         BinaryMerkleProof[] rowProofs;
    -    // The proof of the data root tuple to the data root tuple root that was posted to the BlobstreamX contract.
    +    // The proof of the data root tuple to the data root tuple root that was posted to the Blobstream contract.
         AttestationProof attestationProof;
     }
     
     /// @notice Contains the necessary parameters needed to verify that a data root tuple
    -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
    +/// was committed to, by the Blobstream smart contract, at some specif nonce.
     struct AttestationProof {
         // the attestation nonce that commits to the data root tuple.
         uint256 tupleRootNonce;
    @@ -827,12 +833,12 @@
         NamespaceNode[] rowRoots;
         // The proofs of the rowRoots to the data root.
         BinaryMerkleProof[] rowProofs;
    -    // The proof of the data root tuple to the data root tuple root that was posted to the BlobstreamX contract.
    +    // The proof of the data root tuple to the data root tuple root that was posted to the Blobstream contract.
         AttestationProof attestationProof;
     }
     
     /// @notice Contains the necessary parameters needed to verify that a data root tuple
    -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
    +/// was committed to, by the Blobstream smart contract, at some specif nonce.
     struct AttestationProof {
         // the attestation nonce that commits to the data root tuple.
         uint256 tupleRootNonce;
    @@ -1066,8 +1072,8 @@
     		}
     	}
     	return rowProofs
    -}

    with proofs being sharesProof.RowProof.Proofs.

    attestationProof

    This is the proof of the data root to the data root tuple root, which is committed to in the Blobstream X contract:

    solidity
    /// @notice Contains the necessary parameters needed to verify that a data root tuple
    -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
    +}

    with proofs being sharesProof.RowProof.Proofs.

    attestationProof

    This is the proof of the data root to the data root tuple root, which is committed to in the Blobstream contract:

    solidity
    /// @notice Contains the necessary parameters needed to verify that a data root tuple
    +/// was committed to, by the Blobstream smart contract, at some specif nonce.
     struct AttestationProof {
         // the attestation nonce that commits to the data root tuple.
         uint256 tupleRootNonce;
    @@ -1076,7 +1082,7 @@
         // the binary Merkle proof of the tuple to the commitment.
         BinaryMerkleProof proof;
     }
    /// @notice Contains the necessary parameters needed to verify that a data root tuple
    -/// was committed to, by the BlobstreamX smart contract, at some specif nonce.
    +/// was committed to, by the Blobstream smart contract, at some specif nonce.
     struct AttestationProof {
         // the attestation nonce that commits to the data root tuple.
         uint256 tupleRootNonce;
    @@ -1084,7 +1090,7 @@
         DataRootTuple tuple;
         // the binary Merkle proof of the tuple to the commitment.
         BinaryMerkleProof proof;
    -}
    • tupleRootNonce: the nonce at which Blobstream X committed to the batch containing the block containing the data.
    • tuple: the DataRootTuple of the block:
    solidity
    /// @notice A tuple of data root with metadata. Each data root is associated
    +}
    • tupleRootNonce: the nonce at which Blobstream committed to the batch containing the block containing the data.
    • tuple: the DataRootTuple of the block:
    solidity
    /// @notice A tuple of data root with metadata. Each data root is associated
     ///  with a Celestia block height.
     /// @dev `availableDataRoot` in
     ///  https://github.com/celestiaorg/celestia-specs/blob/master/src/specs/data_structures.md#header
    @@ -1156,7 +1162,7 @@
     			NumLeaves: big.NewInt(dataRootInclusionProof.Total),
     		},
     	}
    -}

    With the nonce being the attestation nonce, which can be retrieved using BlobstreamX 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 BlobstreamXDataCommitmentStored events from the BlobstreamX contract and looking for the nonce attesting to the corresponding data. An example:

    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
    @@ -1270,7 +1276,17 @@
     	}
     	if event == nil {
     		return fmt.Errorf("couldn't find range containing the block height")
    -	}

    Listening for new data commitments

    For listening for new BlobstreamXDataCommitmentStored events, sequencers can use the WatchDataCommitmentStored as follows:

    go
        ethClient, err := ethclient.Dial("evm_rpc")
    +	}
    go
    // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
    +// import the SP1 Blobstream contract:
    +import {
    +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
    +} 
    +// and use the `BlobstreamDataCommitmentStored` event instead.
    // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
    +// import the SP1 Blobstream contract:
    +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")
         if err != nil {
     	    return err
         }
    @@ -1340,7 +1356,17 @@
     			// process the event
     		    fmt.Println(event)
     	    }
    -    }

    Then, new proofs can be created as documented above using the new data commitments contained in the received events.

    Example rollup that uses the DAVerifier

    An example rollup that uses the DAVerifier can be as simple as:

    solidity
    pragma solidity ^0.8.22;
    +    }
    go
    // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
    +// import the SP1 Blobstream contract:
    +import {
    +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
    +} 
    +// and use the `BlobstreamDataCommitmentStored` event instead.
    // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
    +// import the SP1 Blobstream contract:
    +import {
    +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
    +} 
    +// and use the `BlobstreamDataCommitmentStored` event instead.

    Then, new proofs can be created as documented above using the new data commitments contained in the received events.

    Example rollup that uses the DAVerifier

    An example rollup that uses the DAVerifier can be as simple as:

    solidity
    pragma solidity ^0.8.22;
     
     import {DAVerifier} from "@blobstream/lib/verifier/DAVerifier.sol";
     import {IDAOracle} from "@blobstream/IDAOracle.sol";
    @@ -1378,7 +1404,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"
    @@ -1842,8 +1868,18 @@
     		Version: [1]byte{version},
     		Id:      id,
     	}
    -}

    For the step (2), check the rollup inclusion proofs documentation for more information.

    For an example project that uses the above proof queries, checkout the blobstreamx-example sample project.

    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.

    - +}
    go
    // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
    +// import the SP1 Blobstream contract:
    +import {
    +    sp1blobstreamwrapper "github.com/succinctlabs/sp1-blobstream/bindings"
    +} 
    +// and use the `BlobstreamDataCommitmentStored` event instead.
    // Similar to BlobstreamX, but instead of importing the BlobstreamX contract,
    +// import the SP1 Blobstream contract:
    +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.

    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-1680/developers/blobstream-rollups.html b/pr-1680/developers/blobstream-rollups.html index 8c31c04ff7..4eaec26a6f 100644 --- a/pr-1680/developers/blobstream-rollups.html +++ b/pr-1680/developers/blobstream-rollups.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,10 +38,10 @@

    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;
      +

    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-1680/developers/blobstream-x-deploy.html b/pr-1680/developers/blobstream-x-deploy.html index bc91ef1183..3727bfa087 100644 --- a/pr-1680/developers/blobstream-x-deploy.html +++ b/pr-1680/developers/blobstream-x-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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
+

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
@@ -210,8 +210,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-1680/developers/blobstream-x-requesting-data-commitment-ranges.html b/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges.html index 6088ddf566..f621263cb1 100644 --- a/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges.html +++ b/pr-1680/developers/blobstream-x-requesting-data-commitment-ranges.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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.

::: Note 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.

::: Note 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-1680/developers/blobstream.html b/pr-1680/developers/blobstream.html index 6b1902adab..c1cc71ef29 100644 --- a/pr-1680/developers/blobstream.html +++ b/pr-1680/developers/blobstream.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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.

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

Learn more at the sp1-blobstream repo.

What is Blobstream X?

Blobstream X is an 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. Blobstream X utilizes 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 Blobstream X Ethereum smart contract to update it with the latest Celestia header.

The Blobstream X 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.

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

blobstream x draft diagram

Integrate with Blobstream X

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

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

The first deployments of Blobstream X 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 X contract that will include a new data commitment range that covers a 1-hour block range from the latestBlock in the Blobstream X contract. On Ethereum Mainnet, the Blobstream X contract will be updated every 4 hours.

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.

How to integrate with Blobstream X

Integrating your L2 with Blobstream X 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 Blobstream X contracts today. The Blobstream X Solidity smart contracts are currently deployed on the following chains:

WARNING

Blobstream X is in beta and slashing is not enabled yet.

ContractEVM networkContract addressAttested data on CelestiaLink to Celenium
Blobstream XEthereum Mainnet0x7Cf3876F681Dbb6EdA8f6FfC45D66B996Df08fAeMainnet BetaDeployment on Celenium
Blobstream XArbitrum One0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
Blobstream XBase0xA83ca7775Bc2889825BcDeDfFa5b758cf69e8794Mainnet BetaDeployment on Celenium
Blobstream XSepolia0xf0c6429ebab2e7dc6e05dafb61128be21f13cb1eMocha testnetDeployment on Celenium
Blobstream XArbitrum Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium
Blobstream XBase Sepolia0xc3e209eb245Fd59c8586777b499d6A665DF3ABD2Mocha testnetDeployment on Celenium

Deploy Blobstream X

If your target chain is still not supported, 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.

- +

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-1680/developers/blobstreamx.html b/pr-1680/developers/blobstreamx.html new file mode 100644 index 0000000000..2b3c022435 --- /dev/null +++ b/pr-1680/developers/blobstreamx.html @@ -0,0 +1,45 @@ + + + + + + BlobstreamX: the previous zk implementation of Blobstream | Celestia Docs + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Skip to content

BlobstreamX: 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.

+ + + + \ No newline at end of file diff --git a/pr-1680/developers/bubs-testnet.html b/pr-1680/developers/bubs-testnet.html index 6cd35e90d6..1bc46aa30a 100644 --- a/pr-1680/developers/bubs-testnet.html +++ b/pr-1680/developers/bubs-testnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/developers/build-whatever.html b/pr-1680/developers/build-whatever.html index 7785bc5e9e..1dcabf533f 100644 --- a/pr-1680/developers/build-whatever.html +++ b/pr-1680/developers/build-whatever.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

Build whatever

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.

- +

Build whatever

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-1680/developers/celestia-node-key.html b/pr-1680/developers/celestia-node-key.html index 3fd7003079..b4bc705888 100644 --- a/pr-1680/developers/celestia-node-key.html +++ b/pr-1680/developers/celestia-node-key.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,34 +39,34 @@

Create a wallet with celestia-node

This tutorial will go over using the cel-key utility to generate a wallet on celestia-node.

While this tutorial will go over installation process of cel-key, it is recommended that you complete the following prerequisites first:

Once you completed the prerequisite, you can proceed with this tutorial.

Using the cel-key utility

Inside the celestia-node repository is a utility called cel-key that uses the key utility provided by Cosmos-SDK under the hood. The utility can be used to add, delete, and manage keys for any DA node type (bridge || full || light), or just keys in general.

Installation

You need to first pull down the celestia-node repository:

sh
git clone https://github.com/celestiaorg/celestia-node.git
+

Create a wallet with celestia-node

This tutorial will go over using the cel-key utility to generate a wallet on celestia-node.

While this tutorial will go over installation process of cel-key, it is recommended that you complete the following prerequisites first:

Once you completed the prerequisite, you can proceed with this tutorial.

Using the cel-key utility

Inside the celestia-node repository is a utility called cel-key that uses the key utility provided by Cosmos-SDK under the hood. The utility can be used to add, delete, and manage keys for any DA node type (bridge || full || light), or just keys in general.

Installation

You need to first pull down the celestia-node repository:

sh
git clone https://github.com/celestiaorg/celestia-node.git
 cd celestia-node/
git clone https://github.com/celestiaorg/celestia-node.git
 cd celestia-node/

It can be built using either of the following commands:

sh
# dumps binary in current working directory, accessible via `./cel-key`
 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 \
   --node.type full --p2p.network <network>
bash
./cel-key add <key-name> --recover --keyring-backend test \
   --node.type light --p2p.network <network>
./cel-key add <key-name> --recover --keyring-backend test \
   --node.type light --p2p.network <network>

View all options for cel-key

sh
./cel-key --help
./cel-key --help

Docker and cel-key

Prerequisites

Running your node

Run the Docker image (in this example, we are using a light node on Mocha testnet):

bash
docker run --name celestia-node -e NODE_TYPE=light -e P2P_NETWORK=mocha -p 26659:26659 \
-ghcr.io/celestiaorg/celestia-node:v0.16.0-rc0 celestia light start \
+ghcr.io/celestiaorg/celestia-node:v0.16.0 celestia light start \
 --core.ip rpc-mocha.pops.one --p2p.network mocha
docker run --name celestia-node -e NODE_TYPE=light -e P2P_NETWORK=mocha -p 26659:26659 \
-ghcr.io/celestiaorg/celestia-node:v0.16.0-rc0 celestia light start \
+ghcr.io/celestiaorg/celestia-node:v0.16.0 celestia light start \
 --core.ip rpc-mocha.pops.one --p2p.network mocha

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.

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

List active containers in another window with:

bash
docker ps
docker ps

The response will look like:

bash
CONTAINER ID   IMAGE           COMMAND                  CREATED          STATUS          PORTS      NAMES
 <container-id>   celestia-node   "/entrypoint.sh cele…"   22 seconds ago   Up 21 seconds   2121/tcp   docker-compose-test-celestia-1
CONTAINER ID   IMAGE           COMMAND                  CREATED          STATUS          PORTS      NAMES
 <container-id>   celestia-node   "/entrypoint.sh cele…"   22 seconds ago   Up 21 seconds   2121/tcp   docker-compose-test-celestia-1

Interact with the container by replacing <container-id> for the container ID:

bash
docker exec -ti <container-id> /bin/bash
docker exec -ti <container-id> /bin/bash

Now, interact with cel-key to check for the key that was autogenerated when you started the node:

bash
./cel-key list --keyring-backend test --node.type light
./cel-key list --keyring-backend test --node.type light

You can also export your key from the container. In the next section, you'll learn how to mount existing keys to the container.

Mounting existing keys to container

In this example, we'll be mounting an existing key to the container. We're also using an existing image called celestia-node. This will mount the entire /.celestia-light-<p2p-network>/keys directory to your image, or on Mainnet Beta the /.celestia-light/keys directory.

Write a docker-compose.yml to accomplish this:

yaml
version: "3.8"
@@ -101,8 +101,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-1680/developers/deploy-on-bubs.html b/pr-1680/developers/deploy-on-bubs.html index 49752992a2..45a6ea920d 100644 --- a/pr-1680/developers/deploy-on-bubs.html +++ b/pr-1680/developers/deploy-on-bubs.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

Deploy a smart contract on Bubs testnet

In this tutorial, we will deploy a smart contract to the Bubs testnet.

Dependencies

Setup

First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

bash
cd $HOME
+

Deploy a smart contract on Bubs testnet

In this tutorial, we will deploy a smart contract to the Bubs testnet.

Dependencies

Setup

First, in your $HOME directory, set up a new project folder for this tutorial and init the project with npm:

bash
cd $HOME
 mkdir counter-project && cd counter-project && npm init -y
cd $HOME
 mkdir counter-project && cd counter-project && npm init -y

Next, initialize a Foundry project with the following command:

bash
forge init counter_contract
forge init counter_contract

Create your smart contract

Take a look at the Counter.sol file in your counter-project/counter_contract/src directory:

solidity
// SPDX-License-Identifier: UNLICENSED
 pragma solidity ^0.8.13;
@@ -174,8 +174,8 @@
 status                  1
 transactionHash         0x8f15d6004598f0662dd673a9898dceef77be8cc28408cecc284b28d7be32307d
 transactionIndex        0
-type                    2

Now, we can make a read call to view the state of the number variable, using the cast call command:

bash
cast call $CONTRACT_ADDRESS "number()" --rpc-url $BUBS_RPC_URL
cast call $CONTRACT_ADDRESS "number()" --rpc-url $BUBS_RPC_URL

The result will look similar:

bash
0x000000000000000000000000000000000000000000000000000000000000000a
0x000000000000000000000000000000000000000000000000000000000000000a

Convert the result from hexadecimal to a base 10 value with:

bash
echo $((0x000000000000000000000000000000000000000000000000000000000000000a))
echo $((0x000000000000000000000000000000000000000000000000000000000000000a))

Next steps

Congratulations! You've learned how to deploy a smart contract to Bubs testnet.

What will you build next? Now, you're ready to check out the GM Portal tutorial.

- +type 2

Now, we can make a read call to view the state of the number variable, using the cast call command:

bash
cast call $CONTRACT_ADDRESS "number()" --rpc-url $BUBS_RPC_URL
cast call $CONTRACT_ADDRESS "number()" --rpc-url $BUBS_RPC_URL

The result will look similar:

bash
0x000000000000000000000000000000000000000000000000000000000000000a
0x000000000000000000000000000000000000000000000000000000000000000a

Convert the result from hexadecimal to a base 10 value with:

bash
echo $((0x000000000000000000000000000000000000000000000000000000000000000a))
echo $((0x000000000000000000000000000000000000000000000000000000000000000a))

Next steps

Congratulations! You've learned how to deploy a smart contract to Bubs testnet.

What will you build next? Now, you're ready to check out the GM Portal tutorial.

+ \ No newline at end of file diff --git a/pr-1680/developers/ethereum-fallback.html b/pr-1680/developers/ethereum-fallback.html index 9c284bbe88..01a8146ed5 100644 --- a/pr-1680/developers/ethereum-fallback.html +++ b/pr-1680/developers/ethereum-fallback.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

Ethereum fallback

Ethereum fallback is a mechanism that enables Ethereum L2s (or L3s) to “fall back” 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 “fall back” 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-1680/developers/feegrant-for-blobs.html b/pr-1680/developers/feegrant-for-blobs.html index be05578e11..d3d55b1138 100644 --- a/pr-1680/developers/feegrant-for-blobs.html +++ b/pr-1680/developers/feegrant-for-blobs.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,17 +38,11 @@

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.celestia-mocha.com: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>
+

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.celestia-mocha.com: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.celestia-mocha.com
export GRANTER_ADDRESS=<your-granter-account-address>
 export GRANTEE_ADDRESS=<your-grantee-account-address>
-export RPC_URL=rpc.celestia-mocha.com

FeeGrant module implementation in celestia-node

Using celestia-node, you now can easily give permission for other nodes to submit transactions on your behalf. It is also possible to revoke the grant.

The node that receives the grant has to run a node with the --granter.address=$GRANTER_ADDRESS> flag to use FeeGrant functionality.

The granter address will be stored until the next run of your local node. So, in case the granter revokes permission, you will have to restart the node without this flag.

TIP

Transactions paid for by the the FeeGrant module will consume more gas than regular PayForBlobs transactions.

Fee and transaction typeTransaction 1Transaction 2
0.000176 fee with feegrant on Mocha testnetLinkLink
0.00016 fee without feegrant on Mocha testnetLinkLink

Grant permission for an allowance as a granter

First, your node will need to be running with a command similar to:

bash
celestia light start --p2p.network mocha --core.ip $RPC_URL \
-  --keyring.keyname granter_key
celestia light start --p2p.network mocha --core.ip $RPC_URL \
-  --keyring.keyname granter_key

Then, grant the fee to the grantee:

bash
celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000
celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000

Note that the --amount uint flag specifies the spend limit (in utia) for the grantee. The default value is 0 which means the grantee does not have a spend limit.

To set a limit of 42069 utia, use the following command:

bash
celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000 \
-  --amount 42069
celestia state grant-fee $GRANTEE_ADDRESS 2000 1000000 \
-  --amount 42069

Find the example transaction on Celenium.

Using a FeeGrant allowance as a grantee in celestia-node

First, start your node with the grantee account:

bash
celestia light start --core.ip $RPC_URL --p2p.network=mocha
-  --granter.address=$GRANTER_ADDRESS
celestia light start --core.ip $RPC_URL --p2p.network=mocha
-  --granter.address=$GRANTER_ADDRESS

To check the balance of a light node, use the following command:

bash
celestia state balance
celestia state balance

Example response when the account balance does not exist:

json
{
+export RPC_URL=rpc.celestia-mocha.com

FeeGrant module implementation in celestia-node

Using celestia-node, you can now easily give permission for other nodes to submit transactions on your behalf. It is also possible to revoke the grant.

The FeeGrant functionality can now be used during runtime without the need to restart the node.

Grant permission for an allowance as a granter

First, start your node:

bash
celestia light start --p2p.network mocha --core.ip $RPC_URL
celestia light start --p2p.network mocha --core.ip $RPC_URL

Then, grant the fee to the grantee:

bash
celestia state grant-fee $GRANTEE_ADDRESS --amount 2000
celestia state grant-fee $GRANTEE_ADDRESS --amount 2000

Note that the --amount flag specifies the spend limit (in utia) for the grantee. If not specified, the grantee does not have a spend limit.

Using a FeeGrant allowance as a grantee in celestia-node

Start your node:

bash
celestia light start --core.ip $RPC_URL --p2p.network=mocha
celestia light start --core.ip $RPC_URL --p2p.network=mocha

To check the balance of a light node, use the following command:

bash
celestia state balance
celestia state balance

Example response when the account balance does not exist:

json
{
   "result": {
     "denom": "utia",
     "amount": "0"
@@ -58,7 +52,7 @@
     "denom": "utia",
     "amount": "0"
   }
-}

This indicates that the light node currently does not have any funds.

Now submit a blob:

bash
celestia blob submit 0x42690c204d39600fddd3 0x6665656772616e74
celestia blob submit 0x42690c204d39600fddd3 0x6665656772616e74

You'll see the height and the commitment of your blob:

json
{
+}

This indicates that the light node currently does not have any funds.

Now submit a blob using the FeeGrant:

bash
celestia blob submit 0x42690c204d39600fddd3 'gm' --granter.address $GRANTER_ADDRESS
celestia blob submit 0x42690c204d39600fddd3 'gm' --granter.address $GRANTER_ADDRESS

You'll see the height and the commitment of your blob:

json
{
   "result": {
     "height": 1639397,
     "commitments": [
@@ -72,7 +66,7 @@
       "19L/C4iBEsqXGzC5ZxJ3vtuGBiAdQAMIEnbYjKEGcac="
     ]
   }
-}

After the transactions made making this guide, see that the account balance is still 0 utia.

Checking account balances after submission

Light node account: After submitting a blob, you can check the light node account's balance to verify that the fees have been deducted:

bash
celestia state balance
celestia state balance

Example output showing fees are not deducted:

json
{
+}

Checking account balances after submission

Light node account: After submitting a blob, you can check the light node account's balance to verify that the fees have been deducted:

bash
celestia state balance
celestia state balance

Example output showing fees are not deducted:

json
{
   "result": {
     "denom": "utia",
     "amount": "0"
@@ -82,7 +76,7 @@
     "denom": "utia",
     "amount": "0"
   }
-}

Optional: Revoke permission for a FeeGrant allowance as a granter

To revoke the feegrant, run your light node as the granter and run:

bash
celestia state revoke-grant-fee $GRANTEE_ADDRESS 2000 1000000
celestia state revoke-grant-fee $GRANTEE_ADDRESS 2000 1000000

There is also a specific error for the case when you run your node as a grantee, but the granter revokes their permission. In this case, your transaction will fail with the error: granter has revoked the grant This will mean that you have to restart the node without the granter.address flag.

Optional: Submitting a blob from file input

To submit a blob from file input:

bash
celestia blob submit --input-file blob.json
celestia blob submit --input-file blob.json

Optional: Granting fee allowances using celestia-appd

To grant fee allowances, allowing a third-party (granter) account to pay for the fees incurred by a Celestia data availability node (grantee) account, use the following commands.

Set your account addresses for grantee and granter, and the RPC URL:

bash
export GRANTER_ADDRESS=<your-granter-account-address>
+}

Optional: Revoke permission for a FeeGrant allowance as a granter

To revoke the feegrant, run:

bash
celestia state revoke-grant-fee $GRANTEE_ADDRESS
celestia state revoke-grant-fee $GRANTEE_ADDRESS

Optional: Submitting a blob from file input

To submit a blob from file input:

bash
celestia blob submit --input-file blob.json
celestia blob submit --input-file blob.json

Optional: Granting fee allowances using celestia-appd

To grant fee allowances, allowing a third-party (granter) account to pay for the fees incurred by a Celestia data availability node (grantee) account, use the following commands.

Set your account addresses for grantee and granter, and the RPC URL:

bash
export GRANTER_ADDRESS=<your-granter-account-address>
 export GRANTEE_ADDRESS=<your-grantee-account-address>
 export RPC_URL=https://rpc.celestia-mocha.com:443
export GRANTER_ADDRESS=<your-granter-account-address>
 export GRANTEE_ADDRESS=<your-grantee-account-address>
@@ -106,8 +100,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.celestia-mocha.com:443 --denom utia
celestia-appd query bank balances $GRANTER_ADDRESS \
---node https://rpc.celestia-mocha.com: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.celestia-mocha.com: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-1680/developers/full-stack-modular-development-guide.html b/pr-1680/developers/full-stack-modular-development-guide.html index 7babd3dfd7..87aa2b366f 100644 --- a/pr-1680/developers/full-stack-modular-development-guide.html +++ b/pr-1680/developers/full-stack-modular-development-guide.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

Full stack modular blockchain development guide

Note

This tutorial needs to be updated

This guide will introduce you to modular blockchains like Celestia, explain their benefits, and show you how to build a full stack modular dapp with React, Vite, RainbowKit, Celestia, and Foundry.

Current blockchain architectures are not scalable and face challenges around accessibility. In order for blockchains and web3 to reach mass adoption, these challenges must be addressed.

Blockchains have evolved over time from application-specific networks like Bitcoin to shared smart contract platforms like Ethereum. This guide will cover how to build dapps on these newer, shared platforms.

If you're interested in learning more about modular blockchains, or are new to the Celestia ecosystem, we recommend you read the build whatever page first.

Getting started

Now that you’ve had an overview of what Celestia is, let’s start building!

The execution environment that we’ll be leveraging today is Ethermint, an EVM-compatible testnet that you will run locally for this tutorial.

Pre-requisites

Project setup

To get started, create a new Foundry project:

bash
forge init celestia-dapp
+

Full stack modular blockchain development guide

Note

This tutorial needs to be updated

This guide will introduce you to modular blockchains like Celestia, explain their benefits, and show you how to build a full stack modular dapp with React, Vite, RainbowKit, Celestia, and Foundry.

Current blockchain architectures are not scalable and face challenges around accessibility. In order for blockchains and web3 to reach mass adoption, these challenges must be addressed.

Blockchains have evolved over time from application-specific networks like Bitcoin to shared smart contract platforms like Ethereum. This guide will cover how to build dapps on these newer, shared platforms.

If you're interested in learning more about modular blockchains, or are new to the Celestia ecosystem, we recommend you read the build whatever page first.

Getting started

Now that you’ve had an overview of what Celestia is, let’s start building!

The execution environment that we’ll be leveraging today is Ethermint, an EVM-compatible testnet that you will run locally for this tutorial.

Pre-requisites

Project setup

To get started, create a new Foundry project:

bash
forge init celestia-dapp
 cd celestia-dapp
forge init celestia-dapp
 cd celestia-dapp

Foundry has created an example smart contract located at src/Contract.sol.

Updating the contract and tests

Let's update the contracts to include a basic blog example. Create a new file in the src directory named Contract.sol with the following code:

solidity
// SPDX-License-Identifier: MIT
 pragma solidity ^0.8.13;
@@ -930,8 +930,8 @@
 && echo $PRIVATE_KEY | pbcopy
PRIVATE_KEY=$(ethermintd keys unsafe-export-eth-key mykey --keyring-backend test)
 && echo $PRIVATE_KEY | pbcopy

Now, import the private key to MetaMask and switch to that account.

Next, let’s run it on your Ethermint rollup.

To do so, first update the contractAddress variable with the contract address deployed to Ethermint:

jsx
/* src/App.jsx */
 const contractAddress = "your-ethermint-contract-address";
/* src/App.jsx */
-const contractAddress = "your-ethermint-contract-address";

Next, run the React application:

bash
npm run dev
npm run dev

When you run the app, you should now be connected to and using the Ethermint rollup.

If you imported the address that started the chain, you'll see quite a large balance.

Now give it a spin 🌀

Now that you have your dapp running, go ahead and test out a new post on your Ethermint sovereign rollup. If you enjoyed this tutorial, be sure to share your example in our Discord!

- +const contractAddress = "your-ethermint-contract-address";

Next, run the React application:

bash
npm run dev
npm run dev

When you run the app, you should now be connected to and using the Ethermint rollup.

If you imported the address that started the chain, you'll see quite a large balance.

Now give it a spin 🌀

Now that you have your dapp running, go ahead and test out a new post on your Ethermint sovereign rollup. If you enjoyed this tutorial, be sure to share your example in our Discord!

+ \ No newline at end of file diff --git a/pr-1680/developers/gm-portal-bubs.html b/pr-1680/developers/gm-portal-bubs.html index 32109d0a48..dadc64e487 100644 --- a/pr-1680/developers/gm-portal-bubs.html +++ b/pr-1680/developers/gm-portal-bubs.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

Deploying a dapp on Bubs testnet

First, review the Bubs testnet page and the Deploy a smart contract to Bubs testnet tutorial.

You will need a funded account to deploy your smart contract.

Next, clone the gm-portal from Github and start the frontend:

bash
cd $HOME
+

Deploying a dapp on Bubs testnet

First, review the Bubs testnet page and the Deploy a smart contract to Bubs testnet tutorial.

You will need a funded account to deploy your smart contract.

Next, clone the gm-portal from Github and start the frontend:

bash
cd $HOME
 git clone https://github.com/jcstein/gm-portal.git
 cd gm-portal/frontend
 yarn && yarn dev
cd $HOME
@@ -58,8 +58,8 @@
 cast send --private-key $PRIVATE_KEY $RECEIVER --value 1ether --rpc-url $BUBS_RPC_URL
export RECEIVER=<receiver ETH address>
 cast send --private-key $PRIVATE_KEY $RECEIVER --value 1ether --rpc-url $BUBS_RPC_URL

If you are in a different terminal than the one you set the private key in, you may need to set it again.

Update the frontend

Next, you will need to update a few things before you can interact with the contract on the frontend:

  1. Change the contract address on gm-portal/frontend/src/App.tsx to your contract address
  2. Match the chain info on gm-portal/frontend/src/main.tsx with the chain config of your L2
  3. If you changed the contract, update the ABI in gm-portal/frontend/GmPortal.json from gm-portal/contracts/out/GmPortal.sol/GmPortal.json. This can be done with:
bash
cd $HOME
 cp dev/gm-portal/contracts/out/GmPortal.sol/GmPortal.json dev/gm-portal/frontend
cd $HOME
-cp dev/gm-portal/contracts/out/GmPortal.sol/GmPortal.json dev/gm-portal/frontend

Interact with the frontend

Now, login with your wallet that you funded, and post a GM on your GM portal!

gm-bubs

Next steps

There are many possibilities of what could be built with this stack. These projects would be good to build on this stack:

  • onchain gaming
  • decentralized social media
  • an NFT ticketing rollup
  • Optimism on CelOPstia
  • OP Craft on Celestia
- +cp dev/gm-portal/contracts/out/GmPortal.sol/GmPortal.json dev/gm-portal/frontend

Interact with the frontend

Now, login with your wallet that you funded, and post a GM on your GM portal!

gm-bubs

Next steps

There are many possibilities of what could be built with this stack. These projects would be good to build on this stack:

  • onchain gaming
  • decentralized social media
  • an NFT ticketing rollup
  • Optimism on CelOPstia
  • OP Craft on Celestia
+ \ No newline at end of file diff --git a/pr-1680/developers/golang-client-tutorial.html b/pr-1680/developers/golang-client-tutorial.html index f987a70e3e..3fa553e19e 100644 --- a/pr-1680/developers/golang-client-tutorial.html +++ b/pr-1680/developers/golang-client-tutorial.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

Golang client library tutorial

This section tutorial 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 (
+

Golang client library tutorial

This section tutorial 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"
@@ -276,8 +276,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-1680/developers/integrate-celestia.html b/pr-1680/developers/integrate-celestia.html index df0e37b003..19a54f53d7 100644 --- a/pr-1680/developers/integrate-celestia.html +++ b/pr-1680/developers/integrate-celestia.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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 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 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-1680/developers/intro-to-op-stack.html b/pr-1680/developers/intro-to-op-stack.html index 2e687ac7ab..934be3cde2 100644 --- a/pr-1680/developers/intro-to-op-stack.html +++ b/pr-1680/developers/intro-to-op-stack.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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.

Category contents

This category will guide you through interacting with existing OP Stack rollups with Celestia underneath, then how to start your own devnet with a modified version of optimism-bedrock that uses Celestia as a DA layer.

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.

Category contents

This category will guide you through interacting with existing OP Stack rollups with Celestia underneath, then how to start your own devnet with a modified version of optimism-bedrock that uses Celestia as a DA layer.

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-1680/developers/multiaccounts.html b/pr-1680/developers/multiaccounts.html new file mode 100644 index 0000000000..0757a26f35 --- /dev/null +++ b/pr-1680/developers/multiaccounts.html @@ -0,0 +1,49 @@ + + + + + + MultiAccounts feature for blobs submission | Celestia Docs + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Skip to content

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 \
+    --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-1680/developers/node-api.html b/pr-1680/developers/node-api.html index 3eb0a9a4e8..047c0211b1 100644 --- a/pr-1680/developers/node-api.html +++ b/pr-1680/developers/node-api.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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 node tutorial, which uses the RPC CLI, is the recommended way to get started interacting with your Celestia node.

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 node tutorial, which uses the RPC CLI, is the recommended way to get started interacting with your Celestia node.

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-1680/developers/node-tutorial.html b/pr-1680/developers/node-tutorial.html index e21c1a2eed..724c9d6704 100644 --- a/pr-1680/developers/node-tutorial.html +++ b/pr-1680/developers/node-tutorial.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,11 +39,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.

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 a community-run API endpoint and there are several in the Discord. This one is used for demonstration purposes. Check out the Mocha testnet page, or Arabica devnet page.

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.

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 a community-run API endpoint and there are several in the Discord. This one is used for demonstration purposes. Check out the Mocha testnet page, or Arabica devnet page.

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> \
@@ -435,8 +435,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-1680/developers/optimism-devnet.html b/pr-1680/developers/optimism-devnet.html index 5070c2842a..6518801547 100644 --- a/pr-1680/developers/optimism-devnet.html +++ b/pr-1680/developers/optimism-devnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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
+

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
@@ -112,8 +112,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-1680/developers/optimism.html b/pr-1680/developers/optimism.html index 2cb1b5f907..f18bcca316 100644 --- a/pr-1680/developers/optimism.html +++ b/pr-1680/developers/optimism.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,7 +39,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.

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.

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.

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.

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
@@ -83,8 +83,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-1680/developers/prompt-scavenger.html b/pr-1680/developers/prompt-scavenger.html index 6fb624fee3..07d2b628c5 100644 --- a/pr-1680/developers/prompt-scavenger.html +++ b/pr-1680/developers/prompt-scavenger.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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...
+

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
@@ -456,8 +456,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-1680/developers/rust-client-tutorial.html b/pr-1680/developers/rust-client-tutorial.html index 4c5f12adcd..8813b24d5b 100644 --- a/pr-1680/developers/rust-client-tutorial.html +++ b/pr-1680/developers/rust-client-tutorial.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

Rust client library tutorial

This section tutorial 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};
+

Rust client library tutorial

This section tutorial 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::blob::GasPrice;
 use celestia_types::{nmt::Namespace, Blob, ExtendedDataSquare};
 
@@ -208,8 +208,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-1680/developers/sp1-blobstream-deploy.html b/pr-1680/developers/sp1-blobstream-deploy.html index 744c7d9427..be16fe615d 100644 --- a/pr-1680/developers/sp1-blobstream-deploy.html +++ b/pr-1680/developers/sp1-blobstream-deploy.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,10 +38,10 @@

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
+

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-1680/developers/submit-data.html b/pr-1680/developers/submit-data.html index 92fbec9586..92b4729495 100644 --- a/pr-1680/developers/submit-data.html +++ b/pr-1680/developers/submit-data.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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:

Total Fee=Gas Limit×Gas Price

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:

Gas Limit=FC+i=1nSSN(Bi)×SS×GCPBB

Where:

  • FC = Fixed Cost, is a static value (65,000 gas)
  • i=1nSSN(Bi) = SparseSharesNeeded for the ith Blob, is the number of shares needed for the ith blob in the transaction
  • SS = Share Size, is the size of each share
  • GCPBB = Gas Cost Per Blob Byte, is a parameter that could potentially be adjusted through the system's governance mechanisms.

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 (
+

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:

Total Fee=Gas Limit×Gas Price

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:

Gas Limit=FC+i=1nSSN(Bi)×SS×GCPBB

Where:

  • FC = Fixed Cost, is a static value (65,000 gas)
  • i=1nSSN(Bi) = SparseSharesNeeded for the ith Blob, is the number of shares needed for the ith blob in the transaction
  • SS = Share Size, is the size of each share
  • GCPBB = Gas Cost Per Blob Byte, is a parameter that could potentially be adjusted through the system's governance mechanisms.

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 (
@@ -336,8 +336,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.

- +}

RPC to a celestia-node

Using the JSON RPC API, submit data using the following methods:

Learn more in the celestia-node API docs.

+ \ No newline at end of file diff --git a/pr-1680/developers/transaction-resubmission.html b/pr-1680/developers/transaction-resubmission.html index 320718d1f7..fdb5eff749 100644 --- a/pr-1680/developers/transaction-resubmission.html +++ b/pr-1680/developers/transaction-resubmission.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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.

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.

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-1680/developers/wallets.html b/pr-1680/developers/wallets.html index 8e93395b22..37bdca0d05 100644 --- a/pr-1680/developers/wallets.html +++ b/pr-1680/developers/wallets.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,7 +39,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";
 
@@ -187,7 +187,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',
@@ -241,8 +241,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 diff --git a/pr-1680/hashmap.json b/pr-1680/hashmap.json index 14bbd1c67e..483bbd6959 100644 --- a/pr-1680/hashmap.json +++ b/pr-1680/hashmap.json @@ -1 +1 @@ -{"developers_arbitrum-dapp-deploy.md":"94c9ebd9","developers_blobstream-contracts.md":"a96f5b10","community_modular-meetup-intro.md":"15c20508","developers_arbitrum-deploy.md":"839b7894","developers_golang-client-tutorial.md":"1734d91e","developers_intro-to-op-stack.md":"fa5d636c","nodes_systemd.md":"0a76c2e7","developers_blobstream-offchain.md":"714e874f","community_overview.md":"5d3cdb35","developers_build-whatever.md":"a1d2e5ba","developers_arbitrum-bridge.md":"1305b088","developers_bubs-testnet.md":"e6fe9bf8","developers_gm-portal-bubs.md":"69f6963b","readme.md":"84351c9c","developers_blobstream-x-deploy.md":"16c5ae12","community_foundation-delegation-program.md":"d130506e","developers_blobstream.md":"5a20f3f8","developers_feegrant-for-blobs.md":"fb084a8d","developers_full-stack-modular-development-guide.md":"ca053aa5","developers_celestia-node-key.md":"b25623f9","developers_optimism-devnet.md":"a9e0c5a6","learn_how-celestia-works_data-availability-faq.md":"c77d8ed2","developers_arbitrum-integration.md":"9e0aee21","community_itn-tos.md":"c448efcc","developers_arbitrum-smart-contract.md":"26545321","developers_blobstream-proof-queries.md":"8321ccb1","nodes_overview.md":"4fff23da","community_modular-meetup-toolkit.md":"c0a464fb","nodes_participate.md":"be133e40","nodes_quick-start.md":"87f87708","learn_retrievability.md":"624d5724","developers_optimism.md":"6b557910","learn_staking-governance-supply.md":"f12d24a2","learn_tia.md":"4c7134d5","learn_staking.md":"41f598de","developers_integrate-celestia.md":"a09ad5ff","nodes_arabica-devnet.md":"1e272478","nodes_mocha-testnet.md":"21cdb959","nodes_ibc-relayer.md":"7a3c6a4c","developers_rust-client-tutorial.md":"1649c175","developers_wallets.md":"1fc181f4","nodes_config-toml.md":"7c6ec5cd","developers_blobstream-rollups.md":"67f5cc25","nodes_celestia-app-multisig.md":"9965f0f0","developers_arbitrum-full-node.md":"1806878f","nodes_mainnet.md":"71c4e1fb","nodes_celestia-app-slashing.md":"90798e11","nodes_environment.md":"327a8dbd","nodes_celestia-app-wallet.md":"3b09d1dc","nodes_instantiate-testnet.md":"564058ba","nodes_decide-node.md":"e2cf48f2","nodes_celestia-node.md":"a266ee0e","nodes_hardfork-process.md":"9c089234","developers_blobstream-x-requesting-data-commitment-ranges.md":"0ac98150","learn_how-celestia-works_data-availability-layer.md":"3ecbc0a8","nodes_docker-images.md":"cd1555b9","developers_node-api.md":"e5a7b4d3","nodes_full-storage-node.md":"07a0c9a4","learn_how-celestia-works_transaction-lifecycle.md":"a039d39a","learn_how-to-stake-tia.md":"eca4d77a","developers_ethereum-fallback.md":"8387bd5e","learn_how-celestia-works_monolithic-vs-modular.md":"494025b0","learn_how-celestia-works_overview.md":"d0862172","community_modular-meetup-guide.md":"83bd3c81","developers_deploy-on-bubs.md":"d43095f8","nodes_bridge-node.md":"a669cc48","community_speaker-list.md":"dd7785cb","nodes_light-node.md":"4d805f14","nodes_celestia-app-upgrade-monitor.md":"a7f594fd","nodes_celestia-app-metrics.md":"1d5a64b1","nodes_celestia-app-commands.md":"da9e2012","nodes_celestia-app.md":"4ff1b2af","nodes_celestia-node-metrics.md":"216eb211","nodes_celestia-node-custom-networks.md":"20aba34e","community_calendar.md":"cec7b00a","nodes_consensus-node.md":"01077dd8","developers_sp1-blobstream-deploy.md":"2340bea7","learn_paying-for-blobspace.md":"1a14801b","nodes_celestia-node-trusted-hash.md":"f83aaf6b","nodes_celestia-app-vesting.md":"f93598b1","index.md":"0f32fb36","nodes_celestia-node-troubleshooting.md":"821659c6","developers_prompt-scavenger.md":"70ab1baf","developers_transaction-resubmission.md":"2dfb34a4","community_coc.md":"3b3f881c","developers_node-tutorial.md":"185dc136","nodes_validator-node.md":"6d429357","developers_submit-data.md":"c8780ba2"} +{"community_modular-meetup-intro.md":"8430b9a3","community_overview.md":"237c0746","community_modular-meetup-toolkit.md":"676a0a2a","developers_arbitrum-bridge.md":"96018be7","community_coc.md":"532aa249","community_speaker-list.md":"b66230db","developers_node-api.md":"793cfe04","community_foundation-delegation-program.md":"ef8a9b75","developers_blobstream-offchain.md":"628432c8","developers_arbitrum-full-node.md":"3cfe6aa9","developers_blobstream.md":"7c6b29b0","readme.md":"eba3dded","developers_blobstreamx.md":"7d123eea","developers_bubs-testnet.md":"6fd541b2","developers_build-whatever.md":"30271c51","developers_gm-portal-bubs.md":"df82ad53","developers_arbitrum-dapp-deploy.md":"f7dfbfa7","community_calendar.md":"97a43115","learn_staking.md":"5f314f9c","learn_tia.md":"50908c0d","nodes_arabica-devnet.md":"c4919f1d","developers_ethereum-fallback.md":"cd2adaa4","developers_arbitrum-smart-contract.md":"cc5d7a73","developers_golang-client-tutorial.md":"3f31b896","community_modular-meetup-guide.md":"3997fb81","developers_intro-to-op-stack.md":"07bb6aa7","developers_multiaccounts.md":"a7a3ebe9","developers_celestia-node-key.md":"88cf4b78","developers_arbitrum-integration.md":"8282c127","community_itn-tos.md":"89c55442","nodes_celestia-node-custom-networks.md":"18993406","nodes_celestia-node-troubleshooting.md":"f834eff5","nodes_hardfork-process.md":"c86d1151","nodes_overview.md":"1b940623","nodes_participate.md":"44f9ae13","nodes_quick-start.md":"4fe562f2","nodes_celestia-app-commands.md":"c7ad4df8","developers_prompt-scavenger.md":"8af0d32d","nodes_mocha-testnet.md":"aa2ae9c7","developers_blobstream-contracts.md":"94e59fda","nodes_systemd.md":"10732002","developers_integrate-celestia.md":"3f8ccd2c","nodes_mainnet.md":"91c04e4d","nodes_celestia-app-upgrade-monitor.md":"7f8357e1","nodes_decide-node.md":"1303eb5d","developers_rust-client-tutorial.md":"892b74cf","developers_optimism.md":"f09e526a","developers_blobstream-x-requesting-data-commitment-ranges.md":"4aa3e66e","nodes_celestia-node-trusted-hash.md":"09a35d4c","developers_sp1-blobstream-deploy.md":"6a1de8c6","developers_feegrant-for-blobs.md":"77fb195e","developers_node-tutorial.md":"797233e2","developers_transaction-resubmission.md":"a7ae5c83","nodes_celestia-app-wallet.md":"634f19b0","learn_how-celestia-works_monolithic-vs-modular.md":"b9f1f45d","learn_how-celestia-works_overview.md":"c1a281d5","learn_paying-for-blobspace.md":"bf3ce96f","learn_retrievability.md":"502536f6","nodes_celestia-app-multisig.md":"ddb08823","nodes_instantiate-testnet.md":"4237987d","index.md":"c62fad43","developers_arbitrum-deploy.md":"70ab5228","nodes_ibc-relayer.md":"a8f27ce5","nodes_celestia-node.md":"1aba6dda","developers_deploy-on-bubs.md":"1057b5ac","nodes_celestia-node-metrics.md":"ebcb2743","nodes_bridge-node.md":"74cb097b","nodes_environment.md":"3dbd31f9","developers_full-stack-modular-development-guide.md":"0c71091e","nodes_validator-node.md":"56905fa6","nodes_celestia-app-metrics.md":"29cc5cc2","developers_optimism-devnet.md":"5de00bc6","nodes_full-storage-node.md":"b0ec8a5f","developers_wallets.md":"91a1722d","learn_how-celestia-works_data-availability-faq.md":"4f8ba756","developers_blobstream-x-deploy.md":"3886b5a3","learn_staking-governance-supply.md":"d4993c82","nodes_config-toml.md":"baac8bd9","learn_how-celestia-works_transaction-lifecycle.md":"2dbdde2f","developers_blobstream-rollups.md":"41e4a8bc","learn_how-celestia-works_data-availability-layer.md":"fe8c1e7c","nodes_celestia-app-slashing.md":"f566e698","nodes_light-node.md":"ebca7fc4","nodes_docker-images.md":"8cee5aaa","nodes_celestia-app.md":"e40766f7","learn_how-to-stake-tia.md":"8cd56e12","developers_submit-data.md":"84194c6f","nodes_consensus-node.md":"21f5a1d7","nodes_celestia-app-vesting.md":"dd0ddeb3","developers_blobstream-proof-queries.md":"cf3a9152"} diff --git a/pr-1680/index.html b/pr-1680/index.html index 2821afab26..19c24aaed9 100644 --- a/pr-1680/index.html +++ b/pr-1680/index.html @@ -7,11 +7,11 @@ - + - - + + @@ -39,7 +39,7 @@ - + \ No newline at end of file diff --git a/pr-1680/learn/how-celestia-works/data-availability-faq.html b/pr-1680/learn/how-celestia-works/data-availability-faq.html index f889362d09..15bc7cdcff 100644 --- a/pr-1680/learn/how-celestia-works/data-availability-faq.html +++ b/pr-1680/learn/how-celestia-works/data-availability-faq.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/learn/how-celestia-works/data-availability-layer.html b/pr-1680/learn/how-celestia-works/data-availability-layer.html index 67cf0a3f53..2973c81cc1 100644 --- a/pr-1680/learn/how-celestia-works/data-availability-layer.html +++ b/pr-1680/learn/how-celestia-works/data-availability-layer.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/learn/how-celestia-works/monolithic-vs-modular.html b/pr-1680/learn/how-celestia-works/monolithic-vs-modular.html index 8cfc9e5e08..f13ce2d44e 100644 --- a/pr-1680/learn/how-celestia-works/monolithic-vs-modular.html +++ b/pr-1680/learn/how-celestia-works/monolithic-vs-modular.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/learn/how-celestia-works/overview.html b/pr-1680/learn/how-celestia-works/overview.html index 80e020602d..7951b63e8a 100644 --- a/pr-1680/learn/how-celestia-works/overview.html +++ b/pr-1680/learn/how-celestia-works/overview.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/learn/how-celestia-works/transaction-lifecycle.html b/pr-1680/learn/how-celestia-works/transaction-lifecycle.html index f71be882f7..0059274fe9 100644 --- a/pr-1680/learn/how-celestia-works/transaction-lifecycle.html +++ b/pr-1680/learn/how-celestia-works/transaction-lifecycle.html @@ -7,12 +7,12 @@ - + - + - + @@ -39,8 +39,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-1680/learn/how-to-stake-tia.html b/pr-1680/learn/how-to-stake-tia.html index b60b6b10cc..0b9018f66c 100644 --- a/pr-1680/learn/how-to-stake-tia.html +++ b/pr-1680/learn/how-to-stake-tia.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/learn/paying-for-blobspace.html b/pr-1680/learn/paying-for-blobspace.html index 907040327d..ba9844b7a7 100644 --- a/pr-1680/learn/paying-for-blobspace.html +++ b/pr-1680/learn/paying-for-blobspace.html @@ -7,12 +7,12 @@ - + - + - + @@ -39,8 +39,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-1680/learn/retrievability.html b/pr-1680/learn/retrievability.html index 677a7b62a7..483c1d4ac0 100644 --- a/pr-1680/learn/retrievability.html +++ b/pr-1680/learn/retrievability.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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 historic 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 historic 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-1680/learn/staking-governance-supply.html b/pr-1680/learn/staking-governance-supply.html index f503ddbfe8..c27603aa7b 100644 --- a/pr-1680/learn/staking-governance-supply.html +++ b/pr-1680/learn/staking-governance-supply.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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.4%
Future initiatives: 12.6%
20%
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.8%
Early Backers: Series A&BEarly supporters of Celestia19.7%
Early Backers: SeedEarly supporters of Celestia15.9%
Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.6%

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.

CategoryUnlock Schedule
Public AllocationFully unlocked at launch.
R&D & Ecosystem25% unlocked at launch.
Remaining 75% unlocks continuously from year 1 to year 4.
Initial Core Contributors33% unlocked at year 1.
Remaining 67% unlocks continuously from year 1 to year 3.
Early Backers: Seed33% unlocked at year 1.
Remaining 67% unlocks continuously from year 1 to year 2.
Early Backers: Series A&B33% unlocked at year 1.
Remaining 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.4%
Future initiatives: 12.6%
20%
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.8%
Early Backers: Series A&BEarly supporters of Celestia19.7%
Early Backers: SeedEarly supporters of Celestia15.9%
Initial Core ContributorsMembers of Celestia Labs, the first core contributor to Celestia17.6%

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.

CategoryUnlock Schedule
Public AllocationFully unlocked at launch.
R&D & Ecosystem25% unlocked at launch.
Remaining 75% unlocks continuously from year 1 to year 4.
Initial Core Contributors33% unlocked at year 1.
Remaining 67% unlocks continuously from year 1 to year 3.
Early Backers: Seed33% unlocked at year 1.
Remaining 67% unlocks continuously from year 1 to year 2.
Early Backers: Series A&B33% unlocked at year 1.
Remaining 67% unlocks continuously from year 1 to year 2.
+ \ No newline at end of file diff --git a/pr-1680/learn/staking.html b/pr-1680/learn/staking.html index ccef203d21..2f6c6d0d54 100644 --- a/pr-1680/learn/staking.html +++ b/pr-1680/learn/staking.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/learn/tia.html b/pr-1680/learn/tia.html index 04b9100529..02a5504a2c 100644 --- a/pr-1680/learn/tia.html +++ b/pr-1680/learn/tia.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/nodes/arabica-devnet.html b/pr-1680/nodes/arabica-devnet.html index a810726a03..9cb1b6073d 100644 --- a/pr-1680/nodes/arabica-devnet.html +++ b/pr-1680/nodes/arabica-devnet.html @@ -7,14 +7,14 @@ - + - - - - - + + + + + @@ -41,10 +41,10 @@

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 Hardfork 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.16.0-rc0
celestia-appv2.1.2

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 \
+

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 Hardfork 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.16.0
celestia-appv2.1.2

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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

- + --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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

+ \ No newline at end of file diff --git a/pr-1680/nodes/bridge-node.html b/pr-1680/nodes/bridge-node.html index dd1bb26fdc..d7ec876f88 100644 --- a/pr-1680/nodes/bridge-node.html +++ b/pr-1680/nodes/bridge-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,14 +38,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: 10 TB SSD 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: 10 TB SSD 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: 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-1680/nodes/celestia-app-commands.html b/pr-1680/nodes/celestia-app-commands.html index 86bed42479..560020d6e4 100644 --- a/pr-1680/nodes/celestia-app-commands.html +++ b/pr-1680/nodes/celestia-app-commands.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

Helpful CLI commands

View all options:

console
$ celestia-appd --help
+

Helpful CLI commands

View all options:

console
$ celestia-appd --help
 Start celestia-app
 
 Usage:
@@ -250,8 +250,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-1680/nodes/celestia-app-metrics.html b/pr-1680/nodes/celestia-app-metrics.html index cd90e731e1..434fe6d557 100644 --- a/pr-1680/nodes/celestia-app-metrics.html +++ b/pr-1680/nodes/celestia-app-metrics.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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
#######################################################
+

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]
@@ -120,8 +120,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-1680/nodes/celestia-app-multisig.html b/pr-1680/nodes/celestia-app-multisig.html index b92c6fe65e..0314e5b08c 100644 --- a/pr-1680/nodes/celestia-app-multisig.html +++ b/pr-1680/nodes/celestia-app-multisig.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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
+

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"
@@ -140,8 +140,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-1680/nodes/celestia-app-slashing.html b/pr-1680/nodes/celestia-app-slashing.html index 68268a1ec4..189d82cc33 100644 --- a/pr-1680/nodes/celestia-app-slashing.html +++ b/pr-1680/nodes/celestia-app-slashing.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/nodes/celestia-app-upgrade-monitor.html b/pr-1680/nodes/celestia-app-upgrade-monitor.html index 1ae2c45e54..6587224093 100644 --- a/pr-1680/nodes/celestia-app-upgrade-monitor.html +++ b/pr-1680/nodes/celestia-app-upgrade-monitor.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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-1680/nodes/celestia-app-vesting.html b/pr-1680/nodes/celestia-app-vesting.html index a6189aad40..8749f81954 100644 --- a/pr-1680/nodes/celestia-app-vesting.html +++ b/pr-1680/nodes/celestia-app-vesting.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

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
+

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
@@ -252,8 +252,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-1680/nodes/celestia-app-wallet.html b/pr-1680/nodes/celestia-app-wallet.html index fa09acf427..7ec88c9ec6 100644 --- a/pr-1680/nodes/celestia-app-wallet.html +++ b/pr-1680/nodes/celestia-app-wallet.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,10 +38,10 @@

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
+

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-1680/nodes/celestia-app.html b/pr-1680/nodes/celestia-app.html index ecef7b5c97..422957228e 100644 --- a/pr-1680/nodes/celestia-app.html +++ b/pr-1680/nodes/celestia-app.html @@ -7,14 +7,14 @@ - + - - - + + + - + @@ -41,14 +41,14 @@

Install celestia-app

This tutorial will guide you through installing celestia-app, both from source and with a pre-built binary

Building binary from source

This section of the tutorial presumes you completed the steps in setting up your own environment.

The steps below will create a binary file named celestia-appd inside $HOME/go/bin folder which will be used later to run the node. Be sure to select the correct network to install the binary for.

  1. Remove any existing copy of celestia-app, clone the repository, and change into the directory:

    bash
    cd $HOME
    +

Install celestia-app

This tutorial will guide you through installing celestia-app, both from source and with a pre-built binary

Building binary from source

This section of the tutorial presumes you completed the steps in setting up your own environment.

The steps below will create a binary file named celestia-appd inside $HOME/go/bin folder which will be used later to run the node. Be sure to select the correct network to install the binary for.

  1. Remove any existing copy of celestia-app, clone the repository, and change into the directory:

    bash
    cd $HOME
     rm -rf celestia-app
     git clone https://github.com/celestiaorg/celestia-app.git
     cd celestia-app
    cd $HOME
     rm -rf celestia-app
     git clone https://github.com/celestiaorg/celestia-app.git
    -cd celestia-app
  2. Check out to the desired version, based on the network you will use:

    bash
    git checkout tags/v1.13.0 -b v1.13.0
    git checkout tags/v1.13.0 -b v1.13.0
    bash
    git checkout tags/v2.1.2 -b v2.1.2
    git checkout tags/v2.1.2 -b v2.1.2
    bash
    git checkout tags/v2.1.2 -b v2.1.2
    git checkout tags/v2.1.2 -b v2.1.2
  3. Build and install the celestia-appd binary:

    bash
    make install
    make install
  4. 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/v1.13.0
    git checkout tags/v1.13.0
    bash
    git checkout tags/v2.1.2
    git checkout tags/v2.1.2
    bash
    git checkout tags/v2.1.2
    git checkout tags/v2.1.2
  • 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-1680/nodes/celestia-node-custom-networks.html b/pr-1680/nodes/celestia-node-custom-networks.html index e59d0de09b..78a5c68c8e 100644 --- a/pr-1680/nodes/celestia-node-custom-networks.html +++ b/pr-1680/nodes/celestia-node-custom-networks.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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>"
    +

    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>"
     export GENESIS_HASH=<genesis-hash>
     export NETWORK=<network-name>
     export CELESTIA_CUSTOM="${NETWORK}:${GENESIS_HASH}:${BRIDGE}"
    export BRIDGE="/ip4/<ip-address>/tcp/2121/p2p/<node-ID>"
    @@ -50,8 +50,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-1680/nodes/celestia-node-metrics.html b/pr-1680/nodes/celestia-node-metrics.html index 47bf508fc9..50a2d647c7 100644 --- a/pr-1680/nodes/celestia-node-metrics.html +++ b/pr-1680/nodes/celestia-node-metrics.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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> \
    +

    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> \
    @@ -66,8 +66,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-1680/nodes/celestia-node-troubleshooting.html b/pr-1680/nodes/celestia-node-troubleshooting.html index ff23ddffc1..924c29aa50 100644 --- a/pr-1680/nodes/celestia-node-troubleshooting.html +++ b/pr-1680/nodes/celestia-node-troubleshooting.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,7 +39,7 @@

    Troubleshooting

    Network selection

    Note: If you do not select a network, the default network will be Mainnet Beta.

    sh
    celestia <node-type> init --p2p.network <network>
    +

    Troubleshooting

    Network selection

    Note: If you do not select a network, the default network will be Mainnet Beta.

    sh
    celestia <node-type> init --p2p.network <network>
     celestia <node-type> start --p2p.network <network> --core.ip <URI>
    celestia <node-type> init --p2p.network <network>
     celestia <node-type> start --p2p.network <network> --core.ip <URI>

    TIP

    Refer to the ports section of this page for information on which ports are required to be open on your machine.

    NOTE

    It is advised before switching networks to reinitialize your node via init command. This is due to an old config being present. Re-initialisation will reset the config.

    Chain ID

    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 celestia, i.e. no --p2p.network string flag is required for Mainnet Beta.

    NetworkChain ID--p2p.network string
    Mainnet Betacelestianot required (--p2p.network celestia)
    Mochamocha-4--p2p.network mocha
    Arabicaarabica-11--p2p.network arabica

    Ports

    When interacting with a Celestia 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 nodes:

    PortProtocolAddressDescriptionEnabled by default on nodeFlag
    2121TCP/UDPlocalhostP2PtrueN/A
    26658HTTPlocalhostRPCtrue--rpc.port string
    26659HTTPlocalhostREST Gatewayfalse--gateway.port string

    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.

    Changing the location of your node store

    Background

    An enhancement has been made in v0.14.0+ to automate the detection of the running node, eliminating the need to manually specify the --node.store flag for each RPC request.

    Assumptions:

    • The presence of a lock signifies a running node.
    • Networks are ordered as Mainnet, Mocha, Arabica, private, custom.
    • Node types are ordered as bridge, full, and light.
    • Each network has only one running node type.
    • Multiple nodes of the same network and type are prohibited (resulting in an Error: node: store is in use).

    Key Points:

    • Authentication token and other flags maintain their previous behavior and take precedence.
    • Address and port details are fetched from the configuration.
    • skipAuth allows bypassing authentication for trusted setups and follows Unix daemon conventions.
    • Non-default node store and cel-key configurations still require specific flags in the configuration settings.

    Demonstration

    In this section, we'll guide you through starting your node using a node store in a different location than you originally started with.

    First, stop your node safely using control + C.

    Then, init your node again with a new node store:

    bash
    celestia <node-type> init --node.store /home/user/celestia-<node-type>-location/ \
         --p2p.network mocha
    celestia <node-type> init --node.store /home/user/celestia-<node-type>-location/ \
    @@ -99,8 +99,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-1680/nodes/celestia-node-trusted-hash.html b/pr-1680/nodes/celestia-node-trusted-hash.html index 2dd1594233..40e445d7f1 100644 --- a/pr-1680/nodes/celestia-node-trusted-hash.html +++ b/pr-1680/nodes/celestia-node-trusted-hash.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,10 +38,10 @@

    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> \
    +

    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-1680/nodes/celestia-node.html b/pr-1680/nodes/celestia-node.html index b97a70c040..9a5322f520 100644 --- a/pr-1680/nodes/celestia-node.html +++ b/pr-1680/nodes/celestia-node.html @@ -7,14 +7,14 @@ - + - - - + + + - + @@ -41,14 +41,14 @@

    Install celestia-node

    Installing from source

    This section goes over building and installing celestia-node. This tutorial assumes you completed the steps in setting up your development environment.

    Install the celestia-node binary by running the following commands:

    1. Remove any existing copy of celestia-node, clone the repository, and change into the directory:

      bash
      cd $HOME
      +

    Install celestia-node

    Installing from source

    This section goes over building and installing celestia-node. This tutorial assumes you completed the steps in setting up your development environment.

    Install the celestia-node binary by running the following commands:

    1. Remove any existing copy of celestia-node, clone the repository, and change into the directory:

      bash
      cd $HOME
       rm -rf celestia-node
       git clone https://github.com/celestiaorg/celestia-node.git
       cd celestia-node/
      cd $HOME
       rm -rf celestia-node
       git clone https://github.com/celestiaorg/celestia-node.git
      -cd celestia-node/
    2. Check out to the desired version, based on the network you will use:

      bash
      git checkout tags/v0.15.0
      git checkout tags/v0.15.0
      bash
      git checkout tags/v0.16.0-rc0
      git checkout tags/v0.16.0-rc0
      bash
      git checkout tags/v0.16.0-rc0
      git checkout tags/v0.16.0-rc0
    3. 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.

    4. Install the binary:

      bash
      make install
      make install
    5. Build the cel-key utility:

      bash
      make cel-key
      make cel-key
    6. 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 should have these binaries available.

    The steps below will download a binary file named celestia. Depending on the setup that you choose during installation, the celestia binary will be available at either:

    • $HOME/celestia-node-temp/celestia
    • /usr/local/bin/celestia

    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-node.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"

    Follow the instructions in the terminal output to choose your installation preferences.

    You will see an output with the menu for celestia.

    View the script to learn more about what it is doing.

    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.

    - +cd celestia-node/
  • Check out to the desired version, based on the network you will use:

    bash
    git checkout tags/v0.15.0
    git checkout tags/v0.15.0
    bash
    git checkout tags/v0.16.0
    git checkout tags/v0.16.0
    bash
    git checkout tags/v0.16.0
    git checkout tags/v0.16.0
  • 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 should have these binaries available.

    The steps below will download a binary file named celestia. Depending on the setup that you choose during installation, the celestia binary will be available at either:

    • $HOME/celestia-node-temp/celestia
    • /usr/local/bin/celestia

    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-node.sh)"
    bash -c "$(curl -sL https://docs.celestia.org/celestia-node.sh)"

    Follow the instructions in the terminal output to choose your installation preferences.

    You will see an output with the menu for celestia.

    View the script to learn more about what it is doing.

    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-1680/nodes/config-toml.html b/pr-1680/nodes/config-toml.html index 133af69efb..a8343049dc 100644 --- a/pr-1680/nodes/config-toml.html +++ b/pr-1680/nodes/config-toml.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

    config.toml guide

    Pre-requisites

    Please, make sure that you have installed and initialized celestia-node

    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

    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-1680/nodes/consensus-node.html b/pr-1680/nodes/consensus-node.html index 3a2309f95d..b8fa4b0c1f 100644 --- a/pr-1680/nodes/consensus-node.html +++ b/pr-1680/nodes/consensus-node.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,7 +39,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
    @@ -53,7 +53,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
    @@ -79,7 +79,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.

    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.

    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/ | \
    @@ -115,12 +115,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 <height>
    celestia-appd start --v2-upgrade-height <height>
    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 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 unsafe-reset-all to reset your node and start syncing from the genesis block.

    - + $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 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.

    + \ No newline at end of file diff --git a/pr-1680/nodes/decide-node.html b/pr-1680/nodes/decide-node.html index fff66f88fc..9283f01087 100644 --- a/pr-1680/nodes/decide-node.html +++ b/pr-1680/nodes/decide-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

    Deciding which node to run

    Now that you have installed the basic dependencies, you can start exploring which nodes to run!

    Beginner

    It is highly recommended if you are a beginner to get started with running a Data-Availability light node.

    In order to get started, you can proceed to the light node section.

    You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

    Advanced

    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!

    Beginner

    It is highly recommended if you are a beginner to get started with running a Data-Availability light node.

    In order to get started, you can proceed to the light node section.

    You can also play around with the Data Availability API in this tutorial for posting and retrieving data with a light node.

    Advanced

    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-1680/nodes/docker-images.html b/pr-1680/nodes/docker-images.html index ac8661c32f..56d9182c4a 100644 --- a/pr-1680/nodes/docker-images.html +++ b/pr-1680/nodes/docker-images.html @@ -7,14 +7,14 @@ - + - - - + + + - + @@ -41,25 +41,25 @@

    🐳 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.15.0 \
           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.15.0 \
           celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK
      bash
      docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
      -    ghcr.io/celestiaorg/celestia-node:v0.16.0-rc0 \
      +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
           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.16.0-rc0 \
      +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
           celestia $NODE_TYPE start --core.ip $RPC_URL --p2p.network $NETWORK
      bash
      docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
      -    ghcr.io/celestiaorg/celestia-node:v0.16.0-rc0 \
      +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
           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.16.0-rc0 \
      +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
           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.15.0 \
         celestia light init --p2p.network $NETWORK
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
    @@ -67,21 +67,21 @@
         ghcr.io/celestiaorg/celestia-node:v0.15.0 \
         celestia light init --p2p.network $NETWORK
    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.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light init --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.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light init --p2p.network $NETWORK
    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.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light init --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.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light init --p2p.network $NETWORK

    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.

    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.15.0 \
         celestia light start --core.ip $RPC_URL
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
    @@ -89,18 +89,18 @@
         ghcr.io/celestiaorg/celestia-node:v0.15.0 \
         celestia light start --core.ip $RPC_URL
    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.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light start --core.ip $RPC_URL
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
         -v $HOME/my-node-store:/home/celestia \
    -    ghcr.io/celestiaorg/celestia-node:v0.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light start --core.ip $RPC_URL
    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.16.0-rc0 \
    +    ghcr.io/celestiaorg/celestia-node:v0.16.0 \
         celestia light start --core.ip $RPC_URL
    docker run -e NODE_TYPE=$NODE_TYPE -e P2P_NETWORK=$NETWORK \
         -v $HOME/my-node-store:/home/celestia \
    -    ghcr.io/celestiaorg/celestia-node:v0.16.0-rc0 \
    -    celestia light start --core.ip $RPC_URL

    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 the 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.

    - + ghcr.io/celestiaorg/celestia-node:v0.16.0 \ + celestia light start --core.ip $RPC_URL

    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 the 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-1680/nodes/environment.html b/pr-1680/nodes/environment.html index a3a749779d..501c8de534 100644 --- a/pr-1680/nodes/environment.html +++ b/pr-1680/nodes/environment.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,7 +39,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 \
      @@ -53,7 +53,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.22.0"
      ver="1.22.0"
      bash
      ver="1.22.0"
      ver="1.22.0"
      bash
      ver="1.22.0"
      ver="1.22.0"
    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.22.0"
      ver="1.22.0"
      bash
      ver="1.23.0"
      ver="1.23.0"
      bash
      ver="1.23.0"
      ver="1.23.0"
    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"
      @@ -85,12 +85,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-1680/nodes/full-storage-node.html b/pr-1680/nodes/full-storage-node.html index 070e06c409..448213b930 100644 --- a/pr-1680/nodes/full-storage-node.html +++ b/pr-1680/nodes/full-storage-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,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: 10 TB SSD 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 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).

    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: 10 TB SSD 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 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).

    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> \
    @@ -48,8 +48,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: 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-1680/nodes/hardfork-process.html b/pr-1680/nodes/hardfork-process.html index e183bf66e9..1d361f4c4d 100644 --- a/pr-1680/nodes/hardfork-process.html +++ b/pr-1680/nodes/hardfork-process.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

    Celestia hardfork process

    Blockchain networks often times need to upgrade with new features which require coordination work among the validators prior to activating the upgrades.

    This process is called a hardfork or a network upgrade. In those events, the Celestia Labs team will be coordinating with the validators on what they need to do in order to be ready for an upcoming hardfork.

    Hardforks 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 after the network upgrades.

    General process

    The general process can be broken down into several components:

    • Hardfork specifications and features (defined by description of features and code implementation of those features).
    • Binary used to add those features (a new binary release with those features will be provided by Celestia team in order for validators to upgrade their nodes to the new binary).
    • A block number for when the network upgrades (even if validators upgrade their binary to be hardfork ready, the network upgrade does not happen right away, but some short time in the future at a specific block number).
    • Testing of the features (happens on testnets first prior to activating on mainnet in order to ensure the network can upgrade securely).

    The two testnets where hardforks are deployed are:

    Lemongrass hardfork

    The Lemongrass hardfork is the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass hardfork includes all of the CIPs listed in CIP-17. The Lemongrass hardfork will be executed on Arabica, then Mocha, then Mainnet Beta. The hardfork will take place at an "upgrade height" that will be coordinated offline on a per-network basis. The upgrade heights will be announced in advance (see Network upgrades) to give node operators time to download and start a compatible binary prior to the upgrade height.

    • If you are a consensus node or validator operator: you will need to download and run a celestia-app binary >= v2.0.0 prior to the --v2-upgrade-height to remain on the canonical chain. You do not need to use a tool like cosmovisor to upgrade the binary at the upgrade height.
    • If you are a DA node operator, you will need to download and run a compatible celestia-node binary >= v0.16.0-rc0 prior to the upgrade height.
    NetworkChain IDDatetime--v2-upgrade-height
    Arabicaarabica-112024/08/19 @ 14:00 UTC1751707
    Mochamocha-42024/08/28 @ 14:00 UTC2585031
    Mainnet BetacelestiaTBD approximately 2024/09/18 @ 14:00 UTCTBD
    - +

    Celestia hardfork process

    Blockchain networks often times need to upgrade with new features which require coordination work among the validators prior to activating the upgrades.

    This process is called a hardfork or a network upgrade. In those events, the Celestia Labs team will be coordinating with the validators on what they need to do in order to be ready for an upcoming hardfork.

    Hardforks 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 after the network upgrades.

    General process

    The general process can be broken down into several components:

    • Hardfork specifications and features (defined by description of features and code implementation of those features).
    • Binary used to add those features (a new binary release with those features will be provided by Celestia team in order for validators to upgrade their nodes to the new binary).
    • A block number for when the network upgrades (even if validators upgrade their binary to be hardfork ready, the network upgrade does not happen right away, but some short time in the future at a specific block number).
    • Testing of the features (happens on testnets first prior to activating on mainnet in order to ensure the network can upgrade securely).

    The two testnets where hardforks are deployed are:

    Lemongrass hardfork

    The Lemongrass hardfork is the first consensus layer breaking change since Celestia's Mainnet Beta genesis block. The Lemongrass hardfork includes all of the CIPs listed in CIP-17. The Lemongrass hardfork will be executed on Arabica, then Mocha, then Mainnet Beta. The hardfork will take place at an "upgrade height" that will be coordinated offline on a per-network basis. The upgrade heights will be announced in advance (see Network upgrades) to give node operators time to download and start a compatible binary prior to the upgrade height.

    • If you are a consensus node or validator operator: you will need to download and run a celestia-app binary >= v2.0.0 prior to the --v2-upgrade-height to remain on the canonical chain. You do not need to use a tool like cosmovisor to upgrade the binary at the upgrade height.
    • If you are a DA node operator, you will need to download and run a compatible celestia-node binary >= v0.16.0-rc0 prior to the upgrade height.
    NetworkChain IDDate and approximate time--v2-upgrade-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-1680/nodes/ibc-relayer.html b/pr-1680/nodes/ibc-relayer.html index 195d521ecb..a95b9e0096 100644 --- a/pr-1680/nodes/ibc-relayer.html +++ b/pr-1680/nodes/ibc-relayer.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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]
    +

    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]
    @@ -492,8 +492,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-1680/nodes/instantiate-testnet.html b/pr-1680/nodes/instantiate-testnet.html index 09ab47dc2a..bf5e8ccfdb 100644 --- a/pr-1680/nodes/instantiate-testnet.html +++ b/pr-1680/nodes/instantiate-testnet.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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
    +

    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
    @@ -58,8 +58,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-1680/nodes/light-node.html b/pr-1680/nodes/light-node.html index 4f4f492620..db74711d2c 100644 --- a/pr-1680/nodes/light-node.html +++ b/pr-1680/nodes/light-node.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,9 +38,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

    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, mocha, or arabica.

    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

    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, mocha, or arabica.

    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 \
    @@ -50,7 +50,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> \
    @@ -60,8 +60,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: 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-1680/nodes/mainnet.html b/pr-1680/nodes/mainnet.html index dcbfe722f4..e6cec91ddb 100644 --- a/pr-1680/nodes/mainnet.html +++ b/pr-1680/nodes/mainnet.html @@ -7,14 +7,14 @@ - + - - - + + + - + @@ -41,8 +41,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 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.15.0
    celestia-appv1.13.0

    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
    • celestia-rpc.mesa.newmetric.xyz
    • rpc.celestia.pops.one
    • rpc.lunaroasis.net
    • rpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com
    • celestia-rpc.spidey.services
    • rpc-celestia.contributiondao.com
    • celestia.rpc.stakin-nodes.com
    • celestia.cumulo.org.es
    • rpc-celestia.mzonder.com
    • 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.archives.validao.xyz
    • rpc-archive.celestia.bitszn.com
    • celestia-rpc.f5nodes.com
    • celestia-rpc.chainode.tech:33373
    • rpc-celestia.staker.space
    • celestia-rpc.noders.services
    • celestia.moonli.me
    • celestia-mainnet-rpc.itrocket.net:443
    • rpc.celestia.mainnet.dteam.tech: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-api.spidey.services
    • api-celestia.contributiondao.com
    • celestia.rest.stakin-nodes.com
    • celestia.api.cumulo.org.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.rest.archives.validao.xyz
    • api-archive.celestia.bitszn.com
    • celestia-api.f5nodes.com
    • celestia-api.chainode.tech
    • api-celestia.staker.space
    • celestia-api.noders.services
    • celestia.moonli.me/api
    • celestia-mainnet-api.itrocket.net:443
    • api.celestia.mainnet.dteam.tech: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.spidey.services
    • grpc-celestia.contributiondao.com
    • celestia.grpc.stakin-nodes.com:443
    • celestia.grpc.cumulo.org.es:443
    • grpc-celestia.mzonder.com: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.archives.validao.xyz:9090
    • gprc-archive.celestia.bitszn.com
    • celestia-grpc.f5nodes.com:9390
    • celestia-grpc.chainode.tech:443
    • grpc-celestia.staker.space
    • celestia-grpc.noders.services:11090
    • celestia-mainnet-grpc.itrocket.net:443
    • grpc.celestia.mainnet.dteam.tech:28090

    Community WebSocket endpoints

    • wss://celestia-ws.chainode.tech:33373/websocket
    • wss://celestia-mainnet-ws.itrocket.net:443/websocket
    • wss://rpc.celestia.mainnet.dteam.tech: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
    • celestia-consensus.mesa.newmetric.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
    • rpc.celestia.mainnet.dteam.tech
      • gRPC: port 28090
      • RPC: 28657
    • celestia-consensus-mainnet.noders.services
      • gRPC: port 9080
      • RPC: port 26557

    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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

    - +

    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 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.15.0
    celestia-appv1.13.0

    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
    • celestia-rpc.mesa.newmetric.xyz
    • rpc.celestia.pops.one
    • rpc.lunaroasis.net
    • rpc.celestia.nodestake.top
    • celestia-rpc.brightlystake.com
    • celestia-rpc.spidey.services
    • rpc-celestia.contributiondao.com
    • celestia.rpc.stakin-nodes.com
    • celestia.cumulo.org.es
    • rpc-celestia.mzonder.com
    • 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.archives.validao.xyz
    • rpc-archive.celestia.bitszn.com
    • celestia-rpc.f5nodes.com
    • celestia-rpc.chainode.tech:33373
    • rpc-celestia.staker.space
    • celestia-rpc.noders.services
    • celestia.moonli.me
    • celestia-mainnet-rpc.itrocket.net:443
    • rpc.celestia.mainnet.dteam.tech: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-api.spidey.services
    • api-celestia.contributiondao.com
    • celestia.rest.stakin-nodes.com
    • celestia.api.cumulo.org.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.rest.archives.validao.xyz
    • api-archive.celestia.bitszn.com
    • celestia-api.f5nodes.com
    • celestia-api.chainode.tech
    • api-celestia.staker.space
    • celestia-api.noders.services
    • celestia.moonli.me/api
    • celestia-mainnet-api.itrocket.net:443
    • api.celestia.mainnet.dteam.tech: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.spidey.services
    • grpc-celestia.contributiondao.com
    • celestia.grpc.stakin-nodes.com:443
    • celestia.grpc.cumulo.org.es:443
    • grpc-celestia.mzonder.com: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.archives.validao.xyz:9090
    • gprc-archive.celestia.bitszn.com
    • celestia-grpc.f5nodes.com:9390
    • celestia-grpc.chainode.tech:443
    • grpc-celestia.staker.space
    • celestia-grpc.noders.services:11090
    • celestia-mainnet-grpc.itrocket.net:443
    • grpc.celestia.mainnet.dteam.tech:28090

    Community WebSocket endpoints

    • wss://celestia-ws.chainode.tech:33373/websocket
    • wss://celestia-mainnet-ws.itrocket.net:443/websocket
    • wss://rpc.celestia.mainnet.dteam.tech: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
    • celestia-consensus.mesa.newmetric.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
    • rpc.celestia.mainnet.dteam.tech
      • gRPC: port 28090
      • RPC: 28657
    • celestia-consensus-mainnet.noders.services
      • gRPC: port 9080
      • RPC: port 26557

    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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

    + \ No newline at end of file diff --git a/pr-1680/nodes/mocha-testnet.html b/pr-1680/nodes/mocha-testnet.html index da58bcc37d..ae5918b990 100644 --- a/pr-1680/nodes/mocha-testnet.html +++ b/pr-1680/nodes/mocha-testnet.html @@ -7,14 +7,14 @@ - + - - - - - + + + + + @@ -41,8 +41,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.16.0-rc0
    celestia-appv2.1.2

    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
    • rpc.celestia.testnet.dteam.tech:443
      • gRPC: grpc.celestia.testnet.dteam.tech:27090
    • celestia-consensus-testnet.noders.services
      • RPC port: 26357
      • gRPC port: 9070

    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
    • rpc.celestia-mocha.com
    • celestia-testnet-rpc.f5nodes.com
    • celestia-testnet.brightlystake.com
    • rpc-celestia-mocha.architectnodes.com
    • rpc-celestia-mocha.trusted-point.com
    • rpc-celestia-testnet-01.stakeflow.io
    • mocha.celestia.rpc.cumulo.me
    • rpc-mocha-4.spidey.services
    • rpc-mocha-full.avril14th.org
    • rpc.mocha.bitszn.com
    • celestia-t-rpc.noders.services/
    • 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
    • rpc.celestia.testnet.dteam.tech: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-grpc.f5nodes.com
    • celestia-testnet.brightlystake.com:9390
    • grpc-celestia-mocha.architectnodes.com:1443
    • grpc-celestia-mocha.trusted-point.com:9099
    • grpc-celestia-testnet-01.stakeflow.io:16002
    • mocha.grpc.cumulo.me:443
    • grpc-mocha-4.spidey.services
    • grpc-mocha-full.avril14th.org
    • grpc.mocha.bitszn.com
    • celestia-grpc.noders.services:21090
    • 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
    • grpc.celestia.testnet.dteam.tech:27090

    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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

    - +

    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.16.0
    celestia-appv2.1.2

    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
    • rpc.celestia.testnet.dteam.tech:443
      • gRPC: grpc.celestia.testnet.dteam.tech:27090
    • celestia-consensus-testnet.noders.services
      • RPC port: 26357
      • gRPC port: 9070

    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
    • rpc.celestia-mocha.com
    • celestia-testnet-rpc.f5nodes.com
    • celestia-testnet.brightlystake.com
    • rpc-celestia-mocha.architectnodes.com
    • rpc-celestia-mocha.trusted-point.com
    • rpc-celestia-testnet-01.stakeflow.io
    • mocha.celestia.rpc.cumulo.me
    • rpc-mocha-4.spidey.services
    • rpc-mocha-full.avril14th.org
    • rpc.mocha.bitszn.com
    • celestia-t-rpc.noders.services/
    • 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
    • rpc.celestia.testnet.dteam.tech: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-grpc.f5nodes.com
    • celestia-testnet.brightlystake.com:9390
    • grpc-celestia-mocha.architectnodes.com:1443
    • grpc-celestia-mocha.trusted-point.com:9099
    • grpc-celestia-testnet-01.stakeflow.io:16002
    • mocha.grpc.cumulo.me:443
    • grpc-mocha-4.spidey.services
    • grpc-mocha-full.avril14th.org
    • grpc.mocha.bitszn.com
    • celestia-grpc.noders.services:21090
    • 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
    • grpc.celestia.testnet.dteam.tech:27090

    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 Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

    + \ No newline at end of file diff --git a/pr-1680/nodes/overview.html b/pr-1680/nodes/overview.html index 6a562c5930..f2afc93031 100644 --- a/pr-1680/nodes/overview.html +++ b/pr-1680/nodes/overview.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,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 cores10 TB SSD1 Gbps
    Full storage node16 GB RAMQuad-core10 TB SSD1 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 cores10 TB SSD1 Gbps
    Full storage node16 GB RAMQuad-core10 TB SSD1 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-1680/nodes/participate.html b/pr-1680/nodes/participate.html index 27957c39aa..adece7d252 100644 --- a/pr-1680/nodes/participate.html +++ b/pr-1680/nodes/participate.html @@ -7,18 +7,18 @@ - + - - - - - - - + + + + + + + - + @@ -45,8 +45,8 @@

    Participate in the Celestia networks

    Mainnet Beta

    Celestia’s Mainnet Beta is the production network for deploying mainnet 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.15.0
    celestia-appv1.13.0

    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.16.0-rc0
    celestia-appv2.1.2

    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 hardforks in coordination with the validator community on Mocha.

    Compatible software versions for Mocha testnet

    SoftwareVersion
    celestia-nodev0.16.0-rc0
    celestia-appv2.1.2

    Network upgrades

    There are a few ways to stay informed about network upgrades:

    See the Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

    - +

    Participate in the Celestia networks

    Mainnet Beta

    Celestia’s Mainnet Beta is the production network for deploying mainnet 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.15.0
    celestia-appv1.13.0

    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.16.0
    celestia-appv2.1.2

    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 hardforks in coordination with the validator community on Mocha.

    Compatible software versions for Mocha testnet

    SoftwareVersion
    celestia-nodev0.16.0
    celestia-appv2.1.2

    Network upgrades

    There are a few ways to stay informed about network upgrades:

    See the Hardfork process page to learn more about specific upgrades like the Lemongrass hardfork.

    + \ No newline at end of file diff --git a/pr-1680/nodes/quick-start.html b/pr-1680/nodes/quick-start.html index c17118211f..dfb9411d80 100644 --- a/pr-1680/nodes/quick-start.html +++ b/pr-1680/nodes/quick-start.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,8 +38,8 @@

    Quick start guide

    In this section, we show you how to get started with installing the needed libraries and packages in Celestia to help you run a node on Celestia.

    Celestia Node

    Install celestia-node allows you to get started with running a light node and do data availability sampling.

    Light nodes are the best nodes to test out initially if you are new to participating in Celestia.

    celestia-node client also allows you to run other types of data availability (DA) nodes like bridge and full DA storage nodes, which will be covered in later sections.

    Celestia App

    Install celestia-app allows you to get started running a consensus node.

    celestia-app is the software that allows you to run validator nodes and also provide RPC endpoints.

    celestia-app covers the consensus layer, while celestia-node covers the DA layer.

    Getting started

    As covered in the previous section, Celestia offers two different test networks, Arabica devnet and Mocha testnet.

    If you are planning to run a light node, it is recommended to use Arabica, which you will find options to connecting to in the later sections.

    If you plan on running a validator, your only option is to run your node on Mocha.

    In this quick start guide, we will go over installing both of the software clients: celestia-node and celestia-app.

    NOTE

    If you just want to run a light node, you don't need to install celestia-app and can skip that part.

    Proceed to the next section in order to get started.

    - +

    Quick start guide

    In this section, we show you how to get started with installing the needed libraries and packages in Celestia to help you run a node on Celestia.

    Celestia Node

    Install celestia-node allows you to get started with running a light node and do data availability sampling.

    Light nodes are the best nodes to test out initially if you are new to participating in Celestia.

    celestia-node client also allows you to run other types of data availability (DA) nodes like bridge and full DA storage nodes, which will be covered in later sections.

    Celestia App

    Install celestia-app allows you to get started running a consensus node.

    celestia-app is the software that allows you to run validator nodes and also provide RPC endpoints.

    celestia-app covers the consensus layer, while celestia-node covers the DA layer.

    Getting started

    As covered in the previous section, Celestia offers two different test networks, Arabica devnet and Mocha testnet.

    If you are planning to run a light node, it is recommended to use Arabica, which you will find options to connecting to in the later sections.

    If you plan on running a validator, your only option is to run your node on Mocha.

    In this quick start guide, we will go over installing both of the software clients: celestia-node and celestia-app.

    NOTE

    If you just want to run a light node, you don't need to install celestia-app and can skip that part.

    Proceed to the next section in order to get started.

    + \ No newline at end of file diff --git a/pr-1680/nodes/systemd.html b/pr-1680/nodes/systemd.html index 3aac22f799..bdd8a23503 100644 --- a/pr-1680/nodes/systemd.html +++ b/pr-1680/nodes/systemd.html @@ -7,11 +7,11 @@ - + - - + + @@ -38,7 +38,7 @@

    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
    +

    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
    @@ -162,8 +162,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-1680/nodes/validator-node.html b/pr-1680/nodes/validator-node.html index 1bb3cbd95b..2447ca870e 100644 --- a/pr-1680/nodes/validator-node.html +++ b/pr-1680/nodes/validator-node.html @@ -7,12 +7,12 @@ - + - - - + + + @@ -39,7 +39,7 @@

    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:
    +

    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:

    bash
    celestia-appd tx staking delegate \
     celestiavaloper1q3v5cugc8cdpud87u4zwy0a74uxkk6u4q4gx4p 1000000utia \
    @@ -69,7 +69,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.

    If you need a list of RPC endpoints to connect to, you can find the list on the Mocha testnet page or list on the Arabica devnet page.

    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 <height>
    celestia-appd start --v2-upgrade-height <height>
    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.

    If you need a list of RPC endpoints to connect to, you can find the list on the Mocha testnet page or list on the Arabica devnet page.

    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 \
    @@ -121,8 +121,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 unsafe-reset-all to reset your node and start syncing from the genesis block.

    - +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.

    + \ No newline at end of file diff --git a/pr-1680/sitemap.xml b/pr-1680/sitemap.xml index acd035f69e..6f531102a7 100644 --- a/pr-1680/sitemap.xml +++ b/pr-1680/sitemap.xml @@ -1 +1 @@ -https://docs.celestia.org/README2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/calendar2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/coc2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/foundation-delegation-program2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/itn-tos2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/modular-meetup-guide2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/modular-meetup-intro2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/modular-meetup-toolkit2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/overview2024-08-28T17:47:55.000Zhttps://docs.celestia.org/community/speaker-list2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/arbitrum-bridge2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/arbitrum-dapp-deploy2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/arbitrum-deploy2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/arbitrum-full-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/arbitrum-integration2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/arbitrum-smart-contract2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream-contracts2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream-offchain2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream-proof-queries2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream-rollups2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream-x-deploy2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream-x-requesting-data-commitment-ranges2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/blobstream2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/bubs-testnet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/build-whatever2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/celestia-node-key2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/deploy-on-bubs2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/ethereum-fallback2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/feegrant-for-blobs2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/full-stack-modular-development-guide2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/gm-portal-bubs2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/golang-client-tutorial2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/integrate-celestia2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/intro-to-op-stack2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/node-api2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/node-tutorial2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/optimism-devnet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/optimism2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/prompt-scavenger2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/rust-client-tutorial2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/sp1-blobstream-deploy2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/submit-data2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/transaction-resubmission2024-08-28T17:47:55.000Zhttps://docs.celestia.org/developers/wallets2024-08-28T17:47:55.000Zhttps://docs.celestia.org/2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-faq2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-layer2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/how-celestia-works/monolithic-vs-modular2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/how-celestia-works/overview2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/how-celestia-works/transaction-lifecycle2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/how-to-stake-tia2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/paying-for-blobspace2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/retrievability2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/staking-governance-supply2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/staking2024-08-28T17:47:55.000Zhttps://docs.celestia.org/learn/tia2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/arabica-devnet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/bridge-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-commands2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-metrics2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-multisig2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-slashing2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-upgrade-monitor2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-vesting2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app-wallet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-app2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-node-custom-networks2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-node-metrics2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-node-troubleshooting2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-node-trusted-hash2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/celestia-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/config-toml2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/consensus-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/decide-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/docker-images2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/environment2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/full-storage-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/hardfork-process2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/ibc-relayer2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/instantiate-testnet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/light-node2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/mainnet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/mocha-testnet2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/overview2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/participate2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/quick-start2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/systemd2024-08-28T17:47:55.000Zhttps://docs.celestia.org/nodes/validator-node2024-08-28T17:47:55.000Z \ No newline at end of file +https://docs.celestia.org/README2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/calendar2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/coc2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/foundation-delegation-program2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/itn-tos2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/modular-meetup-guide2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/modular-meetup-intro2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/modular-meetup-toolkit2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/overview2024-09-10T08:07:50.000Zhttps://docs.celestia.org/community/speaker-list2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/arbitrum-bridge2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/arbitrum-dapp-deploy2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/arbitrum-deploy2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/arbitrum-full-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/arbitrum-integration2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/arbitrum-smart-contract2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream-contracts2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream-offchain2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream-proof-queries2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream-rollups2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream-x-deploy2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream-x-requesting-data-commitment-ranges2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstream2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/blobstreamx2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/bubs-testnet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/build-whatever2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/celestia-node-key2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/deploy-on-bubs2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/ethereum-fallback2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/feegrant-for-blobs2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/full-stack-modular-development-guide2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/gm-portal-bubs2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/golang-client-tutorial2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/integrate-celestia2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/intro-to-op-stack2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/multiaccounts2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/node-api2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/node-tutorial2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/optimism-devnet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/optimism2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/prompt-scavenger2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/rust-client-tutorial2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/sp1-blobstream-deploy2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/submit-data2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/transaction-resubmission2024-09-10T08:07:50.000Zhttps://docs.celestia.org/developers/wallets2024-09-10T08:07:50.000Zhttps://docs.celestia.org/2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-faq2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/how-celestia-works/data-availability-layer2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/how-celestia-works/monolithic-vs-modular2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/how-celestia-works/overview2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/how-celestia-works/transaction-lifecycle2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/how-to-stake-tia2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/paying-for-blobspace2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/retrievability2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/staking-governance-supply2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/staking2024-09-10T08:07:50.000Zhttps://docs.celestia.org/learn/tia2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/arabica-devnet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/bridge-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-commands2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-metrics2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-multisig2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-slashing2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-upgrade-monitor2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-vesting2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app-wallet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-app2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-node-custom-networks2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-node-metrics2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-node-troubleshooting2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-node-trusted-hash2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/celestia-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/config-toml2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/consensus-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/decide-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/docker-images2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/environment2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/full-storage-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/hardfork-process2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/ibc-relayer2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/instantiate-testnet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/light-node2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/mainnet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/mocha-testnet2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/overview2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/participate2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/quick-start2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/systemd2024-09-10T08:07:50.000Zhttps://docs.celestia.org/nodes/validator-node2024-09-10T08:07:50.000Z \ No newline at end of file