@blaxel/langgraph 0.2.36-dev.185 → 0.2.36-dev.190

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 (50) hide show
  1. package/dist/cjs/.tsbuildinfo +1 -0
  2. package/dist/{model → cjs/model}/google-genai/chat_models.js +13 -8
  3. package/dist/{model → cjs/model}/google-genai/output_parsers.js +1 -0
  4. package/dist/{model → cjs/model}/google-genai/utils/common.js +1 -0
  5. package/dist/cjs/telemetry.js +54 -0
  6. package/dist/{tools.js → cjs/tools.js} +3 -1
  7. package/dist/{model → cjs/types/model}/xai.d.ts +1 -1
  8. package/dist/{tools.d.ts → cjs/types/tools.d.ts} +3 -7
  9. package/dist/esm/.tsbuildinfo +1 -0
  10. package/dist/esm/index.js +3 -0
  11. package/dist/esm/model/cohere.js +168 -0
  12. package/dist/esm/model/google-genai/chat_models.js +756 -0
  13. package/dist/esm/model/google-genai/embeddings.js +107 -0
  14. package/dist/esm/model/google-genai/index.js +2 -0
  15. package/dist/esm/model/google-genai/output_parsers.js +47 -0
  16. package/dist/esm/model/google-genai/types.js +1 -0
  17. package/dist/esm/model/google-genai/utils/common.js +378 -0
  18. package/dist/esm/model/google-genai/utils/tools.js +107 -0
  19. package/dist/esm/model/google-genai/utils/zod_to_genai_parameters.js +41 -0
  20. package/dist/esm/model/google-genai.js +26 -0
  21. package/dist/esm/model/xai.js +78 -0
  22. package/dist/esm/model.js +137 -0
  23. package/dist/esm/package.json +1 -0
  24. package/dist/esm/telemetry.js +19 -0
  25. package/dist/esm/tools.js +22 -0
  26. package/package.json +16 -28
  27. package/dist/telemetry.js +0 -24
  28. /package/dist/{index.js → cjs/index.js} +0 -0
  29. /package/dist/{model → cjs/model}/cohere.js +0 -0
  30. /package/dist/{model → cjs/model}/google-genai/embeddings.js +0 -0
  31. /package/dist/{model → cjs/model}/google-genai/index.js +0 -0
  32. /package/dist/{model → cjs/model}/google-genai/types.js +0 -0
  33. /package/dist/{model → cjs/model}/google-genai/utils/tools.js +0 -0
  34. /package/dist/{model → cjs/model}/google-genai/utils/zod_to_genai_parameters.js +0 -0
  35. /package/dist/{model → cjs/model}/google-genai.js +0 -0
  36. /package/dist/{model → cjs/model}/xai.js +0 -0
  37. /package/dist/{model.js → cjs/model.js} +0 -0
  38. /package/dist/{index.d.ts → cjs/types/index.d.ts} +0 -0
  39. /package/dist/{model → cjs/types/model}/cohere.d.ts +0 -0
  40. /package/dist/{model → cjs/types/model}/google-genai/chat_models.d.ts +0 -0
  41. /package/dist/{model → cjs/types/model}/google-genai/embeddings.d.ts +0 -0
  42. /package/dist/{model → cjs/types/model}/google-genai/index.d.ts +0 -0
  43. /package/dist/{model → cjs/types/model}/google-genai/output_parsers.d.ts +0 -0
  44. /package/dist/{model → cjs/types/model}/google-genai/types.d.ts +0 -0
  45. /package/dist/{model → cjs/types/model}/google-genai/utils/common.d.ts +0 -0
  46. /package/dist/{model → cjs/types/model}/google-genai/utils/tools.d.ts +0 -0
  47. /package/dist/{model → cjs/types/model}/google-genai/utils/zod_to_genai_parameters.d.ts +0 -0
  48. /package/dist/{model → cjs/types/model}/google-genai.d.ts +0 -0
  49. /package/dist/{model.d.ts → cjs/types/model.d.ts} +0 -0
  50. /package/dist/{telemetry.d.ts → cjs/types/telemetry.d.ts} +0 -0
@@ -0,0 +1,3 @@
1
+ export * from "./model.js";
2
+ export * from "./tools.js";
3
+ import "./telemetry.js";
@@ -0,0 +1,168 @@
1
+ import { authenticate, settings } from "@blaxel/core";
2
+ /**
3
+ * Creates a custom fetcher for CohereClient that adds dynamic headers
4
+ * CohereClient's fetcher expects a function that intercepts fetch requests
5
+ */
6
+ export const createCohereFetcher = () => {
7
+ // Return a function that matches CohereClient's FetchFunction interface
8
+ const fetcher = async (args) => {
9
+ await authenticate();
10
+ const dynamicHeaders = settings.headers;
11
+ // Extract all fields from args
12
+ const { url, method, headers: argsHeaders, body, contentType, queryParameters, timeoutMs, withCredentials, abortSignal, requestType, responseType, duplex } = args;
13
+ // Build URL with query parameters
14
+ let requestUrl = url;
15
+ if (queryParameters) {
16
+ const params = new URLSearchParams();
17
+ Object.entries(queryParameters).forEach(([key, value]) => {
18
+ if (Array.isArray(value)) {
19
+ value.forEach(v => {
20
+ if (typeof v === 'object' && v !== null) {
21
+ params.append(key, JSON.stringify(v));
22
+ }
23
+ else {
24
+ params.append(key, String(v));
25
+ }
26
+ });
27
+ }
28
+ else if (typeof value === 'object' && value !== null) {
29
+ params.append(key, JSON.stringify(value));
30
+ }
31
+ else {
32
+ params.append(key, String(value));
33
+ }
34
+ });
35
+ const queryString = params.toString();
36
+ if (queryString) {
37
+ requestUrl += (url.includes('?') ? '&' : '?') + queryString;
38
+ }
39
+ }
40
+ // Merge headers and filter out undefined values
41
+ const mergedHeaders = {
42
+ ...(argsHeaders || {}),
43
+ ...dynamicHeaders,
44
+ };
45
+ // Add content-type if specified
46
+ if (contentType) {
47
+ mergedHeaders['Content-Type'] = contentType;
48
+ }
49
+ // Filter out undefined values
50
+ const headers = Object.entries(mergedHeaders).reduce((acc, [key, value]) => {
51
+ if (value !== undefined) {
52
+ acc[key] = value;
53
+ }
54
+ return acc;
55
+ }, {});
56
+ // Prepare body based on requestType
57
+ let requestBody;
58
+ if (body !== undefined) {
59
+ if (requestType === 'json' || !requestType) {
60
+ requestBody = JSON.stringify(body);
61
+ }
62
+ else if (requestType === 'bytes' && body instanceof Uint8Array) {
63
+ // Create a new ArrayBuffer from the Uint8Array to avoid SharedArrayBuffer issues
64
+ const arrayBuffer = new ArrayBuffer(body.length);
65
+ const view = new Uint8Array(arrayBuffer);
66
+ view.set(body);
67
+ requestBody = arrayBuffer;
68
+ }
69
+ else if (requestType === 'file' && body instanceof Blob) {
70
+ requestBody = body;
71
+ }
72
+ else if (typeof body === 'string') {
73
+ requestBody = body;
74
+ }
75
+ else {
76
+ requestBody = JSON.stringify(body);
77
+ }
78
+ }
79
+ try {
80
+ // Create abort controller for timeout
81
+ const controller = new AbortController();
82
+ let timeoutId;
83
+ if (timeoutMs) {
84
+ timeoutId = setTimeout(() => controller.abort(), timeoutMs);
85
+ }
86
+ // Merge abort signals
87
+ const signal = abortSignal
88
+ ? AbortSignal.any([abortSignal, controller.signal])
89
+ : controller.signal;
90
+ // Make the request with merged headers
91
+ const requestInit = {
92
+ method: method,
93
+ headers,
94
+ body: requestBody,
95
+ credentials: withCredentials ? 'include' : 'same-origin',
96
+ signal,
97
+ };
98
+ // Add duplex if specified (for streaming)
99
+ if (duplex) {
100
+ requestInit.duplex = duplex;
101
+ }
102
+ const response = await fetch(requestUrl, requestInit);
103
+ // Clear timeout
104
+ if (timeoutId) {
105
+ clearTimeout(timeoutId);
106
+ }
107
+ // Handle response based on responseType
108
+ let responseBody;
109
+ if (response.ok) {
110
+ if (responseType === 'blob') {
111
+ responseBody = await response.blob();
112
+ }
113
+ else if (responseType === 'text') {
114
+ responseBody = await response.text();
115
+ }
116
+ else if (responseType === 'arrayBuffer') {
117
+ responseBody = await response.arrayBuffer();
118
+ }
119
+ else if (responseType === 'streaming' || responseType === 'sse') {
120
+ // For streaming, return the response body stream
121
+ responseBody = response.body;
122
+ }
123
+ else {
124
+ // Default to JSON
125
+ responseBody = await response.json();
126
+ }
127
+ // Return success response in the format CohereClient expects
128
+ return {
129
+ ok: true,
130
+ body: responseBody,
131
+ headers: Object.fromEntries(response.headers.entries()),
132
+ };
133
+ }
134
+ else {
135
+ // Return error response in the format CohereClient expects
136
+ const errorBody = await response.text();
137
+ return {
138
+ ok: false,
139
+ error: {
140
+ reason: "status-code",
141
+ statusCode: response.status,
142
+ body: errorBody,
143
+ },
144
+ };
145
+ }
146
+ }
147
+ catch (error) {
148
+ // Check if it's a timeout error
149
+ if (error instanceof Error && error.name === 'AbortError') {
150
+ return {
151
+ ok: false,
152
+ error: {
153
+ reason: "timeout",
154
+ },
155
+ };
156
+ }
157
+ // Return unknown error
158
+ return {
159
+ ok: false,
160
+ error: {
161
+ reason: "unknown",
162
+ errorMessage: error instanceof Error ? error.message : String(error),
163
+ },
164
+ };
165
+ }
166
+ };
167
+ return fetcher;
168
+ };