The Nodetool Packs Registry manages the installation, management, and distribution of node packs within the Nodetool ecosystem. The registry operates using two complementary systems:
- Wheel-based Package Index (PEP 503 compliant) - Hosted at https://nodetool-ai.github.io/nodetool-registry/simple/for fast, reliable package installation viauv pip install
- Package Metadata Registry (index.json) - Provides discovery, descriptions, and browsing functionality for the Nodetool UI
Pack installation is handled by uv/pip using pre-built wheel files, while the Nodetool UI and CLI tools provide interfaces for discovering and managing node packs.
The primary interface for managing packs is through the Nodetool UI, which provides a user-friendly way to:
- Browse available node packs from the registry metadata
- Install/uninstall packs (using uv pip with wheel index under the hood)
- Update packs to latest wheel versions
- View pack information and documentation
The CLI tool is available for developers to create and manage Nodetool packs.
Basic commands:
# List installed packs
nodetool package list
# Scan current directory for nodes and create metadata
nodetool package scan
# Initialize a new Nodetool pack
nodetool package initTo create a pack that can be installed in Nodetool:
IMPORTANT: pack name MUST start with nodetool-
- 
Create a new folder for your project 
- 
Run the nodetool initcommand:
$ nodetool init
Project name: nodetool-example
Description: My example Nodetool pack
Author (name <email>): John Smith <[email protected]>
✅ Successfully initialized Nodetool project
Created:
  - pyproject.toml
  - src/nodetool/nodes/nodetool-example
  - src/nodetool/pack_metadata/- Create your node classes:
from pydantic import Field
from nodetool.workflows.base_node import BaseNode
class MyNode(BaseNode):
    """Example node implementation"""
    prompt: str = Field(
        default="Build me a website for my business.",
        description="Input prompt for the node"
    )
    async def process(self, context: ProcessingContext) -> str:
        # Your node implementation here
        return "Node output"- 
Generate pack metadata: - Run nodetool scanin your pack repository
- This will create your_pack.jsonfile insrc/nodetool/pack_metadata
 
- Run 
- 
Commit and publish your project to a Github repository 
- 
Register your pack in the Nodetool registry: - Fork this repository
- Add your pack information to index.json
- Submit a pull request
 
Your pack should:
- Follow Python packaging best practices
- Include clear documentation for each node
- Provide example usage
- Include proper node metadata (generated via nodetool scan)
Before submitting to the registry:
- Install your pack locally:
pip install -e .- 
Restart Nodetool UI 
- 
Verify your nodes appear in the Nodetool UI 
The Nodetool packs registry is hosted at nodetool-registry. The registry maintains:
- Pack metadata in index.json
- Installation instructions
- Version information
- Node documentation
Each pack in the registry includes:
- Name
- Description
- Repository ID (owner/project format)
- Namespaces provided
- Node metadata
This pack management system is part of the Nodetool project. See the main project repository for license information.