@maiife-ai-pub/probe 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/LICENSE +181 -0
- package/README.md +140 -0
- package/dist/cli/commands/scan.d.ts +3 -0
- package/dist/cli/commands/scan.d.ts.map +1 -0
- package/dist/cli/commands/scan.js +89 -0
- package/dist/cli/commands/scan.js.map +1 -0
- package/dist/cli/commands/watch.d.ts +3 -0
- package/dist/cli/commands/watch.d.ts.map +1 -0
- package/dist/cli/commands/watch.js +35 -0
- package/dist/cli/commands/watch.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +13 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/core/scanner.d.ts +5 -0
- package/dist/core/scanner.d.ts.map +1 -0
- package/dist/core/scanner.js +20 -0
- package/dist/core/scanner.js.map +1 -0
- package/dist/core/scanners/agents.d.ts +3 -0
- package/dist/core/scanners/agents.d.ts.map +1 -0
- package/dist/core/scanners/agents.js +87 -0
- package/dist/core/scanners/agents.js.map +1 -0
- package/dist/core/scanners/deps.d.ts +3 -0
- package/dist/core/scanners/deps.d.ts.map +1 -0
- package/dist/core/scanners/deps.js +50 -0
- package/dist/core/scanners/deps.js.map +1 -0
- package/dist/core/scanners/ide.d.ts +3 -0
- package/dist/core/scanners/ide.d.ts.map +1 -0
- package/dist/core/scanners/ide.js +57 -0
- package/dist/core/scanners/ide.js.map +1 -0
- package/dist/core/scanners/index.d.ts +7 -0
- package/dist/core/scanners/index.d.ts.map +1 -0
- package/dist/core/scanners/index.js +7 -0
- package/dist/core/scanners/index.js.map +1 -0
- package/dist/core/scanners/keys.d.ts +3 -0
- package/dist/core/scanners/keys.d.ts.map +1 -0
- package/dist/core/scanners/keys.js +63 -0
- package/dist/core/scanners/keys.js.map +1 -0
- package/dist/core/scanners/mcp.d.ts +3 -0
- package/dist/core/scanners/mcp.d.ts.map +1 -0
- package/dist/core/scanners/mcp.js +94 -0
- package/dist/core/scanners/mcp.js.map +1 -0
- package/dist/core/scanners/models.d.ts +3 -0
- package/dist/core/scanners/models.d.ts.map +1 -0
- package/dist/core/scanners/models.js +46 -0
- package/dist/core/scanners/models.js.map +1 -0
- package/dist/core/types.d.ts +62 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +7 -0
- package/dist/core/types.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/index.d.ts +2 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +67 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/tools.d.ts +16 -0
- package/dist/mcp/tools.d.ts.map +1 -0
- package/dist/mcp/tools.js +61 -0
- package/dist/mcp/tools.js.map +1 -0
- package/package.json +58 -0
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { runScan } from "../core/scanner.js";
|
|
2
|
+
import { createIDEScanner, createMCPScanner, createAgentsScanner, createKeysScanner, createModelsScanner, createDepsScanner, } from "../core/scanners/index.js";
|
|
3
|
+
const ALL_SCANNERS = {
|
|
4
|
+
ide: createIDEScanner(),
|
|
5
|
+
mcp: createMCPScanner(),
|
|
6
|
+
agents: createAgentsScanner(),
|
|
7
|
+
keys: createKeysScanner(),
|
|
8
|
+
models: createModelsScanner(),
|
|
9
|
+
deps: createDepsScanner(),
|
|
10
|
+
};
|
|
11
|
+
function computeRiskLevel(result) {
|
|
12
|
+
const totalFindings = result.ide.length + result.mcp.length + result.agents.length +
|
|
13
|
+
result.keys.length + result.models.length + result.deps.length;
|
|
14
|
+
const hasHighRiskMCP = result.mcp.some((m) => m.risk === "high" || m.risk === "critical");
|
|
15
|
+
const hasUnmanagedKeys = result.keys.some((k) => !k.managed);
|
|
16
|
+
if (hasHighRiskMCP && hasUnmanagedKeys)
|
|
17
|
+
return "critical";
|
|
18
|
+
if (hasHighRiskMCP || hasUnmanagedKeys)
|
|
19
|
+
return "high";
|
|
20
|
+
if (totalFindings > 5)
|
|
21
|
+
return "medium";
|
|
22
|
+
return "low";
|
|
23
|
+
}
|
|
24
|
+
function generateRecommendations(result) {
|
|
25
|
+
const recs = [];
|
|
26
|
+
const unmanagedKeys = result.keys.filter((k) => !k.managed);
|
|
27
|
+
if (unmanagedKeys.length > 0) {
|
|
28
|
+
recs.push(`${unmanagedKeys.length} API key(s) in plaintext .env files — rotate through a key manager`);
|
|
29
|
+
}
|
|
30
|
+
const highRiskMCP = result.mcp.filter((m) => m.risk === "high" || m.risk === "critical");
|
|
31
|
+
if (highRiskMCP.length > 0) {
|
|
32
|
+
recs.push(`${highRiskMCP.length} MCP server(s) with elevated permissions — review and constrain`);
|
|
33
|
+
}
|
|
34
|
+
if (result.agents.length > 0 && result.deps.length === 0) {
|
|
35
|
+
recs.push(`${result.agents.length} agent framework(s) with no observability SDK — add tracing`);
|
|
36
|
+
}
|
|
37
|
+
return recs;
|
|
38
|
+
}
|
|
39
|
+
export async function probeScan(params) {
|
|
40
|
+
const categories = params.categories
|
|
41
|
+
? params.categories.split(",")
|
|
42
|
+
: ["ide", "mcp", "agents", "keys", "models", "deps"];
|
|
43
|
+
const config = {
|
|
44
|
+
scope: params.scope ?? "full",
|
|
45
|
+
categories,
|
|
46
|
+
path: params.path ?? process.cwd(),
|
|
47
|
+
includeProjectDeps: params.includeProjectDeps ?? true,
|
|
48
|
+
};
|
|
49
|
+
const result = await runScan(config, ALL_SCANNERS);
|
|
50
|
+
const totalFindings = result.ide.length + result.mcp.length + result.agents.length +
|
|
51
|
+
result.keys.length + result.models.length + result.deps.length;
|
|
52
|
+
return {
|
|
53
|
+
findings: result,
|
|
54
|
+
summary: {
|
|
55
|
+
totalFindings,
|
|
56
|
+
riskLevel: computeRiskLevel(result),
|
|
57
|
+
recommendations: generateRecommendations(result),
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=tools.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../../src/mcp/tools.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@maiife-ai-pub/probe",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "AI environment scanner — discover IDE extensions, MCP servers, agent frameworks, API keys, local models",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"import": "./dist/index.js",
|
|
11
|
+
"types": "./dist/index.d.ts"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"bin": {
|
|
15
|
+
"maiife-probe": "./dist/cli/index.js"
|
|
16
|
+
},
|
|
17
|
+
"files": [
|
|
18
|
+
"dist",
|
|
19
|
+
"README.md",
|
|
20
|
+
"LICENSE"
|
|
21
|
+
],
|
|
22
|
+
"scripts": {
|
|
23
|
+
"build": "tsc -p tsconfig.build.json",
|
|
24
|
+
"lint": "tsc --noEmit",
|
|
25
|
+
"test": "vitest run",
|
|
26
|
+
"test:watch": "vitest"
|
|
27
|
+
},
|
|
28
|
+
"dependencies": {
|
|
29
|
+
"@maiife-ai-pub/shared": "^0.1.0",
|
|
30
|
+
"@modelcontextprotocol/sdk": "^1.29.0",
|
|
31
|
+
"chalk": "^5.6.2",
|
|
32
|
+
"commander": "^14.0.3"
|
|
33
|
+
},
|
|
34
|
+
"devDependencies": {
|
|
35
|
+
"typescript": "^5.7.0",
|
|
36
|
+
"vitest": "^3.1.0"
|
|
37
|
+
},
|
|
38
|
+
"license": "Apache-2.0",
|
|
39
|
+
"keywords": [
|
|
40
|
+
"maiife",
|
|
41
|
+
"ai-governance",
|
|
42
|
+
"mcp",
|
|
43
|
+
"ai-environment",
|
|
44
|
+
"scanner",
|
|
45
|
+
"ide-extensions",
|
|
46
|
+
"api-keys"
|
|
47
|
+
],
|
|
48
|
+
"engines": {
|
|
49
|
+
"node": ">=18"
|
|
50
|
+
},
|
|
51
|
+
"repository": {
|
|
52
|
+
"type": "git",
|
|
53
|
+
"url": "https://github.com/sakthivelchan89/MAIIFE-Landing",
|
|
54
|
+
"directory": "toolkit/packages/probe"
|
|
55
|
+
},
|
|
56
|
+
"homepage": "https://github.com/sakthivelchan89/MAIIFE-Landing/tree/main/toolkit/packages/probe",
|
|
57
|
+
"author": "Maiife <contact@maiife.ai> (https://maiife.ai)"
|
|
58
|
+
}
|