Saltar al contenido principal

Tutorial: Despliega Tu Primer Token SAVITRI-20

Este tutorial te guía a través del despliegue de un token fungible en Savitri Network usando el SDK.

Requisitos Previos

  • Un lightnode de Savitri en ejecución (consulta Inicio Rápido)
  • Cadena de herramientas Rust instalada
  • Una billetera con fondos (usa el faucet del testnet)

1. Configuración del Proyecto

Crea un nuevo proyecto Rust:

cargo new my-savitri-token
cd my-savitri-token

Agrega dependencias a Cargo.toml:

[dependencies]
savitri-sdk = { path = "../savitri-sdk" }
tokio = { version = "1", features = ["full"] }
anyhow = "1"
hex = "0.4"

2. Crear una Billetera

use savitri_sdk::{Wallet, RpcClient};

#[tokio::main]
async fn main() -> anyhow::Result<()> {
// Crear o importar una billetera
let wallet = Wallet::new();
println!("Your address: {}", wallet.address());

// Conectar al nodo local
let client = RpcClient::from_url("http://localhost:8545")?;

// Verificar si el nodo está en ejecución
let health = client.health().await?;
println!("Connected to {} ({})", health.service, health.mode);

Ok(())
}

3. Cargar Tu Billetera

Reclama tokens de testnet a través del faucet:

let claim = client.faucet_claim(wallet.address()).await?;
println!("Received {} SAVT (tx: {})", claim.amount, claim.tx_hash);

// Esperar confirmación
tokio::time::sleep(std::time::Duration::from_secs(10)).await;

// Verificar saldo
let account = client.get_account(wallet.address()).await?;
println!("Balance: {} (nonce: {})", account.balance, account.nonce);

4. Desplegar el Contrato del Token

El despliegue de un token es una transacción con to = None y los datos de inicialización en data:

use savitri_sdk::TransactionBuilder;

// Codificar parámetros de inicialización del token
fn encode_token_init(name: &str, symbol: &str, initial_supply: u128) -> Vec<u8> {
let mut data = b"initialize_savitri20".to_vec();
data.push(0); // separator

// Name (length-prefixed)
data.extend_from_slice(&(name.len() as u32).to_le_bytes());
data.extend_from_slice(name.as_bytes());

// Symbol (length-prefixed)
data.extend_from_slice(&(symbol.len() as u32).to_le_bytes());
data.extend_from_slice(symbol.as_bytes());

// Initial supply (u128 LE)
data.extend_from_slice(&initial_supply.to_le_bytes());

data
}

// Construir transacción de despliegue
let nonce = client.get_nonce(wallet.address()).await?;

let deploy_data = encode_token_init(
"My Token", // name
"MTK", // symbol
1_000_000_000_000_000_000_000_000, // 1M tokens (18 decimals)
);

let deploy_tx = TransactionBuilder::new()
// Sin .to() — indica despliegue de contrato
.data(deploy_data)
.value(0)
.nonce(nonce)
.fee(5_000_000_000_000_000) // 0.005 SAVT contract fee
.build_and_sign(&wallet)?;

println!("Deploy TX built. Contract will be created at a derived address.");

5. Interactuar con el Token

Una vez desplegado, usa el ContractClient para interactuar:

use savitri_sdk::ContractClient;

let contract = ContractClient::from_url_and_wallet(
"http://localhost:8545",
wallet.clone(),
)?;

// Transferir tokens
let tx_hash = contract.call_contract(
&token_contract_address,
b"transfer",
&encode_transfer(&recipient_address, 1000_000_000_000_000_000), // 1000 tokens
Some(0),
).await?;
println!("Transfer TX: {}", tx_hash);

6. Consultar el Saldo del Token

// Via RPC
let balance = client.call_raw(
"account_getTokenBalance",
serde_json::json!([wallet.address(), token_contract_address]),
).await?;
println!("Token balance: {}", balance);

Referencia Rápida de Estándares de Token

EstándarCaso de UsoFunciones Clave
SAVITRI-20Tokens fungiblestransfer, approve, transferFrom
SAVITRI-721NFTsmint, transferFrom, tokenURI
SAVITRI-1155Multi-activosafeTransferFrom, balanceOfBatch

Referencia de Comisiones

OperaciónComisión (SAVT)
Despliegue de token0.005
Transferencia de token0.005
Aprobación de token0.005
Acuñación de NFT0.005
Transferencia en lote0.005

Cantidades y Decimales

Todos los tokens Savitri usan 18 decimales:

1 token     = 1_000_000_000_000_000_000  (10^18)
0.001 token = 1_000_000_000_000_000 (10^15)
1M tokens = 1_000_000_000_000_000_000_000_000 (10^24)

Siguientes Pasos