CashScript
CashScript is a high-level programming language for smart contracts on Bitcoin Cash. It offers a strong abstraction layer over Bitcoin Cash' native virtual machine, Bitcoin Script. Its syntax is based on Ethereum's smart contract language Solidity, but its functionality is very different since smart contracts on Bitcoin Cash differ greatly from smart contracts on Ethereum. For a detailed comparison of them, refer to the blog post Smart Contracts on Ethereum, Bitcoin and Bitcoin Cash.
See the GitHub repository and the CashScript website for full documentation and usage examples.
The CashScript Language
CashScript is a high-level language that allows you to write Bitcoin Cash smart contracts in a straightforward and familiar way. Its syntax is inspired by Ethereum's Solidity language, but its functionality is different since the underlying systems have very different fundamentals. See the language documentation for a full reference of the language.
The CashScript SDK
The main way to interact with CashScript contracts and integrate them into applications is using the CashScript SDK. This SDK allows you to import .json
artifact files that were compiled using the cashc
compiler and convert them to Contract
objects. These objects are used to create new contract instances. These instances are used to interact with the contracts using the functions that were implemented in the .cash
file. For more information on the CashScript SDK, refer to the SDK documentation.
Installation
npm install cashscript
Usage
import { Contract, ... } from 'cashscript';
const { Contract, ... } = require('cashscript');
Using the CashScript SDK, you can import contract artifact files, create new instances of these contracts, and interact with these instances:
...
const P2PKH = require('./p2pkh-artifact.json');
const provider = new ElectrumNetworkProvider('mainnet');
const contract = new Contract(P2PKH, [pkh], provider);
console.log('contract address:', contract.address);
console.log('contract balance:', await contract.getBalance());
const txDetails = await contract.functions
.spend(pk, new SignatureTemplate(keypair))
.to(contract.address, 10000)
.send();
console.log(txDetails);
...