askill
payram-agent-onboarding

payram-agent-onboardingSafety 75Repository

Deploy and automate PayRam for AI agents and CLI-only environments. No web UI required — pure API-driven payment infrastructure. Install via setup_payram_agents.sh, configure through environment variables, and run non-interactive payment flows. Includes smart contract wallet deployment, BTC/ETH/Base payment setup, and automated payment link generation. Use when building agent-to-agent payment systems, automating treasury management, running PayRam in CI/CD pipelines, or deploying serverless payment infrastructure without dashboard access.

10 stars
1.2k downloads
Updated 2/21/2026

Package Files

Loading files...
SKILL.md

PayRam Agent Onboarding

Looking for standard deployment with web UI? See payram-setup for the full dashboard installation.

PayRam Agent Onboarding enables fully automated, CLI-driven payment infrastructure for AI agents, automation pipelines, and serverless environments. No web dashboard — pure API interactions controlled via environment variables and shell commands.

When to Use Agent Mode

  • AI Agent Payments: Claude, Copilot, custom MCP clients processing payments autonomously
  • CI/CD Integration: Automated payment testing in deployment pipelines
  • Serverless Infrastructure: Lambda/Cloud Functions triggering payment operations
  • Treasury Automation: Programmatic fund management without human interaction
  • Headless Commerce: Backend-only payment processing for APIs and microservices

Prerequisites

System Requirements:

  • Ubuntu 22.04 or compatible Linux
  • Docker (for PAYRAM_NODE_MODE=docker, default)
  • 4 CPU cores, 4GB RAM minimum
  • PostgreSQL database (configured during installation)

Installation Script:

curl -fsSL https://raw.githubusercontent.com/PayRam/payram-scripts/main/setup_payram_agents.sh -o setup_payram_agents.sh
chmod +x setup_payram_agents.sh

Quick Start

One-Step Interactive Flow

# Install, configure, and create first payment
./setup_payram_agents.sh

This runs the complete setup flow:

  1. Network selection (testnet/mainnet)
  2. Install PayRam backend via setup_payram.sh
  3. Wait for API readiness
  4. Create root user account + default project
  5. Configure local frontend/backend settings
  6. Blockchain setup prompt (ETH/Base/BTC-only)
  7. Optional payment link generation

Fully Non-Interactive Flow

# Set environment variables
export PAYRAM_EMAIL="admin@example.com"
export PAYRAM_PASSWORD="secure-password-123"
export PAYRAM_NETWORK="testnet"
export PAYRAM_BLOCKCHAIN_SETUP="skip"  # BTC-only, no funding needed
export PAYRAM_WALLET_CHOICE="1"        # Auto-create wallet
export PAYRAM_WALLET_QUIET="1"         # Suppress prompts

# Run automated setup
./setup_payram_agents.sh

Commands Reference

Run from repository root: ./setup_payram_agents.sh [command]

Core Commands

CommandPurpose
(none) or menuShow interactive step menu
statusCheck API reachability and authentication status
setupFirst-time: register root user + create default project
signinAuthenticate; saves token to .payraminfo/headless-tokens.env
ensure-configConfigure local frontend/backend URLs (required for payments)
ensure-walletCreate/link BTC wallet (random HD wallet or existing)
runFull automated flow: setup → config → wallet → payment link

Blockchain Setup Commands

CommandPurpose
setup-ethSetup Ethereum payments (post-install) — deploys SCW wallet
setup-baseSetup Base payments (post-install) — deploys SCW wallet
deploy-scwDeploy EVM smart contract wallet; auto-link to project
deploy-scw-flowGenerate mnemonic → fund deployer → balance check → deploy SCW

Payment & Utility Commands

CommandPurpose
create-payment-link [projectId] [email] [amountUSD]Generate payment link; outputs URL
reset-local [-y]Wipe local DB/API data; requires re-running setup

Environment Variables

Authentication & API

VariableDefaultDescription
PAYRAM_API_URLhttp://localhost:8080Backend API base URL
PAYRAM_EMAILRoot user email (setup/signin)
PAYRAM_PASSWORDRoot user password
PAYRAM_CUSTOMER_IDfrom token fileAuto-populated after signin
PAYRAM_FRONTEND_URLhttp://localhostUsed by ensure-config (local)

Project & Payment Configuration

VariableDefaultDescription
PAYRAM_PROJECT_NAMEDefault ProjectProject name during setup
PAYRAM_PAYMENT_EMAILCustomer email for payment links
PAYRAM_PAYMENT_AMOUNT10Payment amount in USD
PAYRAM_NETWORKtestnetNetwork selection: testnet or mainnet
PAYRAM_BLOCKCHAIN_SETUPskipBlockchain choice: eth, base, or skip (BTC-only)

Wallet & Node Configuration

VariableDefaultDescription
PAYRAM_WALLET_CHOICE1 create, 2 link, 3 skip (non-interactive)
PAYRAM_WALLET_QUIETIf set, suppress wallet prompt text
PAYRAM_NODE_MODEdockerJavaScript runtime: docker or host
PAYRAM_NODE_DOCKER_IMAGEnode:20-bullseye-slimDocker image for JS scripts

Smart Contract Wallet (SCW) Deployment

VariableDefaultDescription
PAYRAM_ETH_RPC_URLhttps://ethereum-sepolia-rpc.publicnode.comRPC endpoint (no API key needed)
PAYRAM_FUND_COLLECTORdeployer addressCold wallet address (0x...) for fund sweeps
PAYRAM_SCW_NAMEHeadless SCWName for the SCW wallet
PAYRAM_BLOCKCHAIN_CODEETHBlockchain: ETH, BASE, POLYGON
PAYRAM_MNEMONICBIP39 mnemonic (or read from .payraminfo/headless-wallet-secret.txt)
PAYRAM_SCW_MIN_BALANCE_ETH0.01 (testnet)Minimum balance before deploying SCW
PAYRAM_SCW_SKIP_BALANCE_CHECKSkip balance polling (not recommended)

Token Storage: Saved to .payraminfo/headless-tokens.env after signin.


Typical Agent Workflow

1. Initial Setup (BTC-Only, No Funding Required)

export PAYRAM_EMAIL="agent@example.com"
export PAYRAM_PASSWORD="agent-secure-pass"
export PAYRAM_NETWORK="testnet"
export PAYRAM_BLOCKCHAIN_SETUP="skip"
export PAYRAM_WALLET_CHOICE="1"
export PAYRAM_WALLET_QUIET="1"

./setup_payram_agents.sh

2. Add Ethereum Payments (Requires Funding)

# Generate mnemonic and show deployer address
./setup_payram_agents.sh setup-eth

# Script will display deployer address like:
# "Send testnet ETH to: 0x742d35Cc6634C0532925a3b844Bc9e7595f0bEeB"

# Fund the address using testnet faucet:
# - https://sepoliafaucet.com
# - https://www.alchemy.com/faucets/ethereum-sepolia

# Script automatically polls for balance and deploys when funded

3. Create Payment Link

# Interactive (prompts for project, email, amount)
./setup_payram_agents.sh create-payment-link

# Non-interactive
export PAYRAM_PAYMENT_EMAIL="customer@example.com"
export PAYRAM_PAYMENT_AMOUNT="49.99"
./setup_payram_agents.sh create-payment-link

Payment URL Format:

http://localhost/payment?reference_id=ref_abc123&host=http://localhost:8080

⚠️ Critical: Use the exact URL printed. The host parameter and & separator are required.


Smart Contract Wallet (SCW) Deployment

Deploy-SCW Flow

deploy-scw-flow executes:

  1. Generate Mnemonic: Creates BIP39 seed (saved to .payraminfo/headless-wallet-secret.txt)
  2. Derive Deployer: Shows Ethereum address for funding
  3. Wait for Balance: Polls RPC until balance ≥ PAYRAM_SCW_MIN_BALANCE_ETH
  4. Deploy Contract: Executes scripts/deploy-scw-eth.js
  5. Register & Link: Adds SCW to backend and associates with project

Funding the Deployer

Testnet (Sepolia):

Mainnet:

  • Send real ETH to deployer address
  • Recommended minimum: 0.05 ETH for reliable deployment

RPC Configuration

Default RPC Endpoints:

  • ETH Testnet (Sepolia): https://eth-sepolia.g.alchemy.com/v2/demo
  • ETH Mainnet: Requires your own Alchemy/Infura key
  • Base Testnet: https://sepolia.base.org
  • Base Mainnet: https://mainnet.base.org

Override with:

export PAYRAM_ETH_RPC_URL="https://eth-mainnet.g.alchemy.com/v2/YOUR_KEY"

Fund Collector (Cold Wallet)

By default, funds sweep to the deployer address. Configure a separate cold wallet:

export PAYRAM_FUND_COLLECTOR="0x1234567890abcdef1234567890abcdef12345678"
./setup_payram_agents.sh deploy-scw

Setting Up Additional Blockchains

After initial setup (which includes BTC), add EVM chains:

Ethereum Payments

./setup_payram_agents.sh setup-eth
  • Sets RPC URL based on PAYRAM_NETWORK (testnet → Sepolia, mainnet → Mainnet)
  • Runs full deploy-scw-flow
  • Blockchain code: ETH

Base Payments

./setup_payram_agents.sh setup-base
  • Sets RPC URL based on PAYRAM_NETWORK (testnet → Base Sepolia, mainnet → Base)
  • Runs full deploy-scw-flow
  • Blockchain code: BASE

Note: Both testnet and mainnet ETH use blockchain code ETH. Network is determined by RPC endpoint.


Docker Node Runtime Behavior

When PAYRAM_NODE_MODE=docker (default):

  • JavaScript scripts run inside Docker containers
  • localhost in PAYRAM_API_URL is mapped to host.docker.internal
  • .payraminfo directory is mounted for access to tokens and mnemonic
  • Requires Docker daemon running with host network access

Host Mode Alternative:

export PAYRAM_NODE_MODE="host"
./setup_payram_agents.sh deploy-scw

Agent Automation Best Practices

Non-Interactive Configuration

For fully automated agent runs, always set:

export PAYRAM_EMAIL="agent@example.com"
export PAYRAM_PASSWORD="secure-password"
export PAYRAM_CUSTOMER_ID="from-token-file"
export PAYRAM_BLOCKCHAIN_SETUP="skip"  # or "eth", "base"
export PAYRAM_WALLET_CHOICE="1"
export PAYRAM_WALLET_QUIET="1"

SCW Balance Thresholds

If RPC has delayed balance reporting, increase threshold:

export PAYRAM_SCW_MIN_BALANCE_ETH="0.02"
./setup_payram_agents.sh deploy-scw-flow

Docker Networking

Ensure Docker has access to host networking:

  • Docker Desktop: Enable "Use kernel networking for UDP" in settings
  • Linux: Docker daemon runs with --network=host by default

Files and Secrets Management

Token Storage:

  • .payraminfo/headless-tokens.env — Authentication tokens (created by signin)

Wallet Secrets:

  • .payraminfo/headless-wallet-secret.txt — BIP39 mnemonic for SCW deployment

Scripts:

  • scripts/generate-deposit-wallet.js — BTC HD wallet generation
  • scripts/generate-deposit-wallet-eth.js — Ethereum xpub derivation
  • scripts/deploy-scw-eth.js — Smart contract wallet deployment

⚠️ Security: Never commit .payraminfo/ to version control. Add to .gitignore.


Troubleshooting

IssueSolution
API unreachableEnsure PayRam is running: ./setup_payram_agents.sh. Check PAYRAM_API_URL.
401 UnauthorizedToken expired. Re-authenticate: ./setup_payram_agents.sh signin
Payment creation returns 500Run ensure-config and ensure-wallet. Check logs: docker logs payram 2>&1 | tail -80
deploy-scw RPC 401 errorDon't use placeholder RPC URLs. Default (PublicNode) is used if env looks invalid.
INSUFFICIENT_FUNDS during deploySend testnet ETH to deployer address shown in logs. Wait for confirmations.
Payment page loads indefinitelyUse exact URL returned. Ensure host param and & separator are preserved (not \u0026).
Docker can't reach localhost APIUse PAYRAM_API_URL=http://host.docker.internal:8080 or switch to PAYRAM_NODE_MODE=host

Reset and Reinstall

# Wipe all data and start fresh
./setup_payram_agents.sh reset-local -y

# Re-run setup
./setup_payram_agents.sh

Integration with MCP Clients

Connect your AI agent to PayRam:

{
  "mcpServers": {
    "payram": {
      "url": "http://localhost:8080/mcp",
      "apiKey": "your-api-key-from-signin"
    }
  }
}

Agent Workflow:

  1. Agent calls PayRam MCP tools for payment operations
  2. PayRam processes API requests without UI interaction
  3. Webhooks notify agent of payment status changes
  4. Agent continues workflow based on payment outcomes

Related Skills

SkillPurpose
payram-setupStandard deployment with web dashboard
payram-payment-integrationIntegrate payments into applications
payram-webhook-integrationHandle payment event callbacks
payram-checkout-integrationCheckout flow implementation

Install

Download ZIP
Requires askill CLI v1.0+

AI Quality Score

88/100Analyzed 2/23/2026

Highly comprehensive technical skill for deploying PayRam in agent/CI/CD environments. Excellent structure with clear command references, environment variables, and workflow examples. Well-organized with tables, warnings, and troubleshooting. Slightly less actionability for users unfamiliar with the PayRam ecosystem, but the detailed documentation compensates. Strong clarity and completeness with minor safety improvements possible.

75
96
85
92
88

Metadata

Licenseunknown
Version-
Updated2/21/2026
PublisherPayRam

Tags

apici-cddatabasegithubgithub-actionsllmpromptingsecurity