dc.contributor.author | Marmsoler, D | |
dc.contributor.author | Ahmed, A | |
dc.contributor.author | Brucker, AD | |
dc.date.accessioned | 2024-11-18T13:54:32Z | |
dc.date.issued | 2024 | |
dc.date.updated | 2024-11-16T18:52:01Z | |
dc.description.abstract | Smart contracts are programs stored on the blockchain, often developed in a high-level programming language, the most popular of which is Solidity. Smart contracts are used to automate financial transactions and thus bugs can lead to large financial losses. With this paper, we address this problem by describing a verification environment for Solidity in Isabelle/HOL. The framework consists of a novel formalization of the Solidity storage model, a shallow embedding of Solidity expressions and statements, an implementation of Isabelle commands to support a user in specifying Solidity smart contracts, and a verification condition generator to support a user in the verification. Compliance of the semantics is tested by a set of unit tests and the approach is evaluated by means of three case studies. Our results show that the framework can be used to verify even complex contracts with reasonable effort. Moreover, they show that the shallow embedding significantly reduces the verification effort compared to an alternative approach based on a deep embedding. | en_GB |
dc.identifier.citation | In: Software Engineering and Formal Methods 22nd International Conference, SEFM 2024, Aveiro, Portugal, 6 - 8 November 2024, Proceedings, edited by Alexandre Madeira and Alexander Knapp. Awaiting full citation and resolution of DOI | en_GB |
dc.identifier.doi | 10.1007/978-3-031-77382-2_10 | |
dc.identifier.uri | http://hdl.handle.net/10871/138675 | |
dc.identifier | ORCID: 0000-0002-6355-1200 (Brucker, Achim D) | |
dc.language.iso | en | en_GB |
dc.publisher | Springer | en_GB |
dc.rights.embargoreason | Under temporary indefinite embargo pending publication by Springer. 12 month embargo to be applied on publication (expected 28 December 2024) | en_GB |
dc.rights | © The Author(s), under exclusive license to Springer Nature Switzerland AG 2025 | en_GB |
dc.subject | Program Verification | en_GB |
dc.subject | Smart Contracts | en_GB |
dc.subject | Isabelle | en_GB |
dc.subject | Solidity | en_GB |
dc.title | Secure Smart Contracts with Isabelle/Solidity | en_GB |
dc.type | Conference paper | en_GB |
dc.date.available | 2024-11-18T13:54:32Z | |
dc.contributor.editor | Madeira, A | |
dc.contributor.editor | Knapp, A | |
dc.identifier.isbn | 978-3-031-77382-2 | |
exeter.place-of-publication | Heidelberg | |
dc.description | This is the author accepted manuscript. | en_GB |
dc.description | Lecture Notes in Computer Science volume 15280 | en_GB |
dc.rights.uri | http://www.rioxx.net/licenses/all-rights-reserved | en_GB |
rioxxterms.version | AM | en_GB |
rioxxterms.licenseref.startdate | 2024-08-24 | |
rioxxterms.type | Conference Paper/Proceeding/Abstract | en_GB |
refterms.dateFCD | 2024-11-18T13:50:46Z | |
refterms.versionFCD | AM | |