This guide explains how to import, configure, and initialize the Nevermined Payments Python SDK.
Get the NVM API Key
Before using the SDK, you need a Nevermined API Key:
- Go to the Nevermined App
- Sign in or create an account
- Navigate to Settings > API Keys
- Generate a new API key
- Copy the key (format:
nvm:xxxxxxxx...)
Never commit your API key to version control. Use environment variables or a secrets manager.
Import and Initialize
Basic Initialization
from payments_py import Payments, PaymentOptions
# Initialize with API key and environment
payments = Payments.get_instance(
PaymentOptions(
nvm_api_key="nvm:your-api-key-here",
environment="sandbox"
)
)
# Verify initialization
print(f"Connected to: {payments.environment.backend}")
print(f"Account: {payments.account_address}")
Using Environment Variables
import os
from payments_py import Payments, PaymentOptions
payments = Payments.get_instance(
PaymentOptions(
nvm_api_key=os.getenv("NVM_API_KEY"),
environment=os.getenv("NVM_ENVIRONMENT", "sandbox")
)
)
Configuration Options
The PaymentOptions class accepts the following parameters:
| Parameter | Type | Required | Description |
|---|
nvm_api_key | str | Yes | Your Nevermined API key |
environment | str | Yes | Environment name (see below) |
app_id | str | No | Application identifier |
version | str | No | Application version |
headers | dict | No | Additional HTTP headers |
return_url | str | No | Return URL (browser mode only) |
from payments_py import Payments, PaymentOptions
payments = Payments.get_instance(
PaymentOptions(
nvm_api_key="nvm:your-api-key",
environment="sandbox",
app_id="my-app",
version="1.0.0",
headers={"X-Custom-Header": "value"}
)
)
Environments
Sandbox Environment (Testing)
Use sandbox for development and testing:
payments = Payments.get_instance(
PaymentOptions(
nvm_api_key="nvm:your-api-key",
environment="sandbox"
)
)
- Backend:
https://api.sandbox.nevermined.app
- Proxy:
https://proxy.sandbox.nevermined.app
- Uses test tokens and test networks
Live Environment (Production)
Use live for production:
payments = Payments.get_instance(
PaymentOptions(
nvm_api_key="nvm:your-api-key",
environment="live"
)
)
- Backend:
https://api.live.nevermined.app
- Proxy:
https://proxy.live.nevermined.app
- Uses real tokens and mainnet networks
Custom Environment
For self-hosted or development setups:
import os
# Set environment variables first
os.environ["NVM_BACKEND_URL"] = "http://localhost:3001"
os.environ["NVM_PROXY_URL"] = "http://localhost:443"
payments = Payments.get_instance(
PaymentOptions(
nvm_api_key="nvm:your-api-key",
environment="custom"
)
)
Available Environments
| Environment | Description |
|---|
sandbox | Production sandbox (testing) |
live | Production mainnet |
staging_sandbox | Staging sandbox (internal) |
staging_live | Staging mainnet (internal) |
custom | Custom URLs via environment variables |
Accessing Sub-APIs
The initialized Payments object provides access to specialized APIs:
# Plans API - manage payment plans
payments.plans.register_credits_plan(...)
payments.plans.get_plan(plan_id)
payments.plans.get_plan_balance(plan_id)
# Agents API - manage AI agents
payments.agents.register_agent(...)
payments.agents.get_agent(agent_id)
# Facilitator API - x402 verification/settlement
payments.facilitator.verify_permissions(...)
payments.facilitator.settle_permissions(...)
# X402 Token API - generate access tokens
payments.x402.get_x402_access_token(plan_id, agent_id)
# MCP Integration
payments.mcp.register_tool(...)
await payments.mcp.start(config)
# A2A Integration
payments.a2a["start"](agent_card=card, executor=executor)
Error Handling
The SDK raises PaymentsError for API errors:
from payments_py.common.payments_error import PaymentsError
try:
result = payments.plans.get_plan("invalid-id")
except PaymentsError as e:
print(f"Error: {e.message}")
print(f"Code: {e.code}")
Next Steps
Now that you have initialized the SDK, proceed to: