Skip to content

wavesplatform/ts-contract

Repository files navigation

ts-contract

Create strongly typed invokes for your ride contracts

Installation

npm i @waves/ts-contract

Contract definitions and Invoke script transaction

Lest take a look on a simple contract definition:

interface myContract {
  foo(value: String)
}

Every interface method should correspond to @Callable(i) function in your .ride smart contract. In this case the contract is pretty simple:

{-# STDLIB_VERSION 3 #-}
{-# CONTENT_TYPE DAPP #-}
{-# SCRIPT_TYPE ACCOUNT #-}

@Callable(i)
func foo(value: String) = {
    WriteSet([
        DataEntry("data", value.size())
    ])
}

You can use it to get invoke transaction builder:

import { contract } from '@waves/ts-contract'
const { foo } = contract<myContract>()('3MwGdE779Vhf4bkn8UbqQqEQwos38KtWhsn')
foo('hello').invoke('seed') // => IInvokeScriptTransaction

In case your application use multiple contracts with the same code you can specify dApp address and when calling invoke itself

import { contract } from '@waves/ts-contract'
const { foo } = contract<myContract>()()
foo('hello')
  .invoke('seed', { dApp: '3MwGdE779Vhf4bkn8UbqQqEQwos38KtWhsn' })
  // => IInvokeScriptTransaction

Generate code

To auto generate definitions run the following command in project folder terminal:

npx @waves/ts-contract 3MwGdE779Vhf4bkn8UbqQqEQwos38KtWhsn ./myContract.ts

Where 3MwGdE779Vhf4bkn8UbqQqEQwos38KtWhsn is deployed dApp address.

Or if you want to generate code from .ride file call:

npx @waves/ts-contract ./src/myContract.ride ./myContract.ts

The generated myContract.ts file will look like this:

import { ByteVector, contract } from '@waves/ts-contract'

export interface myContract {
  foo(value: String | Number | Boolean | ByteVector)
}
export const { foo } = contract<myContract>()('3MwGdE779Vhf4bkn8UbqQqEQwos38KtWhsn')

About

Create strongly typed invokes for your Ride contracts

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published