@digitalpresence/cliclaw-auth 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/dist/agent-store.d.ts +53 -0
- package/dist/agent-store.d.ts.map +1 -0
- package/dist/agent-store.js +207 -0
- package/dist/agent-store.js.map +1 -0
- package/dist/calendar-auth.d.ts +6 -0
- package/dist/calendar-auth.d.ts.map +1 -0
- package/dist/calendar-auth.js +17 -0
- package/dist/calendar-auth.js.map +1 -0
- package/dist/claude-md-generator.d.ts +4 -0
- package/dist/claude-md-generator.d.ts.map +1 -0
- package/dist/claude-md-generator.js +82 -0
- package/dist/claude-md-generator.js.map +1 -0
- package/dist/config.d.ts +9 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +34 -0
- package/dist/config.js.map +1 -0
- package/dist/forms-auth.d.ts +6 -0
- package/dist/forms-auth.d.ts.map +1 -0
- package/dist/forms-auth.js +19 -0
- package/dist/forms-auth.js.map +1 -0
- package/dist/gdrive-auth.d.ts +6 -0
- package/dist/gdrive-auth.d.ts.map +1 -0
- package/dist/gdrive-auth.js +17 -0
- package/dist/gdrive-auth.js.map +1 -0
- package/dist/gmail-auth.d.ts +6 -0
- package/dist/gmail-auth.d.ts.map +1 -0
- package/dist/gmail-auth.js +17 -0
- package/dist/gmail-auth.js.map +1 -0
- package/dist/gsheets-auth.d.ts +6 -0
- package/dist/gsheets-auth.d.ts.map +1 -0
- package/dist/gsheets-auth.js +18 -0
- package/dist/gsheets-auth.js.map +1 -0
- package/dist/gslides-auth.d.ts +6 -0
- package/dist/gslides-auth.d.ts.map +1 -0
- package/dist/gslides-auth.js +18 -0
- package/dist/gslides-auth.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +16 -0
- package/dist/index.js.map +1 -0
- package/dist/integration-registry.d.ts +7 -0
- package/dist/integration-registry.d.ts.map +1 -0
- package/dist/integration-registry.js +43 -0
- package/dist/integration-registry.js.map +1 -0
- package/dist/memory-store.d.ts +33 -0
- package/dist/memory-store.d.ts.map +1 -0
- package/dist/memory-store.js +102 -0
- package/dist/memory-store.js.map +1 -0
- package/dist/oauth-client-manager.d.ts +17 -0
- package/dist/oauth-client-manager.d.ts.map +1 -0
- package/dist/oauth-client-manager.js +49 -0
- package/dist/oauth-client-manager.js.map +1 -0
- package/dist/oauth-server.d.ts +7 -0
- package/dist/oauth-server.d.ts.map +1 -0
- package/dist/oauth-server.js +69 -0
- package/dist/oauth-server.js.map +1 -0
- package/dist/scoped-client-manager.d.ts +21 -0
- package/dist/scoped-client-manager.d.ts.map +1 -0
- package/dist/scoped-client-manager.js +51 -0
- package/dist/scoped-client-manager.js.map +1 -0
- package/dist/token-store.d.ts +13 -0
- package/dist/token-store.d.ts.map +1 -0
- package/dist/token-store.js +50 -0
- package/dist/token-store.js.map +1 -0
- package/package.json +25 -0
- package/src/agent-store.ts +263 -0
- package/src/calendar-auth.ts +20 -0
- package/src/claude-md-generator.ts +94 -0
- package/src/config.ts +49 -0
- package/src/forms-auth.ts +22 -0
- package/src/gdrive-auth.ts +20 -0
- package/src/gmail-auth.ts +20 -0
- package/src/gsheets-auth.ts +21 -0
- package/src/gslides-auth.ts +21 -0
- package/src/index.ts +19 -0
- package/src/integration-registry.ts +48 -0
- package/src/memory-store.ts +127 -0
- package/src/oauth-client-manager.ts +63 -0
- package/src/oauth-server.ts +86 -0
- package/src/scoped-client-manager.ts +65 -0
- package/src/token-store.ts +57 -0
- package/tsconfig.json +8 -0
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { readFileSync } from "fs";
|
|
2
|
+
import { google } from "googleapis";
|
|
3
|
+
export function createGSlidesOAuthClient(clientSecretPath, redirectUri) {
|
|
4
|
+
const secret = JSON.parse(readFileSync(clientSecretPath, "utf-8"));
|
|
5
|
+
const { client_id, client_secret } = secret.installed ?? secret.web;
|
|
6
|
+
return new google.auth.OAuth2(client_id, client_secret, redirectUri);
|
|
7
|
+
}
|
|
8
|
+
export function getGSlidesAuthUrl(client) {
|
|
9
|
+
return client.generateAuthUrl({
|
|
10
|
+
access_type: "offline",
|
|
11
|
+
scope: [
|
|
12
|
+
"https://www.googleapis.com/auth/presentations",
|
|
13
|
+
"https://www.googleapis.com/auth/drive.file",
|
|
14
|
+
],
|
|
15
|
+
prompt: "consent",
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=gslides-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gslides-auth.js","sourceRoot":"","sources":["../src/gslides-auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAIpC,MAAM,UAAU,wBAAwB,CAAC,gBAAwB,EAAE,WAAmB;IACpF,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,gBAAgB,EAAE,OAAO,CAAC,CAAC,CAAC;IACnE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,GAAG,CAAC;IACpE,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;AACvE,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,MAAoB;IACpD,OAAO,MAAM,CAAC,eAAe,CAAC;QAC5B,WAAW,EAAE,SAAS;QACtB,KAAK,EAAE;YACL,+CAA+C;YAC/C,4CAA4C;SAC7C;QACD,MAAM,EAAE,SAAS;KAClB,CAAC,CAAC;AACL,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export { TokenStore } from "./token-store.js";
|
|
2
|
+
export { OAuthClientManager } from "./oauth-client-manager.js";
|
|
3
|
+
export { AgentStore } from "./agent-store.js";
|
|
4
|
+
export type { AgentConfig, AgentPermission, CronJobConfig } from "./agent-store.js";
|
|
5
|
+
export { ScopedClientManager, PermissionDeniedError } from "./scoped-client-manager.js";
|
|
6
|
+
export { createOAuthClient, getAuthUrl } from "./gmail-auth.js";
|
|
7
|
+
export { createGDriveOAuthClient, getGDriveAuthUrl } from "./gdrive-auth.js";
|
|
8
|
+
export { createGSlidesOAuthClient, getGSlidesAuthUrl } from "./gslides-auth.js";
|
|
9
|
+
export { createGSheetsOAuthClient, getGSheetsAuthUrl } from "./gsheets-auth.js";
|
|
10
|
+
export { createCalendarOAuthClient, getCalendarAuthUrl } from "./calendar-auth.js";
|
|
11
|
+
export { createFormsOAuthClient, getFormsAuthUrl } from "./forms-auth.js";
|
|
12
|
+
export { waitForOAuthCallback } from "./oauth-server.js";
|
|
13
|
+
export { loadConfig, getConfigDir, getTokensPath, getAgentsDir } from "./config.js";
|
|
14
|
+
export { INTEGRATIONS } from "./integration-registry.js";
|
|
15
|
+
export type { IntegrationDef } from "./integration-registry.js";
|
|
16
|
+
export type { CliclawConfig } from "./config.js";
|
|
17
|
+
export { generateClaudeMd } from "./claude-md-generator.js";
|
|
18
|
+
export { MemoryStore } from "./memory-store.js";
|
|
19
|
+
export type { MemoryEntry } from "./memory-store.js";
|
|
20
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,YAAY,EAAE,WAAW,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACpF,OAAO,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACxF,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,yBAAyB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACnF,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACpF,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,YAAY,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,YAAY,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export { TokenStore } from "./token-store.js";
|
|
2
|
+
export { OAuthClientManager } from "./oauth-client-manager.js";
|
|
3
|
+
export { AgentStore } from "./agent-store.js";
|
|
4
|
+
export { ScopedClientManager, PermissionDeniedError } from "./scoped-client-manager.js";
|
|
5
|
+
export { createOAuthClient, getAuthUrl } from "./gmail-auth.js";
|
|
6
|
+
export { createGDriveOAuthClient, getGDriveAuthUrl } from "./gdrive-auth.js";
|
|
7
|
+
export { createGSlidesOAuthClient, getGSlidesAuthUrl } from "./gslides-auth.js";
|
|
8
|
+
export { createGSheetsOAuthClient, getGSheetsAuthUrl } from "./gsheets-auth.js";
|
|
9
|
+
export { createCalendarOAuthClient, getCalendarAuthUrl } from "./calendar-auth.js";
|
|
10
|
+
export { createFormsOAuthClient, getFormsAuthUrl } from "./forms-auth.js";
|
|
11
|
+
export { waitForOAuthCallback } from "./oauth-server.js";
|
|
12
|
+
export { loadConfig, getConfigDir, getTokensPath, getAgentsDir } from "./config.js";
|
|
13
|
+
export { INTEGRATIONS } from "./integration-registry.js";
|
|
14
|
+
export { generateClaudeMd } from "./claude-md-generator.js";
|
|
15
|
+
export { MemoryStore } from "./memory-store.js";
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,OAAO,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACxF,OAAO,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,yBAAyB,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACnF,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACpF,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAGzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integration-registry.d.ts","sourceRoot":"","sources":["../src/integration-registry.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAyCvD,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export const INTEGRATIONS = {
|
|
2
|
+
gmail: {
|
|
3
|
+
id: "gmail",
|
|
4
|
+
displayName: "Gmail",
|
|
5
|
+
scopes: ["https://www.googleapis.com/auth/gmail.modify"],
|
|
6
|
+
},
|
|
7
|
+
gdrive: {
|
|
8
|
+
id: "gdrive",
|
|
9
|
+
displayName: "Google Drive",
|
|
10
|
+
scopes: ["https://www.googleapis.com/auth/drive"],
|
|
11
|
+
},
|
|
12
|
+
gsheets: {
|
|
13
|
+
id: "gsheets",
|
|
14
|
+
displayName: "Google Sheets",
|
|
15
|
+
scopes: [
|
|
16
|
+
"https://www.googleapis.com/auth/spreadsheets",
|
|
17
|
+
"https://www.googleapis.com/auth/drive",
|
|
18
|
+
],
|
|
19
|
+
},
|
|
20
|
+
gslides: {
|
|
21
|
+
id: "gslides",
|
|
22
|
+
displayName: "Google Slides",
|
|
23
|
+
scopes: [
|
|
24
|
+
"https://www.googleapis.com/auth/presentations",
|
|
25
|
+
"https://www.googleapis.com/auth/drive.file",
|
|
26
|
+
],
|
|
27
|
+
},
|
|
28
|
+
calendar: {
|
|
29
|
+
id: "calendar",
|
|
30
|
+
displayName: "Google Calendar",
|
|
31
|
+
scopes: ["https://www.googleapis.com/auth/calendar"],
|
|
32
|
+
},
|
|
33
|
+
forms: {
|
|
34
|
+
id: "forms",
|
|
35
|
+
displayName: "Google Forms",
|
|
36
|
+
scopes: [
|
|
37
|
+
"https://www.googleapis.com/auth/forms.body",
|
|
38
|
+
"https://www.googleapis.com/auth/forms.responses.readonly",
|
|
39
|
+
"https://www.googleapis.com/auth/drive.metadata.readonly",
|
|
40
|
+
],
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=integration-registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integration-registry.js","sourceRoot":"","sources":["../src/integration-registry.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,YAAY,GAAmC;IAC1D,KAAK,EAAE;QACL,EAAE,EAAE,OAAO;QACX,WAAW,EAAE,OAAO;QACpB,MAAM,EAAE,CAAC,8CAA8C,CAAC;KACzD;IACD,MAAM,EAAE;QACN,EAAE,EAAE,QAAQ;QACZ,WAAW,EAAE,cAAc;QAC3B,MAAM,EAAE,CAAC,uCAAuC,CAAC;KAClD;IACD,OAAO,EAAE;QACP,EAAE,EAAE,SAAS;QACb,WAAW,EAAE,eAAe;QAC5B,MAAM,EAAE;YACN,8CAA8C;YAC9C,uCAAuC;SACxC;KACF;IACD,OAAO,EAAE;QACP,EAAE,EAAE,SAAS;QACb,WAAW,EAAE,eAAe;QAC5B,MAAM,EAAE;YACN,+CAA+C;YAC/C,4CAA4C;SAC7C;KACF;IACD,QAAQ,EAAE;QACR,EAAE,EAAE,UAAU;QACd,WAAW,EAAE,iBAAiB;QAC9B,MAAM,EAAE,CAAC,0CAA0C,CAAC;KACrD;IACD,KAAK,EAAE;QACL,EAAE,EAAE,OAAO;QACX,WAAW,EAAE,cAAc;QAC3B,MAAM,EAAE;YACN,4CAA4C;YAC5C,0DAA0D;YAC1D,yDAAyD;SAC1D;KACF;CACF,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export interface MemoryEntry {
|
|
2
|
+
id: string;
|
|
3
|
+
fact: string;
|
|
4
|
+
tags: string[];
|
|
5
|
+
source: "user" | "agent" | "system";
|
|
6
|
+
importance: 1 | 2 | 3;
|
|
7
|
+
createdAt: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class MemoryStore {
|
|
10
|
+
private memoryDir;
|
|
11
|
+
private filePath;
|
|
12
|
+
constructor(memoryDir: string);
|
|
13
|
+
private ensureDir;
|
|
14
|
+
private readAll;
|
|
15
|
+
private writeAll;
|
|
16
|
+
list(opts?: {
|
|
17
|
+
tag?: string;
|
|
18
|
+
source?: string;
|
|
19
|
+
limit?: number;
|
|
20
|
+
}): MemoryEntry[];
|
|
21
|
+
get(id: string): MemoryEntry | null;
|
|
22
|
+
add(fact: string, opts?: {
|
|
23
|
+
tags?: string[];
|
|
24
|
+
source?: "user" | "agent" | "system";
|
|
25
|
+
importance?: 1 | 2 | 3;
|
|
26
|
+
}): MemoryEntry;
|
|
27
|
+
remove(id: string): boolean;
|
|
28
|
+
removeByTag(tag: string): number;
|
|
29
|
+
search(query: string): MemoryEntry[];
|
|
30
|
+
clear(): number;
|
|
31
|
+
migrate(legacyMemory: string[]): void;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=memory-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-store.d.ts","sourceRoot":"","sources":["../src/memory-store.ts"],"names":[],"mappings":"AAUA,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,MAAM,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;IACpC,UAAU,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,WAAW;IAGV,OAAO,CAAC,SAAS;IAF7B,OAAO,CAAC,QAAQ,CAAS;gBAEL,SAAS,EAAE,MAAM;IAIrC,OAAO,CAAC,SAAS;IAMjB,OAAO,CAAC,OAAO;IAgBf,OAAO,CAAC,QAAQ;IAMhB,IAAI,CAAC,IAAI,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,WAAW,EAAE;IAc7E,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI;IAInC,GAAG,CACD,IAAI,EAAE,MAAM,EACZ,IAAI,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;QAAC,UAAU,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;KAAE,GACvF,WAAW;IAcd,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO;IAQ3B,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM;IAQhC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,EAAE;IASpC,KAAK,IAAI,MAAM;IAOf,OAAO,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,IAAI;CAKtC"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync, appendFileSync, } from "fs";
|
|
2
|
+
import { join } from "path";
|
|
3
|
+
import { randomBytes } from "crypto";
|
|
4
|
+
export class MemoryStore {
|
|
5
|
+
memoryDir;
|
|
6
|
+
filePath;
|
|
7
|
+
constructor(memoryDir) {
|
|
8
|
+
this.memoryDir = memoryDir;
|
|
9
|
+
this.filePath = join(memoryDir, "memories.jsonl");
|
|
10
|
+
}
|
|
11
|
+
ensureDir() {
|
|
12
|
+
if (!existsSync(this.memoryDir)) {
|
|
13
|
+
mkdirSync(this.memoryDir, { recursive: true });
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
readAll() {
|
|
17
|
+
if (!existsSync(this.filePath))
|
|
18
|
+
return [];
|
|
19
|
+
const content = readFileSync(this.filePath, "utf-8").trim();
|
|
20
|
+
if (!content)
|
|
21
|
+
return [];
|
|
22
|
+
return content
|
|
23
|
+
.split("\n")
|
|
24
|
+
.map((line) => {
|
|
25
|
+
try {
|
|
26
|
+
return JSON.parse(line);
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
})
|
|
32
|
+
.filter((e) => e !== null);
|
|
33
|
+
}
|
|
34
|
+
writeAll(entries) {
|
|
35
|
+
this.ensureDir();
|
|
36
|
+
const content = entries.map((e) => JSON.stringify(e)).join("\n");
|
|
37
|
+
writeFileSync(this.filePath, content ? content + "\n" : "", "utf-8");
|
|
38
|
+
}
|
|
39
|
+
list(opts) {
|
|
40
|
+
let entries = this.readAll();
|
|
41
|
+
if (opts?.tag) {
|
|
42
|
+
entries = entries.filter((e) => e.tags.includes(opts.tag));
|
|
43
|
+
}
|
|
44
|
+
if (opts?.source) {
|
|
45
|
+
entries = entries.filter((e) => e.source === opts.source);
|
|
46
|
+
}
|
|
47
|
+
if (opts?.limit && opts.limit > 0) {
|
|
48
|
+
entries = entries.slice(-opts.limit);
|
|
49
|
+
}
|
|
50
|
+
return entries;
|
|
51
|
+
}
|
|
52
|
+
get(id) {
|
|
53
|
+
return this.readAll().find((e) => e.id === id) ?? null;
|
|
54
|
+
}
|
|
55
|
+
add(fact, opts) {
|
|
56
|
+
this.ensureDir();
|
|
57
|
+
const entry = {
|
|
58
|
+
id: randomBytes(4).toString("hex"),
|
|
59
|
+
fact,
|
|
60
|
+
tags: opts?.tags ?? [],
|
|
61
|
+
source: opts?.source ?? "user",
|
|
62
|
+
importance: opts?.importance ?? 2,
|
|
63
|
+
createdAt: new Date().toISOString(),
|
|
64
|
+
};
|
|
65
|
+
appendFileSync(this.filePath, JSON.stringify(entry) + "\n", "utf-8");
|
|
66
|
+
return entry;
|
|
67
|
+
}
|
|
68
|
+
remove(id) {
|
|
69
|
+
const entries = this.readAll();
|
|
70
|
+
const filtered = entries.filter((e) => e.id !== id);
|
|
71
|
+
if (filtered.length === entries.length)
|
|
72
|
+
return false;
|
|
73
|
+
this.writeAll(filtered);
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
removeByTag(tag) {
|
|
77
|
+
const entries = this.readAll();
|
|
78
|
+
const filtered = entries.filter((e) => !e.tags.includes(tag));
|
|
79
|
+
const removed = entries.length - filtered.length;
|
|
80
|
+
if (removed > 0)
|
|
81
|
+
this.writeAll(filtered);
|
|
82
|
+
return removed;
|
|
83
|
+
}
|
|
84
|
+
search(query) {
|
|
85
|
+
const lower = query.toLowerCase();
|
|
86
|
+
return this.readAll().filter((e) => e.fact.toLowerCase().includes(lower) ||
|
|
87
|
+
e.tags.some((t) => t.toLowerCase().includes(lower)));
|
|
88
|
+
}
|
|
89
|
+
clear() {
|
|
90
|
+
const entries = this.readAll();
|
|
91
|
+
const count = entries.length;
|
|
92
|
+
if (count > 0)
|
|
93
|
+
this.writeAll([]);
|
|
94
|
+
return count;
|
|
95
|
+
}
|
|
96
|
+
migrate(legacyMemory) {
|
|
97
|
+
for (const fact of legacyMemory) {
|
|
98
|
+
this.add(fact, { source: "system", importance: 2 });
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=memory-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-store.js","sourceRoot":"","sources":["../src/memory-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { google } from "googleapis";
|
|
2
|
+
import { TokenStore } from "./token-store.js";
|
|
3
|
+
type OAuth2Client = InstanceType<typeof google.auth.OAuth2>;
|
|
4
|
+
export declare class OAuthClientManager {
|
|
5
|
+
private clientSecretPath;
|
|
6
|
+
private redirectUri;
|
|
7
|
+
private tokenStore;
|
|
8
|
+
private clients;
|
|
9
|
+
constructor(clientSecretPath: string, redirectUri: string, tokenStore: TokenStore);
|
|
10
|
+
getClient(account: string): OAuth2Client;
|
|
11
|
+
getRawClient(): OAuth2Client;
|
|
12
|
+
setCredentials(account: string, tokens: Parameters<OAuth2Client["setCredentials"]>[0]): OAuth2Client;
|
|
13
|
+
getTokenStore(): TokenStore;
|
|
14
|
+
listAccounts(): string[];
|
|
15
|
+
}
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=oauth-client-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oauth-client-manager.d.ts","sourceRoot":"","sources":["../src/oauth-client-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAEpC,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,KAAK,YAAY,GAAG,YAAY,CAAC,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAE5D,qBAAa,kBAAkB;IAI3B,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,UAAU;IALpB,OAAO,CAAC,OAAO,CAAmC;gBAGxC,gBAAgB,EAAE,MAAM,EACxB,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,UAAU;IAGhC,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY;IAmBxC,YAAY,IAAI,YAAY;IAI5B,cAAc,CACZ,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,UAAU,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,GACpD,YAAY;IAcf,aAAa,IAAI,UAAU;IAI3B,YAAY,IAAI,MAAM,EAAE;CAGzB"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { createOAuthClient } from "./gmail-auth.js";
|
|
2
|
+
export class OAuthClientManager {
|
|
3
|
+
clientSecretPath;
|
|
4
|
+
redirectUri;
|
|
5
|
+
tokenStore;
|
|
6
|
+
clients = new Map();
|
|
7
|
+
constructor(clientSecretPath, redirectUri, tokenStore) {
|
|
8
|
+
this.clientSecretPath = clientSecretPath;
|
|
9
|
+
this.redirectUri = redirectUri;
|
|
10
|
+
this.tokenStore = tokenStore;
|
|
11
|
+
}
|
|
12
|
+
getClient(account) {
|
|
13
|
+
const existing = this.clients.get(account);
|
|
14
|
+
if (existing)
|
|
15
|
+
return existing;
|
|
16
|
+
const client = createOAuthClient(this.clientSecretPath, this.redirectUri);
|
|
17
|
+
const tokens = this.tokenStore.get(account);
|
|
18
|
+
if (tokens) {
|
|
19
|
+
client.setCredentials(tokens);
|
|
20
|
+
}
|
|
21
|
+
client.on("tokens", (refreshed) => {
|
|
22
|
+
const current = this.tokenStore.get(account) ?? {};
|
|
23
|
+
this.tokenStore.set(account, { ...current, ...refreshed });
|
|
24
|
+
});
|
|
25
|
+
this.clients.set(account, client);
|
|
26
|
+
return client;
|
|
27
|
+
}
|
|
28
|
+
getRawClient() {
|
|
29
|
+
return createOAuthClient(this.clientSecretPath, this.redirectUri);
|
|
30
|
+
}
|
|
31
|
+
setCredentials(account, tokens) {
|
|
32
|
+
const client = createOAuthClient(this.clientSecretPath, this.redirectUri);
|
|
33
|
+
client.setCredentials(tokens);
|
|
34
|
+
client.on("tokens", (refreshed) => {
|
|
35
|
+
const current = this.tokenStore.get(account) ?? {};
|
|
36
|
+
this.tokenStore.set(account, { ...current, ...refreshed });
|
|
37
|
+
});
|
|
38
|
+
this.tokenStore.set(account, tokens);
|
|
39
|
+
this.clients.set(account, client);
|
|
40
|
+
return client;
|
|
41
|
+
}
|
|
42
|
+
getTokenStore() {
|
|
43
|
+
return this.tokenStore;
|
|
44
|
+
}
|
|
45
|
+
listAccounts() {
|
|
46
|
+
return this.tokenStore.list();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=oauth-client-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oauth-client-manager.js","sourceRoot":"","sources":["../src/oauth-client-manager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAKpD,MAAM,OAAO,kBAAkB;IAInB;IACA;IACA;IALF,OAAO,GAAG,IAAI,GAAG,EAAwB,CAAC;IAElD,YACU,gBAAwB,EACxB,WAAmB,EACnB,UAAsB;QAFtB,qBAAgB,GAAhB,gBAAgB,CAAQ;QACxB,gBAAW,GAAX,WAAW,CAAQ;QACnB,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAEJ,SAAS,CAAC,OAAe;QACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,QAAQ;YAAE,OAAO,QAAQ,CAAC;QAE9B,MAAM,MAAM,GAAG,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1E,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC5C,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,SAAS,EAAE,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,GAAG,SAAS,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAClC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,YAAY;QACV,OAAO,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IACpE,CAAC;IAED,cAAc,CACZ,OAAe,EACf,MAAqD;QAErD,MAAM,MAAM,GAAG,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1E,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAE9B,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,SAAS,EAAE,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,GAAG,SAAS,EAAE,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QAClC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Credentials } from "google-auth-library";
|
|
2
|
+
import { google } from "googleapis";
|
|
3
|
+
type OAuth2Client = InstanceType<typeof google.auth.OAuth2>;
|
|
4
|
+
type AuthUrlFn = (client: OAuth2Client) => string;
|
|
5
|
+
export declare function waitForOAuthCallback(client: OAuth2Client, port: number, onUrl: (url: string) => void, authUrlFn?: AuthUrlFn): Promise<Credentials>;
|
|
6
|
+
export {};
|
|
7
|
+
//# sourceMappingURL=oauth-server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oauth-server.d.ts","sourceRoot":"","sources":["../src/oauth-server.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAGpC,KAAK,YAAY,GAAG,YAAY,CAAC,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAC5D,KAAK,SAAS,GAAG,CAAC,MAAM,EAAE,YAAY,KAAK,MAAM,CAAC;AAoBlD,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,YAAY,EACpB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,EAC5B,SAAS,GAAE,SAAsB,GAChC,OAAO,CAAC,WAAW,CAAC,CAqDtB"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import * as http from "http";
|
|
2
|
+
import { URL } from "url";
|
|
3
|
+
import { getAuthUrl } from "./gmail-auth.js";
|
|
4
|
+
const SUCCESS_HTML = `<!DOCTYPE html>
|
|
5
|
+
<html>
|
|
6
|
+
<head><title>cliclaw — Authenticated</title></head>
|
|
7
|
+
<body style="font-family:sans-serif;text-align:center;padding:60px">
|
|
8
|
+
<h1>✅ Authenticated successfully!</h1>
|
|
9
|
+
<p>You can close this tab and return to your terminal.</p>
|
|
10
|
+
</body>
|
|
11
|
+
</html>`;
|
|
12
|
+
const ERROR_HTML = (msg) => `<!DOCTYPE html>
|
|
13
|
+
<html>
|
|
14
|
+
<head><title>cliclaw — Error</title></head>
|
|
15
|
+
<body style="font-family:sans-serif;text-align:center;padding:60px">
|
|
16
|
+
<h1>❌ Authentication failed</h1>
|
|
17
|
+
<p>${msg}</p>
|
|
18
|
+
</body>
|
|
19
|
+
</html>`;
|
|
20
|
+
export async function waitForOAuthCallback(client, port, onUrl, authUrlFn = getAuthUrl) {
|
|
21
|
+
return new Promise((resolve, reject) => {
|
|
22
|
+
const server = http.createServer(async (req, res) => {
|
|
23
|
+
if (!req.url?.startsWith("/oauth/callback")) {
|
|
24
|
+
res.writeHead(404);
|
|
25
|
+
res.end("Not found");
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
const parsed = new URL(req.url, `http://localhost:${port}`);
|
|
29
|
+
const code = parsed.searchParams.get("code");
|
|
30
|
+
const error = parsed.searchParams.get("error");
|
|
31
|
+
if (error) {
|
|
32
|
+
res.writeHead(400, { "Content-Type": "text/html" });
|
|
33
|
+
res.end(ERROR_HTML(error));
|
|
34
|
+
server.close();
|
|
35
|
+
reject(new Error(`OAuth error: ${error}`));
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
if (!code) {
|
|
39
|
+
res.writeHead(400, { "Content-Type": "text/html" });
|
|
40
|
+
res.end(ERROR_HTML("No authorization code received."));
|
|
41
|
+
server.close();
|
|
42
|
+
reject(new Error("No authorization code in callback"));
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
try {
|
|
46
|
+
const { tokens } = await client.getToken(code);
|
|
47
|
+
client.setCredentials(tokens);
|
|
48
|
+
res.writeHead(200, { "Content-Type": "text/html" });
|
|
49
|
+
res.end(SUCCESS_HTML);
|
|
50
|
+
server.close();
|
|
51
|
+
resolve(tokens);
|
|
52
|
+
}
|
|
53
|
+
catch (err) {
|
|
54
|
+
res.writeHead(500, { "Content-Type": "text/html" });
|
|
55
|
+
res.end(ERROR_HTML("Token exchange failed."));
|
|
56
|
+
server.close();
|
|
57
|
+
reject(err);
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
server.listen(port, () => {
|
|
61
|
+
const url = authUrlFn(client);
|
|
62
|
+
onUrl(url);
|
|
63
|
+
});
|
|
64
|
+
server.on("error", (err) => {
|
|
65
|
+
reject(new Error(`OAuth server failed to start: ${err.message}`));
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=oauth-server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oauth-server.js","sourceRoot":"","sources":["../src/oauth-server.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { google } from "googleapis";
|
|
2
|
+
import { OAuthClientManager } from "./oauth-client-manager.js";
|
|
3
|
+
import { TokenStore } from "./token-store.js";
|
|
4
|
+
import type { AgentPermission } from "./agent-store.js";
|
|
5
|
+
type OAuth2Client = InstanceType<typeof google.auth.OAuth2>;
|
|
6
|
+
export declare class PermissionDeniedError extends Error {
|
|
7
|
+
constructor(integration: string, account: string);
|
|
8
|
+
}
|
|
9
|
+
export declare class ScopedClientManager {
|
|
10
|
+
private inner;
|
|
11
|
+
private permissions;
|
|
12
|
+
constructor(inner: OAuthClientManager, permissions: AgentPermission[]);
|
|
13
|
+
private hasPermission;
|
|
14
|
+
getClient(accountKey: string): OAuth2Client;
|
|
15
|
+
listAccounts(): string[];
|
|
16
|
+
getTokenStore(): TokenStore;
|
|
17
|
+
getRawClient(): OAuth2Client;
|
|
18
|
+
setCredentials(account: string, tokens: Parameters<OAuth2Client["setCredentials"]>[0]): OAuth2Client;
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=scoped-client-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scoped-client-manager.d.ts","sourceRoot":"","sources":["../src/scoped-client-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AACpC,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAExD,KAAK,YAAY,GAAG,YAAY,CAAC,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAE5D,qBAAa,qBAAsB,SAAQ,KAAK;gBAClC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;CAIjD;AAUD,qBAAa,mBAAmB;IAE5B,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,WAAW;gBADX,KAAK,EAAE,kBAAkB,EACzB,WAAW,EAAE,eAAe,EAAE;IAGxC,OAAO,CAAC,aAAa;IAMrB,SAAS,CAAC,UAAU,EAAE,MAAM,GAAG,YAAY;IAQ3C,YAAY,IAAI,MAAM,EAAE;IAOxB,aAAa,IAAI,UAAU;IAI3B,YAAY,IAAI,YAAY;IAI5B,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,YAAY;CAOrG"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
export class PermissionDeniedError extends Error {
|
|
2
|
+
constructor(integration, account) {
|
|
3
|
+
super(`Agent does not have permission for ${integration}:${account}`);
|
|
4
|
+
this.name = "PermissionDeniedError";
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
function parseAccountKey(key) {
|
|
8
|
+
const colonIdx = key.indexOf(":");
|
|
9
|
+
if (colonIdx === -1) {
|
|
10
|
+
return { integration: "gmail", account: key };
|
|
11
|
+
}
|
|
12
|
+
return { integration: key.slice(0, colonIdx), account: key.slice(colonIdx + 1) };
|
|
13
|
+
}
|
|
14
|
+
export class ScopedClientManager {
|
|
15
|
+
inner;
|
|
16
|
+
permissions;
|
|
17
|
+
constructor(inner, permissions) {
|
|
18
|
+
this.inner = inner;
|
|
19
|
+
this.permissions = permissions;
|
|
20
|
+
}
|
|
21
|
+
hasPermission(integration, account) {
|
|
22
|
+
return this.permissions.some((p) => p.integration === integration && p.account === account);
|
|
23
|
+
}
|
|
24
|
+
getClient(accountKey) {
|
|
25
|
+
const { integration, account } = parseAccountKey(accountKey);
|
|
26
|
+
if (!this.hasPermission(integration, account)) {
|
|
27
|
+
throw new PermissionDeniedError(integration, account);
|
|
28
|
+
}
|
|
29
|
+
return this.inner.getClient(accountKey);
|
|
30
|
+
}
|
|
31
|
+
listAccounts() {
|
|
32
|
+
return this.inner.listAccounts().filter((key) => {
|
|
33
|
+
const { integration, account } = parseAccountKey(key);
|
|
34
|
+
return this.hasPermission(integration, account);
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
getTokenStore() {
|
|
38
|
+
return this.inner.getTokenStore();
|
|
39
|
+
}
|
|
40
|
+
getRawClient() {
|
|
41
|
+
return this.inner.getRawClient();
|
|
42
|
+
}
|
|
43
|
+
setCredentials(account, tokens) {
|
|
44
|
+
const { integration, account: acct } = parseAccountKey(account);
|
|
45
|
+
if (!this.hasPermission(integration, acct)) {
|
|
46
|
+
throw new PermissionDeniedError(integration, acct);
|
|
47
|
+
}
|
|
48
|
+
return this.inner.setCredentials(account, tokens);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=scoped-client-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scoped-client-manager.js","sourceRoot":"","sources":["../src/scoped-client-manager.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,qBAAsB,SAAQ,KAAK;IAC9C,YAAY,WAAmB,EAAE,OAAe;QAC9C,KAAK,CAAC,sCAAsC,WAAW,IAAI,OAAO,EAAE,CAAC,CAAC;QACtE,IAAI,CAAC,IAAI,GAAG,uBAAuB,CAAC;IACtC,CAAC;CACF;AAED,SAAS,eAAe,CAAC,GAAW;IAClC,MAAM,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAClC,IAAI,QAAQ,KAAK,CAAC,CAAC,EAAE,CAAC;QACpB,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC;IAChD,CAAC;IACD,OAAO,EAAE,WAAW,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,CAAC;AACnF,CAAC;AAED,MAAM,OAAO,mBAAmB;IAEpB;IACA;IAFV,YACU,KAAyB,EACzB,WAA8B;QAD9B,UAAK,GAAL,KAAK,CAAoB;QACzB,gBAAW,GAAX,WAAW,CAAmB;IACrC,CAAC;IAEI,aAAa,CAAC,WAAmB,EAAE,OAAe;QACxD,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAC1B,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,WAAW,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,CAC9D,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,UAAkB;QAC1B,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,eAAe,CAAC,UAAU,CAAC,CAAC;QAC7D,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,CAAC;YAC9C,MAAM,IAAI,qBAAqB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;QACxD,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE;YAC9C,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC;YACtD,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IACpC,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;IACnC,CAAC;IAED,cAAc,CAAC,OAAe,EAAE,MAAqD;QACnF,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QAChE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,EAAE,CAAC;YAC3C,MAAM,IAAI,qBAAqB,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QACrD,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACpD,CAAC;CACF"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Credentials } from "google-auth-library";
|
|
2
|
+
export declare class TokenStore {
|
|
3
|
+
private tokensPath;
|
|
4
|
+
constructor(tokensPath: string);
|
|
5
|
+
private load;
|
|
6
|
+
private save;
|
|
7
|
+
get(account: string): Credentials | null;
|
|
8
|
+
set(account: string, tokens: Credentials): void;
|
|
9
|
+
has(account: string): boolean;
|
|
10
|
+
delete(account: string): boolean;
|
|
11
|
+
list(): string[];
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=token-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-store.d.ts","sourceRoot":"","sources":["../src/token-store.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAMvD,qBAAa,UAAU;IACT,OAAO,CAAC,UAAU;gBAAV,UAAU,EAAE,MAAM;IAEtC,OAAO,CAAC,IAAI;IAWZ,OAAO,CAAC,IAAI;IAQZ,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI;IAKxC,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,GAAG,IAAI;IAM/C,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAI7B,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAQhC,IAAI,IAAI,MAAM,EAAE;CAGjB"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "fs";
|
|
2
|
+
import { dirname } from "path";
|
|
3
|
+
export class TokenStore {
|
|
4
|
+
tokensPath;
|
|
5
|
+
constructor(tokensPath) {
|
|
6
|
+
this.tokensPath = tokensPath;
|
|
7
|
+
}
|
|
8
|
+
load() {
|
|
9
|
+
if (!existsSync(this.tokensPath)) {
|
|
10
|
+
return {};
|
|
11
|
+
}
|
|
12
|
+
try {
|
|
13
|
+
return JSON.parse(readFileSync(this.tokensPath, "utf-8"));
|
|
14
|
+
}
|
|
15
|
+
catch {
|
|
16
|
+
return {};
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
save(data) {
|
|
20
|
+
const dir = dirname(this.tokensPath);
|
|
21
|
+
if (!existsSync(dir)) {
|
|
22
|
+
mkdirSync(dir, { recursive: true });
|
|
23
|
+
}
|
|
24
|
+
writeFileSync(this.tokensPath, JSON.stringify(data, null, 2), "utf-8");
|
|
25
|
+
}
|
|
26
|
+
get(account) {
|
|
27
|
+
const data = this.load();
|
|
28
|
+
return data[account] ?? null;
|
|
29
|
+
}
|
|
30
|
+
set(account, tokens) {
|
|
31
|
+
const data = this.load();
|
|
32
|
+
data[account] = tokens;
|
|
33
|
+
this.save(data);
|
|
34
|
+
}
|
|
35
|
+
has(account) {
|
|
36
|
+
return this.get(account) !== null;
|
|
37
|
+
}
|
|
38
|
+
delete(account) {
|
|
39
|
+
const data = this.load();
|
|
40
|
+
if (!(account in data))
|
|
41
|
+
return false;
|
|
42
|
+
delete data[account];
|
|
43
|
+
this.save(data);
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
list() {
|
|
47
|
+
return Object.keys(this.load());
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=token-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-store.js","sourceRoot":"","sources":["../src/token-store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AACxE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAO/B,MAAM,OAAO,UAAU;IACD;IAApB,YAAoB,UAAkB;QAAlB,eAAU,GAAV,UAAU,CAAQ;IAAG,CAAC;IAElC,IAAI;QACV,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACjC,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAc,CAAC;QACzE,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAEO,IAAI,CAAC,IAAe;QAC1B,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YACrB,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACtC,CAAC;QACD,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IACzE,CAAC;IAED,GAAG,CAAC,OAAe;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC;IAC/B,CAAC;IAED,GAAG,CAAC,OAAe,EAAE,MAAmB;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,GAAG,MAAM,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAED,GAAG,CAAC,OAAe;QACjB,OAAO,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,OAAe;QACpB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,CAAC,OAAO,IAAI,IAAI,CAAC;YAAE,OAAO,KAAK,CAAC;QACrC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI;QACF,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAClC,CAAC;CACF"}
|
package/package.json
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@digitalpresence/cliclaw-auth",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"exports": {
|
|
8
|
+
".": {
|
|
9
|
+
"import": "./dist/index.js",
|
|
10
|
+
"types": "./dist/index.d.ts"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"scripts": {
|
|
14
|
+
"build": "tsc",
|
|
15
|
+
"typecheck": "tsc --noEmit"
|
|
16
|
+
},
|
|
17
|
+
"dependencies": {
|
|
18
|
+
"google-auth-library": "^10.5.0",
|
|
19
|
+
"googleapis": "^144.0.0"
|
|
20
|
+
},
|
|
21
|
+
"devDependencies": {
|
|
22
|
+
"@types/node": "^22.0.0",
|
|
23
|
+
"typescript": "^5.8.0"
|
|
24
|
+
}
|
|
25
|
+
}
|