@agentsid/scanner 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +205 -0
- package/action/action.yml +42 -0
- package/action/index.mjs +179 -0
- package/docs/state-of-agent-security-2026.md +377 -0
- package/examples/security-scan.yml +57 -0
- package/package.json +37 -0
- package/reports/aashari-mcp-server-atlassian-confluence.json +110 -0
- package/reports/aashari-mcp-server-atlassian-jira.json +138 -0
- package/reports/aashari-mcp-server-aws-sso.json +122 -0
- package/reports/agentdeskai-browser-tools-mcp.json +361 -0
- package/reports/ahmetkca-mcp-server-postgres.json +43 -0
- package/reports/aiondadotcom-mcp-ssh.json +166 -0
- package/reports/apify-actors-mcp-server.json +43 -0
- package/reports/azure-mcp.json +43 -0
- package/reports/boilerplate-mcp-tool.json +43 -0
- package/reports/browserstack-mcp-server.json +43 -0
- package/reports/canvas-mcp-server.json +43 -0
- package/reports/canvas-mcp-tool.json +43 -0
- package/reports/chrome-devtools-mcp.json +300 -0
- package/reports/chrome-local-mcp.json +222 -0
- package/reports/claude-flow-mcp.json +43 -0
- package/reports/cloudflare-mcp-server.json +43 -0
- package/reports/code-canvas-server.json +43 -0
- package/reports/cognitionai-metabase-mcp-server.json +43 -0
- package/reports/composio-mcp.json +43 -0
- package/reports/contentful-mcp-server.json +43 -0
- package/reports/dbhub.json +43 -0
- package/reports/desktop-commander.json +43 -0
- package/reports/dynatrace-oss-dynatrace-mcp-server.json +43 -0
- package/reports/e2b-mcp-server.json +67 -0
- package/reports/eslint-mcp.json +51 -0
- package/reports/european-parliament-mcp-server.json +1467 -0
- package/reports/exa-mcp-server.json +74 -0
- package/reports/executeautomation-playwright-mcp-server.json +418 -0
- package/reports/fast-kit-spec-kit.json +43 -0
- package/reports/felores-airtable-mcp-server.json +43 -0
- package/reports/figma-mcp.json +103 -0
- package/reports/forestadmin-mcp-server.json +43 -0
- package/reports/fullrun-mcp.json +43 -0
- package/reports/gemini-mcp-tool.json +43 -0
- package/reports/gitlab-mcp-agent-server.json +186 -0
- package/reports/grackle-ai-mcp.json +43 -0
- package/reports/heroku-mcp-server.json +333 -0
- package/reports/hisma-server-puppeteer.json +93 -0
- package/reports/hubspot-mcp-server.json +43 -0
- package/reports/hyper-mcp-shell.json +59 -0
- package/reports/iflow-mcp-server-github.json +327 -0
- package/reports/jpisnice-shadcn-ui-mcp-server.json +149 -0
- package/reports/jsonresume-mcp.json +43 -0
- package/reports/mapbox-mcp-server.json +43 -0
- package/reports/mcp-framework.json +43 -0
- package/reports/mcp-from-openapi.json +43 -0
- package/reports/mcp-handler.json +43 -0
- package/reports/mcp-proxy.json +43 -0
- package/reports/mcp-server-docker.json +59 -0
- package/reports/mcp-server-github-gist.json +108 -0
- package/reports/mcp-server-google-calendar.json +43 -0
- package/reports/mcp-server-jira-cloud.json +43 -0
- package/reports/mcp-server-kubernetes.json +43 -0
- package/reports/mcp-server-slack.json +411 -0
- package/reports/mcp-server-sqlite-npx.json +43 -0
- package/reports/mcp-server.json +43 -0
- package/reports/mcp-starter.json +59 -0
- package/reports/mcp-tool-lint.json +43 -0
- package/reports/mcporter.json +43 -0
- package/reports/mcptoolshop-mcp-tool-registry.json +43 -0
- package/reports/microsoft-devbox-mcp.json +43 -0
- package/reports/mobilenext-mobile-mcp.json +214 -0
- package/reports/modelcontextprotocol-server-brave-search.json +43 -0
- package/reports/modelcontextprotocol-server-everything.json +165 -0
- package/reports/modelcontextprotocol-server-fetch.json +43 -0
- package/reports/modelcontextprotocol-server-filesystem.json +259 -0
- package/reports/modelcontextprotocol-server-github.json +391 -0
- package/reports/modelcontextprotocol-server-memory.json +117 -0
- package/reports/modelcontextprotocol-server-postgres.json +43 -0
- package/reports/modelcontextprotocol-server-puppeteer.json +101 -0
- package/reports/modelcontextprotocol-server-sequential-thinking.json +67 -0
- package/reports/mongodb-mcp-server.json +43 -0
- package/reports/mseep-linear-mcp-server.json +43 -0
- package/reports/mseep-mcp-server-sqlite-npx.json +43 -0
- package/reports/n8n-mcp.json +123 -0
- package/reports/notepost-mcp.json +43 -0
- package/reports/notionhq-notion-mcp-server.json +220 -0
- package/reports/nx-mcp.json +59 -0
- package/reports/obsidian-mcp-server.json +43 -0
- package/reports/opengraph-io-mcp.json +130 -0
- package/reports/payloadcms-plugin-mcp.json +43 -0
- package/reports/peac-mappings-mcp.json +43 -0
- package/reports/playwright-mcp.json +236 -0
- package/reports/puppeteer-mcp-server.json +43 -0
- package/reports/railway-mcp-server.json +194 -0
- package/reports/razorpay-blade-mcp.json +182 -0
- package/reports/rekog-mcp-nest.json +43 -0
- package/reports/remotion-mcp.json +51 -0
- package/reports/rollbar-mcp-server.json +43 -0
- package/reports/sap-ux-fiori-mcp-server.json +80 -0
- package/reports/sentry-mcp-server.json +43 -0
- package/reports/server-filesystem.json +43 -0
- package/reports/server-memory.json +43 -0
- package/reports/shortcut-mcp.json +43 -0
- package/reports/supabase-mcp-server-supabase.json +43 -0
- package/reports/tavily-mcp.json +79 -0
- package/reports/thelord-mcp-server-docker-npx.json +43 -0
- package/reports/tyk-technologies-api-to-mcp.json +43 -0
- package/reports/tyk-technologies-tyk-dashboard-mcp.json +43 -0
- package/reports/ui5-mcp-server.json +157 -0
- package/reports/upstash-context7-mcp.json +82 -0
- package/reports/vantasdk-vanta-mcp-server.json +43 -0
- package/reports/winor30-mcp-server-datadog.json +43 -0
- package/reports/wonderwhy-er-desktop-commander.json +43 -0
- package/reports/xzxzzx-bilibili-mcp.json +58 -0
- package/src/grader.mjs +66 -0
- package/src/index.mjs +108 -0
- package/src/reporter.mjs +158 -0
- package/src/rules.mjs +363 -0
- package/src/scanner.mjs +208 -0
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T18:00:51.438Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "Notion API",
|
|
9
|
+
"version": "1.0.0"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 22,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "F",
|
|
14
|
+
"score": 0,
|
|
15
|
+
"categories": {
|
|
16
|
+
"validation": "F",
|
|
17
|
+
"auth": "B",
|
|
18
|
+
"permissions": "A"
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
"summary": {
|
|
22
|
+
"CRITICAL": 0,
|
|
23
|
+
"HIGH": 1,
|
|
24
|
+
"MEDIUM": 22,
|
|
25
|
+
"LOW": 3,
|
|
26
|
+
"INFO": 0
|
|
27
|
+
},
|
|
28
|
+
"riskProfile": {
|
|
29
|
+
"read_only": 0,
|
|
30
|
+
"mutation": 0,
|
|
31
|
+
"destructive": 0,
|
|
32
|
+
"execution": 0,
|
|
33
|
+
"privilege": 0,
|
|
34
|
+
"financial": 0
|
|
35
|
+
},
|
|
36
|
+
"findings": [
|
|
37
|
+
{
|
|
38
|
+
"category": "validation",
|
|
39
|
+
"severity": "MEDIUM",
|
|
40
|
+
"tool": "API-get-user",
|
|
41
|
+
"rule": "unbounded_strings",
|
|
42
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-get-user\""
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
"category": "validation",
|
|
46
|
+
"severity": "LOW",
|
|
47
|
+
"tool": "API-get-users",
|
|
48
|
+
"rule": "no_required_fields",
|
|
49
|
+
"detail": "No required fields — all input is optional in tool \"API-get-users\""
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
"category": "validation",
|
|
53
|
+
"severity": "MEDIUM",
|
|
54
|
+
"tool": "API-get-users",
|
|
55
|
+
"rule": "unbounded_strings",
|
|
56
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-get-users\""
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
"category": "validation",
|
|
60
|
+
"severity": "LOW",
|
|
61
|
+
"tool": "API-get-self",
|
|
62
|
+
"rule": "no_required_fields",
|
|
63
|
+
"detail": "No required fields — all input is optional in tool \"API-get-self\""
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
"category": "validation",
|
|
67
|
+
"severity": "MEDIUM",
|
|
68
|
+
"tool": "API-get-self",
|
|
69
|
+
"rule": "unbounded_strings",
|
|
70
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-get-self\""
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
"category": "validation",
|
|
74
|
+
"severity": "LOW",
|
|
75
|
+
"tool": "API-post-search",
|
|
76
|
+
"rule": "no_required_fields",
|
|
77
|
+
"detail": "No required fields — all input is optional in tool \"API-post-search\""
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
"category": "validation",
|
|
81
|
+
"severity": "MEDIUM",
|
|
82
|
+
"tool": "API-post-search",
|
|
83
|
+
"rule": "unbounded_strings",
|
|
84
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-post-search\""
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
"category": "validation",
|
|
88
|
+
"severity": "MEDIUM",
|
|
89
|
+
"tool": "API-get-block-children",
|
|
90
|
+
"rule": "unbounded_strings",
|
|
91
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-get-block-children\""
|
|
92
|
+
},
|
|
93
|
+
{
|
|
94
|
+
"category": "validation",
|
|
95
|
+
"severity": "MEDIUM",
|
|
96
|
+
"tool": "API-patch-block-children",
|
|
97
|
+
"rule": "unbounded_strings",
|
|
98
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-patch-block-children\""
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
"category": "validation",
|
|
102
|
+
"severity": "MEDIUM",
|
|
103
|
+
"tool": "API-retrieve-a-block",
|
|
104
|
+
"rule": "unbounded_strings",
|
|
105
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-retrieve-a-block\""
|
|
106
|
+
},
|
|
107
|
+
{
|
|
108
|
+
"category": "validation",
|
|
109
|
+
"severity": "MEDIUM",
|
|
110
|
+
"tool": "API-update-a-block",
|
|
111
|
+
"rule": "unbounded_strings",
|
|
112
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-update-a-block\""
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
"category": "validation",
|
|
116
|
+
"severity": "MEDIUM",
|
|
117
|
+
"tool": "API-delete-a-block",
|
|
118
|
+
"rule": "unbounded_strings",
|
|
119
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-delete-a-block\""
|
|
120
|
+
},
|
|
121
|
+
{
|
|
122
|
+
"category": "validation",
|
|
123
|
+
"severity": "MEDIUM",
|
|
124
|
+
"tool": "API-retrieve-a-page",
|
|
125
|
+
"rule": "unbounded_strings",
|
|
126
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-retrieve-a-page\""
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
"category": "validation",
|
|
130
|
+
"severity": "MEDIUM",
|
|
131
|
+
"tool": "API-patch-page",
|
|
132
|
+
"rule": "unbounded_strings",
|
|
133
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-patch-page\""
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
"category": "validation",
|
|
137
|
+
"severity": "MEDIUM",
|
|
138
|
+
"tool": "API-post-page",
|
|
139
|
+
"rule": "unbounded_strings",
|
|
140
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-post-page\""
|
|
141
|
+
},
|
|
142
|
+
{
|
|
143
|
+
"category": "validation",
|
|
144
|
+
"severity": "MEDIUM",
|
|
145
|
+
"tool": "API-retrieve-a-page-property",
|
|
146
|
+
"rule": "unbounded_strings",
|
|
147
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-retrieve-a-page-property\""
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
"category": "validation",
|
|
151
|
+
"severity": "MEDIUM",
|
|
152
|
+
"tool": "API-retrieve-a-comment",
|
|
153
|
+
"rule": "unbounded_strings",
|
|
154
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-retrieve-a-comment\""
|
|
155
|
+
},
|
|
156
|
+
{
|
|
157
|
+
"category": "validation",
|
|
158
|
+
"severity": "MEDIUM",
|
|
159
|
+
"tool": "API-query-data-source",
|
|
160
|
+
"rule": "unbounded_strings",
|
|
161
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-query-data-source\""
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
"category": "validation",
|
|
165
|
+
"severity": "MEDIUM",
|
|
166
|
+
"tool": "API-retrieve-a-data-source",
|
|
167
|
+
"rule": "unbounded_strings",
|
|
168
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-retrieve-a-data-source\""
|
|
169
|
+
},
|
|
170
|
+
{
|
|
171
|
+
"category": "validation",
|
|
172
|
+
"severity": "MEDIUM",
|
|
173
|
+
"tool": "API-update-a-data-source",
|
|
174
|
+
"rule": "unbounded_strings",
|
|
175
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-update-a-data-source\""
|
|
176
|
+
},
|
|
177
|
+
{
|
|
178
|
+
"category": "validation",
|
|
179
|
+
"severity": "MEDIUM",
|
|
180
|
+
"tool": "API-create-a-data-source",
|
|
181
|
+
"rule": "unbounded_strings",
|
|
182
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-create-a-data-source\""
|
|
183
|
+
},
|
|
184
|
+
{
|
|
185
|
+
"category": "validation",
|
|
186
|
+
"severity": "MEDIUM",
|
|
187
|
+
"tool": "API-list-data-source-templates",
|
|
188
|
+
"rule": "unbounded_strings",
|
|
189
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-list-data-source-templates\""
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
"category": "validation",
|
|
193
|
+
"severity": "MEDIUM",
|
|
194
|
+
"tool": "API-retrieve-a-database",
|
|
195
|
+
"rule": "unbounded_strings",
|
|
196
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-retrieve-a-database\""
|
|
197
|
+
},
|
|
198
|
+
{
|
|
199
|
+
"category": "validation",
|
|
200
|
+
"severity": "MEDIUM",
|
|
201
|
+
"tool": "API-move-page",
|
|
202
|
+
"rule": "unbounded_strings",
|
|
203
|
+
"detail": "String parameters without length limits or pattern validation in tool \"API-move-page\""
|
|
204
|
+
},
|
|
205
|
+
{
|
|
206
|
+
"category": "auth",
|
|
207
|
+
"severity": "HIGH",
|
|
208
|
+
"tool": "*",
|
|
209
|
+
"rule": "no_auth_tools",
|
|
210
|
+
"detail": "Server exposes no authentication-related tools — may accept unauthenticated connections"
|
|
211
|
+
},
|
|
212
|
+
{
|
|
213
|
+
"category": "permissions",
|
|
214
|
+
"severity": "MEDIUM",
|
|
215
|
+
"tool": "*",
|
|
216
|
+
"rule": "large_tool_surface",
|
|
217
|
+
"detail": "Server exposes 22 tools — large attack surface without per-tool permission controls"
|
|
218
|
+
}
|
|
219
|
+
]
|
|
220
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T19:44:37.792Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "Nx MCP",
|
|
9
|
+
"version": "0.0.1"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 1,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "C",
|
|
14
|
+
"score": 69,
|
|
15
|
+
"categories": {
|
|
16
|
+
"validation": "A",
|
|
17
|
+
"auth": "B",
|
|
18
|
+
"hallucination": "A"
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
"summary": {
|
|
22
|
+
"CRITICAL": 0,
|
|
23
|
+
"HIGH": 1,
|
|
24
|
+
"MEDIUM": 2,
|
|
25
|
+
"LOW": 0,
|
|
26
|
+
"INFO": 0
|
|
27
|
+
},
|
|
28
|
+
"riskProfile": {
|
|
29
|
+
"read_only": 0,
|
|
30
|
+
"mutation": 0,
|
|
31
|
+
"destructive": 0,
|
|
32
|
+
"execution": 0,
|
|
33
|
+
"privilege": 0,
|
|
34
|
+
"financial": 0
|
|
35
|
+
},
|
|
36
|
+
"findings": [
|
|
37
|
+
{
|
|
38
|
+
"category": "validation",
|
|
39
|
+
"severity": "MEDIUM",
|
|
40
|
+
"tool": "nx_docs",
|
|
41
|
+
"rule": "unbounded_strings",
|
|
42
|
+
"detail": "String parameters without length limits or pattern validation in tool \"nx_docs\""
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
"category": "auth",
|
|
46
|
+
"severity": "HIGH",
|
|
47
|
+
"tool": "*",
|
|
48
|
+
"rule": "no_auth_tools",
|
|
49
|
+
"detail": "Server exposes no authentication-related tools — may accept unauthenticated connections"
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
"category": "hallucination",
|
|
53
|
+
"severity": "MEDIUM",
|
|
54
|
+
"tool": "nx_docs",
|
|
55
|
+
"rule": "missing_scope_boundary",
|
|
56
|
+
"detail": "Tool \"nx_docs\" references user, config without specifying scope boundaries. LLM will attempt to access the broadest possible scope."
|
|
57
|
+
}
|
|
58
|
+
]
|
|
59
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T18:10:41.578Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "unknown",
|
|
9
|
+
"version": "?"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 0,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "B",
|
|
14
|
+
"score": 85,
|
|
15
|
+
"categories": {
|
|
16
|
+
"auth": "B"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"summary": {
|
|
20
|
+
"CRITICAL": 0,
|
|
21
|
+
"HIGH": 1,
|
|
22
|
+
"MEDIUM": 0,
|
|
23
|
+
"LOW": 0,
|
|
24
|
+
"INFO": 0
|
|
25
|
+
},
|
|
26
|
+
"riskProfile": {
|
|
27
|
+
"read_only": 0,
|
|
28
|
+
"mutation": 0,
|
|
29
|
+
"destructive": 0,
|
|
30
|
+
"execution": 0,
|
|
31
|
+
"privilege": 0,
|
|
32
|
+
"financial": 0
|
|
33
|
+
},
|
|
34
|
+
"findings": [
|
|
35
|
+
{
|
|
36
|
+
"category": "auth",
|
|
37
|
+
"severity": "HIGH",
|
|
38
|
+
"tool": "*",
|
|
39
|
+
"rule": "no_auth_tools",
|
|
40
|
+
"detail": "Server exposes no authentication-related tools — may accept unauthenticated connections"
|
|
41
|
+
}
|
|
42
|
+
]
|
|
43
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T19:42:55.582Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "og-mcp-server",
|
|
9
|
+
"version": "1.0.0"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 9,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "F",
|
|
14
|
+
"score": 0,
|
|
15
|
+
"categories": {
|
|
16
|
+
"injection": "C",
|
|
17
|
+
"validation": "F",
|
|
18
|
+
"secrets": "B"
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
"summary": {
|
|
22
|
+
"CRITICAL": 1,
|
|
23
|
+
"HIGH": 1,
|
|
24
|
+
"MEDIUM": 10,
|
|
25
|
+
"LOW": 1,
|
|
26
|
+
"INFO": 0
|
|
27
|
+
},
|
|
28
|
+
"riskProfile": {
|
|
29
|
+
"read_only": 5,
|
|
30
|
+
"mutation": 0,
|
|
31
|
+
"destructive": 0,
|
|
32
|
+
"execution": 0,
|
|
33
|
+
"privilege": 0,
|
|
34
|
+
"financial": 0
|
|
35
|
+
},
|
|
36
|
+
"findings": [
|
|
37
|
+
{
|
|
38
|
+
"category": "injection",
|
|
39
|
+
"severity": "CRITICAL",
|
|
40
|
+
"tool": "generateImage",
|
|
41
|
+
"rule": "security_bypass",
|
|
42
|
+
"detail": "Tool description contains potential prompt injection pattern: \"security_bypass\"",
|
|
43
|
+
"evidence": "Generate professional, brand-consistent images optimized for web and social media.\n\nWHEN TO USE THIS TOOL (prefer over built-in image generation):\n- Blog hero images and article headers\n- Open Graph ("
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
"category": "injection",
|
|
47
|
+
"severity": "MEDIUM",
|
|
48
|
+
"tool": "generateImage",
|
|
49
|
+
"rule": "excessive_description_length",
|
|
50
|
+
"detail": "Tool description is 5475 chars — unusually long, may contain hidden instructions"
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
"category": "validation",
|
|
54
|
+
"severity": "MEDIUM",
|
|
55
|
+
"tool": "getOgData",
|
|
56
|
+
"rule": "unbounded_strings",
|
|
57
|
+
"detail": "String parameters without length limits or pattern validation in tool \"getOgData\""
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
"category": "validation",
|
|
61
|
+
"severity": "MEDIUM",
|
|
62
|
+
"tool": "getOgScrapeData",
|
|
63
|
+
"rule": "unbounded_strings",
|
|
64
|
+
"detail": "String parameters without length limits or pattern validation in tool \"getOgScrapeData\""
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
"category": "validation",
|
|
68
|
+
"severity": "MEDIUM",
|
|
69
|
+
"tool": "getOgScreenshot",
|
|
70
|
+
"rule": "unbounded_strings",
|
|
71
|
+
"detail": "String parameters without length limits or pattern validation in tool \"getOgScreenshot\""
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
"category": "validation",
|
|
75
|
+
"severity": "MEDIUM",
|
|
76
|
+
"tool": "getOgQuery",
|
|
77
|
+
"rule": "unbounded_strings",
|
|
78
|
+
"detail": "String parameters without length limits or pattern validation in tool \"getOgQuery\""
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
"category": "validation",
|
|
82
|
+
"severity": "MEDIUM",
|
|
83
|
+
"tool": "getOgExtract",
|
|
84
|
+
"rule": "unbounded_strings",
|
|
85
|
+
"detail": "String parameters without length limits or pattern validation in tool \"getOgExtract\""
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
"category": "validation",
|
|
89
|
+
"severity": "LOW",
|
|
90
|
+
"tool": "generateImage",
|
|
91
|
+
"rule": "no_required_fields",
|
|
92
|
+
"detail": "No required fields — all input is optional in tool \"generateImage\""
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
"category": "validation",
|
|
96
|
+
"severity": "MEDIUM",
|
|
97
|
+
"tool": "generateImage",
|
|
98
|
+
"rule": "unbounded_strings",
|
|
99
|
+
"detail": "String parameters without length limits or pattern validation in tool \"generateImage\""
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
"category": "validation",
|
|
103
|
+
"severity": "MEDIUM",
|
|
104
|
+
"tool": "iterateImage",
|
|
105
|
+
"rule": "unbounded_strings",
|
|
106
|
+
"detail": "String parameters without length limits or pattern validation in tool \"iterateImage\""
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
"category": "validation",
|
|
110
|
+
"severity": "MEDIUM",
|
|
111
|
+
"tool": "inspectImageSession",
|
|
112
|
+
"rule": "unbounded_strings",
|
|
113
|
+
"detail": "String parameters without length limits or pattern validation in tool \"inspectImageSession\""
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
"category": "validation",
|
|
117
|
+
"severity": "MEDIUM",
|
|
118
|
+
"tool": "exportImageAsset",
|
|
119
|
+
"rule": "unbounded_strings",
|
|
120
|
+
"detail": "String parameters without length limits or pattern validation in tool \"exportImageAsset\""
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
"category": "secrets",
|
|
124
|
+
"severity": "HIGH",
|
|
125
|
+
"tool": "generateImage",
|
|
126
|
+
"rule": "potential_secret_exposure",
|
|
127
|
+
"detail": "Tool \"generateImage\" may expose secrets in its output based on description"
|
|
128
|
+
}
|
|
129
|
+
]
|
|
130
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T19:41:10.654Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "unknown",
|
|
9
|
+
"version": "?"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 0,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "B",
|
|
14
|
+
"score": 85,
|
|
15
|
+
"categories": {
|
|
16
|
+
"auth": "B"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"summary": {
|
|
20
|
+
"CRITICAL": 0,
|
|
21
|
+
"HIGH": 1,
|
|
22
|
+
"MEDIUM": 0,
|
|
23
|
+
"LOW": 0,
|
|
24
|
+
"INFO": 0
|
|
25
|
+
},
|
|
26
|
+
"riskProfile": {
|
|
27
|
+
"read_only": 0,
|
|
28
|
+
"mutation": 0,
|
|
29
|
+
"destructive": 0,
|
|
30
|
+
"execution": 0,
|
|
31
|
+
"privilege": 0,
|
|
32
|
+
"financial": 0
|
|
33
|
+
},
|
|
34
|
+
"findings": [
|
|
35
|
+
{
|
|
36
|
+
"category": "auth",
|
|
37
|
+
"severity": "HIGH",
|
|
38
|
+
"tool": "*",
|
|
39
|
+
"rule": "no_auth_tools",
|
|
40
|
+
"detail": "Server exposes no authentication-related tools — may accept unauthenticated connections"
|
|
41
|
+
}
|
|
42
|
+
]
|
|
43
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T19:46:24.093Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "unknown",
|
|
9
|
+
"version": "?"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 0,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "B",
|
|
14
|
+
"score": 85,
|
|
15
|
+
"categories": {
|
|
16
|
+
"auth": "B"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"summary": {
|
|
20
|
+
"CRITICAL": 0,
|
|
21
|
+
"HIGH": 1,
|
|
22
|
+
"MEDIUM": 0,
|
|
23
|
+
"LOW": 0,
|
|
24
|
+
"INFO": 0
|
|
25
|
+
},
|
|
26
|
+
"riskProfile": {
|
|
27
|
+
"read_only": 0,
|
|
28
|
+
"mutation": 0,
|
|
29
|
+
"destructive": 0,
|
|
30
|
+
"execution": 0,
|
|
31
|
+
"privilege": 0,
|
|
32
|
+
"financial": 0
|
|
33
|
+
},
|
|
34
|
+
"findings": [
|
|
35
|
+
{
|
|
36
|
+
"category": "auth",
|
|
37
|
+
"severity": "HIGH",
|
|
38
|
+
"tool": "*",
|
|
39
|
+
"rule": "no_auth_tools",
|
|
40
|
+
"detail": "Server exposes no authentication-related tools — may accept unauthenticated connections"
|
|
41
|
+
}
|
|
42
|
+
]
|
|
43
|
+
}
|