Skip to content

Latest commit

 

History

History
240 lines (161 loc) · 5.57 KB

README.md

File metadata and controls

240 lines (161 loc) · 5.57 KB

ICSI Scripts Guideline

This document serves as a comprehensive walkthrough to deploy and interact with the ICSI canister on the Internet Computer mainnet and local network.

Prerequisites

  1. Internet Identity (II): Acquire your Internet Identity via Internet Identity. It's recommended to use a password manager like Bitwarden with Chrome extension for passkey activation.

  2. NNS Login: Access the NNS Dapp and log in.

  3. ICP Tokens: Top up at least 2.0 ICP tokens to your NNS-II address. Navigate to Tokens > Internet Computer in the NNS Dapp.

  4. DFX CLI: Install the DFINITY Canister SDK (DFX) on your system. Follow the guide at Installing tools | Internet Computer.

  5. Git and Rust: Ensure you have Git and Rust installed on your system.

Deployment Process

1. Create a New Identity

Create a new identity locally using dfx:

dfx identity new custodian_name

Verify and manage identities:

dfx identity whoami
dfx identity list
dfx identity use some_idname

Export the principal address to an environment variable:

export CUSTODIAN_PRINCIPAL=$(dfx identity get-principal)

2. Create a New Canister via NNS Dashboard

  1. Create a new canister through the NNS Dashboard.
  2. Add cycles to the canister.
  3. Add the controller using the custodian_principal obtained earlier.

3. Clone the Project

git clone git@github.com:garudaidr/icp-subaccount-indexer-prototype.git
cd icp-subaccount-indexer-prototype

4. Configure canister_ids.json

Create or modify canister_ids.json in the project root:

{
  "icp_prototype_backend": {
    "ic": "upy4y-myaaa-aaaaal-qjbxa-cai"
  }
}

Replace the canister ID with the one from your NNS dashboard.

5. Prepare for Deployment

Sync the local wallet to the mainnet:

dfx identity --network ic deploy-wallet <canister_id>

Convert ICP to cycles:

dfx cycles convert 0.3 --network ic

6. Deploy the Canister

Use the deploy.sh script for deployment:

# Deploy to mainnet (IC network)
./deploy.sh --network ic

# Deploy to local network
./deploy.sh --network local

# For a clean local deployment
./deploy.sh --network local --clean

Alternatively, you can use the dfx command directly:

dfx deploy icp_prototype_backend --network ic --no-wallet --argument "(variant { Mainnet }, 15 : nat64, 10 : nat32, \"ryjl3-tyaaa-aaaaa-aaaba-cai\", \"$CUSTODIAN_PRINCIPAL\")"

Note: If you encounter issues with the wasm32-unknown-unknown target, install it:

rustup target add wasm32-unknown-unknown

7. Post-Deployment Setup

Export the Canister ID:

export CANISTER_ID=<your_canister_id>

Initialize the poller:

dfx canister --network ic call $CANISTER_ID set_interval '(1)'

Set the starting block to avoid querying from 0:

dfx canister --network ic call $CANISTER_ID set_next_block '(12110174)'

Verify the current block:

dfx canister --network ic call $CANISTER_ID get_next_block '()'

Testing and Interaction

Using test.sh

The test.sh script provides a comprehensive test suite:

# Run tests with deployment
./test.sh --network local

# Run tests without deployment
./test.sh --network local --skip-deploy

Using index.js

The index.js file offers an interactive CLI for canister interaction:

  1. Interactive mode:

    node index.js
  2. CLI mode:

    # Add a subaccount
    node index.js --cli add_subaccount
    
    # Set webhook URL
    node index.js --cli set_webhook_url https://example.com/webhook

Manual CLI Testing

Test methods using the format:

dfx canister --network ic call $CANISTER_ID <method_name> '<argument>'

Examples:

# Check canister status
dfx canister --network ic call $CANISTER_ID canister_status '()'

# Sweep funds
dfx canister --network ic call $CANISTER_ID sweep '()'

# Check balance
dfx ledger --network ic balance

# Transfer out (deduct 0.0001 for fee)
dfx ledger transfer --network ic --amount 0.5098 --memo 0 5c8aea1a5c6b871125c5b876688f2c28483a37314717750f2175156742fd08d8

Identity Management

Exporting Identity

dfx identity export <identity_name>

Importing Identity

dfx identity import <identity_name> <pem_file>

List and switch identities:

dfx identity list
dfx identity use <some_id>

Troubleshooting

If the initial deployment doesn't set the principal ID or ledger ID correctly, modify the post_upgrade() function in your Rust code:

async fn post_upgrade() {
    let custodian_principal = "".to_string(); // fill this ""
    let custodian_principal = Principal::from_text(&custodian_principal).expect("Invalid custodian principal");
    CUSTODIAN_PRINCIPAL.with(|principal_ref| {
        let stored_principal = StoredPrincipal::new(custodian_principal);
        let _ = principal_ref.borrow_mut().set(stored_principal);
    });

    let ledger_principal = "ryjl3-tyaaa-aaaaa-aaaba-cai".to_string();
    let principal = Principal::from_text(&ledger_principal).expect("Invalid ledger principal");
    PRINCIPAL.with(|principal_ref| {
        let stored_principal = StoredPrincipal::new(principal);
        let _ = principal_ref.borrow_mut().set(stored_principal);
    });

    ic_cdk::println!("running post_upgrade...");
    reconstruct_subaccounts();
    reconstruct_network();
}

This comprehensive guide should help you deploy, test, and interact with your ICSI canister effectively.