From 4c15a02369e48daee21acef20b34b46762cf2b9c Mon Sep 17 00:00:00 2001 From: Pete Date: Fri, 22 Nov 2024 13:00:24 -0600 Subject: [PATCH 1/4] Addressed GitHub issue 1840 --- arbitrum-docs/partials/_troubleshooting-stylus-partial.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arbitrum-docs/partials/_troubleshooting-stylus-partial.mdx b/arbitrum-docs/partials/_troubleshooting-stylus-partial.mdx index 92f712d59..d701ee5e5 100644 --- a/arbitrum-docs/partials/_troubleshooting-stylus-partial.mdx +++ b/arbitrum-docs/partials/_troubleshooting-stylus-partial.mdx @@ -54,7 +54,7 @@ No. Stylus contracts are compiled down to WASM. The user writes a program in Rus ### How is a Stylus contract deployed?

-Stylus contracts are deployed on chain as a blob of bytes, just like EVM ones. The only difference is that when the contract is executed, instead of invoking the EVM, we invoke a separate WASM runtime. Note that a special EOF-inspired prefix distinguishes Stylus contracts from traditional EVM contracts: when a contract's bytecode starts with the magic 0xEF000000 prefix, it's a Stylus WASM contract. +Stylus contracts are deployed on chain as a blob of bytes, just like EVM ones. The only difference is that when the contract is executed, instead of invoking the EVM, we invoke a separate WASM runtime. Note that a special EOF-inspired prefix distinguishes Stylus contracts from traditional EVM contracts: when a contract's bytecode starts with the magic 0xEFF00000 prefix, it's a Stylus WASM contract.

From cd77f002ac6f5d184c17eff0e13d6c3dcd01fd40 Mon Sep 17 00:00:00 2001 From: Pete Date: Fri, 22 Nov 2024 13:02:53 -0600 Subject: [PATCH 2/4] Addressed GitHub issue 1801 --- .../launch-orbit-chain/how-tos/fast-withdrawals.mdx | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx b/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx index 247d0d9ea..cc58ec5a7 100644 --- a/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx +++ b/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx @@ -194,3 +194,9 @@ The following parameters need to be configured in those nodes. | ----------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | `--node.staker.enable-fast-confirmation=true` | Enables fast withdrawals in the validator node | | `--node.staker.make-assertion-interval=0h15m0s` | Since assertions need to be created for them to be confirmed, the minimum interval to create these assertions should be set to an amount close to the `minimumAssertionPeriod` defined in the Rollup contract. Modify `0h15m0s` to the configured value. | + +:::note + +Immediately after configuring fast withdrawals, your chain may not operate at full speed yet. This ramp-up is because the validators must work through the backlog of assertions that have yet to be confirmed. You will see a series of 'NodeCreated' and 'NodeConfirmed' events. Once the backlog is processed, your chain should operate fully at speed. + +::: \ No newline at end of file From 20f70b73e830aea6b1bde29a598ea48bc5acb84e Mon Sep 17 00:00:00 2001 From: Pete Date: Fri, 22 Nov 2024 13:05:09 -0600 Subject: [PATCH 3/4] Yarn cleanup --- arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx b/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx index cc58ec5a7..90cbb2c0b 100644 --- a/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx +++ b/arbitrum-docs/launch-orbit-chain/how-tos/fast-withdrawals.mdx @@ -199,4 +199,4 @@ The following parameters need to be configured in those nodes. Immediately after configuring fast withdrawals, your chain may not operate at full speed yet. This ramp-up is because the validators must work through the backlog of assertions that have yet to be confirmed. You will see a series of 'NodeCreated' and 'NodeConfirmed' events. Once the backlog is processed, your chain should operate fully at speed. -::: \ No newline at end of file +::: From 8c8170ff2e6fd0e04ee8e89f9846b4bdce91e53d Mon Sep 17 00:00:00 2001 From: Pete Date: Fri, 22 Nov 2024 15:26:20 -0600 Subject: [PATCH 4/4] updated notion/yarn --- .../partials/_troubleshooting-orbit-partial.mdx | 12 ++++++++++-- website/static/building-orbit-faqs.json | 2 +- website/static/building-stylus-faqs.json | 2 +- 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/arbitrum-docs/partials/_troubleshooting-orbit-partial.mdx b/arbitrum-docs/partials/_troubleshooting-orbit-partial.mdx index bd8c7358f..1471fbc92 100644 --- a/arbitrum-docs/partials/_troubleshooting-orbit-partial.mdx +++ b/arbitrum-docs/partials/_troubleshooting-orbit-partial.mdx @@ -20,11 +20,19 @@ Check our -You can permissionlessly launch an L3 Orbit chain that settles to one of Arbitrum's Layer 2 (L2) chains. There is an emerging licensing structure will soon make it possible to permissionlessly launch an L2 Orbit chain that settles directly to Ethereum. Please get in touch with the Arbitrum Foundation or Offchain Labs for more information. +You can launch any Orbit chain permissionlessly.

-Note that launching a testnet doesn't require any license. +Nitro is licensed under a Business Source license, similar to DeFi protocols like Uniswap and Aave, among others. This license contains an Additional Use Grant that permits the permissionless deployment of Nitro software on blockchains that settle to Arbitrum One or Nova. +

+ +

+However, Orbit chains that settle to a parent chain other than Arbitrum One or Nova are subject to additional licensing guidelines under the AEP. +

+ +

+

diff --git a/website/static/building-orbit-faqs.json b/website/static/building-orbit-faqs.json index 9cb263dee..1bded4aac 100644 --- a/website/static/building-orbit-faqs.json +++ b/website/static/building-orbit-faqs.json @@ -1,7 +1,7 @@ [ {"question": "Can I use Orbit to deploy a mainnet chain?","answer": "

\nYes! Arbitrum Orbit's core technology has undergone a comprehensive audit and is now able to support deployments to mainnet. You can read more about it here.\n

\n\n

\n\n

\n\n","key": "can-i-use-orbit-to-deploy-a-mainnet-chain"}, {"question": "How can I deploy an Orbit-based Layer 3 (L3) chain?","answer": "

\nCheck our Quickstart to learn how to launch your own Orbit chain today.\n

\n\n

\n\n

\n\n","key": "how-can-i-deploy-an-orbitbased-layer-3-l3-chain"}, -{"question": "Do I need permission/license to launch an Orbit chain?","answer": "

\nYou can permissionlessly launch an L3 Orbit chain that settles to one of Arbitrum's Layer 2 (L2) chains. There is an emerging licensing structure will soon make it possible to permissionlessly launch an L2 Orbit chain that settles directly to Ethereum. Please get in touch with the Arbitrum Foundation or Offchain Labs for more information.\n

\n\n

\nNote that launching a testnet doesn't require any license.\n

\n\n

\n\n

\n\n","key": "do-i-need-permissionlicense-to-launch-an-orbit-chain"}, +{"question": "Do I need permission/license to launch an Orbit chain?","answer": "

\nYou can launch any Orbit chain permissionlessly. \n

\n\n

\nNitro is licensed under a Business Source license, similar to DeFi protocols like Uniswap and Aave, among others. This license contains an Additional Use Grant that permits the permissionless deployment of Nitro software on blockchains that settle to Arbitrum One or Nova. \n

\n\n

\nHowever, Orbit chains that settle to a parent chain other than Arbitrum One or Nova are subject to additional licensing guidelines under the AEP.\n

\n\n

\n\n

\n\n

\n\n

\n\n","key": "do-i-need-permissionlicense-to-launch-an-orbit-chain"}, {"question": "Does Arbitrum officially deploy and/or maintain L3s for external teams?","answer": "

\nNo. Teams are required to deploy and maintain their Orbit chains. There are, however, several RaaS (Rollup as a Service) providers that can deploy and maintain the Orbit chain for you.\n

\n\n

\n\n

\n\n","key": "does-arbitrum-officially-deploy-andor-maintain-l3s-for-external-teams"}, {"question": "Can I modify Orbit's underlying technology to customize my chain?","answer": "

\nYes, you can make any changes you require to the underlying Nitro code base.\n

\n\n

\n\n

\n\n","key": "can-i-modify-orbits-underlying-technology-to-customize-my-chain"}, {"question": "What Data Availability (DA) solutions are currently available for Orbit chains?","answer": "

\nArbitrum Orbit currently supports 3 different DA solutions:\n

\n\n\n

\nNote that using AnyTrust gives the chain owner the most flexibility and cheapest fees.\n

\n\n

\n\n

\n\n","key": "what-data-availability-da-solutions-are-currently-available-for-orbit-chains"}, diff --git a/website/static/building-stylus-faqs.json b/website/static/building-stylus-faqs.json index b77c50b3c..5baef3006 100644 --- a/website/static/building-stylus-faqs.json +++ b/website/static/building-stylus-faqs.json @@ -4,7 +4,7 @@ {"question": "Why are constructors not yet supported for Stylus contracts?","answer": "

\nConstructors use EVM bytecode to initialize state. While one could add EVM bytecode manually to their Stylus deployment, we don't allow WASM execution in the constructor so there's no way to express this in the SDK.\n

\n\n

\nWe're working on models that will make init easier, so there might be better solutions available in the future. For now, we suggest calling an init method after deploying.\n

\n\n

\n\n

\n\n","key": "why-are-constructors-not-yet-supported-for-stylus-contracts"}, {"question": "Is it possible to verify Stylus contracts on the block explorer?","answer": "

\nCurrently it is not possible to verify contracts compiled to WASM on the block explorer, but we are actively working with providers to have the verification process ready for when Stylus reaches mainnet-ready status.\n

\n\n

\n\n

\n\n","key": "is-it-possible-to-verify-stylus-contracts-on-the-block-explorer"}, {"question": "Do Stylus contracts compile down to EVM bytecode like prior other attempts?","answer": "

\nNo. Stylus contracts are compiled down to WASM. The user writes a program in Rust / C / C++ which is then compiled down to WebAssembly.\n

\n\n

\n\n

\n\n","key": "do-stylus-contracts-compile-down-to-evm-bytecode-like-prior-other-attempts"}, -{"question": "How is a Stylus contract deployed?","answer": "

\nStylus contracts are deployed on chain as a blob of bytes, just like EVM ones. The only difference is that when the contract is executed, instead of invoking the EVM, we invoke a separate WASM runtime. Note that a special EOF-inspired prefix distinguishes Stylus contracts from traditional EVM contracts: when a contract's bytecode starts with the magic 0xEF000000 prefix, it's a Stylus WASM contract.\n

\n\n

\n\n

\n\n","key": "how-is-a-stylus-contract-deployed"}, +{"question": "How is a Stylus contract deployed?","answer": "

\nStylus contracts are deployed on chain as a blob of bytes, just like EVM ones. The only difference is that when the contract is executed, instead of invoking the EVM, we invoke a separate WASM runtime. Note that a special EOF-inspired prefix distinguishes Stylus contracts from traditional EVM contracts: when a contract's bytecode starts with the magic 0xEFF00000 prefix, it's a Stylus WASM contract.\n

\n\n

\n\n

\n\n","key": "how-is-a-stylus-contract-deployed"}, {"question": "Is there a new transaction type to deploy Stylus contracts?","answer": "

\nYou deploy a Stylus contract the same way that Solidity contracts are deployed. There are no special transaction types. As a UX note: a WASM will revert until a special instrumentation operation is performed by a call to the new  ArbWasm precompile, which readies the program for calls on-chain.\n

\n\n

\nYou can find instructions for deploying a Stylus contract in our Quickstart.\n

\n\n","key": "is-there-a-new-transaction-type-to-deploy-stylus-contracts"}, {"question": "Do Stylus contracts use a different type of ABI?","answer": "

\nStylus contracts use solidity ABIs. Methods, signatures, logs, calls, etc. work exactly as in the EVM. From a user's / explorer's perspective, it all just looks and behaves like solidity.\n

\n\n

\n\n

\n\n","key": "do-stylus-contracts-use-a-different-type-of-abi"}, {"question": "Does the Stylus SDK for Rust support custom data structures?","answer": "

\nFor in-memory usage, you should be able to use any implementation of custom data structures without problems.\n

\n\n

\nFor storage usage, it might be a bit more complicated. Stylus uses the EVM storage system, so you'll need to define the data structure on top of it. However, in the SDK there's a storage trait that custom types can implement to back their collections with the EVM state trie. The SDK macros are compatible with them too, although fundamentally it's still a global key-value system.\n

\n\n

\nYou can read more about it in the Stylus Rust SDK page.\n

\n\n

\nAs an alternative solution, you can use entrypoint-style contracts for your custom data structures.\n

\n\n

\n\n

\n\n

\n\n

\n\n","key": "does-the-stylus-sdk-for-rust-support-custom-data-structures"},