@ouro.bot/cli 0.1.0-alpha.375 → 0.1.0-alpha.377

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.
@@ -1,15 +1,67 @@
1
1
  "use strict";
2
- // Thin entrypoint for `npm run cli` / `node dist/senses/cli-entry.js --agent <name>`.
3
- // Separated from cli.ts so the CLI adapter is pure library code with clean
4
- // 100% test coverage -- entrypoints can't be covered by vitest since
5
- // require.main !== module in the test runner.
6
- // All config comes from the conventional ~/.agentsecrets/<agent>/secrets.json path.
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
7
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
+ const runtime_1 = require("../nerves/runtime");
8
37
  // Fail fast if --agent is missing (before any src/ code tries getAgentName())
9
- if (!process.argv.includes("--agent")) {
38
+ const agentArgIndex = process.argv.indexOf("--agent");
39
+ const agentName = agentArgIndex >= 0 ? process.argv[agentArgIndex + 1] : undefined;
40
+ if (!agentName) {
10
41
  // eslint-disable-next-line no-console -- pre-boot guard: --agent check before imports
11
42
  console.error("Missing required --agent <name> argument.\nUsage: node dist/senses/cli-entry.js --agent ouroboros");
12
43
  process.exit(1);
13
44
  }
14
- const cli_1 = require("./cli");
15
- (0, cli_1.main)();
45
+ (0, runtime_1.emitNervesEvent)({
46
+ component: "senses",
47
+ event: "senses.entry_boot",
48
+ message: "booting CLI entrypoint",
49
+ meta: { entry: "cli", agentName },
50
+ });
51
+ Promise.resolve().then(() => __importStar(require("../heart/runtime-credentials"))).then(async ({ refreshRuntimeCredentialConfig }) => {
52
+ await refreshRuntimeCredentialConfig(agentName, { preserveCachedOnFailure: true }).catch(() => undefined);
53
+ const { main } = await Promise.resolve().then(() => __importStar(require("./cli")));
54
+ main();
55
+ })
56
+ .catch((error) => {
57
+ (0, runtime_1.emitNervesEvent)({
58
+ level: "error",
59
+ component: "senses",
60
+ event: "senses.entry_error",
61
+ message: "CLI entrypoint failed",
62
+ meta: { entry: "cli", agentName, error: error instanceof Error ? error.message : String(error) },
63
+ });
64
+ // eslint-disable-next-line no-console -- fatal startup guard for sense process
65
+ console.error(error instanceof Error ? error.message : String(error));
66
+ process.exit(1);
67
+ });
@@ -1,15 +1,67 @@
1
1
  "use strict";
2
- // Thin entrypoint for `npm run teams` / `node dist/senses/teams-entry.js --agent <name>`.
3
- // Separated from teams.ts so the Teams adapter is pure library code with clean
4
- // 100% test coverage -- entrypoints can't be covered by vitest since
5
- // require.main !== module in the test runner.
6
- // All config comes from the conventional ~/.agentsecrets/<agent>/secrets.json path.
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
7
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
+ const runtime_1 = require("../nerves/runtime");
8
37
  // Fail fast if --agent is missing (before any src/ code tries getAgentName())
9
- if (!process.argv.includes("--agent")) {
38
+ const agentArgIndex = process.argv.indexOf("--agent");
39
+ const agentName = agentArgIndex >= 0 ? process.argv[agentArgIndex + 1] : undefined;
40
+ if (!agentName) {
10
41
  // eslint-disable-next-line no-console -- pre-boot guard: --agent check before imports
11
42
  console.error("Missing required --agent <name> argument.\nUsage: node dist/senses/teams-entry.js --agent ouroboros");
12
43
  process.exit(1);
13
44
  }
14
- const teams_1 = require("./teams");
15
- (0, teams_1.startTeamsApp)();
45
+ (0, runtime_1.emitNervesEvent)({
46
+ component: "senses",
47
+ event: "senses.entry_boot",
48
+ message: "booting Teams entrypoint",
49
+ meta: { entry: "teams", agentName },
50
+ });
51
+ Promise.resolve().then(() => __importStar(require("../heart/runtime-credentials"))).then(async ({ refreshRuntimeCredentialConfig }) => {
52
+ await refreshRuntimeCredentialConfig(agentName, { preserveCachedOnFailure: true }).catch(() => undefined);
53
+ const { startTeamsApp } = await Promise.resolve().then(() => __importStar(require("./teams")));
54
+ startTeamsApp();
55
+ })
56
+ .catch((error) => {
57
+ (0, runtime_1.emitNervesEvent)({
58
+ level: "error",
59
+ component: "senses",
60
+ event: "senses.entry_error",
61
+ message: "Teams entrypoint failed",
62
+ meta: { entry: "teams", agentName, error: error instanceof Error ? error.message : String(error) },
63
+ });
64
+ // eslint-disable-next-line no-console -- fatal startup guard for sense process
65
+ console.error(error instanceof Error ? error.message : String(error));
66
+ process.exit(1);
67
+ });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ouro.bot/cli",
3
- "version": "0.1.0-alpha.375",
3
+ "version": "0.1.0-alpha.377",
4
4
  "main": "dist/heart/daemon/ouro-entry.js",
5
5
  "bin": {
6
6
  "cli": "dist/heart/daemon/ouro-bot-entry.js",
@@ -82,15 +82,11 @@ enter model context.
82
82
  - Use browser-navigation skill form patterns for entering credentials during interactive sessions
83
83
 
84
84
  **How credentials work:**
85
- - Agent-owned credentials are AES-256-GCM encrypted in `~/AgentBundles/<agent>.ouro/vault/`
86
- - The master key lives at `~/.agentsecrets/<agent>/vault.key` (auto-generated on first use)
85
+ - Agent-owned credentials live in the agent's Bitwarden/Vaultwarden vault
86
+ - Travel credentials such as Duffel and Stripe are ordinary vault credential items
87
87
  - The agent can sign up for services and store its own credentials
88
88
  - Stored passwords are never returned to the model — only metadata (domain, username, notes)
89
89
 
90
- **Upgrade path:** Install `aac` (Bitwarden Agent Access CLI) for vault-backed credentials.
91
- When `aac` is available, the harness can read credentials from Bitwarden directly,
92
- enabling access to human-managed vault items without storing them locally.
93
-
94
90
  ### Post-Booking
95
91
  - Save confirmation details (confirmation number, dates, hotel name, airline, booking reference)
96
92
  - Save to diary/journal for future reference