@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.
Files changed (63) hide show
  1. package/LICENSE +181 -0
  2. package/README.md +140 -0
  3. package/dist/cli/commands/scan.d.ts +3 -0
  4. package/dist/cli/commands/scan.d.ts.map +1 -0
  5. package/dist/cli/commands/scan.js +89 -0
  6. package/dist/cli/commands/scan.js.map +1 -0
  7. package/dist/cli/commands/watch.d.ts +3 -0
  8. package/dist/cli/commands/watch.d.ts.map +1 -0
  9. package/dist/cli/commands/watch.js +35 -0
  10. package/dist/cli/commands/watch.js.map +1 -0
  11. package/dist/cli/index.d.ts +3 -0
  12. package/dist/cli/index.d.ts.map +1 -0
  13. package/dist/cli/index.js +13 -0
  14. package/dist/cli/index.js.map +1 -0
  15. package/dist/core/scanner.d.ts +5 -0
  16. package/dist/core/scanner.d.ts.map +1 -0
  17. package/dist/core/scanner.js +20 -0
  18. package/dist/core/scanner.js.map +1 -0
  19. package/dist/core/scanners/agents.d.ts +3 -0
  20. package/dist/core/scanners/agents.d.ts.map +1 -0
  21. package/dist/core/scanners/agents.js +87 -0
  22. package/dist/core/scanners/agents.js.map +1 -0
  23. package/dist/core/scanners/deps.d.ts +3 -0
  24. package/dist/core/scanners/deps.d.ts.map +1 -0
  25. package/dist/core/scanners/deps.js +50 -0
  26. package/dist/core/scanners/deps.js.map +1 -0
  27. package/dist/core/scanners/ide.d.ts +3 -0
  28. package/dist/core/scanners/ide.d.ts.map +1 -0
  29. package/dist/core/scanners/ide.js +57 -0
  30. package/dist/core/scanners/ide.js.map +1 -0
  31. package/dist/core/scanners/index.d.ts +7 -0
  32. package/dist/core/scanners/index.d.ts.map +1 -0
  33. package/dist/core/scanners/index.js +7 -0
  34. package/dist/core/scanners/index.js.map +1 -0
  35. package/dist/core/scanners/keys.d.ts +3 -0
  36. package/dist/core/scanners/keys.d.ts.map +1 -0
  37. package/dist/core/scanners/keys.js +63 -0
  38. package/dist/core/scanners/keys.js.map +1 -0
  39. package/dist/core/scanners/mcp.d.ts +3 -0
  40. package/dist/core/scanners/mcp.d.ts.map +1 -0
  41. package/dist/core/scanners/mcp.js +94 -0
  42. package/dist/core/scanners/mcp.js.map +1 -0
  43. package/dist/core/scanners/models.d.ts +3 -0
  44. package/dist/core/scanners/models.d.ts.map +1 -0
  45. package/dist/core/scanners/models.js +46 -0
  46. package/dist/core/scanners/models.js.map +1 -0
  47. package/dist/core/types.d.ts +62 -0
  48. package/dist/core/types.d.ts.map +1 -0
  49. package/dist/core/types.js +7 -0
  50. package/dist/core/types.js.map +1 -0
  51. package/dist/index.d.ts +3 -0
  52. package/dist/index.d.ts.map +1 -0
  53. package/dist/index.js +2 -0
  54. package/dist/index.js.map +1 -0
  55. package/dist/mcp/index.d.ts +2 -0
  56. package/dist/mcp/index.d.ts.map +1 -0
  57. package/dist/mcp/index.js +67 -0
  58. package/dist/mcp/index.js.map +1 -0
  59. package/dist/mcp/tools.d.ts +16 -0
  60. package/dist/mcp/tools.d.ts.map +1 -0
  61. package/dist/mcp/tools.js +61 -0
  62. package/dist/mcp/tools.js.map +1 -0
  63. 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
+ }