NodeAPI
Node API
Version: 0.5.2
Status: Phase 3 — Public
Live at: nodeapi.ai | API Docs | MCP
Machine-native spatial data processing for AI agents and developers. 25 endpoints. Pay $0.01 USDC per operation on Solana. No accounts, no API keys, no subscriptions.
Quick Start
# 1. Send a request — get a 402 with payment details
curl -X POST https://nodeapi.ai/v1/validate \
-F "file=@parcels.geojson"
# → 402: { "recipient": "D8m8C9amSawdqSgEdXWkMZ3M86qsVQuDJswG1wZYkezP", "amount_usd": "0.01", ... }
# 2. Send 0.01 USDC to the recipient on Solana Mainnet
# Get the transaction signature from your wallet
# 3. Retry with the transaction signature
curl -X POST https://nodeapi.ai/v1/validate \
-F "file=@parcels.geojson" \
-H "X-PAYMENT: <your_solana_tx_signature>"
# → 200: { "total_features": 1204, "valid_count": 1204, ... }Related MCP server: LocuSync Server
Payment
Every paid endpoint uses Solana Pay with USDC on Solana Mainnet.
Protocol | Solana Pay |
Network | Solana Mainnet |
Asset | USDC ( |
Price | $0.01 flat per operation |
Recipient |
|
Flow:
Call any endpoint → receive
402with Solana Pay URL + recipientSend 0.01 USDC on Solana Mainnet (include memo:
nodeapi:<operation>)Retry with
X-PAYMENT: <transaction_signature>Receive processed data
Endpoints
All endpoints available at /v1/<path> (recommended) and /<path> (legacy, still supported).
Info (free)
Method | Path | Description |
GET |
| Service health |
GET |
| Full pricing list |
Format & Inspection
Method | Path | Description |
POST |
| Convert between GeoJSON, Shapefile, GeoPackage, KML |
POST |
| Project or reproject to any EPSG (auto-detects assign vs transform) |
POST |
| Validate geometry — returns JSON report |
POST |
| Repair invalid geometry (make_valid) |
POST |
| Extract field schema, CRS, bbox, feature count |
POST |
| Extract geometry from DXF/CAD files |
Geoprocessing (single input)
Method | Path | Description |
POST |
| Clip to bounding box or polygon mask |
POST |
| Buffer features by distance in meters |
POST |
| Delete all features, preserve empty schema |
POST |
| Dissolve features by attribute field |
POST |
| Convert geometries to centroid points |
POST |
| Extract polygon boundaries as lines |
POST |
| Convert closed lines to polygons |
POST |
| Explode multipart geometries |
POST |
| Add a new attribute column |
Geoprocessing (two inputs)
Method | Path | Description |
POST |
| Combine all features from two layers |
POST |
| Spatial intersection of two layers |
POST |
| Layer A minus overlap with layer B |
POST |
| Append features from layer B into layer A's schema |
POST |
| Merge two layers, preserving all fields |
POST |
| Join attributes by spatial relationship |
Tiles
Method | Path | Description |
POST |
| Generate |
Jobs
Method | Path | Description |
GET |
| Poll async job status |
GET |
| Download completed job result |
Supported input formats: GeoJSON, Shapefile (.zip), GeoPackage (.gpkg), KML, GDB (read), DXF
MCP Integration
Node API exposes all 25 endpoints as MCP tools — compatible with Claude, GPT-4o, and any MCP-enabled agent.
Remote (no install required)
https://nodeapi.ai/mcp/sseConnect any MCP client to this SSE endpoint. No authentication needed.
Claude Desktop (local)
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"node-api": {
"command": "/path/to/venv/bin/python",
"args": ["-m", "app.mcp_server"],
"cwd": "/path/to/node-api"
}
}
}22 MCP tools: convert, reproject, validate, repair, schema, clip, dxf, buffer, union, intersect, difference, erase, dissolve, feature-to-point, feature-to-line, feature-to-polygon, multipart-to-singlepart, add-field, append, merge, spatial-join, pricing
Webhooks
For async jobs (DXF conversion, any large file), pass a webhook_url to receive a POST on completion instead of polling.
curl -X POST https://nodeapi.ai/v1/dxf \
-F "file=@site-plan.dxf" \
-F "output_format=geojson" \
-F "webhook_url=https://your-agent.com/callback" \
-H "X-PAYMENT: <tx_signature>"Webhook payload:
{
"job_id": "abc-123",
"operation": "dxf",
"status": "done",
"result_url": "https://nodeapi.ai/v1/jobs/abc-123/download",
"result_filename": "output.geojson",
"size_bytes": 48291
}Signed with X-Webhook-Signature: sha256=<HMAC> for verification.
Architecture
FastAPI — async, OpenAPI spec at
/docsGeoPandas + GDAL — 200+ vector format support
Shapely 2.x — geometry operations
pyproj — CRS reprojection
tippecanoe 2.79 — vector tile generation
PostgreSQL — operations log + job queue
Solana Pay — USDC micropayments on Solana Mainnet
MCP SDK — stdio (local) + SSE (remote) transport
Cloudflare Tunnel —
nodeapi.ai→ API server
Dev Setup
git clone https://github.com/eianray/node-api
cd node-api
python3 -m venv venv
venv/bin/pip install -r requirements.txt
cp .env.example .env
# Leave SOLANA_WALLET_ADDRESS=YOUR_SOLANA_WALLET_ADDRESS for dev mode (bypasses payment)
venv/bin/uvicorn app.main:app --reload --port 8100Roadmap
Phase 1 ✅ — Convert, reproject, validate, repair, schema, clip
Phase 2 ✅ — DXF/CAD, buffer, topology (union/intersect/difference), remote MCP SSE
Phase 3 ✅ (Mar 4 2026) — 11 new geoprocessing endpoints, Solana Pay, webhooks, vector tiles, API versioning, 22 MCP tools
Phase 4 — Hetzner migration, CDN caching, batch API, agent directory listings
nodeapi.ai — spatial processing infrastructure for the agent economy.
This server cannot be installed
Maintenance
Appeared in Searches
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/eianray/node-api'
If you have feedback or need assistance with the MCP directory API, please join our Discord server