Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
@zilliqa-js/contract
Advanced tools
Classes for managing Scilla smart contracts on the Zilliqa blockchain.
interface DeployParams {
gasPrice: BN;
gasLimit: Long;
nonce?: number;
pubKey?: string;
}
interface CallParams {
amount: BN;
gasPrice: BN;
gasLimit: Long;
nonce?: number;
pubKey?: string;
}
interface Field {
name: string;
type: string;
}
interface Transition {
name: string;
params: Field[];
}
interface ABI {
name: string;
fields: Field[];
params: Field[];
transitions: Transition[];
}
interface Value {
vname: string;
type: string;
value: string;
}
type Init = Value[];
type State = any;
Contracts
A factory class for creating Contract
instances. Useful for managing
Provider
instances set on Contract
s. The factory is mainly used by the
top-level module exported by @zilliqa-js/zilliqa
.
Contracts(provider: Provider, signer?: Wallet): Contracts
provider
: Provider
- a Provider
instancesigner
: Wallet
- a Wallet
instance, used for signing transactions.Contracts
- a Contracts
instance.provider: Provider
signer: Wallet
static getAddressForContract(tx: Transaction): string
Computes the address for a contract deployment by concatenating senderAddress
and nonce
and hasing the resulting bytes. Note that this method will not
compute an accurate address if the provided nonce
is not up to date with the
actual nonce on the blockchain.
tx
: Transaction
- a Transaction
with nonce
and senderAddress
.at(address: string, abi: ABI, code: string, init?: Init, state?: State): Contract
Constructs a Contract
with the provided parameters. It is recommended that
this method by used only to construct contracts that have already been deployed.
address
: string
- the contract address.abi
: ABI
(optional) - the ABI return by scilla-checker
with
-contractinfo
flag.code
: string
(optional) - UTF-8 encoded Scilla smart contract code.init
: Init
(optional) - the initialisation parameters of the smart
contract.state
: State
(optional) - the current smart contract state.Contract
- a Contract
instance.new(code: string, init: Init, abi?: ABI): Contract
Constructs a Contract
with the provided parameters, that is not deployed. The
contract may subsequently be deployed.
code
: string
- UTF-8 encoded Scilla smart contract code.init
: Init
- the initialisation parameters of the smart contract.abi
: ABI
(optional) - the ABI return by scilla-checker
.Contract
- a Contract
instance.Contract(factory: Contracts, code?: string, address?: string, abi?: ABI, init?: Init, state?: State): Contracts
A class representing a single smart contract. Allows for deployment and calling the smart contract's transitions.
factory
: Contracts - the creating factory instance.code
: string
(Optional) - UTF-8 Scilla smart contract code.address
: string
(Optional)init
: any
(Optional) - contract initialisation parameters.state
: any
(Optional) - contract state.abi
: string
(Optional) - scilla interfaceContract
- a Contract
instance.Contract
factory: Contracts
provider: Provider
signer: Wallet
init: Init
abi?: ABI
(Optional) state?: State
(Optional)
address?: string
(Optional) code?: string
(Optional)
status: ContractStatus
isInitialised(): boolean
Returns true
if no attempt has been made to deploy the Contract
, or its
status is unknown.
boolean
isDeployed(): boolean
Returns true
if the contract has been successfully deployed.
boolean
isRejected(): boolean
Returns true
if the contract deployment attempt was rejected by the network.
boolean
deploy(params: DeployParams, attempts: number = 33, interval: number = 1000): Promise<Contract>
Deploys a contract to the blockchain. This method will automatically generate
and sign the underlying Transaction
and broadcast it. The status of the
Contract
may then be ascertained by using isRejected
or isDeployed
, once
the Promise
resolves.
params
: DeployParams
- a subset of TxParams. Passed to the underlying
Transaction
. This can be used to manually provide nonce
and pubKey
, if
it is desirable to sign the underlying transaction with a non-default account
in the Wallet
.attempts
(Optional - default 33): number
- the number of times to poll the
lookup node for transaction receipt.interval
(Optional - default 1000): number
- the amount of time to wait
between attempts. increases linearly (numAttempts * interval
).Promise<Contract>
- will be rejected if a network error occurs. A resolved
Promise
does not indicate that the Contract
is deployed, as the underlying
Transaction
may be confirmed by the blockchain but unsuccessful, due to lack
of gas
, and so on.call(transition: string, args: Value[], params: CallParams): Promise<Transaction>
Calls a transition of the current contract. At the moment, this is a low-level interface for interacting with simple smart contracts.
transition
: string
- the exact name of the contract transition to be
invoked. case mattersargs
: Value[]
- JSON-encoded array of transition arguments.params
: CallParams
- a subset of TxParams
. Passed to the underlying
Transaction
.attempts
(Optional - default 20): number
- the number of times to poll the
lookup node for transaction receipt.interval
(Optional - default 1000): number
- the amount of time to wait
between attempts. increases linearly (numAttempts * interval
).Promise<Transaction>
- the Transaction that has been signed and broadcast to
the network.getState(): Promise<State>
Queries the blockchain for the smart contract's state. Note that this method will return the entire state of the smart contract. As a result, if you have a large amount of data stored in a smart contract do not use this method on a client. Instead, use a server-side layer to cache and proxy such queries.
None
Promise<State>
- the Contract state.getInit(): Promise<State>
Queries the blockchain for the smart contract's init (a.k.a. immutable variables of a contract)
None
Promise<State>
- the Contract Init.getSubState(variableName: string, indices: string[]): Promise<State>
Queries the contract state, filtered by the variable names. This function is the
filtered version of getState
. As getSubState
performs the filtering,
variableName
of a field is required.
If the subState
is not found, this returns a null
response.
variableName
: string
- the variable name within a stateindices
: string[]
- optional variable. If the variableName
is a Map
,
an array of indices may be provided.Promise<State>
- the Contract Init.FAQs
Contract-related functionality.
We found that @zilliqa-js/contract demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.