@base44-preview/sdk 0.7.0-pr.26.ab75236 → 0.7.0-pr.27.2a9d388

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.
@@ -0,0 +1,44 @@
1
+ export type AgentConversation = {
2
+ id: string;
3
+ app_id: string;
4
+ agent_name: string;
5
+ created_by_id: string;
6
+ messages: AgentMessage[];
7
+ metadata?: Record<string, any>;
8
+ };
9
+ export type AgentMessage = {
10
+ id: string;
11
+ role: "user" | "assistant" | "system";
12
+ reasoning: {
13
+ start_date: string;
14
+ end_date?: string;
15
+ content: string;
16
+ };
17
+ content?: string | Record<string, any> | null;
18
+ file_urls?: string[] | null;
19
+ tool_calls?: {
20
+ id: string;
21
+ name: string;
22
+ arguments_string: string;
23
+ status: "running" | "success" | "error" | "stopped";
24
+ results?: string | null;
25
+ }[] | null;
26
+ usage: {
27
+ prompt_tokens?: number;
28
+ completion_tokens?: number;
29
+ } | null;
30
+ hidden?: boolean;
31
+ custom_context?: {
32
+ message: string;
33
+ data: Record<string, any>;
34
+ type: string;
35
+ }[] | null;
36
+ model: string | null;
37
+ checkpoint_id: string | null;
38
+ metadata?: {
39
+ created_date: string;
40
+ created_by_email: string;
41
+ created_by_full_name: string | null;
42
+ };
43
+ additional_message_params?: Record<string, any>;
44
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -77,6 +77,7 @@ export function createAuthModule(axios, functionsAxiosClient, appId) {
77
77
  setToken(token, saveToStorage = true) {
78
78
  if (!token)
79
79
  return;
80
+ // handle token change for axios clients
80
81
  axios.defaults.headers.common["Authorization"] = `Bearer ${token}`;
81
82
  functionsAxiosClient.defaults.headers.common["Authorization"] = `Bearer ${token}`;
82
83
  // Save token to localStorage if requested
@@ -23,7 +23,7 @@ export declare class Base44Error extends Error {
23
23
  * @param {string} options.serverUrl - Server URL (needed for login redirect)
24
24
  * @returns {import('axios').AxiosInstance} Configured axios instance
25
25
  */
26
- export declare function createAxiosClient({ baseURL, headers, token, requiresAuth, appId, serverUrl, interceptResponses, }: {
26
+ export declare function createAxiosClient({ baseURL, headers, token, requiresAuth, appId, serverUrl, interceptResponses, onError, }: {
27
27
  baseURL: string;
28
28
  headers?: Record<string, string>;
29
29
  token?: string;
@@ -31,4 +31,5 @@ export declare function createAxiosClient({ baseURL, headers, token, requiresAut
31
31
  appId: string;
32
32
  serverUrl: string;
33
33
  interceptResponses?: boolean;
34
+ onError?: (error: Error) => void;
34
35
  }): import("axios").AxiosInstance;
@@ -64,7 +64,7 @@ function redirectToLogin(serverUrl, appId) {
64
64
  * @param {string} options.serverUrl - Server URL (needed for login redirect)
65
65
  * @returns {import('axios').AxiosInstance} Configured axios instance
66
66
  */
67
- export function createAxiosClient({ baseURL, headers = {}, token, requiresAuth = false, appId, serverUrl, interceptResponses = true, }) {
67
+ export function createAxiosClient({ baseURL, headers = {}, token, requiresAuth = false, appId, serverUrl, interceptResponses = true, onError, }) {
68
68
  const client = axios.create({
69
69
  baseURL,
70
70
  headers: {
@@ -107,6 +107,7 @@ export function createAxiosClient({ baseURL, headers = {}, token, requiresAuth =
107
107
  redirectToLogin(serverUrl, appId);
108
108
  }, 100);
109
109
  }
110
+ onError === null || onError === void 0 ? void 0 : onError(base44Error);
110
111
  return Promise.reject(base44Error);
111
112
  });
112
113
  }
@@ -0,0 +1,47 @@
1
+ import { Socket } from "socket.io-client";
2
+ export type RoomsSocketConfig = {
3
+ serverUrl: string;
4
+ mountPath: string;
5
+ transports: string[];
6
+ appId: string;
7
+ token?: string;
8
+ };
9
+ export type TSocketRoom = string;
10
+ export type TJsonStr = string;
11
+ type RoomsSocketEventsMap = {
12
+ listen: {
13
+ connect: () => void;
14
+ update_model: (msg: {
15
+ room: string;
16
+ data: TJsonStr;
17
+ }) => void;
18
+ };
19
+ emit: {
20
+ join: (room: string) => void;
21
+ leave: (room: string) => void;
22
+ };
23
+ };
24
+ type TEvent = keyof RoomsSocketEventsMap["listen"];
25
+ type THandler<E extends TEvent> = (...args: Parameters<RoomsSocketEventsMap["listen"][E]>) => void;
26
+ export declare function RoomsSocket({ config }: {
27
+ config: RoomsSocketConfig;
28
+ }): {
29
+ socket: Socket<{
30
+ connect: () => void;
31
+ update_model: (msg: {
32
+ room: string;
33
+ data: TJsonStr;
34
+ }) => void;
35
+ }, {
36
+ join: (room: string) => void;
37
+ leave: (room: string) => void;
38
+ }>;
39
+ subscribeToRoom: (room: TSocketRoom, handlers: { [k in TEvent]: THandler<k>; }) => () => void;
40
+ updateConfig: (config: Partial<RoomsSocketConfig>) => void;
41
+ handlers: {
42
+ connect: THandler<"connect">;
43
+ update_model: THandler<"update_model">;
44
+ };
45
+ disconnect: () => void;
46
+ };
47
+ export {};
@@ -0,0 +1,85 @@
1
+ import { io } from "socket.io-client";
2
+ function initializeSocket(config, handlers) {
3
+ const socket = io(config.serverUrl, {
4
+ path: config.mountPath,
5
+ transports: config.transports,
6
+ query: {
7
+ appId: config.appId,
8
+ token: config.token,
9
+ },
10
+ });
11
+ socket.on("connect", () => {
12
+ console.log("connect", socket.id);
13
+ handlers.connect();
14
+ });
15
+ socket.on("update_model", (msg) => {
16
+ handlers.update_model(msg);
17
+ });
18
+ return socket;
19
+ }
20
+ export function RoomsSocket({ config }) {
21
+ let currentConfig = { ...config };
22
+ const roomsToListeners = {};
23
+ const handlers = {
24
+ connect: () => {
25
+ Object.keys(roomsToListeners).forEach((room) => {
26
+ var _a;
27
+ joinRoom(room);
28
+ (_a = getListeners(room)) === null || _a === void 0 ? void 0 : _a.forEach(({ connect: connectHandler }) => {
29
+ connectHandler();
30
+ });
31
+ });
32
+ },
33
+ update_model: (msg) => {
34
+ var _a;
35
+ if (roomsToListeners[msg.room]) {
36
+ (_a = getListeners(msg.room)) === null || _a === void 0 ? void 0 : _a.forEach(({ update_model }) => {
37
+ update_model(msg);
38
+ });
39
+ }
40
+ },
41
+ };
42
+ let socket = initializeSocket(config, handlers);
43
+ function cleanup() {
44
+ disconnect();
45
+ }
46
+ function disconnect() {
47
+ if (socket) {
48
+ socket.disconnect();
49
+ }
50
+ }
51
+ function updateConfig(config) {
52
+ cleanup();
53
+ currentConfig = {
54
+ ...currentConfig,
55
+ ...config,
56
+ };
57
+ socket = initializeSocket(currentConfig, handlers);
58
+ }
59
+ function joinRoom(room) {
60
+ socket.emit("join", room);
61
+ }
62
+ function leaveRoom(room) {
63
+ socket.emit("leave", room);
64
+ }
65
+ function getListeners(room) {
66
+ return roomsToListeners[room];
67
+ }
68
+ const subscribeToRoom = (room, handlers) => {
69
+ if (!roomsToListeners[room]) {
70
+ joinRoom(room);
71
+ roomsToListeners[room] = [];
72
+ }
73
+ roomsToListeners[room].push(handlers);
74
+ return () => {
75
+ roomsToListeners[room] = roomsToListeners[room].filter((listener) => listener !== handlers);
76
+ };
77
+ };
78
+ return {
79
+ socket,
80
+ subscribeToRoom,
81
+ updateConfig,
82
+ handlers,
83
+ disconnect,
84
+ };
85
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@base44-preview/sdk",
3
- "version": "0.7.0-pr.26.ab75236",
3
+ "version": "0.7.0-pr.27.2a9d388",
4
4
  "description": "JavaScript SDK for Base44 API",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -19,7 +19,8 @@
19
19
  "prepublishOnly": "npm run build"
20
20
  },
21
21
  "dependencies": {
22
- "axios": "^1.6.2"
22
+ "axios": "^1.6.2",
23
+ "socket.io-client": "^4.7.5"
23
24
  },
24
25
  "devDependencies": {
25
26
  "@vitest/coverage-istanbul": "^1.0.0",