发表时间:2020年5月29日
信息来源:https://coingeek.com/the-story-behind-the-op_push_tx-technique
最近Stas Trock撰写了一篇文章,内容是关于如何让能够体现现实世界状态的智能合约在Bitcoin SV区块链上实施、部署和交易。Stas与sCrypt的创始人刘晓晖合作密切,正在利用sCrypt平台开发智能合约。在一篇关于状态型智能合约的Medium文章中,刘晓辉将OP_PUSH_TX的概念归功于nChain。
我们联系了nChain的首席技术官Steve Shadders,了解他如何参与了这一概念的验证过程。
这一概念最早产生于2016至2017年间,主要来自前nChain研究员Ying Chan。我相信其他人也参与了该项目,但是Ying在这个领域的专业知识是最丰富的。
因为那时我还没有参与进来,我想应该让Ying来直接回答这个问题:
“我就想看看当脚本操作码都解锁且不加限制之后,比特币的局限性将如何被突破。”“那时,还只有BTC。”
私钥这里只是被用于在推送交易时生成签名。需要该签名来验证OP_CHECKSIG有效运行,并确认你计算出的内容与你当前正在进行的交易相匹配。
由于私钥实际上并没有在保护任何资产,因此只要你不再次使用它,它就不存在安全性问题。通过推送私钥,你可以重新计算ECDSA签名算法的许多元素,因此计算变得非常简单。
你需要使用另一个不同的私钥来保护交易本身,这个私钥当然是不公开的。
从技术上讲,脚本不需要签名检查,但通常签名检查被用作为一种机制,来限制向持有密文的人转移比特币的能力。
挖矿谜题也能做到这一点,但它需要你解出脚本谜题后公开密文。而ECDSA签名却能够允许在不泄露私钥的情况下对私钥进行验证。
据我所知,至少有9项专利是针对该技术并涉及其相关扩展范畴的。之前由于BTC上人为施加的限制,我们不得不等待比特币协议被恢复后才能够在真实环境下展示它们。
目前,我们正在基于创世纪升级后的比特币规则下对这些技术进行审查,并开始重新测试。
我认为OP_CODESEPERATOR可以创造出混合功能,但在此处我们并不需要它。
2018年3月,BCH社区就一个新的操作码OP_GROUP进行了激烈讨论。从本质上讲,这个操作码可以让你“用颜色标记UTXO”,并附加了一个非常有限的转发条件,即该UTXO及其所有后代都必须都是相同的颜色。
这被吹捧为一种能够在BCH上“无需许可就可以操作资产”的方法。该提案极具争议,以至于讨论甚至可能引发算力战和分裂。
nChain既不想分裂BCH,也不想要引入新的OP_GROUP操作码,于是我们向他们说明了OP_PUSH_TX可以解决相同的问题,同时还可以实现更多操作功能。我们根本不需要引入任何新的操作码,我们只需要将脚本语言恢复到最初的形态,这本应该就在BCH的发展路线图里。
我们提出的方案既能满足Bitcoin ABC希望引入此操作码的愿望,还能满足Bitcoin Unlimited所追求的功能。不幸的是,该提案遭到质疑,他们认为该提案行不通,并且脚本太大。
现在,sCrypt团队所做的工作已经证明了方案是可行的,而脚本太大的问题也迟早会被解决,我正在研究其他技术。
一直以来,人们总是认为比特币缺少以太坊所拥有的一个基本功能,那就是将脚本的条件推进到下一个事务的能力。举例来说,你可以设定花费一个比特币的条件,但是你不能这样设定这个条件——下一个事务中必须包含一个特定的条件,你才能花费这个比特币。
OP_PUSH_TX这项技术打破了这个神话,展示出了比特上可以实现这种功能。通过访问脚本中的事务,您可以针对这个事务检查部分脚本或者检查其它特性,如果状态不满足,你可以强制不履行脚本。
Steve,谢谢你抽出时间回答上述问题。我希望读者们可以由此更好地了解现在在Bitcoin SV上已经实现的脚本技术。
为了更清晰的表述,本文中的人物引言被稍加编辑过。
Bitcoin SV是唯一遵循着中本聪于2008年发表的白皮书《比特币:点对点的电子现金系统》中协议的区块链。