Welcome 👋,
This tutorial provides an interactive approach to quickly dive into the Ternoa SDK and commence your journey of building on the blockchain. By completing the three fundamental exercises, you will acquire the skills to mint, retrieve and sell an NFT using our tools:
-
Ternoa-js API: A Javascript tool, built on the Polkadot.js API, available as an npm package. It streamlines the execution of transactions (referred to as extrinsics in the Polkadot/Substrate ecosystem) on the Ternoa chain, simplifying the process for developers. For more detailed information, please refer to our documentation.
-
Ternoa Indexer: Our indexer serves as a comprehensive record of Ternoa Chain data, which you can seamlessly integrate into your codebase or experiment with in a playground environment.
Please note that this tutorial assumes a basic understanding of JavaScript and Node.js to grasp the fundamental concepts. If you are seeking detailed documentation, kindly visit the Ternoa Documentation.
Before getting started, please ensure that you have the following prerequisites in place:
- Create a Ternoa account with Alphanet CAPS from the faucet.
- Install and configure your preferred code editor (for this tutorial, we will be using Visual Studio Code [VSC]).
- Install NodeJS v.14+, along with NPM.
- Generate an IPFS Key from the Ternoa IPFS Key manager
Warning: We assume you have already created a new wallet for development purposes with no CAPS on Ternoa Mainnet. It is essential you use a development wallet with NO REAL MONEY in it when learning, practicing, and testing.
We already installed the Ternoa-JS, you can directly run the following command:
npm install
In the .env.exemple
file, you will find the expected environement variables. Copy and paste them into a .env
file at the root of the project.
SEED_TEST_FUNDS
: Your Ternoa account seed you will use to sign transactions.IPFS_API_KEY
: An IPFS KEY generated with the Ternoa IPFS Key manager.
In the src/basics/
folder we will find the following files:
-
01_mintNFT.ts
: In this 1st step, you will understand how to initialize the API and run your first on-chain transaction to create an NFT. Keep the NFT id from the log with you as you will need it later. -
02_getNFT.ts
: In the 2nd step, you will see how to use our Indexer to retrieve your NFT data. -
03_sellNFT.ts
: In the 3rd and last step, you will learn how to list your NFT for sale on a marketplace.
Run the following command to execute each script once you have read carefully the comments (replace FILENAME with the correct file name):
npm run start src/basics/FILENAME.ts
Impressive, isn't it? Just one line of code to create an NFT and another single line to list it on a marketplace. Exciting, isn't it? Now, you're all set to kickstart your dApp development journey using our toolkit. Let's get started!
Just follow the advanced guide:
01-mintSecretNFT.ts
: In this 1st advanced step you will see how to create a secret NFT, upload metadata on IPFS, encrypt content and send some private key shares on a TEE/SGX Cluster.
Ternoa is a Decentralized, Open source, NFT-centric Layer 1 blockchain that is multi-chain by design and aims to provide a technical stack to build scalable and secure NFTs with native support for advanced features.