Rank
83
A Model Context Protocol (MCP) server for GitLab
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
Syrin is a runtime intelligence system that makes MCP servers debuggable, testable, and safe to run in production. Syrin $1 $1 $1 **A linter + test runner for MCP servers.** --- The Problem $1 is how AI agents call external tools — read files, query databases, hit APIs. If you are building or using an MCP server, your AI agent depends on those tool definitions being correct. They usually are not. - Tool descriptions too vague for the LLM to pick the right one - Two tools look so similar the model picks one at random - Parameter s Capability contract not published. No trust telemetry is available yet. 43 GitHub stars reported by the source. Last updated 2/25/2026.
Freshness
Last checked 2/25/2026
Best For
@syrin/cli is best for mcp, model-context-protocol, debugging workflows where MCP compatibility matters.
Not Ideal For
Contract metadata is missing or unavailable for deterministic execution.
Evidence Sources Checked
editorial-content, GITHUB MCP, runtime-metrics, public facts pack
Syrin is a runtime intelligence system that makes MCP servers debuggable, testable, and safe to run in production. Syrin $1 $1 $1 **A linter + test runner for MCP servers.** --- The Problem $1 is how AI agents call external tools — read files, query databases, hit APIs. If you are building or using an MCP server, your AI agent depends on those tool definitions being correct. They usually are not. - Tool descriptions too vague for the LLM to pick the right one - Two tools look so similar the model picks one at random - Parameter s
Public facts
5
Change events
1
Artifacts
0
Freshness
Feb 25, 2026
Capability contract not published. No trust telemetry is available yet. 43 GitHub stars reported by the source. Last updated 2/25/2026.
Trust score
Unknown
Compatibility
MCP
Freshness
Feb 25, 2026
Vendor
Syrin Labs
Artifacts
0
Benchmarks
0
Last release
1.5.0
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Capability contract not published. No trust telemetry is available yet. 43 GitHub stars reported by the source. Last updated 2/25/2026.
Setup snapshot
git clone https://github.com/syrin-labs/cli.gitSetup complexity is MEDIUM. Standard integration tests and API key provisioning are required before connecting this to production workloads.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Syrin Labs
Protocol compatibility
MCP
Adoption signal
43 GitHub stars
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
bash
$ syrin analyse --transport http --url http://localhost:8000/mcp E110 Tool Ambiguity get_user ↔ fetch_user E101 Missing Tool Description process_data has no description E102 Underspecified Input user_id: no format, no example, no enum E105 Free Text Propagation get_status → update_user (unconstrained string) W104 Generic Description "Get data" — too vague for tool selection 5 issues found (4 errors, 1 warning)
bash
npx @syrin/cli analyse --transport http --url https://docs.syrin.dev/mcp
bash
npx @syrin/cli analyse --transport http --url http://localhost:8000/mcp
bash
npx @syrin/cli analyse --transport stdio --script "python server.py"
bash
git clone https://github.com/Syrin-Labs/cli.git cd cli/examples/demo-mcp-py python3 -m venv .venv && source .venv/bin/activate pip install -r requirements.txt python server.py --mode http --port 8000 & npx @syrin/cli list tools --transport http --url http://localhost:8000/mcp npx @syrin/cli analyse --transport http --url http://localhost:8000/mcp
bash
# Run without installing npx @syrin/cli analyse --transport http --url http://localhost:8000/mcp # Or install globally npm install -g @syrin/cli syrin --version
Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB MCP
Editorial quality
ready
Syrin is a runtime intelligence system that makes MCP servers debuggable, testable, and safe to run in production. Syrin $1 $1 $1 **A linter + test runner for MCP servers.** --- The Problem $1 is how AI agents call external tools — read files, query databases, hit APIs. If you are building or using an MCP server, your AI agent depends on those tool definitions being correct. They usually are not. - Tool descriptions too vague for the LLM to pick the right one - Two tools look so similar the model picks one at random - Parameter s

A linter + test runner for MCP servers.
MCP (Model Context Protocol) is how AI agents call external tools — read files, query databases, hit APIs. If you are building or using an MCP server, your AI agent depends on those tool definitions being correct.
They usually are not.
Syrin catches all of this before production.
$ syrin analyse --transport http --url http://localhost:8000/mcp
E110 Tool Ambiguity get_user ↔ fetch_user
E101 Missing Tool Description process_data has no description
E102 Underspecified Input user_id: no format, no example, no enum
E105 Free Text Propagation get_status → update_user (unconstrained string)
W104 Generic Description "Get data" — too vague for tool selection
5 issues found (4 errors, 1 warning)

One command. No install, no config, no API keys:
npx @syrin/cli analyse --transport http --url https://docs.syrin.dev/mcp
Have your own MCP server running? Point Syrin at it:
npx @syrin/cli analyse --transport http --url http://localhost:8000/mcp
If your server uses stdio instead of HTTP:
npx @syrin/cli analyse --transport stdio --script "python server.py"
Want to try more commands against a local example server?
git clone https://github.com/Syrin-Labs/cli.git
cd cli/examples/demo-mcp-py
python3 -m venv .venv && source .venv/bin/activate
pip install -r requirements.txt
python server.py --mode http --port 8000 &
npx @syrin/cli list tools --transport http --url http://localhost:8000/mcp
npx @syrin/cli analyse --transport http --url http://localhost:8000/mcp
Requirements: Node.js >= 20.12, npm >= 9
| Code | Issue | What Happens Without Syrin | | ---- | --------------------- | ------------------------------------------- | | E110 | Tool Ambiguity | LLM picks the wrong tool at random | | E101 | Missing Description | LLM has no idea what the tool does | | E102 | Underspecified Input | LLM hallucinates parameter values | | E105 | Free Text Propagation | LLM passes sentences where data is expected | | E103 | Type Mismatch | Tool chains break silently | | E107 | Circular Dependency | Agent loops forever, burns tokens | | E301 | Output Explosion | 12MB response blows the context window | | E500 | Side Effect Detected | Tool writes to disk when it should not |
See the full list: Error Reference · Warning Reference
| Command | What It Does |
| --------------- | ------------------------------------------------------------------------ |
| syrin list | Show tools, resources, and prompts a server exposes |
| syrin analyse | Static analysis — catch contract issues without executing tools |
| syrin test | Run tools in a sandbox and validate behavior against contracts |
| syrin dev | Interactive session — watch an LLM interact with your tools in real time |
| syrin doctor | Validate your config, environment, and connections |
Zero-config commands: list, analyse, and test --connection work with just --url or --script. No config file needed.
Config required: dev mode needs LLM API keys. Run syrin init --global to set up once.
# Run without installing
npx @syrin/cli analyse --transport http --url http://localhost:8000/mcp
# Or install globally
npm install -g @syrin/cli
syrin --version
syrin init # Creates syrin.yaml + tools/ directory
syrin doctor # Validates config and connections
syrin analyse # Analyse your MCP server
syrin test # Run contract tests
syrin dev --exec # Interactive LLM-MCP session
Define behavioral guarantees for your tools in tools/<tool-name>.yaml:
version: 1
tool: fetch_user
contract:
input_schema: FetchUserRequest
output_schema: User
guarantees:
side_effects: none
max_output_size: 10kb
tests:
- name: 'valid user'
input:
user_id: '123'
expect:
output_schema: User
- name: 'invalid input'
input:
user_id: 123
expect:
error:
type: input_validation
Run tests: syrin test or syrin test --tool fetch_user
Documentation: Writing Test Cases · Test Your MCP Tools
# .github/workflows/syrin.yml
name: MCP Validation
on: [push, pull_request]
jobs:
validate:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'
- run: npm install -g @syrin/cli
- run: syrin analyse --ci
- run: syrin test --ci --strict
See full CI docs: Add Syrin to CI
Full docs at docs.syrin.dev
| Topic | Link | | --------------- | ---------------------------------------------------------------------------------------- | | Getting Started | docs.syrin.dev/getting-started | | Setup Guide | docs.syrin.dev/setup | | Configuration | docs.syrin.dev/configuration | | All Commands | docs.syrin.dev/commands | | Error Reference | docs.syrin.dev/testing/error-reference |
Contributions welcome. See Contributing Guide and Code of Conduct.
For security issues: Security Policy.
ISC License. See LICENSE.
Made by Syrin Labs.
Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
missing
Auth
None
Streaming
No
Data region
Unspecified
Protocol support
Requires: none
Forbidden: none
Guardrails
Operational confidence: low
curl -s "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/snapshot"
curl -s "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/contract"
curl -s "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Do not use if
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
83
A Model Context Protocol (MCP) server for GitLab
Traction
No public download signal
Freshness
Updated 2d ago
Rank
80
A Model Context Protocol (MCP) server for GitLab
Traction
No public download signal
Freshness
Updated 2d ago
Rank
74
Expose OpenAPI definition endpoints as MCP tools using the official Rust SDK for the Model Context Protocol (https://github.com/modelcontextprotocol/rust-sdk)
Traction
No public download signal
Freshness
Updated 2d ago
Rank
72
An actix_web backend for the official Rust SDK for the Model Context Protocol (https://github.com/modelcontextprotocol/rust-sdk)
Traction
No public download signal
Freshness
Updated 2d ago
Contract JSON
{
"contractStatus": "missing",
"authModes": [],
"requires": [],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": null,
"outputSchemaRef": null,
"dataRegion": null,
"contractUpdatedAt": null,
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"MCP"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_MCP",
"generatedAt": "2026-04-16T23:51:58.942Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "MCP",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
},
{
"key": "mcp",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "model-context-protocol",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "debugging",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "testing",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "cli",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "runtime-intelligence",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "llm",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "ai",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
}
],
"flattenedTokens": "protocol:MCP|unknown|profile capability:mcp|supported|profile capability:model-context-protocol|supported|profile capability:debugging|supported|profile capability:testing|supported|profile capability:cli|supported|profile capability:runtime-intelligence|supported|profile capability:llm|supported|profile capability:ai|supported|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Syrin Labs",
"href": "https://github.com/Syrin-Labs/cli#readme",
"sourceUrl": "https://github.com/Syrin-Labs/cli#readme",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-25T03:23:03.758Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "MCP",
"href": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-02-25T03:23:03.758Z",
"isPublic": true
},
{
"factKey": "traction",
"category": "adoption",
"label": "Adoption signal",
"value": "43 GitHub stars",
"href": "https://github.com/syrin-labs/cli",
"sourceUrl": "https://github.com/syrin-labs/cli",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-25T03:23:03.758Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/mcp-syrin-labs-cli/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to @syrin/cli and adjacent AI workflows.