Guide · 4 min
Call the API directly
POST a JSON payload of files to the public scan endpoint and get back grade, score, and findings. Usable from any CI system, custom build tool, or scripted workflow. No API key required for the public endpoint.
The endpoint
Single POST endpoint, accepts JSON, returns JSON. Body limit is 5MB.
POST https://xploitscan-api.vercel.app/api/scans/upload-json
Send a single-file scan with curl
Quickest way to confirm the endpoint is reachable. The body is a JSON object with a files array; each file has a path and content.
curl -X POST https://xploitscan-api.vercel.app/api/scans/upload-json \
-H "Content-Type: application/json" \
-d '{
"files": [
{
"path": "server.js",
"content": "const API_KEY = \"sk_live_abc123\";"
}
]
}'Read the response
You should get back a JSON object with the grade, severity counts, and a list of findings:
{
"grade": "F",
"score": 0,
"filesScanned": 1,
"criticalCount": 1,
"highCount": 0,
"mediumCount": 0,
"lowCount": 0,
"findings": [
{
"id": "f_001",
"rule": "VC001",
"severity": "critical",
"title": "Hardcoded API Key",
"description": "API key committed to source code",
"file": "server.js",
"line": 1,
"fix": "Move to environment variable"
}
]
}Each finding includes rule, severity, title, description, file, line, and an optional fix string.
Wire it into a Node script
Drop this into your build pipeline. It scans a single file and exits non-zero on any critical finding.
// scan.js
import { readFileSync } from 'node:fs';
const file = process.argv[2];
const content = readFileSync(file, 'utf8');
const res = await fetch(
'https://xploitscan-api.vercel.app/api/scans/upload-json',
{
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ files: [{ path: file, content }] }),
},
);
const data = await res.json();
console.log(`Grade: ${data.grade} (${data.score}/100)`);
console.log(`Findings: ${data.findings.length}`);
process.exit(data.criticalCount > 0 ? 1 : 0);node scan.js server.js
Limits and rules
5MB body limit
For larger projects, scan in batches or use the CLI which streams files.
Public endpoint = 30 free rules
The public endpoint runs the same 30-rule set as anonymous web scans. To unlock the full 131 rules, sign up and use the CLI with
npx xploitscan auth login, or use the GitHub Action with your account.Rate limited per IP
The endpoint is rate-limited to prevent abuse. For production CI use, prefer the GitHub Action or CLI which authenticate with your account.
Need help? Run into something not covered above?
Email admin@xploitscan.com