@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,411 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T18:09:26.394Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "slack-mcp",
|
|
9
|
+
"version": "1.0.0"
|
|
10
|
+
},
|
|
11
|
+
"toolCount": 20,
|
|
12
|
+
"grade": {
|
|
13
|
+
"overall": "F",
|
|
14
|
+
"score": 0,
|
|
15
|
+
"categories": {
|
|
16
|
+
"permissions": "F",
|
|
17
|
+
"validation": "F",
|
|
18
|
+
"auth": "B",
|
|
19
|
+
"output": "B"
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
"summary": {
|
|
23
|
+
"CRITICAL": 0,
|
|
24
|
+
"HIGH": 1,
|
|
25
|
+
"MEDIUM": 40,
|
|
26
|
+
"LOW": 12,
|
|
27
|
+
"INFO": 0
|
|
28
|
+
},
|
|
29
|
+
"riskProfile": {
|
|
30
|
+
"read_only": 0,
|
|
31
|
+
"mutation": 0,
|
|
32
|
+
"destructive": 0,
|
|
33
|
+
"execution": 0,
|
|
34
|
+
"privilege": 0,
|
|
35
|
+
"financial": 0,
|
|
36
|
+
"external_action": 20
|
|
37
|
+
},
|
|
38
|
+
"findings": [
|
|
39
|
+
{
|
|
40
|
+
"category": "permissions",
|
|
41
|
+
"severity": "MEDIUM",
|
|
42
|
+
"tool": "slack_list_workspaces",
|
|
43
|
+
"rule": "dangerous_tool_external_action",
|
|
44
|
+
"detail": "Tool \"slack_list_workspaces\" classified as external_action — requires permission controls"
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
"category": "permissions",
|
|
48
|
+
"severity": "MEDIUM",
|
|
49
|
+
"tool": "slack_switch_workspace",
|
|
50
|
+
"rule": "dangerous_tool_external_action",
|
|
51
|
+
"detail": "Tool \"slack_switch_workspace\" classified as external_action — requires permission controls"
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
"category": "permissions",
|
|
55
|
+
"severity": "MEDIUM",
|
|
56
|
+
"tool": "slack_get_current_workspace",
|
|
57
|
+
"rule": "dangerous_tool_external_action",
|
|
58
|
+
"detail": "Tool \"slack_get_current_workspace\" classified as external_action — requires permission controls"
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
"category": "permissions",
|
|
62
|
+
"severity": "MEDIUM",
|
|
63
|
+
"tool": "slack_list_channels",
|
|
64
|
+
"rule": "dangerous_tool_external_action",
|
|
65
|
+
"detail": "Tool \"slack_list_channels\" classified as external_action — requires permission controls"
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
"category": "permissions",
|
|
69
|
+
"severity": "MEDIUM",
|
|
70
|
+
"tool": "slack_get_channel_info",
|
|
71
|
+
"rule": "dangerous_tool_external_action",
|
|
72
|
+
"detail": "Tool \"slack_get_channel_info\" classified as external_action — requires permission controls"
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
"category": "permissions",
|
|
76
|
+
"severity": "MEDIUM",
|
|
77
|
+
"tool": "slack_get_channel_members",
|
|
78
|
+
"rule": "dangerous_tool_external_action",
|
|
79
|
+
"detail": "Tool \"slack_get_channel_members\" classified as external_action — requires permission controls"
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
"category": "permissions",
|
|
83
|
+
"severity": "MEDIUM",
|
|
84
|
+
"tool": "slack_get_messages",
|
|
85
|
+
"rule": "dangerous_tool_external_action",
|
|
86
|
+
"detail": "Tool \"slack_get_messages\" classified as external_action — requires permission controls"
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
"category": "permissions",
|
|
90
|
+
"severity": "MEDIUM",
|
|
91
|
+
"tool": "slack_get_thread_replies",
|
|
92
|
+
"rule": "dangerous_tool_external_action",
|
|
93
|
+
"detail": "Tool \"slack_get_thread_replies\" classified as external_action — requires permission controls"
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
"category": "permissions",
|
|
97
|
+
"severity": "MEDIUM",
|
|
98
|
+
"tool": "slack_send_message",
|
|
99
|
+
"rule": "dangerous_tool_external_action",
|
|
100
|
+
"detail": "Tool \"slack_send_message\" classified as external_action — requires permission controls"
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
"category": "permissions",
|
|
104
|
+
"severity": "MEDIUM",
|
|
105
|
+
"tool": "slack_reply_to_thread",
|
|
106
|
+
"rule": "dangerous_tool_external_action",
|
|
107
|
+
"detail": "Tool \"slack_reply_to_thread\" classified as external_action — requires permission controls"
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
"category": "permissions",
|
|
111
|
+
"severity": "MEDIUM",
|
|
112
|
+
"tool": "slack_search_messages",
|
|
113
|
+
"rule": "dangerous_tool_external_action",
|
|
114
|
+
"detail": "Tool \"slack_search_messages\" classified as external_action — requires permission controls"
|
|
115
|
+
},
|
|
116
|
+
{
|
|
117
|
+
"category": "permissions",
|
|
118
|
+
"severity": "MEDIUM",
|
|
119
|
+
"tool": "slack_list_users",
|
|
120
|
+
"rule": "dangerous_tool_external_action",
|
|
121
|
+
"detail": "Tool \"slack_list_users\" classified as external_action — requires permission controls"
|
|
122
|
+
},
|
|
123
|
+
{
|
|
124
|
+
"category": "permissions",
|
|
125
|
+
"severity": "MEDIUM",
|
|
126
|
+
"tool": "slack_get_user_info",
|
|
127
|
+
"rule": "dangerous_tool_external_action",
|
|
128
|
+
"detail": "Tool \"slack_get_user_info\" classified as external_action — requires permission controls"
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
"category": "permissions",
|
|
132
|
+
"severity": "MEDIUM",
|
|
133
|
+
"tool": "slack_get_user_profile",
|
|
134
|
+
"rule": "dangerous_tool_external_action",
|
|
135
|
+
"detail": "Tool \"slack_get_user_profile\" classified as external_action — requires permission controls"
|
|
136
|
+
},
|
|
137
|
+
{
|
|
138
|
+
"category": "permissions",
|
|
139
|
+
"severity": "MEDIUM",
|
|
140
|
+
"tool": "slack_list_files",
|
|
141
|
+
"rule": "dangerous_tool_external_action",
|
|
142
|
+
"detail": "Tool \"slack_list_files\" classified as external_action — requires permission controls"
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
"category": "permissions",
|
|
146
|
+
"severity": "MEDIUM",
|
|
147
|
+
"tool": "slack_get_file_info",
|
|
148
|
+
"rule": "dangerous_tool_external_action",
|
|
149
|
+
"detail": "Tool \"slack_get_file_info\" classified as external_action — requires permission controls"
|
|
150
|
+
},
|
|
151
|
+
{
|
|
152
|
+
"category": "permissions",
|
|
153
|
+
"severity": "MEDIUM",
|
|
154
|
+
"tool": "slack_upload_file",
|
|
155
|
+
"rule": "dangerous_tool_external_action",
|
|
156
|
+
"detail": "Tool \"slack_upload_file\" classified as external_action — requires permission controls"
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
"category": "permissions",
|
|
160
|
+
"severity": "MEDIUM",
|
|
161
|
+
"tool": "slack_add_reaction",
|
|
162
|
+
"rule": "dangerous_tool_external_action",
|
|
163
|
+
"detail": "Tool \"slack_add_reaction\" classified as external_action — requires permission controls"
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
"category": "permissions",
|
|
167
|
+
"severity": "MEDIUM",
|
|
168
|
+
"tool": "slack_remove_reaction",
|
|
169
|
+
"rule": "dangerous_tool_external_action",
|
|
170
|
+
"detail": "Tool \"slack_remove_reaction\" classified as external_action — requires permission controls"
|
|
171
|
+
},
|
|
172
|
+
{
|
|
173
|
+
"category": "permissions",
|
|
174
|
+
"severity": "MEDIUM",
|
|
175
|
+
"tool": "slack_get_reactions",
|
|
176
|
+
"rule": "dangerous_tool_external_action",
|
|
177
|
+
"detail": "Tool \"slack_get_reactions\" classified as external_action — requires permission controls"
|
|
178
|
+
},
|
|
179
|
+
{
|
|
180
|
+
"category": "validation",
|
|
181
|
+
"severity": "MEDIUM",
|
|
182
|
+
"tool": "slack_list_workspaces",
|
|
183
|
+
"rule": "empty_schema",
|
|
184
|
+
"detail": "Schema defined but no properties specified in tool \"slack_list_workspaces\""
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
"category": "validation",
|
|
188
|
+
"severity": "LOW",
|
|
189
|
+
"tool": "slack_list_workspaces",
|
|
190
|
+
"rule": "no_required_fields",
|
|
191
|
+
"detail": "No required fields — all input is optional in tool \"slack_list_workspaces\""
|
|
192
|
+
},
|
|
193
|
+
{
|
|
194
|
+
"category": "validation",
|
|
195
|
+
"severity": "MEDIUM",
|
|
196
|
+
"tool": "slack_switch_workspace",
|
|
197
|
+
"rule": "unbounded_strings",
|
|
198
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_switch_workspace\""
|
|
199
|
+
},
|
|
200
|
+
{
|
|
201
|
+
"category": "validation",
|
|
202
|
+
"severity": "MEDIUM",
|
|
203
|
+
"tool": "slack_get_current_workspace",
|
|
204
|
+
"rule": "empty_schema",
|
|
205
|
+
"detail": "Schema defined but no properties specified in tool \"slack_get_current_workspace\""
|
|
206
|
+
},
|
|
207
|
+
{
|
|
208
|
+
"category": "validation",
|
|
209
|
+
"severity": "LOW",
|
|
210
|
+
"tool": "slack_get_current_workspace",
|
|
211
|
+
"rule": "no_required_fields",
|
|
212
|
+
"detail": "No required fields — all input is optional in tool \"slack_get_current_workspace\""
|
|
213
|
+
},
|
|
214
|
+
{
|
|
215
|
+
"category": "validation",
|
|
216
|
+
"severity": "LOW",
|
|
217
|
+
"tool": "slack_list_channels",
|
|
218
|
+
"rule": "no_required_fields",
|
|
219
|
+
"detail": "No required fields — all input is optional in tool \"slack_list_channels\""
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
"category": "validation",
|
|
223
|
+
"severity": "MEDIUM",
|
|
224
|
+
"tool": "slack_list_channels",
|
|
225
|
+
"rule": "unbounded_strings",
|
|
226
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_list_channels\""
|
|
227
|
+
},
|
|
228
|
+
{
|
|
229
|
+
"category": "validation",
|
|
230
|
+
"severity": "MEDIUM",
|
|
231
|
+
"tool": "slack_get_channel_info",
|
|
232
|
+
"rule": "unbounded_strings",
|
|
233
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_channel_info\""
|
|
234
|
+
},
|
|
235
|
+
{
|
|
236
|
+
"category": "validation",
|
|
237
|
+
"severity": "MEDIUM",
|
|
238
|
+
"tool": "slack_get_channel_members",
|
|
239
|
+
"rule": "unbounded_strings",
|
|
240
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_channel_members\""
|
|
241
|
+
},
|
|
242
|
+
{
|
|
243
|
+
"category": "validation",
|
|
244
|
+
"severity": "MEDIUM",
|
|
245
|
+
"tool": "slack_get_messages",
|
|
246
|
+
"rule": "unbounded_strings",
|
|
247
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_messages\""
|
|
248
|
+
},
|
|
249
|
+
{
|
|
250
|
+
"category": "validation",
|
|
251
|
+
"severity": "MEDIUM",
|
|
252
|
+
"tool": "slack_get_thread_replies",
|
|
253
|
+
"rule": "unbounded_strings",
|
|
254
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_thread_replies\""
|
|
255
|
+
},
|
|
256
|
+
{
|
|
257
|
+
"category": "validation",
|
|
258
|
+
"severity": "MEDIUM",
|
|
259
|
+
"tool": "slack_send_message",
|
|
260
|
+
"rule": "unbounded_strings",
|
|
261
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_send_message\""
|
|
262
|
+
},
|
|
263
|
+
{
|
|
264
|
+
"category": "validation",
|
|
265
|
+
"severity": "MEDIUM",
|
|
266
|
+
"tool": "slack_reply_to_thread",
|
|
267
|
+
"rule": "unbounded_strings",
|
|
268
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_reply_to_thread\""
|
|
269
|
+
},
|
|
270
|
+
{
|
|
271
|
+
"category": "validation",
|
|
272
|
+
"severity": "MEDIUM",
|
|
273
|
+
"tool": "slack_search_messages",
|
|
274
|
+
"rule": "unbounded_strings",
|
|
275
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_search_messages\""
|
|
276
|
+
},
|
|
277
|
+
{
|
|
278
|
+
"category": "validation",
|
|
279
|
+
"severity": "LOW",
|
|
280
|
+
"tool": "slack_list_users",
|
|
281
|
+
"rule": "no_required_fields",
|
|
282
|
+
"detail": "No required fields — all input is optional in tool \"slack_list_users\""
|
|
283
|
+
},
|
|
284
|
+
{
|
|
285
|
+
"category": "validation",
|
|
286
|
+
"severity": "MEDIUM",
|
|
287
|
+
"tool": "slack_list_users",
|
|
288
|
+
"rule": "unbounded_strings",
|
|
289
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_list_users\""
|
|
290
|
+
},
|
|
291
|
+
{
|
|
292
|
+
"category": "validation",
|
|
293
|
+
"severity": "MEDIUM",
|
|
294
|
+
"tool": "slack_get_user_info",
|
|
295
|
+
"rule": "unbounded_strings",
|
|
296
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_user_info\""
|
|
297
|
+
},
|
|
298
|
+
{
|
|
299
|
+
"category": "validation",
|
|
300
|
+
"severity": "LOW",
|
|
301
|
+
"tool": "slack_get_user_profile",
|
|
302
|
+
"rule": "no_required_fields",
|
|
303
|
+
"detail": "No required fields — all input is optional in tool \"slack_get_user_profile\""
|
|
304
|
+
},
|
|
305
|
+
{
|
|
306
|
+
"category": "validation",
|
|
307
|
+
"severity": "MEDIUM",
|
|
308
|
+
"tool": "slack_get_user_profile",
|
|
309
|
+
"rule": "unbounded_strings",
|
|
310
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_user_profile\""
|
|
311
|
+
},
|
|
312
|
+
{
|
|
313
|
+
"category": "validation",
|
|
314
|
+
"severity": "LOW",
|
|
315
|
+
"tool": "slack_list_files",
|
|
316
|
+
"rule": "no_required_fields",
|
|
317
|
+
"detail": "No required fields — all input is optional in tool \"slack_list_files\""
|
|
318
|
+
},
|
|
319
|
+
{
|
|
320
|
+
"category": "validation",
|
|
321
|
+
"severity": "MEDIUM",
|
|
322
|
+
"tool": "slack_list_files",
|
|
323
|
+
"rule": "unbounded_strings",
|
|
324
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_list_files\""
|
|
325
|
+
},
|
|
326
|
+
{
|
|
327
|
+
"category": "validation",
|
|
328
|
+
"severity": "MEDIUM",
|
|
329
|
+
"tool": "slack_get_file_info",
|
|
330
|
+
"rule": "unbounded_strings",
|
|
331
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_file_info\""
|
|
332
|
+
},
|
|
333
|
+
{
|
|
334
|
+
"category": "validation",
|
|
335
|
+
"severity": "MEDIUM",
|
|
336
|
+
"tool": "slack_upload_file",
|
|
337
|
+
"rule": "unbounded_strings",
|
|
338
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_upload_file\""
|
|
339
|
+
},
|
|
340
|
+
{
|
|
341
|
+
"category": "validation",
|
|
342
|
+
"severity": "MEDIUM",
|
|
343
|
+
"tool": "slack_add_reaction",
|
|
344
|
+
"rule": "unbounded_strings",
|
|
345
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_add_reaction\""
|
|
346
|
+
},
|
|
347
|
+
{
|
|
348
|
+
"category": "validation",
|
|
349
|
+
"severity": "MEDIUM",
|
|
350
|
+
"tool": "slack_remove_reaction",
|
|
351
|
+
"rule": "unbounded_strings",
|
|
352
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_remove_reaction\""
|
|
353
|
+
},
|
|
354
|
+
{
|
|
355
|
+
"category": "validation",
|
|
356
|
+
"severity": "MEDIUM",
|
|
357
|
+
"tool": "slack_get_reactions",
|
|
358
|
+
"rule": "unbounded_strings",
|
|
359
|
+
"detail": "String parameters without length limits or pattern validation in tool \"slack_get_reactions\""
|
|
360
|
+
},
|
|
361
|
+
{
|
|
362
|
+
"category": "auth",
|
|
363
|
+
"severity": "HIGH",
|
|
364
|
+
"tool": "*",
|
|
365
|
+
"rule": "no_auth_tools",
|
|
366
|
+
"detail": "Server exposes no authentication-related tools — may accept unauthenticated connections"
|
|
367
|
+
},
|
|
368
|
+
{
|
|
369
|
+
"category": "output",
|
|
370
|
+
"severity": "LOW",
|
|
371
|
+
"tool": "slack_get_thread_replies",
|
|
372
|
+
"rule": "unfiltered_file_output",
|
|
373
|
+
"detail": "File reading tool \"slack_get_thread_replies\" may output sensitive file contents without filtering"
|
|
374
|
+
},
|
|
375
|
+
{
|
|
376
|
+
"category": "output",
|
|
377
|
+
"severity": "LOW",
|
|
378
|
+
"tool": "slack_reply_to_thread",
|
|
379
|
+
"rule": "unfiltered_file_output",
|
|
380
|
+
"detail": "File reading tool \"slack_reply_to_thread\" may output sensitive file contents without filtering"
|
|
381
|
+
},
|
|
382
|
+
{
|
|
383
|
+
"category": "output",
|
|
384
|
+
"severity": "LOW",
|
|
385
|
+
"tool": "slack_get_user_profile",
|
|
386
|
+
"rule": "unfiltered_file_output",
|
|
387
|
+
"detail": "File reading tool \"slack_get_user_profile\" may output sensitive file contents without filtering"
|
|
388
|
+
},
|
|
389
|
+
{
|
|
390
|
+
"category": "output",
|
|
391
|
+
"severity": "LOW",
|
|
392
|
+
"tool": "slack_list_files",
|
|
393
|
+
"rule": "unfiltered_file_output",
|
|
394
|
+
"detail": "File reading tool \"slack_list_files\" may output sensitive file contents without filtering"
|
|
395
|
+
},
|
|
396
|
+
{
|
|
397
|
+
"category": "output",
|
|
398
|
+
"severity": "LOW",
|
|
399
|
+
"tool": "slack_get_file_info",
|
|
400
|
+
"rule": "unfiltered_file_output",
|
|
401
|
+
"detail": "File reading tool \"slack_get_file_info\" may output sensitive file contents without filtering"
|
|
402
|
+
},
|
|
403
|
+
{
|
|
404
|
+
"category": "output",
|
|
405
|
+
"severity": "LOW",
|
|
406
|
+
"tool": "slack_upload_file",
|
|
407
|
+
"rule": "unfiltered_file_output",
|
|
408
|
+
"detail": "File reading tool \"slack_upload_file\" may output sensitive file contents without filtering"
|
|
409
|
+
}
|
|
410
|
+
]
|
|
411
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T18:09:51.442Z",
|
|
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:52:16.605Z",
|
|
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,59 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T19:58:19.947Z",
|
|
7
|
+
"server": {
|
|
8
|
+
"name": "mcp-starter",
|
|
9
|
+
"version": "0.1.0"
|
|
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": "hello_tool",
|
|
41
|
+
"rule": "unbounded_strings",
|
|
42
|
+
"detail": "String parameters without length limits or pattern validation in tool \"hello_tool\""
|
|
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": "hello_tool",
|
|
55
|
+
"rule": "description_too_short",
|
|
56
|
+
"detail": "Tool \"hello_tool\" description is only 10 chars. LLM will hallucinate capabilities based on the name alone."
|
|
57
|
+
}
|
|
58
|
+
]
|
|
59
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"scanner": {
|
|
3
|
+
"name": "agentsid-scanner",
|
|
4
|
+
"version": "0.1.0"
|
|
5
|
+
},
|
|
6
|
+
"scannedAt": "2026-03-29T19:43:45.670Z",
|
|
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:45:59.021Z",
|
|
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:54:06.373Z",
|
|
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
|
+
}
|