Unity SDK TokenContract object
The Unity SDK class TezosSDK.Tezos.API.Models.TokenContract
, which is available at runtime as the TezosManager.Instance.Tezos.TokenContract
object, provides a built-in FA2-compatible smart contract and convenience methods to work with it.
For information about FA2 contracts and tokens, see FA2 tokens.
Properties
These properties are populated after you deploy the contract with the Deploy()
method:
Address
: The address of the deployed contractTokensCount
: The total number of token types in the contractLastActivityTime
: The timestamp of the last time tokens were minted or transferred
Methods
Constructors
new TokenContract(string address)
TODO does this create a contract from the template in the SDK or is this how I access an already-deployed contract?
new TokenContract()
Deploy()
void Deploy(Action<string> completedCallback)
Deploys (originates) a contract based on the built-in contract, including prompting the connected wallet to pay the origination fees.
Parameters:
completedCallback
: A callback method to run when the contract is deployed, which receives the address of the new contract
Example:
public void HandleDeploy()
{
TezosManager.Instance.Tezos.TokenContract.Deploy(OnContractDeployed);
}
private void OnContractDeployed(string contractAddress)
{
Debug.Log(contractAddress);
}
Mint()
void Mint(
Action<TokenBalance> completedCallback,
TokenMetadata tokenMetadata,
string destination,
int amount)
Calls the Mint
entrypoint of the contract to create a token type and mint tokens.
Parameters:
completedCallback
: A callback method to run when the token is minted, which receives aTokenBalance
object with information about the new tokentokenMetadata
: ATokenMetadata
object with information about the new tokendestination
: The account that owns the new token, which can be a user account or a smart contract accountamount
: The number of tokens of the new type to create
Example:
var initialOwner = TezosManager
.Instance
.Wallet
.GetActiveAddress();
const string imageAddress = "ipfs://QmX4t8ikQgjvLdqTtL51v6iVun9tNE7y7Txiw4piGQVNgK";
var tokenMetadata = new TokenMetadata
{
Name = "My token",
Description = "Description for my token",
Symbol = "MYTOKEN",
Decimals = "0",
DisplayUri = imageAddress,
ArtifactUri = imageAddress,
ThumbnailUri = imageAddress
};
TezosManager
.Instance
.Tezos
.TokenContract
.Mint(
completedCallback: OnTokenMinted,
tokenMetadata: tokenMetadata,
destination: initialOwner,
amount: 100);
private void OnTokenMinted(TokenBalance tokenBalance)
{
Debug.Log($"Successfully minted token with Token ID {tokenBalance.TokenId}");
}
Transfer()
void Transfer(
Action<string> completedCallback,
string destination,
int tokenId,
int amount)
Transfers tokens from the currently connected account to the destination account.
Parameters:
completedCallback
: A callback method to run when the token is minted, which receives the hash of the transfer transactiondestination
: The account to send the token to, which can be a user account or a smart contract accounttokenId
: The ID of the token to transferamount
: The number of tokens to transfer
Example:
public void HandleTransfer()
{
TezosManager
.Instance
.Tezos
.TokenContract
.Transfer(
completedCallback: TransferCompleted,
destination: address.text,
tokenId: int.Parse(id.text),
amount: int.Parse(amount.text));
}
private void TransferCompleted(string txHash)
{
Logger.LogDebug($"Transfer complete with transaction hash {txHash}");
}