@luanpoppe/ai 1.1.2 → 1.1.4
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/@types/image.d.ts +4 -0
- package/dist/@types/image.d.ts.map +1 -0
- package/dist/@types/image.js +10 -0
- package/dist/@types/image.js.map +1 -0
- package/dist/ai.d.ts +1 -1
- package/dist/ai.d.ts.map +1 -1
- package/dist/ai.js +9 -3
- package/dist/ai.js.map +1 -1
- package/dist/index.d.ts +6 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -3
- package/dist/index.js.map +1 -1
- package/dist/langchain/memory.d.ts +96 -0
- package/dist/langchain/memory.d.ts.map +1 -0
- package/dist/langchain/memory.js +268 -0
- package/dist/langchain/memory.js.map +1 -0
- package/dist/langchain/messages.d.ts +17 -0
- package/dist/langchain/messages.d.ts.map +1 -1
- package/dist/langchain/messages.js +21 -0
- package/dist/langchain/messages.js.map +1 -1
- package/dist/langchain/models.d.ts +4 -0
- package/dist/langchain/models.d.ts.map +1 -1
- package/dist/langchain/models.js +14 -2
- package/dist/langchain/models.js.map +1 -1
- package/dist/utils/image-utils.d.ts +8 -0
- package/dist/utils/image-utils.d.ts.map +1 -0
- package/dist/utils/image-utils.js +91 -0
- package/dist/utils/image-utils.js.map +1 -0
- package/package.json +1 -1
- package/src/@types/image.ts +14 -0
- package/src/ai.ts +317 -306
- package/src/index.ts +7 -2
- package/src/langchain/{checkpointers.ts → memory.ts} +48 -22
- package/src/langchain/messages.ts +47 -0
- package/src/langchain/models.ts +19 -2
- package/src/utils/image-utils.ts +113 -0
- package/tests/e2e/@fixtures/imagem-teste-bateria.jpg +0 -0
- package/tests/e2e/ai-audio.test.ts +3 -3
- package/tests/e2e/ai-image.test.ts +173 -0
- package/tests/e2e/ai.test.ts +96 -4
- package/tests/unit/index.test.ts +98 -3
- package/tests/unit/langchain/checkpointers.test.ts +72 -5
- package/tests/unit/langchain/image-utils.test.ts +127 -0
- package/tests/unit/langchain/messages.test.ts +78 -0
- package/tests/unit/langchain/models.test.ts +16 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../src/langchain/messages.ts"],"names":[],"mappings":";;;AAAA,yCAAmE;AACnE,sDAAkD;
|
|
1
|
+
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../src/langchain/messages.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import { ChatGoogleGenerativeAI } from "@langchain/google-genai";
|
|
2
2
|
import { ChatOpenAI } from "@langchain/openai";
|
|
3
|
+
/** Nível de esforço de raciocínio para modelos OpenAI (o1, gpt-5, etc.). Valores: "low" | "medium" | "high" */
|
|
4
|
+
export type ReasoningEffort = "low" | "medium" | "high";
|
|
3
5
|
export type LLMModelConfig = {
|
|
4
6
|
model: string;
|
|
5
7
|
apiKey?: string | undefined;
|
|
6
8
|
maxTokens?: number | undefined;
|
|
7
9
|
temperature?: number | undefined;
|
|
10
|
+
/** Nível de esforço de raciocínio (modelos OpenAI: o1, gpt-5, etc.) */
|
|
11
|
+
reasoningEffort?: ReasoningEffort | undefined;
|
|
8
12
|
};
|
|
9
13
|
export declare class AIModels {
|
|
10
14
|
static gpt(params: LLMModelConfig): ChatOpenAI<import("@langchain/openai").ChatOpenAICallOptions>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.d.ts","sourceRoot":"","sources":["../../src/langchain/models.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAEvB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAoB,MAAM,mBAAmB,CAAC;AAEjE,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC/B,WAAW,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"models.d.ts","sourceRoot":"","sources":["../../src/langchain/models.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAEvB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,UAAU,EAAoB,MAAM,mBAAmB,CAAC;AAEjE,+GAA+G;AAC/G,MAAM,MAAM,eAAe,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC;AAExD,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC/B,WAAW,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACjC,uEAAuE;IACvE,eAAe,CAAC,EAAE,eAAe,GAAG,SAAS,CAAC;CAC/C,CAAC;AAEF,qBAAa,QAAQ;IACnB,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,cAAc;IAsBjC,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,cAAc;IAmBpC,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,cAAc;CA2BzC"}
|
package/dist/langchain/models.js
CHANGED
|
@@ -5,7 +5,7 @@ const google_genai_1 = require("@langchain/google-genai");
|
|
|
5
5
|
const openai_1 = require("@langchain/openai");
|
|
6
6
|
class AIModels {
|
|
7
7
|
static gpt(params) {
|
|
8
|
-
const { model, apiKey, maxTokens, temperature } = params;
|
|
8
|
+
const { model, apiKey, maxTokens, temperature, reasoningEffort } = params;
|
|
9
9
|
if (!apiKey)
|
|
10
10
|
throw new Error("OpenAI API key is not passed in the model parameters");
|
|
11
11
|
const options = {
|
|
@@ -16,6 +16,12 @@ class AIModels {
|
|
|
16
16
|
options.maxTokens = maxTokens;
|
|
17
17
|
if (temperature)
|
|
18
18
|
options.temperature = temperature;
|
|
19
|
+
if (reasoningEffort) {
|
|
20
|
+
options.modelKwargs = {
|
|
21
|
+
...(options.modelKwargs ?? {}),
|
|
22
|
+
reasoning_effort: reasoningEffort,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
19
25
|
return new openai_1.ChatOpenAI(options);
|
|
20
26
|
}
|
|
21
27
|
static gemini(params) {
|
|
@@ -33,7 +39,7 @@ class AIModels {
|
|
|
33
39
|
return new google_genai_1.ChatGoogleGenerativeAI(options);
|
|
34
40
|
}
|
|
35
41
|
static openrouter(params) {
|
|
36
|
-
const { apiKey, maxTokens, model, temperature } = params;
|
|
42
|
+
const { apiKey, maxTokens, model, temperature, reasoningEffort } = params;
|
|
37
43
|
if (!apiKey)
|
|
38
44
|
throw new Error("OpenRouter API key is not passed in the model parameters");
|
|
39
45
|
const options = {
|
|
@@ -47,6 +53,12 @@ class AIModels {
|
|
|
47
53
|
options.maxTokens = maxTokens;
|
|
48
54
|
if (temperature)
|
|
49
55
|
options.temperature = temperature;
|
|
56
|
+
if (reasoningEffort) {
|
|
57
|
+
options.modelKwargs = {
|
|
58
|
+
...(options.modelKwargs ?? {}),
|
|
59
|
+
reasoning_effort: reasoningEffort,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
50
62
|
return new openai_1.ChatOpenAI(options);
|
|
51
63
|
}
|
|
52
64
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/langchain/models.ts"],"names":[],"mappings":";;;AAAA,0DAGiC;AACjC,8CAAiE;
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/langchain/models.ts"],"names":[],"mappings":";;;AAAA,0DAGiC;AACjC,8CAAiE;AAcjE,MAAa,QAAQ;IACnB,MAAM,CAAC,GAAG,CAAC,MAAsB;QAC/B,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,MAAM,CAAC;QAC1E,IAAI,CAAC,MAAM;YACT,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAE1E,MAAM,OAAO,GAAqB;YAChC,KAAK;YACL,MAAM;SACP,CAAC;QAEF,IAAI,SAAS;YAAE,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;QAC7C,IAAI,WAAW;YAAE,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC;QACnD,IAAI,eAAe,EAAE,CAAC;YACpB,OAAO,CAAC,WAAW,GAAG;gBACpB,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;gBAC9B,gBAAgB,EAAE,eAAe;aAClC,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,mBAAU,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,MAAM,CAAC,MAAM,CAAC,MAAsB;QAClC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,MAAM,CAAC;QAEzD,IAAI,CAAC,MAAM;YACT,MAAM,IAAI,KAAK,CACb,6DAA6D,CAC9D,CAAC;QAEJ,MAAM,OAAO,GAAgC;YAC3C,KAAK;YACL,MAAM;SACP,CAAC;QAEF,IAAI,SAAS;YAAE,OAAO,CAAC,eAAe,GAAG,SAAS,CAAC;QACnD,IAAI,WAAW;YAAE,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC;QAEnD,OAAO,IAAI,qCAAsB,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,CAAC,UAAU,CAAC,MAAsB;QACtC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,MAAM,CAAC;QAE1E,IAAI,CAAC,MAAM;YACT,MAAM,IAAI,KAAK,CACb,0DAA0D,CAC3D,CAAC;QAEJ,MAAM,OAAO,GAAqB;YAChC,KAAK;YACL,MAAM;YACN,aAAa,EAAE;gBACb,OAAO,EAAE,8BAA8B;aACxC;SACF,CAAC;QAEF,IAAI,SAAS;YAAE,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;QAC7C,IAAI,WAAW;YAAE,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC;QACnD,IAAI,eAAe,EAAE,CAAC;YACpB,OAAO,CAAC,WAAW,GAAG;gBACpB,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;gBAC9B,gBAAgB,EAAE,eAAe;aAClC,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,mBAAU,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;CACF;AArED,4BAqEC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ImageBuffer, ImageMimeType } from "../@types/image";
|
|
2
|
+
export declare class ImageUtils {
|
|
3
|
+
static bufferToBase64(buffer: ImageBuffer): string;
|
|
4
|
+
static detectMimeTypeFromExtension(filename?: string): ImageMimeType | null;
|
|
5
|
+
static detectMimeTypeFromBuffer(buffer: ImageBuffer): ImageMimeType | null;
|
|
6
|
+
static detectImageMimeType(buffer: ImageBuffer, filename?: string): ImageMimeType;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=image-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image-utils.d.ts","sourceRoot":"","sources":["../../src/utils/image-utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAElE,qBAAa,UAAU;IACrB,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,GAAG,MAAM;IAiBlD,MAAM,CAAC,2BAA2B,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI;IAkB3E,MAAM,CAAC,wBAAwB,CAAC,MAAM,EAAE,WAAW,GAAG,aAAa,GAAG,IAAI;IAyD1E,MAAM,CAAC,mBAAmB,CACxB,MAAM,EAAE,WAAW,EACnB,QAAQ,CAAC,EAAE,MAAM,GAChB,aAAa;CAcjB"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ImageUtils = void 0;
|
|
4
|
+
class ImageUtils {
|
|
5
|
+
static bufferToBase64(buffer) {
|
|
6
|
+
if (buffer instanceof Buffer) {
|
|
7
|
+
return buffer.toString("base64");
|
|
8
|
+
}
|
|
9
|
+
if (buffer instanceof ArrayBuffer) {
|
|
10
|
+
const uint8Array = new Uint8Array(buffer);
|
|
11
|
+
return Buffer.from(uint8Array).toString("base64");
|
|
12
|
+
}
|
|
13
|
+
if (buffer instanceof Uint8Array) {
|
|
14
|
+
return Buffer.from(buffer).toString("base64");
|
|
15
|
+
}
|
|
16
|
+
throw new Error("Tipo de buffer não suportado");
|
|
17
|
+
}
|
|
18
|
+
static detectMimeTypeFromExtension(filename) {
|
|
19
|
+
if (!filename) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
const extension = filename.toLowerCase().split(".").pop();
|
|
23
|
+
const mimeTypeMap = {
|
|
24
|
+
jpg: "image/jpeg",
|
|
25
|
+
jpeg: "image/jpeg",
|
|
26
|
+
png: "image/png",
|
|
27
|
+
gif: "image/gif",
|
|
28
|
+
webp: "image/webp",
|
|
29
|
+
};
|
|
30
|
+
return extension ? mimeTypeMap[extension] ?? null : null;
|
|
31
|
+
}
|
|
32
|
+
static detectMimeTypeFromBuffer(buffer) {
|
|
33
|
+
let bytes;
|
|
34
|
+
if (buffer instanceof Buffer) {
|
|
35
|
+
bytes = new Uint8Array(buffer.slice(0, 16));
|
|
36
|
+
}
|
|
37
|
+
else if (buffer instanceof ArrayBuffer) {
|
|
38
|
+
bytes = new Uint8Array(buffer.slice(0, 16));
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
bytes = buffer.slice(0, 16);
|
|
42
|
+
}
|
|
43
|
+
// JPEG: FF D8 FF
|
|
44
|
+
if (bytes[0] === 0xff && bytes[1] === 0xd8 && bytes[2] === 0xff) {
|
|
45
|
+
return "image/jpeg";
|
|
46
|
+
}
|
|
47
|
+
// PNG: 89 50 4E 47 0D 0A 1A 0A
|
|
48
|
+
if (bytes[0] === 0x89 &&
|
|
49
|
+
bytes[1] === 0x50 &&
|
|
50
|
+
bytes[2] === 0x4e &&
|
|
51
|
+
bytes[3] === 0x47 &&
|
|
52
|
+
bytes[4] === 0x0d &&
|
|
53
|
+
bytes[5] === 0x0a &&
|
|
54
|
+
bytes[6] === 0x1a &&
|
|
55
|
+
bytes[7] === 0x0a) {
|
|
56
|
+
return "image/png";
|
|
57
|
+
}
|
|
58
|
+
// GIF: 47 49 46 38 (GIF8)
|
|
59
|
+
if (bytes[0] === 0x47 &&
|
|
60
|
+
bytes[1] === 0x49 &&
|
|
61
|
+
bytes[2] === 0x46 &&
|
|
62
|
+
bytes[3] === 0x38) {
|
|
63
|
+
return "image/gif";
|
|
64
|
+
}
|
|
65
|
+
// WebP: 52 49 46 46 (RIFF) ... 57 45 42 50 (WEBP)
|
|
66
|
+
if (bytes[0] === 0x52 &&
|
|
67
|
+
bytes[1] === 0x49 &&
|
|
68
|
+
bytes[2] === 0x46 &&
|
|
69
|
+
bytes[3] === 0x46 &&
|
|
70
|
+
bytes[8] === 0x57 &&
|
|
71
|
+
bytes[9] === 0x45 &&
|
|
72
|
+
bytes[10] === 0x42 &&
|
|
73
|
+
bytes[11] === 0x50) {
|
|
74
|
+
return "image/webp";
|
|
75
|
+
}
|
|
76
|
+
return null;
|
|
77
|
+
}
|
|
78
|
+
static detectImageMimeType(buffer, filename) {
|
|
79
|
+
const mimeFromExtension = ImageUtils.detectMimeTypeFromExtension(filename);
|
|
80
|
+
if (mimeFromExtension) {
|
|
81
|
+
return mimeFromExtension;
|
|
82
|
+
}
|
|
83
|
+
const mimeFromBuffer = ImageUtils.detectMimeTypeFromBuffer(buffer);
|
|
84
|
+
if (mimeFromBuffer) {
|
|
85
|
+
return mimeFromBuffer;
|
|
86
|
+
}
|
|
87
|
+
return "image/jpeg";
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.ImageUtils = ImageUtils;
|
|
91
|
+
//# sourceMappingURL=image-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"image-utils.js","sourceRoot":"","sources":["../../src/utils/image-utils.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export type ImageBuffer = Buffer | ArrayBuffer | Uint8Array;
|
|
2
|
+
|
|
3
|
+
export type ImageMimeType =
|
|
4
|
+
| "image/jpeg"
|
|
5
|
+
| "image/png"
|
|
6
|
+
| "image/gif"
|
|
7
|
+
| "image/webp";
|
|
8
|
+
|
|
9
|
+
export const MIME_TO_EXTENSION: Record<ImageMimeType, string> = {
|
|
10
|
+
"image/jpeg": "jpg",
|
|
11
|
+
"image/png": "png",
|
|
12
|
+
"image/gif": "gif",
|
|
13
|
+
"image/webp": "webp",
|
|
14
|
+
};
|