@recallkit/cli 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 (41) hide show
  1. package/dist/args.d.ts +4 -0
  2. package/dist/args.d.ts.map +1 -0
  3. package/dist/args.js +29 -0
  4. package/dist/args.js.map +1 -0
  5. package/dist/commands/approve.d.ts +2 -0
  6. package/dist/commands/approve.d.ts.map +1 -0
  7. package/dist/commands/approve.js +25 -0
  8. package/dist/commands/approve.js.map +1 -0
  9. package/dist/commands/dev.d.ts +2 -0
  10. package/dist/commands/dev.d.ts.map +1 -0
  11. package/dist/commands/dev.js +107 -0
  12. package/dist/commands/dev.js.map +1 -0
  13. package/dist/commands/drafts.d.ts +2 -0
  14. package/dist/commands/drafts.d.ts.map +1 -0
  15. package/dist/commands/drafts.js +24 -0
  16. package/dist/commands/drafts.js.map +1 -0
  17. package/dist/commands/init.d.ts +2 -0
  18. package/dist/commands/init.d.ts.map +1 -0
  19. package/dist/commands/init.js +8 -0
  20. package/dist/commands/init.js.map +1 -0
  21. package/dist/commands/open.d.ts +2 -0
  22. package/dist/commands/open.d.ts.map +1 -0
  23. package/dist/commands/open.js +11 -0
  24. package/dist/commands/open.js.map +1 -0
  25. package/dist/commands/reject.d.ts +2 -0
  26. package/dist/commands/reject.d.ts.map +1 -0
  27. package/dist/commands/reject.js +21 -0
  28. package/dist/commands/reject.js.map +1 -0
  29. package/dist/commands/status.d.ts +2 -0
  30. package/dist/commands/status.d.ts.map +1 -0
  31. package/dist/commands/status.js +10 -0
  32. package/dist/commands/status.js.map +1 -0
  33. package/dist/commands/sync.d.ts +2 -0
  34. package/dist/commands/sync.d.ts.map +1 -0
  35. package/dist/commands/sync.js +13 -0
  36. package/dist/commands/sync.js.map +1 -0
  37. package/dist/index.d.ts +3 -0
  38. package/dist/index.d.ts.map +1 -0
  39. package/dist/index.js +51 -0
  40. package/dist/index.js.map +1 -0
  41. package/package.json +29 -0
package/dist/args.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ export declare function hasFlag(args: string[], flag: string): boolean;
2
+ export declare function readOption(args: string[], name: string): string | undefined;
3
+ export declare function positionalArgs(args: string[], optionNamesWithValues?: string[]): string[];
4
+ //# sourceMappingURL=args.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"args.d.ts","sourceRoot":"","sources":["../src/args.ts"],"names":[],"mappings":"AAAA,wBAAgB,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAE7D;AAED,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAO3E;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,qBAAqB,GAAE,MAAM,EAAO,GAAG,MAAM,EAAE,CAmB7F"}
package/dist/args.js ADDED
@@ -0,0 +1,29 @@
1
+ export function hasFlag(args, flag) {
2
+ return args.includes(flag);
3
+ }
4
+ export function readOption(args, name) {
5
+ const inline = args.find((arg) => arg.startsWith(`${name}=`));
6
+ if (inline)
7
+ return inline.slice(name.length + 1);
8
+ const index = args.indexOf(name);
9
+ const value = index === -1 ? undefined : args[index + 1];
10
+ return value && !value.startsWith("--") ? value : undefined;
11
+ }
12
+ export function positionalArgs(args, optionNamesWithValues = []) {
13
+ const valueOptions = new Set(optionNamesWithValues);
14
+ const values = [];
15
+ for (let index = 0; index < args.length; index += 1) {
16
+ const arg = args[index];
17
+ if (!arg)
18
+ continue;
19
+ if (arg.startsWith("--")) {
20
+ if (valueOptions.has(arg) && args[index + 1] && !args[index + 1]?.startsWith("--")) {
21
+ index += 1;
22
+ }
23
+ continue;
24
+ }
25
+ values.push(arg);
26
+ }
27
+ return values;
28
+ }
29
+ //# sourceMappingURL=args.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"args.js","sourceRoot":"","sources":["../src/args.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,OAAO,CAAC,IAAc,EAAE,IAAY;IAClD,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,IAAc,EAAE,IAAY;IACrD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC;IAC9D,IAAI,MAAM;QAAE,OAAO,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAEjD,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,KAAK,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACzD,OAAO,KAAK,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;AAC9D,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,IAAc,EAAE,wBAAkC,EAAE;IACjF,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,qBAAqB,CAAC,CAAC;IACpD,MAAM,MAAM,GAAa,EAAE,CAAC;IAE5B,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC;QACpD,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,GAAG;YAAE,SAAS;QAEnB,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,IAAI,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;gBACnF,KAAK,IAAI,CAAC,CAAC;YACb,CAAC;YACD,SAAS;QACX,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function approveCommand(args: string[]): Promise<void>;
2
+ //# sourceMappingURL=approve.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approve.d.ts","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AAGA,wBAAsB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAsBlE"}
@@ -0,0 +1,25 @@
1
+ import { normalizeMemoryScope, readPendingMemories, updatePendingMemory } from "@recallkit/core";
2
+ import { hasFlag, positionalArgs, readOption } from "../args.js";
3
+ export async function approveCommand(args) {
4
+ const all = hasFlag(args, "--all");
5
+ const project = readOption(args, "--project");
6
+ const ids = positionalArgs(args, ["--project"]);
7
+ const drafts = await readPendingMemories();
8
+ const selected = drafts.filter((draft) => {
9
+ const scope = normalizeMemoryScope(draft.scope);
10
+ if (draft.status === "rejected" || draft.status === "committed" || scope.level === "session")
11
+ return false;
12
+ if (all)
13
+ return !project || scope.projectId === project;
14
+ return ids.includes(draft.id);
15
+ });
16
+ if (!all && ids.length === 0) {
17
+ console.log("Usage: recallkit approve <draft-id...> | --all [--project name]");
18
+ return;
19
+ }
20
+ for (const draft of selected) {
21
+ await updatePendingMemory(draft.id, { status: "approved" });
22
+ }
23
+ console.log(`Approved ${selected.length} local memory draft${selected.length === 1 ? "" : "s"}.`);
24
+ }
25
+ //# sourceMappingURL=approve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approve.js","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACjG,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAEjE,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,IAAc;IACjD,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IAC9C,MAAM,GAAG,GAAG,cAAc,CAAC,IAAI,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;IAChD,MAAM,MAAM,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC3C,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;QACvC,MAAM,KAAK,GAAG,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,KAAK,CAAC,MAAM,KAAK,UAAU,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS;YAAE,OAAO,KAAK,CAAC;QAC3G,IAAI,GAAG;YAAE,OAAO,CAAC,OAAO,IAAI,KAAK,CAAC,SAAS,KAAK,OAAO,CAAC;QACxD,OAAO,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,iEAAiE,CAAC,CAAC;QAC/E,OAAO;IACT,CAAC;IAED,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;QAC7B,MAAM,mBAAmB,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,YAAY,QAAQ,CAAC,MAAM,sBAAsB,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;AACpG,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function devCommand(): void;
2
+ //# sourceMappingURL=dev.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dev.d.ts","sourceRoot":"","sources":["../../src/commands/dev.ts"],"names":[],"mappings":"AAKA,wBAAgB,UAAU,IAAI,IAAI,CA+BjC"}
@@ -0,0 +1,107 @@
1
+ import { spawn } from "node:child_process";
2
+ import fs from "node:fs";
3
+ import { createRequire } from "node:module";
4
+ import path from "node:path";
5
+ export function devCommand() {
6
+ const env = {
7
+ ...process.env,
8
+ RECALLKIT_DATA_DIR: process.env.RECALLKIT_DATA_DIR ?? process.cwd(),
9
+ RECALLKIT_LOCAL_URL: process.env.RECALLKIT_LOCAL_URL ?? "http://localhost:4317",
10
+ RECALLKIT_DAEMON_URL: process.env.RECALLKIT_DAEMON_URL ?? "http://localhost:4318",
11
+ RECALLKIT_PORT: process.env.RECALLKIT_PORT ?? approvalAppPort(process.env.RECALLKIT_LOCAL_URL),
12
+ };
13
+ const root = workspaceRoot();
14
+ const children = root
15
+ ? startWorkspaceRuntime(env, root)
16
+ : startInstalledRuntime(env);
17
+ let stopping = false;
18
+ const stop = (code = 0) => {
19
+ if (stopping)
20
+ return;
21
+ stopping = true;
22
+ for (const child of children)
23
+ stopChild(child.pid);
24
+ process.exit(code ?? 0);
25
+ };
26
+ for (const child of children) {
27
+ child.on("exit", (code) => {
28
+ if (code !== 0 && code !== null)
29
+ stop(code);
30
+ if (child === children[1])
31
+ stop(code ?? 0);
32
+ });
33
+ }
34
+ process.on("SIGINT", () => stop(0));
35
+ process.on("SIGTERM", () => stop(0));
36
+ }
37
+ function startWorkspaceRuntime(env, cwd) {
38
+ return [
39
+ spawn("pnpm", ["--filter", "@recallkit/daemon", "dev"], spawnOptions(env, cwd)),
40
+ spawn("pnpm", ["--filter", "@recallkit/web", "dev"], spawnOptions(env, cwd)),
41
+ ];
42
+ }
43
+ function startInstalledRuntime(env) {
44
+ const require = createRequire(import.meta.url);
45
+ const daemonEntry = require.resolve("@recallkit/daemon");
46
+ const webPackageJson = require.resolve("@recallkit/web/package.json");
47
+ const webDir = path.dirname(webPackageJson);
48
+ const webRequire = createRequire(webPackageJson);
49
+ const nextBin = webRequire.resolve("next/dist/bin/next");
50
+ return [
51
+ spawn(process.execPath, [daemonEntry], spawnOptions(env)),
52
+ spawn(process.execPath, [nextBin, "dev", webDir, "-p", env.RECALLKIT_PORT ?? "4317"], spawnOptions(env)),
53
+ ];
54
+ }
55
+ function spawnOptions(env, cwd = process.cwd()) {
56
+ return {
57
+ stdio: "inherit",
58
+ cwd,
59
+ env,
60
+ detached: process.platform !== "win32",
61
+ shell: process.platform === "win32",
62
+ };
63
+ }
64
+ function stopChild(pid) {
65
+ if (!pid)
66
+ return;
67
+ try {
68
+ if (process.platform === "win32") {
69
+ process.kill(pid, "SIGTERM");
70
+ return;
71
+ }
72
+ process.kill(-pid, "SIGTERM");
73
+ }
74
+ catch (error) {
75
+ if (process.env.RECALLKIT_DEBUG) {
76
+ console.warn("Unable to stop RecallKit child process", error);
77
+ }
78
+ }
79
+ }
80
+ function workspaceRoot(start = process.cwd()) {
81
+ let current = start;
82
+ while (true) {
83
+ if (fs.existsSync(path.join(current, "pnpm-workspace.yaml")) &&
84
+ fs.existsSync(path.join(current, "packages/daemon/package.json")) &&
85
+ fs.existsSync(path.join(current, "apps/web/package.json"))) {
86
+ return current;
87
+ }
88
+ const parent = path.dirname(current);
89
+ if (parent === current)
90
+ return undefined;
91
+ current = parent;
92
+ }
93
+ }
94
+ function approvalAppPort(localUrl) {
95
+ if (!localUrl)
96
+ return "4317";
97
+ try {
98
+ return new URL(localUrl).port || "4317";
99
+ }
100
+ catch (error) {
101
+ if (process.env.RECALLKIT_DEBUG) {
102
+ console.warn("Invalid RECALLKIT_LOCAL_URL", error);
103
+ }
104
+ return "4317";
105
+ }
106
+ }
107
+ //# sourceMappingURL=dev.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dev.js","sourceRoot":"","sources":["../../src/commands/dev.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function draftsCommand(args: string[]): Promise<void>;
2
+ //# sourceMappingURL=drafts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drafts.d.ts","sourceRoot":"","sources":["../../src/commands/drafts.ts"],"names":[],"mappings":"AAGA,wBAAsB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAwBjE"}
@@ -0,0 +1,24 @@
1
+ import { normalizeMemoryScope, readPendingMemories } from "@recallkit/core";
2
+ import { hasFlag } from "../args.js";
3
+ export async function draftsCommand(args) {
4
+ const all = hasFlag(args, "--all");
5
+ const json = hasFlag(args, "--json");
6
+ const drafts = (await readPendingMemories()).filter((draft) => all || (draft.status !== "rejected" && draft.status !== "committed"));
7
+ if (json) {
8
+ console.log(JSON.stringify({ drafts }, null, 2));
9
+ return;
10
+ }
11
+ if (drafts.length === 0) {
12
+ console.log("No local memory drafts.");
13
+ return;
14
+ }
15
+ for (const draft of drafts) {
16
+ const scope = normalizeMemoryScope(draft.scope);
17
+ const project = scope.projectId ? `:${scope.projectId}` : "";
18
+ console.log(`${draft.id} ${draft.status} ${scope.level}${project} ${draft.kind}`);
19
+ console.log(` ${draft.text}`);
20
+ if (draft.scopeReason)
21
+ console.log(` scope: ${draft.scopeReason}`);
22
+ }
23
+ }
24
+ //# sourceMappingURL=drafts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drafts.js","sourceRoot":"","sources":["../../src/commands/drafts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAErC,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,IAAc;IAChD,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IACrC,MAAM,MAAM,GAAG,CAAC,MAAM,mBAAmB,EAAE,CAAC,CAAC,MAAM,CACjD,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,UAAU,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW,CAAC,CAChF,CAAC;IAEF,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,OAAO;IACT,CAAC;IAED,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;QACvC,OAAO;IACT,CAAC;IAED,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,MAAM,KAAK,GAAG,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAChD,MAAM,OAAO,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7D,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,KAAK,KAAK,CAAC,KAAK,GAAG,OAAO,KAAK,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QACrF,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAC/B,IAAI,KAAK,CAAC,WAAW;YAAE,OAAO,CAAC,GAAG,CAAC,YAAY,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;IACtE,CAAC;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function initCommand(): Promise<void>;
2
+ //# sourceMappingURL=init.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAEA,wBAAsB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC,CAKjD"}
@@ -0,0 +1,8 @@
1
+ import { ensureRecallKitDir, readConfig, writeConfig } from "@recallkit/core";
2
+ export async function initCommand() {
3
+ await ensureRecallKitDir();
4
+ const config = await writeConfig(await readConfig());
5
+ console.log(`RecallKit initialized at .recallkit`);
6
+ console.log(`Approval app URL: ${config.approvalAppUrl}`);
7
+ }
8
+ //# sourceMappingURL=init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9E,MAAM,CAAC,KAAK,UAAU,WAAW;IAC/B,MAAM,kBAAkB,EAAE,CAAC;IAC3B,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,MAAM,UAAU,EAAE,CAAC,CAAC;IACrD,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;IACnD,OAAO,CAAC,GAAG,CAAC,qBAAqB,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;AAC5D,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function openCommand(path?: string): void;
2
+ //# sourceMappingURL=open.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"open.d.ts","sourceRoot":"","sources":["../../src/commands/open.ts"],"names":[],"mappings":"AAGA,wBAAgB,WAAW,CAAC,IAAI,SAAM,GAAG,IAAI,CAQ5C"}
@@ -0,0 +1,11 @@
1
+ import { spawn } from "node:child_process";
2
+ import { DEFAULT_APPROVAL_APP_URL } from "@recallkit/core";
3
+ export function openCommand(path = "/") {
4
+ const url = `${process.env.RECALLKIT_LOCAL_URL ?? DEFAULT_APPROVAL_APP_URL}${path}`;
5
+ const command = process.platform === "darwin" ? "open" : process.platform === "win32" ? "cmd" : "xdg-open";
6
+ const args = process.platform === "win32" ? ["/c", "start", url] : [url];
7
+ const child = spawn(command, args, { stdio: "ignore", detached: true });
8
+ child.unref();
9
+ console.log(url);
10
+ }
11
+ //# sourceMappingURL=open.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"open.js","sourceRoot":"","sources":["../../src/commands/open.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAE3D,MAAM,UAAU,WAAW,CAAC,IAAI,GAAG,GAAG;IACpC,MAAM,GAAG,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,wBAAwB,GAAG,IAAI,EAAE,CAAC;IACpF,MAAM,OAAO,GACX,OAAO,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC;IAC7F,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IACzE,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;IACxE,KAAK,CAAC,KAAK,EAAE,CAAC;IACd,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AACnB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function rejectCommand(args: string[]): Promise<void>;
2
+ //# sourceMappingURL=reject.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reject.d.ts","sourceRoot":"","sources":["../../src/commands/reject.ts"],"names":[],"mappings":"AAGA,wBAAsB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAmBjE"}
@@ -0,0 +1,21 @@
1
+ import { readPendingMemories, updatePendingMemory } from "@recallkit/core";
2
+ import { hasFlag, positionalArgs } from "../args.js";
3
+ export async function rejectCommand(args) {
4
+ const all = hasFlag(args, "--all");
5
+ const ids = positionalArgs(args);
6
+ const drafts = await readPendingMemories();
7
+ const selected = drafts.filter((draft) => {
8
+ if (draft.status === "committed")
9
+ return false;
10
+ return all || ids.includes(draft.id);
11
+ });
12
+ if (!all && ids.length === 0) {
13
+ console.log("Usage: recallkit reject <draft-id...> | --all");
14
+ return;
15
+ }
16
+ for (const draft of selected) {
17
+ await updatePendingMemory(draft.id, { status: "rejected" });
18
+ }
19
+ console.log(`Rejected ${selected.length} local memory draft${selected.length === 1 ? "" : "s"}.`);
20
+ }
21
+ //# sourceMappingURL=reject.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reject.js","sourceRoot":"","sources":["../../src/commands/reject.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAErD,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,IAAc;IAChD,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,GAAG,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,MAAM,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC3C,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;QACvC,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW;YAAE,OAAO,KAAK,CAAC;QAC/C,OAAO,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;QAC7D,OAAO;IACT,CAAC;IAED,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;QAC7B,MAAM,mBAAmB,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,YAAY,QAAQ,CAAC,MAAM,sBAAsB,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;AACpG,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function statusCommand(): Promise<void>;
2
+ //# sourceMappingURL=status.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAEA,wBAAsB,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAOnD"}
@@ -0,0 +1,10 @@
1
+ import { getWalletStatus, readPendingMemories } from "@recallkit/core";
2
+ export async function statusCommand() {
3
+ const [status, pending] = await Promise.all([getWalletStatus(), readPendingMemories()]);
4
+ console.log(JSON.stringify({
5
+ ...status,
6
+ draftCount: pending.filter((draft) => draft.status !== "rejected" && draft.status !== "committed").length,
7
+ approvedCount: pending.filter((draft) => draft.status === "approved").length,
8
+ }, null, 2));
9
+ }
10
+ //# sourceMappingURL=status.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEvE,MAAM,CAAC,KAAK,UAAU,aAAa;IACjC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,eAAe,EAAE,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC;IACxF,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;QACzB,GAAG,MAAM;QACT,UAAU,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,UAAU,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,MAAM;QACzG,aAAa,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,MAAM;KAC7E,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;AACf,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function syncCommand(): Promise<void>;
2
+ //# sourceMappingURL=sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../src/commands/sync.ts"],"names":[],"mappings":"AAGA,wBAAsB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC,CAajD"}
@@ -0,0 +1,13 @@
1
+ import { normalizeMemoryScope, readPendingMemories } from "@recallkit/core";
2
+ import { openCommand } from "./open.js";
3
+ export async function syncCommand() {
4
+ const drafts = await readPendingMemories();
5
+ const approved = drafts.filter((draft) => draft.status === "approved" && normalizeMemoryScope(draft.scope).level !== "session");
6
+ if (approved.length === 0) {
7
+ console.log("No approved memories are ready to save. Open RecallKit to review captured drafts.");
8
+ return;
9
+ }
10
+ console.log(`Opening RecallKit to save ${approved.length} approved memor${approved.length === 1 ? "y" : "ies"}.`);
11
+ openCommand("/drafts");
12
+ }
13
+ //# sourceMappingURL=sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/commands/sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,MAAM,CAAC,KAAK,UAAU,WAAW;IAC/B,MAAM,MAAM,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC3C,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAC5B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,UAAU,IAAI,oBAAoB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,KAAK,KAAK,SAAS,CAChG,CAAC;IAEF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,CAAC,GAAG,CAAC,mFAAmF,CAAC,CAAC;QACjG,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,6BAA6B,QAAQ,CAAC,MAAM,kBAAkB,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;IAClH,WAAW,CAAC,SAAS,CAAC,CAAC;AACzB,CAAC"}
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
package/dist/index.js ADDED
@@ -0,0 +1,51 @@
1
+ #!/usr/bin/env node
2
+ import { approveCommand } from "./commands/approve.js";
3
+ import { devCommand } from "./commands/dev.js";
4
+ import { draftsCommand } from "./commands/drafts.js";
5
+ import { initCommand } from "./commands/init.js";
6
+ import { openCommand } from "./commands/open.js";
7
+ import { rejectCommand } from "./commands/reject.js";
8
+ import { statusCommand } from "./commands/status.js";
9
+ import { syncCommand } from "./commands/sync.js";
10
+ const command = process.argv[2] ?? "help";
11
+ const args = process.argv.slice(3);
12
+ switch (command) {
13
+ case "init":
14
+ await initCommand();
15
+ break;
16
+ case "dev":
17
+ devCommand();
18
+ break;
19
+ case "status":
20
+ await statusCommand();
21
+ break;
22
+ case "drafts":
23
+ await draftsCommand(args);
24
+ break;
25
+ case "approve":
26
+ await approveCommand(args);
27
+ break;
28
+ case "reject":
29
+ await rejectCommand(args);
30
+ break;
31
+ case "sync":
32
+ await syncCommand();
33
+ break;
34
+ case "open":
35
+ openCommand(process.argv[3] ?? "/");
36
+ break;
37
+ default:
38
+ console.log(`RecallKit
39
+
40
+ Usage:
41
+ recallkit init
42
+ recallkit dev
43
+ recallkit status
44
+ recallkit drafts [--json] [--all]
45
+ recallkit approve <draft-id...> | --all [--project name]
46
+ recallkit reject <draft-id...> | --all
47
+ recallkit sync
48
+ recallkit open [/path]
49
+ `);
50
+ }
51
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC;AAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAEnC,QAAQ,OAAO,EAAE,CAAC;IAChB,KAAK,MAAM;QACT,MAAM,WAAW,EAAE,CAAC;QACpB,MAAM;IACR,KAAK,KAAK;QACR,UAAU,EAAE,CAAC;QACb,MAAM;IACR,KAAK,QAAQ;QACX,MAAM,aAAa,EAAE,CAAC;QACtB,MAAM;IACR,KAAK,QAAQ;QACX,MAAM,aAAa,CAAC,IAAI,CAAC,CAAC;QAC1B,MAAM;IACR,KAAK,SAAS;QACZ,MAAM,cAAc,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM;IACR,KAAK,QAAQ;QACX,MAAM,aAAa,CAAC,IAAI,CAAC,CAAC;QAC1B,MAAM;IACR,KAAK,MAAM;QACT,MAAM,WAAW,EAAE,CAAC;QACpB,MAAM;IACR,KAAK,MAAM;QACT,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC;QACpC,MAAM;IACR;QACE,OAAO,CAAC,GAAG,CAAC;;;;;;;;;;;CAWf,CAAC,CAAC;AACH,CAAC"}
package/package.json ADDED
@@ -0,0 +1,29 @@
1
+ {
2
+ "name": "@recallkit/cli",
3
+ "version": "0.1.0",
4
+ "type": "module",
5
+ "bin": {
6
+ "recallkit": "./dist/index.js"
7
+ },
8
+ "main": "./dist/index.js",
9
+ "types": "./dist/index.d.ts",
10
+ "scripts": {
11
+ "build": "tsc -p tsconfig.json",
12
+ "typecheck": "tsc -p tsconfig.json --noEmit"
13
+ },
14
+ "dependencies": {
15
+ "@recallkit/core": "workspace:*",
16
+ "@recallkit/daemon": "workspace:*",
17
+ "@recallkit/web": "workspace:*"
18
+ },
19
+ "devDependencies": {
20
+ "@types/node": "^25.9.1",
21
+ "typescript": "^5.9.3"
22
+ },
23
+ "files": [
24
+ "dist"
25
+ ],
26
+ "engines": {
27
+ "node": ">=20.9.0"
28
+ }
29
+ }