assistant-cloud 0.0.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 (47) hide show
  1. package/LICENSE +21 -0
  2. package/dist/AssistantCloud.d.ts +15 -0
  3. package/dist/AssistantCloud.d.ts.map +1 -0
  4. package/dist/AssistantCloud.js +25 -0
  5. package/dist/AssistantCloud.js.map +1 -0
  6. package/dist/AssistantCloudAPI.d.ts +28 -0
  7. package/dist/AssistantCloudAPI.d.ts.map +1 -0
  8. package/dist/AssistantCloudAPI.js +87 -0
  9. package/dist/AssistantCloudAPI.js.map +1 -0
  10. package/dist/AssistantCloudAuthStrategy.d.ts +30 -0
  11. package/dist/AssistantCloudAuthStrategy.d.ts.map +1 -0
  12. package/dist/AssistantCloudAuthStrategy.js +139 -0
  13. package/dist/AssistantCloudAuthStrategy.js.map +1 -0
  14. package/dist/AssistantCloudAuthTokens.d.ts +11 -0
  15. package/dist/AssistantCloudAuthTokens.d.ts.map +1 -0
  16. package/dist/AssistantCloudAuthTokens.js +13 -0
  17. package/dist/AssistantCloudAuthTokens.js.map +1 -0
  18. package/dist/AssistantCloudFiles.d.ts +27 -0
  19. package/dist/AssistantCloudFiles.d.ts.map +1 -0
  20. package/dist/AssistantCloudFiles.js +25 -0
  21. package/dist/AssistantCloudFiles.js.map +1 -0
  22. package/dist/AssistantCloudRuns.d.ts +25 -0
  23. package/dist/AssistantCloudRuns.d.ts.map +1 -0
  24. package/dist/AssistantCloudRuns.js +39 -0
  25. package/dist/AssistantCloudRuns.js.map +1 -0
  26. package/dist/AssistantCloudThreadMessages.d.ts +30 -0
  27. package/dist/AssistantCloudThreadMessages.d.ts.map +1 -0
  28. package/dist/AssistantCloudThreadMessages.js +21 -0
  29. package/dist/AssistantCloudThreadMessages.js.map +1 -0
  30. package/dist/AssistantCloudThreads.d.ts +48 -0
  31. package/dist/AssistantCloudThreads.d.ts.map +1 -0
  32. package/dist/AssistantCloudThreads.js +30 -0
  33. package/dist/AssistantCloudThreads.js.map +1 -0
  34. package/dist/index.d.ts +3 -0
  35. package/dist/index.d.ts.map +1 -0
  36. package/dist/index.js +6 -0
  37. package/dist/index.js.map +1 -0
  38. package/package.json +55 -0
  39. package/src/AssistantCloud.tsx +22 -0
  40. package/src/AssistantCloudAPI.tsx +121 -0
  41. package/src/AssistantCloudAuthStrategy.tsx +193 -0
  42. package/src/AssistantCloudAuthTokens.tsx +13 -0
  43. package/src/AssistantCloudFiles.tsx +48 -0
  44. package/src/AssistantCloudRuns.tsx +44 -0
  45. package/src/AssistantCloudThreadMessages.tsx +48 -0
  46. package/src/AssistantCloudThreads.tsx +79 -0
  47. package/src/index.ts +2 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 AgentbaseAI Inc.
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,15 @@
1
+ import { AssistantCloudConfig } from "./AssistantCloudAPI";
2
+ import { AssistantCloudAuthTokens } from "./AssistantCloudAuthTokens";
3
+ import { AssistantCloudRuns } from "./AssistantCloudRuns";
4
+ import { AssistantCloudThreads } from "./AssistantCloudThreads";
5
+ import { AssistantCloudFiles } from "./AssistantCloudFiles";
6
+ export declare class AssistantCloud {
7
+ readonly threads: AssistantCloudThreads;
8
+ readonly auth: {
9
+ tokens: AssistantCloudAuthTokens;
10
+ };
11
+ readonly runs: AssistantCloudRuns;
12
+ readonly files: AssistantCloudFiles;
13
+ constructor(config: AssistantCloudConfig);
14
+ }
15
+ //# sourceMappingURL=AssistantCloud.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloud.d.ts","sourceRoot":"","sources":["../src/AssistantCloud.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAqB,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,qBAAa,cAAc;IACzB,SAAgB,OAAO,wBAAC;IACxB,SAAgB,IAAI;;MAAC;IACrB,SAAgB,IAAI,qBAAC;IACrB,SAAgB,KAAK,sBAAC;gBAEV,MAAM,EAAE,oBAAoB;CASzC"}
@@ -0,0 +1,25 @@
1
+ // src/AssistantCloud.tsx
2
+ import { AssistantCloudAPI } from "./AssistantCloudAPI.js";
3
+ import { AssistantCloudAuthTokens } from "./AssistantCloudAuthTokens.js";
4
+ import { AssistantCloudRuns } from "./AssistantCloudRuns.js";
5
+ import { AssistantCloudThreads } from "./AssistantCloudThreads.js";
6
+ import { AssistantCloudFiles } from "./AssistantCloudFiles.js";
7
+ var AssistantCloud = class {
8
+ threads;
9
+ auth;
10
+ runs;
11
+ files;
12
+ constructor(config) {
13
+ const api = new AssistantCloudAPI(config);
14
+ this.threads = new AssistantCloudThreads(api);
15
+ this.auth = {
16
+ tokens: new AssistantCloudAuthTokens(api)
17
+ };
18
+ this.runs = new AssistantCloudRuns(api);
19
+ this.files = new AssistantCloudFiles(api);
20
+ }
21
+ };
22
+ export {
23
+ AssistantCloud
24
+ };
25
+ //# sourceMappingURL=AssistantCloud.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloud.tsx"],"sourcesContent":["import { AssistantCloudAPI, AssistantCloudConfig } from \"./AssistantCloudAPI\";\nimport { AssistantCloudAuthTokens } from \"./AssistantCloudAuthTokens\";\nimport { AssistantCloudRuns } from \"./AssistantCloudRuns\";\nimport { AssistantCloudThreads } from \"./AssistantCloudThreads\";\nimport { AssistantCloudFiles } from \"./AssistantCloudFiles\";\n\nexport class AssistantCloud {\n public readonly threads;\n public readonly auth;\n public readonly runs;\n public readonly files;\n\n constructor(config: AssistantCloudConfig) {\n const api = new AssistantCloudAPI(config);\n this.threads = new AssistantCloudThreads(api);\n this.auth = {\n tokens: new AssistantCloudAuthTokens(api),\n };\n this.runs = new AssistantCloudRuns(api);\n this.files = new AssistantCloudFiles(api);\n }\n}\n"],"mappings":";AAAA,SAAS,yBAA+C;AACxD,SAAS,gCAAgC;AACzC,SAAS,0BAA0B;AACnC,SAAS,6BAA6B;AACtC,SAAS,2BAA2B;AAE7B,IAAM,iBAAN,MAAqB;AAAA,EACV;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAEhB,YAAY,QAA8B;AACxC,UAAM,MAAM,IAAI,kBAAkB,MAAM;AACxC,SAAK,UAAU,IAAI,sBAAsB,GAAG;AAC5C,SAAK,OAAO;AAAA,MACV,QAAQ,IAAI,yBAAyB,GAAG;AAAA,IAC1C;AACA,SAAK,OAAO,IAAI,mBAAmB,GAAG;AACtC,SAAK,QAAQ,IAAI,oBAAoB,GAAG;AAAA,EAC1C;AACF;","names":[]}
@@ -0,0 +1,28 @@
1
+ import { AssistantCloudAuthStrategy } from "./AssistantCloudAuthStrategy";
2
+ export type AssistantCloudConfig = {
3
+ baseUrl: string;
4
+ authToken: () => Promise<string | null>;
5
+ } | {
6
+ apiKey: string;
7
+ userId: string;
8
+ workspaceId: string;
9
+ } | {
10
+ baseUrl: string;
11
+ anonymous: true;
12
+ };
13
+ type MakeRequestOptions = {
14
+ method?: "POST" | "PUT" | "DELETE" | undefined;
15
+ headers?: Record<string, string> | undefined;
16
+ query?: Record<string, string | number | boolean> | undefined;
17
+ body?: object | undefined;
18
+ };
19
+ export declare class AssistantCloudAPI {
20
+ _auth: AssistantCloudAuthStrategy;
21
+ _baseUrl: string;
22
+ constructor(config: AssistantCloudConfig);
23
+ initializeAuth(): Promise<boolean>;
24
+ makeRawRequest(endpoint: string, options?: MakeRequestOptions): Promise<Response>;
25
+ makeRequest(endpoint: string, options?: MakeRequestOptions): Promise<any>;
26
+ }
27
+ export {};
28
+ //# sourceMappingURL=AssistantCloudAPI.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloudAPI.d.ts","sourceRoot":"","sources":["../src/AssistantCloudAPI.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,0BAA0B,EAI3B,MAAM,8BAA8B,CAAC;AAEtC,MAAM,MAAM,oBAAoB,GAC5B;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CACzC,GACD;IACE,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;CACrB,GACD;IACE,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;CACjB,CAAC;AASN,KAAK,kBAAkB,GAAG;IACxB,MAAM,CAAC,EAAE,MAAM,GAAG,KAAK,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC;IAC7C,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,GAAG,SAAS,CAAC;IAC9D,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC3B,CAAC;AAEF,qBAAa,iBAAiB;IACrB,KAAK,EAAE,0BAA0B,CAAC;IAClC,QAAQ,SAAC;gBAEJ,MAAM,EAAE,oBAAoB;IAqB3B,cAAc;IAId,cAAc,CACzB,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE,kBAAuB;IAiDrB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,GAAE,kBAAuB;CAI5E"}
@@ -0,0 +1,87 @@
1
+ // src/AssistantCloudAPI.tsx
2
+ import {
3
+ AssistantCloudJWTAuthStrategy,
4
+ AssistantCloudAPIKeyAuthStrategy,
5
+ AssistantCloudAnonymousAuthStrategy
6
+ } from "./AssistantCloudAuthStrategy.js";
7
+ var CloudAPIError = class extends Error {
8
+ constructor(message) {
9
+ super(message);
10
+ this.name = "APIError";
11
+ }
12
+ };
13
+ var AssistantCloudAPI = class {
14
+ _auth;
15
+ _baseUrl;
16
+ constructor(config) {
17
+ if ("authToken" in config) {
18
+ this._baseUrl = config.baseUrl;
19
+ this._auth = new AssistantCloudJWTAuthStrategy(config.authToken);
20
+ } else if ("apiKey" in config) {
21
+ this._baseUrl = "https://backend.assistant-api.com";
22
+ this._auth = new AssistantCloudAPIKeyAuthStrategy(
23
+ config.apiKey,
24
+ config.userId,
25
+ config.workspaceId
26
+ );
27
+ } else if ("anonymous" in config) {
28
+ this._baseUrl = config.baseUrl;
29
+ this._auth = new AssistantCloudAnonymousAuthStrategy(config.baseUrl);
30
+ } else {
31
+ throw new Error(
32
+ "Invalid configuration: Must provide authToken, apiKey, or anonymous configuration"
33
+ );
34
+ }
35
+ }
36
+ async initializeAuth() {
37
+ return !!this._auth.getAuthHeaders();
38
+ }
39
+ async makeRawRequest(endpoint, options = {}) {
40
+ const authHeaders = await this._auth.getAuthHeaders();
41
+ if (!authHeaders) throw new Error("Authorization failed");
42
+ const headers = {
43
+ ...authHeaders,
44
+ ...options.headers,
45
+ "Content-Type": "application/json"
46
+ };
47
+ const queryParams = new URLSearchParams();
48
+ if (options.query) {
49
+ for (const [key, value] of Object.entries(options.query)) {
50
+ if (value === false) continue;
51
+ if (value === true) {
52
+ queryParams.set(key, "true");
53
+ } else {
54
+ queryParams.set(key, value.toString());
55
+ }
56
+ }
57
+ }
58
+ const url = new URL(`${this._baseUrl}/v1${endpoint}`);
59
+ url.search = queryParams.toString();
60
+ const response = await fetch(url, {
61
+ method: options.method ?? "GET",
62
+ headers,
63
+ body: options.body ? JSON.stringify(options.body) : null
64
+ });
65
+ this._auth.readAuthHeaders(response.headers);
66
+ if (!response.ok) {
67
+ const text = await response.text();
68
+ try {
69
+ const body = JSON.parse(text);
70
+ throw new CloudAPIError(body.message);
71
+ } catch {
72
+ throw new Error(
73
+ `Request failed with status ${response.status}, ${text}`
74
+ );
75
+ }
76
+ }
77
+ return response;
78
+ }
79
+ async makeRequest(endpoint, options = {}) {
80
+ const response = await this.makeRawRequest(endpoint, options);
81
+ return response.json();
82
+ }
83
+ };
84
+ export {
85
+ AssistantCloudAPI
86
+ };
87
+ //# sourceMappingURL=AssistantCloudAPI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloudAPI.tsx"],"sourcesContent":["import {\n AssistantCloudAuthStrategy,\n AssistantCloudJWTAuthStrategy,\n AssistantCloudAPIKeyAuthStrategy,\n AssistantCloudAnonymousAuthStrategy,\n} from \"./AssistantCloudAuthStrategy\";\n\nexport type AssistantCloudConfig =\n | {\n baseUrl: string;\n authToken: () => Promise<string | null>;\n }\n | {\n apiKey: string;\n userId: string;\n workspaceId: string;\n }\n | {\n baseUrl: string;\n anonymous: true;\n };\n\nclass CloudAPIError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"APIError\";\n }\n}\n\ntype MakeRequestOptions = {\n method?: \"POST\" | \"PUT\" | \"DELETE\" | undefined;\n headers?: Record<string, string> | undefined;\n query?: Record<string, string | number | boolean> | undefined;\n body?: object | undefined;\n};\n\nexport class AssistantCloudAPI {\n public _auth: AssistantCloudAuthStrategy;\n public _baseUrl;\n\n constructor(config: AssistantCloudConfig) {\n if (\"authToken\" in config) {\n this._baseUrl = config.baseUrl;\n this._auth = new AssistantCloudJWTAuthStrategy(config.authToken);\n } else if (\"apiKey\" in config) {\n this._baseUrl = \"https://backend.assistant-api.com\";\n this._auth = new AssistantCloudAPIKeyAuthStrategy(\n config.apiKey,\n config.userId,\n config.workspaceId,\n );\n } else if (\"anonymous\" in config) {\n this._baseUrl = config.baseUrl;\n this._auth = new AssistantCloudAnonymousAuthStrategy(config.baseUrl);\n } else {\n throw new Error(\n \"Invalid configuration: Must provide authToken, apiKey, or anonymous configuration\",\n );\n }\n }\n\n public async initializeAuth() {\n return !!this._auth.getAuthHeaders();\n }\n\n public async makeRawRequest(\n endpoint: string,\n options: MakeRequestOptions = {},\n ) {\n const authHeaders = await this._auth.getAuthHeaders();\n if (!authHeaders) throw new Error(\"Authorization failed\");\n\n const headers = {\n ...authHeaders,\n ...options.headers,\n \"Content-Type\": \"application/json\",\n };\n\n const queryParams = new URLSearchParams();\n if (options.query) {\n for (const [key, value] of Object.entries(options.query)) {\n if (value === false) continue;\n if (value === true) {\n queryParams.set(key, \"true\");\n } else {\n queryParams.set(key, value.toString());\n }\n }\n }\n\n const url = new URL(`${this._baseUrl}/v1${endpoint}`);\n url.search = queryParams.toString();\n\n const response = await fetch(url, {\n method: options.method ?? \"GET\",\n headers,\n body: options.body ? JSON.stringify(options.body) : null,\n });\n\n this._auth.readAuthHeaders(response.headers);\n\n if (!response.ok) {\n const text = await response.text();\n try {\n const body = JSON.parse(text);\n throw new CloudAPIError(body.message);\n } catch {\n throw new Error(\n `Request failed with status ${response.status}, ${text}`,\n );\n }\n }\n\n return response;\n }\n\n public async makeRequest(endpoint: string, options: MakeRequestOptions = {}) {\n const response = await this.makeRawRequest(endpoint, options);\n return response.json();\n }\n}\n"],"mappings":";AAAA;AAAA,EAEE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAiBP,IAAM,gBAAN,cAA4B,MAAM;AAAA,EAChC,YAAY,SAAiB;AAC3B,UAAM,OAAO;AACb,SAAK,OAAO;AAAA,EACd;AACF;AASO,IAAM,oBAAN,MAAwB;AAAA,EACtB;AAAA,EACA;AAAA,EAEP,YAAY,QAA8B;AACxC,QAAI,eAAe,QAAQ;AACzB,WAAK,WAAW,OAAO;AACvB,WAAK,QAAQ,IAAI,8BAA8B,OAAO,SAAS;AAAA,IACjE,WAAW,YAAY,QAAQ;AAC7B,WAAK,WAAW;AAChB,WAAK,QAAQ,IAAI;AAAA,QACf,OAAO;AAAA,QACP,OAAO;AAAA,QACP,OAAO;AAAA,MACT;AAAA,IACF,WAAW,eAAe,QAAQ;AAChC,WAAK,WAAW,OAAO;AACvB,WAAK,QAAQ,IAAI,oCAAoC,OAAO,OAAO;AAAA,IACrE,OAAO;AACL,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAa,iBAAiB;AAC5B,WAAO,CAAC,CAAC,KAAK,MAAM,eAAe;AAAA,EACrC;AAAA,EAEA,MAAa,eACX,UACA,UAA8B,CAAC,GAC/B;AACA,UAAM,cAAc,MAAM,KAAK,MAAM,eAAe;AACpD,QAAI,CAAC,YAAa,OAAM,IAAI,MAAM,sBAAsB;AAExD,UAAM,UAAU;AAAA,MACd,GAAG;AAAA,MACH,GAAG,QAAQ;AAAA,MACX,gBAAgB;AAAA,IAClB;AAEA,UAAM,cAAc,IAAI,gBAAgB;AACxC,QAAI,QAAQ,OAAO;AACjB,iBAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,QAAQ,KAAK,GAAG;AACxD,YAAI,UAAU,MAAO;AACrB,YAAI,UAAU,MAAM;AAClB,sBAAY,IAAI,KAAK,MAAM;AAAA,QAC7B,OAAO;AACL,sBAAY,IAAI,KAAK,MAAM,SAAS,CAAC;AAAA,QACvC;AAAA,MACF;AAAA,IACF;AAEA,UAAM,MAAM,IAAI,IAAI,GAAG,KAAK,QAAQ,MAAM,QAAQ,EAAE;AACpD,QAAI,SAAS,YAAY,SAAS;AAElC,UAAM,WAAW,MAAM,MAAM,KAAK;AAAA,MAChC,QAAQ,QAAQ,UAAU;AAAA,MAC1B;AAAA,MACA,MAAM,QAAQ,OAAO,KAAK,UAAU,QAAQ,IAAI,IAAI;AAAA,IACtD,CAAC;AAED,SAAK,MAAM,gBAAgB,SAAS,OAAO;AAE3C,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,OAAO,MAAM,SAAS,KAAK;AACjC,UAAI;AACF,cAAM,OAAO,KAAK,MAAM,IAAI;AAC5B,cAAM,IAAI,cAAc,KAAK,OAAO;AAAA,MACtC,QAAQ;AACN,cAAM,IAAI;AAAA,UACR,8BAA8B,SAAS,MAAM,KAAK,IAAI;AAAA,QACxD;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,MAAa,YAAY,UAAkB,UAA8B,CAAC,GAAG;AAC3E,UAAM,WAAW,MAAM,KAAK,eAAe,UAAU,OAAO;AAC5D,WAAO,SAAS,KAAK;AAAA,EACvB;AACF;","names":[]}
@@ -0,0 +1,30 @@
1
+ export type AssistantCloudAuthStrategy = {
2
+ readonly strategy: "anon" | "jwt" | "api-key";
3
+ getAuthHeaders(): Promise<Record<string, string> | false>;
4
+ readAuthHeaders(headers: Headers): void;
5
+ };
6
+ export declare class AssistantCloudJWTAuthStrategy implements AssistantCloudAuthStrategy {
7
+ #private;
8
+ readonly strategy = "jwt";
9
+ private cachedToken;
10
+ private tokenExpiry;
11
+ constructor(authTokenCallback: () => Promise<string | null>);
12
+ getAuthHeaders(): Promise<Record<string, string> | false>;
13
+ readAuthHeaders(headers: Headers): void;
14
+ }
15
+ export declare class AssistantCloudAPIKeyAuthStrategy implements AssistantCloudAuthStrategy {
16
+ #private;
17
+ readonly strategy = "api-key";
18
+ constructor(apiKey: string, userId: string, workspaceId: string);
19
+ getAuthHeaders(): Promise<Record<string, string>>;
20
+ readAuthHeaders(): void;
21
+ }
22
+ export declare class AssistantCloudAnonymousAuthStrategy implements AssistantCloudAuthStrategy {
23
+ readonly strategy = "anon";
24
+ private baseUrl;
25
+ private jwtStrategy;
26
+ constructor(baseUrl: string);
27
+ getAuthHeaders(): Promise<Record<string, string> | false>;
28
+ readAuthHeaders(headers: Headers): void;
29
+ }
30
+ //# sourceMappingURL=AssistantCloudAuthStrategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloudAuthStrategy.d.ts","sourceRoot":"","sources":["../src/AssistantCloudAuthStrategy.tsx"],"names":[],"mappings":"AAAA,MAAM,MAAM,0BAA0B,GAAG;IACvC,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,KAAK,GAAG,SAAS,CAAC;IAC9C,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;IAC1D,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;CACzC,CAAC;AAgCF,qBAAa,6BACX,YAAW,0BAA0B;;IAErC,SAAgB,QAAQ,SAAS;IAEjC,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,WAAW,CAAuB;gBAG9B,iBAAiB,EAAE,MAAM,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAI9C,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC;IAsB/D,eAAe,CAAC,OAAO,EAAE,OAAO;CAYxC;AAED,qBAAa,gCACX,YAAW,0BAA0B;;IAErC,SAAgB,QAAQ,aAAa;gBAMzB,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAMlD,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAQvD,eAAe;CAGvB;AAID,qBAAa,mCACX,YAAW,0BAA0B;IAErC,SAAgB,QAAQ,UAAU;IAElC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,WAAW,CAAgC;gBAEvC,OAAO,EAAE,MAAM;IA8Dd,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC;IAI/D,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;CAG/C"}
@@ -0,0 +1,139 @@
1
+ // src/AssistantCloudAuthStrategy.tsx
2
+ var getJwtExpiry = (jwt) => {
3
+ try {
4
+ const parts = jwt.split(".");
5
+ const bodyPart = parts[1];
6
+ if (!bodyPart) {
7
+ throw new Error("Invalid JWT format");
8
+ }
9
+ let base64 = bodyPart.replace(/-/g, "+").replace(/_/g, "/");
10
+ while (base64.length % 4 !== 0) {
11
+ base64 += "=";
12
+ }
13
+ const payload = atob(base64);
14
+ const payloadObj = JSON.parse(payload);
15
+ const exp = payloadObj.exp;
16
+ if (!exp || typeof exp !== "number") {
17
+ throw new Error('JWT does not contain a valid "exp" field');
18
+ }
19
+ return exp * 1e3;
20
+ } catch (error) {
21
+ throw new Error("Unable to determine the token expiry: " + error);
22
+ }
23
+ };
24
+ var AssistantCloudJWTAuthStrategy = class {
25
+ strategy = "jwt";
26
+ cachedToken = null;
27
+ tokenExpiry = null;
28
+ #authTokenCallback;
29
+ constructor(authTokenCallback) {
30
+ this.#authTokenCallback = authTokenCallback;
31
+ }
32
+ async getAuthHeaders() {
33
+ const currentTime = Date.now();
34
+ if (this.cachedToken && this.tokenExpiry && this.tokenExpiry - currentTime > 30 * 1e3) {
35
+ return { Authorization: `Bearer ${this.cachedToken}` };
36
+ }
37
+ const newToken = await this.#authTokenCallback();
38
+ if (!newToken) return false;
39
+ this.cachedToken = newToken;
40
+ this.tokenExpiry = getJwtExpiry(newToken);
41
+ return { Authorization: `Bearer ${newToken}` };
42
+ }
43
+ readAuthHeaders(headers) {
44
+ const authHeader = headers.get("Authorization");
45
+ if (!authHeader) return;
46
+ const [scheme, token] = authHeader.split(" ");
47
+ if (scheme !== "Bearer" || !token) {
48
+ throw new Error("Invalid auth header received");
49
+ }
50
+ this.cachedToken = token;
51
+ this.tokenExpiry = getJwtExpiry(token);
52
+ }
53
+ };
54
+ var AssistantCloudAPIKeyAuthStrategy = class {
55
+ strategy = "api-key";
56
+ #apiKey;
57
+ #userId;
58
+ #workspaceId;
59
+ constructor(apiKey, userId, workspaceId) {
60
+ this.#apiKey = apiKey;
61
+ this.#userId = userId;
62
+ this.#workspaceId = workspaceId;
63
+ }
64
+ async getAuthHeaders() {
65
+ return {
66
+ Authorization: `Bearer ${this.#apiKey}`,
67
+ "Aui-User-Id": this.#userId,
68
+ "Aui-Workspace-Id": this.#workspaceId
69
+ };
70
+ }
71
+ readAuthHeaders() {
72
+ }
73
+ };
74
+ var AUI_REFRESH_TOKEN_NAME = "aui:refresh_token";
75
+ var AssistantCloudAnonymousAuthStrategy = class {
76
+ strategy = "anon";
77
+ baseUrl;
78
+ jwtStrategy;
79
+ constructor(baseUrl) {
80
+ this.baseUrl = baseUrl;
81
+ this.jwtStrategy = new AssistantCloudJWTAuthStrategy(async () => {
82
+ const currentTime = Date.now();
83
+ const storedRefreshTokenJson = localStorage.getItem(
84
+ AUI_REFRESH_TOKEN_NAME
85
+ );
86
+ const storedRefreshToken = storedRefreshTokenJson ? JSON.parse(storedRefreshTokenJson) : void 0;
87
+ if (storedRefreshToken) {
88
+ const refreshExpiry = new Date(storedRefreshToken.expires_at).getTime();
89
+ if (refreshExpiry - currentTime > 30 * 1e3) {
90
+ const response2 = await fetch(
91
+ `${this.baseUrl}/v1/auth/tokens/refresh`,
92
+ {
93
+ method: "POST",
94
+ headers: { "Content-Type": "application/json" },
95
+ body: JSON.stringify({ refresh_token: storedRefreshToken.token })
96
+ }
97
+ );
98
+ if (response2.ok) {
99
+ const data2 = await response2.json();
100
+ const { access_token: access_token2, refresh_token: refresh_token2 } = data2;
101
+ if (refresh_token2) {
102
+ localStorage.setItem(
103
+ AUI_REFRESH_TOKEN_NAME,
104
+ JSON.stringify(refresh_token2)
105
+ );
106
+ }
107
+ return access_token2;
108
+ }
109
+ } else {
110
+ localStorage.removeItem(AUI_REFRESH_TOKEN_NAME);
111
+ }
112
+ }
113
+ const response = await fetch(`${this.baseUrl}/v1/auth/tokens/anonymous`, {
114
+ method: "POST"
115
+ });
116
+ if (!response.ok) return null;
117
+ const data = await response.json();
118
+ const { access_token, refresh_token } = data;
119
+ if (!access_token || !refresh_token) return null;
120
+ localStorage.setItem(
121
+ AUI_REFRESH_TOKEN_NAME,
122
+ JSON.stringify(refresh_token)
123
+ );
124
+ return access_token;
125
+ });
126
+ }
127
+ async getAuthHeaders() {
128
+ return this.jwtStrategy.getAuthHeaders();
129
+ }
130
+ readAuthHeaders(headers) {
131
+ this.jwtStrategy.readAuthHeaders(headers);
132
+ }
133
+ };
134
+ export {
135
+ AssistantCloudAPIKeyAuthStrategy,
136
+ AssistantCloudAnonymousAuthStrategy,
137
+ AssistantCloudJWTAuthStrategy
138
+ };
139
+ //# sourceMappingURL=AssistantCloudAuthStrategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloudAuthStrategy.tsx"],"sourcesContent":["export type AssistantCloudAuthStrategy = {\n readonly strategy: \"anon\" | \"jwt\" | \"api-key\";\n getAuthHeaders(): Promise<Record<string, string> | false>;\n readAuthHeaders(headers: Headers): void;\n};\n\nconst getJwtExpiry = (jwt: string): number => {\n try {\n const parts = jwt.split(\".\");\n const bodyPart = parts[1];\n if (!bodyPart) {\n throw new Error(\"Invalid JWT format\");\n }\n\n // Convert from Base64Url to Base64 and add padding if necessary\n let base64 = bodyPart.replace(/-/g, \"+\").replace(/_/g, \"/\");\n while (base64.length % 4 !== 0) {\n base64 += \"=\";\n }\n\n // Decode the Base64 string and parse the payload\n const payload = atob(base64);\n const payloadObj = JSON.parse(payload);\n const exp = payloadObj.exp;\n\n if (!exp || typeof exp !== \"number\") {\n throw new Error('JWT does not contain a valid \"exp\" field');\n }\n\n // Convert expiration time to milliseconds\n return exp * 1000;\n } catch (error) {\n throw new Error(\"Unable to determine the token expiry: \" + error);\n }\n};\n\nexport class AssistantCloudJWTAuthStrategy\n implements AssistantCloudAuthStrategy\n{\n public readonly strategy = \"jwt\";\n\n private cachedToken: string | null = null;\n private tokenExpiry: number | null = null;\n #authTokenCallback: () => Promise<string | null>;\n\n constructor(authTokenCallback: () => Promise<string | null>) {\n this.#authTokenCallback = authTokenCallback;\n }\n\n public async getAuthHeaders(): Promise<Record<string, string> | false> {\n const currentTime = Date.now();\n\n // Use cached token if it's valid for at least 30 more seconds\n if (\n this.cachedToken &&\n this.tokenExpiry &&\n this.tokenExpiry - currentTime > 30 * 1000\n ) {\n return { Authorization: `Bearer ${this.cachedToken}` };\n }\n\n // Fetch a new token via the callback\n const newToken = await this.#authTokenCallback();\n if (!newToken) return false;\n\n this.cachedToken = newToken;\n this.tokenExpiry = getJwtExpiry(newToken);\n\n return { Authorization: `Bearer ${newToken}` };\n }\n\n public readAuthHeaders(headers: Headers) {\n const authHeader = headers.get(\"Authorization\");\n if (!authHeader) return;\n\n const [scheme, token] = authHeader.split(\" \");\n if (scheme !== \"Bearer\" || !token) {\n throw new Error(\"Invalid auth header received\");\n }\n\n this.cachedToken = token;\n this.tokenExpiry = getJwtExpiry(token);\n }\n}\n\nexport class AssistantCloudAPIKeyAuthStrategy\n implements AssistantCloudAuthStrategy\n{\n public readonly strategy = \"api-key\";\n\n #apiKey: string;\n #userId: string;\n #workspaceId: string;\n\n constructor(apiKey: string, userId: string, workspaceId: string) {\n this.#apiKey = apiKey;\n this.#userId = userId;\n this.#workspaceId = workspaceId;\n }\n\n public async getAuthHeaders(): Promise<Record<string, string>> {\n return {\n Authorization: `Bearer ${this.#apiKey}`,\n \"Aui-User-Id\": this.#userId,\n \"Aui-Workspace-Id\": this.#workspaceId,\n };\n }\n\n public readAuthHeaders() {\n // No operation needed for API key auth\n }\n}\n\nconst AUI_REFRESH_TOKEN_NAME = \"aui:refresh_token\";\n\nexport class AssistantCloudAnonymousAuthStrategy\n implements AssistantCloudAuthStrategy\n{\n public readonly strategy = \"anon\";\n\n private baseUrl: string;\n private jwtStrategy: AssistantCloudJWTAuthStrategy;\n\n constructor(baseUrl: string) {\n this.baseUrl = baseUrl;\n this.jwtStrategy = new AssistantCloudJWTAuthStrategy(async () => {\n const currentTime = Date.now();\n const storedRefreshTokenJson = localStorage.getItem(\n AUI_REFRESH_TOKEN_NAME,\n );\n const storedRefreshToken = storedRefreshTokenJson\n ? (JSON.parse(storedRefreshTokenJson) as {\n token: string;\n expires_at: string;\n })\n : undefined;\n\n if (storedRefreshToken) {\n const refreshExpiry = new Date(storedRefreshToken.expires_at).getTime();\n if (refreshExpiry - currentTime > 30 * 1000) {\n const response = await fetch(\n `${this.baseUrl}/v1/auth/tokens/refresh`,\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ refresh_token: storedRefreshToken.token }),\n },\n );\n\n if (response.ok) {\n const data = await response.json();\n const { access_token, refresh_token } = data;\n if (refresh_token) {\n localStorage.setItem(\n AUI_REFRESH_TOKEN_NAME,\n JSON.stringify(refresh_token),\n );\n }\n return access_token;\n }\n } else {\n localStorage.removeItem(AUI_REFRESH_TOKEN_NAME);\n }\n }\n\n // No valid refresh token; request a new anonymous token\n const response = await fetch(`${this.baseUrl}/v1/auth/tokens/anonymous`, {\n method: \"POST\",\n });\n\n if (!response.ok) return null;\n\n const data = await response.json();\n const { access_token, refresh_token } = data;\n\n if (!access_token || !refresh_token) return null;\n\n localStorage.setItem(\n AUI_REFRESH_TOKEN_NAME,\n JSON.stringify(refresh_token),\n );\n return access_token;\n });\n }\n\n public async getAuthHeaders(): Promise<Record<string, string> | false> {\n return this.jwtStrategy.getAuthHeaders();\n }\n\n public readAuthHeaders(headers: Headers): void {\n this.jwtStrategy.readAuthHeaders(headers);\n }\n}\n"],"mappings":"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","names":["response","data","access_token","refresh_token"]}
@@ -0,0 +1,11 @@
1
+ import { AssistantCloudAPI } from "./AssistantCloudAPI";
2
+ type AssistantCloudAuthTokensCreateResponse = {
3
+ token: string;
4
+ };
5
+ export declare class AssistantCloudAuthTokens {
6
+ private cloud;
7
+ constructor(cloud: AssistantCloudAPI);
8
+ create(): Promise<AssistantCloudAuthTokensCreateResponse>;
9
+ }
10
+ export {};
11
+ //# sourceMappingURL=AssistantCloudAuthTokens.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloudAuthTokens.d.ts","sourceRoot":"","sources":["../src/AssistantCloudAuthTokens.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,KAAK,sCAAsC,GAAG;IAC5C,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,qBAAa,wBAAwB;IACvB,OAAO,CAAC,KAAK;gBAAL,KAAK,EAAE,iBAAiB;IAE/B,MAAM,IAAI,OAAO,CAAC,sCAAsC,CAAC;CAGvE"}
@@ -0,0 +1,13 @@
1
+ // src/AssistantCloudAuthTokens.tsx
2
+ var AssistantCloudAuthTokens = class {
3
+ constructor(cloud) {
4
+ this.cloud = cloud;
5
+ }
6
+ async create() {
7
+ return this.cloud.makeRequest("/auth/tokens", { method: "POST" });
8
+ }
9
+ };
10
+ export {
11
+ AssistantCloudAuthTokens
12
+ };
13
+ //# sourceMappingURL=AssistantCloudAuthTokens.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloudAuthTokens.tsx"],"sourcesContent":["import { AssistantCloudAPI } from \"./AssistantCloudAPI\";\n\ntype AssistantCloudAuthTokensCreateResponse = {\n token: string;\n};\n\nexport class AssistantCloudAuthTokens {\n constructor(private cloud: AssistantCloudAPI) {}\n\n public async create(): Promise<AssistantCloudAuthTokensCreateResponse> {\n return this.cloud.makeRequest(\"/auth/tokens\", { method: \"POST\" });\n }\n}\n"],"mappings":";AAMO,IAAM,2BAAN,MAA+B;AAAA,EACpC,YAAoB,OAA0B;AAA1B;AAAA,EAA2B;AAAA,EAE/C,MAAa,SAA0D;AACrE,WAAO,KAAK,MAAM,YAAY,gBAAgB,EAAE,QAAQ,OAAO,CAAC;AAAA,EAClE;AACF;","names":[]}
@@ -0,0 +1,27 @@
1
+ import { AssistantCloudAPI } from "./AssistantCloudAPI";
2
+ type PdfToImagesRequestBody = {
3
+ file_blob?: string | undefined;
4
+ file_url?: string | undefined;
5
+ };
6
+ type PdfToImagesResponse = {
7
+ success: boolean;
8
+ urls: string[];
9
+ message: string;
10
+ };
11
+ type GeneratePresignedUploadUrlRequestBody = {
12
+ filename: string;
13
+ };
14
+ type GeneratePresignedUploadUrlResponse = {
15
+ success: boolean;
16
+ signedUrl: string;
17
+ expiresAt: string;
18
+ publicUrl: string;
19
+ };
20
+ export declare class AssistantCloudFiles {
21
+ private cloud;
22
+ constructor(cloud: AssistantCloudAPI);
23
+ pdfToImages(body: PdfToImagesRequestBody): Promise<PdfToImagesResponse>;
24
+ generatePresignedUploadUrl(body: GeneratePresignedUploadUrlRequestBody): Promise<GeneratePresignedUploadUrlResponse>;
25
+ }
26
+ export {};
27
+ //# sourceMappingURL=AssistantCloudFiles.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloudFiles.d.ts","sourceRoot":"","sources":["../src/AssistantCloudFiles.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,KAAK,sBAAsB,GAAG;IAC5B,SAAS,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC/B,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC/B,CAAC;AAEF,KAAK,mBAAmB,GAAG;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,KAAK,qCAAqC,GAAG;IAC3C,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,KAAK,kCAAkC,GAAG;IACxC,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,qBAAa,mBAAmB;IAClB,OAAO,CAAC,KAAK;gBAAL,KAAK,EAAE,iBAAiB;IAE/B,WAAW,CACtB,IAAI,EAAE,sBAAsB,GAC3B,OAAO,CAAC,mBAAmB,CAAC;IAOlB,0BAA0B,CACrC,IAAI,EAAE,qCAAqC,GAC1C,OAAO,CAAC,kCAAkC,CAAC;CAS/C"}
@@ -0,0 +1,25 @@
1
+ // src/AssistantCloudFiles.tsx
2
+ var AssistantCloudFiles = class {
3
+ constructor(cloud) {
4
+ this.cloud = cloud;
5
+ }
6
+ async pdfToImages(body) {
7
+ return this.cloud.makeRequest("/files/pdf-to-images", {
8
+ method: "POST",
9
+ body
10
+ });
11
+ }
12
+ async generatePresignedUploadUrl(body) {
13
+ return this.cloud.makeRequest(
14
+ "/files/attachments/generate-presigned-upload-url",
15
+ {
16
+ method: "POST",
17
+ body
18
+ }
19
+ );
20
+ }
21
+ };
22
+ export {
23
+ AssistantCloudFiles
24
+ };
25
+ //# sourceMappingURL=AssistantCloudFiles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloudFiles.tsx"],"sourcesContent":["import { AssistantCloudAPI } from \"./AssistantCloudAPI\";\n\ntype PdfToImagesRequestBody = {\n file_blob?: string | undefined;\n file_url?: string | undefined;\n};\n\ntype PdfToImagesResponse = {\n success: boolean;\n urls: string[];\n message: string;\n};\n\ntype GeneratePresignedUploadUrlRequestBody = {\n filename: string;\n};\n\ntype GeneratePresignedUploadUrlResponse = {\n success: boolean;\n signedUrl: string;\n expiresAt: string;\n publicUrl: string;\n};\n\nexport class AssistantCloudFiles {\n constructor(private cloud: AssistantCloudAPI) {}\n\n public async pdfToImages(\n body: PdfToImagesRequestBody,\n ): Promise<PdfToImagesResponse> {\n return this.cloud.makeRequest(\"/files/pdf-to-images\", {\n method: \"POST\",\n body,\n });\n }\n\n public async generatePresignedUploadUrl(\n body: GeneratePresignedUploadUrlRequestBody,\n ): Promise<GeneratePresignedUploadUrlResponse> {\n return this.cloud.makeRequest(\n \"/files/attachments/generate-presigned-upload-url\",\n {\n method: \"POST\",\n body,\n },\n );\n }\n}\n"],"mappings":";AAwBO,IAAM,sBAAN,MAA0B;AAAA,EAC/B,YAAoB,OAA0B;AAA1B;AAAA,EAA2B;AAAA,EAE/C,MAAa,YACX,MAC8B;AAC9B,WAAO,KAAK,MAAM,YAAY,wBAAwB;AAAA,MACpD,QAAQ;AAAA,MACR;AAAA,IACF,CAAC;AAAA,EACH;AAAA,EAEA,MAAa,2BACX,MAC6C;AAC7C,WAAO,KAAK,MAAM;AAAA,MAChB;AAAA,MACA;AAAA,QACE,QAAQ;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
@@ -0,0 +1,25 @@
1
+ import { AssistantCloudAPI } from "./AssistantCloudAPI";
2
+ import { AssistantStream } from "assistant-stream";
3
+ type AssistantCloudRunsStreamBody = {
4
+ thread_id: string;
5
+ assistant_id: "system/thread_title";
6
+ messages: readonly unknown[];
7
+ };
8
+ export declare class AssistantCloudRuns {
9
+ private cloud;
10
+ constructor(cloud: AssistantCloudAPI);
11
+ __internal_getAssistantOptions(assistantId: string): {
12
+ api: string;
13
+ headers: () => Promise<{
14
+ Accept: string;
15
+ }>;
16
+ body: {
17
+ assistant_id: string;
18
+ response_format: string;
19
+ thread_id: string;
20
+ };
21
+ };
22
+ stream(body: AssistantCloudRunsStreamBody): Promise<AssistantStream>;
23
+ }
24
+ export {};
25
+ //# sourceMappingURL=AssistantCloudRuns.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloudRuns.d.ts","sourceRoot":"","sources":["../src/AssistantCloudRuns.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAoB,MAAM,kBAAkB,CAAC;AAErE,KAAK,4BAA4B,GAAG;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,qBAAqB,CAAC;IACpC,QAAQ,EAAE,SAAS,OAAO,EAAE,CAAC;CAC9B,CAAC;AAEF,qBAAa,kBAAkB;IACjB,OAAO,CAAC,KAAK;gBAAL,KAAK,EAAE,iBAAiB;IAErC,8BAA8B,CAAC,WAAW,EAAE,MAAM;;;;;;;;;;;IAmB5C,MAAM,CACjB,IAAI,EAAE,4BAA4B,GACjC,OAAO,CAAC,eAAe,CAAC;CAU5B"}
@@ -0,0 +1,39 @@
1
+ // src/AssistantCloudRuns.tsx
2
+ import { AssistantStream, PlainTextDecoder } from "assistant-stream";
3
+ var AssistantCloudRuns = class {
4
+ constructor(cloud) {
5
+ this.cloud = cloud;
6
+ }
7
+ __internal_getAssistantOptions(assistantId) {
8
+ return {
9
+ api: this.cloud._baseUrl + "/v1/runs/stream",
10
+ headers: async () => {
11
+ const headers = await this.cloud._auth.getAuthHeaders();
12
+ if (!headers) throw new Error("Authorization failed");
13
+ return {
14
+ ...headers,
15
+ Accept: "text/plain"
16
+ };
17
+ },
18
+ body: {
19
+ assistant_id: assistantId,
20
+ response_format: "vercel-ai-data-stream/v1",
21
+ thread_id: "unstable_todo"
22
+ }
23
+ };
24
+ }
25
+ async stream(body) {
26
+ const response = await this.cloud.makeRawRequest("/runs/stream", {
27
+ method: "POST",
28
+ headers: {
29
+ Accept: "text/plain"
30
+ },
31
+ body
32
+ });
33
+ return AssistantStream.fromResponse(response, new PlainTextDecoder());
34
+ }
35
+ };
36
+ export {
37
+ AssistantCloudRuns
38
+ };
39
+ //# sourceMappingURL=AssistantCloudRuns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloudRuns.tsx"],"sourcesContent":["import { AssistantCloudAPI } from \"./AssistantCloudAPI\";\nimport { AssistantStream, PlainTextDecoder } from \"assistant-stream\";\n\ntype AssistantCloudRunsStreamBody = {\n thread_id: string;\n assistant_id: \"system/thread_title\";\n messages: readonly unknown[]; // TODO type\n};\n\nexport class AssistantCloudRuns {\n constructor(private cloud: AssistantCloudAPI) {}\n\n public __internal_getAssistantOptions(assistantId: string) {\n return {\n api: this.cloud._baseUrl + \"/v1/runs/stream\",\n headers: async () => {\n const headers = await this.cloud._auth.getAuthHeaders();\n if (!headers) throw new Error(\"Authorization failed\");\n return {\n ...headers,\n Accept: \"text/plain\",\n };\n },\n body: {\n assistant_id: assistantId,\n response_format: \"vercel-ai-data-stream/v1\",\n thread_id: \"unstable_todo\",\n },\n };\n }\n\n public async stream(\n body: AssistantCloudRunsStreamBody,\n ): Promise<AssistantStream> {\n const response = await this.cloud.makeRawRequest(\"/runs/stream\", {\n method: \"POST\",\n headers: {\n Accept: \"text/plain\",\n },\n body,\n });\n return AssistantStream.fromResponse(response, new PlainTextDecoder());\n }\n}\n"],"mappings":";AACA,SAAS,iBAAiB,wBAAwB;AAQ3C,IAAM,qBAAN,MAAyB;AAAA,EAC9B,YAAoB,OAA0B;AAA1B;AAAA,EAA2B;AAAA,EAExC,+BAA+B,aAAqB;AACzD,WAAO;AAAA,MACL,KAAK,KAAK,MAAM,WAAW;AAAA,MAC3B,SAAS,YAAY;AACnB,cAAM,UAAU,MAAM,KAAK,MAAM,MAAM,eAAe;AACtD,YAAI,CAAC,QAAS,OAAM,IAAI,MAAM,sBAAsB;AACpD,eAAO;AAAA,UACL,GAAG;AAAA,UACH,QAAQ;AAAA,QACV;AAAA,MACF;AAAA,MACA,MAAM;AAAA,QACJ,cAAc;AAAA,QACd,iBAAiB;AAAA,QACjB,WAAW;AAAA,MACb;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAa,OACX,MAC0B;AAC1B,UAAM,WAAW,MAAM,KAAK,MAAM,eAAe,gBAAgB;AAAA,MAC/D,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,QAAQ;AAAA,MACV;AAAA,MACA;AAAA,IACF,CAAC;AACD,WAAO,gBAAgB,aAAa,UAAU,IAAI,iBAAiB,CAAC;AAAA,EACtE;AACF;","names":[]}
@@ -0,0 +1,30 @@
1
+ import { ReadonlyJSONObject } from "assistant-stream/utils";
2
+ import { AssistantCloudAPI } from "./AssistantCloudAPI";
3
+ export type CloudMessage = {
4
+ id: string;
5
+ parent_id: string | null;
6
+ height: number;
7
+ created_at: Date;
8
+ updated_at: Date;
9
+ format: "aui/v0" | string;
10
+ content: ReadonlyJSONObject;
11
+ };
12
+ type AssistantCloudThreadMessageListResponse = {
13
+ messages: CloudMessage[];
14
+ };
15
+ type AssistantCloudThreadMessageCreateBody = {
16
+ parent_id: string | null;
17
+ format: "aui/v0" | string;
18
+ content: ReadonlyJSONObject;
19
+ };
20
+ type AssistantCloudMessageCreateResponse = {
21
+ message_id: string;
22
+ };
23
+ export declare class AssistantCloudThreadMessages {
24
+ private cloud;
25
+ constructor(cloud: AssistantCloudAPI);
26
+ list(threadId: string): Promise<AssistantCloudThreadMessageListResponse>;
27
+ create(threadId: string, body: AssistantCloudThreadMessageCreateBody): Promise<AssistantCloudMessageCreateResponse>;
28
+ }
29
+ export {};
30
+ //# sourceMappingURL=AssistantCloudThreadMessages.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssistantCloudThreadMessages.d.ts","sourceRoot":"","sources":["../src/AssistantCloudThreadMessages.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,MAAM,MAAM,YAAY,GAAG;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,IAAI,CAAC;IACjB,UAAU,EAAE,IAAI,CAAC;IACjB,MAAM,EAAE,QAAQ,GAAG,MAAM,CAAC;IAC1B,OAAO,EAAE,kBAAkB,CAAC;CAC7B,CAAC;AAEF,KAAK,uCAAuC,GAAG;IAC7C,QAAQ,EAAE,YAAY,EAAE,CAAC;CAC1B,CAAC;AAEF,KAAK,qCAAqC,GAAG;IAC3C,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,MAAM,EAAE,QAAQ,GAAG,MAAM,CAAC;IAC1B,OAAO,EAAE,kBAAkB,CAAC;CAC7B,CAAC;AAEF,KAAK,mCAAmC,GAAG;IACzC,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,qBAAa,4BAA4B;IAC3B,OAAO,CAAC,KAAK;gBAAL,KAAK,EAAE,iBAAiB;IAE/B,IAAI,CACf,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC,uCAAuC,CAAC;IAMtC,MAAM,CACjB,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,qCAAqC,GAC1C,OAAO,CAAC,mCAAmC,CAAC;CAMhD"}
@@ -0,0 +1,21 @@
1
+ // src/AssistantCloudThreadMessages.tsx
2
+ var AssistantCloudThreadMessages = class {
3
+ constructor(cloud) {
4
+ this.cloud = cloud;
5
+ }
6
+ async list(threadId) {
7
+ return this.cloud.makeRequest(
8
+ `/threads/${encodeURIComponent(threadId)}/messages`
9
+ );
10
+ }
11
+ async create(threadId, body) {
12
+ return this.cloud.makeRequest(
13
+ `/threads/${encodeURIComponent(threadId)}/messages`,
14
+ { method: "POST", body }
15
+ );
16
+ }
17
+ };
18
+ export {
19
+ AssistantCloudThreadMessages
20
+ };
21
+ //# sourceMappingURL=AssistantCloudThreadMessages.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssistantCloudThreadMessages.tsx"],"sourcesContent":["import { ReadonlyJSONObject } from \"assistant-stream/utils\";\nimport { AssistantCloudAPI } from \"./AssistantCloudAPI\";\n\nexport type CloudMessage = {\n id: string;\n parent_id: string | null;\n height: number;\n created_at: Date;\n updated_at: Date;\n format: \"aui/v0\" | string;\n content: ReadonlyJSONObject;\n};\n\ntype AssistantCloudThreadMessageListResponse = {\n messages: CloudMessage[];\n};\n\ntype AssistantCloudThreadMessageCreateBody = {\n parent_id: string | null;\n format: \"aui/v0\" | string;\n content: ReadonlyJSONObject;\n};\n\ntype AssistantCloudMessageCreateResponse = {\n message_id: string;\n};\n\nexport class AssistantCloudThreadMessages {\n constructor(private cloud: AssistantCloudAPI) {}\n\n public async list(\n threadId: string,\n ): Promise<AssistantCloudThreadMessageListResponse> {\n return this.cloud.makeRequest(\n `/threads/${encodeURIComponent(threadId)}/messages`,\n );\n }\n\n public async create(\n threadId: string,\n body: AssistantCloudThreadMessageCreateBody,\n ): Promise<AssistantCloudMessageCreateResponse> {\n return this.cloud.makeRequest(\n `/threads/${encodeURIComponent(threadId)}/messages`,\n { method: \"POST\", body },\n );\n }\n}\n"],"mappings":";AA2BO,IAAM,+BAAN,MAAmC;AAAA,EACxC,YAAoB,OAA0B;AAA1B;AAAA,EAA2B;AAAA,EAE/C,MAAa,KACX,UACkD;AAClD,WAAO,KAAK,MAAM;AAAA,MAChB,YAAY,mBAAmB,QAAQ,CAAC;AAAA,IAC1C;AAAA,EACF;AAAA,EAEA,MAAa,OACX,UACA,MAC8C;AAC9C,WAAO,KAAK,MAAM;AAAA,MAChB,YAAY,mBAAmB,QAAQ,CAAC;AAAA,MACxC,EAAE,QAAQ,QAAQ,KAAK;AAAA,IACzB;AAAA,EACF;AACF;","names":[]}