@node-llm/core 1.5.2 → 1.6.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/README.md +84 -110
- package/dist/aliases.js +239 -239
- package/dist/chat/Chat.d.ts +18 -17
- package/dist/chat/Chat.d.ts.map +1 -1
- package/dist/chat/Chat.js +63 -42
- package/dist/chat/ChatOptions.d.ts +8 -9
- package/dist/chat/ChatOptions.d.ts.map +1 -1
- package/dist/chat/ChatResponse.d.ts +1 -1
- package/dist/chat/ChatResponse.d.ts.map +1 -1
- package/dist/chat/ChatResponse.js +22 -8
- package/dist/chat/ChatStream.d.ts.map +1 -1
- package/dist/chat/ChatStream.js +16 -22
- package/dist/chat/Content.d.ts +3 -3
- package/dist/chat/Content.d.ts.map +1 -1
- package/dist/chat/Content.js +3 -6
- package/dist/chat/Message.d.ts +3 -1
- package/dist/chat/Message.d.ts.map +1 -1
- package/dist/chat/Role.d.ts.map +1 -1
- package/dist/chat/Tool.d.ts +15 -15
- package/dist/chat/Tool.d.ts.map +1 -1
- package/dist/chat/Tool.js +9 -7
- package/dist/chat/ToolHandler.d.ts +4 -3
- package/dist/chat/ToolHandler.d.ts.map +1 -1
- package/dist/chat/ToolHandler.js +10 -14
- package/dist/chat/Validation.d.ts.map +1 -1
- package/dist/chat/Validation.js +13 -6
- package/dist/config.d.ts +4 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +80 -25
- package/dist/constants.js +1 -1
- package/dist/errors/index.d.ts +21 -7
- package/dist/errors/index.d.ts.map +1 -1
- package/dist/errors/index.js +14 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/llm.d.ts +44 -46
- package/dist/llm.d.ts.map +1 -1
- package/dist/llm.js +206 -134
- package/dist/model_aliases.d.ts.map +1 -1
- package/dist/models/ModelRegistry.d.ts.map +1 -1
- package/dist/models/ModelRegistry.js +12 -10
- package/dist/models/PricingRegistry.d.ts +31 -0
- package/dist/models/PricingRegistry.d.ts.map +1 -0
- package/dist/models/PricingRegistry.js +101 -0
- package/dist/models/models.d.ts.map +1 -1
- package/dist/models/models.js +5954 -7352
- package/dist/models/types.d.ts +37 -34
- package/dist/models/types.d.ts.map +1 -1
- package/dist/moderation/Moderation.d.ts.map +1 -1
- package/dist/moderation/Moderation.js +15 -5
- package/dist/providers/BaseProvider.d.ts +12 -8
- package/dist/providers/BaseProvider.d.ts.map +1 -1
- package/dist/providers/BaseProvider.js +17 -7
- package/dist/providers/Provider.d.ts +20 -5
- package/dist/providers/Provider.d.ts.map +1 -1
- package/dist/providers/anthropic/AnthropicProvider.d.ts +1 -1
- package/dist/providers/anthropic/AnthropicProvider.d.ts.map +1 -1
- package/dist/providers/anthropic/AnthropicProvider.js +3 -3
- package/dist/providers/anthropic/Capabilities.d.ts +2 -1
- package/dist/providers/anthropic/Capabilities.d.ts.map +1 -1
- package/dist/providers/anthropic/Capabilities.js +3 -20
- package/dist/providers/anthropic/Chat.d.ts.map +1 -1
- package/dist/providers/anthropic/Chat.js +27 -17
- package/dist/providers/anthropic/Errors.d.ts.map +1 -1
- package/dist/providers/anthropic/Errors.js +5 -2
- package/dist/providers/anthropic/Models.d.ts.map +1 -1
- package/dist/providers/anthropic/Models.js +6 -6
- package/dist/providers/anthropic/Streaming.d.ts.map +1 -1
- package/dist/providers/anthropic/Streaming.js +17 -12
- package/dist/providers/anthropic/Utils.js +8 -5
- package/dist/providers/anthropic/index.d.ts.map +1 -1
- package/dist/providers/anthropic/index.js +4 -3
- package/dist/providers/anthropic/types.d.ts +11 -4
- package/dist/providers/anthropic/types.d.ts.map +1 -1
- package/dist/providers/deepseek/Capabilities.d.ts +7 -5
- package/dist/providers/deepseek/Capabilities.d.ts.map +1 -1
- package/dist/providers/deepseek/Capabilities.js +9 -5
- package/dist/providers/deepseek/Chat.d.ts.map +1 -1
- package/dist/providers/deepseek/Chat.js +10 -9
- package/dist/providers/deepseek/DeepSeekProvider.d.ts +1 -1
- package/dist/providers/deepseek/DeepSeekProvider.d.ts.map +1 -1
- package/dist/providers/deepseek/DeepSeekProvider.js +4 -4
- package/dist/providers/deepseek/Models.d.ts.map +1 -1
- package/dist/providers/deepseek/Models.js +7 -7
- package/dist/providers/deepseek/Streaming.d.ts.map +1 -1
- package/dist/providers/deepseek/Streaming.js +11 -8
- package/dist/providers/deepseek/index.d.ts.map +1 -1
- package/dist/providers/deepseek/index.js +5 -4
- package/dist/providers/gemini/Capabilities.d.ts +5 -33
- package/dist/providers/gemini/Capabilities.d.ts.map +1 -1
- package/dist/providers/gemini/Capabilities.js +7 -30
- package/dist/providers/gemini/Chat.d.ts.map +1 -1
- package/dist/providers/gemini/Chat.js +24 -19
- package/dist/providers/gemini/ChatUtils.d.ts.map +1 -1
- package/dist/providers/gemini/ChatUtils.js +10 -10
- package/dist/providers/gemini/Embeddings.d.ts.map +1 -1
- package/dist/providers/gemini/Embeddings.js +2 -2
- package/dist/providers/gemini/Errors.d.ts.map +1 -1
- package/dist/providers/gemini/Errors.js +5 -2
- package/dist/providers/gemini/GeminiProvider.d.ts +1 -1
- package/dist/providers/gemini/GeminiProvider.d.ts.map +1 -1
- package/dist/providers/gemini/GeminiProvider.js +3 -3
- package/dist/providers/gemini/Image.d.ts.map +1 -1
- package/dist/providers/gemini/Image.js +8 -8
- package/dist/providers/gemini/Models.d.ts.map +1 -1
- package/dist/providers/gemini/Models.js +6 -6
- package/dist/providers/gemini/Streaming.d.ts.map +1 -1
- package/dist/providers/gemini/Streaming.js +18 -14
- package/dist/providers/gemini/Transcription.d.ts.map +1 -1
- package/dist/providers/gemini/Transcription.js +11 -11
- package/dist/providers/gemini/index.d.ts +1 -1
- package/dist/providers/gemini/index.d.ts.map +1 -1
- package/dist/providers/gemini/index.js +5 -4
- package/dist/providers/gemini/types.d.ts +4 -4
- package/dist/providers/gemini/types.d.ts.map +1 -1
- package/dist/providers/ollama/Capabilities.d.ts.map +1 -1
- package/dist/providers/ollama/Capabilities.js +6 -2
- package/dist/providers/ollama/Models.js +1 -1
- package/dist/providers/ollama/OllamaProvider.d.ts +1 -1
- package/dist/providers/ollama/OllamaProvider.d.ts.map +1 -1
- package/dist/providers/ollama/OllamaProvider.js +2 -2
- package/dist/providers/ollama/index.d.ts +1 -1
- package/dist/providers/ollama/index.d.ts.map +1 -1
- package/dist/providers/ollama/index.js +7 -3
- package/dist/providers/openai/Capabilities.d.ts +2 -1
- package/dist/providers/openai/Capabilities.d.ts.map +1 -1
- package/dist/providers/openai/Capabilities.js +9 -21
- package/dist/providers/openai/Chat.d.ts.map +1 -1
- package/dist/providers/openai/Chat.js +18 -14
- package/dist/providers/openai/Embedding.d.ts.map +1 -1
- package/dist/providers/openai/Embedding.js +11 -7
- package/dist/providers/openai/Errors.d.ts.map +1 -1
- package/dist/providers/openai/Errors.js +5 -2
- package/dist/providers/openai/Image.d.ts.map +1 -1
- package/dist/providers/openai/Image.js +6 -6
- package/dist/providers/openai/Models.d.ts +1 -1
- package/dist/providers/openai/Models.d.ts.map +1 -1
- package/dist/providers/openai/Models.js +12 -8
- package/dist/providers/openai/Moderation.d.ts.map +1 -1
- package/dist/providers/openai/Moderation.js +6 -6
- package/dist/providers/openai/OpenAIProvider.d.ts +2 -3
- package/dist/providers/openai/OpenAIProvider.d.ts.map +1 -1
- package/dist/providers/openai/OpenAIProvider.js +4 -4
- package/dist/providers/openai/Streaming.d.ts.map +1 -1
- package/dist/providers/openai/Streaming.js +18 -13
- package/dist/providers/openai/Transcription.d.ts.map +1 -1
- package/dist/providers/openai/Transcription.js +15 -12
- package/dist/providers/openai/index.d.ts +1 -1
- package/dist/providers/openai/index.d.ts.map +1 -1
- package/dist/providers/openai/index.js +6 -5
- package/dist/providers/openai/types.d.ts +1 -1
- package/dist/providers/openai/utils.js +2 -2
- package/dist/providers/openrouter/Capabilities.d.ts +3 -3
- package/dist/providers/openrouter/Capabilities.d.ts.map +1 -1
- package/dist/providers/openrouter/Capabilities.js +21 -24
- package/dist/providers/openrouter/Models.d.ts.map +1 -1
- package/dist/providers/openrouter/Models.js +20 -16
- package/dist/providers/openrouter/OpenRouterProvider.d.ts.map +1 -1
- package/dist/providers/openrouter/OpenRouterProvider.js +1 -1
- package/dist/providers/openrouter/index.d.ts +1 -1
- package/dist/providers/openrouter/index.d.ts.map +1 -1
- package/dist/providers/openrouter/index.js +6 -5
- package/dist/providers/registry.d.ts +18 -2
- package/dist/providers/registry.d.ts.map +1 -1
- package/dist/providers/registry.js +17 -2
- package/dist/providers/utils.js +1 -1
- package/dist/schema/Schema.d.ts +3 -3
- package/dist/schema/Schema.d.ts.map +1 -1
- package/dist/schema/Schema.js +2 -2
- package/dist/schema/to-json-schema.d.ts +1 -1
- package/dist/schema/to-json-schema.d.ts.map +1 -1
- package/dist/streaming/Stream.d.ts.map +1 -1
- package/dist/streaming/Stream.js +3 -3
- package/dist/utils/Binary.d.ts.map +1 -1
- package/dist/utils/Binary.js +32 -23
- package/dist/utils/FileLoader.d.ts.map +1 -1
- package/dist/utils/FileLoader.js +25 -4
- package/dist/utils/audio.js +2 -2
- package/dist/utils/fetch.d.ts.map +1 -1
- package/dist/utils/fetch.js +14 -4
- package/dist/utils/logger.d.ts +3 -3
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +2 -2
- package/package.json +1 -1
package/dist/utils/Binary.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import fs from "fs";
|
|
2
2
|
import path from "path";
|
|
3
|
+
import { logger } from "./logger.js";
|
|
3
4
|
export class BinaryUtils {
|
|
4
5
|
/**
|
|
5
6
|
* Converts a URL (data:, http:, or local path) to a base64 string and mime type.
|
|
@@ -10,7 +11,7 @@ export class BinaryUtils {
|
|
|
10
11
|
if (match && match[1] && match[2]) {
|
|
11
12
|
return {
|
|
12
13
|
mimeType: match[1],
|
|
13
|
-
data: match[2]
|
|
14
|
+
data: match[2]
|
|
14
15
|
};
|
|
15
16
|
}
|
|
16
17
|
}
|
|
@@ -24,29 +25,27 @@ export class BinaryUtils {
|
|
|
24
25
|
const mimeType = response.headers.get("content-type") || this.guessMimeType(url);
|
|
25
26
|
return {
|
|
26
27
|
mimeType,
|
|
27
|
-
data: base64
|
|
28
|
+
data: base64
|
|
28
29
|
};
|
|
29
30
|
}
|
|
30
31
|
catch (e) {
|
|
31
|
-
|
|
32
|
+
logger.error("Error converting URL to base64:", e);
|
|
32
33
|
return null;
|
|
33
34
|
}
|
|
34
35
|
}
|
|
35
36
|
else {
|
|
36
37
|
// Assume local file path
|
|
37
38
|
try {
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
};
|
|
46
|
-
}
|
|
39
|
+
const buffer = await fs.promises.readFile(url);
|
|
40
|
+
const base64 = buffer.toString("base64");
|
|
41
|
+
const mimeType = this.guessMimeType(url);
|
|
42
|
+
return {
|
|
43
|
+
mimeType,
|
|
44
|
+
data: base64
|
|
45
|
+
};
|
|
47
46
|
}
|
|
48
47
|
catch (e) {
|
|
49
|
-
|
|
48
|
+
logger.error("Error reading local file for base64:", e);
|
|
50
49
|
return null;
|
|
51
50
|
}
|
|
52
51
|
}
|
|
@@ -55,17 +54,27 @@ export class BinaryUtils {
|
|
|
55
54
|
static guessMimeType(filePath) {
|
|
56
55
|
const ext = path.extname(filePath).toLowerCase();
|
|
57
56
|
switch (ext) {
|
|
58
|
-
case ".png":
|
|
57
|
+
case ".png":
|
|
58
|
+
return "image/png";
|
|
59
59
|
case ".jpg":
|
|
60
|
-
case ".jpeg":
|
|
61
|
-
|
|
62
|
-
case ".
|
|
63
|
-
|
|
64
|
-
case ".
|
|
65
|
-
|
|
66
|
-
case ".
|
|
67
|
-
|
|
68
|
-
|
|
60
|
+
case ".jpeg":
|
|
61
|
+
return "image/jpeg";
|
|
62
|
+
case ".webp":
|
|
63
|
+
return "image/webp";
|
|
64
|
+
case ".gif":
|
|
65
|
+
return "image/gif";
|
|
66
|
+
case ".mp3":
|
|
67
|
+
return "audio/mpeg";
|
|
68
|
+
case ".wav":
|
|
69
|
+
return "audio/wav";
|
|
70
|
+
case ".ogg":
|
|
71
|
+
return "audio/ogg";
|
|
72
|
+
case ".m4a":
|
|
73
|
+
return "audio/mp4";
|
|
74
|
+
case ".pdf":
|
|
75
|
+
return "application/pdf";
|
|
76
|
+
default:
|
|
77
|
+
return "application/octet-stream";
|
|
69
78
|
}
|
|
70
79
|
}
|
|
71
80
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FileLoader.d.ts","sourceRoot":"","sources":["../../src/utils/FileLoader.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"FileLoader.d.ts","sourceRoot":"","sources":["../../src/utils/FileLoader.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAgEjD,qBAAa,UAAU;WACR,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;CAmF1D"}
|
package/dist/utils/FileLoader.js
CHANGED
|
@@ -33,11 +33,32 @@ const MIME_TYPES = {
|
|
|
33
33
|
".rs": "text/x-rust",
|
|
34
34
|
".swift": "text/x-swift",
|
|
35
35
|
".kt": "text/x-kotlin",
|
|
36
|
-
".pdf": "application/pdf"
|
|
36
|
+
".pdf": "application/pdf"
|
|
37
37
|
};
|
|
38
38
|
const TEXT_EXTENSIONS = new Set([
|
|
39
|
-
".json",
|
|
40
|
-
".
|
|
39
|
+
".json",
|
|
40
|
+
".js",
|
|
41
|
+
".mjs",
|
|
42
|
+
".cjs",
|
|
43
|
+
".ts",
|
|
44
|
+
".rb",
|
|
45
|
+
".py",
|
|
46
|
+
".txt",
|
|
47
|
+
".md",
|
|
48
|
+
".html",
|
|
49
|
+
".css",
|
|
50
|
+
".xml",
|
|
51
|
+
".yml",
|
|
52
|
+
".yaml",
|
|
53
|
+
".env",
|
|
54
|
+
".csv",
|
|
55
|
+
".go",
|
|
56
|
+
".java",
|
|
57
|
+
".c",
|
|
58
|
+
".cpp",
|
|
59
|
+
".rs",
|
|
60
|
+
".swift",
|
|
61
|
+
".kt"
|
|
41
62
|
]);
|
|
42
63
|
export class FileLoader {
|
|
43
64
|
static async load(filePath) {
|
|
@@ -70,7 +91,7 @@ export class FileLoader {
|
|
|
70
91
|
// Default to image_url for unknown binary or use as-is
|
|
71
92
|
return { type: "image_url", image_url: { url: dataUri } };
|
|
72
93
|
}
|
|
73
|
-
catch
|
|
94
|
+
catch {
|
|
74
95
|
// Fallback to URL if fetch fails
|
|
75
96
|
return { type: "image_url", image_url: { url: filePath } };
|
|
76
97
|
}
|
package/dist/utils/audio.js
CHANGED
|
@@ -15,7 +15,7 @@ export class AudioUtils {
|
|
|
15
15
|
fileName = path.basename(urlPath) || "audio.mp3";
|
|
16
16
|
}
|
|
17
17
|
else {
|
|
18
|
-
const buffer = fs.
|
|
18
|
+
const buffer = await fs.promises.readFile(filePath);
|
|
19
19
|
data = new Uint8Array(buffer);
|
|
20
20
|
fileName = path.basename(filePath);
|
|
21
21
|
}
|
|
@@ -38,7 +38,7 @@ export class AudioUtils {
|
|
|
38
38
|
return data.length / (128000 / 8);
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
|
-
catch
|
|
41
|
+
catch {
|
|
42
42
|
// Ignore estimation errors
|
|
43
43
|
}
|
|
44
44
|
return undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/utils/fetch.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,wBAAsB,gBAAgB,CACpC,GAAG,EAAE,MAAM,EACX,OAAO,GAAE,WAAgB,EACzB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/utils/fetch.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,wBAAsB,gBAAgB,CACpC,GAAG,EAAE,MAAM,EACX,OAAO,GAAE,WAAgB,EACzB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,QAAQ,CAAC,CAwCnB"}
|
package/dist/utils/fetch.js
CHANGED
|
@@ -9,7 +9,12 @@
|
|
|
9
9
|
* @throws Error if the request times out
|
|
10
10
|
*/
|
|
11
11
|
export async function fetchWithTimeout(url, options = {}, timeoutMs) {
|
|
12
|
-
|
|
12
|
+
const userSignal = options.signal;
|
|
13
|
+
// If no timeout is specified and no user signal, use standard fetch
|
|
14
|
+
if ((!timeoutMs || timeoutMs <= 0) && !userSignal) {
|
|
15
|
+
return fetch(url, options);
|
|
16
|
+
}
|
|
17
|
+
// If only user signal (no timeout), use it directly
|
|
13
18
|
if (!timeoutMs || timeoutMs <= 0) {
|
|
14
19
|
return fetch(url, options);
|
|
15
20
|
}
|
|
@@ -18,17 +23,22 @@ export async function fetchWithTimeout(url, options = {}, timeoutMs) {
|
|
|
18
23
|
if (timeoutId.unref)
|
|
19
24
|
timeoutId.unref();
|
|
20
25
|
try {
|
|
26
|
+
// Merge user signal with timeout signal
|
|
27
|
+
const mergedSignal = userSignal
|
|
28
|
+
? AbortSignal.any([userSignal, controller.signal])
|
|
29
|
+
: controller.signal;
|
|
21
30
|
const response = await fetch(url, {
|
|
22
31
|
...options,
|
|
23
|
-
signal:
|
|
32
|
+
signal: mergedSignal
|
|
24
33
|
});
|
|
25
34
|
clearTimeout(timeoutId);
|
|
26
35
|
return response;
|
|
27
36
|
}
|
|
28
37
|
catch (error) {
|
|
29
38
|
clearTimeout(timeoutId);
|
|
30
|
-
// Check if the error was due to abort
|
|
31
|
-
|
|
39
|
+
// Check if the error was due to timeout abort
|
|
40
|
+
const isAbortError = error instanceof Error && error.name === "AbortError";
|
|
41
|
+
if (isAbortError && controller.signal.aborted) {
|
|
32
42
|
throw new Error(`Request timeout after ${timeoutMs}ms`);
|
|
33
43
|
}
|
|
34
44
|
throw error;
|
package/dist/utils/logger.d.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
declare class Logger {
|
|
2
2
|
private isDebugEnabled;
|
|
3
|
-
debug(message: string, data?:
|
|
3
|
+
debug(message: string, data?: unknown): void;
|
|
4
4
|
/**
|
|
5
5
|
* Log HTTP request details for debugging
|
|
6
6
|
*/
|
|
7
|
-
logRequest(provider: string, method: string, url: string, body?:
|
|
7
|
+
logRequest(provider: string, method: string, url: string, body?: unknown): void;
|
|
8
8
|
/**
|
|
9
9
|
* Log HTTP response details for debugging
|
|
10
10
|
*/
|
|
11
|
-
logResponse(provider: string, status: number, statusText: string, body?:
|
|
11
|
+
logResponse(provider: string, status: number, statusText: string, body?: unknown): void;
|
|
12
12
|
warn(message: string): void;
|
|
13
13
|
error(message: string, error?: Error): void;
|
|
14
14
|
info(message: string): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAEA,cAAM,MAAM;IACV,OAAO,CAAC,cAAc;IAItB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAEA,cAAM,MAAM;IACV,OAAO,CAAC,cAAc;IAItB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAO5C;;OAEG;IACH,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAS/E;;OAEG;IACH,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IASvF,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAI3B,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI;IAI3C,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;CAG5B;AAED,eAAO,MAAM,MAAM,QAAe,CAAC"}
|
package/dist/utils/logger.js
CHANGED
|
@@ -5,7 +5,7 @@ class Logger {
|
|
|
5
5
|
}
|
|
6
6
|
debug(message, data) {
|
|
7
7
|
if (this.isDebugEnabled()) {
|
|
8
|
-
const formattedData = data ? `\n${JSON.stringify(data, null, 2)}` :
|
|
8
|
+
const formattedData = data ? `\n${JSON.stringify(data, null, 2)}` : "";
|
|
9
9
|
console.log(`[NodeLLM Debug] ${message}${formattedData}`);
|
|
10
10
|
}
|
|
11
11
|
}
|
|
@@ -35,7 +35,7 @@ class Logger {
|
|
|
35
35
|
console.warn(`[NodeLLM] ${message}`);
|
|
36
36
|
}
|
|
37
37
|
error(message, error) {
|
|
38
|
-
console.error(`[NodeLLM Error] ${message}`, error ||
|
|
38
|
+
console.error(`[NodeLLM Error] ${message}`, error || "");
|
|
39
39
|
}
|
|
40
40
|
info(message) {
|
|
41
41
|
console.log(`[NodeLLM] ${message}`);
|