Cryptology ePrint Archive: Report 2018/122

BitML: A Calculus for Bitcoin Smart Contracts

Massimo Bartoletti and Roberto Zunino

Abstract: We introduce BitML, a domain-specific language for specifying contracts that regulate transfers of bitcoins among participants, without relying on trusted intermediaries. We define a symbolic and a computational model for reasoning about BitML security. In the symbolic model, participants act according to the semantics of BitML, while in the computational model they exchange bitstrings, and read/append transactions on the Bitcoin blockchain. A compiler is provided to translate contracts into standard Bitcoin transactions. Participants can execute a contract by appending these transactions on the Bitcoin blockchain, according to their strategies. We prove the correctness of our compiler, showing that computational attacks on compiled contracts are also observable in the symbolic model.

Category / Keywords: applications / cryptocurrencies

Original Publication (with major differences): ACM CCS 2018

Date: received 31 Jan 2018, last revised 3 Oct 2018

Contact author: bart at unica it

Available format(s): PDF | BibTeX Citation

Note: Added remark on replay attacks

Version: 20181003:112220 (All versions of this report)

Short URL: ia.cr/2018/122


[ Cryptology ePrint archive ]