金色观察|Layer1与layer2互操作性举例:条件事务

这篇文章介绍的是StarkEx提供的快速取款的解决方案:在区块链时间内从L2提取资金到任何L1地址,并且该解决方案与L2运营商生成有效性证明的频率无关。StarkEx是L2扩容技术服务商StarkWare的二层交易应用。

目前,快速取款功能已经在StarkEx的以太坊主网上运行,并为DeversiFi和dYdX的交易所提供支持。

下面的解决方案可以应用于行业内广泛的用例,首先我们来看场景需求。

场景需求

区块链允许Alice和Bob两方之间的无信任交互。Alice可能希望发布一个只有在某个条件事件发生时才能执行的交易;Bob希望在满足条件后执行Alice的交易,而无需再次获得她的批准。我们将这样的规范称为条件事务(CT)。

金色晚报 | 11月27日晚间重要动态一览:12:00-21:00关键词:PlusToken、Libra、ETC硬分叉、Upbit交易所

1. PlusToken案涉案42亿美元加密资产将被依法处理,含19万枚比特币。

2. Facebook计划最早在明年一月以有限形式发行加密货币Libra。

3. Upbit交易所将于明日实行有限的加密货币提现延迟措施。

4. 欧洲央行管委魏德曼:可以发行央行数字货币供商业银行使用。

5. 英国欲成立数字市场部门 监管谷歌、Facebook等数字科技平台。

6. ETC官方预计Thanos硬分叉升级将于11月29日发生。

7. 江卓尔:PlusToken资产拍卖就是大新闻,不卖就是锁仓。

8. 数据:持有1000个BTC以上的投资者拒绝抛售并且仍在买入。[2020/11/27 22:23:34]

在L1上实施CT很简单,因为智能合约可以加强事件和交易执行之间的耦合。也就是事件发生自动执行。并且把执行条件固定。但当迁移到L2系统时,这将成为一个挑战。例如,在StarkEx中,签名者将签署的交易传递给运营商,运营商负责执行它,在满足请求的条件之前,没有什么可以阻止运营商执行这个交易。

金色晨讯 | 6月18日隔夜重要动态一览:21:00-7:00关键词:DeFi、PoS协议、ETH 2.0、波卡、亿邦国际

1. DeFi代币总市值已突破32亿美元。

2. 以太坊测试网开发者:ETH 2.0主网或将于11月启动。

3. 亿邦国际宣布IPO条款,拟筹资1.06亿美元。

4. 报告:PoS协议可能会给质押资产持有者带来重大经济成本。

5. 美联储主席:各国央行都需要了解数字货币。

6. V神:以太坊供应量比原先预期少4000万。

7. 波卡项目创始人:波卡网络预计明晚切换至NPoS。

8. 国家外汇管理局安徽省分局:跨境金融区块链平台助力企业融资。

9. ETH测试网开发者:以太坊2.0 Casper能够在支持大量验证者的情况下实现扩容性。[2020/6/18]

在这篇文章中我们提到的在L2上指定的CT,它依赖于L1事件。也就是说,CT确保操作员只有在发生某些链上事件时才能执行签名交易。如果我们再添加一个CT,它依赖于另一个L2事件上的事件,这将实现StarkEx实例和StarkNet之间的互操作性。

金色财经矿池数据播报:金色财经报道,据蜘蛛矿池数据显示:距离BTC减半还有69天;BSV减半还有37天。

ETH全网算力178.812TH/s,挖矿难度2243.8T,目前区块高度9595011,理论收益0.00762257/100MH/天。

BTC全网算力115.57EH/s,挖矿难度15.49T,目前区块高度619911,理论收益0.00001623/T/天。

BSV全网算力2.977EH/s,挖矿难度0.43T,目前区块高度624550,理论收益0.00060459/T/天。[2020/3/3]

下面,我们将此类链上事件的概念形式化,并了解如何将它们用于StarkEx中的CT。

金色晚报 | 2月27日晚间重要动态一览:12:00-21:00关键词:ETC、日本央行、数字货币、湖南省区块链产业园

1. 湖南省工信部批准设立湖南省区块链产业园。

2. ETC开发者会议:计划在10,500,839高度进行升级。

3. 日本央行副行长:日本央行将研究数字货币的利弊。

4. 浙江省委宣传部:加快区块链等技术在文化产业领域的应用。

5. 苏州市相城区:2020年将强化数字货币和区块链研发应用。

6. 数字货币入选《麻省理工科技评论》2020年全球十大突破性技术。

7. 美国律师事务所预计美国国税局将对加密逃税者提起更多诉讼。

8. 尼日利亚仍居比特币、区块链区域搜索热度首位。

9. 当前BTC全网合约持仓总量为26.97亿美元。

10. 比特币日内震荡下跌,最低跌至8531美元,现报8773美元。[2020/2/27]

条件事务

CT使用FactRegistry合约来跟踪链上事件。特别是,除非在事实登记处注册,否则CT不能以事件为条件。例如,如果Alice直接在Ethereum上向Bob转账1ETH,则没有可以用作CT的链上事件。

也就是需要进行一次单独的定义某些事件为条件。

在上面的例子中,FactRegistry合约需要一个函数transfer(),Alice使用Bob的地址作为接收者参数调用该函数。

transfer()函数做两件事:(a)将传输的ETH发送给接收者,(b)保留传输的记录,例如合约中存储传输参数的哈希值。

FactRegistry也有一个isValid()函数,它接收一个哈希值作为参数,并返回一个布尔值——True当且仅当它是这个合约记录的交易哈希值。

交易的哈希被称为事实—代表事件的发生。向事实登记处引入新事实的过程称为事实登记。

在CT中签署的链上事件包会含两个字段:(a)一个事实登记合约的地址,(b)一个应该在执行交易之前注册的事实。

StarkEx中的条件交易

StarkEx对交易进行批量处理,并使用单个STARK证明在链上进行结算。如果批次中的交易之一是CT,StarkEx将确保关联的Fact确实已注册登记,以便对批次进行结算;否则,整个批次将被还原。

条件事务示例

快速提款

在任何L2解决方案中,在L2到L1之间转移资金的理想方法是完成L2状态更新和L1上的提款交易。

在基于有效性证明的系统中,如StarkEx,L2状态更新的最终确定发生在链上接受证明它的有效证明时,这通常需要10分钟。这意味着如果用户想要将他们的资金从L2转移到L1,他们将被迫等待。

快速取款的目的是解耦这种依赖性,并允许用户在“区块链时间”无需信任地将资金提取到L1。

这将如何运作?如果Alice想从L2提取1ETH到L1,Alice可以签署CT将1ETH转移到L2上的流动性提供者,条件是LP在L1上转移1ETH给Alice。

Alice的CT只有在她首先在L1上获得资金时才能执行,因此她也不会面临交易对手风险。

更多其他用例

类似的流程可以通过L2CT事务捕获以下类型的事件,及为以下提供证明,就可以在L1上进行一些关联操作,例如:

ETH的价格跌至1010DAI,Alice想在L2上以1000DAI的价格出售她在L2上的1ETH。

Alice希望在L2上给Bob10ETH,Bob在她选择的dApp中以Alice的名义存入9.5ETH。

Alice想在DeversiFi的L2上为Bob提供10ETH,Bob在dYdX的L2中将9.5ETH存入Alice的账户。

这些其他操作用例代表着虽然CT的第一个用例是快速提款,但StarkEx运营商可以使用这个方式实现更多L2-L1交互,用来丰富产品功能。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

[0:15ms0-2:867ms