Skip to main content

Unity SDK API object

The Unity SDK class TezosSDK.Tezos.API.TezosAPI, which is available at runtime as the TezosManager.Instance.Tezos.API object, provides information about the Tezos blockchain, such as what tokens accounts or contracts control.

Properties

None.

Methods

GetTezosBalance()

IEnumerator GetTezosBalance(Action<ulong> callback, string address);

Returns the balance of the specified account address in mutez.

Example:

public void RunGetTezosBalance()
{
Debug.Log("Getting balance");
var routine = TezosManager.Instance.Tezos.API.GetTezosBalance(
callback: HandleTezosBalance,
address: myAddress
);
StartCoroutine(routine);
}

private void HandleTezosBalance(ulong balanceMutez)
{
Debug.Log(balanceMutez/1000000);
}

ReadView()

IEnumerator ReadView(string contractAddress,
string entrypoint,
string input,
Action<JsonElement> callback);

Returns the response from a contract view.

Example:

TODO

GetTokensForOwner()

IEnumerator GetTokensForOwner(
Action<IEnumerable<TokenBalance>> callback,
string owner,
bool withMetadata,
long maxItems,
TokensForOwnerOrder orderBy);

Gets the tokens that an account owns.

Example:

public void RunGetTokensForOwner()
{
var routine = TezosManager.Instance.Tezos.API.GetTokensForOwner(
callback: HandleTokenBalances,
owner: myAddress,
withMetadata: true,
maxItems: 10,
orderBy: new TokensForOwnerOrder.ByLastTimeAsc(0)
);
StartCoroutine(routine);
}

private void HandleTokenBalances(IEnumerable<TokenBalance> tokenBalances)
{
List<TokenBalance> tokens = new List<TokenBalance>(tokenBalances);
foreach (var tb in tokens)
{
Debug.Log($"{tb.Balance} tokens on contract {tb.TokenContract.Address}");
}
}

GetOwnersForToken()

IEnumerator GetOwnersForToken(
Action<IEnumerable<TokenBalance>> callback,
string contractAddress,
uint tokenId,
long maxItems,
OwnersForTokenOrder orderBy);

Gets the accounts that own the specified token.

Example:

public void RunGetOwnersForToken()
{
var routine = TezosManager.Instance.Tezos.API.GetOwnersForToken(
callback: HandleTokenOwners,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address,
tokenId: 0,
maxItems: 10,
orderBy: new OwnersForTokenOrder.ByLastTimeAsc(0)
);
StartCoroutine(routine);
}

private void HandleTokenOwners(IEnumerable<TokenBalance> tokenBalances)
{
List<TokenBalance> tokens = new List<TokenBalance>(tokenBalances);
foreach (var tb in tokens)
{
Debug.Log($"{tb.Balance} tokens on contract {tb.TokenContract.Address}");
}
}

GetOwnersForContract()

IEnumerator GetOwnersForContract(
Action<IEnumerable<TokenBalance>> callback,
string contractAddress,
long maxItems,
OwnersForContractOrder orderBy);

Gets the accounts that own tokens on the specified contract.

Example:

public void RunGetOwnersForContract()
{
var routine = TezosManager.Instance.Tezos.API.GetOwnersForContract(
callback: HandleOwnersForContract,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address,
maxItems: 10,
orderBy: new OwnersForContractOrder.ByLastTimeAsc(0)
);
StartCoroutine(routine);
}

private void HandleOwnersForContract(IEnumerable<TokenBalance> tokenBalances)
{
List<TokenBalance> tokens = new List<TokenBalance>(tokenBalances);
foreach (var tb in tokens)
{
Debug.Log($"{tb.Owner} owns {tb.Balance} tokens on contract {tb.TokenContract.Address}");
}
}

IsHolderOfContract()

IEnumerator IsHolderOfContract(
Action<bool> callback,
string wallet,
string contractAddress);

Returns true if the specified account owns any token in the specified contract.

Example:

public void GetIsHolderOfContract()
{
var routine = TezosManager.Instance.Tezos.API.IsHolderOfContract(
callback: HandleIsHolderOfContract,
wallet: myAddress,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address
);
StartCoroutine(routine);
}

private void HandleIsHolderOfContract(bool response)
{
Debug.Log(response);
}

IsHolderOfToken()

IEnumerator IsHolderOfToken(
Action<bool> callback,
string wallet,
string contractAddress,
uint tokenId);

Returns true if the specified account owns the specified token in the specified contract.

Example:

public void GetIsHolderOfToken()
{
var routine = TezosManager.Instance.Tezos.API.IsHolderOfToken(
callback: HandleIsHolderOfToken,
wallet: myAddress,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address,
tokenId: 0
);
StartCoroutine(routine);
}

private void HandleIsHolderOfToken(bool response)
{
Debug.Log(response);
}

GetTokenMetadata()

IEnumerator GetTokenMetadata(
Action<JsonElement> callback,
string contractAddress,
uint tokenId);

Gets the metadata for the specified token.

Example:

public void RunGetTokenMetadata()
{
var routine = TezosManager.Instance.Tezos.API.GetTokenMetadata(
callback: HandleGetTokenMetadata,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address,
tokenId: 0
);
StartCoroutine(routine);
}

private void HandleGetTokenMetadata(JsonElement tokenMetadata)
{
Debug.Log(tokenMetadata.GetProperty("name"));
}

GetContractMetadata()

public IEnumerator GetContractMetadata(
Action<JsonElement> callback,
string contractAddress);

Gets the metadata for the specified contract. Most contracts, including the built-in FA2 contract, do not have metadata.

Example:

public void RunGetContractMetadata()
{
var routine = TezosManager.Instance.Tezos.API.GetContractMetadata(
callback: HandleGetContractMetadata,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address
);
StartCoroutine(routine);
}

private void HandleGetContractMetadata(JsonElement contractMetadata)
{
Debug.Log(contractMetadata);
}

GetTokensForContract()

IEnumerator GetTokensForContract(
Action<IEnumerable<Token>> callback,
string contractAddress,
bool withMetadata,
long maxItems,
TokensForContractOrder orderBy);

Gets the tokens in a contract.

Example:

public void RunGetTokensForContract()
{
timesCalled = 0;
var routine = TezosManager.Instance.Tezos.API.GetTokensForContract(
callback: HandleGetTokensForContract,
contractAddress: TezosManager.Instance.Tezos.TokenContract.Address,
withMetadata: true,
maxItems: 10,
orderBy: new TokensForContractOrder.ByLastTimeAsc(0)
);
StartCoroutine(routine);
}

private void HandleGetTokensForContract(IEnumerable<Token> tokenList)
{
List<Token> tokens = new List<Token>(tokenList);
foreach (var tk in tokens)
{
Debug.Log(tk.TokenId);
}
}

The callback returns a list of tokens, but not all of the fields in the Token objects are populated by default. You can populate the fields you want to retrieve by editing the GetTokensForContract method of the TezosSDK.Tezos.API.TezosAPI class.

The methods in this class retrieves information about Tezos via the TZKT block explorer. To change the information that the GetTokensForContract method retrieves, update the URL to add fields.

The default URL looks like this:

var url =
$"tokens?contract={contractAddress}&select=contract,tokenId as token_id" +
$"{(withMetadata ? ",metadata as token_metadata" : "")},holdersCount as holders_count,id," +
$"lastTime as last_time&{sort}&limit={maxItems}";

To get the total supply of each token type, add the totalSupply field to the URL, like this:

var url =
$"tokens?contract={contractAddress}&select=contract,tokenId as token_id" +
$"{(withMetadata ? ",metadata as token_metadata" : "")},holdersCount as holders_count,id," +
$"totalSupply as total_supply," +
$"lastTime as last_time&{sort}&limit={maxItems}";

Now when you run the GetTokensForContract method, the data passed to the callback includes the total supply of each token:

private void HandleGetTokensForContract(IEnumerable<Token> tokenList)
{
List<Token> tokens = new List<Token>(tokenList);
foreach (var tk in tokens)
{
Debug.Log($"Token ID {tk.TokenId} has total supply {tk.TotalSupply} among {tk.HoldersCount} holders");
}
}

For information about what fields you can add to this URL, see the TZKT API reference.

GetOperationStatus()

IEnumerator GetOperationStatus(
Action<bool?> callback,
string operationHash);

Returns true if the specified operation was successful, false if it failed, or null (or HTTP 204) if it doesn't exist.

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)
{
Debug.Log($"Transfer complete with transaction hash {txHash}");
var routine = TezosManager.Instance.Tezos.API.GetOperationStatus(
callback: HandleGetOperationStatus,
operationHash: txHash
);
StartCoroutine(routine);
}

private void HandleGetOperationStatus(bool? result)
{
Debug.Log(result);
}

GetLatestBlockLevel()

IEnumerator GetLatestBlockLevel(
Action<int> callback);

Returns the block level, or the number of blocks since the genesis block.

Example:

public void RunGetLatestBlockLevel()
{
var routine = TezosManager.Instance.Tezos.API.GetLatestBlockLevel(
callback: HandleGetLatestBlockLevel
);
StartCoroutine(routine);
}

private void HandleGetLatestBlockLevel(int blockLevel)
{
Debug.Log(blockLevel);
}

GetAccountCounter()

IEnumerator GetAccountCounter(
Action<int> callback,
string address);

Returns the counter for implicit accounts, which is a unique number that you can use to ensure that transactions are not duplicated.

Example:

public void RunGetAccountCounter()
{
var routine = TezosManager.Instance.Tezos.API.GetAccountCounter(
callback: HandleGetAccountCounter,
address: myAddress
);
StartCoroutine(routine);
}

private void HandleGetAccountCounter(int counter)
{
Debug.Log(counter);
}

GetOriginatedContractsForOwner()

IEnumerator GetOriginatedContractsForOwner(
Action<IEnumerable<TokenContract>> callback,
string creator,
string codeHash,
long maxItems,
OriginatedContractsForOwnerOrder orderBy);

Gets the contracts that the specified account deployed (originated). Optionally, you can pass the hash of a contract to return only contracts that match that hash. For example, the hash of the contract in the TokenContract object is in the Resources/Contracts/FA2TokenContractCodeHash.txt file.

Example:

public void RunGetOriginatedContractsForOwner()
{
var routine = TezosManager.Instance.Tezos.API.GetOriginatedContractsForOwner(
callback: HandleGetOriginatedContractsForOwner,
creator: myAddress,
codeHash: "",
maxItems: 10,
orderBy: new OriginatedContractsForOwnerOrder.ByLastActivityTimeAsc(0)

);
StartCoroutine(routine);
}

private void HandleGetOriginatedContractsForOwner(IEnumerable<TokenContract> contractList)
{
List<TokenContract> contracts = new List<TokenContract>(contractList);
foreach (var contract in contracts)
{
Debug.Log(contract.Address);
}
}