内容简介:一个类lisp语言我准备去除区块链的虚拟机,因为虚拟机不是必要的,改以解释执行类list语言的形式表达智能合约,然后提供标准交易模板,普通交易使用交易模板进行,有复杂逻辑的交易由应用者使用tlang语言书写逻辑表达(也可以使用面向java、.net、js、go等语言的sdk书写,使用sdk书写的程序会自动翻译为tlang)。这个合约的逻辑是:要么知道我的birthDay是2017-06-23 要么 给出pubKey和用对应的私钥对你的pubKeyHash的签名。
tlang
一个类lisp语言
我准备去除区块链的虚拟机,因为虚拟机不是必要的,改以解释执行类list语言的形式表达智能合约,然后提供标准交易模板,普通交易使用交易模板进行,有复杂逻辑的交易由应用者使用tlang语言书写逻辑表达(也可以使用面向 java 、.net、js、 go 等语言的sdk书写,使用sdk书写的程序会自动翻译为tlang)。
案例
下面是用tlang书写的一段合约逻辑
这个合约的逻辑是:要么知道我的birthDay是2017-06-23 要么 给出pubKey和用对应的私钥对你的pubKeyHash的签名。
由合约调用者传入的三个参数赋值下面三个变量。
合约定义方定义逻辑,合约调用方定义数据。
合约调用方提供数据:
(define birthDay "{birthDay}") (define pubKey "{pubKey}") (define sign "{sign}")
上面的键值对来自合约调用者,数据是键值对,执行时直接把键值对加入作用域不需要拼代码从而没有注入代码的可能。
下面三行是智能合约的逻辑,这三行是死的不会被调用者注入代码。
合约定义方定义的逻辑:
(define pubKeyHash="8658cefd0c1cf0ff294d14a66278f5a5490a1f8e") (define myBirthDayHash="d4a0f6c5b4bcbf2f5830eabed3daa7304fb794d6") (or (= (hash160 birthDay) myBirthDayHash) (and (= (hash160 pubKey) pubKeyHash) (= (decrypt pubKey sign) pubKeyHash)))
and = hash160 or decrypt是系统函数。
如果提供checksig系统函数的话(= (decrypt pubKey sign) pubKeyHash)也可以是(checksig pubKey sign pubKeyHash)。
ps:话说,这个案例不好,因为生日可以被枚举出来,从今天往前推100年挨着计算每一天的hash然后跟myBirthDayHash比对的话就能取走被这个合约锁定的资产了。
以上所述就是小编给大家介绍的《码云推荐 | 可实现智能合约的类 Lisp 语言 tlang》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 智能合约基础语言(四):Solidity函数
- 智能合约基础语言(十):Solidity内联汇编
- 智能合约基础语言(五):Solidity变量类型:引用类型
- 智能合约语言DAML现在可以在R3的Corda上使用
- 用 Go 创建一个新的智能合约语言 - 新项目动机,概念
- 用 Go 创建一个新的智能合约语言 - 词法分析器部分
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python源码剖析
陈儒 / 电子工业出版社 / 2008-6 / 69.80元
作为主流的动态语言,Python不仅简单易学、移植性好,而且拥有强大丰富的库的支持。此外,Python强大的可扩展性,让开发人员既可以非常容易地利用C/C++编写Python的扩展模块,还能将Python嵌入到C/C++程序中,为自己的系统添加动态扩展和动态编程的能力。. 为了更好地利用Python语言,无论是使用Python语言本身,还是将Python与C/C++交互使用,深刻理解Pyth......一起来看看 《Python源码剖析》 这本书的介绍吧!