opena2a-cli 0.7.2 → 0.8.1

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 (65) hide show
  1. package/README.md +51 -603
  2. package/dist/adapters/docker.d.ts.map +1 -1
  3. package/dist/adapters/docker.js +5 -2
  4. package/dist/adapters/docker.js.map +1 -1
  5. package/dist/adapters/registry.d.ts.map +1 -1
  6. package/dist/adapters/registry.js +1 -0
  7. package/dist/adapters/registry.js.map +1 -1
  8. package/dist/adapters/types.d.ts +2 -0
  9. package/dist/adapters/types.d.ts.map +1 -1
  10. package/dist/commands/create/index.d.ts +21 -0
  11. package/dist/commands/create/index.d.ts.map +1 -0
  12. package/dist/commands/create/index.js +44 -0
  13. package/dist/commands/create/index.js.map +1 -0
  14. package/dist/commands/create/skill.d.ts +35 -0
  15. package/dist/commands/create/skill.d.ts.map +1 -0
  16. package/dist/commands/create/skill.js +250 -0
  17. package/dist/commands/create/skill.js.map +1 -0
  18. package/dist/commands/create/templates.d.ts +47 -0
  19. package/dist/commands/create/templates.d.ts.map +1 -0
  20. package/dist/commands/create/templates.js +392 -0
  21. package/dist/commands/create/templates.js.map +1 -0
  22. package/dist/commands/detect.js +1 -1
  23. package/dist/commands/detect.js.map +1 -1
  24. package/dist/commands/guard-harden.d.ts +15 -0
  25. package/dist/commands/guard-harden.d.ts.map +1 -0
  26. package/dist/commands/guard-harden.js +242 -0
  27. package/dist/commands/guard-harden.js.map +1 -0
  28. package/dist/commands/guard.d.ts +3 -1
  29. package/dist/commands/guard.d.ts.map +1 -1
  30. package/dist/commands/guard.js +25 -1
  31. package/dist/commands/guard.js.map +1 -1
  32. package/dist/commands/identity.d.ts +5 -0
  33. package/dist/commands/identity.d.ts.map +1 -1
  34. package/dist/commands/identity.js +515 -11
  35. package/dist/commands/identity.js.map +1 -1
  36. package/dist/commands/login.d.ts +24 -0
  37. package/dist/commands/login.d.ts.map +1 -0
  38. package/dist/commands/login.js +238 -0
  39. package/dist/commands/login.js.map +1 -0
  40. package/dist/commands/mcp-audit.d.ts.map +1 -1
  41. package/dist/commands/mcp-audit.js +4 -0
  42. package/dist/commands/mcp-audit.js.map +1 -1
  43. package/dist/index.js +124 -5
  44. package/dist/index.js.map +1 -1
  45. package/dist/lib/registry-client.d.ts +59 -0
  46. package/dist/lib/registry-client.d.ts.map +1 -0
  47. package/dist/lib/registry-client.js +169 -0
  48. package/dist/lib/registry-client.js.map +1 -0
  49. package/dist/semantic/command-index.json +27 -0
  50. package/dist/shield/status.d.ts.map +1 -1
  51. package/dist/shield/status.js +22 -1
  52. package/dist/shield/status.js.map +1 -1
  53. package/dist/util/aim-client.d.ts +141 -0
  54. package/dist/util/aim-client.d.ts.map +1 -0
  55. package/dist/util/aim-client.js +225 -0
  56. package/dist/util/aim-client.js.map +1 -0
  57. package/dist/util/auth.d.ts +23 -0
  58. package/dist/util/auth.d.ts.map +1 -0
  59. package/dist/util/auth.js +54 -0
  60. package/dist/util/auth.js.map +1 -0
  61. package/dist/util/server-url.d.ts +15 -0
  62. package/dist/util/server-url.d.ts.map +1 -0
  63. package/dist/util/server-url.js +45 -0
  64. package/dist/util/server-url.js.map +1 -0
  65. package/package.json +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aim-client.js","sourceRoot":"","sources":["../../src/util/aim-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Auth credential storage for browser-based (OAuth device flow) authentication.
3
+ *
4
+ * Credentials are stored in ~/.opena2a/auth.json, separate from the agent-level
5
+ * ServerConfig (which stores per-agent registration data in
6
+ * ~/.opena2a/aim-core/identities/server.json).
7
+ *
8
+ * File permissions are set to 0o600 (owner read/write only).
9
+ */
10
+ export interface AuthCredentials {
11
+ serverUrl: string;
12
+ accessToken: string;
13
+ refreshToken: string;
14
+ expiresAt: string;
15
+ tokenType: string;
16
+ authenticatedAt: string;
17
+ }
18
+ export declare function authConfigPath(): string;
19
+ export declare function loadAuth(): AuthCredentials | null;
20
+ export declare function saveAuth(creds: AuthCredentials): void;
21
+ export declare function removeAuth(): boolean;
22
+ export declare function isAuthValid(creds: AuthCredentials): boolean;
23
+ //# sourceMappingURL=auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/util/auth.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAQH,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED,wBAAgB,QAAQ,IAAI,eAAe,GAAG,IAAI,CASjD;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,eAAe,GAAG,IAAI,CAKrD;AAED,wBAAgB,UAAU,IAAI,OAAO,CAKpC;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,eAAe,GAAG,OAAO,CAI3D"}
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ /**
3
+ * Auth credential storage for browser-based (OAuth device flow) authentication.
4
+ *
5
+ * Credentials are stored in ~/.opena2a/auth.json, separate from the agent-level
6
+ * ServerConfig (which stores per-agent registration data in
7
+ * ~/.opena2a/aim-core/identities/server.json).
8
+ *
9
+ * File permissions are set to 0o600 (owner read/write only).
10
+ */
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.authConfigPath = authConfigPath;
13
+ exports.loadAuth = loadAuth;
14
+ exports.saveAuth = saveAuth;
15
+ exports.removeAuth = removeAuth;
16
+ exports.isAuthValid = isAuthValid;
17
+ const node_fs_1 = require("node:fs");
18
+ const node_path_1 = require("node:path");
19
+ const node_os_1 = require("node:os");
20
+ const AUTH_DIR = (0, node_path_1.join)((0, node_os_1.homedir)(), '.opena2a');
21
+ function authConfigPath() {
22
+ return (0, node_path_1.join)(AUTH_DIR, 'auth.json');
23
+ }
24
+ function loadAuth() {
25
+ const p = authConfigPath();
26
+ if (!(0, node_fs_1.existsSync)(p))
27
+ return null;
28
+ try {
29
+ const creds = JSON.parse((0, node_fs_1.readFileSync)(p, 'utf-8'));
30
+ return creds;
31
+ }
32
+ catch {
33
+ return null;
34
+ }
35
+ }
36
+ function saveAuth(creds) {
37
+ if (!(0, node_fs_1.existsSync)(AUTH_DIR)) {
38
+ (0, node_fs_1.mkdirSync)(AUTH_DIR, { recursive: true });
39
+ }
40
+ (0, node_fs_1.writeFileSync)(authConfigPath(), JSON.stringify(creds, null, 2), { encoding: 'utf-8', mode: 0o600 });
41
+ }
42
+ function removeAuth() {
43
+ const p = authConfigPath();
44
+ if (!(0, node_fs_1.existsSync)(p))
45
+ return false;
46
+ (0, node_fs_1.unlinkSync)(p);
47
+ return true;
48
+ }
49
+ function isAuthValid(creds) {
50
+ // Check if access token has expired (with 60-second buffer)
51
+ const expiresAt = new Date(creds.expiresAt).getTime();
52
+ return Date.now() < expiresAt - 60_000;
53
+ }
54
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/util/auth.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;;AAiBH,wCAEC;AAED,4BASC;AAED,4BAKC;AAED,gCAKC;AAED,kCAIC;AAhDD,qCAAyF;AACzF,yCAAiC;AACjC,qCAAkC;AAElC,MAAM,QAAQ,GAAG,IAAA,gBAAI,EAAC,IAAA,iBAAO,GAAE,EAAE,UAAU,CAAC,CAAC;AAW7C,SAAgB,cAAc;IAC5B,OAAO,IAAA,gBAAI,EAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;AACrC,CAAC;AAED,SAAgB,QAAQ;IACtB,MAAM,CAAC,GAAG,cAAc,EAAE,CAAC;IAC3B,IAAI,CAAC,IAAA,oBAAU,EAAC,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAChC,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAA,sBAAY,EAAC,CAAC,EAAE,OAAO,CAAC,CAAoB,CAAC;QACtE,OAAO,KAAK,CAAC;IACf,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,SAAgB,QAAQ,CAAC,KAAsB;IAC7C,IAAI,CAAC,IAAA,oBAAU,EAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,IAAA,mBAAS,EAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3C,CAAC;IACD,IAAA,uBAAa,EAAC,cAAc,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AACtG,CAAC;AAED,SAAgB,UAAU;IACxB,MAAM,CAAC,GAAG,cAAc,EAAE,CAAC;IAC3B,IAAI,CAAC,IAAA,oBAAU,EAAC,CAAC,CAAC;QAAE,OAAO,KAAK,CAAC;IACjC,IAAA,oBAAU,EAAC,CAAC,CAAC,CAAC;IACd,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAgB,WAAW,CAAC,KAAsB;IAChD,4DAA4D;IAC5D,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAAC;IACtD,OAAO,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,GAAG,MAAM,CAAC;AACzC,CAAC"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Resolve a user-provided --server value into a full URL.
3
+ *
4
+ * Shortcuts:
5
+ * "cloud" → https://aim.opena2a.org
6
+ * "aim.opena2a.org" → https://aim.opena2a.org
7
+ * "localhost:8080" → http://localhost:8080
8
+ * "http://..." / "https://..." → used as-is
9
+ * "cloud" -> https://aim.opena2a.org
10
+ * "aim.opena2a.org" -> https://aim.opena2a.org
11
+ * "localhost:8080" -> http://localhost:8080
12
+ * "http://..." / "https://..." -> used as-is
13
+ */
14
+ export declare function resolveServerUrl(input: string): string;
15
+ //# sourceMappingURL=server-url.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server-url.d.ts","sourceRoot":"","sources":["../../src/util/server-url.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAgCtD"}
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resolveServerUrl = resolveServerUrl;
4
+ /**
5
+ * Resolve a user-provided --server value into a full URL.
6
+ *
7
+ * Shortcuts:
8
+ * "cloud" → https://aim.opena2a.org
9
+ * "aim.opena2a.org" → https://aim.opena2a.org
10
+ * "localhost:8080" → http://localhost:8080
11
+ * "http://..." / "https://..." → used as-is
12
+ * "cloud" -> https://aim.opena2a.org
13
+ * "aim.opena2a.org" -> https://aim.opena2a.org
14
+ * "localhost:8080" -> http://localhost:8080
15
+ * "http://..." / "https://..." -> used as-is
16
+ */
17
+ function resolveServerUrl(input) {
18
+ const trimmed = input.trim();
19
+ // Shorthand for the hosted AIM service (API endpoint, not the dashboard)
20
+ if (trimmed === 'cloud') {
21
+ return 'https://api.aim.opena2a.org';
22
+ }
23
+ // Already a full URL — use as-is
24
+ // Already a full URL -- use as-is
25
+ if (trimmed.startsWith('http://') || trimmed.startsWith('https://')) {
26
+ // Strip trailing slash for consistency
27
+ return trimmed.replace(/\/+$/, '');
28
+ }
29
+ // Bare hostname that matches the cloud service — route to API endpoint
30
+ if (trimmed === 'aim.opena2a.org' || trimmed.startsWith('aim.opena2a.org/')) {
31
+ return 'https://api.aim.opena2a.org';
32
+ }
33
+ if (trimmed === 'api.aim.opena2a.org' || trimmed.startsWith('api.aim.opena2a.org/')) {
34
+ return `https://${trimmed}`.replace(/\/+$/, '');
35
+ }
36
+ // localhost / 127.0.0.1 / [::1] → default to http
37
+ // localhost / 127.0.0.1 / [::1] -- default to http
38
+ if (/^(localhost|127\.0\.0\.1|\[::1\])(:\d+)?(\/|$)/.test(trimmed)) {
39
+ return `http://${trimmed}`.replace(/\/+$/, '');
40
+ }
41
+ // Any other hostname — default to https
42
+ // Any other hostname -- default to https
43
+ return `https://${trimmed}`.replace(/\/+$/, '');
44
+ }
45
+ //# sourceMappingURL=server-url.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server-url.js","sourceRoot":"","sources":["../../src/util/server-url.ts"],"names":[],"mappings":";;AAaA,4CAgCC;AA7CD;;;;;;;;;;;;GAYG;AACH,SAAgB,gBAAgB,CAAC,KAAa;IAC5C,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;IAE7B,yEAAyE;IACzE,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;QACxB,OAAO,6BAA6B,CAAC;IACvC,CAAC;IAED,iCAAiC;IACjC,kCAAkC;IAClC,IAAI,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QACpE,uCAAuC;QACvC,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACrC,CAAC;IAED,uEAAuE;IACvE,IAAI,OAAO,KAAK,iBAAiB,IAAI,OAAO,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE,CAAC;QAC5E,OAAO,6BAA6B,CAAC;IACvC,CAAC;IACD,IAAI,OAAO,KAAK,qBAAqB,IAAI,OAAO,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE,CAAC;QACpF,OAAO,WAAW,OAAO,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IAClD,CAAC;IAED,kDAAkD;IAClD,mDAAmD;IACnD,IAAI,gDAAgD,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QACnE,OAAO,UAAU,OAAO,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,wCAAwC;IACxC,yCAAyC;IACzC,OAAO,WAAW,OAAO,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;AAClD,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opena2a-cli",
3
- "version": "0.7.2",
3
+ "version": "0.8.1",
4
4
  "description": "Unified CLI for the OpenA2A security platform",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",