From 6d4e07ff65c4423aec7e5f9c899238fbb277aa98 Mon Sep 17 00:00:00 2001 From: reigj1 <61514978+reigj1@users.noreply.github.com> Date: Sun, 8 Dec 2024 17:13:29 +0100 Subject: [PATCH 01/10] add library to learn menu (#3867) --- docusaurus.config.js | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/docusaurus.config.js b/docusaurus.config.js index ca75c2206d..013e249e17 100644 --- a/docusaurus.config.js +++ b/docusaurus.config.js @@ -198,6 +198,11 @@ const marketingNav = { href: "/capabilities/sustainability", description: "Building green, efficient tech", }, + { + name: "Library", + href: "/library", + description: "Resources to get you started", + }, /* { name: "ICP as a Bitcoin L2", From e1113f06f300524f8d3b02da2e7c00ae30244074 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?The=20Fenix=20=E2=88=9E?= Date: Mon, 9 Dec 2024 11:19:23 +0200 Subject: [PATCH 02/10] Add icptokens.net to showcase (#3751) --- showcase.json | 16 ++++++++++++ static/img/showcase/icptokens_logo.svg | 34 ++++++++++++++++++++++++++ 2 files changed, 50 insertions(+) create mode 100644 static/img/showcase/icptokens_logo.svg diff --git a/showcase.json b/showcase.json index 038f2b67a8..e3f835c8a8 100644 --- a/showcase.json +++ b/showcase.json @@ -4841,5 +4841,21 @@ ], "github": "https://github.com/tolgayayci/dfx-dashboard", "website": "https://dfx-dashboard-docs.netlify.app/" + }, + { + "id": "icptokens", + "name": "ICP Tokens", + "tags": [ + "Tools / Infrastructure" + ], + "stats": "15,000+ users", + "website": "https://icptokens.net", + "github": "https://github.com/CyberNinjasLab", + "youtube": "https://www.youtube.com/watch?v=2hKfVcJviTM", + "twitter": "https://x.com/ICPTokens", + "description": "Advanced tool for tracking ICP tokens, designed to simplify the way you monitor, analyze, and manage tokens within the Internet Computer DeFi ecosystem. Portfolio insights, advanced charts and bubble maps for visual insights.", + "usesInternetIdentity": true, + "display": "Normal", + "logo": "/img/showcase/icptokens_logo.svg" } ] diff --git a/static/img/showcase/icptokens_logo.svg b/static/img/showcase/icptokens_logo.svg new file mode 100644 index 0000000000..989baa37fa --- /dev/null +++ b/static/img/showcase/icptokens_logo.svg @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + \ No newline at end of file From c98b33c544f90d289f40f93fceee3d19a516d651 Mon Sep 17 00:00:00 2001 From: Jessie Mongeon <133128541+jessiemongeon1@users.noreply.github.com> Date: Mon, 9 Dec 2024 07:57:08 -0800 Subject: [PATCH 03/10] Remove overview headings (#3866) * Remove overview headings * Update docs/developer-docs/smart-contracts/advanced-features/async-code.mdx Co-authored-by: venkkatesh-sekar <94061546+venkkatesh-sekar@users.noreply.github.com> --------- Co-authored-by: venkkatesh-sekar <94061546+venkkatesh-sekar@users.noreply.github.com> --- docs/developer-docs/ai/ai-on-chain.mdx | 2 +- docs/developer-docs/ai/inference.mdx | 2 +- .../ai/machine-learning-sample.mdx | 2 +- docs/developer-docs/ai/samples.mdx | 2 +- docs/developer-docs/ai/training-models.mdx | 2 +- .../backend/rust/access-control.mdx | 2 +- docs/developer-docs/backend/rust/candid.mdx | 2 +- docs/developer-docs/backend/rust/counter.mdx | 2 +- .../developer-docs/backend/rust/deploying.mdx | 2 +- .../backend/rust/generating-candid.mdx | 2 +- .../backend/rust/intercanister.mdx | 2 +- .../backend/rust/message-inspect.mdx | 2 +- .../backend/rust/optimizing.mdx | 2 +- .../backend/rust/project-organization.mdx | 2 +- .../backend/rust/quickstart.mdx | 2 +- .../backend/rust/rust-considerations.mdx | 2 +- .../backend/rust/rust-limitations.mdx | 2 +- .../backend/rust/searching-records.mdx | 2 +- .../backend/rust/stable-structures.mdx | 2 +- docs/developer-docs/backend/rust/timers.mdx | 2 +- .../developer-docs/backend/rust/upgrading.mdx | 2 +- .../cost-estimations-and-examples.mdx | 2 +- .../neurons/becoming-a-known-neuron.mdx | 2 +- .../nns/concepts/neurons/neuron-following.mdx | 2 +- .../concepts/neurons/neuron-management.mdx | 2 +- .../neurons/staking-voting-rewards.mdx | 2 +- .../nns/concepts/proposals/direct-voting.mdx | 2 +- docs/developer-docs/daos/nns/overview.mdx | 2 +- .../using-the-nns-dapp/nns-app-quickstart.mdx | 2 +- .../nns-dapp-additional-features.mdx | 2 +- .../nns-dapp-advanced-neuron-operations.mdx | 2 +- .../nns-dapp-following-other-neurons.mdx | 2 +- .../nns-dapp-importing-tokens.mdx | 2 +- .../nns-dapp-making-neurons-public.mdx | 2 +- .../nns-dapp-manage-quill-neurons.mdx | 2 +- .../nns-dapp-send-and-receive-tokens.mdx | 2 +- docs/developer-docs/daos/sns/index.mdx | 2 +- .../daos/sns/launching/integrating.mdx | 2 +- .../sns/launching/launch-steps-1proposal.mdx | 2 +- .../launching/launch-summary-1proposal.mdx | 2 +- .../daos/sns/managing/cycles-usage.mdx | 2 +- .../daos/sns/managing/making-proposals.mdx | 2 +- .../daos/sns/managing/manage-sns-intro.mdx | 2 +- .../managing-nervous-system-parameters.mdx | 2 +- .../daos/sns/managing/sns-asset-canister.mdx | 2 +- .../daos/sns/testing/testing-locally.mdx | 2 +- .../daos/sns/testing/testing-on-mainnet.mdx | 2 +- .../daos/sns/tokenomics/index.mdx | 2 +- .../predeployment-considerations.mdx | 2 +- .../daos/sns/tokenomics/preparation.mdx | 2 +- .../converting_icp_tokens_into_cycles.mdx | 2 +- .../defi/cycles/cycles-ledger.mdx | 2 +- .../defi/cycles/cycles-wallet.mdx | 2 +- .../defi/exchange-rate-canister.mdx | 2 +- .../defi/icp-tokens/account-trimming.mdx | 2 +- .../developer-docs/defi/nfts/marketplaces.mdx | 2 +- .../defi/nfts/nft-collections.mdx | 2 +- .../icp_rosetta/construction_api/index.mdx | 2 +- .../operations_flow/combine.mdx | 2 +- .../operations_flow/derive.mdx | 2 +- .../operations_flow/index.mdx | 2 +- .../operations_flow/metadata.mdx | 2 +- .../operations_flow/payloads.mdx | 2 +- .../operations_flow/preprocess.mdx | 2 +- .../operations_flow/submit.mdx | 2 +- .../staking/change_auto_stake_maturity.mdx | 2 +- .../staking/derive_neuron_id.mdx | 2 +- .../construction_api/staking/disburse.mdx | 2 +- .../construction_api/staking/dissolve.mdx | 2 +- .../construction_api/staking/hotkeys.mdx | 2 +- .../construction_api/staking/index.mdx | 2 +- .../construction_api/staking/lock_neuron.mdx | 2 +- .../construction_api/staking/neuron_info.mdx | 2 +- .../construction_api/staking/spawn.mdx | 2 +- .../construction_api/staking/stake_icp.mdx | 2 +- .../staking/stake_maturity.mdx | 2 +- .../construction_api/voting/follow.mdx | 2 +- .../construction_api/voting/index.mdx | 2 +- .../construction_api/voting/vote.mdx | 2 +- .../rosetta/icp_rosetta/data_api/balances.mdx | 2 +- .../rosetta/icp_rosetta/data_api/blocks.mdx | 2 +- .../data_api/get_pending_proposals.mdx | 2 +- .../data_api/get_proposal_info.mdx | 2 +- .../rosetta/icp_rosetta/data_api/index.mdx | 2 +- .../data_api/list_known_neurons.mdx | 2 +- .../rosetta/icp_rosetta/data_api/network.mdx | 2 +- .../icp_rosetta/data_api/transactions.mdx | 2 +- .../asset_transfer/approve.mdx | 2 +- .../construction_api/asset_transfer/index.mdx | 2 +- .../asset_transfer/transfer.mdx | 2 +- .../icrc_rosetta/construction_api/index.mdx | 2 +- .../icrc_rosetta/data_api/balances.mdx | 2 +- .../rosetta/icrc_rosetta/data_api/blocks.mdx | 2 +- .../rosetta/icrc_rosetta/data_api/index.mdx | 2 +- .../rosetta/icrc_rosetta/data_api/network.mdx | 2 +- .../icrc_rosetta/data_api/transactions.mdx | 2 +- docs/developer-docs/defi/rosetta/overview.mdx | 2 +- docs/developer-docs/defi/tokens/create.mdx | 2 +- docs/developer-docs/defi/tokens/indexes.mdx | 2 +- .../tokens/ledger/setup/icp_ledger_setup.mdx | 2 +- .../ledger/setup/icrc1_ledger_setup.mdx | 2 +- .../tokens/ledger/usage/icp_ledger_usage.mdx | 2 +- .../ledger/usage/icrc1_ledger_usage.mdx | 2 +- .../defi/tokens/token-standards.mdx | 2 +- .../self-custody/hardware-wallet-cli.mdx | 2 +- .../self-custody/self-custody-quickstart.mdx | 2 +- .../advanced-dfx/check-chunk-store.mdx | 2 +- .../cli-tools/advanced-dfx/dfx-migration.mdx | 2 +- .../cli-tools/advanced-dfx/init-args.mdx | 2 +- .../cli-tools/advanced-dfx/networks-json.mdx | 2 +- .../specifying-replica-version.mdx | 2 +- .../cli-tools/dfx-json-reference.mdx | 2 +- .../developer-tools/cli-tools/dfx-json.mdx | 2 +- .../developer-tools/cli-tools/idl2json.mdx | 2 +- .../developer-tools/dev-tools-overview.mdx | 2 +- .../developer-tools/ide/codespaces.mdx | 2 +- .../developer-tools/ide/dev-containers.mdx | 2 +- .../developer-tools/ide/gitpod.mdx | 2 +- .../developer-tools/ide/icp-ninja.mdx | 2 +- .../developer-tools/ide/playground.mdx | 2 +- .../developer-tools/ide/vs-code.mdx | 2 +- .../off-chain/agents/javascript-agent.mdx | 2 +- .../off-chain/agents/nodejs.mdx | 2 +- .../off-chain/agents/rust-agent.mdx | 2 +- .../developer-tools/off-chain/canbench.mdx | 2 +- .../developer-tools/off-chain/canpack.mdx | 2 +- .../developer-tools/on-chain/cdks.mdx | 2 +- .../developer-tools/on-chain/ic-js.mdx | 2 +- docs/developer-docs/gas-cost.mdx | 2 +- .../getting-started/deploy-and-manage.mdx | 2 +- .../getting-started/deploy/local.mdx | 2 +- .../getting-started/deploy/mainnet.mdx | 2 +- .../getting-started/deploy/testnet.mdx | 2 +- .../getting-started/explore-examples.mdx | 2 +- .../getting-started/identities.mdx | 2 +- .../getting-started/install.mdx | 2 +- .../getting-started/tokens-and-cycles.mdx | 2 +- .../getting-started/troubleshooting.mdx | 2 +- .../getting-started/write-smart-contracts.mdx | 2 +- .../getting-started/wsl-troubleshoot.mdx | 2 +- .../internet-identity/alternative-origins.mdx | 2 +- .../internet-identity/creating-ii.mdx | 2 +- .../integrate-internet-identity.mdx | 2 +- .../verifiable-credentials/how-it-works.mdx | 2 +- .../verifiable-credentials/issuer.mdx | 2 +- .../verifiable-credentials/relying-party.mdx | 2 +- .../bitcoin/using-btc/btc-comparison.mdx | 2 +- .../bitcoin/using-btc/btc-dev-workflow.mdx | 2 +- .../bitcoin/using-btc/create-transactions.mdx | 2 +- .../bitcoin/using-btc/generate-addresses.mdx | 2 +- .../bitcoin/using-btc/local-development.mdx | 2 +- .../bitcoin/using-btc/ordinals.mdx | 2 +- .../bitcoin/using-btc/read-state.mdx | 2 +- .../multi-chain/bitcoin/using-btc/runes.mdx | 2 +- .../bitcoin/using-btc/sign-transactions.mdx | 2 +- .../bitcoin/using-btc/submit-transactions.mdx | 2 +- .../ckbtc/making-transactions.mdx | 2 +- .../ckbtc/using-ckbtc-in-dapps.mdx | 2 +- .../ckerc20/making-transactions.mdx | 2 +- .../ckerc20/using-ckerc20-in-dapps.mdx | 2 +- .../cketh/making-transactions.mdx | 2 +- .../cketh/using-cketh-in-dapps.mdx | 2 +- .../multi-chain/ethereum/evm-rpc/costs.mdx | 2 +- .../ethereum/evm-rpc/how-it-works.mdx | 2 +- .../ethereum/using-eth/eth-comparison.mdx | 2 +- .../ethereum/using-eth/eth-dev-workflow.mdx | 2 +- .../using-eth/generating-addresses.mdx | 2 +- .../using-eth/signing-transactions.mdx | 2 +- .../using-eth/submit-transactions.mdx | 2 +- docs/developer-docs/multi-chain/examples.mdx | 2 +- .../multi-chain/supported-chains.mdx | 2 +- .../security-best-practices/resources.mdx | 2 +- .../advanced-features/async-code.mdx | 4 +-- .../advanced-features/composite-query.mdx | 2 +- .../handling-get-post-requests.mdx | 2 +- .../https-outcalls/https-outcalls-get.mdx | 2 +- .../https-outcalls/https-outcalls-post.mdx | 2 +- .../advanced-features/management-canister.mdx | 2 +- .../advanced-features/periodic-tasks.mdx | 2 +- .../advanced-features/query-stats.mdx | 2 +- .../advanced-features/randomness.mdx | 2 +- .../advanced-features/simd.mdx | 2 +- .../advanced-features/system-canisters.mdx | 2 +- .../advanced-features/time-and-timestamps.mdx | 2 +- .../best-practices/general.mdx | 2 +- .../best-practices/idempotency.mdx | 2 +- .../best-practices/reproducible-builds.mdx | 2 +- .../best-practices/storage.mdx | 2 +- .../best-practices/troubleshooting.mdx | 2 +- .../candid/candid-concepts.mdx | 2 +- .../smart-contracts/candid/candid-howto.mdx | 2 +- .../smart-contracts/candid/candid-tools.mdx | 2 +- .../smart-contracts/compile.mdx | 2 +- .../developer-docs/smart-contracts/create.mdx | 2 +- .../deploy/custom-testnets.mdx | 2 +- .../encryption/using-vetkeys.mdx | 2 +- .../smart-contracts/install.mdx | 2 +- .../smart-contracts/maintain/control.mdx | 2 +- .../smart-contracts/maintain/delete.mdx | 2 +- .../smart-contracts/maintain/history.mdx | 2 +- .../smart-contracts/maintain/import.mdx | 2 +- .../smart-contracts/maintain/logs.mdx | 2 +- .../smart-contracts/maintain/recovery.mdx | 2 +- .../maintain/resource-limits.mdx | 2 +- .../smart-contracts/maintain/settings.mdx | 2 +- .../smart-contracts/maintain/snapshots.mdx | 2 +- .../smart-contracts/maintain/state.mdx | 2 +- .../smart-contracts/maintain/storage.mdx | 2 +- .../smart-contracts/maintain/trapping.mdx | 2 +- .../smart-contracts/maintain/upgrade.mdx | 2 +- .../overview/trust-in-canisters.mdx | 2 +- .../signatures/signing-messages-t-ecdsa.mdx | 2 +- .../signatures/signing-messages-t-schnorr.mdx | 2 +- .../smart-contracts/signatures/t-ecdsa.mdx | 2 +- .../smart-contracts/signatures/t-schnorr.mdx | 2 +- .../smart-contracts/test/pocket-ic.mdx | 2 +- .../topping-up/cycles_management_services.mdx | 2 +- .../topping-up/topping-up-canister.mdx | 2 +- .../application-frontends/add-stylesheet.mdx | 2 +- .../application-frontends/asset-security.mdx | 2 +- .../default-frontend.mdx | 2 +- .../existing-frontend.mdx | 2 +- .../application-frontends/webpack.mdx | 2 +- .../web-apps/browser-js/js-frameworks.mdx | 2 +- .../web-apps/custom-domains/dns-setup.mdx | 2 +- .../custom-domains/using-custom-domains.mdx | 2 +- .../web-apps/frameworks/juno.mdx | 2 +- .../independently-verifying-ic-signatures.mdx | 2 +- docs/references/dashboard/dashboard-apis.mdx | 2 +- .../dashboard/using-the-dashboard.mdx | 2 +- docs/references/ingress-messages.mdx | 28 +++++++++---------- docs/references/ledger.mdx | 2 +- .../node-providers/node-metrics.mdx | 2 +- docs/references/subnets/overview.mdx | 2 +- docs/references/subnets/subnet-types.mdx | 2 +- docs/references/t-sigs-how-it-works.mdx | 2 +- docs/references/vetkeys-overview.mdx | 2 +- docs/tutorials/developer-journey/index.mdx | 2 +- .../level-0/01-ic-overview.mdx | 2 +- .../developer-journey/level-0/02-ic-terms.mdx | 2 +- .../developer-journey/level-0/03-dev-env.mdx | 2 +- .../level-0/04-intro-canisters.mdx | 2 +- .../level-0/05-intro-languages.mdx | 2 +- .../level-0/06-intro-dfx.mdx | 2 +- .../level-1/1.1-live-demo.mdx | 2 +- .../level-1/1.2-motoko-lvl1.mdx | 2 +- .../level-1/1.3-first-dapp.mdx | 2 +- .../level-1/1.4-using-cycles.mdx | 2 +- .../level-1/1.5-deploying-canisters.mdx | 2 +- .../level-1/1.6-managing-canisters.mdx | 2 +- .../level-2/2.1-storage-persistence.mdx | 2 +- .../level-2/2.2-advanced-canister-calls.mdx | 2 +- .../level-2/2.3-third-party-canisters.mdx | 2 +- .../level-2/2.4-intro-candid.mdx | 2 +- .../level-2/2.5-unit-testing.mdx | 2 +- .../level-2/2.6-motoko-lvl2.mdx | 2 +- .../level-3/3.1-package-managers.mdx | 2 +- .../level-3/3.2-https-outcalls.mdx | 2 +- .../level-3/3.3-certified-data.mdx | 2 +- .../level-3/3.4-intro-to-agents.mdx | 2 +- .../level-3/3.5-identities-and-auth.mdx | 2 +- .../level-3/3.6-motoko-lvl3.mdx | 2 +- .../level-4/4.1-icp-ledger.mdx | 2 +- .../level-4/4.2-icrc-tokens.mdx | 2 +- .../level-4/4.3-ckbtc-and-bitcoin.mdx | 2 +- .../level-4/4.4-nns-governance.mdx | 2 +- .../level-4/4.5-using-quill.mdx | 2 +- .../level-4/4.6-motoko-lvl4.mdx | 2 +- .../level-5/5.1-vetKeys-tutorial.mdx | 2 +- .../level-5/5.2-ICP-ETH-tutorial.mdx | 2 +- .../level-5/5.3-token-swap-tutorial.mdx | 2 +- .../level-5/5.4-NFT-tutorial.mdx | 2 +- .../level-5/5.5-auction-tutorial.mdx | 2 +- .../level-5/5.6-next-steps.mdx | 2 +- .../hackathon-prep-course/1-what-is-icp.mdx | 2 +- .../2-deploying-first-fullstack-dapp.mdx | 2 +- .../3-exploring-the-backend.mdx | 2 +- .../4-exploring-the-frontend.mdx | 2 +- .../5-integrating-with-tokens.mdx | 2 +- .../6-authentication.mdx | 2 +- .../7-obtaining-cycles.mdx | 2 +- .../8-managing-canisters.mdx | 2 +- 282 files changed, 296 insertions(+), 296 deletions(-) diff --git a/docs/developer-docs/ai/ai-on-chain.mdx b/docs/developer-docs/ai/ai-on-chain.mdx index 5595e8760e..7d9298e75d 100644 --- a/docs/developer-docs/ai/ai-on-chain.mdx +++ b/docs/developer-docs/ai/ai-on-chain.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + ICP's unique ability to run compute at scale allows AI and neural networks to run directly onchain within a canister smart contract. diff --git a/docs/developer-docs/ai/inference.mdx b/docs/developer-docs/ai/inference.mdx index c161521e99..33b6c65c9a 100644 --- a/docs/developer-docs/ai/inference.mdx +++ b/docs/developer-docs/ai/inference.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Inference in the context of decentralized AI refers to using a trained model to draw conclusions about new data. It's possible for canister smart contracts to run inference in a number of ways depending on the decentralization and performance requirements. diff --git a/docs/developer-docs/ai/machine-learning-sample.mdx b/docs/developer-docs/ai/machine-learning-sample.mdx index 3c8db1b341..4982efc2fb 100644 --- a/docs/developer-docs/ai/machine-learning-sample.mdx +++ b/docs/developer-docs/ai/machine-learning-sample.mdx @@ -11,7 +11,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Machine learning is a form of artificial intelligence (AI) that observes statistical algorithms and their data to learn patterns and generalizations. By analyzing these data patterns, machine learning algorithms can execute tasks by predicting the correct result with high accuracy. diff --git a/docs/developer-docs/ai/samples.mdx b/docs/developer-docs/ai/samples.mdx index 4d546283a5..65f283425d 100644 --- a/docs/developer-docs/ai/samples.mdx +++ b/docs/developer-docs/ai/samples.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + ICP's unique ability to run compute at scale allows AI and neural networks to run directly onchain within a canister smart contract. Canisters can also interact with LLMs stored off-chain through HTTPS outcalls, or stored locally on a user's device. diff --git a/docs/developer-docs/ai/training-models.mdx b/docs/developer-docs/ai/training-models.mdx index b3ab656bbf..a02d9d137b 100644 --- a/docs/developer-docs/ai/training-models.mdx +++ b/docs/developer-docs/ai/training-models.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Training AI models on ICP provides developers with a decentralized infrastructure and simplifies the setup process. ICP’s built-in computation and storage capabilities remove the need for external hardware. With GPU support on the roadmap, ICP will soon further enhance its AI capabilities and allow developers to train complex models, including large-scale AI systems. diff --git a/docs/developer-docs/backend/rust/access-control.mdx b/docs/developer-docs/backend/rust/access-control.mdx index 6220ce6be9..fec0a2f74c 100644 --- a/docs/developer-docs/backend/rust/access-control.mdx +++ b/docs/developer-docs/backend/rust/access-control.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To demonstrate access control using a Rust backend canister, you'll explore access control in the context of NFTs. NFTs (non-fungible tokens) are unique tokens with arbitrary metadata, usually an image of some kind, to form the digital equivalent of trading cards. diff --git a/docs/developer-docs/backend/rust/candid.mdx b/docs/developer-docs/backend/rust/candid.mdx index 38003a57b6..b1ae7edbc4 100644 --- a/docs/developer-docs/backend/rust/candid.mdx +++ b/docs/developer-docs/backend/rust/candid.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Candid is an **interface description language** with the primary purpose of describing the public interface of a service. A service is usually in the form of a program deployed as a canister. Candid is language-agnostic, meaning that it allows for the inter-operation between services and frontends written in different programming languages, including Rust. diff --git a/docs/developer-docs/backend/rust/counter.mdx b/docs/developer-docs/backend/rust/counter.mdx index bfddc269a1..4bd89cd61c 100644 --- a/docs/developer-docs/backend/rust/counter.mdx +++ b/docs/developer-docs/backend/rust/counter.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + In this guide, you are going to write a dapp that provides a few basic functions to increment a counter value. by calling functions on a deployed canister. By calling the function to increment a value multiple times, you can verify that the variable state, that is, the value of the variable between calls, persists. diff --git a/docs/developer-docs/backend/rust/deploying.mdx b/docs/developer-docs/backend/rust/deploying.mdx index e372e38570..2eac673d90 100644 --- a/docs/developer-docs/backend/rust/deploying.mdx +++ b/docs/developer-docs/backend/rust/deploying.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + In this guide, you'll learn the steps required to write, compile, deploy, and interact with a Rust backend canister. diff --git a/docs/developer-docs/backend/rust/generating-candid.mdx b/docs/developer-docs/backend/rust/generating-candid.mdx index 67f1ce1b56..09ea4e6fa0 100644 --- a/docs/developer-docs/backend/rust/generating-candid.mdx +++ b/docs/developer-docs/backend/rust/generating-candid.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + In versions of the Rusk CDK `v0.11.0` and higher, the Candid export workflow has been changed. You can call the `ic_cdk::export_candid!()` macro to enable the Candid export behavior, then use the [candid-extractor](https://github.com/dfinity/cdk-rs/tree/main/src/candid-extractor) to extract the Candid from the canister's Wasm. diff --git a/docs/developer-docs/backend/rust/intercanister.mdx b/docs/developer-docs/backend/rust/intercanister.mdx index 3068125950..7def78c59d 100644 --- a/docs/developer-docs/backend/rust/intercanister.mdx +++ b/docs/developer-docs/backend/rust/intercanister.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Inter-canister calls can be used to update information between two or more canisters. diff --git a/docs/developer-docs/backend/rust/message-inspect.mdx b/docs/developer-docs/backend/rust/message-inspect.mdx index 43e792978b..86f961305f 100644 --- a/docs/developer-docs/backend/rust/message-inspect.mdx +++ b/docs/developer-docs/backend/rust/message-inspect.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A canister can inspect an ingress message and either accept or decline the message through the canister's HTTPS interface. If the message is accepted, the canister will execute it. diff --git a/docs/developer-docs/backend/rust/optimizing.mdx b/docs/developer-docs/backend/rust/optimizing.mdx index 717b9090d3..16283ceca6 100644 --- a/docs/developer-docs/backend/rust/optimizing.mdx +++ b/docs/developer-docs/backend/rust/optimizing.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Compiling Rust to Wasm often increases the file size significantly. `dfx` versions `0.14.0` and newer include the `wasm-opt` package that can be used to optimize cycle consumption and binary size. ## Prerequisites diff --git a/docs/developer-docs/backend/rust/project-organization.mdx b/docs/developer-docs/backend/rust/project-organization.mdx index b9311036bc..b2993f1307 100644 --- a/docs/developer-docs/backend/rust/project-organization.mdx +++ b/docs/developer-docs/backend/rust/project-organization.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + When a new Rust project is created with the command: diff --git a/docs/developer-docs/backend/rust/quickstart.mdx b/docs/developer-docs/backend/rust/quickstart.mdx index 2610ba7e1b..17319784c7 100644 --- a/docs/developer-docs/backend/rust/quickstart.mdx +++ b/docs/developer-docs/backend/rust/quickstart.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Applications for ICP start as **projects**. You can create new projects for ICP using the IC SDK. This guide focuses on how to create, build, and deploy a Rust program by using the `dfx` parent command and its subcommands. diff --git a/docs/developer-docs/backend/rust/rust-considerations.mdx b/docs/developer-docs/backend/rust/rust-considerations.mdx index d14fbbecca..9d7f57b190 100644 --- a/docs/developer-docs/backend/rust/rust-considerations.mdx +++ b/docs/developer-docs/backend/rust/rust-considerations.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide describes information that developers should consider when writing Rust canisters, specifically regarding canister observability and global state. diff --git a/docs/developer-docs/backend/rust/rust-limitations.mdx b/docs/developer-docs/backend/rust/rust-limitations.mdx index b03050052d..3c4ffada37 100644 --- a/docs/developer-docs/backend/rust/rust-limitations.mdx +++ b/docs/developer-docs/backend/rust/rust-limitations.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + WebAssembly (Wasm) is a binary code format and does not provide network access, a filesystem, or other functionalities other than pure computation. Anything function that needs to communicate outside of the Wasm module must use an IC API. This guide details limitations imposed by Wasm on canisters written in Rust. diff --git a/docs/developer-docs/backend/rust/searching-records.mdx b/docs/developer-docs/backend/rust/searching-records.mdx index 445f392afc..524370eb99 100644 --- a/docs/developer-docs/backend/rust/searching-records.mdx +++ b/docs/developer-docs/backend/rust/searching-records.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + In this guide, you are going to write a dapp that provides a few basic functions to add and retrieve simple profile records that consist of a name, description, and an array of keywords. This program supports the following functions: diff --git a/docs/developer-docs/backend/rust/stable-structures.mdx b/docs/developer-docs/backend/rust/stable-structures.mdx index 149fd98e65..a4a0ea603a 100644 --- a/docs/developer-docs/backend/rust/stable-structures.mdx +++ b/docs/developer-docs/backend/rust/stable-structures.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Stable structures are designed to use stable memory as the backing store, allowing them to grow to gigabytes in size without the need for `pre_upgrade`/`post_upgrade` hooks. diff --git a/docs/developer-docs/backend/rust/timers.mdx b/docs/developer-docs/backend/rust/timers.mdx index a43e1f2277..c57bbb7b69 100644 --- a/docs/developer-docs/backend/rust/timers.mdx +++ b/docs/developer-docs/backend/rust/timers.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + This guide demonstrates how to create a small dapp with a periodic task. The task is triggered automatically by the ICP network with a specified interval. ## Prerequisites diff --git a/docs/developer-docs/backend/rust/upgrading.mdx b/docs/developer-docs/backend/rust/upgrading.mdx index 62755ff301..0184e2cd6a 100644 --- a/docs/developer-docs/backend/rust/upgrading.mdx +++ b/docs/developer-docs/backend/rust/upgrading.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Unlike a canister reinstall that preserves the canister identifier but no state, a canister upgrade enables you to preserve the state of a deployed canister and change the code. diff --git a/docs/developer-docs/cost-estimations-and-examples.mdx b/docs/developer-docs/cost-estimations-and-examples.mdx index 07707f94fa..26beaa5418 100644 --- a/docs/developer-docs/cost-estimations-and-examples.mdx +++ b/docs/developer-docs/cost-estimations-and-examples.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To get a rough estimate of how much your project may cost, below is a pricing calculator that can be used to estimate the cost of a dapp deployed on ICP. Costs are charged to a canister in cycles, which are fixed against the price of [XDR](/docs/current/references/glossary#xdr), where **1 trillion cycles equals 1 XDR**. Cycles costs are calculated based on: diff --git a/docs/developer-docs/daos/nns/concepts/neurons/becoming-a-known-neuron.mdx b/docs/developer-docs/daos/nns/concepts/neurons/becoming-a-known-neuron.mdx index fb909d1a7f..3ce4d7c190 100644 --- a/docs/developer-docs/daos/nns/concepts/neurons/becoming-a-known-neuron.mdx +++ b/docs/developer-docs/daos/nns/concepts/neurons/becoming-a-known-neuron.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + A know neuron has a name and optionally a short description. A known neuron can be registered in the NNS governance via a proposal, officially storing its name and description within the NNS. This information can be used by other neurons to find known neurons and [follow](/docs/current/developer-docs/daos/nns/concepts/neurons/neuron-following) them. diff --git a/docs/developer-docs/daos/nns/concepts/neurons/neuron-following.mdx b/docs/developer-docs/daos/nns/concepts/neurons/neuron-following.mdx index cf0f160a53..7ae27b0f3e 100644 --- a/docs/developer-docs/daos/nns/concepts/neurons/neuron-following.mdx +++ b/docs/developer-docs/daos/nns/concepts/neurons/neuron-following.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Users may not have the time or knowledge to participate in all voting decisions. Therefore, instead of directly voting on proposals, neuron holders may choose to delegate their vote to other neurons that they trust with certain decisions. This concept, where a neuron follows the decisions of some other neurons, is called **following** in the NNS DAO. diff --git a/docs/developer-docs/daos/nns/concepts/neurons/neuron-management.mdx b/docs/developer-docs/daos/nns/concepts/neurons/neuron-management.mdx index 664b2a51f3..5bbd35586a 100644 --- a/docs/developer-docs/daos/nns/concepts/neurons/neuron-management.mdx +++ b/docs/developer-docs/daos/nns/concepts/neurons/neuron-management.mdx @@ -15,7 +15,7 @@ This page is for you if you want to learn the technical details about neuron ope Tutorials for users who want to interact with the NNS using the [NNS dapp](https://nns.ic0.app) frontend are available in the [NNS dapp quickguide](/docs/current/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart). -## Overview + View the most up-to-date [`candid` definition for the NNS governance canister](https://github.com/dfinity/ic/blob/master/rs/nns/governance/canister/governance.did). This page will explain some of the relevant definitions from this Candid file. To keep up to date with new NNS release proposals from DFINITY, you can subscribe to [this forum thread](https://forum.dfinity.org/t/nns-updates-aggregation-thread/23551). diff --git a/docs/developer-docs/daos/nns/concepts/neurons/staking-voting-rewards.mdx b/docs/developer-docs/daos/nns/concepts/neurons/staking-voting-rewards.mdx index e1c2e28d61..ccdbf3e5d7 100644 --- a/docs/developer-docs/daos/nns/concepts/neurons/staking-voting-rewards.mdx +++ b/docs/developer-docs/daos/nns/concepts/neurons/staking-voting-rewards.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Stakeholders gain voting power and can earn voting rewards by staking their ICP tokens in neurons and participating in governance. The Internet Computer is a decentralized platform whose evolution is decided by its stakeholders through voting. diff --git a/docs/developer-docs/daos/nns/concepts/proposals/direct-voting.mdx b/docs/developer-docs/daos/nns/concepts/proposals/direct-voting.mdx index f38809424b..d4f228f424 100644 --- a/docs/developer-docs/daos/nns/concepts/proposals/direct-voting.mdx +++ b/docs/developer-docs/daos/nns/concepts/proposals/direct-voting.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + The NNS DAO is an open governance system where anyone can become a participant by [staking some ICP in a neuron](https://internetcomputer.org/docs/current/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart#stake-icp-utility-tokens-in-a-neuron). At least 1 ICP is required to create a neuron. Locking tokens for a period of time is known as the neuron's dissolve delay. If a neuron has more than 6 months dissolve delay, it is eligible to participate in voting. This means that it can both submit and vote on proposals. diff --git a/docs/developer-docs/daos/nns/overview.mdx b/docs/developer-docs/daos/nns/overview.mdx index 977e1af59c..740621c9ae 100644 --- a/docs/developer-docs/daos/nns/overview.mdx +++ b/docs/developer-docs/daos/nns/overview.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview +

diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart.mdx index e031bad71e..3bb6c075e6 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + There are different ways to interact with the NNS DAO to participate in governance. diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-additional-features.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-additional-features.mdx index 5df6b6de9f..39becd9bd2 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-additional-features.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-additional-features.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + In addition to being the portal for interacting with the NNS DAO, the NNS dapp also provides access to the SNS DAOs, their launches, and allows users to manage canisters that they control. This is a brief guide to some of these additional functionalities. diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-advanced-neuron-operations.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-advanced-neuron-operations.mdx index 4ee772d880..d7d0938828 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-advanced-neuron-operations.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-advanced-neuron-operations.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Once you are a bit more familiar with the NNS, you might want to use the NNS dapp to perform additional neuron operations. For more background on neurons, including the concepts of voting rewards and what the different neuron operations do in details, diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-following-other-neurons.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-following-other-neurons.mdx index 486e3e0225..3ed27fba50 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-following-other-neurons.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-following-other-neurons.mdx @@ -15,7 +15,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + Neuron owners may find it hard to manually vote on every proposal submitted to the NNS. For example, they may not have the time or necessary expertise to evaluate each individual proposal. The NNS uses a form of liquid democracy to address these challenges called **following**. diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-importing-tokens.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-importing-tokens.mdx index 71a535021f..0ad634f781 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-importing-tokens.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-importing-tokens.mdx @@ -15,7 +15,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + The NNS dapp focuses on providing a simple user interface where community members can interact with different on-chain governance systems deployed on the Internet Computer. diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-making-neurons-public.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-making-neurons-public.mdx index 75f66ba2c6..65f7055a47 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-making-neurons-public.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-making-neurons-public.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Neuron visibility settings are available in order to support a [neuron index](https://dashboard.internetcomputer.org/proposal/48491) while respecting neuron holders' privacy. A neuron can be private or public. For public neurons, anyone who knows the neuron's ID can see the full neuron's details, including how they vote on proposals. [Learn more about the differences between private and public neurons](/docs/current/developer-docs/daos/nns/concepts/neurons/neuron-management#neuron-visibility). diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-manage-quill-neurons.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-manage-quill-neurons.mdx index a43ef9c84e..2b2bbad661 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-manage-quill-neurons.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-manage-quill-neurons.mdx @@ -15,7 +15,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + You may have neurons controlled by a principal ID that was created using [quill](../../../../../../docs/current/developer-docs/developer-tools/cli-tools/quill-cli-reference/quill-parent). In this case, it may be inconvenient to manage your neurons through the terminal. If you know the seed phrase of this principal ID, you can use a Ledger hardware wallet to manage your neurons through the [NNS dapp](https://nns.ic0.app/). ## How to access neurons controlled by a principal ID created with quill diff --git a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-send-and-receive-tokens.mdx b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-send-and-receive-tokens.mdx index 88e6e42f3e..c7b9b2ffdc 100644 --- a/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-send-and-receive-tokens.mdx +++ b/docs/developer-docs/daos/nns/using-the-nns-dapp/nns-dapp-send-and-receive-tokens.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + When you log into the NNS dapp for the first time you will not yet have any ICP tokens in your wallet. Therefore, you first might want transfer some tokens to the NNS dapp wallet. This also the first step required for staking a neuron with the NNS dapp. diff --git a/docs/developer-docs/daos/sns/index.mdx b/docs/developer-docs/daos/sns/index.mdx index 64f6289449..c35b0243e6 100644 --- a/docs/developer-docs/daos/sns/index.mdx +++ b/docs/developer-docs/daos/sns/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + These pages introduce instructions needed when considering handing over control of a dapp to a Service Nervous System (SNS) or integrating with an SNS. If this is the first time you hear about the SNS, it is recommended to take a look at the high level [SNS](/sns) diff --git a/docs/developer-docs/daos/sns/launching/integrating.mdx b/docs/developer-docs/daos/sns/launching/integrating.mdx index 7cad7720ff..74fd75ca09 100644 --- a/docs/developer-docs/daos/sns/launching/integrating.mdx +++ b/docs/developer-docs/daos/sns/launching/integrating.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + When planning an SNS launch, one topic to consider is whether and how the SNS functionality should be integrated in the dapp. For example, one may want to embed a frontend for the SNS swap or for the SNS governance in the dapp's UI. diff --git a/docs/developer-docs/daos/sns/launching/launch-steps-1proposal.mdx b/docs/developer-docs/daos/sns/launching/launch-steps-1proposal.mdx index 0f0adbf923..5a267c9baf 100644 --- a/docs/developer-docs/daos/sns/launching/launch-steps-1proposal.mdx +++ b/docs/developer-docs/daos/sns/launching/launch-steps-1proposal.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + At a high level, the stages for launching an SNS in production are explained [here](../launching/launch-summary-1proposal.mdx). diff --git a/docs/developer-docs/daos/sns/launching/launch-summary-1proposal.mdx b/docs/developer-docs/daos/sns/launching/launch-summary-1proposal.mdx index c4a0b8ee93..4f08219e3b 100644 --- a/docs/developer-docs/daos/sns/launching/launch-summary-1proposal.mdx +++ b/docs/developer-docs/daos/sns/launching/launch-summary-1proposal.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + During an SNS launch, a dapp is handed over to the NNS and the NNS both creates the SNS canisters and starts a decentralization swap to decentralize the SNS and thereby the dapp. diff --git a/docs/developer-docs/daos/sns/managing/cycles-usage.mdx b/docs/developer-docs/daos/sns/managing/cycles-usage.mdx index e690f7ed9e..b8d2f937c5 100644 --- a/docs/developer-docs/daos/sns/managing/cycles-usage.mdx +++ b/docs/developer-docs/daos/sns/managing/cycles-usage.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + :::caution An SNS community must ensure that all SNS and dapp canisters have sufficient cycles by manually sending cycles when necessary to diff --git a/docs/developer-docs/daos/sns/managing/making-proposals.mdx b/docs/developer-docs/daos/sns/managing/making-proposals.mdx index a150aeb5cb..e3d3312474 100644 --- a/docs/developer-docs/daos/sns/managing/making-proposals.mdx +++ b/docs/developer-docs/daos/sns/managing/making-proposals.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To manage an SNS, the SNS community needs to understand how proposals work, how they can be submitted, voted on, and what effect they have. diff --git a/docs/developer-docs/daos/sns/managing/manage-sns-intro.mdx b/docs/developer-docs/daos/sns/managing/manage-sns-intro.mdx index f8bf013e45..645d0ff379 100644 --- a/docs/developer-docs/daos/sns/managing/manage-sns-intro.mdx +++ b/docs/developer-docs/daos/sns/managing/manage-sns-intro.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + SNSs are protocol-provided DAOs on ICP that are to some extent maintained by the NNS community, who for example approve new upgrades of SNS canister code. This eliminates much of the maintenance burden from the SNS communities. diff --git a/docs/developer-docs/daos/sns/managing/managing-nervous-system-parameters.mdx b/docs/developer-docs/daos/sns/managing/managing-nervous-system-parameters.mdx index af1a2b9f35..609982f2fc 100644 --- a/docs/developer-docs/daos/sns/managing/managing-nervous-system-parameters.mdx +++ b/docs/developer-docs/daos/sns/managing/managing-nervous-system-parameters.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The nervous system parameters define the settings of a particular SNS. diff --git a/docs/developer-docs/daos/sns/managing/sns-asset-canister.mdx b/docs/developer-docs/daos/sns/managing/sns-asset-canister.mdx index 4cd6eb69ea..3103de6511 100644 --- a/docs/developer-docs/daos/sns/managing/sns-asset-canister.mdx +++ b/docs/developer-docs/daos/sns/managing/sns-asset-canister.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The [asset canister](https://github.com/dfinity/sdk/tree/master/src/canisters/frontend/ic-frontend-canister) provides users with a way to store and retrieve static assets from a canister deployed on ICP. Generally, asset canisters are used to serve HTML, CSS, or JavaScript assets, which are typically part of a dapp's frontend. For this reason, the asset canister is also referred to as the frontend canister. For purposes of this guide, it will be referred to as the asset canister. diff --git a/docs/developer-docs/daos/sns/testing/testing-locally.mdx b/docs/developer-docs/daos/sns/testing/testing-locally.mdx index c10f7adfa7..d689e3416a 100644 --- a/docs/developer-docs/daos/sns/testing/testing-locally.mdx +++ b/docs/developer-docs/daos/sns/testing/testing-locally.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To help developers, DFINITY has created the [sns-testing repo](https://github.com/dfinity/sns-testing) which has scripts that help developers test the SNS process. Developers can run a local version of the ICP execution environment on their local machine, deploy their dapp locally and run through [the stages](../launching/launch-summary-1proposal.mdx) of decentralizing their dapp. diff --git a/docs/developer-docs/daos/sns/testing/testing-on-mainnet.mdx b/docs/developer-docs/daos/sns/testing/testing-on-mainnet.mdx index ebd9160026..856eb3e47c 100644 --- a/docs/developer-docs/daos/sns/testing/testing-on-mainnet.mdx +++ b/docs/developer-docs/daos/sns/testing/testing-on-mainnet.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Once a developer has tested the process of an SNS, it is highly recommended they do an **"SNS testflight" [on the mainnet](./testing-on-mainnet.mdx)**. An SNS testflight is when a developer deploys their dapp (to the mainnet) and hands control of it to a mock SNS (on the mainnet). diff --git a/docs/developer-docs/daos/sns/tokenomics/index.mdx b/docs/developer-docs/daos/sns/tokenomics/index.mdx index 3893719c98..57c6bb184b 100644 --- a/docs/developer-docs/daos/sns/tokenomics/index.mdx +++ b/docs/developer-docs/daos/sns/tokenomics/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Launching an SNS entails many non-technical and technical preparations steps. [The SNS launch checklist](sns-checklist.mdx) summarizes some of the most important preparation diff --git a/docs/developer-docs/daos/sns/tokenomics/predeployment-considerations.mdx b/docs/developer-docs/daos/sns/tokenomics/predeployment-considerations.mdx index 2b3cee79f4..8cd0402d64 100644 --- a/docs/developer-docs/daos/sns/tokenomics/predeployment-considerations.mdx +++ b/docs/developer-docs/daos/sns/tokenomics/predeployment-considerations.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Preparing an SNS launch includes many non-technical considerations. For example, to decentralize a dapp, the governance control has to be distributed diff --git a/docs/developer-docs/daos/sns/tokenomics/preparation.mdx b/docs/developer-docs/daos/sns/tokenomics/preparation.mdx index ba7b1ce15d..0c3bb39c46 100644 --- a/docs/developer-docs/daos/sns/tokenomics/preparation.mdx +++ b/docs/developer-docs/daos/sns/tokenomics/preparation.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Typically, one would first decide on tokenomics and other configurations, for examples using the [SNS tokenomics training & tools](https://wiki.internetcomputer.org/wiki/How-To:_SNS_tokenomics_configuration) diff --git a/docs/developer-docs/defi/cycles/converting_icp_tokens_into_cycles.mdx b/docs/developer-docs/defi/cycles/converting_icp_tokens_into_cycles.mdx index 3e297f813d..91877872c3 100644 --- a/docs/developer-docs/defi/cycles/converting_icp_tokens_into_cycles.mdx +++ b/docs/developer-docs/defi/cycles/converting_icp_tokens_into_cycles.mdx @@ -11,7 +11,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + To convert ICP tokens into cycles, you first need to obtain some ICP and transfer to the right account. You can get ICP tokens on exchanges, or ask someone you know to send you some. To figure out which account to transfer the ICP tokens to, run the following: ``` bash diff --git a/docs/developer-docs/defi/cycles/cycles-ledger.mdx b/docs/developer-docs/defi/cycles/cycles-ledger.mdx index e0f999489c..229c885a98 100644 --- a/docs/developer-docs/defi/cycles/cycles-ledger.mdx +++ b/docs/developer-docs/defi/cycles/cycles-ledger.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + When developing and deploying canisters on the Internet Computer, developers need to have cycles to pay for the resources used by their canisters. The **cycles ledger** canister has been developed as an alternative to the **cycles wallet** canister for cycles management. diff --git a/docs/developer-docs/defi/cycles/cycles-wallet.mdx b/docs/developer-docs/defi/cycles/cycles-wallet.mdx index 87a85fc74d..b090efca67 100644 --- a/docs/developer-docs/defi/cycles/cycles-wallet.mdx +++ b/docs/developer-docs/defi/cycles/cycles-wallet.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + As discussed in [tokens and cycles](/docs/current/developer-docs/getting-started/tokens-and-cycles), ICP tokens can be converted into **cycles** to power canister operations. Cycles reflect the operational cost of communication, computation, and storage that dapps consume. diff --git a/docs/developer-docs/defi/exchange-rate-canister.mdx b/docs/developer-docs/defi/exchange-rate-canister.mdx index d927cacba5..f229fe57f4 100644 --- a/docs/developer-docs/defi/exchange-rate-canister.mdx +++ b/docs/developer-docs/defi/exchange-rate-canister.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The exchange rate canister, referred to as the XRC, is a canister that runs on the **uzr34 system subnet**. The XRC uses [HTTPS outcalls](https://internetcomputer.org/https-outcalls/) to fetch data from major cryptocurrency exchanges by using the exchange's public API to retrieve real time or historical cryptocurrency pricing information. The XRC also queries the public APIs for foreign exchange data providers around the world periodically in order to get forex rates. diff --git a/docs/developer-docs/defi/icp-tokens/account-trimming.mdx b/docs/developer-docs/defi/icp-tokens/account-trimming.mdx index 8dbace8a12..e818485f09 100644 --- a/docs/developer-docs/defi/icp-tokens/account-trimming.mdx +++ b/docs/developer-docs/defi/icp-tokens/account-trimming.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Even if the ledger can index a large number of accounts, it has a finite capacity. To avoid saturation and maintain good performance, some accounts are trimmed if the ledger capacity is reaching a threshold. diff --git a/docs/developer-docs/defi/nfts/marketplaces.mdx b/docs/developer-docs/defi/nfts/marketplaces.mdx index 1668efe77f..48dfc204c7 100644 --- a/docs/developer-docs/defi/nfts/marketplaces.mdx +++ b/docs/developer-docs/defi/nfts/marketplaces.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + An NFT marketplace is a dapp used to mint, buy, sell, and trade NFTs. An NFT listed on a marketplace may be part of a large collection, or it may be a one-of-a-kind token. diff --git a/docs/developer-docs/defi/nfts/nft-collections.mdx b/docs/developer-docs/defi/nfts/nft-collections.mdx index 5221c6168c..a7532da87d 100644 --- a/docs/developer-docs/defi/nfts/nft-collections.mdx +++ b/docs/developer-docs/defi/nfts/nft-collections.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + An NFT collection is a series of non-fungible tokens that each have a unique identifier value. Each token's metadata may be the same, such as the name, image, and description, or each token's data can be unique and associated with a 'rarity' value, where some metadata values are less common than others. Rarity metadata attributes are common in generative NFT collections, often referring to an NFT collection where the artwork for each image has been randomly generated and some components only appear in a select few of the generated images. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/index.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/index.mdx index 44e9b6a572..bb0cf4c966 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/index.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will give you an overview of how you can make transactions via Rosetta using the construction API. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/combine.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/combine.mdx index f187db0660..d243ffc9d7 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/combine.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/combine.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section details how to call the `construction/combine` endpoint of the Rosetta construction API. The request and response types can be found in the [official documentation](https://docs.cdp.coinbase.com/mesh/reference/constructioncombine). diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/derive.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/derive.mdx index bfce2cbe33..1d5bd72e4a 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/derive.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/derive.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section details how to derive an ICP adress using the Rosetta construction API. The ICP ledger is using `accountidentifiers` to represent public keys internally. To derive an `accountidentifier` from a public key the Rosetta API offers the `construction/derive` endpoint. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/index.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/index.mdx index 34588637e8..3403168a8e 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/index.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/index.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; # Flow of operations -## Overview + This section will give you an overview of how the flow of operations in the construction API works. It will guide you through each of the necessary endpoints that you will have to call in order to post a valid transaction with your signature to the ICP ledger. As an example of such a transaction this guide will use a simple transfer between accounts. It is recommended to first read through the interactions of each endpoint to acquire an understanding of how the flow of operations works. Although the example of transferring tokens is only one use case of the construction API of Rosetta, it serves as a good example on what to expect from the interaction with the Construction-API. The other functionalities that are supported by ICP Rosetta through the construction API follow a similar flow of operations. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/metadata.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/metadata.mdx index fd32ac9d2d..e66c154d46 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/metadata.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/metadata.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section details how to call the `construction/metadata` endpoint of the Rosetta construction API. The request and response types can be found in the [official documentation](https://docs.cdp.coinbase.com/rosetta/reference/constructionmetadata). diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/payloads.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/payloads.mdx index 9cf32167b4..1054fac4ad 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/payloads.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/payloads.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section details how to call the `construction/payloads` endpoint of the Rosetta construction API. The request and response types can be found in the [official documentation](https://docs.cdp.coinbase.com/mesh/reference/constructionpayloads). diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/preprocess.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/preprocess.mdx index 32edf9451a..a54445bff8 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/preprocess.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/preprocess.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section details how to call the `construction/preprocess` endpoint of the Rosetta construction API. Preprocess is called prior to `/construction/payloads` to construct a request for any metadata that is needed for transaction construction. The ICP Rosetta implementation will return the required list of public keys that has to be provided by the user and in the metadata it returns the request type that is associated with the given set of operations. The metadata returned from this endpoint will be sent to the `/construction/metadata` endpoint UNMODIFIED by the caller (in an offline execution environment). diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/submit.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/submit.mdx index 8acd3a81b6..b73d28b518 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/submit.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/submit.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section details how to call the `construction/submit` endpoint of the Rosetta construction API. The request and response types can be found in the [official documentation](https://docs.cdp.coinbase.com/mesh/reference/constructionsubmit). The endpoint sends to transactions to the IC. The first being the `Call Request` which contains the information of what submit, which canister, what function in the canister and with what arguments should be called. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/change_auto_stake_maturity.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/change_auto_stake_maturity.mdx index 4960214427..2b09e8c055 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/change_auto_stake_maturity.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/change_auto_stake_maturity.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|--------| | Since version | 1.7.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/derive_neuron_id.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/derive_neuron_id.mdx index 5a5d191ed7..7f8658201f 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/derive_neuron_id.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/derive_neuron_id.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |---------------|-------| diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/disburse.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/disburse.mdx index 87fb2d7a2c..e259f5b653 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/disburse.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/disburse.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|--------| | Since version | 1.4.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/dissolve.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/dissolve.mdx index f26bd609c9..08bd401ed7 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/dissolve.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/dissolve.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|------------| | Since version | 1.1.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/hotkeys.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/hotkeys.mdx index f0f8e39375..2afd0c5335 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/hotkeys.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/hotkeys.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will explain how to generate a hotkey for neuron management and add or remove hotkeys to your neuron using ICP Rosetta. The recommended way to get hotkeys is to programmatically generate them using the same process used in the public `ic` repository. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/index.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/index.mdx index f3ad3dbc0a..8f0503ebb1 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/index.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will give you an overview of how how ICP staking on the Internet Computer using Rosetta works. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/lock_neuron.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/lock_neuron.mdx index 4d6aefb5cd..425cd91928 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/lock_neuron.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/lock_neuron.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|------------| | Since version | 1.1.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/neuron_info.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/neuron_info.mdx index bbd754d1b6..c3de3c3895 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/neuron_info.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/neuron_info.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|--------| | Since version | 1.5.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/spawn.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/spawn.mdx index 8f5a2ab87e..cc9ef429ae 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/spawn.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/spawn.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|------------| | Since version | 1.3.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_icp.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_icp.mdx index 7d0c147bfa..ed4b016813 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_icp.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_icp.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |---------------|-------| | Since version | 1.5.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_maturity.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_maturity.mdx index 9ce5651750..b78b069d89 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_maturity.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/staking/stake_maturity.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|------------| | Since version | 1.4.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/follow.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/follow.mdx index 2e5272c9ca..9ad9693c68 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/follow.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/follow.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|------------| | Since version | 1.5.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/index.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/index.mdx index 893f8dcf6e..5b73531469 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/index.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will give you an overview of how to vote on NNS proposals using Rosetta. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/vote.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/vote.mdx index c6a752ace5..9bf836cb6b 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/vote.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/voting/vote.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + | | | |----------------------|--------| | Since version | 1.7.0 | diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/balances.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/balances.mdx index d4e2be420b..a6f4ad0ffa 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/balances.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/balances.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This endpoint allows you to fetch the balances for a certain account. It is the implementation of the [/account/balance endpoint](https://www.rosetta-api.org/docs/AccountApi.html#accountbalance) of the Rosetta API standard. ### Prerequisites diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/blocks.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/blocks.mdx index 2e953bc8f3..b6c16891d0 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/blocks.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/blocks.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This endpoint allows you to fetch blocks at a certain block height. It is the implementation of the [/block endpoint](https://docs.cdp.coinbase.com/mesh/reference/block) of the Rosetta API standard. ### Prerequisites diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_pending_proposals.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_pending_proposals.mdx index fe9296ee38..83c4fdee1f 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_pending_proposals.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_pending_proposals.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This endpoint allows you to fetch all pending proposals from the NNS. It is the implementation of the [/call endpoint](https://docs.cdp.coinbase.com/mesh/reference/call) of the Rosetta API standard. The call endpoint is very flexible as to what it can be used for. In the case of ICP Rosetta it is used to fetch various custom information that is not covered by the Rosetta API standard. ### Prerequisites diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_proposal_info.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_proposal_info.mdx index aaefc01510..f420e7ead1 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_proposal_info.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/get_proposal_info.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This endpoint allows you to fetch more detailed information about a specific proposal from the NNS. It is the implementation of the [/call endpoint](https://docs.cdp.coinbase.com/mesh/reference//call) of the Rosetta API standard. The call endpoint is very flexible as to what it can be used for. In the case of ICP Rosetta it is used to fetch various custom information that is not covered by the Rosetta API standard. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/index.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/index.mdx index 296a3d5751..1f9524028a 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/index.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will give you an overview of what data can be fetched from the data API endpoints for the ICP Rosetta implementation. diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/list_known_neurons.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/list_known_neurons.mdx index d6589cc17c..3e1e9418cd 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/list_known_neurons.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/list_known_neurons.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This endpoint allows you to fetch all neurons from the NNS that are publicly known. It is the implementation of the [/call endpoint](https://docs.cdp.coinbase.com/mesh/reference/call) of the Rosetta API standard. The call endpoint is very flexible as to what it can be used for. In the case of ICP Rosetta it is used to fetch various custom information that is not covered by the Rosetta API standard. ### Prerequisites diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/network.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/network.mdx index 0f3f5879ee..7191446987 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/network.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/network.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + For most endpoints you will require some information about the network represented as a [NetworkIdentifier](https://www.rosetta-api.org/docs/models/NetworkIdentifier.html). diff --git a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/transactions.mdx b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/transactions.mdx index acf376c491..dd035ccd8e 100644 --- a/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/transactions.mdx +++ b/docs/developer-docs/defi/rosetta/icp_rosetta/data_api/transactions.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There exist two different entpoints that allow for querying of transaction. This endpoint allows you to fetch a transaction at a certain block height. It is the implementation of the [/block/transaction endpoint](https://docs.cdp.coinbase.com/mesh/reference/blocktransaction) of the Rosetta API standard. The `search_transactions` endpoint allows you to query for transactions given a set of parameters. It is the implementation of the [/search/transactions endpoint](https://docs.cdp.coinbase.com/mesh/reference/searchtransactions/) diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/approve.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/approve.mdx index c9ac7b5f5a..bcfb5143cf 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/approve.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/approve.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will show you how to use the ICRC Rosetta implementation to authorize a spender to spend your ICRC-1 tokens. Make sure you are familiar with the [flow of operations](/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/index.mdx) for Rosetta. The request types used for making direct transfers are `APPROVE` and `SPENDER`. They consist of two operations, one for the the approve operation and another for the spender operation. diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/index.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/index.mdx index e33894c31b..55eaee69f2 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/index.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section will give you an overview on what types of asset transfers are supported by ICRC Rosetta and how to use them. It is divided in the following topics: diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/transfer.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/transfer.mdx index 58557a377f..2b9f07588f 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/transfer.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/asset_transfer/transfer.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The request type that is used for making direct transfers is `TRANSFER`. In the simplest form it consists of two operations, one for the debit operation and one for the credit operation. diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/index.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/index.mdx index 0f3a511218..75cad51ffe 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/index.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/construction_api/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The construction API allows for offline signing of transactions and then posting them on ICP at a later point in time. It is recommended to first go through [flow of operations](/docs/developer-docs/defi/rosetta/icp_rosetta/construction_api/operations_flow/index.mdx) of the construction API to gain an understanding of how it works, what endpoints to call with what parameters, and where the user has to take action upon receiving certain responses. diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/balances.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/balances.mdx index 27b0f1bd4f..4a6653b8a9 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/balances.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/balances.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The `account_balance` endpoint allows you to fetch the balances for a certain account. It is the implementation of the [/account/balance endpoint](https://www.rosetta-api.org/docs/AccountApi.html#accountbalance) of the Rosetta API standard. diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/blocks.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/blocks.mdx index b1bc114a92..896d891e38 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/blocks.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/blocks.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; # Fetch blocks -## Overview + The `block` endpoint allows you to fetch blocks at a certain block height. It is the implementation of the [/block endpoint](https://docs.cdp.coinbase.com/mesh/reference/block) of the Rosetta API standard. ### Prerequisites diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/index.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/index.mdx index 6e6cd474fa..8e60a7853d 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/index.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The following data can be fetched from the data API endpoints for the ICRC Rosetta implementation: - [Network](/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/network.mdx): Fetch network specific information, such as the most recent block and what network Rosetta is connected to. diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/network.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/network.mdx index 0090db1f9f..fa3d48d454 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/network.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/network.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Most endpoints require some information about the network represented as a [`NetworkIdentifier`](https://www.rosetta-api.org/docs/models/NetworkIdentifier.html). diff --git a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/transactions.mdx b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/transactions.mdx index 549611e566..3b788eff95 100644 --- a/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/transactions.mdx +++ b/docs/developer-docs/defi/rosetta/icrc_rosetta/data_api/transactions.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are two endpoints that allow for querying transactions. The `block_transaction` endpoint allows you to fetch a transaction at a certain block height. It is the implementation of the [/block/transaction endpoint](https://docs.cdp.coinbase.com/mesh/reference/blocktransaction) of the Rosetta API standard. The `search_transactions` endpoint allows you to query for transactions given a set of parameters. It is the implementation of the [/search/transactions endpoint](https://docs.cdp.coinbase.com/mesh/reference/searchtransactions/). diff --git a/docs/developer-docs/defi/rosetta/overview.mdx b/docs/developer-docs/defi/rosetta/overview.mdx index 9ca9b9befe..fbdbe62d57 100644 --- a/docs/developer-docs/defi/rosetta/overview.mdx +++ b/docs/developer-docs/defi/rosetta/overview.mdx @@ -5,7 +5,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; # Rosetta -## Overview + [Rosetta](https://www.rosetta-api.org/) is an open standard introduced by Coinbase to simplify the integration of blockchain-based tokens in exchanges, block explorers, and wallets. This documentation might help if you want to deploy a token on ICP that aims to be tradable on CeFi exchanges or if you are working on a block explorer or wallet. diff --git a/docs/developer-docs/defi/tokens/create.mdx b/docs/developer-docs/defi/tokens/create.mdx index 9c6ee45ca6..5b974722e8 100644 --- a/docs/developer-docs/defi/tokens/create.mdx +++ b/docs/developer-docs/defi/tokens/create.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Custom tokens can be created and deployed on ICP using the [ICRC-1](https://github.com/dfinity/ICRC-1/tree/main/standards/ICRC-1) or [ICRC-2](https://github.com/dfinity/ICRC-1/tree/main/standards/ICRC-2) token standards. diff --git a/docs/developer-docs/defi/tokens/indexes.mdx b/docs/developer-docs/defi/tokens/indexes.mdx index b77d1ed0c3..d66ed98cc2 100644 --- a/docs/developer-docs/defi/tokens/indexes.mdx +++ b/docs/developer-docs/defi/tokens/indexes.mdx @@ -12,7 +12,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + On ICP, an index canister is used in conjunction with a ledger canister to provide the ability for transactions to be queried for a specific account. Without an index canister, a ledger's transaction history cannot easily be parsed and used by applications, as the entire transaction history of a ledger would need to be processed. diff --git a/docs/developer-docs/defi/tokens/ledger/setup/icp_ledger_setup.mdx b/docs/developer-docs/defi/tokens/ledger/setup/icp_ledger_setup.mdx index 21cca18718..3309978f39 100644 --- a/docs/developer-docs/defi/tokens/ledger/setup/icp_ledger_setup.mdx +++ b/docs/developer-docs/defi/tokens/ledger/setup/icp_ledger_setup.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The Internet Computer Protocol (ICP) implements management of its utility token (ticker "ICP") using a specialized canister, called the **ICP ledger canister**. It is a single ledger canister that runs alongside other canisters on a special subnet of the Internet Computer - the NNS subnet. The ICP ledger canister is a smart contract that holds **blocks**, each containing a single transaction. diff --git a/docs/developer-docs/defi/tokens/ledger/setup/icrc1_ledger_setup.mdx b/docs/developer-docs/defi/tokens/ledger/setup/icrc1_ledger_setup.mdx index 19b9dfc9a6..d0692d5268 100644 --- a/docs/developer-docs/defi/tokens/ledger/setup/icrc1_ledger_setup.mdx +++ b/docs/developer-docs/defi/tokens/ledger/setup/icrc1_ledger_setup.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide will show you how to deploy an ICRC-1 ledger locally and on the mainnet. ICRC-1 is a [token standard](https://github.com/dfinity/ICRC-1). Thus, deploying a new token that is ICRC-1-compatible is synonymous with deploying an ICRC-1 ledger. The ICRC-1 ledger used in this guide is a reference implementation. This guide aims at showing you how to setup an existing ICRC-1 ledger implementation rather than how to build an ICRC-1 ledger yourself. diff --git a/docs/developer-docs/defi/tokens/ledger/usage/icp_ledger_usage.mdx b/docs/developer-docs/defi/tokens/ledger/usage/icp_ledger_usage.mdx index b79423601f..58fa95467d 100644 --- a/docs/developer-docs/defi/tokens/ledger/usage/icp_ledger_usage.mdx +++ b/docs/developer-docs/defi/tokens/ledger/usage/icp_ledger_usage.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are multiple ways to interact with the ICP ledger. They depend on whether you want to interact with the ICP ledger on mainnet, the `dfx ledger` default ICP ledger on a local network, or whether you have deployed your own local ledger version. Also, how you interact with the ICP ledger is dependent on whether you want to interact with it from the command line, from your web app, or from another canister. This guide will discuss the different ways to interact with the ICP ledger. In this guide, the following workflows will be covered: diff --git a/docs/developer-docs/defi/tokens/ledger/usage/icrc1_ledger_usage.mdx b/docs/developer-docs/defi/tokens/ledger/usage/icrc1_ledger_usage.mdx index f631ef6c69..e0fdda2854 100644 --- a/docs/developer-docs/defi/tokens/ledger/usage/icrc1_ledger_usage.mdx +++ b/docs/developer-docs/defi/tokens/ledger/usage/icrc1_ledger_usage.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are two main ways to interact with an ICRC-1 ledger. - `dfx canister`: The generic canister call from `dfx`. - `ic-cdk`: Inter-canister calls for the ICRC-1 ledger. diff --git a/docs/developer-docs/defi/tokens/token-standards.mdx b/docs/developer-docs/defi/tokens/token-standards.mdx index da584fea88..d93cb5ead8 100644 --- a/docs/developer-docs/defi/tokens/token-standards.mdx +++ b/docs/developer-docs/defi/tokens/token-standards.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Tokens deployed on ICP must adhere to a standard. The network's native token, ICP, adheres to its own standard as it is unique on the network in the sense that it is used for network utility and governance. Tokens created for other purposes on the network typically adhere to one of the ICRC standards. diff --git a/docs/developer-docs/defi/wallets/self-custody/hardware-wallet-cli.mdx b/docs/developer-docs/defi/wallets/self-custody/hardware-wallet-cli.mdx index 477f38ae37..2527bd07ce 100644 --- a/docs/developer-docs/defi/wallets/self-custody/hardware-wallet-cli.mdx +++ b/docs/developer-docs/defi/wallets/self-custody/hardware-wallet-cli.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A hardware wallet is a physical ledger device that is used to store assets. Hardware wallets are protected by a seed phase, similar to software wallets, but they can be disconnected from the internet whenever they are ejected from your computer. diff --git a/docs/developer-docs/defi/wallets/self-custody/self-custody-quickstart.mdx b/docs/developer-docs/defi/wallets/self-custody/self-custody-quickstart.mdx index bb9338257a..495ecb403d 100644 --- a/docs/developer-docs/defi/wallets/self-custody/self-custody-quickstart.mdx +++ b/docs/developer-docs/defi/wallets/self-custody/self-custody-quickstart.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Within the Internet Computer ecosystem, ICP tokens the network's native utility token and are used in both the governance and economics of the network. This self-custody guide scenario assumes: diff --git a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/check-chunk-store.mdx b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/check-chunk-store.mdx index bd468fe91f..02d3574220 100644 --- a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/check-chunk-store.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/check-chunk-store.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A canister's chunk store must be empty before a Wasm module can be installed in the canister. diff --git a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/dfx-migration.mdx b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/dfx-migration.mdx index e4e2383429..8c59cf17c5 100644 --- a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/dfx-migration.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/dfx-migration.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + `dfxvm` is a new tool used for installing and managing different versions of `dfx`. In `dfx` versions 0.17.0 and newer, `dfxvm` is used to install and update `dfx`. This means CI jobs that install `dfx` will need to update their workflow. diff --git a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/init-args.mdx b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/init-args.mdx index ee7aff1387..303fd7bd2a 100644 --- a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/init-args.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/init-args.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + When installing a canister's code, it may require Candid initialization arguments to be passed with the `dfx canister install` command. Initialization arguments are initial configuration parameters that the canister's installation expects in order to install the code correctly. One example of a canister that requires these Candid initialization arguments is the [ICP ledger canister](/docs/developer-docs/defi/tokens/ledger/setup/icp_ledger_setup.mdx). diff --git a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/networks-json.mdx b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/networks-json.mdx index 35ff6589a3..67f97dc149 100644 --- a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/networks-json.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/networks-json.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + When developing multiple projects simultaneously, it can be beneficial to deploy each project to a different local network for simplicity or to support different development workflows. Custom networks can be configured with `dfx` at both the system-wide and project-specific levels. diff --git a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/specifying-replica-version.mdx b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/specifying-replica-version.mdx index 6ea2e4911f..a8111425e6 100644 --- a/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/specifying-replica-version.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/advanced-dfx/specifying-replica-version.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The replica version included in the most recent release of `dfx` may not reflect the most up to date replica release. In some workflows, such as testing new features of the replica, having the most recent version of the replica may be desirable. diff --git a/docs/developer-docs/developer-tools/cli-tools/dfx-json-reference.mdx b/docs/developer-docs/developer-tools/cli-tools/dfx-json-reference.mdx index 261fab6d26..a83420a877 100644 --- a/docs/developer-docs/developer-tools/cli-tools/dfx-json-reference.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/dfx-json-reference.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This is the schema reference for `dfx.json` in [JSON Schema](https://json-schema.org) format. diff --git a/docs/developer-docs/developer-tools/cli-tools/dfx-json.mdx b/docs/developer-docs/developer-tools/cli-tools/dfx-json.mdx index 1aa03f716a..4cac13434f 100644 --- a/docs/developer-docs/developer-tools/cli-tools/dfx-json.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/dfx-json.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Every project created and deployed with `dfx` requires a `dfx.json` file to be present in the project's root directory. The `dfx.json` file configures the project's settings such as the canisters in the project, their name, type, and source file, default project build settings, and other configuration parameters such as Wasm optimizations. This page will detail some of the most common configuration options. For a full list of the possible configuration settings in `dfx.json`, view the [`dfx.json` schema](/docs/current/developer-docs/developer-tools/cli-tools/dfx-json-reference). diff --git a/docs/developer-docs/developer-tools/cli-tools/idl2json.mdx b/docs/developer-docs/developer-tools/cli-tools/idl2json.mdx index 1c3510d08a..af541dc789 100644 --- a/docs/developer-docs/developer-tools/cli-tools/idl2json.mdx +++ b/docs/developer-docs/developer-tools/cli-tools/idl2json.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + [`idl2json`](https://github.com/dfinity/idl2json/tree/main) is a command-line tool used to translate [Candid](https://github.com/dfinity/candid) textual values from `stdin` into JSON values outputted in `stdout`. diff --git a/docs/developer-docs/developer-tools/dev-tools-overview.mdx b/docs/developer-docs/developer-tools/dev-tools-overview.mdx index 9f85247401..d73b3e01c2 100644 --- a/docs/developer-docs/developer-tools/dev-tools-overview.mdx +++ b/docs/developer-docs/developer-tools/dev-tools-overview.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Developer tools are used to create, manage, and interact with canisters. They can come in several formats, such as command line tools, onchain and off-chain libraries, and integrated development environments. For ICP developers, there are tools within each of these categories available for you to utilize when developing your ICP canisters. diff --git a/docs/developer-docs/developer-tools/ide/codespaces.mdx b/docs/developer-docs/developer-tools/ide/codespaces.mdx index 512bb6e828..5f8643ae45 100644 --- a/docs/developer-docs/developer-tools/ide/codespaces.mdx +++ b/docs/developer-docs/developer-tools/ide/codespaces.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + GitHub Codespaces is a web-based cloud development environment that provides a platform for developing and deploying code without downloading any necessary tools or packages. GitHub Codespaces can be configured with a local ICP developer environment, including `dfx` and an instance of the ICP replica, to support canister development. diff --git a/docs/developer-docs/developer-tools/ide/dev-containers.mdx b/docs/developer-docs/developer-tools/ide/dev-containers.mdx index df63d12a89..75f7d67252 100644 --- a/docs/developer-docs/developer-tools/ide/dev-containers.mdx +++ b/docs/developer-docs/developer-tools/ide/dev-containers.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Developer containers are a local development option that uses [Docker](https://www.docker.com/get-started/) and [VS Code](https://code.visualstudio.com/) to run local containerized environments. Containers are isolated from the rest of your local environment, and files within a container cannot be used by applications outside of the container unless explicitly mounted and given access. Developer containers are a good option for developers on Windows systems, since `dfx` is not natively supported for local development on Windows. diff --git a/docs/developer-docs/developer-tools/ide/gitpod.mdx b/docs/developer-docs/developer-tools/ide/gitpod.mdx index 42f512d223..8d50c5c768 100644 --- a/docs/developer-docs/developer-tools/ide/gitpod.mdx +++ b/docs/developer-docs/developer-tools/ide/gitpod.mdx @@ -11,7 +11,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Gitpod is a web-based cloud development environment that provides a platform for developing and deploying code without downloading any necessary tools or packages. Gitpod can be configured with a local ICP developer environment, including `dfx` and an instance of the ICP replica, to support canister development. diff --git a/docs/developer-docs/developer-tools/ide/icp-ninja.mdx b/docs/developer-docs/developer-tools/ide/icp-ninja.mdx index 6d4658bfed..5d21ce68d2 100644 --- a/docs/developer-docs/developer-tools/ide/icp-ninja.mdx +++ b/docs/developer-docs/developer-tools/ide/icp-ninja.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + [ICP Ninja](https://icp.ninja/) is a web-based code editor and deployment environment for ICP canister smart contracts. Users can choose from a gallery of example projects, then edit and deploy the project directly to ICP without downloading `dfx` or obtaining cycles. Projects will be live for 20 minutes unless redeployed. The deployment timer resets on each deployment. diff --git a/docs/developer-docs/developer-tools/ide/playground.mdx b/docs/developer-docs/developer-tools/ide/playground.mdx index 22aebd7f8b..deddb9a878 100644 --- a/docs/developer-docs/developer-tools/ide/playground.mdx +++ b/docs/developer-docs/developer-tools/ide/playground.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Deploying a canister to the playground is ICP's equivalent of deploying to a testnet network. It can be used through `dfx` using the `--network playground` flag, however the playground is also available through a frontend canister, which can be accessed at the following public URL: diff --git a/docs/developer-docs/developer-tools/ide/vs-code.mdx b/docs/developer-docs/developer-tools/ide/vs-code.mdx index 0e8fc10015..b6ca607c1e 100644 --- a/docs/developer-docs/developer-tools/ide/vs-code.mdx +++ b/docs/developer-docs/developer-tools/ide/vs-code.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Visual Studio (VS) Code is a [widely used](https://survey.stackoverflow.co/2022/#section-worked-with-vs-want-to-work-with-integrated-development-environment) open-source IDE which supports canister development in [Motoko](/docs/current/motoko/main/getting-started/motoko-introduction) and [Rust](https://www.rust-lang.org/). diff --git a/docs/developer-docs/developer-tools/off-chain/agents/javascript-agent.mdx b/docs/developer-docs/developer-tools/off-chain/agents/javascript-agent.mdx index 96a8f6af82..c87bdb925d 100644 --- a/docs/developer-docs/developer-tools/off-chain/agents/javascript-agent.mdx +++ b/docs/developer-docs/developer-tools/off-chain/agents/javascript-agent.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + An agent is an API client used to interact with ICP. The [ICP JavaScript agent](https://www.npmjs.com/package/@dfinity/agent) is used to interact with the public ICP API endpoints and canisters deployed on ICP. ICP JavaScript agent provides `call`, `query`, and `readState` methods, along with other utilities, to an actor. diff --git a/docs/developer-docs/developer-tools/off-chain/agents/nodejs.mdx b/docs/developer-docs/developer-tools/off-chain/agents/nodejs.mdx index ad43265796..0d61cf6484 100644 --- a/docs/developer-docs/developer-tools/off-chain/agents/nodejs.mdx +++ b/docs/developer-docs/developer-tools/off-chain/agents/nodejs.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + [Node.js](https://nodejs.org/en) is a runtime environment for JavaScript. To interact with a canister through Node.js, you can use the [JavaScript agent](https://www.npmjs.com/package/@dfinity/agent). Using Node.js can enable use cases such as running an oracle, connecting an existing Node.js application to ICP, or introducing a websocket layer to your application. diff --git a/docs/developer-docs/developer-tools/off-chain/agents/rust-agent.mdx b/docs/developer-docs/developer-tools/off-chain/agents/rust-agent.mdx index 7dcd66e3e7..559726cf0c 100644 --- a/docs/developer-docs/developer-tools/off-chain/agents/rust-agent.mdx +++ b/docs/developer-docs/developer-tools/off-chain/agents/rust-agent.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The [ICP Rust agent](https://docs.rs/ic-agent/latest/ic_agent/) by DFINITY is a simple library that enables you to build applications and interact with ICP, serving as a low-level Rust backend for the IC SDK. diff --git a/docs/developer-docs/developer-tools/off-chain/canbench.mdx b/docs/developer-docs/developer-tools/off-chain/canbench.mdx index b134bf5e52..4779db201d 100644 --- a/docs/developer-docs/developer-tools/off-chain/canbench.mdx +++ b/docs/developer-docs/developer-tools/off-chain/canbench.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Canisters deployed on ICP use resources such as memory and compute. Resources are finite, and there are limits configured that restrict how many resources a canister may consume. The `canbench` Rust crate provides a way to benchmark a canister's resources so developers can gain an insight into how their canister uses memory, instructions, and other resources. diff --git a/docs/developer-docs/developer-tools/off-chain/canpack.mdx b/docs/developer-docs/developer-tools/off-chain/canpack.mdx index 842e8e025e..4bc198a15f 100644 --- a/docs/developer-docs/developer-tools/off-chain/canpack.mdx +++ b/docs/developer-docs/developer-tools/off-chain/canpack.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Canpack is a code generation tool designed to simplify communication across canisters written in different languages. It currently supports calling a Rust crate from Motoko code. Canpack generates a separate canister for the host language, then combines the other language's code fragments that are defined across different libraries. diff --git a/docs/developer-docs/developer-tools/on-chain/cdks.mdx b/docs/developer-docs/developer-tools/on-chain/cdks.mdx index 7c635e2f4d..51b2841077 100644 --- a/docs/developer-docs/developer-tools/on-chain/cdks.mdx +++ b/docs/developer-docs/developer-tools/on-chain/cdks.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Canister development kits (CDKs) are used to interface with the IC SDK and provide different programming languages with the necessary functionalities to develop canisters. These functionalities include the ability to create, deploy, call, and manage canisters, both locally deployed and deployed to the mainnet. diff --git a/docs/developer-docs/developer-tools/on-chain/ic-js.mdx b/docs/developer-docs/developer-tools/on-chain/ic-js.mdx index b7b0eb10b1..f05979a80c 100644 --- a/docs/developer-docs/developer-tools/on-chain/ic-js.mdx +++ b/docs/developer-docs/developer-tools/on-chain/ic-js.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + `ic-js` is a collection of JavaScript libraries that can be used to interface with ICP. Each library can be used independently from one another, or a project can use all of the libraries together. The NNS dapp is an example demonstration of all `ic-js` libraries being used together. diff --git a/docs/developer-docs/gas-cost.mdx b/docs/developer-docs/gas-cost.mdx index 8a35ed2ae8..60ed6eb91f 100644 --- a/docs/developer-docs/gas-cost.mdx +++ b/docs/developer-docs/gas-cost.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Canister smart contracts pay for consumed resources (storage, messaging, execution, and special features) by burning **cycles**. Developers can obtain cycles by converting ICP tokens into cycles using [`dfx`](/docs/current/developer-docs/defi/cycles/converting_icp_tokens_into_cycles). diff --git a/docs/developer-docs/getting-started/deploy-and-manage.mdx b/docs/developer-docs/getting-started/deploy-and-manage.mdx index e799e4b793..4aeea36a88 100644 --- a/docs/developer-docs/getting-started/deploy-and-manage.mdx +++ b/docs/developer-docs/getting-started/deploy-and-manage.mdx @@ -14,7 +14,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Once a canister's code has been written, it must be compiled into Wasm, installed into the canister itself, and then deployed to a network. The `dfx deploy` command executes each of these tasks as part of the deployment process; however, `dfx` commands also exist for running each step individually. diff --git a/docs/developer-docs/getting-started/deploy/local.mdx b/docs/developer-docs/getting-started/deploy/local.mdx index 872a6b84a2..fa4cde87ed 100644 --- a/docs/developer-docs/getting-started/deploy/local.mdx +++ b/docs/developer-docs/getting-started/deploy/local.mdx @@ -11,7 +11,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + When developing canisters and projects, it is recommended to first deploy your project to the local development environment. This is so you can fabricate cycles in your local development environment, which you cannot do on the mainnet. Cycles are charged for the resources used by your canister. [Learn more about cycles](/docs/current/developer-docs/gas-cost). diff --git a/docs/developer-docs/getting-started/deploy/mainnet.mdx b/docs/developer-docs/getting-started/deploy/mainnet.mdx index 00af98dab0..de8e60cf48 100644 --- a/docs/developer-docs/getting-started/deploy/mainnet.mdx +++ b/docs/developer-docs/getting-started/deploy/mainnet.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + To make your canister available to others, you must deploy it to the mainnet. diff --git a/docs/developer-docs/getting-started/deploy/testnet.mdx b/docs/developer-docs/getting-started/deploy/testnet.mdx index 7a312f4306..cf980def0d 100644 --- a/docs/developer-docs/getting-started/deploy/testnet.mdx +++ b/docs/developer-docs/getting-started/deploy/testnet.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + In contrast to other blockchain networks, ICP does not have a testnet network where smart contract developers can deploy their projects to test functionality. diff --git a/docs/developer-docs/getting-started/explore-examples.mdx b/docs/developer-docs/getting-started/explore-examples.mdx index 09b7a23b46..57b194cff4 100644 --- a/docs/developer-docs/getting-started/explore-examples.mdx +++ b/docs/developer-docs/getting-started/explore-examples.mdx @@ -11,7 +11,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + [ICP Ninja](https://icp.ninja) is a web-based integrated development environment (IDE) for creating and deploying decentralized applications (dapps) on the Internet Computer (ICP). diff --git a/docs/developer-docs/getting-started/identities.mdx b/docs/developer-docs/getting-started/identities.mdx index 725a6ba051..2490f0c01f 100644 --- a/docs/developer-docs/getting-started/identities.mdx +++ b/docs/developer-docs/getting-started/identities.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + On the Internet Computer (ICP), a developer **identity** is essential to developing canisters. Developer identities use a private/public key pair for authentication. The public key can be distributed openly as it will be used to encrypt messages. The private key must be kept secret and stored securely. diff --git a/docs/developer-docs/getting-started/install.mdx b/docs/developer-docs/getting-started/install.mdx index ce5bc0a57f..3cf308c95e 100644 --- a/docs/developer-docs/getting-started/install.mdx +++ b/docs/developer-docs/getting-started/install.mdx @@ -11,7 +11,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The IC SDK is a software development kit used to develop and deploy applications on the Internet Computer (ICP) from a local developer environment. It is comprised of several tools. diff --git a/docs/developer-docs/getting-started/tokens-and-cycles.mdx b/docs/developer-docs/getting-started/tokens-and-cycles.mdx index e773172e10..b9c746864a 100644 --- a/docs/developer-docs/getting-started/tokens-and-cycles.mdx +++ b/docs/developer-docs/getting-started/tokens-and-cycles.mdx @@ -11,7 +11,7 @@ import { AdornedTabs } from "/src/components/Tabs/AdornedTabs"; -## Overview + On the Internet Computer, there are three types of token assets: ICP tokens, cycles, and ICRC tokens. ICP and cycles are the most important for every developer to understand and use, as they are necessary for deploying and maintaining a canister. diff --git a/docs/developer-docs/getting-started/troubleshooting.mdx b/docs/developer-docs/getting-started/troubleshooting.mdx index 06197041f5..566ff20393 100644 --- a/docs/developer-docs/getting-started/troubleshooting.mdx +++ b/docs/developer-docs/getting-started/troubleshooting.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This section provides information to help you troubleshoot and resolve or work around common issues that are related to the following tasks: diff --git a/docs/developer-docs/getting-started/write-smart-contracts.mdx b/docs/developer-docs/getting-started/write-smart-contracts.mdx index 2f166120ae..a5a56d4f95 100644 --- a/docs/developer-docs/getting-started/write-smart-contracts.mdx +++ b/docs/developer-docs/getting-started/write-smart-contracts.mdx @@ -14,7 +14,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Canisters are an enhanced type of smart contract. Before a canister is deployed to ICP, the canister's code is compiled into a WebAssembly (Wasm) program, enabling it to store persistent data, be managed by entities such as DAOs, host entire applications, and more. Each canister has the following components: diff --git a/docs/developer-docs/getting-started/wsl-troubleshoot.mdx b/docs/developer-docs/getting-started/wsl-troubleshoot.mdx index 4786d2f228..484512fef5 100644 --- a/docs/developer-docs/getting-started/wsl-troubleshoot.mdx +++ b/docs/developer-docs/getting-started/wsl-troubleshoot.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The IC SDK is not natively supported on Windows operating systems. It is recommended for Windows users to install [Windows Subsystem for Linux](https://docs.microsoft.com/en-us/windows/wsl/install). diff --git a/docs/developer-docs/identity/internet-identity/alternative-origins.mdx b/docs/developer-docs/identity/internet-identity/alternative-origins.mdx index b509a15e4e..d65c18179c 100644 --- a/docs/developer-docs/identity/internet-identity/alternative-origins.mdx +++ b/docs/developer-docs/identity/internet-identity/alternative-origins.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + If your application has reached the stage where you want to change domain names, and you have been authenticating with Internet Identity (II), you will want to make sure that your users can seamlessly keep the same principals they have already been using. To support this functionality, you can configure your application for alternative frontend origins using this guide. ![End Result](../_attachments/alternative-origins.png) diff --git a/docs/developer-docs/identity/internet-identity/creating-ii.mdx b/docs/developer-docs/identity/internet-identity/creating-ii.mdx index 51a3b96873..69f45747bc 100644 --- a/docs/developer-docs/identity/internet-identity/creating-ii.mdx +++ b/docs/developer-docs/identity/internet-identity/creating-ii.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide walks through how to create an Internet Identity. Internet Identity is ICP's native form of identity. It is used by many dapps build on ICP for users to authenticate with. diff --git a/docs/developer-docs/identity/internet-identity/integrate-internet-identity.mdx b/docs/developer-docs/identity/internet-identity/integrate-internet-identity.mdx index 7285aa8a50..607c449197 100644 --- a/docs/developer-docs/identity/internet-identity/integrate-internet-identity.mdx +++ b/docs/developer-docs/identity/internet-identity/integrate-internet-identity.mdx @@ -12,7 +12,7 @@ import { BetaChip } from "/src/components/Chip/BetaChip"; -## Overview + This guide shows an example of how to integrate Internet Identity into an application by using a simple 'Who am I?' backend canister and a frontend UI that returns the Internet Identity principal of the user who calls the backend's `whoami` method. This project uses the **pullable** version of the Internet identity canister. A pullable canister is a canister that provides a public service at a static canister ID. To learn more about pullable canisters, please [see the documentation](/docs/current/developer-docs/smart-contracts/maintain/import). diff --git a/docs/developer-docs/identity/verifiable-credentials/how-it-works.mdx b/docs/developer-docs/identity/verifiable-credentials/how-it-works.mdx index 1f0685e2e4..fb63d4542c 100644 --- a/docs/developer-docs/identity/verifiable-credentials/how-it-works.mdx +++ b/docs/developer-docs/identity/verifiable-credentials/how-it-works.mdx @@ -9,7 +9,7 @@ import useBaseUrl from "@docusaurus/useBaseUrl"; -## Overview + Verifiable credentials (VCs) on ICP rely on Internet Identity (II), which provides distinct identities that preserve unlinkability for each dapp. A dapp utilizing verifiable credentials can’t ask for a user's credentials from the [issuer](/docs/current/developer-docs/identity/verifiable-credentials/overview#terminology) of the verifiable credential directly. When a [relying party](/docs/current/developer-docs/identity/verifiable-credentials/overview#terminology) wants to obtain a credential from an issuer, it must request it through an [identity provider](/docs/current/developer-docs/identity/verifiable-credentials/overview#terminology) such as Internet Identity. diff --git a/docs/developer-docs/identity/verifiable-credentials/issuer.mdx b/docs/developer-docs/identity/verifiable-credentials/issuer.mdx index 6fd309f1e1..b3438db61d 100644 --- a/docs/developer-docs/identity/verifiable-credentials/issuer.mdx +++ b/docs/developer-docs/identity/verifiable-credentials/issuer.mdx @@ -9,7 +9,7 @@ import useBaseUrl from "@docusaurus/useBaseUrl"; -## Overview + An **issuer** is a service or app that can issue a verifiable credential (VC) to a user. On ICP, an issuer is an exposed API that receives calls from an identity provider and does not trigger any workflows itself. To become an issuer, your canister must implement the issuer API as described in the [verifiable credential spec](https://github.com/dfinity/internet-identity/blob/main/docs/vc-spec.md). diff --git a/docs/developer-docs/identity/verifiable-credentials/relying-party.mdx b/docs/developer-docs/identity/verifiable-credentials/relying-party.mdx index e48577c4ef..ccd5dede44 100644 --- a/docs/developer-docs/identity/verifiable-credentials/relying-party.mdx +++ b/docs/developer-docs/identity/verifiable-credentials/relying-party.mdx @@ -9,7 +9,7 @@ import useBaseUrl from "@docusaurus/useBaseUrl"; -## Overview + A **relying party** is a service or app that requests a user's verifiable credentials from an [issuer](issuer.mdx). Relying parties use an **identity provider**, such as Internet Identity, to communicate with the issuer. Identity providers must support the [verifiable credentials specification](https://github.com/dfinity/internet-identity/blob/main/docs/vc-spec.md). Communication with the identity provider uses the [`window.postMessage()`](https://developer.mozilla.org/en-US/docs/Web/API/Window/postMessage) communication channel. diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-comparison.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-comparison.mdx index b2df1912b3..9b87508081 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-comparison.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-comparison.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide is designed to help Bitcoin developers understand the core concepts of ICP in order to properly use ICP as a Layer-2 solution for Bitcoin. ## Terminology mapping diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-dev-workflow.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-dev-workflow.mdx index 25caf4bbf8..ed41c69a9d 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-dev-workflow.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/btc-dev-workflow.mdx @@ -11,7 +11,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Developers on ICP can create canisters and dapps that interact directly with the Bitcoin mainnet and testnet networks through ICP's direct integration with Bitcoin. To use this integration, developers must implement a specific workflow to prepare transactions and submit them to the Bitcoin network. Developers can also integrate and interact with chain-key Bitcoin (ckBTC) from within a canister, which uses the ICRC-1 token implementation. diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/create-transactions.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/create-transactions.mdx index fc178b5b71..0629f95e8a 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/create-transactions.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/create-transactions.mdx @@ -11,7 +11,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A Bitcoin transaction spends a number of unspent transaction outputs (UTXOs) and creates new UTXOs. In order to create a Bitcoin transaction, you need to: diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/generate-addresses.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/generate-addresses.mdx index 485edf60b7..159eef1fe2 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/generate-addresses.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/generate-addresses.mdx @@ -11,7 +11,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + For a canister to receive Bitcoin payments, it must generate a Bitcoin address. In contrast to most other blockchains, Bitcoin doesn't use accounts. Instead, it diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/local-development.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/local-development.mdx index 18f940a79c..1bf5d45edf 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/local-development.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/local-development.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + In this guide, you'll explore how you can develop and test a Bitcoin dapp locally. Testing locally allows you to iterate and improve your dapp more quickly. diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/ordinals.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/ordinals.mdx index cfe71eff34..1e6adf269b 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/ordinals.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/ordinals.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + On Bitcoin, the term 'satoshi' refers to the smallest denomination of BTC, equal to 100 millionth of 1 bitcoin. [Ordinal theory](https://docs.ordinals.com/digital-artifacts.html), or simply 'Ordinals', refers to a numbering scheme used to track and transfer individual satoshis. The term 'Ordinal' comes from the fact that each satoshi is numbered based on the order in which it has been mined and the order in which it is transferred, based on transaction inputs and outputs. diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/read-state.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/read-state.mdx index d4b51c34f7..f072401a71 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/read-state.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/read-state.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To read information from the Bitcoin network's state, the Bitcoin integration API exposes the following methods: diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/runes.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/runes.mdx index 5f50342578..5dc075de01 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/runes.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/runes.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Bitcoin Runes are a type of fungible asset deployed on the Bitcoin network. Runes are not reliant on the [Ordinals protocol](ordinals.mdx) like other Bitcoin asset standards such as BRC-20 and SRC-20. Runes are designed to be an efficient and simple asset that utilizes Bitcoin's UTXO model and the `OP_RETURN` opcode. Although Runes aren't reliant on Ordinals, the Rune protocol was created and implemented by the same creator, and is part of the same open source project that Ordinals are. diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/sign-transactions.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/sign-transactions.mdx index 8c46b22e02..9f293bd51d 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/sign-transactions.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/sign-transactions.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Before a transaction can be sent to the Bitcoin network, each input must be signed. diff --git a/docs/developer-docs/multi-chain/bitcoin/using-btc/submit-transactions.mdx b/docs/developer-docs/multi-chain/bitcoin/using-btc/submit-transactions.mdx index 9d098aa4e3..adb0358a1f 100644 --- a/docs/developer-docs/multi-chain/bitcoin/using-btc/submit-transactions.mdx +++ b/docs/developer-docs/multi-chain/bitcoin/using-btc/submit-transactions.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To submit transactions to the Bitcoin network, the Bitcoin integration API exposes the `bitcoin_send_transaction` method. diff --git a/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/making-transactions.mdx b/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/making-transactions.mdx index e302cc4ee8..e44e1222dd 100644 --- a/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/making-transactions.mdx +++ b/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/making-transactions.mdx @@ -11,7 +11,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are several different ways to interact with ckBTC: diff --git a/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/using-ckbtc-in-dapps.mdx b/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/using-ckbtc-in-dapps.mdx index db48fd9e34..905d8d5110 100644 --- a/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/using-ckbtc-in-dapps.mdx +++ b/docs/developer-docs/multi-chain/chain-key-tokens/ckbtc/using-ckbtc-in-dapps.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + ckBTC is an ICRC-2 compliant token, meaning it supports the [ICRC-1](https://github.com/dfinity/ICRC-1/tree/main/standards/ICRC-1) and [ICRC-2](https://github.com/dfinity/ICRC-1/blob/main/standards/ICRC-2/README.md) token standards. diff --git a/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/making-transactions.mdx b/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/making-transactions.mdx index 3c70227949..de5975040c 100644 --- a/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/making-transactions.mdx +++ b/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/making-transactions.mdx @@ -11,7 +11,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are several different ways to interact with ckERC20 tokens: diff --git a/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/using-ckerc20-in-dapps.mdx b/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/using-ckerc20-in-dapps.mdx index daa9c575bf..85605a1615 100644 --- a/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/using-ckerc20-in-dapps.mdx +++ b/docs/developer-docs/multi-chain/chain-key-tokens/ckerc20/using-ckerc20-in-dapps.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + All ckERC20 tokens are ICRC-2 compliant tokens, which means that they support the [ICRC-1](https://github.com/dfinity/ICRC-1/blob/main/standards/ICRC-1/README.md) and [ICRC-2](https://github.com/dfinity/ICRC-1/blob/main/standards/ICRC-2/README.md) token standards. diff --git a/docs/developer-docs/multi-chain/chain-key-tokens/cketh/making-transactions.mdx b/docs/developer-docs/multi-chain/chain-key-tokens/cketh/making-transactions.mdx index 270fc064f2..0d55fce044 100644 --- a/docs/developer-docs/multi-chain/chain-key-tokens/cketh/making-transactions.mdx +++ b/docs/developer-docs/multi-chain/chain-key-tokens/cketh/making-transactions.mdx @@ -11,7 +11,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are several different ways to interact with ckETH: diff --git a/docs/developer-docs/multi-chain/chain-key-tokens/cketh/using-cketh-in-dapps.mdx b/docs/developer-docs/multi-chain/chain-key-tokens/cketh/using-cketh-in-dapps.mdx index 823e732745..eecc24aa1a 100644 --- a/docs/developer-docs/multi-chain/chain-key-tokens/cketh/using-cketh-in-dapps.mdx +++ b/docs/developer-docs/multi-chain/chain-key-tokens/cketh/using-cketh-in-dapps.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + ckETH is an ICRC-2 compliant token, meaning it supports the [ICRC-1](https://github.com/dfinity/ICRC-1/blob/main/standards/ICRC-1/README.md) and [ICRC-2](https://github.com/dfinity/ICRC-1/blob/main/standards/ICRC-2/README.md) token standards. diff --git a/docs/developer-docs/multi-chain/ethereum/evm-rpc/costs.mdx b/docs/developer-docs/multi-chain/ethereum/evm-rpc/costs.mdx index 87e58c7917..a3635724ca 100644 --- a/docs/developer-docs/multi-chain/ethereum/evm-rpc/costs.mdx +++ b/docs/developer-docs/multi-chain/ethereum/evm-rpc/costs.mdx @@ -11,7 +11,7 @@ import { AdornedTab } from "/src/components/Tabs/AdornedTab"; -## Overview + Each call made to the EVM RPC canister costs [cycles](/docs/current/developer-docs/getting-started/tokens-and-cycles). diff --git a/docs/developer-docs/multi-chain/ethereum/evm-rpc/how-it-works.mdx b/docs/developer-docs/multi-chain/ethereum/evm-rpc/how-it-works.mdx index de1383d145..b03b39ccf2 100644 --- a/docs/developer-docs/multi-chain/ethereum/evm-rpc/how-it-works.mdx +++ b/docs/developer-docs/multi-chain/ethereum/evm-rpc/how-it-works.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The [Ethereum Virtual Machine](https://ethereum.org/en/developers/docs/evm/) (EVM) [Remote Procedure Call](https://ethereum.org/en/developers/docs/apis/json-rpc/) (RPC) canister enables communication between ICP canisters and RPC services. These services, such as Cloudflare and Alchemy, provide public APIs for interacting with blockchain networks. The EVM RPC canister acts as a gateway for a dapp's canisters to communicate with and query information from EVM-compatible chains. It provides endpoints that ICP developers can use to interact with Ethereum smart contracts and ensures that the responses received from the Ethereum network are secure and immediately useful within a canister. diff --git a/docs/developer-docs/multi-chain/ethereum/using-eth/eth-comparison.mdx b/docs/developer-docs/multi-chain/ethereum/using-eth/eth-comparison.mdx index f9aacedd4e..ceaa429997 100644 --- a/docs/developer-docs/multi-chain/ethereum/using-eth/eth-comparison.mdx +++ b/docs/developer-docs/multi-chain/ethereum/using-eth/eth-comparison.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide is designed to help Ethereum developers understand the core concepts of ICP, focusing on the terminology and functionalities that differ between the two protocols. While the underlying concepts might be similar, ICP utilizes different terms to describe them. For a feature comparison between the two protocols, refer to the [quick comparison between ICP and Ethereum](/docs/current/developer-docs/getting-started/network-overview#quick-comparison-with-ethereum). diff --git a/docs/developer-docs/multi-chain/ethereum/using-eth/eth-dev-workflow.mdx b/docs/developer-docs/multi-chain/ethereum/using-eth/eth-dev-workflow.mdx index e1bd07ef5c..c3996d489c 100644 --- a/docs/developer-docs/multi-chain/ethereum/using-eth/eth-dev-workflow.mdx +++ b/docs/developer-docs/multi-chain/ethereum/using-eth/eth-dev-workflow.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Developers on ICP can create canisters and dapps that interact with the Ethereum mainnet, Sepolia testnet, and other EVM-compatible networks through ICP's Ethereum integration. To use this integration, developers must implement a specific workflow that makes JSON-RPC calls to the EVM RPC canister in order to query network information and submit transactions to an EVM-compatible network. Developers can also integrate and interact with chain-key Ethereum (ckETH) from within a canister, which uses the ICRC-1 token implementation. diff --git a/docs/developer-docs/multi-chain/ethereum/using-eth/generating-addresses.mdx b/docs/developer-docs/multi-chain/ethereum/using-eth/generating-addresses.mdx index 363003dde6..ab5b838d57 100644 --- a/docs/developer-docs/multi-chain/ethereum/using-eth/generating-addresses.mdx +++ b/docs/developer-docs/multi-chain/ethereum/using-eth/generating-addresses.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + On Ethereum, there are two types of addresses: wallet addresses for holding assets and contract addresses. Wallet addresses are public accounts that can send and receive ETH tokens. Contract addresses refer to a smart contract that has been executed on Ethereum and the transactions associated with that contract. diff --git a/docs/developer-docs/multi-chain/ethereum/using-eth/signing-transactions.mdx b/docs/developer-docs/multi-chain/ethereum/using-eth/signing-transactions.mdx index 19410fe153..d380705ca7 100644 --- a/docs/developer-docs/multi-chain/ethereum/using-eth/signing-transactions.mdx +++ b/docs/developer-docs/multi-chain/ethereum/using-eth/signing-transactions.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Before a transaction can be sent to the Ethereum network, it must be signed and formatted into a raw ETH transaction. Transactions are signed with [threshold ECDSA](/docs/current/developer-docs/smart-contracts/signatures/t-ecdsa). For this example, the transaction standard EIP1559 will be used. diff --git a/docs/developer-docs/multi-chain/ethereum/using-eth/submit-transactions.mdx b/docs/developer-docs/multi-chain/ethereum/using-eth/submit-transactions.mdx index df9c900d0c..0df229cfc9 100644 --- a/docs/developer-docs/multi-chain/ethereum/using-eth/submit-transactions.mdx +++ b/docs/developer-docs/multi-chain/ethereum/using-eth/submit-transactions.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To submit transactions to the Ethereum network, first the transaction must be signed and formatted as an ETH transaction. [Learn more about signing transactions](signing-transactions.mdx). diff --git a/docs/developer-docs/multi-chain/examples.mdx b/docs/developer-docs/multi-chain/examples.mdx index 63627a8cdf..4265719bfe 100644 --- a/docs/developer-docs/multi-chain/examples.mdx +++ b/docs/developer-docs/multi-chain/examples.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + ICP's Chain Fusion technology allows developers to build dapps that can interact seamlessly with other blockchain networks without using an intermediary, such as an oracle or a bridge. diff --git a/docs/developer-docs/multi-chain/supported-chains.mdx b/docs/developer-docs/multi-chain/supported-chains.mdx index 06efed3971..4b0cfdb6ba 100644 --- a/docs/developer-docs/multi-chain/supported-chains.mdx +++ b/docs/developer-docs/multi-chain/supported-chains.mdx @@ -41,7 +41,7 @@ import { BetaChip } from "/src/components/Chip/BetaChip"; -## Overview + Other blockchain networks can be integrated with ICP if they leverage an authentication method that is supported by the threshold signing protocols of diff --git a/docs/developer-docs/security/security-best-practices/resources.mdx b/docs/developer-docs/security/security-best-practices/resources.mdx index 1cc7e29e6e..1de4ce1a02 100644 --- a/docs/developer-docs/security/security-best-practices/resources.mdx +++ b/docs/developer-docs/security/security-best-practices/resources.mdx @@ -10,7 +10,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Below are resources which cover security best practices for technologies you are likely using in your dapp. These best practices are equally important as our Internet Computer specific guidelines and should be studied carefully. They can be useful to reference when developing secure dapps or executing security reviews. ## General diff --git a/docs/developer-docs/smart-contracts/advanced-features/async-code.mdx b/docs/developer-docs/smart-contracts/advanced-features/async-code.mdx index 4ab1db4151..9a9089d24e 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/async-code.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/async-code.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + In programming, the [async/await pattern](https://en.wikipedia.org/wiki/Async/await) is a syntactic feature of many programming languages that allows an asynchronous, non-blocking function to be structured in a similar way to an ordinary synchronous function. @@ -20,7 +20,7 @@ The `async/await` pattern makes this look straightforward, as the developer can the callee is handled “synchronously”. However, given ICP's message passing model, one has to be careful in case there are [concurrent calls that message executions can interleave](/docs/current/references/message-execution-properties) as these can lead to inconsistencies if they are not anticipated. -## Overview of language runtime for asynchronous code + ## Language runtime for asynchronous code Most languages implement asynchronous code through constructs that they typically call [futures](https://docs.rs/futures/latest/futures/) ([promises](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) in Javascript). A future is a representation diff --git a/docs/developer-docs/smart-contracts/advanced-features/composite-query.mdx b/docs/developer-docs/smart-contracts/advanced-features/composite-query.mdx index 7c2663b012..5f4db06c79 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/composite-query.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/composite-query.mdx @@ -12,7 +12,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The Internet Computer Protocol supports two types of messages: updates and queries. An update message is executed on all nodes and persists canister state changes. A query message discards state changes and typically executes on a single node. It is possible to execute a query message as an update. In such a case, the query still discards the state changes, but the execution happens on all nodes and the result of execution goes through consensus. This “query-as-update” execution mode is also known as replicated query. An update can call other updates and queries. However a query cannot make any calls, which can hinder development of scalable decentralized applications, especially those that shard data across multiple canisters. diff --git a/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx b/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx index 1d1f801617..77f35791f0 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Canisters running on ICP can use HTTP requests in two ways: incoming and outgoing. Incoming HTTP requests refer to HTTP requests that are sent to a canister and can be used to retrieve data from a canister or send new data to the canister. Outgoing HTTP requests refer to HTTP requests that the canister sends to other canisters or external services to retrieve data or send new data. diff --git a/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-get.mdx b/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-get.mdx index 2dfc04365c..7782198d78 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-get.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-get.mdx @@ -13,7 +13,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A minimal example to make a `GET` HTTP request. The purpose of this dapp is only to show how to make HTTP requests from a canister. It sends a `GET` request to the Coinbase API and retrieves some historical data about the ICP token. diff --git a/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-post.mdx b/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-post.mdx index 59371eb8f4..d2d7b77b5b 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-post.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-post.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A minimal example of how to make a `POST` HTTP request. The purpose of this dapp is only to show how to make HTTP requests from a canister. It sends a `POST` request with some JSON to a free API where you can verify the headers and body were sent correctly. diff --git a/docs/developer-docs/smart-contracts/advanced-features/management-canister.mdx b/docs/developer-docs/smart-contracts/advanced-features/management-canister.mdx index 28d74eeee9..ccd76a472b 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/management-canister.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/management-canister.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The ICP management canister is used to provide access to system features, such as managing canisters, integrating with Bitcoin, making HTTPS outcalls, signing with threshold signatures, and securely retrieving randomness. diff --git a/docs/developer-docs/smart-contracts/advanced-features/periodic-tasks.mdx b/docs/developer-docs/smart-contracts/advanced-features/periodic-tasks.mdx index b8aed0f245..1f79c87176 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/periodic-tasks.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/periodic-tasks.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Unlike other blockchains, ICP canisters can automatically execute tasks after a specified delay or interval. There are two ways to schedule an automatic canister execution on ICP: diff --git a/docs/developer-docs/smart-contracts/advanced-features/query-stats.mdx b/docs/developer-docs/smart-contracts/advanced-features/query-stats.mdx index f5a7380992..d71d644ce1 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/query-stats.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/query-stats.mdx @@ -1,6 +1,6 @@ # Query stats -## Overview + When users interact with a dapp, query calls may be used. Query calls cannot modify a canister's state, making it impossible to track them from the canister's code. diff --git a/docs/developer-docs/smart-contracts/advanced-features/randomness.mdx b/docs/developer-docs/smart-contracts/advanced-features/randomness.mdx index 307b1c4993..bea955a696 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/randomness.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/randomness.mdx @@ -13,7 +13,7 @@ import { BetaChip } from "/src/components/Chip/BetaChip"; -## Overview + The Internet Computer provides a secure and verifiable way to generate random numbers directly within canisters. This functionality is exposed through the [raw_rand](../../../references/ic-interface-spec.md) method offered by the [management canister](../advanced-features/management-canister.mdx) and the [Motoko Random module](/docs/current/motoko/main/base/Random). diff --git a/docs/developer-docs/smart-contracts/advanced-features/simd.mdx b/docs/developer-docs/smart-contracts/advanced-features/simd.mdx index aa7e0e87fd..82086b42c9 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/simd.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/simd.mdx @@ -13,7 +13,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + ICP supports deterministic WebAssembly SIMD support. This is a significant milestone for smart contracts demanding top onchain performance, such as artificial intelligence (AI), image processing (NFTs), games, scientific decentralized applications (dapps), and more. diff --git a/docs/developer-docs/smart-contracts/advanced-features/system-canisters.mdx b/docs/developer-docs/smart-contracts/advanced-features/system-canisters.mdx index 57d8564a23..e29c2574e4 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/system-canisters.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/system-canisters.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + System canisters are canisters that provide a necessary function to the ICP network. They are controlled by the NNS and upgraded via NNS proposals. These canisters have static canister IDs that projects can make calls to. One common example of a system canister that is used by projects is the Internet Identity canister. diff --git a/docs/developer-docs/smart-contracts/advanced-features/time-and-timestamps.mdx b/docs/developer-docs/smart-contracts/advanced-features/time-and-timestamps.mdx index e3a2d19857..01f84871a7 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/time-and-timestamps.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/time-and-timestamps.mdx @@ -13,7 +13,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + System time is a publicly exposed and verified part of the [IC state tree](/docs/current/references/ic-interface-spec#state-tree). System time is expressed in nanoseconds since `1970-01-01` and indicates the time at which the state is current. It is exposed at `/time`, and all partial state trees include a timestamp. diff --git a/docs/developer-docs/smart-contracts/best-practices/general.mdx b/docs/developer-docs/smart-contracts/best-practices/general.mdx index 0ad4374f35..2f96d49b1a 100644 --- a/docs/developer-docs/smart-contracts/best-practices/general.mdx +++ b/docs/developer-docs/smart-contracts/best-practices/general.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide outlines essential development best practices for building on the Internet Computer Protocol (ICP). diff --git a/docs/developer-docs/smart-contracts/best-practices/idempotency.mdx b/docs/developer-docs/smart-contracts/best-practices/idempotency.mdx index 66b2231a81..b20f6db610 100644 --- a/docs/developer-docs/smart-contracts/best-practices/idempotency.mdx +++ b/docs/developer-docs/smart-contracts/best-practices/idempotency.mdx @@ -9,7 +9,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + In the case of network issues or other unexpected behavior, ICP clients (such as agents) that issue ingress update calls may be unable to determine whether their ingress diff --git a/docs/developer-docs/smart-contracts/best-practices/reproducible-builds.mdx b/docs/developer-docs/smart-contracts/best-practices/reproducible-builds.mdx index bce4af1759..e115bc91e7 100644 --- a/docs/developer-docs/smart-contracts/best-practices/reproducible-builds.mdx +++ b/docs/developer-docs/smart-contracts/best-practices/reproducible-builds.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + If you are using a canister that you did not develop yourself, you may want to verify that the canister is running the code that you expect it to be before giving it control to make important decisions for you, such as accepting ICP for a payment. Verifying a canister's code requires confirming that the Wasm module is the correct result of compiling the canister source code and that the canister is in fact running that Wasm module and not another Wasm module. diff --git a/docs/developer-docs/smart-contracts/best-practices/storage.mdx b/docs/developer-docs/smart-contracts/best-practices/storage.mdx index 3d09844bd0..c7bb0f33c7 100644 --- a/docs/developer-docs/smart-contracts/best-practices/storage.mdx +++ b/docs/developer-docs/smart-contracts/best-practices/storage.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + There are two forms of storage available to ICP canisters: **heap memory** and **stable memory**. diff --git a/docs/developer-docs/smart-contracts/best-practices/troubleshooting.mdx b/docs/developer-docs/smart-contracts/best-practices/troubleshooting.mdx index 123fa74c0d..356e84d7f9 100644 --- a/docs/developer-docs/smart-contracts/best-practices/troubleshooting.mdx +++ b/docs/developer-docs/smart-contracts/best-practices/troubleshooting.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + When a dapp or canister is running with a high amount of latency, there are some steps that developers can take to troubleshoot or optimize the performance of their canisters. diff --git a/docs/developer-docs/smart-contracts/candid/candid-concepts.mdx b/docs/developer-docs/smart-contracts/candid/candid-concepts.mdx index 724bea1ddf..0cb85a3dac 100644 --- a/docs/developer-docs/smart-contracts/candid/candid-concepts.mdx +++ b/docs/developer-docs/smart-contracts/candid/candid-concepts.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Candid is an **interface description language**. Its primary purpose is to describe the public interface of a **service**, usually in the form of a program deployed as a canister that runs on the Internet Computer. One of the key benefits of Candid is that it is language-agnostic, and allows inter-operation between services and frontends written in different programming languages, including Motoko, Rust, and JavaScript. diff --git a/docs/developer-docs/smart-contracts/candid/candid-howto.mdx b/docs/developer-docs/smart-contracts/candid/candid-howto.mdx index 3ee957c4db..11006e0e76 100644 --- a/docs/developer-docs/smart-contracts/candid/candid-howto.mdx +++ b/docs/developer-docs/smart-contracts/candid/candid-howto.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Candid provides a language-agnostic way to interact with canisters. diff --git a/docs/developer-docs/smart-contracts/candid/candid-tools.mdx b/docs/developer-docs/smart-contracts/candid/candid-tools.mdx index cbfb0a6d05..bfe794f1cf 100644 --- a/docs/developer-docs/smart-contracts/candid/candid-tools.mdx +++ b/docs/developer-docs/smart-contracts/candid/candid-tools.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Candid is an **interface description language** that can be used by ICP canisters to define the public interface of a service. Candid is language-agnostic and allows for the inter-operation of services and frontends written in different programming languages, including Motoko, Rust, and JavaScript. diff --git a/docs/developer-docs/smart-contracts/compile.mdx b/docs/developer-docs/smart-contracts/compile.mdx index 86c542753f..edbfa3f8ab 100644 --- a/docs/developer-docs/smart-contracts/compile.mdx +++ b/docs/developer-docs/smart-contracts/compile.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + After you have [written the code](/docs/current/developer-docs/smart-contracts/write/overview) for your project's canisters and [created them](/docs/current/developer-docs/smart-contracts/create), you need to compile the code into a WebAssembly module before it can be deployed on ICP. diff --git a/docs/developer-docs/smart-contracts/create.mdx b/docs/developer-docs/smart-contracts/create.mdx index 75abc51005..131e109c99 100644 --- a/docs/developer-docs/smart-contracts/create.mdx +++ b/docs/developer-docs/smart-contracts/create.mdx @@ -14,7 +14,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Canisters contain both code and state. Once you have written the code for a canister, the canister doesn't exist until it is registered with ICP, either locally, on the playground, or on the mainnet. diff --git a/docs/developer-docs/smart-contracts/deploy/custom-testnets.mdx b/docs/developer-docs/smart-contracts/deploy/custom-testnets.mdx index 1675bc55a9..cbc1937c5a 100644 --- a/docs/developer-docs/smart-contracts/deploy/custom-testnets.mdx +++ b/docs/developer-docs/smart-contracts/deploy/custom-testnets.mdx @@ -5,7 +5,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + ICP does not have a public testnet network that developers can use to deploy and test canisters because canisters deployed to the mainnet can be upgraded and changed. Plus, deployment costs are fairly low compared to other chains. diff --git a/docs/developer-docs/smart-contracts/encryption/using-vetkeys.mdx b/docs/developer-docs/smart-contracts/encryption/using-vetkeys.mdx index 1c147ab3dc..7c5d27189b 100644 --- a/docs/developer-docs/smart-contracts/encryption/using-vetkeys.mdx +++ b/docs/developer-docs/smart-contracts/encryption/using-vetkeys.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This demo provides a canister (`src/system_api`) that offers the [proposed vetKD system API](https://github.com/dfinity/interface-spec/pull/158), implemented demonstration, testing, and initial development purposes. We stress that it does not offer security yet as no threshold cryptography is used yet to secure the key. diff --git a/docs/developer-docs/smart-contracts/install.mdx b/docs/developer-docs/smart-contracts/install.mdx index 4e768572e8..ea21efd9b6 100644 --- a/docs/developer-docs/smart-contracts/install.mdx +++ b/docs/developer-docs/smart-contracts/install.mdx @@ -14,7 +14,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + When a canister has been initially created, it is empty and does not contain code or state. It only contains information such as the settings, canister ID, cycles balance, and controllers. [Learn more about creating a canister](/docs/current/developer-docs/smart-contracts/create). diff --git a/docs/developer-docs/smart-contracts/maintain/control.mdx b/docs/developer-docs/smart-contracts/maintain/control.mdx index 49c8878b1c..14965d0a05 100644 --- a/docs/developer-docs/smart-contracts/maintain/control.mdx +++ b/docs/developer-docs/smart-contracts/maintain/control.mdx @@ -11,7 +11,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + A canister is managed by a list of controllers. A controller is specified by a principal, which can be self-authenticating, e.g. a `dfx` developer identity, or another canister. Canisters can have multiple controllers where each has the same administrative rights, or it can have no controller, in which case the canister becomes immutable (blackholed) and cannot be upgraded or deleted. diff --git a/docs/developer-docs/smart-contracts/maintain/delete.mdx b/docs/developer-docs/smart-contracts/maintain/delete.mdx index 72bb900183..69bb27b500 100644 --- a/docs/developer-docs/smart-contracts/maintain/delete.mdx +++ b/docs/developer-docs/smart-contracts/maintain/delete.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + If you want to permanently delete a specific canister or all canisters for a project, you can use the [`dfx canister delete `](/docs/current/developer-docs/developer-tools/cli-tools/cli-reference/dfx-canister#dfx-canister-delete) command. diff --git a/docs/developer-docs/smart-contracts/maintain/history.mdx b/docs/developer-docs/smart-contracts/maintain/history.mdx index 4d4aa075e7..cc57348522 100644 --- a/docs/developer-docs/smart-contracts/maintain/history.mdx +++ b/docs/developer-docs/smart-contracts/maintain/history.mdx @@ -14,7 +14,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The Internet Computer tracks the history of a deployed canister through the canister's Wasm module hashes and controller changes. This tracking provides insight into the canister's history, such as what code has been used to run the canister and which controller deployed that code. diff --git a/docs/developer-docs/smart-contracts/maintain/import.mdx b/docs/developer-docs/smart-contracts/maintain/import.mdx index 4aac16cab1..8a996401f9 100644 --- a/docs/developer-docs/smart-contracts/maintain/import.mdx +++ b/docs/developer-docs/smart-contracts/maintain/import.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The interoperability of canisters is a vital feature for many developers. `dfx` provides a consistent developer workflow for creating, integrating and testing third-party canisters with local developer environments. diff --git a/docs/developer-docs/smart-contracts/maintain/logs.mdx b/docs/developer-docs/smart-contracts/maintain/logs.mdx index 6ed299224c..d49ae1444b 100644 --- a/docs/developer-docs/smart-contracts/maintain/logs.mdx +++ b/docs/developer-docs/smart-contracts/maintain/logs.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The canister logging feature is designed to provide developers with insight into their canister's behavior and assist with scenarios where their canister traps. This feature supports log messages for: diff --git a/docs/developer-docs/smart-contracts/maintain/recovery.mdx b/docs/developer-docs/smart-contracts/maintain/recovery.mdx index 4b0a1f3730..d1a2a9cdb1 100644 --- a/docs/developer-docs/smart-contracts/maintain/recovery.mdx +++ b/docs/developer-docs/smart-contracts/maintain/recovery.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + A canister is managed and maintained by **controllers**. A controller can be a single developer identity, a list of developer identities, or another canister. If a canister does not have a controller, it cannot be upgraded, deleted, or otherwise maintained. This also applies if access to all canister's controllers identities are lost. If a canister's code traps with an unrecoverable error and cannot be upgraded, the canister can potentially be recovered using canister snapshots or an NNS proposal. diff --git a/docs/developer-docs/smart-contracts/maintain/resource-limits.mdx b/docs/developer-docs/smart-contracts/maintain/resource-limits.mdx index 1f1d6b151b..062fec3f77 100644 --- a/docs/developer-docs/smart-contracts/maintain/resource-limits.mdx +++ b/docs/developer-docs/smart-contracts/maintain/resource-limits.mdx @@ -10,7 +10,7 @@ import { Tooltip } from "/src/components/Tooltip/Tooltip"; -## Overview + The Internet Computer uses WebAssembly as the platform for executing messages of smart contracts. Since WebAssembly is [Turing-complete](https://en.wikipedia.org/wiki/Turing_completeness), it can express different kinds of computations including non-terminating computations. diff --git a/docs/developer-docs/smart-contracts/maintain/settings.mdx b/docs/developer-docs/smart-contracts/maintain/settings.mdx index 9e0efe905f..60e8a55dc4 100644 --- a/docs/developer-docs/smart-contracts/maintain/settings.mdx +++ b/docs/developer-docs/smart-contracts/maintain/settings.mdx @@ -11,7 +11,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Each canister has a group of possible settings that control its behavior. diff --git a/docs/developer-docs/smart-contracts/maintain/snapshots.mdx b/docs/developer-docs/smart-contracts/maintain/snapshots.mdx index bd4ba13384..599e6d2d8b 100644 --- a/docs/developer-docs/smart-contracts/maintain/snapshots.mdx +++ b/docs/developer-docs/smart-contracts/maintain/snapshots.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + A canister contains compiled Wasm code and data, such as the canister ID, settings, and Wasm memory. If a canister stops working as expected, traps, or simply needs to be rolled back to a previous version, the developer can use canister snapshots. Developers can take a snapshot of a stopped canister to save the canister's current stable memory, heap memory, data, and Wasm module. This snapshot can be loaded at a later date, rolling the canister back to the code and data saved within that snapshot. diff --git a/docs/developer-docs/smart-contracts/maintain/state.mdx b/docs/developer-docs/smart-contracts/maintain/state.mdx index 36f1ab4edd..534e648e28 100644 --- a/docs/developer-docs/smart-contracts/maintain/state.mdx +++ b/docs/developer-docs/smart-contracts/maintain/state.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + After you deploy a canister, it can begin receiving and processing requests from users and from other canisters. Canisters that are available to send requests and receive replies are considered in be in a **Running** state. diff --git a/docs/developer-docs/smart-contracts/maintain/storage.mdx b/docs/developer-docs/smart-contracts/maintain/storage.mdx index 19847ca6c6..be53920b36 100644 --- a/docs/developer-docs/smart-contracts/maintain/storage.mdx +++ b/docs/developer-docs/smart-contracts/maintain/storage.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + When developing projects on ICP, there are two primary forms of data storage that your canisters can utilize. The first type of storage is the canister's **heap memory**, sometimes referred to as the canister's *main memory*. Heap memory is **temporary**, and any data stored in a canister's heap memory is cleared whenever the canister is reinstalled or upgraded. diff --git a/docs/developer-docs/smart-contracts/maintain/trapping.mdx b/docs/developer-docs/smart-contracts/maintain/trapping.mdx index 4f77674b52..474cbc5979 100644 --- a/docs/developer-docs/smart-contracts/maintain/trapping.mdx +++ b/docs/developer-docs/smart-contracts/maintain/trapping.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Trapping, in the context of WebAssembly code, refers to an interruption of code execution that returns an error. Trapping is defined by [the WebAssembly documentation](https://webassembly.github.io/spec/core/intro/overview.html) as: diff --git a/docs/developer-docs/smart-contracts/maintain/upgrade.mdx b/docs/developer-docs/smart-contracts/maintain/upgrade.mdx index 86b6d53bec..aed683d785 100644 --- a/docs/developer-docs/smart-contracts/maintain/upgrade.mdx +++ b/docs/developer-docs/smart-contracts/maintain/upgrade.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Unlike a canister reinstall that preserves the canister identifier but no state, a canister upgrade enables you to preserve the state of a deployed canister and change the code. diff --git a/docs/developer-docs/smart-contracts/overview/trust-in-canisters.mdx b/docs/developer-docs/smart-contracts/overview/trust-in-canisters.mdx index 3c65c7ee6a..6035c6219f 100644 --- a/docs/developer-docs/smart-contracts/overview/trust-in-canisters.mdx +++ b/docs/developer-docs/smart-contracts/overview/trust-in-canisters.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Applications that provide DeFi or other valuable transactions, such as the ability to transfer assets, require that users trust the application to act honestly and reliably. How can one ensure that it is safe to entrust assets to a canister? diff --git a/docs/developer-docs/smart-contracts/signatures/signing-messages-t-ecdsa.mdx b/docs/developer-docs/smart-contracts/signatures/signing-messages-t-ecdsa.mdx index 562ee12ae6..240f9ec7e2 100644 --- a/docs/developer-docs/smart-contracts/signatures/signing-messages-t-ecdsa.mdx +++ b/docs/developer-docs/smart-contracts/signatures/signing-messages-t-ecdsa.mdx @@ -13,7 +13,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The threshold ECDSA API allows canisters to securely sign messages and transactions without the corresponding private keys ever existing. Each canister can control an unlimited number of keys by specifying different key `derivation_path`s. The API provides two methods: diff --git a/docs/developer-docs/smart-contracts/signatures/signing-messages-t-schnorr.mdx b/docs/developer-docs/smart-contracts/signatures/signing-messages-t-schnorr.mdx index cf0145cc47..dc1caa918c 100644 --- a/docs/developer-docs/smart-contracts/signatures/signing-messages-t-schnorr.mdx +++ b/docs/developer-docs/smart-contracts/signatures/signing-messages-t-schnorr.mdx @@ -12,7 +12,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The threshold Schnorr API allows canisters to securely sign messages and transactions without the corresponding private keys ever existing. Each canister can control an unlimited number of keys by specifying different key `derivation_path`s and `key_id`s. diff --git a/docs/developer-docs/smart-contracts/signatures/t-ecdsa.mdx b/docs/developer-docs/smart-contracts/signatures/t-ecdsa.mdx index 4bca0319e1..ec6e029d66 100644 --- a/docs/developer-docs/smart-contracts/signatures/t-ecdsa.mdx +++ b/docs/developer-docs/smart-contracts/signatures/t-ecdsa.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + The Internet Computer implements a novel threshold ECDSA protocol as part of its chain-key signatures suite. In this protocol, the private ECDSA key exists only as secret shares held by nodes. Secret shares are shards of the ECDSA private key. Signatures are computed using those secret shares without the private key ever being reconstructed. Each replica of such subnet holds a key share that provides no information on its own. More than one third of the nodes are required to generate a threshold signature using their respective key shares. Besides the actual threshold signing protocol, chain-key ECDSA is comprised of protocols for secure, distributed key generation and periodic key resharing. Distributed key generation enables the nodes on a subnet to collaboratively generate keys, while periodic key resharing allows for ECDSA keys to be re-shared within the subnet. This makes chain-key ECDSA signatures much more powerful than any off-the-shelf threshold ECDSA protocol. diff --git a/docs/developer-docs/smart-contracts/signatures/t-schnorr.mdx b/docs/developer-docs/smart-contracts/signatures/t-schnorr.mdx index d936176e99..9516dca689 100644 --- a/docs/developer-docs/smart-contracts/signatures/t-schnorr.mdx +++ b/docs/developer-docs/smart-contracts/signatures/t-schnorr.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Schnorr signatures are a type of digital signature scheme popularly used amongst blockchain networks because they are efficient, simple, and allow for multi-signatures, threshold signatures, and aggregated signatures to be used on the network. On ICP, threshold Schnorr signatures enable canisters to hold a wider range of digital assets and allow for direct integrations with other chains like Solana. diff --git a/docs/developer-docs/smart-contracts/test/pocket-ic.mdx b/docs/developer-docs/smart-contracts/test/pocket-ic.mdx index 9f0a76e226..eed7a4ecdd 100644 --- a/docs/developer-docs/smart-contracts/test/pocket-ic.mdx +++ b/docs/developer-docs/smart-contracts/test/pocket-ic.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + PocketIC is a lightweight, deterministic testing solution for programmatic testing of canisters. It seamlessly integrates with existing testing infrastructure, such as `cargo test`, and runs as a standalone binary that doesn't require additional containers or virtual machines. diff --git a/docs/developer-docs/smart-contracts/topping-up/cycles_management_services.mdx b/docs/developer-docs/smart-contracts/topping-up/cycles_management_services.mdx index 378ac9766b..609c412605 100644 --- a/docs/developer-docs/smart-contracts/topping-up/cycles_management_services.mdx +++ b/docs/developer-docs/smart-contracts/topping-up/cycles_management_services.mdx @@ -5,7 +5,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Once a canister is deployed to the Internet Computer, the compute and storage it utilizes must be pre-paid. The process of burning ICP to obtain cycles and transferring them to a canister is referred to as "topping up" a canister. diff --git a/docs/developer-docs/smart-contracts/topping-up/topping-up-canister.mdx b/docs/developer-docs/smart-contracts/topping-up/topping-up-canister.mdx index 7cc81e5220..8d997a3609 100644 --- a/docs/developer-docs/smart-contracts/topping-up/topping-up-canister.mdx +++ b/docs/developer-docs/smart-contracts/topping-up/topping-up-canister.mdx @@ -9,7 +9,7 @@ import { AdornedTab } from "/src/components/Tabs/AdornedTab"; -## Overview + A canister needs to have cycles deposited continuously into it to pay for the resources it uses. This process is known as 'topping up' the canister. Topping up canisters is routine maintenance. diff --git a/docs/developer-docs/web-apps/application-frontends/add-stylesheet.mdx b/docs/developer-docs/web-apps/application-frontends/add-stylesheet.mdx index 253f721793..001d328aa6 100644 --- a/docs/developer-docs/web-apps/application-frontends/add-stylesheet.mdx +++ b/docs/developer-docs/web-apps/application-frontends/add-stylesheet.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + [Cascading stylesheets (CSS)](https://www.w3schools.com/css/default.asp) are an important part of any frontend user interface. The default project template is configured to include a basic stylesheet that you can edit, but you may prefer to import your own custom stylesheet or use an alternate format. This guide illustrates how to style the [default frontend canister](default-frontend.mdx) using SCSS, the default format used by `dfx new` when creating React frontend canisters. diff --git a/docs/developer-docs/web-apps/application-frontends/asset-security.mdx b/docs/developer-docs/web-apps/application-frontends/asset-security.mdx index 58f20eb929..eedc9b0625 100644 --- a/docs/developer-docs/web-apps/application-frontends/asset-security.mdx +++ b/docs/developer-docs/web-apps/application-frontends/asset-security.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + You can configure how a frontend canister responds to requests for specific assets by defining your desired configuration in a file named `.ic-assets.json` Each entry in `.ic-assets.json` allows for specifying a [glob](https://code.visualstudio.com/docs/editor/glob-patterns) pattern along with the headers to be returned in the response for any file that matches the pattern. You may also dictate whether redirects are performed from the non-certified endpoint to a certified endpoint for any given filename pattern. diff --git a/docs/developer-docs/web-apps/application-frontends/default-frontend.mdx b/docs/developer-docs/web-apps/application-frontends/default-frontend.mdx index 92c7acb6e3..e38c8b07a9 100644 --- a/docs/developer-docs/web-apps/application-frontends/default-frontend.mdx +++ b/docs/developer-docs/web-apps/application-frontends/default-frontend.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Dapps may have complex frontends that serve dynamic, interactive interfaces, or they can serve simple, static webpages such as HTML and CSS pages. diff --git a/docs/developer-docs/web-apps/application-frontends/existing-frontend.mdx b/docs/developer-docs/web-apps/application-frontends/existing-frontend.mdx index af258f87a7..fefab9b8ae 100644 --- a/docs/developer-docs/web-apps/application-frontends/existing-frontend.mdx +++ b/docs/developer-docs/web-apps/application-frontends/existing-frontend.mdx @@ -10,7 +10,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + While numerous starter projects and examples exist for those who prefer to start from scratch, deploying an existing frontend application as a frontend canister is also a viable option for building an application on ICP. diff --git a/docs/developer-docs/web-apps/application-frontends/webpack.mdx b/docs/developer-docs/web-apps/application-frontends/webpack.mdx index 06227f9a54..b332a80bb7 100644 --- a/docs/developer-docs/web-apps/application-frontends/webpack.mdx +++ b/docs/developer-docs/web-apps/application-frontends/webpack.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Webpack is a popular and highly configurable module bundler for JavaScript-based applications. New projects created with `dfx new` that choose to create a default JavaScript frontend include a default `webpack.config.js` file that makes it easy to add specific modules such as `react` and `markdown`. diff --git a/docs/developer-docs/web-apps/browser-js/js-frameworks.mdx b/docs/developer-docs/web-apps/browser-js/js-frameworks.mdx index e5714945df..f7a3923b3a 100644 --- a/docs/developer-docs/web-apps/browser-js/js-frameworks.mdx +++ b/docs/developer-docs/web-apps/browser-js/js-frameworks.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + To build user interfaces that utilize in-browser JavaScript, several frameworks can be used. diff --git a/docs/developer-docs/web-apps/custom-domains/dns-setup.mdx b/docs/developer-docs/web-apps/custom-domains/dns-setup.mdx index d5ab678687..20fee2a1bd 100644 --- a/docs/developer-docs/web-apps/custom-domains/dns-setup.mdx +++ b/docs/developer-docs/web-apps/custom-domains/dns-setup.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This guide explains how to configure the DNS records of your domain for three popular registrars: [Namecheap](#namecheap), [GoDaddy](#godaddy), and [Amazon Route 53](#amazonroute53). diff --git a/docs/developer-docs/web-apps/custom-domains/using-custom-domains.mdx b/docs/developer-docs/web-apps/custom-domains/using-custom-domains.mdx index 0935e24fa8..ec7800d8fe 100644 --- a/docs/developer-docs/web-apps/custom-domains/using-custom-domains.mdx +++ b/docs/developer-docs/web-apps/custom-domains/using-custom-domains.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + By default, all canisters on the Internet Computer are accessible through the domain `icp0.io` and their canister ID. In addition to that default domain, one diff --git a/docs/developer-docs/web-apps/frameworks/juno.mdx b/docs/developer-docs/web-apps/frameworks/juno.mdx index 9e59d5d148..8c1213adff 100644 --- a/docs/developer-docs/web-apps/frameworks/juno.mdx +++ b/docs/developer-docs/web-apps/frameworks/juno.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Juno is a cutting-edge blockchain-as-a-service platform designed to enable developers to create decentralized applications at lightning speed. It can be thought of as an innovative, open-source alternative to Google Firebase, but with the added benefits of the Internet Computer technology. diff --git a/docs/developer-docs/web-apps/independently-verifying-ic-signatures.mdx b/docs/developer-docs/web-apps/independently-verifying-ic-signatures.mdx index 4136775964..5720384933 100644 --- a/docs/developer-docs/web-apps/independently-verifying-ic-signatures.mdx +++ b/docs/developer-docs/web-apps/independently-verifying-ic-signatures.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Calls made on ICP require a cryptographic `signature` and `principal` to be included within the call. This is typically attached in the form of an identity. This identity can either be authenticated or anonymous. Canisters use this identity to respond to the call and process authentication-based workflows. diff --git a/docs/references/dashboard/dashboard-apis.mdx b/docs/references/dashboard/dashboard-apis.mdx index 56e70d76f7..96c689c165 100644 --- a/docs/references/dashboard/dashboard-apis.mdx +++ b/docs/references/dashboard/dashboard-apis.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + ## IC API diff --git a/docs/references/dashboard/using-the-dashboard.mdx b/docs/references/dashboard/using-the-dashboard.mdx index 306b4ec3a5..ec84e027f2 100644 --- a/docs/references/dashboard/using-the-dashboard.mdx +++ b/docs/references/dashboard/using-the-dashboard.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + The ICP dashboard is a graphical user interface that can be used to obtain detailed data about the ICP network architecture, canisters deployed on the network, tokenomics and token transactions, and information about each active SNS. Data displayed by the dashboard can also be obtained through one of several [data APIs](dashboard-apis.mdx). This page will detail using the graphic user interface to obtain different data. diff --git a/docs/references/ingress-messages.mdx b/docs/references/ingress-messages.mdx index 525f9c9417..9bcd5c91ce 100644 --- a/docs/references/ingress-messages.mdx +++ b/docs/references/ingress-messages.mdx @@ -8,9 +8,9 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview -Ingress messages are requests to ICP canisters that are sent by external entities, such as users, usually through an [agent](/docs/current/developer-docs/developer-tools/dev-tools-overview/#agents) like [agent-js](https://github.com/dfinity/agent-js/tree/main) that runs within a web application, or [agent-rs](https://github.com/dfinity/agent-rs/tree/main) in a Rust application. See also the introductory [call overview](/docs/current/developer-docs/smart-contracts/call/overview). + +Ingress messages are requests to ICP canisters that are sent by external entities, such as users, usually through an [agent](/docs/current/developer-docs/developer-tools/dev-tools-overview/#agents) like [agent-js](https://github.com/dfinity/agent-js/tree/main) that runs within a web application, or [agent-rs](https://github.com/dfinity/agent-rs/tree/main) in a Rust application. See also the introductory [call overview](/docs/current/developer-docs/smart-contracts/call/overview). For example, you can browse what ingress messages can be sent to the ckBTC ledger by browsing through its [API using the dashboard](https://dashboard.internetcomputer.org/canister/mxzaz-hqaaa-aaaar-qaada-cai). The tool also allows you to send messages, using agent-js behind the scenes. @@ -18,27 +18,27 @@ This page discusses ICP's ingress message APIs. While these APIs are defined in ## Types of ingress messages -ICP supports several types of calls, as defined in the [HTTPS interface specification](/docs/current/references/ic-interface-spec#http-interface). These include query and update calls. +ICP supports several types of calls, as defined in the [HTTPS interface specification](/docs/current/references/ic-interface-spec#http-interface). These include query and update calls. ## Query calls -Queries don't modify a canister's state and are answered and signed by a single replica. Responses can be obtained within milliseconds, but they are typically not signed by the subnet, meaning a malicious replica or boundary node could arbitrarily modify the response. +Queries don't modify a canister's state and are answered and signed by a single replica. Responses can be obtained within milliseconds, but they are typically not signed by the subnet, meaning a malicious replica or boundary node could arbitrarily modify the response. -Some applications may have higher authenticity requirements for query responses. For example, if a dapp queries a proposal description that the user then votes on, it may not be acceptable that the result could be tampered with, as it could trick users to vote in the attacker's favor. As an alternative, you can issue query calls as update calls instead. While that's easy to implement, it makes the calls significantly slower. +Some applications may have higher authenticity requirements for query responses. For example, if a dapp queries a proposal description that the user then votes on, it may not be acceptable that the result could be tampered with, as it could trick users to vote in the attacker's favor. As an alternative, you can issue query calls as update calls instead. While that's easy to implement, it makes the calls significantly slower. Another alternative approach is to sign the data beforehand and provide *certified variables* (see [tutorial](/docs/current/tutorials/developer-journey/level-3/3.3-certified-data/), [security best practices](/docs/current/developer-docs/security/security-best-practices/data-integrity-and-authenticity#certified-variables)) in query responses. While this approach has better performance than sending query calls as update calls, it can be complex to implement depending on the specific use case. An example where certified variables are used is within the [HTTP asset certification](/docs/current/developer-docs/security/security-best-practices/data-integrity-and-authenticity#use-http-asset-certification-and-avoid-serving-your-dapp-through-rawicp0io). -Error handling for queries is typically simple: on error, one can simply retry until a successful response is received. +Error handling for queries is typically simple: on error, one can simply retry until a successful response is received. ## Update calls Updates can modify a canister's state and thus must go through consensus, typically taking 1-3 seconds. They return certified responses (signed by the subnet), providing authenticity within the subnet's corruption bounds. -Update calls can be [synchronous](/docs/current/references/ic-interface-spec#http-sync-call-overview) or [asynchronous](/docs/current/references/ic-interface-spec#http-async-call-overview). +Update calls can be [synchronous](/docs/current/references/ic-interface-spec#http-sync-call-overview) or [asynchronous](/docs/current/references/ic-interface-spec#http-async-call-overview). -A [synchronous `call`](https://internetcomputer.org/docs/current/references/ic-interface-spec#http-call) follows the "call and await" pattern. In the success case, it maintains the HTTPS connection until a certified response is produced, as illustrated below. +A [synchronous `call`](https://internetcomputer.org/docs/current/references/ic-interface-spec#http-call) follows the "call and await" pattern. In the success case, it maintains the HTTPS connection until a certified response is produced, as illustrated below. ![Dev containers 1](./_attachments/ingress_sync_call.png) -Compared to the [asynchronous `call`](/docs/current/references/ic-interface-spec#http-async-call) endpoint, where the [`read_state`](/docs/current/references/ic-interface-spec#http-read-state) endpoint is used to poll for the request status and obtain the reply, the synchronous endpoint removes the need to poll for the response in the success case. +Compared to the [asynchronous `call`](/docs/current/references/ic-interface-spec#http-async-call) endpoint, where the [`read_state`](/docs/current/references/ic-interface-spec#http-read-state) endpoint is used to poll for the request status and obtain the reply, the synchronous endpoint removes the need to poll for the response in the success case. However, a response may not be produced until some implementation-specific timeout is reached. In that case, the synchronous endpoint behaves like the asynchronous one: it returns a `202` response, and the client must poll [`read_state`](/docs/current/references/ic-interface-spec#http-read-state) to get the request status and eventually obtain the reply, as illustrated below. @@ -65,7 +65,7 @@ In general, there are cases where it is impossible to determine if a call was su * The client loses its connection until the request status has been removed from the state tree. (Recall that ICP will remove the request from the system state tree some time after ingress expiry.) * There is no application specific way to tell if the call successfully executed. For example, the canister does not provide a way to find out if the call happened. -In this situation, it is indistinguishable if the call was successful, but all information has already been removed from the system state tree, or the call never made it into the state tree in the first place and hasn't been executed. +In this situation, it is indistinguishable if the call was successful, but all information has already been removed from the system state tree, or the call never made it into the state tree in the first place and hasn't been executed. ### Recommendations and best practices for secure update call handling @@ -81,13 +81,13 @@ In summary, there are two options for a client: * _No retries, only poll `read_state`:_ Submit the `call` once, and poll `read_state` until at least one of the following conditions is met: * A certified response was produced. That is, the call status is `replied`, `rejected`, or `done`. * The subnet time exceeds`ingress_expiry`, and the call status is not `processing`. - - Evaluating the second condition may be hard if the subnet time and local time of the user differ. -* _Retry the call while polling `read_state`_ Do the same as above, but resubmit the initial `call` (same `request_id`) periodically (e.g. every `30s`) until at least one of the following conditions is met: + + Evaluating the second condition may be hard if the subnet time and local time of the user differ. +* _Retry the call while polling `read_state`_ Do the same as above, but resubmit the initial `call` (same `request_id`) periodically (e.g. every `30s`) until at least one of the following conditions is met: * The call is known to the system. That is, the call status is `received`, `processing`, `replied`, `rejected`, or `done`. * `ingress_expiry` is reached. - This can be beneficial because a call that didn’t make it is retried. For example, if the first call was dropped due to a network issue or by a malicious replica, a subsequent call could make it through e.g. if it is successfully routed to an honest replica. + This can be beneficial because a call that didn’t make it is retried. For example, if the first call was dropped due to a network issue or by a malicious replica, a subsequent call could make it through e.g. if it is successfully routed to an honest replica. At the time of writing, both agent-js (v2.1.3) and agent-rs (v0.39.1) don't retry `call`, so they follow the first option above. By default, both agent-rs and agent-js use `ingress_expiry` of four minutes and poll for five minutes. Additionally, agent-rs resets the timer to allow for an additional five minutes of polling whenever it observes a `received` or `processing` status. diff --git a/docs/references/ledger.mdx b/docs/references/ledger.mdx index 84e3e5c4d4..745e1a153e 100644 --- a/docs/references/ledger.mdx +++ b/docs/references/ledger.mdx @@ -4,7 +4,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This document is a specification of the public interface of the ledger canister. It provides an overview of the functionality, details some internal aspects, and documents publicly available methods. It also provides an abstract mathematical model precisely describing the expected behavior of the methods implemented by the canister, albeit at a somewhat high level of abstraction. :::info diff --git a/docs/references/node-providers/node-metrics.mdx b/docs/references/node-providers/node-metrics.mdx index 25938d2e03..5508acbfe6 100644 --- a/docs/references/node-providers/node-metrics.mdx +++ b/docs/references/node-providers/node-metrics.mdx @@ -9,7 +9,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + ICP publishes node metrics publicly and provides an observability stack to collect, inspect, and analyze these metrics. By publishing these metrics worldwide, anyone can monitor the health of ICP nodes, therefore decentralizing the monitoring process, ensuring that more nodes stay healthy, and decreasing the amount of time it takes to resolve any issues. This feature provides increased overall transparency and a more stable network. diff --git a/docs/references/subnets/overview.mdx b/docs/references/subnets/overview.mdx index 095ac85589..8197d5833b 100644 --- a/docs/references/subnets/overview.mdx +++ b/docs/references/subnets/overview.mdx @@ -9,7 +9,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -## Overview + Internet Computer **subnet blockchains** are formed by a number of independently owned and controlled high-performance hardware devices called **node machines**, that run the Internet Computer Protocol (ICP). diff --git a/docs/references/subnets/subnet-types.mdx b/docs/references/subnets/subnet-types.mdx index a72f319c06..b59dc9c315 100644 --- a/docs/references/subnets/subnet-types.mdx +++ b/docs/references/subnets/subnet-types.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + A subnet on ICP is a collection of interacting replicas that run their own, separate instance of the ICP consensus mechanism, effectively creating their own blockchain on which a set of canisters can run. Each subnet can communicate with other subnets and is controlled by a root subnet. The root subnet uses chain-key cryptography to delegate its authority to the various subnets. diff --git a/docs/references/t-sigs-how-it-works.mdx b/docs/references/t-sigs-how-it-works.mdx index 8c0b0ddbd3..81ee3874cc 100644 --- a/docs/references/t-sigs-how-it-works.mdx +++ b/docs/references/t-sigs-how-it-works.mdx @@ -4,7 +4,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + This page gives a high-level outline of threshold signatures on ICP. Some of the information in this section is not required to use threshold signing features, but may be of interest to the technically inclined reader for obtaining background information on the technology. ICP currently supports **threshold Schnorr** signing and **threshold ECDSA** signing. diff --git a/docs/references/vetkeys-overview.mdx b/docs/references/vetkeys-overview.mdx index ef6186dc09..1bdeb1f0b5 100644 --- a/docs/references/vetkeys-overview.mdx +++ b/docs/references/vetkeys-overview.mdx @@ -4,7 +4,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + vetKeys on the Internet Computer allow developers to more easily perform encryption, threshold decryption, and signing when building dapps on ICP. It is powered by a protocol called **vetKD (Verifiably Encrypted Threshold Key Derivation)** that allows to derive decryption keys on demand. ## Key derivation on demand diff --git a/docs/tutorials/developer-journey/index.mdx b/docs/tutorials/developer-journey/index.mdx index 5dcaa7c73b..10230161b3 100644 --- a/docs/tutorials/developer-journey/index.mdx +++ b/docs/tutorials/developer-journey/index.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Are you ready to get started developing on the Internet Computer, but not sure where to begin? diff --git a/docs/tutorials/developer-journey/level-0/01-ic-overview.mdx b/docs/tutorials/developer-journey/level-0/01-ic-overview.mdx index cbfb3be778..2fbfaf8116 100644 --- a/docs/tutorials/developer-journey/level-0/01-ic-overview.mdx +++ b/docs/tutorials/developer-journey/level-0/01-ic-overview.mdx @@ -17,7 +17,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + The **Internet Computer Protocol (ICP)** is a secure and transparent blockchain-based network that can be used to host data and programs. Programs and their data hosted on ICP are referred to as **decentralized applications**, often abbreviated to **dapps**. diff --git a/docs/tutorials/developer-journey/level-0/02-ic-terms.mdx b/docs/tutorials/developer-journey/level-0/02-ic-terms.mdx index dcfd9fffdd..f417d1deaf 100644 --- a/docs/tutorials/developer-journey/level-0/02-ic-terms.mdx +++ b/docs/tutorials/developer-journey/level-0/02-ic-terms.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + This page introduces some of the most commonly used terminology that developers should be aware of when building on the Internet Computer. This page covers many terms, but does not include every single term that is related to the Internet Computer. [View the full glossary of terms](/docs/current/references/glossary). diff --git a/docs/tutorials/developer-journey/level-0/03-dev-env.mdx b/docs/tutorials/developer-journey/level-0/03-dev-env.mdx index 9c0d9e6fca..af0b434226 100644 --- a/docs/tutorials/developer-journey/level-0/03-dev-env.mdx +++ b/docs/tutorials/developer-journey/level-0/03-dev-env.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Before you can begin the developer ladder, you need to set up a developer environment. A developer environment consists of tools and packages that are required to develop code projects. Usually, developer environments are stored and hosted on your local computer, but there are some situations where a virtual, web-based development environment exists. diff --git a/docs/tutorials/developer-journey/level-0/04-intro-canisters.mdx b/docs/tutorials/developer-journey/level-0/04-intro-canisters.mdx index ef433d13b7..fa4e0d0eee 100644 --- a/docs/tutorials/developer-journey/level-0/04-intro-canisters.mdx +++ b/docs/tutorials/developer-journey/level-0/04-intro-canisters.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Smart contracts on the Internet Computer are known as **canisters**. A canister contains both the source code and software state. A canister's source code is compiled into a WebAssembly module and is associated with a module of stable memory. diff --git a/docs/tutorials/developer-journey/level-0/05-intro-languages.mdx b/docs/tutorials/developer-journey/level-0/05-intro-languages.mdx index 64942b9790..a04a9cc819 100644 --- a/docs/tutorials/developer-journey/level-0/05-intro-languages.mdx +++ b/docs/tutorials/developer-journey/level-0/05-intro-languages.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + When developing canisters, the most common development workflow is to use a software development kit (SDK). The Internet Computer SDK is the most commonly used, which natively supports Motoko and Rust out of the box. diff --git a/docs/tutorials/developer-journey/level-0/06-intro-dfx.mdx b/docs/tutorials/developer-journey/level-0/06-intro-dfx.mdx index 9363851f66..210fae6a31 100644 --- a/docs/tutorials/developer-journey/level-0/06-intro-dfx.mdx +++ b/docs/tutorials/developer-journey/level-0/06-intro-dfx.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + `dfx` is a command line utility that is used to interact with the IC SDK. It is the primary tool that is used for creating, managing, and deploying dapps onto the Internet Computer. diff --git a/docs/tutorials/developer-journey/level-1/1.1-live-demo.mdx b/docs/tutorials/developer-journey/level-1/1.1-live-demo.mdx index 45048c1422..017705d09a 100644 --- a/docs/tutorials/developer-journey/level-1/1.1-live-demo.mdx +++ b/docs/tutorials/developer-journey/level-1/1.1-live-demo.mdx @@ -18,7 +18,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + In the previous segment of our developer ladder, introduction to `dfx`, you created a new `dfx` project using the default 'Hello, world' template and looked into the project's structure and code. However, you didn't build or deploy the canister. diff --git a/docs/tutorials/developer-journey/level-1/1.2-motoko-lvl1.mdx b/docs/tutorials/developer-journey/level-1/1.2-motoko-lvl1.mdx index 1bd3fa8fe4..6b7b929bd4 100644 --- a/docs/tutorials/developer-journey/level-1/1.2-motoko-lvl1.mdx +++ b/docs/tutorials/developer-journey/level-1/1.2-motoko-lvl1.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Motoko is a programming language that has been developed and optimized for creating programs built on the Internet Computer. In this module, you'll cover the fundamental basics of Motoko that you'll use when you build your [first dapp](/docs/current/tutorials/developer-journey/level-1/1.3-first-dapp). diff --git a/docs/tutorials/developer-journey/level-1/1.3-first-dapp.mdx b/docs/tutorials/developer-journey/level-1/1.3-first-dapp.mdx index 6c600cf950..a379ea86b7 100644 --- a/docs/tutorials/developer-journey/level-1/1.3-first-dapp.mdx +++ b/docs/tutorials/developer-journey/level-1/1.3-first-dapp.mdx @@ -21,7 +21,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; The video corresponding to this tutorial is outdated and follows a different project structure than what is written on this page. ::: -## Overview + At this point in your developer ladder, you've covered the fundamentals of canister development and deployed the default 'Hello, world' project template on the playground. It's time to get into writing code and developing your first dapp! diff --git a/docs/tutorials/developer-journey/level-1/1.4-using-cycles.mdx b/docs/tutorials/developer-journey/level-1/1.4-using-cycles.mdx index 3e860517f8..96c3dae404 100644 --- a/docs/tutorials/developer-journey/level-1/1.4-using-cycles.mdx +++ b/docs/tutorials/developer-journey/level-1/1.4-using-cycles.mdx @@ -17,7 +17,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + If you recall from the previous module, [Internet Computer terminology](/docs/current/tutorials/developer-journey/level-0/ic-terms), cycles are used to measure the resources, such as memory, storage, and compute power, that are used by a canister. When a canister is deployed on the mainnet, cycles are 'charged' for every action that a canister performs. diff --git a/docs/tutorials/developer-journey/level-1/1.5-deploying-canisters.mdx b/docs/tutorials/developer-journey/level-1/1.5-deploying-canisters.mdx index a7908ef799..7ab9e695e4 100644 --- a/docs/tutorials/developer-journey/level-1/1.5-deploying-canisters.mdx +++ b/docs/tutorials/developer-journey/level-1/1.5-deploying-canisters.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Now that you have some cycles to pay for your canister's resources, you can deploy your dapp on the mainnet. When a canister is deployed to the mainnet, it's code will be hosted on the nodes that make up one of the mainnet's subnets. The canister will be hosted on these nodes until it is manually uninstalled by the developer, or until it runs out of cycles and is uninstalled automatically. diff --git a/docs/tutorials/developer-journey/level-1/1.6-managing-canisters.mdx b/docs/tutorials/developer-journey/level-1/1.6-managing-canisters.mdx index ed868ae122..7f42a0653f 100644 --- a/docs/tutorials/developer-journey/level-1/1.6-managing-canisters.mdx +++ b/docs/tutorials/developer-journey/level-1/1.6-managing-canisters.mdx @@ -16,7 +16,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Now that you have canisters deployed on the mainnet, the next step is to learn how to manage those canisters. Managing a canister includes workflows such as obtaining information, setting an identity as the canister's owner, and deleting a canister. You'll dive into these different workflows and more in this guide to assure that you have the core fundamentals of how to maintain canisters. diff --git a/docs/tutorials/developer-journey/level-2/2.1-storage-persistence.mdx b/docs/tutorials/developer-journey/level-2/2.1-storage-persistence.mdx index 1fdb682f73..c2e42f03e2 100644 --- a/docs/tutorials/developer-journey/level-2/2.1-storage-persistence.mdx +++ b/docs/tutorials/developer-journey/level-2/2.1-storage-persistence.mdx @@ -18,7 +18,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + The Internet Computer handles persistent data storage using a feature known as **stable memory**. **Stable memory** is a unique feature of the Internet Computer that defines a data store separate from the canister's regular Wasm memory data store, which is known as **heap memory**. A canister's heap memory is not persistent storage and does not persist across canister upgrades; canister data and state stored in heap memory is removed when a canister is upgraded or reinstalled. For immutable canisters that use less than the heap memory limit of 4GiB, heap memory can be used. For larger canisters, and especially those that intend to be upgraded and changed over time, stable memory is important since it persists across canister upgrades, has a much larger storage capacity than heap memory, and is very beneficial for vertically scaling a dapp. diff --git a/docs/tutorials/developer-journey/level-2/2.2-advanced-canister-calls.mdx b/docs/tutorials/developer-journey/level-2/2.2-advanced-canister-calls.mdx index a33395e8bb..bda989a24a 100644 --- a/docs/tutorials/developer-journey/level-2/2.2-advanced-canister-calls.mdx +++ b/docs/tutorials/developer-journey/level-2/2.2-advanced-canister-calls.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + In the previous tutorial where you [created your first dapp](/docs/current/tutorials/developer-journey/level-1/1.3-first-dapp), the developer ladder briefly discussed query and update canister calls. In this tutorial, you'll dive deeper into these types of canister calls, but also take a look at advanced canister calls such as composite queries, certified variables, and inter-canister calls. diff --git a/docs/tutorials/developer-journey/level-2/2.3-third-party-canisters.mdx b/docs/tutorials/developer-journey/level-2/2.3-third-party-canisters.mdx index 08f6bb4838..16861819eb 100644 --- a/docs/tutorials/developer-journey/level-2/2.3-third-party-canisters.mdx +++ b/docs/tutorials/developer-journey/level-2/2.3-third-party-canisters.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Third-party canisters are canisters that provide a public service at a static canister ID. Some examples are the DFINITY NNS and Internet Identity canisters, but third-party canisters can also be made by community developers. Using third-party canisters can be a good way to add additional functionalities to your dapp. For example, by integrating the Internet Identity canister into your dapp, you can enable identity and authentication for the users of your application. diff --git a/docs/tutorials/developer-journey/level-2/2.4-intro-candid.mdx b/docs/tutorials/developer-journey/level-2/2.4-intro-candid.mdx index aff7247042..1c8e6f9821 100644 --- a/docs/tutorials/developer-journey/level-2/2.4-intro-candid.mdx +++ b/docs/tutorials/developer-journey/level-2/2.4-intro-candid.mdx @@ -16,7 +16,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Candid is an interface description language that is used to describe the public interface of a service. A **service** is usually in the form of an application deployed as a canister on ICP. Public interfaces of canisters are used to interact with the canister. Candid supports interactions through the IC SDK via the terminal, through a web browser, or through the use of agents. It also provides a way to specify input argument values and display return values from different canister **methods**, regardless of the manner used to interact with the canister. Recall that a method is a piece of code specifying a task which declares a sequence of arguments and their associated result types. diff --git a/docs/tutorials/developer-journey/level-2/2.5-unit-testing.mdx b/docs/tutorials/developer-journey/level-2/2.5-unit-testing.mdx index 2f17abc20b..b5978d14bc 100644 --- a/docs/tutorials/developer-journey/level-2/2.5-unit-testing.mdx +++ b/docs/tutorials/developer-journey/level-2/2.5-unit-testing.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + Testing code is an important stage of any development workflow. Without proper testing before the code is put into production, bugs and errors that may have been caught during testing can be detrimental to production environments. At this point of the developer ladder, it's time to explore tools that can be used to test our code. diff --git a/docs/tutorials/developer-journey/level-2/2.6-motoko-lvl2.mdx b/docs/tutorials/developer-journey/level-2/2.6-motoko-lvl2.mdx index fd256620d3..8e47fd8fe9 100644 --- a/docs/tutorials/developer-journey/level-2/2.6-motoko-lvl2.mdx +++ b/docs/tutorials/developer-journey/level-2/2.6-motoko-lvl2.mdx @@ -15,7 +15,7 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip";
-## Overview + As you've seen so far, **actors** are at the core functionality of canisters written in Motoko. In this tutorial, you'll explore actors further by taking a look at actor type definitions, how actors interact with async data, actor classes, and using multiple actors. diff --git a/docs/tutorials/developer-journey/level-3/3.1-package-managers.mdx b/docs/tutorials/developer-journey/level-3/3.1-package-managers.mdx index 62aa662f97..6dbfb4e5b1 100644 --- a/docs/tutorials/developer-journey/level-3/3.1-package-managers.mdx +++ b/docs/tutorials/developer-journey/level-3/3.1-package-managers.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + [Mops](https://mops.one) and [Vessel](https://github.com/dfinity/vessel) are package managers for Motoko. In this guide, you'll explore how to download and install Mops and Vessel, then how to import and use different libraries that have been downloaded through a package manager. diff --git a/docs/tutorials/developer-journey/level-3/3.2-https-outcalls.mdx b/docs/tutorials/developer-journey/level-3/3.2-https-outcalls.mdx index 2252d3bf31..e6d789527e 100644 --- a/docs/tutorials/developer-journey/level-3/3.2-https-outcalls.mdx +++ b/docs/tutorials/developer-journey/level-3/3.2-https-outcalls.mdx @@ -15,7 +15,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + In the past, blockchain networks were only able to communicate with external servers through blockchain oracles, or third-party entities that relayed calls from the blockchain to an external server, then routed the response back to the blockchain. This is because blockchains are a form of replicated state machine, where each replica must perform the same computations within the same state to make the same transitions each round. Since doing computations with results from an external source may lead to a state divergence, tools like oracles have been used in the past. However, on the Internet Computer, canisters can communicate directly with external servers or other blockchains through **HTTPS outcalls**. diff --git a/docs/tutorials/developer-journey/level-3/3.3-certified-data.mdx b/docs/tutorials/developer-journey/level-3/3.3-certified-data.mdx index 54cf4234af..eb4ae0ea39 100644 --- a/docs/tutorials/developer-journey/level-3/3.3-certified-data.mdx +++ b/docs/tutorials/developer-journey/level-3/3.3-certified-data.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + In a previous module, [2.2: Advanced canister calls](/docs/current/tutorials/developer-journey/level-2/2.2-advanced-canister-calls), you briefly touched on certified variables. In this guide, you'll dive deeper into certified data and take a look at an example that displays how to use certified data. diff --git a/docs/tutorials/developer-journey/level-3/3.4-intro-to-agents.mdx b/docs/tutorials/developer-journey/level-3/3.4-intro-to-agents.mdx index f69860c7a2..aab45fa174 100644 --- a/docs/tutorials/developer-journey/level-3/3.4-intro-to-agents.mdx +++ b/docs/tutorials/developer-journey/level-3/3.4-intro-to-agents.mdx @@ -16,7 +16,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + When you have a canister running, either locally or on the mainnet, you have two primary ways for interacting with the canister: using the API through an agent, or using the canister's HTTP interface. On the Internet Computer, an **agent** is a library used to make calls to ICP's public interface. diff --git a/docs/tutorials/developer-journey/level-3/3.5-identities-and-auth.mdx b/docs/tutorials/developer-journey/level-3/3.5-identities-and-auth.mdx index 74e931c1e3..6fd7e2758b 100644 --- a/docs/tutorials/developer-journey/level-3/3.5-identities-and-auth.mdx +++ b/docs/tutorials/developer-journey/level-3/3.5-identities-and-auth.mdx @@ -16,7 +16,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + When developing on the Internet Computer, there are several types of identities and methods of authentication that you'll encounter. In the previous module where you obtained a cycles coupon, [1.4: acquiring and using cycles](/docs/current/tutorials/developer-journey/level-1/1.4-using-cycles), you created a **developer identity** that has a **cycles balance**. You also looked at how to convert ICP tokens stored in a **ledger account** into cycles. diff --git a/docs/tutorials/developer-journey/level-3/3.6-motoko-lvl3.mdx b/docs/tutorials/developer-journey/level-3/3.6-motoko-lvl3.mdx index 1381c7e081..f9f08b5d75 100644 --- a/docs/tutorials/developer-journey/level-3/3.6-motoko-lvl3.mdx +++ b/docs/tutorials/developer-journey/level-3/3.6-motoko-lvl3.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + In the previous module, [3.5: Identities and authentication](/docs/current/tutorials/developer-journey/level-3/3.5-identities-and-auth) you covered different forms of identities and authentication on ICP. In this Motoko level, you'll look into caller identification, adding access control with identities, plus other non-identity related functionalities such as pattern matching and periodic tasks. diff --git a/docs/tutorials/developer-journey/level-4/4.1-icp-ledger.mdx b/docs/tutorials/developer-journey/level-4/4.1-icp-ledger.mdx index 1de4aa6288..c1b8565efd 100644 --- a/docs/tutorials/developer-journey/level-4/4.1-icp-ledger.mdx +++ b/docs/tutorials/developer-journey/level-4/4.1-icp-ledger.mdx @@ -17,7 +17,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + Recall from previous modules that ICP is the native token of the Internet Computer. ICP tokens have three key functionalities on the Internet Computer: diff --git a/docs/tutorials/developer-journey/level-4/4.2-icrc-tokens.mdx b/docs/tutorials/developer-journey/level-4/4.2-icrc-tokens.mdx index a23fdeb212..bfaafa4075 100644 --- a/docs/tutorials/developer-journey/level-4/4.2-icrc-tokens.mdx +++ b/docs/tutorials/developer-journey/level-4/4.2-icrc-tokens.mdx @@ -16,7 +16,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + For developers to create their own fungible tokens on the Internet Computer, the ICRC-1 token standard can be used. The acronym "ICRC" stands for "Internet Computer Request for Comments", as the standard was created by the Internet Computer working group. [Learn more about the working group](https://github.com/dfinity/ICRC). diff --git a/docs/tutorials/developer-journey/level-4/4.3-ckbtc-and-bitcoin.mdx b/docs/tutorials/developer-journey/level-4/4.3-ckbtc-and-bitcoin.mdx index 38d44f0ecb..ca751d9313 100644 --- a/docs/tutorials/developer-journey/level-4/4.3-ckbtc-and-bitcoin.mdx +++ b/docs/tutorials/developer-journey/level-4/4.3-ckbtc-and-bitcoin.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + One of the key features of the Internet Computer is known as **chain-key cryptography**. Chain-key cryptography is a feature that encompasses several cryptographic mechanisms that enable novel workflows and functionalities such as chain-key tokens. Chain-key tokens are not wrapped tokens; they are twin tokens that are backed 1:1 with the original token (BTC, ETH) that use chain-key cryptography to transfer and use the original tokens with less fees and higher transfer speeds than using the token's native blockchain network. diff --git a/docs/tutorials/developer-journey/level-4/4.4-nns-governance.mdx b/docs/tutorials/developer-journey/level-4/4.4-nns-governance.mdx index c50a3b4068..3dde42c03c 100644 --- a/docs/tutorials/developer-journey/level-4/4.4-nns-governance.mdx +++ b/docs/tutorials/developer-journey/level-4/4.4-nns-governance.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + When blockchain networks need to be upgraded, traditionally they use a method known as a 'hard fork', which involves substantial work and manual coordination. In comparison, the Internet Computer upgrades itself weekly, which can be seen on the [ICP dashboard](https://dashboard.internetcomputer.org/releases). diff --git a/docs/tutorials/developer-journey/level-4/4.5-using-quill.mdx b/docs/tutorials/developer-journey/level-4/4.5-using-quill.mdx index 35f5ba8437..b643d26f23 100644 --- a/docs/tutorials/developer-journey/level-4/4.5-using-quill.mdx +++ b/docs/tutorials/developer-journey/level-4/4.5-using-quill.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + Now that you've covered both the ICP ledger and the NNS, it's time to take a look at a CLI tool that can be used to interact with both. Quill is a ledger and governance toolkit that provides support for self-custody of ICP or ckBTC tokens and functionality to interact with the NNS, SNSs, and ICP ledger from a **cold wallet**. diff --git a/docs/tutorials/developer-journey/level-4/4.6-motoko-lvl4.mdx b/docs/tutorials/developer-journey/level-4/4.6-motoko-lvl4.mdx index 6a306ce0eb..9bfa1fb679 100644 --- a/docs/tutorials/developer-journey/level-4/4.6-motoko-lvl4.mdx +++ b/docs/tutorials/developer-journey/level-4/4.6-motoko-lvl4.mdx @@ -14,7 +14,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow";
-## Overview + In this final Motoko module of the developer ladder series, you'll cover the following Motoko concepts and components: diff --git a/docs/tutorials/developer-journey/level-5/5.1-vetKeys-tutorial.mdx b/docs/tutorials/developer-journey/level-5/5.1-vetKeys-tutorial.mdx index 15aa03d90e..d6bd8394d3 100644 --- a/docs/tutorials/developer-journey/level-5/5.1-vetKeys-tutorial.mdx +++ b/docs/tutorials/developer-journey/level-5/5.1-vetKeys-tutorial.mdx @@ -16,7 +16,7 @@ import '/src/components/CenterImages/center.scss';
-## Overview + Many types of applications rely on secure ways to store user data and keep certain aspects of the dapp private. On a blockchain, transactions are traditionally public and dapps might rely on the storage within a web browser to store user-side secrets, which can lead to potential security risks. diff --git a/docs/tutorials/developer-journey/level-5/5.2-ICP-ETH-tutorial.mdx b/docs/tutorials/developer-journey/level-5/5.2-ICP-ETH-tutorial.mdx index 16c6e83584..01fda73be0 100644 --- a/docs/tutorials/developer-journey/level-5/5.2-ICP-ETH-tutorial.mdx +++ b/docs/tutorials/developer-journey/level-5/5.2-ICP-ETH-tutorial.mdx @@ -17,7 +17,7 @@ import useBaseUrl from "@docusaurus/useBaseUrl";
-## Overview + As you explored in a previous tutorial, the Internet Computer is integrated with the Bitcoin network, allowing for smart contracts to seamlessly communicate from ICP to Bitcoin for multi-chain functionality. ICP also has an integration with Ethereum and EVM networks, but in a different manner than the Bitcoin integration. diff --git a/docs/tutorials/developer-journey/level-5/5.3-token-swap-tutorial.mdx b/docs/tutorials/developer-journey/level-5/5.3-token-swap-tutorial.mdx index 3cb68ccaf7..e15f34f64b 100644 --- a/docs/tutorials/developer-journey/level-5/5.3-token-swap-tutorial.mdx +++ b/docs/tutorials/developer-journey/level-5/5.3-token-swap-tutorial.mdx @@ -17,7 +17,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + The Internet Computer enables decentralized finance (DeFi) applications through its design that includes complex, onchain computation. One primary example of a DeFi application is a decentralized exchange (DEX). A DEX is an exchange that can be used to buy, sell, trade, and withdraw cryptocurrencies and other digital assets without a centralized authority that authorizes the trades, such as bank. Decentralized exchanges are extremely useful, as they allow users to buy and hold cryptocurrencies, trade it directly for another token or coin, then withdraw the tokens to be used elsewhere. diff --git a/docs/tutorials/developer-journey/level-5/5.4-NFT-tutorial.mdx b/docs/tutorials/developer-journey/level-5/5.4-NFT-tutorial.mdx index 3b994efeae..27de1e93bd 100644 --- a/docs/tutorials/developer-journey/level-5/5.4-NFT-tutorial.mdx +++ b/docs/tutorials/developer-journey/level-5/5.4-NFT-tutorial.mdx @@ -17,7 +17,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + A **non-fungible token**, commonly referred to as an NFT, is a type of tokenized asset that is assigned a unique identifier that is used to distinguish one NFT from another. An NFT cannot be replicated or reproduced since it is cryptographically unique. A non-fungible token is a type of token that cannot be exchanged 1:1 with another token of the same type, as the value of the NFT token can vary. In comparison, a **fungible** token can always be transferred 1:1 for another token of the same type. diff --git a/docs/tutorials/developer-journey/level-5/5.5-auction-tutorial.mdx b/docs/tutorials/developer-journey/level-5/5.5-auction-tutorial.mdx index 4de9493fde..94bf2fa02e 100644 --- a/docs/tutorials/developer-journey/level-5/5.5-auction-tutorial.mdx +++ b/docs/tutorials/developer-journey/level-5/5.5-auction-tutorial.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Until this point in the developer ladder series, each tutorial has focused on a specific use case or feature of ICP. To wrap up the series, this tutorial will showcase how to create a general purpose dapp that provides a real-world use case. In this tutorial, you'll create the foundation for a simple auction dapp. diff --git a/docs/tutorials/developer-journey/level-5/5.6-next-steps.mdx b/docs/tutorials/developer-journey/level-5/5.6-next-steps.mdx index 7f54573111..851341cfa6 100644 --- a/docs/tutorials/developer-journey/level-5/5.6-next-steps.mdx +++ b/docs/tutorials/developer-journey/level-5/5.6-next-steps.mdx @@ -8,7 +8,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -## Overview + Congratulations! You've completed the ICP developer ladder series, and are now an ICP astronaut! diff --git a/docs/tutorials/hackathon-prep-course/1-what-is-icp.mdx b/docs/tutorials/hackathon-prep-course/1-what-is-icp.mdx index 9414129a0d..3b7683e0e4 100644 --- a/docs/tutorials/hackathon-prep-course/1-what-is-icp.mdx +++ b/docs/tutorials/hackathon-prep-course/1-what-is-icp.mdx @@ -11,7 +11,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + The Internet Computer (ICP) is a transparent and secure blockchain network that enables developers to create and deploy fully decentralized applications. Decentralized applications are created through deploying smart contracts, which are known as **canisters** on ICP. Canisters are highly scalable to directly serve user experiences. Each canister on the Internet Computer is hosted on an independent version of the blockchain network called a **subnet**. **Subnets** can seamlessly communicate with each other. diff --git a/docs/tutorials/hackathon-prep-course/2-deploying-first-fullstack-dapp.mdx b/docs/tutorials/hackathon-prep-course/2-deploying-first-fullstack-dapp.mdx index 4fa745910c..1278f842b1 100644 --- a/docs/tutorials/hackathon-prep-course/2-deploying-first-fullstack-dapp.mdx +++ b/docs/tutorials/hackathon-prep-course/2-deploying-first-fullstack-dapp.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + To get started developing on ICP, there are several sample projects, boilerplate templates, and other resources to help you get started. In this tutorial, you'll learn how to deploy your first full-stack dapp using a boilerplate sample. This sample dapp uses Motoko for the backend canister and the frameworks Vite and React to create a frontend user interface (UI) that makes calls to a simple counter method in the backend canister. When the button in the UI is clicked, the counter function increases the value of the count by an increment of 1. The updated count value is then reflected in the UI. diff --git a/docs/tutorials/hackathon-prep-course/3-exploring-the-backend.mdx b/docs/tutorials/hackathon-prep-course/3-exploring-the-backend.mdx index db07240115..a3db8e4d6f 100644 --- a/docs/tutorials/hackathon-prep-course/3-exploring-the-backend.mdx +++ b/docs/tutorials/hackathon-prep-course/3-exploring-the-backend.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + In the previous tutorial, you deployed a sample full-stack dapp using the `vite-react-motoko` example boilerplate. This tutorial builds off of that previous tutorial, so if you haven't followed [2: Deploying your first fullstack dapp](/docs/current/tutorials/hackathon-prep-course/deploying-first-fullstack-dapp), it is recommended that you complete it prior to starting this tutorial. diff --git a/docs/tutorials/hackathon-prep-course/4-exploring-the-frontend.mdx b/docs/tutorials/hackathon-prep-course/4-exploring-the-frontend.mdx index ee79c07349..810e950c97 100644 --- a/docs/tutorials/hackathon-prep-course/4-exploring-the-frontend.mdx +++ b/docs/tutorials/hackathon-prep-course/4-exploring-the-frontend.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Recall that a frontend canister is used to contain an application's user interface assets. In this tutorial, you will explore the frontend canister code to learn more. diff --git a/docs/tutorials/hackathon-prep-course/5-integrating-with-tokens.mdx b/docs/tutorials/hackathon-prep-course/5-integrating-with-tokens.mdx index 42cf363818..766bfb62d4 100644 --- a/docs/tutorials/hackathon-prep-course/5-integrating-with-tokens.mdx +++ b/docs/tutorials/hackathon-prep-course/5-integrating-with-tokens.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + When building dapps on the Internet Computer, integrating tokens into your dapp may be necessary for enabling DeFi, governance, marketplace, or other tokenomic functions. There are several types of tokens in the Internet Computer ecosystem, such as the protocol's native token ICP, fungible tokens that use the ICRC-1 or ICRC-2 standards, and soon non-fungible tokens that will use the upcoming ICRC-7 standard. diff --git a/docs/tutorials/hackathon-prep-course/6-authentication.mdx b/docs/tutorials/hackathon-prep-course/6-authentication.mdx index 97018a6c74..0d66d44f30 100644 --- a/docs/tutorials/hackathon-prep-course/6-authentication.mdx +++ b/docs/tutorials/hackathon-prep-course/6-authentication.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + For end-users to interact with the frontend of applications on ICP, Internet Identity can be used. Internet Identity is ICP's native form of digital identity that can be used to authenticate with apps, such as the NNS dashboard, without having to manage a username or password. Instead, Internet Identity uses a cryptographic key pair that's stored in your local device's hardware. diff --git a/docs/tutorials/hackathon-prep-course/7-obtaining-cycles.mdx b/docs/tutorials/hackathon-prep-course/7-obtaining-cycles.mdx index e21cbc9fae..b0350eb8f9 100644 --- a/docs/tutorials/hackathon-prep-course/7-obtaining-cycles.mdx +++ b/docs/tutorials/hackathon-prep-course/7-obtaining-cycles.mdx @@ -11,7 +11,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Cycles are used to measure the resources, such as memory, storage, and compute power, that are used by a canister. When a canister is deployed on the mainnet, cycles are 'charged' for every action that a canister performs. diff --git a/docs/tutorials/hackathon-prep-course/8-managing-canisters.mdx b/docs/tutorials/hackathon-prep-course/8-managing-canisters.mdx index 2aff9956de..423e42763f 100644 --- a/docs/tutorials/hackathon-prep-course/8-managing-canisters.mdx +++ b/docs/tutorials/hackathon-prep-course/8-managing-canisters.mdx @@ -10,7 +10,7 @@ import '/src/components/CenterImages/center.scss'; -## Overview + Now that you have canisters deployed on the mainnet, it's important to learn how to manage and maintain those canisters. Basic canister management includes obtaining information about a canister, adding an identity as a controller of a canister, topping up a canister, starting and stopping a canister, and deleting a canister. From d1059361d4b64aeb773c957ce3a372fd107063f0 Mon Sep 17 00:00:00 2001 From: radudiaconescu <139108402+radudiaconescu@users.noreply.github.com> Date: Tue, 10 Dec 2024 06:26:33 +0100 Subject: [PATCH 04/10] Update showcase.json (#3654) Edit Catalyze entry (link and minor edit on description) Co-authored-by: Jennifer K. Tran <38402540+jennifertrin@users.noreply.github.com> --- showcase.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/showcase.json b/showcase.json index e3f835c8a8..b14d487ae5 100644 --- a/showcase.json +++ b/showcase.json @@ -334,13 +334,13 @@ { "id": "catalyze", "name": "Catalyze", - "website": "https://aqs24-xaaaa-aaaal-qbbea-cai.ic0.app/", + "website": "https://catalyze.one/", "tags": [ "SocialFi", "DAO" ], + "description": "Catalyze is building the new Web3 social learning hub: Communities, Events & Seamless Token Transfer, all in one place.", "twitter": "https://x.com/catalyze_one", - "description": "Catalyze is building the new Web3 social learning hub: Communities, Events & Seamless Token Transfer. Now onboarding KOLs.", "usesInternetIdentity": true, "oneLiner": "Manage your Web3 communities and events", "display": "Large", From 9c616d7873d26b24c386e5aeadb5b18b3ce30b50 Mon Sep 17 00:00:00 2001 From: raymondk Date: Tue, 10 Dec 2024 09:38:26 -0500 Subject: [PATCH 05/10] fix: Link HTTPS outcalls to the https outcalls overview page (#3872) --- docs/developer-docs/multi-chain/overview.mdx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/developer-docs/multi-chain/overview.mdx b/docs/developer-docs/multi-chain/overview.mdx index 13de2a38d2..4a1352fd7f 100644 --- a/docs/developer-docs/multi-chain/overview.mdx +++ b/docs/developer-docs/multi-chain/overview.mdx @@ -434,7 +434,7 @@ There are several building blocks available to augment non-ICP smart contracts w - **[Threshold signatures](/docs/current/references/t-ecdsa-how-it-works)**: An ICP service implementing the threshold ECDSA and threshold Schnorr protocols. -- **[HTTPS outcalls](/docs/current/developer-docs/security/security-best-practices/https-outcalls)**: Replicated calls into external web services. +- **[HTTPS outcalls](/docs/current/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-overview)**: Replicated calls into external web services. - **[Bitcoin API](/docs/current/references/bitcoin-how-it-works)**: A protocol API that allows canisters to interact with the Bitcoin blockchain directly. @@ -442,4 +442,4 @@ There are several building blocks available to augment non-ICP smart contracts w - [ICP Chain Fusion Educate - Bitcoin Edition: Introduction to ICP and Chain Fusion](https://www.youtube.com/watch?v=A0K9GXsfw74&list=PLfEHHr3qexv_L0t6KrCyJ-l2ZaHaO-m85). -- [ICP Chain Fusion Educate Powered by Encode Club](https://www.youtube.com/playlist?list=PLfEHHr3qexv9bjbFNp3ItK7yBZ5IQVXjf). \ No newline at end of file +- [ICP Chain Fusion Educate Powered by Encode Club](https://www.youtube.com/playlist?list=PLfEHHr3qexv9bjbFNp3ItK7yBZ5IQVXjf). From d77ef99c2467022bcfd8f5e5c8564d6a1d4a4f10 Mon Sep 17 00:00:00 2001 From: Jessie Mongeon <133128541+jessiemongeon1@users.noreply.github.com> Date: Tue, 10 Dec 2024 09:45:25 -0600 Subject: [PATCH 06/10] fix: http_request_update (#3868) * Update handling-get-post-requests.mdx * Update handling-get-post-requests.mdx --- .../advanced-features/handling-get-post-requests.mdx | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx b/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx index 77f35791f0..a739b45263 100644 --- a/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx +++ b/docs/developer-docs/smart-contracts/advanced-features/handling-get-post-requests.mdx @@ -110,13 +110,9 @@ For outgoing HTTP requests, the [HTTPS outcalls](./https-outcalls/https-outcalls ## Incoming HTTP requests -To handle incoming HTTP requests, canisters must define methods for `http_requests` and `http_requests_update` for `GET` and `POST` requests respectively. +Every HTTP request first goes to `http_request`, and only if you return `upgrade: true` will it be upgraded and re-called as `http_request_update`. The HTTP method (`GET`, `POST`) does not matter. -All HTTP requests are handled by the ICP HTTP Gateway, therefore you cannot make direct `POST` calls to a canister's `http_request_update` method with HTTP clients such as curl. Instead, you can make a `POST` call to a canister's HTTP endpoint, then configure the canister's `http_request` method to [upgrade the call to `http_request_update` if necessary](/docs/current/references/http-gateway-protocol-spec#upgrade-to-update-calls). Below is an example `POST` call to a canister's endpoint: - -``` -curl -X POST -H "Content-Type: application/json" -d '{"key":"value"}' https://.raw.ic0.app/ -``` +View the [HTTP Candid interface reference](/docs/current/references/http-gateway-protocol-spec#canister-http-interface) for more information. ## `GET` requests @@ -152,7 +148,9 @@ Check out the [Rust documentation](https://docs.rs/ic-cdk/latest/ic_cdk/attr.que ## `POST` requests -HTTP `POST` requests are used to send data to an endpoint with the intention of retaining that data. To handle incoming `POST` requests, the `http_request_update` method can be used. This method uses an `update` call, which can be used to change a canister's state. The following examples display how to configure `http_request_update` method within your canister. +HTTP `POST` requests are used to send data to an endpoint with the intention of retaining that data. You cannot make direct `POST` calls to a canister's `http_request_update` method with HTTP clients such as curl. Instead, you can make a `POST` call to a canister's HTTP endpoint, then configure the canister's `http_request` method to [upgrade the call to `http_request_update`](/docs/current/references/http-gateway-protocol-spec#upgrade-to-update-calls). + +The following examples display how to configure `http_request_update` method within your canister. From 573aa9572b3549e3b37cc3b82c40740cbae0b6cf Mon Sep 17 00:00:00 2001 From: Jessie Mongeon <133128541+jessiemongeon1@users.noreply.github.com> Date: Tue, 10 Dec 2024 10:52:04 -0600 Subject: [PATCH 07/10] fix: WSL install instructions (#3870) * fix wsl instrucs * fix wsl instrucs --- docs/developer-docs/getting-started/install.mdx | 2 ++ .../quickstart/first-smart-contract.mdx | 13 ++++++++++++- .../getting-started/quickstart/react-quickstart.mdx | 13 ++++++++++++- 3 files changed, 26 insertions(+), 2 deletions(-) diff --git a/docs/developer-docs/getting-started/install.mdx b/docs/developer-docs/getting-started/install.mdx index 3cf308c95e..192f198f8f 100644 --- a/docs/developer-docs/getting-started/install.mdx +++ b/docs/developer-docs/getting-started/install.mdx @@ -86,6 +86,8 @@ dfx --version #### Prerequisites +`dfx` is not natively supported on Windows. You will need to install a Linux instance via Windows Subsystem for Linux and run all commands within that Linux instance. + Download and install Windows Subsystem for Linux.
diff --git a/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx b/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx index de2e03f105..05ca775b97 100644 --- a/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx +++ b/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx @@ -111,10 +111,21 @@ project. #### Prerequisites +`dfx` is not natively supported on Windows. You will need to install a Linux instance via Windows Subsystem for Linux and run all commands within that Linux instance. + Download and install Windows Subsystem for Linux.
- Download and install Node.js within your WSL environment. + Open a WSL terminal window. +
+
+ Download and install a Linux distribution (i.e., Ubuntu) using Windows Subsystem for Linux: wsl --install -d ubuntu +
+
+ Open the WSL Linux environment. Run all following commands within this environment. +
+
+ Download and install Node.js within your WSL Linux environment. --------- diff --git a/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx b/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx index 9926b2d3a5..a014f52bd3 100644 --- a/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx +++ b/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx @@ -66,10 +66,21 @@ dfx --version #### Prerequisites +`dfx` is not natively supported on Windows. You will need to install a Linux instance via Windows Subsystem for Linux and run all commands within that Linux instance. + Download and install Windows Subsystem for Linux.
- Download and install Node.js within your WSL environment. + Open a WSL terminal window. +
+
+ Download and install a Linux distribution (i.e., Ubuntu) using Windows Subsystem for Linux: wsl --install -d ubuntu +
+
+ Open the WSL Linux environment. Run all following commands within this environment. +
+
+ Download and install Node.js within your WSL Linux environment. --------- From 18a5085e2728af9a771819d504d327266506617b Mon Sep 17 00:00:00 2001 From: Jessie Mongeon <133128541+jessiemongeon1@users.noreply.github.com> Date: Wed, 11 Dec 2024 13:59:47 -0600 Subject: [PATCH 08/10] update: new page headings (#3869) * new headings * adjust * Update docs/developer-docs/getting-started/quickstart/react-quickstart.mdx * Update identities.mdx * Update deploy-and-manage.mdx * Update react-quickstart.mdx * Update deploy-and-manage.mdx --- .../defi/tokens/token-standards.mdx | 6 +- .../getting-started/deploy-and-manage.mdx | 30 +-- .../getting-started/deploy/local.mdx | 235 ------------------ .../getting-started/deploy/mainnet.mdx | 186 -------------- .../getting-started/deploy/testnet.mdx | 83 ------- .../getting-started/explore-examples.mdx | 5 +- .../getting-started/identities.mdx | 12 +- .../getting-started/install.mdx | 6 +- .../getting-started/next-steps.mdx | 20 -- .../quickstart/first-smart-contract.mdx | 2 +- .../quickstart/react-quickstart.mdx | 4 +- .../getting-started/tokens-and-cycles.mdx | 10 +- .../getting-started/troubleshooting.mdx | 2 - .../getting-started/write-smart-contracts.mdx | 28 +-- sidebars.js | 17 +- 15 files changed, 44 insertions(+), 602 deletions(-) delete mode 100644 docs/developer-docs/getting-started/deploy/local.mdx delete mode 100644 docs/developer-docs/getting-started/deploy/mainnet.mdx delete mode 100644 docs/developer-docs/getting-started/deploy/testnet.mdx delete mode 100644 docs/developer-docs/getting-started/next-steps.mdx diff --git a/docs/developer-docs/defi/tokens/token-standards.mdx b/docs/developer-docs/defi/tokens/token-standards.mdx index d93cb5ead8..7dbbe456a2 100644 --- a/docs/developer-docs/defi/tokens/token-standards.mdx +++ b/docs/developer-docs/defi/tokens/token-standards.mdx @@ -20,7 +20,7 @@ In the past, the [DIP-721](#dip-721) standard was promoted and used by projects ### How standards are created -- The [ICRC working group](https://github.com/dfinity/ICRC) creates an initial proposal for an ICRC standard. +- The [ICRC working group](https://github.com/dfinity/ICRC) creates an initial proposal for an ICRC standard. - The proposal is agreed upon through a rough consensus of the working group as a starting point for the standard. @@ -28,13 +28,13 @@ In the past, the [DIP-721](#dip-721) standard was promoted and used by projects - Once the proposal is deemed ready for implementation by the working group, it is proposed to the NNS through an NNS proposal. -- The ICRC standard is either adopted or rejected by the NNS. +- The ICRC standard is either adopted or rejected by the NNS. ## ICP tokens The ICP token is the network's native token used for various utility and governance functions, such as: -- Paying for a canister's resources by being converted into cycles. +- Using tokens and cycles by being converted into cycles. - Rewarding node providers for contributing resources to the network. diff --git a/docs/developer-docs/getting-started/deploy-and-manage.mdx b/docs/developer-docs/getting-started/deploy-and-manage.mdx index 4aeea36a88..d1fbfb890f 100644 --- a/docs/developer-docs/getting-started/deploy-and-manage.mdx +++ b/docs/developer-docs/getting-started/deploy-and-manage.mdx @@ -10,17 +10,15 @@ import { BetaChip } from "/src/components/Chip/BetaChip"; import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -# Deploy and manage +# Deploying and managing canisters - - Once a canister's code has been written, it must be compiled into Wasm, installed into the canister itself, and then deployed to a network. The `dfx deploy` command executes each of these tasks as part of the deployment process; however, `dfx` commands also exist for running each step individually. It is recommended to deploy canisters locally or to the temporary [playground](/docs/current/developer-docs/smart-contracts/deploy/overview#deploying-to-playground) network to test canister functionality and make adjustments before considering the canister production-ready and deploying it to the mainnet. Deploying canisters locally and to the playground is free and does not cost cycles. Once a canister is deployed to the mainnet, it will consistently consume cycles and will need to be topped up periodically. -## Start the local replica +## Starting the local replica To deploy your canister locally, first start the local replica. This simulates the mainnet environment with a single node for local development and testing. @@ -29,7 +27,7 @@ To deploy your canister locally, first start the local replica. This simulates t - `dfx start --background`: Runs the processes in the background and allows you to continue running commands in the current terminal. -## Deploy locally +## Deploying the project locally Deploy the backend canister that you have written code for: @@ -73,7 +71,7 @@ Your deployed canister will now be executing two timers and printing the output You can interact with the canister's public methods either in your web browser through the [Candid UI](/docs/current/developer-docs/smart-contracts/candid/candid-concepts) URL that was returned in the deployment output or using the command line. Candid is an interface description language used to interact with a canister's public methods. -## Upgrades +## Upgrading canisters Canisters can be upgraded, allowing the same canister ID to be retained for an application. Upgrades preserve the state of a canister while allowing you to change the code. However, canister upgrades clear the canister's Wasm memory. Any data not stored in [stable memory](/docs/current/developer-docs/smart-contracts/maintain/storage) will be removed. @@ -106,7 +104,7 @@ Confirm that the change you made results in the expected functionality or behavi dfx canister stop PROJECT_NAME_backend --network=local ``` -## Deploy to the mainnet +## Deploying your project to the mainnet Now that the canister has been tested, you can deploy it to the mainnet. **Deploying to the mainnet costs [cycles](/docs/current/developer-docs/getting-started/tokens-and-cycles).** @@ -142,7 +140,7 @@ URLs: When a canister is running on the mainnet, you will always need to pass the `--network=ic` flag to interact with it. ::: -## Settings +## Canister settings After a canister is deployed to the mainnet, it will constantly be consuming resources and cycles. To view information about how many resources and cycles currently being used, along with other information, view the canister's settings: @@ -210,7 +208,7 @@ Log visibility: controllers -## Topping up +## Topping up canisters A canister will burn cycles even in an idle state to pay for the network storage it uses. Additional costs will be charged whenever the canister sends and receives messages, uses compute resources, or uses special features like HTTPS outcalls and threshold signatures. @@ -236,7 +234,7 @@ Manually monitoring canisters to determine when they are getting close to the fr - [ICPTopup.com](https://www.icptopup.com/): A simplified version of CycleOps that allows you to top up several canisters (up to 50) at one time. -### Freezing threshold +### Cycles freezing threshold To prevent a canister from running out of cycles and being deleted, you can set what is known as a **freezing threshold**. This threshold is a duration of time set in seconds, indicating the minimum duration that the canister should exist without running out of cycles. Once a canister hits this threshold, it will not execute messages. It will only pay for the network resources it uses, such as compute allocation, memory usage, and storage allocation. @@ -251,7 +249,7 @@ If you set a freezing threshold longer than 1.5 years, you will need to include ::: -## Logging +## Canister logging [Canister logs](/docs/current/developer-docs/smart-contracts/maintain/logs) can be used to gain insight into a canister's behavior and assist with debugging situations such as when a canister traps. @@ -267,7 +265,7 @@ By default, canister logs are only visible to the canister's controllers, but th dfx canister update-settings PROJECT_NAME_backend --network=ic --log-visibility public ``` -## Snapshots +## Canister snapshots Canister snapshots are used as a checkpoint that can be used to roll back your canister to a previous version in the event that the latest upgraded version becomes unresponsive or stops working as expected. @@ -329,16 +327,12 @@ Any cycles remaining in the canister's balance will be returned to your develope dfx canister delete PROJECT_NAME_backend --network=ic ``` -## Stopping `dfx` +## Stopping the local replica -To stop `dfx`, simply use the `dfx stop` command. +To stop the local replica, simply use the `dfx stop` command. For unresponsive `dfx` processes that are not stopped by `dfx stop`, you can use `dfx killall` to forcibly end them. ## Getting help To view help information for `dfx`, you can use the `dfx help` command or view the [`dfx` reference documentation](/docs/current/developer-docs/developer-tools/cli-tools/cli-reference/). - -## Next steps - -- [x] View the [developer next steps](/docs/current/developer-docs/getting-started/next-steps). diff --git a/docs/developer-docs/getting-started/deploy/local.mdx b/docs/developer-docs/getting-started/deploy/local.mdx deleted file mode 100644 index fa4cde87ed..0000000000 --- a/docs/developer-docs/getting-started/deploy/local.mdx +++ /dev/null @@ -1,235 +0,0 @@ ---- -keywords: [beginner, tutorial, local deployment, deploy] ---- - - -import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; - - -# Local deployment - - - - - -When developing canisters and projects, it is recommended to first deploy your project to the local development environment. This is so you can fabricate cycles in your local development environment, which you cannot do on the mainnet. Cycles are charged for the resources used by your canister. [Learn more about cycles](/docs/current/developer-docs/gas-cost). - -Deploying to your local development environment is similar to deploying to a testnet. ICP does not have a testnet available for developers to deploy to. Instead, the IC SDK runs a local version of the ICP node software known as the **replica** and provides a single-node environment on your local machine for you to deploy canisters to. - -## Prerequisites - -Before you create your first canister, verify the following: - --   [x] You have an internet connection and access to a shell terminal on your local computer. - --   [x] You have `Node.js` `16.0.0` or newer installed if you want to include the default template files for frontend development in your project. - --   [x] You have downloaded and installed the IC SDK package as described in the [installing the IC SDK](/docs/current/developer-docs/getting-started/install/) page. - -## Start the local deployment - -Before you can build your first project, you need to connect to the local replica. As a best practice, this step requires you to have **two terminal shells** open, so that you can start and see canister execution operations in one terminal and manage your project in another. - -To prepare the local replica: - -- #### Step 1:  Open a new second terminal window or tab on your local computer. - -- #### Step 2:  Navigate to the root directory for your project, if necessary. - -You should now have **two terminals** open with your **project directory** as your **current working directory** in both terminals. - -- #### Step 3:  Start the local replica on your computer in your second terminal by running the following command: - -``` -dfx start -``` - -Depending on your platform and local security settings, you might see a warning displayed. If you are prompted to allow or deny incoming network connections, click **Allow**. - -- #### Step 4:  Leave the terminal window that displays canister execution operations open and switch your focus to the first terminal window where you created your new project. - -You should perform the remaining steps in the terminal that doesn’t display canister execution operations. - -## Register, build, and deploy the application - -After you connect to the local canister execution environment, you can register, build, and deploy your dapp locally. - -To deploy your first canister locally: - -- #### Step 1:  Check that you are still in the root directory for your project, if needed. - -It is recommended to follow the [creating your first canister](/docs/current/developer-docs/getting-started/default-template) guide to have a simple 'Hello, world!' canister ready to deploy. - -- #### Step 2:  Ensure that `node` modules are available in your project directory, if needed, by running the following command: - -``` -npm install -``` - -For more information about this step, see [ensuring node is available in a project](/docs/current/developer-docs/getting-started/install/#nodejs-is-not-properly-installed). - -- #### Step 3:  Register, build, and deploy your first dapp by running the following command: - -``` -dfx deploy -``` - -The `dfx deploy` command output displays information about the operations it performs. For example, this step registers two identifiers. One is for the `hello_backend` main program, and the other is for the `hello_frontend` frontend user interface and installation information similar to the following: - -``` -Creating a wallet canister on the local network. -The wallet canister on the "local" network for user "mainnet" is "rwlgt-iiaaa-aaaaa-aaaaa-cai" -Deploying all canisters. -Creating canisters... -Creating canister hello_backend... -hello_backend canister created with canister id: rrkah-fqaaa-aaaaa-aaaaq-cai -Creating canister hello_frontend... -hello_frontend canister created with canister id: ryjl3-tyaaa-aaaaa-aaaba-cai -Building canisters... -Building frontend... -Installing canisters... -Creating UI canister on the local network. -The UI canister on the "local" network is "r7inp-6aaaa-aaaaa-aaabq-cai" -Installing code for canister hello_backend, with canister ID rrkah-fqaaa-aaaaa-aaaaq-cai -Installing code for canister hello_frontend, with canister ID ryjl3-tyaaa-aaaaa-aaaba-cai -Uploading assets to asset canister... -Starting batch. -Staging contents of new and changed assets: -  /sample-asset.txt 1/1 (24 bytes) -  /logo2.svg 1/1 (15139 bytes) -  /index.js.map 1/1 (681670 bytes) -  /index.js.map (gzip) 1/1 (156940 bytes) -  /favicon.ico 1/1 (15406 bytes) -  /main.css 1/1 (537 bytes) -  /main.css (gzip) 1/1 (297 bytes) -  /index.html 1/1 (690 bytes) -  /index.html (gzip) 1/1 (386 bytes) -  /index.js (gzip) 1/1 (152884 bytes) -  /index.js 1/1 (637230 bytes) -Committing batch. -Deployed canisters. -URLs: -  Frontend canister via browser -    hello_frontend: http://127.0.0.1:4943/?canisterId=ryjl3-tyaaa-aaaaa-aaaba-cai -  Backend canister via Candid interface: -    hello_backend: http://127.0.0.1:4943/?canisterId=r7inp-6aaaa-aaaaa-aaabq-cai&id=rrkah-fqaaa-aaaaa-aaaaq-cai -``` - -If you create a project with a different name, however, your canister names will match your project name instead of `hello_backend` and `hello_frontend`. - -## Call the canister from the CLI - -Call the `hello_backend` canister and the predefined `greet` function by running the following command: - -``` -dfx canister call hello_backend greet everyone -``` - -Let’s take a closer look at this example command: - --   The `dfx canister call` command requires you to specify a canister name and a method or function to call. - --   `hello_backend` specifies the name of the **canister** you want to call. - --   `greet` specifies the name of the **function** you want to call in the `hello` canister. - --   `everyone` is the text data type argument that you want to pass to the `greet` function. - -Remember, however, that if you create a project with a different name, the canister name will match your project name, and you’ll need to modify the command line to match the name you used instead of `hello_backend`. If you were to choose `test` as the project name, your backend canister would be called `test_backend` and the frontend canister `test_frontend`. - -Verify the command displays the return value of the `greet` function. For example: - -``` -("Hello, everyone!") -``` - -## Call the canister from the browser - -It is possible to access the frontend canister directly from the browser. You will need to navigate to the URL that was printed in the output of the `dfx deploy` command (your URL might differ): - -``` -Frontend canister via browser -    hello_frontend: http://127.0.0.1:4943/?canisterId=bd3sg-teaaa-aaaaa-qaaba-cai -``` - -This will render a webpage with a form that accepts a string and sends it to the backend canister. - -The source code of the webpage is defined in the `src/hello_frontend/src/index.{html,js}` files. - -```html title="src/hello_frontend/src/index.html" - - -  -    -    -    hello -    -    -    -  -  -   
-      DFINITY logo -     
-     
-     
-        -        -        -     
-     
-   
-  - -``` - -```javascript title="src/hello_frontend/src/index.js" -import { hello_backend } from "../../declarations/hello_backend"; - -document.querySelector("form").addEventListener("submit", async (e) => { -  e.preventDefault(); -  const button = e.target.querySelector("button"); - -  const name = document.getElementById("name").value.toString(); - -  button.setAttribute("disabled", true); - -  // Interact with foo actor, calling the greet method -  const greeting = await hello_backend.greet(name); - -  button.removeAttribute("disabled"); - -  document.getElementById("greeting").innerText = greeting; - -  return false; -}); -``` - -The JavaScript code running in the browser uses the [ICP JavaScript agent](/docs/current/developer-docs/developer-tools/off-chain/agents/javascript-agent) library to interact with the backend canister. The library creates a wrapper JavaScript object based on the interface of the canister. That wrapper object provides convenience methods for calling the canister functions as if they were JavaScript functions: - -``` -const greeting = await hello_backend.greet(name); -``` - -## Stop the local canister execution environment - -After testing the application in the browser, you can stop the local canister execution environment so that it doesn’t continue running in the background. - -To stop the local deployment: - -- #### Step 1:  In the terminal that displays the development server, press Control-C to interrupt the development server process. - -- #### Step 2:  In the terminal that displays canister execution operations, press Control-C to interrupt the local network process. - -- #### Step 3:  Stop the local replica running on your local computer by running the following command: - -``` -dfx stop -``` - -## Next steps - -Next, you can deploy your canister on the playground. - -- [Testnet deployment](/docs/current/developer-docs/getting-started/deploy/testnet) \ No newline at end of file diff --git a/docs/developer-docs/getting-started/deploy/mainnet.mdx b/docs/developer-docs/getting-started/deploy/mainnet.mdx deleted file mode 100644 index de8e60cf48..0000000000 --- a/docs/developer-docs/getting-started/deploy/mainnet.mdx +++ /dev/null @@ -1,186 +0,0 @@ ---- -keywords: [beginner, tutorial, mainnet deployment, deploy] ---- - -import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; - - -# Mainnet deployment - - - - - -To make your canister available to others, you must deploy it to the mainnet. - -If you are only deploying projects in a local development environment, see the [local development](/docs/current/developer-docs/getting-started/deploy/local) scenario. - -## Prerequisites - -Before you download and install this release of the IC SDK, verify the following: - -- [x] You have an internet connection and access to a shell terminal on your local computer. - -- [x] You have `Node.js` `16.0.0` or newer installed if you want to access the default frontend for the default project. - -- [x] You have ICP tokens or cycles available for you to use. - -:::info -You must have **cycles** available to complete this guide. To get cycles, you must either convert ICP tokens to cycles or be provided cycles from another source, for example, from a canister controlled by another developer or from a third-party cycles provider. This guide assumes that you have an account with ICP tokens available and illustrates how to convert ICP tokens into cycles. - -For information about how to get ICP tokens, see [how you can get ICP tokens](/docs/current/developer-docs/defi/cycles/converting_icp_tokens_into_cycles). - -For an introduction to using the Network Nervous System application to manage ICP tokens, see [Network Nervous System dapp quickstart](/docs/current/developer-docs/daos/nns/using-the-nns-dapp/nns-app-quickstart). -::: - -## Check the connection to the mainnet - -There is a reserved network alias that you can use to access the mainnet. The network alias is a system setting that’s defined internally, so there’s nothing you need to configure in your projects by default. - -To check your connection to ICP: - -- #### Step 1: Check that you are in the root directory for your project, if needed. - -- #### Step 2: Check the current status of ICP and your ability to connect to it by running the following command for the network alias `ic`: - -``` -dfx ping ic -``` - -- #### Step 3: Verify that the `dfx ping ic` command returns information about ICP. - - For example, you should see output similar to the following: -``` -{ - "ic_api_version": "0.18.0" "impl_hash": "d639545e0f38e075ad240fd4ec45d4eeeb11e1f67a52cdd449cd664d825e7fec" "impl_version": "8dc1a28b4fb9605558c03121811c9af9701a6142" "replica_health_status": "healthy" "root_key": [48, 129, 130, 48, 29, 6, 13, 43, 6, 1, 4, 1, 130, 220, 124, 5, 3, 1, 2, 1, 6, 12, 43, 6, 1, 4, 1, 130, 220, 124, 5, 3, 2, 1, 3, 97, 0, 129, 76, 14, 110, 199, 31, 171, 88, 59, 8, 189, 129, 55, 60, 37, 92, 60, 55, 27, 46, 132, 134, 60, 152, 164, 241, 224, 139, 116, 35, 93, 20, 251, 93, 156, 12, 213, 70, 217, 104, 95, 145, 58, 12, 11, 44, 197, 52, 21, 131, 191, 75, 67, 146, 228, 103, 219, 150, 214, 91, 155, 180, 203, 113, 113, 18, 248, 71, 46, 13, 90, 77, 20, 80, 95, 253, 116, 132, 176, 18, 145, 9, 28, 95, 135, 185, 136, 131, 70, 63, 152, 9, 26, 11, 170, 174] -} -``` - -## Register, build, and deploy the application - -After you have a [cycles balance](/docs/current/developer-docs/getting-started/tokens-and-cycles), you can register, build, and deploy your sample application. - -To deploy your first application on the mainnet: - -- #### Step 1: In your terminal shell, check that you are still in the root directory for your project. - -- #### Step 2: Ensure that `node` modules are available in your project directory, if needed, by running the following command: - -``` -npm install -``` - -For more information about this step, see [ensuring node is available in a project](/docs/current/developer-docs/getting-started/install). - -- #### Step 3: Register, build, and deploy your first application by running the following command: - -``` -dfx deploy --network ic -``` - -The `--network` option specifies the network alias or URL for deploying the dapp. This option is required to deploy your canister on the mainnet. - -The `dfx deploy` command output displays information about the operations it performs. - -For example, this step registers two identifiers—one for the `hello_backend` main program and one for the `hello_frontend` frontend user interface—and installation information similar to the following: - -``` -Deploying all canisters. -Creating canisters... -Creating canister "hello_backend"... -"hello" canister created on network "ic" with canister id: "5o6tz-saaaa-aaaaa-qaacq-cai" -Creating canister "hello_frontend"... -"hello_assets" canister created on network "ic" with canister id: "5h5yf-eiaaa-aaaaa-qaada-cai" -Building canisters... -Building frontend... -Installing canisters... -Installing code for canister hello_backend, with canister_id 5o6tz-saaaa-aaaaa-qaacq-cai -Installing code for canister hello_frontend, with canister_id 5h5yf-eiaaa-aaaaa-qaada-cai -Authorizing our identity (default) to the asset canister... -Uploading assets to asset canister... - /index.html 1/1 (472 bytes) - /index.html (gzip) 1/1 (314 bytes) - /index.js 1/1 (260215 bytes) - /index.js (gzip) 1/1 (87776 bytes) - /main.css 1/1 (484 bytes) - /main.css (gzip) 1/1 (263 bytes) - /sample-asset.txt 1/1 (24 bytes) - /logo.png 1/1 (25397 bytes) - /index.js.map 1/1 (842511 bytes) - /index.js.map (gzip) 1/1 (228404 bytes) - /index.js.LICENSE.txt 1/1 (499 bytes) - /index.js.LICENSE.txt (gzip) 1/1 (285 bytes) -Deployed canisters. -``` - -If you didn’t convert enough ICP tokens to cycles to complete the operation, you can add cycles to your balance by running a command similar to the following: - -``` -dfx cycles convert 1.005 --network ic -``` - -This command converts an additional `1.005` ICP tokens to cycles. The command returns output similar to the following: - -``` -Transfer sent at BlockHeight: 81520 -Canister was topped up! -``` - -- #### Step 4: Call the `hello_backend` canister and the predefined `greet` function by running the following command: - -``` -dfx canister --network ic call hello_backend greet '("everyone": text)' -``` - -Let’s take a closer look at this example: - -- Using the `--network ic` option indicates that the canister you want to call is deployed on the `ic`. The `ic` network alias is an internally-reserved alias for accessing the Internet Computer blockchain mainnet. - -- Note that the `--network ic` option must precede the operation subcommand, which, in this case, is the `dfx canister call` command. - -- The `hello_backend` argument specifies the name of the canister you want to call. - -- The `greet` argument specifies the name of the function you want to call in the `hello` canister. - -- The text string `everyone` is the argument that you want to pass to the `greet` function. - -- #### Step 5: Verify the command displays the return value of the `greet` function. For example: - -``` -("Hello, everyone!") -``` - -- #### Step 6: Rerun the `dfx cycles balance --network ic` command or refresh the browser to see your new cycle balance and recent activity. - -## Test the dapp frontend - -Now that you have verified that your dapp has been deployed and tested its operation using the command line, let’s verify that you can access the frontend using your web browser. - -To access the dapp frontend: - -- #### Step 1: Open a browser. - -- #### Step 2: Navigate to the frontend for the dapp using a URL that consists of the `hello_frontend` identifier and the `boundary.icp0.io` suffix. - -If you didn’t make a note of the canister identifier, you can look it up by running the following command: - -``` -dfx canister --network ic id hello_assets -``` - -For example, the full URL should look similar to the following: - -``` -https://gsueu-yaaaa-aaaae-aaagq-cai.icp0.io -``` - -Navigating to this URL displays the HTML entry page for the template application. For example: - - - -- #### Step 3: Type a greeting, then click **Click Me** to return the greeting. - -## Next steps - -Want to go further? [Start the developer journey series](/docs/current/tutorials/developer-journey/). diff --git a/docs/developer-docs/getting-started/deploy/testnet.mdx b/docs/developer-docs/getting-started/deploy/testnet.mdx deleted file mode 100644 index cf980def0d..0000000000 --- a/docs/developer-docs/getting-started/deploy/testnet.mdx +++ /dev/null @@ -1,83 +0,0 @@ ---- -keywords: [beginner, tutorial, testnet, testnet deployment, deploy] ---- - -import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; - - -# Testnet deployment - - - - - -In contrast to other blockchain networks, ICP does not have a testnet network where smart contract developers can deploy their projects to test functionality. - -This is because canister smart contracts can be upgraded and changed once they have been deployed on the mainnet, and mainnet deployment is fairly cheap. - -For developers who are looking for a testnet environment, however, ICP offers the [playground](https://m7sm4-2iaaa-aaaab-qabra-cai.ic0.app/) that allows for simple, small-scale, temporary testing for free. It can be used to build and deploy canisters directly in the [web browser](/docs/current/developer-docs/developer-tools/ide/playground), or it can be utilized through the `dfx deploy --playground` command via the CLI. - -Canisters deployed to the playground use resources that are borrowed from a canister pool. Each canister has an initial amount of 0.5T cycles that it receives from the resource pool and can be used for 20 minutes once the canister has been deployed. Note that there are function [limitations and restrictions](/docs/current/developer-docs/smart-contracts/deploy/custom-testnets) imposed on canisters deployed to the playground. - -For advanced developers and use cases, there are [custom testnet options](/docs/current/developer-docs/smart-contracts/deploy/custom-testnets). - -## Deploying to the playground - -Through `dfx`, canisters can be deployed directly from the CLI to the playground using the `--playground` flag. When this flag is used, the specified canister is deployed to the playground canister pool, and a canister URL will be returned to the developer. If no canister is specified, all canisters within the project's `dfx.json` file will be deployed to the playground. - -This workflow enables developers to test canister functionality without needing to obtain cycles or configure other parameters that are required for deployment to the mainnet. - -### Prerequisites - -Before you start, verify the following: - -- [x] You have an internet connection and access to a shell terminal on your local macOS or Linux computer. - -- [x] You have a command line interface (CLI) window open. This window is also referred to as the 'terminal' window. - -- [x] You have downloaded and installed the IC SDK package as described in the [installing the IC SDK](/docs/current/developer-docs/getting-started/install/) page. - -:::info -`dfx deploy --playground` is available in `dfx` versions v0.15.1 and above. -::: - -To deploy a canister to the playground, first create a new `dfx` project with the command: - -``` -dfx new hello_world -``` - -This command will create a new default `dfx` project that contains a simple 'Hello, world!' sample that includes a `hello_world_backend` canister with a predefined `greet` function. - -Then, to deploy this canister to the playground, run the command: - -``` -dfx deploy hello_world_backend --playground -``` - -Once deployed, the canister can be interacted with using a command such as: - -``` -dfx canister call hello_world_backend greet '("everyone")' --network playground -``` - -This command calls the `hello_world_backend` canister that has been deployed to the playground using the `--network` flag since the playground is classified as a deployment network. - -:::info -Any commands that intend to target a canister deployed to the playground must use the `--playground` or `--network playground` flag in order to target the borrowed canister(s). -::: - -Verify the command displays the return value of the `greet` function. - -For example: - -``` -("Hello, everyone!") -``` - -## Next steps - -Next, you can deploy your canister on the mainnet. - -- [Mainnet deployment](/docs/current/developer-docs/getting-started/deploy/mainnet) \ No newline at end of file diff --git a/docs/developer-docs/getting-started/explore-examples.mdx b/docs/developer-docs/getting-started/explore-examples.mdx index 57b194cff4..7bb6f0b9e8 100644 --- a/docs/developer-docs/getting-started/explore-examples.mdx +++ b/docs/developer-docs/getting-started/explore-examples.mdx @@ -11,8 +11,6 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; - - [ICP Ninja](https://icp.ninja) is a web-based integrated development environment (IDE) for creating and deploying decentralized applications (dapps) on the Internet Computer (ICP). ICP Ninja provides a gallery of example projects you can explore to learn about different application types, architectures, and use cases. Example projects can be edited and then deployed to ICP directly from your web browser. Once deployed, you can open the application's frontend in your browser, share the public link to your new onchain dapp, or make calls directly to the backend through the [Candid UI](/docs/current/developer-docs/smart-contracts/candid/candid-concepts). @@ -25,7 +23,6 @@ ICP Ninja serves as an introduction to developing on ICP and learning about: - ICP's unique features, such as [randomness](/docs/current/developer-docs/smart-contracts/advanced-features/randomness), [timers](/docs/current/developer-docs/smart-contracts/advanced-features/periodic-tasks), and [HTTPS outcalls](/docs/current/developer-docs/smart-contracts/advanced-features/https-outcalls/https-outcalls-overview). - :::info Want to skip directly to using CLI tools in a local dev environment? [Get started with the IC SDK](/docs/current/developer-docs/getting-started/install). @@ -91,4 +88,4 @@ Once you are ready to either deploy your ICP Ninja project longer than the tempo - [x] Download the ICP Ninja project files by selecting the dropdown menu next to the "Deploy" button, then select "Download files." **If you want to start a new project instead, you can skip this step.** -- [x] [Install tools.](/docs/current/developer-docs/getting-started/install) +- [x] [Installing developer tools.](/docs/current/developer-docs/getting-started/install) diff --git a/docs/developer-docs/getting-started/identities.mdx b/docs/developer-docs/getting-started/identities.mdx index 2490f0c01f..15a9040b3a 100644 --- a/docs/developer-docs/getting-started/identities.mdx +++ b/docs/developer-docs/getting-started/identities.mdx @@ -5,12 +5,10 @@ keywords: [beginner, getting started, tutorial, accounts, developer account] import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -# Create a developer identity +# Creating a developer identity - - On the Internet Computer (ICP), a developer **identity** is essential to developing canisters. Developer identities use a private/public key pair for authentication. The public key can be distributed openly as it will be used to encrypt messages. The private key must be kept secret and stored securely. Developer identities have a **principal**, a generic identifier value used to identify users, canisters, and potentially other entities on the network in the future. Each developer identity's principal value is derived from the identity's public key. @@ -41,8 +39,6 @@ Developer identities are not the only form of identity on ICP. Other ICP identit ::: -## Creating your identity - By default, `dfx` will create and use the `default` identity. ***This identity is not stored securely. It is recommended you create your own personal identity.*** First, use `dfx` to list all current identities. If none exist, it will automatically create the `default` identity. @@ -77,7 +73,7 @@ Identity names must use the characters `ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmn To recover an identity, use `dfx identity import --seed-file seedphrase.txt`, where `seedphrase.txt` contains the seed phrase shown when you created your identity. ::: -### Storing the identity's private key +### Storing the developer identity's private key The private key for an identity is stored in the `~/.config/dfx/identity/IDENTITY_NAME/identity.pem`. ***This file should be backed up to a secure location.*** @@ -85,7 +81,7 @@ The private key for an identity is stored in the `~/.config/dfx/identity/IDENTIT By default, `dfx` will store your identity in the local keyring/keychain. If a keyring/keychain is unavailable, it will prompt you to choose a password, then store your private key locally in a password-protected PEM file at `~/.config/dfx/identity/IDENTITY_NAME/identity.pem.encrypted`. ::: -## Using your identity +## Using your developer identity Once your identity is created, you must tell `dfx` that this is the identity you want to use. If you do not, the `default` identity will be used, and any canister creation and management you execute will not be secure. @@ -125,4 +121,4 @@ aez2y-7yvs5-e6dpq-gwlld-t6ozx-l5hoo-j4vwr-mimoy-me2xq-yrxkx-rae Next, you must obtain cycles. Cycles are required to pay for the resources a canister consumes. -- [x] [Tokens and cycles](/docs/current/developer-docs/getting-started/tokens-and-cycles) +- [x] [Using tokens and cycles](/docs/current/developer-docs/getting-started/tokens-and-cycles) diff --git a/docs/developer-docs/getting-started/install.mdx b/docs/developer-docs/getting-started/install.mdx index 192f198f8f..920558e46e 100644 --- a/docs/developer-docs/getting-started/install.mdx +++ b/docs/developer-docs/getting-started/install.mdx @@ -7,12 +7,10 @@ import { AdornedTabs } from "/src/components/Tabs/AdornedTabs"; import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -# Install tools +# Installing developer tools - - The IC SDK is a software development kit used to develop and deploy applications on the Internet Computer (ICP) from a local developer environment. It is comprised of several tools. ## Installing the IC SDK @@ -144,4 +142,4 @@ For troubleshooting common `dfx` errors, see [IC SDK troubleshooting](troublesho Next, you must create a developer identity. This identity will be used to control and manage your project's canisters. -- [x] [Create a developer identity](/docs/current/developer-docs/getting-started/identities). +- [x] [Creating a developer identity](/docs/current/developer-docs/getting-started/identities). diff --git a/docs/developer-docs/getting-started/next-steps.mdx b/docs/developer-docs/getting-started/next-steps.mdx deleted file mode 100644 index fb87240ab7..0000000000 --- a/docs/developer-docs/getting-started/next-steps.mdx +++ /dev/null @@ -1,20 +0,0 @@ ---- -keywords: [beginner, getting started, user journeys, developer paths, features, application types] ---- - -import useBaseUrl from "@docusaurus/useBaseUrl"; -import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; -import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -import NextSteps from "@site/src/components/Card/NextSteps"; - -# Next steps - - - -Continue building with these suggested next steps. - - - - - - diff --git a/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx b/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx index 05ca775b97..1b9c9f8e6f 100644 --- a/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx +++ b/docs/developer-docs/getting-started/quickstart/first-smart-contract.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; import TabItem from "@theme/TabItem"; import { OsType, useOs } from "/src/hooks/useOs"; -# Quick start +# First smart contract diff --git a/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx b/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx index a014f52bd3..69ff57bcd1 100644 --- a/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx +++ b/docs/developer-docs/getting-started/quickstart/react-quickstart.mdx @@ -7,7 +7,7 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; import TabItem from "@theme/TabItem"; import { AdornedTabs } from "/src/components/Tabs/AdornedTabs"; -# React quick start +# First web app @@ -129,4 +129,4 @@ dfx deploy --playground Open the `frontend` URL in a web browser. You'll see the template React frontend interface. -*Congratulations, you just created your first internet-native React dapp!* \ No newline at end of file +*Congratulations, you just created your first internet-native React app!* diff --git a/docs/developer-docs/getting-started/tokens-and-cycles.mdx b/docs/developer-docs/getting-started/tokens-and-cycles.mdx index b9c746864a..df76bc0aee 100644 --- a/docs/developer-docs/getting-started/tokens-and-cycles.mdx +++ b/docs/developer-docs/getting-started/tokens-and-cycles.mdx @@ -7,12 +7,10 @@ import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; import TabItem from "@theme/TabItem"; import { AdornedTabs } from "/src/components/Tabs/AdornedTabs"; -# Tokens and cycles +# Using tokens and cycles - - On the Internet Computer, there are three types of token assets: ICP tokens, cycles, and ICRC tokens. ICP and cycles are the most important for every developer to understand and use, as they are necessary for deploying and maintaining a canister. ICP tokens are important because they can be converted into cycles and used to pay for a canister's resource consumption. Cycles reflect the real cost of operations for resources such as physical hardware, rack space, energy, storage devices, and bandwidth. @@ -85,7 +83,7 @@ b0d7beee54be8679a42e999218a16a0d396f223d7e44d259ac089848c1b820bf You can obtain [ICP tokens](https://internetcomputer.org/icp-tokens) from an [exchange](https://coinmarketcap.com/currencies/internet-computer/markets) or through a [developer grant](https://dfinity.org/grants). If you are using an exchange, initiate a withdrawal transaction, then enter the ledger account ID as the "destination" address to send ICP tokens to. -### 3. Check the balance. +### 3. Check the ICP balance. ``` dfx ledger balance --network=ic @@ -135,7 +133,7 @@ The amount of cycles that your canister will use depends on a variety of factors ::: -### 5. Confirm the balance. +### 5. Confirm the cycles balance. ``` dfx cycles balance --network=ic @@ -154,4 +152,4 @@ dfx cycles balance --network=ic Next, it's time to write the code for a smart contract. -- [x] [Write smart contracts](/docs/current/developer-docs/getting-started/write-smart-contracts). +- [x] [Writing smart contracts](/docs/current/developer-docs/getting-started/write-smart-contracts). diff --git a/docs/developer-docs/getting-started/troubleshooting.mdx b/docs/developer-docs/getting-started/troubleshooting.mdx index 566ff20393..773c5d7d9b 100644 --- a/docs/developer-docs/getting-started/troubleshooting.mdx +++ b/docs/developer-docs/getting-started/troubleshooting.mdx @@ -8,8 +8,6 @@ import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; - - This section provides information to help you troubleshoot and resolve or work around common issues that are related to the following tasks: - Downloading and installing the IC SDK. diff --git a/docs/developer-docs/getting-started/write-smart-contracts.mdx b/docs/developer-docs/getting-started/write-smart-contracts.mdx index a5a56d4f95..593fa82ddf 100644 --- a/docs/developer-docs/getting-started/write-smart-contracts.mdx +++ b/docs/developer-docs/getting-started/write-smart-contracts.mdx @@ -10,12 +10,10 @@ import { BetaChip } from "/src/components/Chip/BetaChip"; import { MarkdownChipRow } from "/src/components/Chip/MarkdownChipRow"; import { GlossaryTooltip } from "/src/components/Tooltip/GlossaryTooltip"; -# Write smart contracts +# Writing smart contracts - - Canisters are an enhanced type of smart contract. Before a canister is deployed to ICP, the canister's code is compiled into a WebAssembly (Wasm) program, enabling it to store persistent data, be managed by entities such as DAOs, host entire applications, and more. Each canister has the following components:
@@ -121,7 +119,7 @@ The `frontend` canister stores the app's frontend assets, including files such a   />
-## Writing code +## Writing canister code :::danger @@ -292,14 +290,14 @@ fn get_current_number() -> Nat {
}> -Azle code coming soon. + [Learn more about Azle](https://demergent-labs.github.io/azle/). }> -Kybra code coming soon. + [Learn more about Kybra](https://demergent-labs.github.io/kybra/). @@ -413,21 +411,17 @@ fn get_current_number() -> Nat { }> -Azle code coming soon. - [Learn more about Azle](https://demergent-labs.github.io/azle/). }> -Kybra code coming soon. - [Learn more about Kybra](https://demergent-labs.github.io/kybra/).
-### 4. Retrieve data. +### 4. Retrieve external data. HTTPS outcalls can obtain data from any external source, including other blockchains, traditional Web2 APIs, and other web services. When HTTPS outcalls are used locally, the returned result is not validated since the local replica is only a single node. HTTPS outcalls used on the mainnet validate the returned result through the subnet's consensus, providing security that the data obtained has not been maliciously tampered with during transport. @@ -676,14 +670,12 @@ fn transform(raw: TransformArgs) -> HttpResponse { }> -Azle code coming soon. - [Learn more about Azle](https://demergent-labs.github.io/azle/). }> -Kybra code coming soon. + [Learn more about Kybra](https://demergent-labs.github.io/kybra/). @@ -898,15 +890,13 @@ fn print_results() { }> -Azle code coming soon. - [Learn more about Azle](https://demergent-labs.github.io/azle/). + }> -Kybra code coming soon. - [Learn more about Kybra](https://demergent-labs.github.io/kybra/). + @@ -914,4 +904,4 @@ Kybra code coming soon. Now that you have written the canister's code, the canister needs to be deployed. -- [x] [Deploy and manage](/docs/current/developer-docs/getting-started/deploy-and-manage). +- [x] [Deploying and managing dapps](/docs/current/developer-docs/getting-started/deploy-and-manage). diff --git a/sidebars.js b/sidebars.js index bbff85da62..64b175562f 100644 --- a/sidebars.js +++ b/sidebars.js @@ -14,7 +14,7 @@ const sidebars = { }, { type: "doc", - label: "React", + label: "First web app", id: "developer-docs/getting-started/quickstart/react-quickstart", }, ], @@ -35,34 +35,29 @@ const sidebars = { }, { type: "doc", - label: "Install tools", + label: "Installing developer tools", id: "developer-docs/getting-started/install", }, { type: "doc", - label: "Create an identity", + label: "Creating a developer identity", id: "developer-docs/getting-started/identities", }, { type: "doc", - label: "Tokens and cycles", + label: "Using tokens and cycles", id: "developer-docs/getting-started/tokens-and-cycles", }, { type: "doc", - label: "Write smart contracts", + label: "Writing smart contracts", id: "developer-docs/getting-started/write-smart-contracts", }, { type: "doc", - label: "Deploy and manage", + label: "Deploying and managing dapps", id: "developer-docs/getting-started/deploy-and-manage", }, - { - type: "doc", - label: "Next steps", - id: "developer-docs/getting-started/next-steps", - }, ], }, { From 03348561d1576977ff77bfdd7aea013e04e0d943 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Tackmann?= <54846571+Dfinity-Bjoern@users.noreply.github.com> Date: Thu, 12 Dec 2024 12:41:59 +0100 Subject: [PATCH 09/10] Fix link to whitepaper (#3875) Co-authored-by: Bjoern Tackmann --- ...01_overview-of-the-internet-computer.subpage.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/how-it-works/0_general/01_overview-of-the-internet-computer.subpage.md b/how-it-works/0_general/01_overview-of-the-internet-computer.subpage.md index a6a0529ed1..2e7a630861 100644 --- a/how-it-works/0_general/01_overview-of-the-internet-computer.subpage.md +++ b/how-it-works/0_general/01_overview-of-the-internet-computer.subpage.md @@ -75,12 +75,12 @@ dapps on the IC can be governed by an out-of-the-box deployable governance syste If you want to learn in more detail how the IC works and realizes the vision of a World Computer, read through the sections of the page and the referenced Medium articles, or watch the YouTube videos. If you prefer to have a single source of information, the [White Paper](https://dfinity.org/whitepaper.pdf) is highly recommended. However, note that it is a little technical at times. -[Internet Computer for Geeks – White Paper](https://dfinity.org/whitepaper.pdf) -[Internet Computer Dashboard](https://dashboard.internetcomputer.org/) -[Internet Computer Source Code](https://github.com/dfinity/ic) -[Public Repositories for the Internet Computer](https://github.com/dfinity?q=&type=public&language=&sort=) -[Internet Computer Interface Specification Docs](https://internetcomputer.org/docs/current/references/ic-interface-spec) -[Internet Computer Primer - Deck](https://dfinity.org/deck/) -[Internet Computer SDK](https://github.com/dfinity/sdk) +- [Internet Computer for Geeks – White Paper](https://internetcomputer.org/whitepapers/The%20Internet%20Computer%20for%20Geeks.pdf) +- [Internet Computer Dashboard](https://dashboard.internetcomputer.org/) +- [Internet Computer Source Code](https://github.com/dfinity/ic) +- [Public Repositories for the Internet Computer](https://github.com/dfinity?q=&type=public&language=&sort=) +- [Internet Computer Interface Specification Docs](https://internetcomputer.org/docs/current/references/ic-interface-spec) +- [Internet Computer Primer - Deck](https://dfinity.org/deck/) +- [Internet Computer SDK](https://github.com/dfinity/sdk) [![Watch youtube video](https://i.ytimg.com/vi/YWHTNr8RZHg/maxresdefault.jpg)](https://www.youtube.com/watch?v=YWHTNr8RZHg) From d9f7989a7e8d4f304dd5adfc0a7515a1afcf4d77 Mon Sep 17 00:00:00 2001 From: Jessie Mongeon <133128541+jessiemongeon1@users.noreply.github.com> Date: Thu, 12 Dec 2024 05:53:27 -0600 Subject: [PATCH 10/10] Developer Weekly Update: Dec 11 2024 (#3873) * new headings * adjust * dev update dec 11 2024 * Dev Weekly Update Dec 11 2024 * ifx * fix --------- Co-authored-by: reigj1 <61514978+reigj1@users.noreply.github.com> --- blog/news-and-updates/2024-12-11-update.mdx | 44 ++++++++++++++++++ .../getting-started/deploy-and-manage.mdx | 1 - static/img/blog/dev-update-blog-dec-11.jpg | Bin 0 -> 344442 bytes 3 files changed, 44 insertions(+), 1 deletion(-) create mode 100644 blog/news-and-updates/2024-12-11-update.mdx create mode 100644 static/img/blog/dev-update-blog-dec-11.jpg diff --git a/blog/news-and-updates/2024-12-11-update.mdx b/blog/news-and-updates/2024-12-11-update.mdx new file mode 100644 index 0000000000..1f4ba03f13 --- /dev/null +++ b/blog/news-and-updates/2024-12-11-update.mdx @@ -0,0 +1,44 @@ +--- +title: Developer weekly update December 11, 2024 +description: This week, we have an important Motoko security update, an upgrade to the NNS Chain Fusion signer canister, and a new package from Mops- regex. +tags: [Devs] +image: /img/blog/dev-update-blog-dec-11.jpg +--- + +# Developer weekly update December 11, 2024 + +![December 11 2024](../../static/img/blog/dev-update-blog-dec-11.jpg) + +Hello developers, and welcome to this week's developer weekly update! This week, we have an important Motoko security update, an upgrade to the NNS Chain Fusion signer canister, and a new package from Mops: regex. Let's get started! + +## Motoko security fix in dfx v0.24.3 + +A security bug in Motoko was recently discovered that, under certain circumstances, may lead to unwanted memory reads or writes. This bug only affected those using the incremental garbage collector or enhanced orthogonal persistence and was hard to trigger depending on heap constellations, garbage collection scheduling, and specific language features used at a large scale. + +This bug has been fixed in Motoko v0.14.3, which is included in `dfx` v0.24.3 and newer. It is highly recommended to upgrade to the latest `dfx` version if you are using the incremental garbage collector or enhanced orthogonal persistence. + +[Learn more on the dev forum](https://forum.dfinity.org/t/security-fix-in-motoko-dfx-0-24-3/38656/1). + +## Upgrade NNS canister: Chain Fusion signer + +The latest update to the Chain Fusion signer canister can be used to sign transactions from APIs directly from a web browser or off-chain client. + +NNS proposal 134424 introduces Schnorr signatures to be added to the signer canister API, specifically adding the `schnorr_public_key()` and `schnorr_sign()` methods. The Schnorr API can also be used to sign Solana transactions. + +[Read more on the dev forum](https://forum.dfinity.org/t/upgrade-nns-canister-chain-fusion-signer/38623/1). + +## Mops regex package + +A new Mops package has been released: regex. This package allows you to use regex patterns for objects and flags. The team behind this package has published a [tutorial video](https://www.youtube.com/watch?v=O1dOZfK6DQA). + +You can install the Motoko regex package with: + +``` +mops add regex +``` + +[Learn more on the dev forum](https://forum.dfinity.org/t/motoko-regex-is-live-on-mops/37428/1). + +That'll wrap up this week. Tune back in next week for more developer updates! + +-DFINITY \ No newline at end of file diff --git a/docs/developer-docs/getting-started/deploy-and-manage.mdx b/docs/developer-docs/getting-started/deploy-and-manage.mdx index d1fbfb890f..4371776652 100644 --- a/docs/developer-docs/getting-started/deploy-and-manage.mdx +++ b/docs/developer-docs/getting-started/deploy-and-manage.mdx @@ -26,7 +26,6 @@ To deploy your canister locally, first start the local replica. This simulates t - `dfx start --background`: Runs the processes in the background and allows you to continue running commands in the current terminal. - ## Deploying the project locally Deploy the backend canister that you have written code for: diff --git a/static/img/blog/dev-update-blog-dec-11.jpg b/static/img/blog/dev-update-blog-dec-11.jpg new file mode 100644 index 0000000000000000000000000000000000000000..a219d0ce294d8462a04e4959b4a7b952d3f5e496 GIT binary patch literal 344442 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�*@!HC|1{HK2x{Y|jR0P#r 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

w-Jk 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

CU>k+P1Uoa!!E6}>YHLF70-jVT` zK?}4@8ZGy+t#?3zR4vXo@a8o!RKI~w6h&!Q%YYVBfL!321tot6^evd)n=G7GQ9Yf% zr`f2VER{hj1Jt!({-2VS`gD|ZuZvS+c9a2VtM{83XGH0wJxX3Nl4UE!^xhuH3@2Qn zy{0g{oJRE$Lja=!5M5(t{`!ZH^8WpD!R2S^w6IGC3+(j!V(AGFq$xIM=-WQFH*5d%0j{#~$C-8YEn!z{k2D+ViSs8o)=+|^eXex+!7E7->~Kwm zh_!Rz%g^g3qo45CtoQkxaCPuU#KG$+{~efoYITG`iSsL+ppQb>on-g-x~Vljc^|#< z?rxL3t86J6JJbm5!WFG-H8w+5PPSq7Zn6Q};&xYw$;UvQEmWL)r<2Jy_A{fA%|cTPwfIZe7U-mT_rJS3 z@6w@1o_c0M9IH&`1hH$DdMy;0%EMdhhy7;U08)BRA#tjtRiA#6)DC?ZXOJYHLiwF? zIBA3upRBAUYzxUz>qPlo4k6=?rwa+zHS3Soc9^qWbRFxHj$K42u8^$$-0637)#5yp zJnL5+c52kmPa>~vyZs*LJ(5GPY2>!@^wQF-*?(M^G2K;g;W7Vvjq~9dVyiqC_vqbh zt7R)*HU~yTe!m+k^vPRd!u7uMwY9zV!-(6g!PwIe7w|S0dAXLXP>sGjuk@Q8Tr=Bh z{+6O11L|jy+TL)#aqj1voKT1;Z(Xir0o;)%EI3R63m)@(o7>Fhoiq9tU%xVqC9iSN zUOwbhWc_h(o|Wml_O*MD{TR&3aH!|#|NXvapzxmyv$Aq?ti`WpxkT2vVnqsLhx9+D zJZQ=D%Gv(IzYc&{T<=;L`+COpJY!LK(YQ>riuNPKcG4HOMRnx0#q(pPjywu#i#dkv zYJXjn>z_a94uM;9b|v4x@W5f3 zfr%MwSo>HUsm4;&R zI;fZooMteg+(?Um!F0gT9mlB79dTbGSa4%ziyQ5eG(*&J0voqAHLGWXRWFH_(h(Q2 zWh2u=@k`cg6C}5^IG!5er_$T6IOFp!Z}T9fLVcTeBz39B1HnfglrVO^bS9FeEL8se z;^`875I9}wUg$~yI_Ot3#32Va zYPNQC$pBwXbRw&Nf;j;-a>OYYI7G59$6p*b7CRBltyb9`&uyCZkKCmbw1lAEu$d*Wwu=5dXubF3R zg5>?q$0%K9UG$QEn9~EIp^h%8fCXd2)MuaIfz@+>CCC7f-bfb~z4ib|L3?NSyH8Cq z(icJ6s8LC`^jHaTd*^HBGzMdbIl~>Xpt&=53^F^?!s=lc0xy$}#S7I#ta``+w#Xfj7hL6+v&bGuFhpYGJKHtXPz)Wa{-54Gz|yp` z#Twg@6;M1-VrL-UQ_6W~48!mPHxo8y#7O$|r!HEffLQr`E?1~&CJkqAzU+B|#5R${ zv0%0eF!ZZd^J!H6(<+55>6}M)M}`Zx0OcTSZYZsW`RI8HogxOYIaCO&XSSLV5 z&b(FUE?6YILUhyy?-Bh6Rc~NDTXgG|{TYPh8wH3+@_tHl8uTu?2|~3-VK#QHH`TNYH;0{LFI006-OVK?_5U-`SBb>K*ZBYrRrh71C(cyZhI||Aw z7)hACDPCIF!E9IYcQ<&&#<#A8GkOH{34!x!xFZtV3;&cY?|Q+g)`}&{G0Ar2GDBc0 z?*M+Lg`2j;4l9s0IYg)H#^Pu~j7o`)5mrd_+Y`?he#+J`M>zNgm)2}|CcQ$`m z<={}XR4Pb(?Q^o9>|5rUpVg`=ix{%sQQ_|5Zqn-8@4jjkca3l5xQM%1_y&e_7wb^7 zF0GuTuZwh<{ov;~1dOmJU2+&2gS*}d!_0WO$XsU)Z2>S8YUsaeK4I?Ha0yqCzQQv} zF(dSSvZrz`++th4dQ=7?B{K~HQiWkG7^4n_6yhdJ3Czbw! zK(iSRhe-v;0}S+`6*D17(s~57O10wzZz+g6w%M~JBHZZYt(Xzn1S^;~aI+u8aAF*_s;(4p4Zw0@H8zOgum}9qv|NB-)Af0b;GaIcz{Z>W%^D@f&BhpAgwiLO(RH2VvJ?^|~n(KIru;$y2 zvz}M$OuH4EZcj4I{=uE{hAkto{!#c6%zdZ&t?9}5 zpI&iF#jB<~%yluKnBN z@-ta^Qx9fj7XHwF&Um4n8QgqU?wtdlgo;ryr;}98|L~SX+86nx9QQ`1-idWYlthV zKfHLa>XvL;e%<2P{@%2)@^eKMfA;T?I-YpRIL=jKL4HWKmfu0F@N(2dZ`lrzqY0(8 z=3Z1DvV(fU??CQf|85Rz9p?YCh@JbFEq!S-e(-}weAqFwpw>Kx=I1XC8sAy7VB=&| zM;-S)cmCtk%3?T}wf_z8RJ@vJt{57&O&NZCI4j@%c$-~g;W@)--n#x{w@*etsh_?r z|LJIQ>VDBJ&(;7&$o$5{w5{xR*LJjkaku@uht1Ew+fqL83S(2%y(j z_~y~>jL?q@y_WAz3CRh0|1G~#c1O{CZtCmpk{AQvdV{-FZ<>FAB?f6=6Qs*+bEyPen;g>7R6_)kJMbZK_mf@?yna3r z2D`m!M2Ix(5ABt@yKnJ32ouvgXMH^_()|3p_|jW8(K{d>I*8cBXOH)MTX*`_yY*qr zl}}?I6I|E*lk)Y_CF?rtbMxu1&(v88nkr5)X3cX*_d0Fe;{UMtSZ9!R%ocn1_?+;EE3D zf=dQPSdN0%BOK1%4_-FF4T}X6*Uyt?An*fy@U@t0;QMoZj(~YlkAYa=+*Y{atFwP0mZRuGp99-#-Q) zWG)+klAE_Q@ZFuScVq46xV-rDoJkj_ixGgmrCmwcp0+sM{q(Ay5#q6wgDZ$H+hZ&q zc8+Fs0PGd6qJ@jlywuwl#lmelRXSCn&91~U&XXQbI+tRZC6 z%Zz$w^~*>QFfV*P(R>YAtY-4njQkz>4UIN6vZp z_`Q+pLf424Y7s0>Pa+hT8QKY7Wg0VrH+%Ph(24`Dov#_cW@yK^1Vsktc-EP%#K!Ij6FoQqS1S4XUUoU#R(#foFoOVIo@X#Hp+-2$Q?>JsBk11U9(^=wB+)F*b3McV_lh-McA4>w zG#714*v_zrtJ-2%1wHDo!OcB|X+pO0%fK4v;X3mRuCK#Q6$2?$9vD;zArJli!PdXa zGAUIDWdxBQj{(QU=v z9hWE2E?6rO9j#>aVQOl7u{5d&xDLMS+!kFmz4OQBt+b z3TDOH)c1bfPaVacxKOF(qde4mSPNZ`=|Ey?pq4S2I)q<@HYTx^CQ0hN&I^C|8$ z3g%3~l>@-p5+%mmj)PFeZ#Mweb~Q9MAXab(h!Ks+YTN}@iIy`Sq3qIvP_;!L=v=jG z6h<(Qhlchf0WI-dC{PKZsc94{xw)6LQNzkd(#0zI4$h5Acp$kD0h;6j1Dr5Vs0Ab7 z+J^#VlS4Q`3}nAL8djU@O!T1Lmas@Xm!L*5XU{JU7rW|0JK+LW57Tf8v7F4?I02Th zF}lX!3=-e~LoE^f7FhDuUQ)laYdkkp+zMnEne*J5qx{?x1O%~UVH|@7cx^z!B*QvE46131g+HlzChFdM>*XvY;SAj40%5V2=NN3aMu?f* z3uEmTK$)@7DTrehC`?n`x;+%*TA8yL&19kkKkrbS##b!ja3--(m^P8^36;v{QLeH2 zh;q?WE!7VCseqzm$aLs`xs?~e!L(>A+<$A(>ROe}Jwt?CZ3 zMLaQ<4;>n=@@ONrn&=<}8Zs(hpxtEBiRoJaAdu)Z&0G844eu}VY4#Tqe@VUoz|9?) zIh8VeMC0gXKHGm-7lWNw5d8Gc;&chnC?T0jnQ1HYo^lxi4Ff9=t|tn4xH_dm1bpzhWcSL=E=;O1k!VruY9(l5)yA#W@sKQPG8TJ8rY&C*d$A zDXJwog%hD%rtOnD<%G;7Dai-l=VK(T>EX(Sk7Rg3gBEP*tMKas~NF-tte0l1+m6W6MTz&cpyng1B+ zpzzLrgBd}!7RF=9s{ELNsT~T-RP;$J!cg%M1kyl7kGX{W?1zC-1fky(%isDtYF*xDE4b`>J_bFL9bIC5 zSR*WttYuuj%%0_c@qu)9Lz#|cn1TUUlL37mw2*VA_d}L9K1s>@dGgKb`EYsARAAfe z#Xt}KvJYE7?`6cM4rS%_ltG6J6lsc2o4pZnpB^c>dL04`L3@oLlU@Gu(J)xprec&}LcoQAgK``&;R+&R&H+e{89Nh3hfN-|n zV0H+4@!3`})H#GLkWx^{jo6Bw(tvY11?29HGzh;H4Ut|gBM zAK&A)9=b$a`JP5Id34L7MoO&dl2Z9&Iz&pV3XZH&}^-&0^Xi) zr)G7;ud+;gV6odmN0@@*tEES5M!SR6q=SIwxi>uwfG;l0!!xANM*_|?+sJR<(L<-F z2y%}4w%+I4gA|>NTwB}4r&rpFt$zf?P`VFb{gDZsgB;1&c0eOLDGC=-pt|99fuDYX zU%0zZDT}jk>Ecz&K<-bL~W4=$z)_WHpF}JW49Z>gn_M9va>h6by}L`Rk?kiq87QIdbLGyP*yX7WgZIOB-sNmy)XvEEE@q9 zAe_aAD3za!Jm$FNbG?x;}Q)_WRX&w|g$T$2+QMncYF8+9?qy2kT%!f(wH&hylp_Ax!@K9+Gm8Ag!nE-(uwq*7Yrmam(h+$y+ z%$-29z=YW^dwph1_qO{)jBM~6sL}K9DF0EArh4AI^~*2Qy*?$K_9}+Mcjit-y*Es2 zqnT0G->CDf_e>8gnMvz8n>uwmK7snsp-Vde9Qj4BT+w z-D%u1XxM0hebuUJx86~UPFIc?8bRL_qs!6CE53SJ*Y5dkkL{22H5r`oYg~e#KW2FqoalJeE(oA~lg)x$R zp^>marCHH-NgHTINQZ`p+V;qN9@5i0W-LNNYp773+uxWub+A7M1s9_ zlGf{@*ps1eF8zFkWScUE`@}V8KW;WND{?YB7v2#O#5PIdQz(t+lF-#vu+lH<_wjOcZ@+Ia#~;&YG2g7nzZc>neEyu{ z#i#e*^_rv-AP*5{OOmFhxKU7N;UHTu^8MC2I7wBe6eX7b%>rf|IBHvJi>f!9&axOm2a# z@ST2_VBSJxi^NS6zbmq5?hwAU7k0j^&=ln)BQOf9)a`p1FdamK{+YtCg$DXTjx?#2REMCI6WI>IHn$X3Cj!>y9U-@EZZKAil8qveMlKhMX$kE4H+o`qmIlboNbnp+V^nrTn@sOAOcAQ3Gz7ZEttVec#@*+)Suwa8>M^+7L{}AY6m>D(_vGD zFV&El#mc7n!g^@YohhZ~QLD0FA&ZOi#s9!JTPxR+Xz9*hU z)=$*CB?(~@{F+cJ9EQ~)HgT}f5 zh}96%*#9aGUkjj=08*47BBjWoiC4B!NX>9#Ta*K!a(Jl`fli)@gU@UwGBxO3ijaWl zuDE_|SEDYH4e{2&Qk8z0WEKirnwmy75TUY@Y_cF#8_PMHjK?Y(!YqNv7#1T}b%s9P zdVGdCx++ST49>&)f7$Bth$uBSSDW|D8Zmt&{$aEq^NkF+hQQRbxhk65{p3fmDc0Ep zEIbS;cHWLKea~vEFhsp5+4wB6UjZ>pbk4%KaJBOJcGa9p=tbqV4hmZbZGqdVQ0akY zEIf~0reqGyN(h30sQ$PKRV1ZC#0q5?&r@+cAk0TL+SJIaEmI%|MeW3RreaqStVH!2 zIHqufRr-G9bS-tDf=|sq!2fdtJ?>mM2G&r)WBe;`${>t+IrQ8KfM9S0+;^NK} zp5RaKsQcBU?zEu7@JU_(-ni++(w3;V>{08ITcO&=Y_*Py@iTzdNQ(^U-0S!~j=_;;_rSbE$le(^kn zUcI26-|4$)B8Xrm!AiT)UGGkqrY_sivFFzn%F64quIMan`Z}cd%IW(V9c{rUx+C+v zY|H+rK11)vky}dBGgBiXNa{^57^L$EI|7 zlr=(XoR;ymD!xadbmECYo9a=Vg8mPh&^!XCg!W4OKULrPTd#oXg}qLLz#e8e>#&fD zXKw~kFm4+u@k4B`gNR5XiR4ir=cF13rh*~0P$&4GL$GchxcxVpecg23foO5NNXs_W zSLITclB<>{1E0cv{ypo1`L@}_2on{vctBvk8M}l4!7ZeGH%nKZ}#(9Q$M~(jJ zAEY`Im-PCe_?>6i+Oq~QXHmlz15E10D46MY4Ee$+U!EM=iDb#uC{2fcWM^#!K!9!m z2(p#eLQ{y*y&TT99ioZ>F(BTVsKCj!H*?v7Cr~63q z|J}gfHHo%4{jptNX>jcoQHwod!>i!k8M*VsseIeRT#`(4P}{VI%dd$WkzQXv@a*EF z(T?;yOuIl!dTf+LnE_l=$o~|rwmV`u@JQ}k(hz)m0;sPvnf~JN;?@6c{umR`Zhi6F z=Yx;?U-*e9e0=--{?0X)nH4*cIWtA|oOdIo-Z#C^$+nyi`Rw=`+r{KkT6atudWz#u zY$ge&buAf%*sX-88dxnFZ>MbQ%z7-l4h9xC^DqE^jVLITEyv9{%FbKlm&3lkYrpkD zM9xIoadX;`Ts`Tg$*8lh$-zSNV+gR?)b!0x$c>5y>f1?KLTzf?Xq6 z`aMJPXbIb6NinI*JG1tWGpUhugQvo-SKC?5Guy(?)$9wbHG-?&e3{rmK1*Bu9z$^_o4(=AhO84gUA zop@aRAtBJ)hIfb35Z~e%dL@+mrCK^_iF$qYWf>p%EwYLmV$hl2>z!GHe|g1G<+bl! zpJBu79ok|wy*T${I>muc8QcD7PxX54Jy!MgKcyRc^4mX8-a`!9R;n(|QPS9HbJ?re z@#RqOE8$$$eYf$nY^0Sm+*sz4414HfBx?aE@1ZDEqir3e$9}aX*$Oj{Q<^$smebdh zFzY}sU;!E`%Z0(z?9vG13s@D*d0NY44H@4mw`=@Itp+Djk&*@Sh&32zm3tdaZAQ#@ z`%mfP({;K~(qs_78%@m7?SK(gH!+XcLx@RafBYPLO%GT8pVFhGLRt-SIcMlh4T(qs zS0{Z_h;fz#=;wCRNU)37I0N#nc@efr9{W9gUpe-=UJqk-9s(Jr-M(G-dPnd>08$n> z2Km+kX-LDkcLq-pd~|O@&l82IfmGUX1k6t(92B?C5KthZ{c^aUo80jR$iJoN1CaA# zOn$42l_JdAq;ymN5sE|_PfY05p5;3*Df7t8R*)RA0=H-&M<+jpz9#W2R~l{6*~bXW$wuaL$EgP+gSJ z85ts)aIR$8i)1jX4?B_@h}r3Nu~3=L1Nll8itALjf+#5YO*p{SLq_~LE&UqKi0P?- z2#Im9o>`I{F@vh}q70JYSrEF=n3NL(ZmVqpH)f=4zoDzP8q}n~EZCg|C=TDoY}8yp zj&nY~@|l$X>DW!DDD2CU!o!du8_EAA40L~UjugHjO`B6wk_dzto#%GsKM!Ps=s ze@f~pB^<5;b}(`tH-wYq6hfXcitkXg?D{pXOXF^qDpC*0qZ4qvhe2!GbtRR4aE3J* zGLm!=Q!>93O8uC9eDyv!*x!&(8VSYNgOr@=7yZm3NWCuq1Q)NjHCL$5ERbVvy`*r% z+Xa}nbG-CP6lS_V!}qp;{Q|H%UNQXV!Q9$d=l7+eMwDT9Kw<;O0k{K z&SrH(x#B0r7-xNq+2m5}|2}uqI3+o_%~J(!K{=?sdNrcrIIi*vBX*?({VUbS5712B zh5SuDmfE}Zbw#vx>DBOU1_A5Lbx)pDQq$Wiev+{^p7k!Odw*%3_6ajbhl5om{NH|& zaAKG)SJ{VkT+TL}+jt@U_KlYdk%TV?G&O2t#X3s#{hXb*=Y)?Xm7)X=Wq!ro%s$31 z=`n_XdUoN{ukYOXCN$e}%|x@W&fwFwOmaeD3G=v4&Dw8lr=5OtY{;zh5+3yl%FJy4+1-h-s(V3Zct5k|##WQBy4(UPFTYA*0IL&YvewY#OR6pb zL*hxBfy)cW(vYvr-zHS=7}le$UT3&z3_lYb(C&kHX??o_{+ z$MO$dJa8XGfa72xUV{!7G;dyK2&U}>bJ-bFkGj4I>Ym;E`?kj->!*_~tL$$yom5sz zj@DVMK0o;z`*0Fzqf@Ycm-{tmpKl3S9we8{3BRV+N3Pkbg^u;EPCLszAI5c_DVL7p sMC^Ji6tB)

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≫i+Aq5AQpZd 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�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