npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

pha-deploy

v0.2.3

Published

CLI token deployment and minting tool for Phantasma blockchain

Readme

pha-deploy

CLI utility for deploying fungible tokens and NFTs on the Phantasma blockchain. The tool consumes structured metadata and token schemas defined in TOML configuration files and relies on the latest phantasma-sdk-ts builders for serialization.

  • Four primary actions: --create-token, --create-series, --mint-fungible, --mint-nft.
  • Configuration-first workflow: fill in config.toml (JSON blobs embedded in TOML) and let the CLI generate and submit Carbon transactions.
  • Dry-run mode available for payload inspection without broadcasting.

Quick Start

# install globally (recommended for CLI usage)
npm i -g pha-deploy

# or run once via npx
npx pha-deploy --help

# local dev install
npm install

# copy the sample configuration and adjust it to your needs
cp config/config.example.toml config.toml

# build the CLI
npm run build

# run an action (uses config.toml by default)
pha-deploy --create-token

Helper just recipes are available (just ct, just cs, just mn, etc.) if you have just installed.


Configuration Overview

All configuration is read from config.toml (or an alternate file passed via --config). CLI flags remain available for overrides, but the recommended flow is to edit config.toml and keep secrets outside of version control.

Key sections in config/config.example.toml:

  • Connection
    rpc, nexus, wif. wif may be left empty for dry runs.

  • Token definition
    symbol, token_type ("nft" or "fungible"), optional token_max_supply / fungible_max_supply and fungible_decimals (mandatory for fungible tokens), optional rom (hex string) for Carbon token ROM.

  • Carbon identifiers
    carbon_token_id (required for series creation or minting against an existing token) and carbon_token_series_id (required for minting).

  • Metadata blobs
    Each metadata block is a multi-line JSON string embedded in TOML:

    token_metadata = """
    {
      "name": "My test token!",
      "icon": "data:image/webp;base64,...",
      "url": "https://example.com",
      "description": "Token description",
      "extraField": "Optional custom data"
    }
    """
    • token_metadata is mandatory for all tokens. Required fields: name, icon, url, description.
      The icon must be a base64 encoded data URI (data:image/png;base64,..., data:image/jpeg;base64,..., or data:image/webp;base64,...).
    • series_metadata (optional) defines shared metadata for NFT series. Populate when metadata should be stored once at the series level.
    • nft_metadata (optional) defines per-instance defaults for minting. You can override fields per mint by editing this block before running --mint-nft.
    • Numeric settings such as royalties should be plain numbers (e.g. 10000000 for 1%).
  • Token schemas
    token_schemas is a JSON object describing the Carbon VM schemas used for series metadata, NFT ROM, and NFT RAM. Example structure:

    token_schemas = """
    {
      "seriesMetadata": [
        { "name": "extraSharedSampleField", "type": "String" }
      ],
      "rom": [
        { "name": "name", "type": "String" },
        { "name": "description", "type": "String" },
        { "name": "imageURL", "type": "String" },
        { "name": "infoURL", "type": "String" },
        { "name": "royalties", "type": "Int32" },
        { "name": "extraSampleField", "type": "String" }
      ],
      "ram": []
    }
    """

    Rules enforced by the SDK:

    • Mandatory fields name, description, imageURL, infoURL, royalties must appear either in seriesMetadata (shared) or in rom (per NFT); the builder fills core structural fields such as the Carbon id, mode, and rom placeholders automatically.

    • Field type values must match VmType names understood by the SDK. Supported values:

      Dynamic
      Array
      Bytes
      Struct
      Int8
      Int16
      Int32
      Int64
      Int256
      Bytes16
      Bytes32
      Bytes64
      String
      Array_Dynamic
      Array_Bytes
      Array_Struct
      Array_Int8
      Array_Int16
      Array_Int32
      Array_Int64
      Array_Int256
      Array_Bytes16
      Array_Bytes32
      Array_Bytes64
      Array_String
    • Leave ram empty ([]) to use a dynamic RAM schema; provide field definitions if you need strict RAM layout.

  • Limits and fees
    create_token_max_data, create_token_series_max_data, mint_token_max_data, gas_fee_* entries are numeric boundaries passed to the transaction helpers. The bundled defaults are tuned for typical deployments and are a safe starting point; change them only if you know you need higher caps or different fee multipliers.

  • Runtime flags
    dry_run toggles dry-run mode when set to true in TOML. config_path is automatically injected when you load a custom file via --config.

Ensure every value present in config.example.toml is reviewed and updated (or deliberately left as default) before sending real transactions.


Running Actions

Each action reads the active configuration, prints a summary (without exposing your WIF), and either broadcasts or exits depending on --dry-run.

  • Create a token

    pha-deploy --create-token --config path/to/config.toml

    Requirements:

    • token_type must be set (nft or fungible).
    • For fungible tokens provide token_max_supply / fungible_max_supply and fungible_decimals.
    • token_metadata and (for NFTs) token_schemas must be present.
  • Create an NFT series

    pha-deploy --create-series --config path/to/config.toml

    Requirements:

    • carbon_token_id referencing the deployed token.
    • token_schemas.seriesMetadata describing the shared schema used for the series.
    • Optional metadata comes from series_metadata.
  • Mint an NFT

    pha-deploy --mint-nft --config path/to/config.toml

    Requirements:

    • carbon_token_id and carbon_token_series_id.
    • token_schemas.rom to drive ROM serialization.
    • nft_metadata containing per-instance values.
  • Mint fungible tokens

    pha-deploy --mint-fungible --config path/to/config.toml

    Requirements:

    • carbon_token_id.
    • mint_fungible_amount (integer atomic units).
    • Optional mint_fungible_to (defaults to the WIF owner when omitted).

Append --dry-run to any command to inspect the serialized payload without submitting it:

pha-deploy --create-token --dry-run

Usage without config.toml

These examples do not use config.toml. Every required value is passed via CLI flags. All JSON values must be single-line strings; line breaks will break JSON parsing.

TOKEN_SCHEMAS_JSON='{"seriesMetadata":[{"name":"extraSharedSampleField","type":"String"}],"rom":[{"name":"name","type":"String"},{"name":"description","type":"String"},{"name":"imageURL","type":"String"},{"name":"infoURL","type":"String"},{"name":"royalties","type":"Int32"},{"name":"extraSampleField","type":"String"}],"ram":[]}'
TOKEN_METADATA_JSON='{"name":"My test token!","icon":"","url":"http://example.com","description":"My test token description"}'

pha-deploy --create-token \
  --rpc https://testnet.phantasma.info/rpc \
  --nexus testnet \
  --wif <WIF> \
  --symbol NFTMY \
  --token-type nft \
  --token-schemas "$TOKEN_SCHEMAS_JSON" \
  --token-metadata "$TOKEN_METADATA_JSON" \
  --create-token-max-data 1000000000 \
  --gas-fee-base 10000 \
  --gas-fee-create-token-base 10000000000 \
  --gas-fee-create-token-symbol 10000000000 \
  --gas-fee-multiplier 10000
TOKEN_SCHEMAS_JSON='{"seriesMetadata":[{"name":"extraSharedSampleField","type":"String"}],"rom":[{"name":"name","type":"String"},{"name":"description","type":"String"},{"name":"imageURL","type":"String"},{"name":"infoURL","type":"String"},{"name":"royalties","type":"Int32"},{"name":"extraSampleField","type":"String"}],"ram":[]}'
SERIES_METADATA_JSON='{"rom":"0xAABBCC","extraSharedSampleField":"aabbsadsd"}'

pha-deploy --create-series \
  --rpc https://testnet.phantasma.info/rpc \
  --nexus testnet \
  --wif <WIF> \
  --carbon-token-id <TOKEN_ID> \
  --token-schemas "$TOKEN_SCHEMAS_JSON" \
  --series-metadata "$SERIES_METADATA_JSON" \
  --create-token-series-max-data 100000000 \
  --gas-fee-base 10000 \
  --gas-fee-create-token-series 2500000000 \
  --gas-fee-multiplier 10000
TOKEN_SCHEMAS_JSON='{"seriesMetadata":[{"name":"extraSharedSampleField","type":"String"}],"rom":[{"name":"name","type":"String"},{"name":"description","type":"String"},{"name":"imageURL","type":"String"},{"name":"infoURL","type":"String"},{"name":"royalties","type":"Int32"},{"name":"extraSampleField","type":"String"}],"ram":[]}'
NFT_METADATA_JSON='{"name":"Test NFT Name","description":"Test NFT Description","imageURL":"images-assets.nasa.gov/image/PIA13227/PIA13227~orig.jpg","infoURL":"https://images.nasa.gov/details/PIA13227","royalties":10000000,"extraSampleField":"abc"}'

pha-deploy --mint-nft \
  --rpc https://testnet.phantasma.info/rpc \
  --nexus testnet \
  --wif <WIF> \
  --carbon-token-id <TOKEN_ID> \
  --carbon-token-series-id <SERIES_ID> \
  --token-schemas "$TOKEN_SCHEMAS_JSON" \
  --nft-metadata "$NFT_METADATA_JSON" \
  --mint-token-max-data 100000000 \
  --gas-fee-base 10000 \
  --gas-fee-multiplier 10000

CLI Flags and Overrides

Action selectors (first match wins):

  • --create-token
  • --create-series
  • --mint-fungible
  • --mint-nft

Common utility flags:

  • --config <path> – load an alternate TOML file.
  • --dry-run – skip broadcasting even if the config has dry_run = false.
  • --rpc-log – enable verbose SDK JSON-RPC logging (full response payloads).
  • --settings-log – print resolved settings before executing an action.

Configuration overrides (values override config.toml when provided):

  • --rpc <url> – RPC endpoint (fallback: https://testnet.phantasma.info/rpc).
  • --nexus <name> – chain nexus (example: mainnet or testnet).
  • --wif <wif> – signer WIF.
  • --symbol <symbol> – token symbol.
  • --token-type <nft|fungible> – token kind (default: nft).
  • --token-max-supply <int> / --fungible-max-supply <int> – max supply (required when token-type is fungible).
  • --fungible-decimals <0..255> – decimals for fungible token (required when token-type is fungible).
  • --carbon-token-id <int> – existing carbon token id (for series or mint).
  • --carbon-token-series-id <int> – existing series id (for mint).
  • --mint-fungible-to <address> – recipient address for fungible mint (default: WIF owner).
  • --mint-fungible-amount <int> – amount to mint (integer atomic units).
  • --rom <hex> – token ROM as hex string.
  • --token-schemas '<json>' – inline JSON for token schemas (seriesMetadata, rom, ram).
  • --token-metadata '<json>' – inline JSON for token metadata fields.
  • --series-metadata '<json>' – inline JSON object or array of { name, value } pairs.
  • --nft-metadata '<json>' – inline JSON object or array of { name, value } pairs.
  • --create-token-max-data <int> – payload limit for token creation.
  • --create-token-series-max-data <int> – payload limit for series creation.
  • --mint-token-max-data <int> – payload limit for minting.
  • --gas-fee-base <int> – base gas fee.
  • --gas-fee-create-token-base <int> – gas fee for token creation.
  • --gas-fee-create-token-symbol <int> – symbol registration fee.
  • --gas-fee-create-token-series <int> – fee for series creation.
  • --gas-fee-multiplier <int> – multiplier applied to gas fee.

Notes:

  • JSON arguments must be passed as single-line quoted strings; for substantial edits, updating config.toml is usually more convenient.
  • Unknown flags are ignored by the loader; prefer editing the TOML file for long-lived configuration changes.