Quickstart
Follow these steps to install the Tezos SDK for Unity in an existing Unity project and start using it.
These instructions cover:
- Installing the SDK into an existing Unity project
- Testing that the SDK works in your project
- Adding objects that connect to a user's Tezos wallet
Connecting to a user's wallet is a prerequisite to working with Tezos in any application. Accessing the wallet allows your project to see the tokens in it and to prompt the user to submit transactions, but it does not give your project direct control over the wallet. Users must still confirm all transactions in their wallet application.
Using a wallet application in this way saves you from having to implement payment processing and security in your application. Game developers can also use the wallet and its account as a unique account identifier and as the user's inventory.
-
Make sure that you have Unity Editor version 2021.3.23f1 or later.
-
Install a Tezos-compatible wallet on a mobile device that has a camera and can scan QR codes. If you don't have a wallet on a mobile device, follow these steps:
-
Install a Tezos-compatible wallet app on a mobile device. Mobile wallet apps for Tezos include Temple, Kukai, and Umami.
-
Switch the wallet to use Ghostnet testnet instead of Tezos Mainnet. Ghostnet is a network for testing Tezos applications where tokens are free so you don't have to spend real currency to work with your applications.
The process for changing the network is different for each wallet type. These steps are for the Temple wallet:
-
Go to https://teztnets.xyz/, which lists Tezos testnets.
-
Click Ghostnet.
-
Copy one of the public RPC endpoints for Ghostnet, such as
https://rpc.ghostnet.teztnets.xyz
. These URLs accept Tezos transactions from wallets and other applications. -
In the Temple app, open the settings and then click Default node (RPC).
-
Click the plus
+
symbol to add an RPC node. -
On the Add RPC screen, enter the URL that you copied and give the connection a name, such as "Ghostnet," as shown in this picture:
-
Click Add.
-
Make sure that the new RPC node is selected, as in this image:
-
-
From your wallet, get the address of your account, which starts with
tz1
. This is the address that applications use to work with your wallet. -
Get some testnet tez for the wallet:
-
Go to the Ghostnet faucet at https://faucet.ghostnet.teztnets.xyz. This faucet provides tez for free to use on the testnet.
-
On the faucet page, paste your wallet address into the input field labeled "Or fund any address" and click the button for the amount of tez to add to your wallet. 20 tez is enough to work with, and you can return to the faucet later if you need more tez.
It may take a few minutes for the faucet to send the tokens and for those tokens to appear in your wallet.
You can use the faucet as much as you need to get tokens on the testnet, but those tokens are worthless and cannot be used on Mainnet.
-
-
-
Install the SDK through the Unity asset store:
- In the Unity asset store, find the Tezos SDK for Unity.
- Click Add to My Assets.
- In the Unity Editor, in the Package Manager panel, find the Tezos SDK for Unity and click the Download button.
- TODO double-check these instructions when the new package is available on the asset store.
- Verify that the SDK is installed by opening the Project panel and expanding the Assets > TezosSDK folder.
If you see the TezosSDK folder with sub-folders including Editor, Examples, Resources, and Runtime, the SDK is installed correctly.
-
Verify that the SDK works in your project by running the WalletConnection example scene, which demonstrates how to connect to a Tezos wallet in a Unity project:
-
In the Unity Editor, in the Project panel, open the Assets > TezosSDK > Examples folder and click the WalletConnection folder.
-
In the WalletConnection folder, double-click the _WalletConnection scene to open it in the editor.
-
Click the Play button to run the scene.
-
Open the Simulator panel, which shows a QR code.
-
Use your wallet app to scan the barcode and confirm the connection to the Unity project. The project UI shows the address of the connected account, as in this picture:
-
-
Add the prerequisite SDK components to your scene:
-
Open a scene in your project or create a scene.
-
In the Project panel, expand Assets > TezosSDK > Runtime > Prefabs.
-
From the Prefabs folder in the Project panel, drag the MainThreadExecutor prefab to the Hierarchy panel.
-
In the same way, drag the TezosManager prefab to the Hierarchy panel. The TezosManager prefab opens in the Inspector panel.
-
In the Inspector panel, set the information for your project, including its name and URL.
This prefab provides prerequisites to use Tezos in a scene. Its fields control what users see in their wallet applications before connecting to the project.
-
-
Copy the necessary objects to the scene:
-
Open the _WalletConnection scene again.
-
In the Hierarchy panel, expand the Canvas object.
-
Under Canvas, select the following objects by holding Ctrl or Cmd and clicking them:
- ConnectedText
- QRCode
- LogoutButton
- MetadataInfo
- AccountAddress
-
Right-click the elements and then click Copy.
-
Go back to your scene and paste the objects into the scene's canvas in the Hierarchy panel. The Hierarchy panel looks like this:
-
If the objects appear outside the border of your scene, reposition them on the canvas.
-
Save the scene.
-
Click the Play button to run the scene.
-
Open the Simulator panel, which shows a QR code.
-
Use your wallet app to scan the barcode and confirm the connection to the Unity project. Note that the wallet app shows the name of the project that you set on the TezosManager prefab.
The project shows the address that you used to connect.
-
Click the Logout button and then click the Play button to stop the scene.
-
-
Add text to show the account's balance in tez:
-
In the Hierarchy pane, right click the Canvas object and then click Create Empty.
-
Name the new object "AccountBalance."
-
Right-click the AccountBalance object and then click UI > Text - TextMeshPro.
-
Name the new text object "Label" and set its text to "Account balance:".
-
In the Scene panel, move the new text object to below the text "Account Address." If you can't find the text object, you can right-click the label object in the Hierarchy panel and then click Move To View.
-
In the Hierarchy pane, right-click the AccountBalance object and then click UI > Text - TextMeshPro again.
-
Name the new text object "Balance," clear its default text, and move it to the right of the Label object.
-
In the Hierarchy pane, select the AccountBalance object, not the Label or Balance sub-objects.
-
At the bottom of the Inspector pane, click Add Component.
-
Click New Script, name the script "AccountBalance," and click Create and Add.
The new script appears in the Inspector pane, as in this image:
-
Double-click the AccountBalance script to open the script file in your IDE.
-
At the top of the file, add these imports:
using TMPro;
using TezosSDK.Tezos;
using TezosSDK.Beacon; -
Inside the
AccountBalance
class, add this variable to represent the text in the Balance object:public TMP_Text balance;
-
Inside the
Start
function, add these lines of code to add listeners:TezosManager.Instance.MessageReceiver.AccountConnected += OnAccountConnected;
TezosManager.Instance.MessageReceiver.AccountDisconnected += OnAccountDisconnected;These lines of code set functions that respond to events in the Tezos SDK. In this case, they set functions that run when the user's account connects or disconnects.
-
After the
Start
function, add these functions:private void OnAccountConnected(AccountInfo account_info)
{
var routine = TezosManager.Instance.Tezos.GetCurrentWalletBalance(OnBalanceFetched);
StartCoroutine(routine);
}
private void OnBalanceFetched(ulong balance)
{
balance.text = $"{mutezBalance / 1000000f}";
}
private void OnAccountDisconnected(AccountInfo account_info)
{
balance.text = "";
}The
OnAccountConnected
function runs when the account connects. It creates a routine that fetches the account balance and sets theOnBalanceFetched
function as a callback. When the SDK returns the balance, theOnBalanceFetched
function updates the text.The complete script file looks like this:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using TMPro;
using TezosSDK.Tezos;
using TezosSDK.Beacon;
public class AccountBalance : MonoBehaviour
{
public TMP_Text balance;
// Start is called before the first frame update
void Start()
{
TezosManager.Instance.MessageReceiver.AccountConnected += OnAccountConnected;
TezosManager.Instance.MessageReceiver.AccountDisconnected += OnAccountDisconnected;
}
private void OnAccountConnected(AccountInfo account_info)
{
var routine = TezosManager.Instance.Tezos.GetCurrentWalletBalance(OnBalanceFetched);
StartCoroutine(routine);
}
private void OnBalanceFetched(ulong mutezBalance)
{
balance.text = $"{mutezBalance / 1000000f}";
}
private void OnAccountDisconnected(AccountInfo account_info)
{
balance.text = "";
}
// Update is called once per frame
void Update()
{
}
}-
Save the file.
-
In the Unity Editor, in the Hierarchy pane, drag the Balance object to the
Balance
field of the Account Balance script in the Inspector pane. Now the Balance object on the canvas is bound to thebalance
variable in the script, as shown in this picture: -
Run the project, connect your wallet, and see that the UI shows the account's balance in tez.
Now you can bind objects to variables in the code and use listeners to respond to Tezos SDK events. For the complete list of listeners, see the file
Assets/TezosSDK/Runtime/Scripts/Beacon/WalletEventManager.cs
in the SDK. -
-
Now that your project can connect to a user's account, you can use this connection to identify a user's account, because Tezos addresses are unique.
You can also use this connection to send transactions to Tezos on behalf of the user, such as manipulating Tezos tokens as game assets.
For examples, see the scenes in the TezosSDK/Examples
folder.
Note that if you stop the project while your wallet is connected and restart the project later, it remembers that your wallet is connected. The SDK uses the Beacon SDK to connect to wallets and remember connections.