Building a Smart Contract in Rust for Solana: Minting and Deploying a New Token

posted Originally published at web3dev.click 4 min read

Minting and Deploying a New Token

Introduction

Solana is one of the fastest-growing blockchain platforms, renowned for its high throughput and low transaction fees. One of the most exciting features of Solana is its ability to support smart contracts written in Rust, a systems programming language that emphasizes safety, concurrency, and performance. In this article, we will walk you through the process of creating a smart contract in Rust for Solana, minting a new token, and deploying it on the Solana network.

By the end of this guide, you'll have a fully functional token minted and deployed on Solana's testnet. Let’s get started!

Prerequisites

Before diving into the development process, ensure you have the following tools installed:

Rust: Install Rust by following the instructions on rust-lang.org.

Solana CLI: Install the Solana Command-Line Interface (CLI) by following the instructions on solana.com.

Anchor Framework: Anchor is a framework for building Solana programs in Rust. Install it using cargo:

cargo install --git https://github.com/project-serum/anchor anchor-cli --locked

Node.js and Yarn: These are required for frontend integration if needed. You can download them from nodejs.org and yarnpkg.com.

Step 1: Setting Up Your Development Environment

Create a New Anchor Project

To create a new project, use the anchor CLI:

anchor init my_token_program
cd my_token_program

This command initializes a new Anchor project with the necessary structure and dependencies.

Update the Cargo.toml File

Navigate to the programs/my_token_program/Cargo.toml file and ensure the dependencies include the Solana Program Library (SPL). The SPL provides utilities for token creation and management.

[dependencies]
anchor-lang = "0.28.0"
anchor-spl = "0.28.0"

Step 2: Writing the Smart Contract

The smart contract will define the logic for minting a new token. We'll use the SPL Token program, which is a standard for creating fungible tokens on Solana.

Define the Instruction

In the programs/my_token_program/src/lib.rs file, define an instruction to mint a new token:

use anchor_lang::prelude::*;
use anchor_spl::token::{self, Mint, Token, TokenAccount};

declare_id!("Fg6PaFpoGXkYsidMpWTK6W2BeZ7FEfcYkg476zPFsLnS");

#[program]
pub mod my_token_program {
    use super::*;

    pub fn mint_token(ctx: Context<MintToken>, amount: u64) -> Result<()> {
        msg!("Minting {} tokens", amount);

        // Mint tokens to the associated token account
        token::mint_to(
            CpiContext::new(
                ctx.accounts.token_program.to_account_info(),
                token::MintTo {
                    mint: ctx.accounts.mint.to_account_info(),
                    to: ctx.accounts.destination.to_account_info(),
                    authority: ctx.accounts.authority.to_account_info(),
                },
            ),
            amount,
        )?;

        Ok(())
    }
}

#[derive(Accounts)]
pub struct MintToken<'info> {
    #[account(mut)]
    pub mint: Account<'info, Mint>,
    #[account(mut)]
    pub destination: Account<'info, TokenAccount>,
    /// CHECK: This is the authority of the mint
    pub authority: AccountInfo<'info>,
    pub token_program: Program<'info, Token>,
}

Explanation of the Code

Instruction Definition: The mint_token function defines the logic for minting tokens. It takes two parameters: the context (ctx) and the amount of tokens to mint.

CPI Call: The token::mint_to function is a Cross-Program Invocation (CPI) call to the SPL Token program, which handles the actual minting of tokens.

Accounts: The MintToken struct specifies the accounts required for the instruction:

mint: The token mint account.

destination: The account where the tokens will be minted.

authority: The authority account that has permission to mint tokens.

token_program: The SPL Token program.

Step 3: Compiling the Program

Compile the program using the following command:

anchor build

This command compiles the Rust code into a binary format that can be deployed on the Solana network.

Step 4: Deploying the Program

Deploy the compiled program to the Solana testnet:

anchor deploy

This command uploads the program to the Solana testnet and returns the program ID, which is essential for interacting with the program.

Step 5: Minting a New Token

To mint a new token, follow these steps:

Create a Mint Account

Use the Solana CLI to create a mint account:

spl-token create-token

This command generates a new mint account and outputs the mint address.

Create an Associated Token Account

Next, create an associated token account for the mint:

spl-token create-account <MINT_ADDRESS>

Replace with the address of the mint account created in the previous step.

Mint Tokens Using the Smart Contract

Finally, use the anchor CLI or a custom script to invoke the mint_token instruction. Here's an example using the Solana CLI:

solana program invoke <PROGRAM_ID> \
--accounts mint=<MINT_ADDRESS> \
destination=<TOKEN_ACCOUNT_ADDRESS> \
authority=<AUTHORITY_KEYPAIR> \
token-program=TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA \
--args amount=1000000

Replace the placeholders with the appropriate values:

: The ID of your deployed program.

: The address of the mint account.

: The address of the associated token account.

: The keypair of the mint authority.

Conclusion

In this article, we walked through the process of creating a smart contract in Rust for Solana, minting a new token, and deploying it on the Solana testnet. By leveraging the power of Rust and the Anchor framework, developers can build efficient and secure smart contracts for decentralized applications.

Feel free to experiment with additional features, such as transferring tokens, burning tokens, or implementing custom token logic. Happy coding!

If you read this far, tweet to the author to show them you care. Tweet a Thanks
0 votes

More Posts

Securing a Smart Contract Built with Rust for Solana

Web3Dev - Feb 21

A Deep Dive into Decentralized Provenance Tracking and Smart Contracts

Web3Dev - Mar 28

Smart Contract Bug: Reentrancy Attacks and How to Fix Them

Web3Dev - Feb 19

Revolutionizing Logistics with Web3: A New Era of Transparency, Efficiency, and Trust

Web3Dev - Feb 25

Rust for Beginners: Going Beyond "Hello, World!" (Formatting & Debugging Basics)

Vincent - Aug 30
chevron_left