Nullsec S1 MCP
Exposes Nullsec security tooling for scanning and explaining ZK circuits (Circom/Halo2) to MCP-compatible AI agents.
README
Nullsec S1 MCP
Security scanning tools for MCP-compatible coding agents.
s1-mcp brings Nullsec S1-style security checks into Cursor, Claude Desktop, and other MCP clients. General app/repo scanning is deterministic and local-first: it does not call a hosted S1 API, does not require an LLM, and does not claim a project is secure just because no supported files were found.
The server also keeps the existing s1_zk_* tools for Circom and Halo2 circuits through @trynullsec/s1-zk.
Install
Use it directly with npx:
npx -y s1-mcp
Or install it in a project:
npm install --save-dev s1-mcp
npx s1-mcp
Requires Node.js 20 or newer.
MCP Config
Add this server to Cursor or Claude Desktop:
{
"mcpServers": {
"nullsec-s1": {
"command": "npx",
"args": ["-y", "s1-mcp"]
}
}
}
Once connected, ask your agent to run s1_scan_repo, s1_scan_file, s1_gate, s1_explain_finding, or the ZK-specific s1_zk_* tools.
General App Tools
s1_scan_repo
Recursively scans supported app files under a target path.
Supported files:
.ts,.tsx,.js,.jsx,.mjs,.cjs.json.env.examplefor key-name exposure checks.solfor Base/EVM Solidity checks
Ignored by default: node_modules, .git, .next, dist, build, coverage, generated lockfile internals, pnpm-lock.yaml, and yarn.lock.
Input:
{
"target": "app",
"ruleCategories": ["auth", "secrets", "dangerous_exec"]
}
Output includes:
targetfilesScannedrulesExecuted- severity
summary issuesproductionGateunsupportedwhen no supported files are found
s1_scan_file
Scans one supported file with the same deterministic rules. Unsupported extensions return an explicit unsupported result instead of a pass/secure verdict.
{
"filePath": "app/api/admin/route.ts"
}
s1_gate
Evaluates production readiness from existing findings or scans a target first.
{
"target": "app",
"policy": {
"blockCritical": true,
"blockHigh": true,
"requireDimensions": ["auth", "secrets", "rate_limits"]
}
}
Blocks by default on critical findings, high findings, secret exposure, dangerous execution with user input, live Base/EVM deploy key patterns, and unauthenticated admin routes with dangerous behavior.
s1_explain_finding
Explains a finding for a developer, founder, or auditor using local templates.
{
"findingId": "S1-EXEC-005",
"audience": "developer"
}
You can also pass a full finding object returned by s1_scan_repo or s1_scan_file.
Deterministic Rule Coverage
General scanning catches common AI-generated app risks:
- Secrets: hardcoded OpenAI/Anthropic/Stripe-style keys,
sk_live_, bearer tokens, private keys, seed phrases, database URLs, webhook secrets, secrets returned in JSON, and secret-likeNEXT_PUBLIC_variables. - Dangerous execution:
child_process.exec,execSync,spawnwithshell: true, user input flowing into command execution,eval, andnew Function. - Auth: admin API routes without visible session/role checks, admin responses without auth, and mutation endpoints without visible auth.
- Input validation:
await req.json()without visible schema validation. - Rate limits: mutation API routes without visible rate limiting.
- Environment exposure: returning
process.env, logging secrets, and concrete.envfiles if scanned. - Dependency risk: install lifecycle scripts, git/http dependencies, and suspicious package scripts.
- Base/EVM Solidity:
tx.origin,delegatecall,selfdestruct, unrestricted mint patterns, low-level calls, deploy private keys, live broadcast/deploy command patterns, and detectable hidden fee/drain controls.
No Solana assumptions are made by default; web3 wording and rules use Base/EVM terminology.
ZK Tools
s1_zk_scan
Scan Circom or Halo2-style ZK circuits using Nullsec S1-ZK.
{
"target": "circuits",
"deep": true,
"format": "json"
}
Behavior:
npx @trynullsec/s1-zk scan <target> --format json --no-banner
When deep is true, the server adds --deep.
s1_zk_explain
Explain a Nullsec S1-ZK rule.
{
"ruleId": "NS-H2-005"
}
s1_zk_rules
List supported Nullsec S1-ZK rules.
{}
Examples
Next.js API route scan:
Use s1_scan_file on app/api/admin/route.ts and explain any production blockers.
Base/EVM contract scan:
Use s1_scan_repo on contracts/ and then run s1_gate with blockHigh enabled.
ZK circuit scan:
Use s1_zk_scan on circuits/ with deep mode enabled.
Security Notes
- General scanning is deterministic and local-only.
- Target paths must stay within the server working directory.
- General scanning performs no shell execution.
- ZK tools invoke
@trynullsec/s1-zkthrough argv arrays withshell: false. - The server does not send code to remote APIs.
- Evidence is sanitized to avoid returning full secrets in MCP responses.
Development
npm install
npm run build
npm test
Run the MCP server locally:
npm run dev
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.