译文出自:登链翻译计划
译者:翻译小组
校对:Tiny熊
Optimism的OptimisticRollup主网发布在即!我们在热切的期待中,因此我们为Optimisim的早期参与者准备了一个scaffold-eth的专门分支,脚手架包含以下内容:
运行本地链(L1)与OptimisticRollup(L2)。
L1和L2交互
在L1和L2之间移动ETH
在L2部署智能合约
创建自己的ERC20代币桥接!
这些工作仍在进行中:这是在一个全新的协议上的全新的构建方式,所以预计一切都会发展和变化:),欢迎反馈!
如果你想直奔主题,代码在这里6。
关于Optimism的Rollup是如何工作的,其他人已经写了更详细的。这篇文章的重点是我们可以在乐观的以太坊上做什么,如何运行和开发...
我们开始吧!
运行一个具有Rollup的本地链
你需要安装Docker!
在本地几条链,让他们互相交互,不是件容易的事。值得庆幸的是,Optimism团队提供了一个开箱即用的集成仓库,包含了运行所需的六个Docker容器。这是local-optimism分支的一部分,作为Git子模块提供。当你把repo拉下来的时候,你需要启动&更新子模块,然后就是一个命令就可以把整个东西创建起来。
cddocker/optimism-integration&&makeup
img启动并运行
有点像飞船起飞的感觉!
看日志可以很实际的感受到Optimism的工作原理--首先初始化一个L1链,并部署Optimism核心合约,然后初始化几个在L1和L2之间传递信息服务,最后启动L2geth实现。
Gensler:加密证券发行人需要向SEC登记其投资合同的要约和销售,或者满足豁免要求:金色财经报道,美国证券交易委员会(SEC)主席 Gary Gensler反驳了 Coinbase 的论点,并表示,我们对注册声明中要求的披露信息制定了灵活的规则,因此,加密证券发行人需要向SEC登记其投资合同的要约和销售,或者满足豁免要求。[2023/6/9 21:25:09]
如果一切顺利,我们就可以开始了!
Rollup与本地链交互
Optimism实现的真正优势之一是与EVM的兼容性--在很多方面,它就像改变RPCURL和chainID一样简单。
l1Local:{rpc:"http://localhost:9545",chainId:31337}l2Local:{rpc:"http://localhost:9545",chainId:420}l2Kovan:{rpc:"https://kovan.optimism.io",chainId:69}
当然,也有一些需要考虑的差异,这里让我们边走边讲。
从用户和开发者的角度来看,需要考虑的主要问题之一是如何处理L1和L2网络,哪些要呈现给用户,以及如何确保钱包连接到正确的网络。
使用自定义网络API,可以很好的解决后一个问题(在这个分支中还没有实现--欢迎PR!)
在这个分支中,我们实例化了两个provider(提供者)和两个singer(签名者),因为我们要支持与本地链和Rollup的交互。
1_vF4ynkFGTcdgvDm77hEC3g一个钱包有两个余额!
在L1和L2之间转移ETH
本地Rollup和目前在Kovan上的部署不需要任何交易费用,但这将是主网的一个关键过渡。我们有一个简单的OptimisticETHBridge组件,它可以显示用户在L1和L2的余额,并允许他们存款到L2或从L2取款。
1_iUEdefxX0UwlELeOwG4GdgL1/L2桥
存款是指在L1ETHGateway合约上调用_payable_deposit函数,存入你想存入的数量。该合约作为Optimism初始化的一部分进行部署,在本地设置上的部署地址总是相同的,但在Kovan上是不同的。
在Optimism上,没有原生的ETH,ETH只是一个ERC20的代币,提现是转入到ERC20合约中。
awaitl2Tx(L2ETHGatewayContract.withdraw(parseEther(values.amount.toString())))
该组件还为L1和L2内置了简单的Send功能。
Optimism团队短期内正在研究的难题:
目前L2还不支持用{value}发送的交易,所以我们实例化一个ethers.js合约,并调用transfer。
目前在L2上实现的geth版本并不像在L1上那样抛出transactionResponse,需要wait()等待transactionReceipt。在scaffold-eth中,这意味着要给我们的Transactorhelper增加一行。
result=awaitsigner.sendTransaction(tx);awaitresult.wait()
在Optimism上进行部署合约。
Optimism的主要关注点之一是转移性,从EVM到OVM。因此,我们只需要做一些小的改动,就可以使我们的现有scaffold-eth上的合约在L2上可行--我们只需要在我们的hardhat配置中导入Optimism编译器17,然后使用Optimismethersvariant来部署我们的合约。
const{l2ethers}=require("hardhat");...contractArtifacts=awaitl2ethers.getContractFactory(contractName,signerProvider);constdeployed=awaitcontractArtifacts.deploy(...contractArgs,overrides);awaitdeployed.deployTransaction.wait()
请注意前面提到的wait()!
有一些细微的差别--我们不能使用内置的Hardhat网络,必须实例化我们自己的提供者和签名者。
我们不需要对合约做任何修改,尽管可能不一定是这样,例如对.balance的调用会在编译时抛出一个错误。一般来说,编译器的错误对追踪问题都很有帮助。
我们确实做了一些改动,在Optimism上出块时间block.timestamp确实存在,但却是对L1时间的引用。有两件动作会更新了L2上的时间:从L1到L2的桥接信息,以及按设定频率(心跳)定期更新L2时间。
1_dCfswNwv6CKF4PXboiR_Hg
这确实给处理L2上的时间时产生了一些有趣的挑战,因为获取的block.timestamp总是过去的。以后还会有更多的思考...
在一个非常实际的问题上,这意味着在本地开发中,你需要定期在本地链上进行交易,以保持你的L2时间的更新!
在Optimism的桥接:古英语ERC20
虽然对于很多使用场景来说,使用他人部署的ETH桥和代币桥可以满足大部分L1到L2桥接的需求,但我们也想了解如何将自己的L1ERC20转移到L2,以及如何返回。
幸运的是,Optimism团队在他们合约包提供了一些参考合约,再加上有用的教程,所以我们能够把它们拉到我们的分支中,我们将部署三个合约:
ERC20.sol:在L1上,这是真理之源----一个简单的ERC20实现,有一个mint(value)函数,允许任何人自己铸造一些代币。
L1ERC20Gateway.sol:也是在L1上,这允许我们向L2存款,同时锁定代币。
L2DepositedERC20.sol:该合约部署在L2上,它也是一个ERC20的实现,当新的代币从L1存入时,它就将其铸成新的代币,当它们被提取时,就将其销毁。
部署顺序很重要,因为L1ERC20Gateway需要知道ERC20地址和L2DepositedERC20地址,然后需要通过init()与L1ERC20Gateway地址激活L2DepositedERC20合约,完成连接。我们部署的合约分别与L1Messenger和L2Messenger进行通信,以进行存款和提款。
部署完成后,我们就可以测试桥接功能了,可以在前端应用中测试,也可以在直接在部署脚本中测试。
l2l1桥接测试
L1ERC20Gateway必须经过批准才能转移代币,才能启动整个事情。
目前有在进行一个想法,希望有一个通用的用于ERC20代币的桥接,这样的桥接在生产中可能不需要,但它仍然是一个有益的概念验证,以方便本地开发。
下一步
显然,下一步的关键是上测试网local-optimism分支包含了去Kovan部署Optimism的配置选项,就像更新App.js中的selectedNetwork,以及从Hardhat部署时的defaultNetwork或--network参数一样简单。
但更大的问题是,在Optimism上构建什么!
我们将在未来几周内发布更多的试运行、概念验证,甚至可能是成熟的产品。欢迎关注。
如果你还没有-获取分支,那就赶快尝试一下吧。
非常感谢来自Optimism的Ben和Kevin的有益回答,以及__AustinGriffith的帮助、努力和支持!
本翻译由CellNetwork赞助支持。
来源:https://azfuller20.medium.com/optimism-scaffold-eth-draft-b76d3e6849e8
参考资料
登链翻译计划:https://github.com/lbc-team/Pioneer
翻译小组:https://learnblockchain.cn/people/412
Tiny熊:https://learnblockchain.cn/people/15
Optimism的OptimisticRollup:https://optimism.io/
scaffold-eth:https://github.com/austintgriffith/scaffold-eth/tree/local-optimism
代码在这里:https://github.com/austintgriffith/scaffold-eth/tree/local-optimism
Optimism的Rollup是如何工作的:https://research.paradigm.xyz/optimism
Docker:https://www.docker.com/products/docker-desktop
开箱即用的集成仓库:https://github.com/ethereum-optimism/optimism-integration
Git子模块:https://git-scm.com/book/en/v2/Git-Tools-Submodules
Optimism核心合约:https://community.optimism.io/docs/protocol/protocol.html#system-overview
一些需要考虑的差异:https://community.optimism.io/docs/protocol/evm-comparison.html#behavioral-differences
自定义网络API:https://learnblockchain.cn/article/2223
provider(提供者):https://docs.ethers.io/v5/api/providers/
singer(签名者):https://docs.ethers.io/v5/api/signer/
预部署地址:https://community.optimism.io/docs/protocol/protocol.html#predeployed-contracts
Optimism编译器:https://hardhat.org/plugins/eth-optimism-plugins-hardhat-compiler.html
Optimismethersvariant:https://hardhat.org/plugins/eth-optimism-plugins-hardhat-ethers.html
合约包:https://www.npmjs.com/package/@eth-optimism/contracts
有用的教程:https://github.com/ethereum-optimism/optimism-tutorial/tree/deposit-withdrawal
部署脚本:https://github.com/austintgriffith/scaffold-eth/blob/local-optimism/packages/hardhat/scripts/oe-deploy.js
通用的用于ERC20代币的桥接:https://github.com/ethereum-optimism/contracts/pull/257
获取分支:https://github.com/austintgriffith/scaffold-eth/tree/local-optimism
AustinGriffith:https://twitter.com/austingriffith
CellNetwork:https://www.cellnetwork.io/?utm_souce=learnblockchain
免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。
本文来源于非小号媒体平台:
登链社区
现已在非小号资讯平台发布105篇作品,
非小号开放平台欢迎币圈作者入驻
入驻指南:
/apply_guide/
本文网址:
/news/9788536.html
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场
上一篇:
盘点零知识证明代表性项目:如何影响和塑造区块链生态系统?
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。