@push.rocks/smartai 0.0.14 → 0.0.19
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_ts/00_commitinfo_data.d.ts +1 -1
- package/dist_ts/00_commitinfo_data.js +2 -2
- package/dist_ts/abstract.classes.multimodal.d.ts +50 -17
- package/dist_ts/abstract.classes.multimodal.js +5 -1
- package/dist_ts/plugins.d.ts +0 -1
- package/dist_ts/provider.anthropic.d.ts +5 -12
- package/dist_ts/provider.anthropic.js +79 -9
- package/dist_ts/provider.groq.d.ts +18 -0
- package/dist_ts/provider.groq.js +157 -0
- package/dist_ts/provider.ollama.d.ts +18 -1
- package/dist_ts/provider.ollama.js +145 -2
- package/dist_ts/provider.openai.d.ts +1 -2
- package/dist_ts/provider.openai.js +62 -6
- package/dist_ts/provider.perplexity.d.ts +15 -1
- package/dist_ts/provider.perplexity.js +136 -2
- package/package.json +13 -13
- package/readme.md +122 -39
- package/ts/00_commitinfo_data.ts +2 -2
- package/ts/abstract.classes.multimodal.ts +51 -18
- package/ts/provider.anthropic.ts +88 -17
- package/ts/provider.groq.ts +179 -0
- package/ts/provider.ollama.ts +168 -1
- package/ts/provider.openai.ts +67 -6
- package/ts/provider.perplexity.ts +156 -1
|
@@ -15,14 +15,70 @@ export class OpenAiProvider extends MultiModalModel {
|
|
|
15
15
|
}
|
|
16
16
|
async stop() { }
|
|
17
17
|
async chatStream(input) {
|
|
18
|
-
//
|
|
19
|
-
const
|
|
20
|
-
|
|
18
|
+
// Create a TextDecoder to handle incoming chunks
|
|
19
|
+
const decoder = new TextDecoder();
|
|
20
|
+
let buffer = '';
|
|
21
|
+
let currentMessage = null;
|
|
22
|
+
// Create a TransformStream to process the input
|
|
23
|
+
const transform = new TransformStream({
|
|
24
|
+
async transform(chunk, controller) {
|
|
25
|
+
buffer += decoder.decode(chunk, { stream: true });
|
|
26
|
+
// Try to parse complete JSON messages from the buffer
|
|
27
|
+
while (true) {
|
|
28
|
+
const newlineIndex = buffer.indexOf('\n');
|
|
29
|
+
if (newlineIndex === -1)
|
|
30
|
+
break;
|
|
31
|
+
const line = buffer.slice(0, newlineIndex);
|
|
32
|
+
buffer = buffer.slice(newlineIndex + 1);
|
|
33
|
+
if (line.trim()) {
|
|
34
|
+
try {
|
|
35
|
+
const message = JSON.parse(line);
|
|
36
|
+
currentMessage = {
|
|
37
|
+
role: message.role || 'user',
|
|
38
|
+
content: message.content || '',
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
catch (e) {
|
|
42
|
+
console.error('Failed to parse message:', e);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
// If we have a complete message, send it to OpenAI
|
|
47
|
+
if (currentMessage) {
|
|
48
|
+
const stream = await this.openAiApiClient.chat.completions.create({
|
|
49
|
+
model: 'gpt-4',
|
|
50
|
+
messages: [{ role: currentMessage.role, content: currentMessage.content }],
|
|
51
|
+
stream: true,
|
|
52
|
+
});
|
|
53
|
+
// Process each chunk from OpenAI
|
|
54
|
+
for await (const chunk of stream) {
|
|
55
|
+
const content = chunk.choices[0]?.delta?.content;
|
|
56
|
+
if (content) {
|
|
57
|
+
controller.enqueue(content);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
currentMessage = null;
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
flush(controller) {
|
|
64
|
+
if (buffer) {
|
|
65
|
+
try {
|
|
66
|
+
const message = JSON.parse(buffer);
|
|
67
|
+
controller.enqueue(message.content || '');
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
console.error('Failed to parse remaining buffer:', e);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
// Connect the input to our transform stream
|
|
76
|
+
return input.pipeThrough(transform);
|
|
21
77
|
}
|
|
22
78
|
// Implementing the synchronous chat interaction
|
|
23
79
|
async chat(optionsArg) {
|
|
24
80
|
const result = await this.openAiApiClient.chat.completions.create({
|
|
25
|
-
model: 'gpt-
|
|
81
|
+
model: 'gpt-4o',
|
|
26
82
|
messages: [
|
|
27
83
|
{ role: 'system', content: optionsArg.systemMessage },
|
|
28
84
|
...optionsArg.messageHistory,
|
|
@@ -59,7 +115,7 @@ export class OpenAiProvider extends MultiModalModel {
|
|
|
59
115
|
return plugins.smartfile.SmartFile.fromBuffer('pdfDocumentImage.jpg', Buffer.from(pdfDocumentImageBytes));
|
|
60
116
|
});
|
|
61
117
|
const result = await this.openAiApiClient.chat.completions.create({
|
|
62
|
-
model: 'gpt-
|
|
118
|
+
model: 'gpt-4o',
|
|
63
119
|
// response_format: { type: "json_object" }, // not supported for now
|
|
64
120
|
messages: [
|
|
65
121
|
{ role: 'system', content: optionsArg.systemMessage },
|
|
@@ -89,4 +145,4 @@ export class OpenAiProvider extends MultiModalModel {
|
|
|
89
145
|
};
|
|
90
146
|
}
|
|
91
147
|
}
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIub3BlbmFpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvcHJvdmlkZXIub3BlbmFpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sS0FBSyxLQUFLLE1BQU0sWUFBWSxDQUFDO0FBRXBDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQU1uRSxNQUFNLE9BQU8sY0FBZSxTQUFRLGVBQWU7SUFLakQsWUFBWSxVQUFrQztRQUM1QyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFDO0lBQzVCLENBQUM7SUFFTSxLQUFLLENBQUMsS0FBSztRQUNoQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDaEQsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVztZQUNoQyx1QkFBdUIsRUFBRSxJQUFJO1NBQzlCLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDMUQsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLEtBQUksQ0FBQztJQUVmLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBaUM7UUFDdkQsaURBQWlEO1FBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUksV0FBVyxFQUFFLENBQUM7UUFDbEMsSUFBSSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLElBQUksY0FBYyxHQUE4QyxJQUFJLENBQUM7UUFFckUsZ0RBQWdEO1FBQ2hELE1BQU0sU0FBUyxHQUFHLElBQUksZUFBZSxDQUFxQjtZQUN4RCxLQUFLLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxVQUFVO2dCQUMvQixNQUFNLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQkFFbEQsc0RBQXNEO2dCQUN0RCxPQUFPLElBQUksRUFBRSxDQUFDO29CQUNaLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7b0JBQzFDLElBQUksWUFBWSxLQUFLLENBQUMsQ0FBQzt3QkFBRSxNQUFNO29CQUUvQixNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQztvQkFDM0MsTUFBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUV4QyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDO3dCQUNoQixJQUFJLENBQUM7NEJBQ0gsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQzs0QkFDakMsY0FBYyxHQUFHO2dDQUNmLElBQUksRUFBRSxPQUFPLENBQUMsSUFBSSxJQUFJLE1BQU07Z0NBQzVCLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTyxJQUFJLEVBQUU7NkJBQy9CLENBQUM7d0JBQ0osQ0FBQzt3QkFBQyxPQUFPLENBQUMsRUFBRSxDQUFDOzRCQUNYLE9BQU8sQ0FBQyxLQUFLLENBQUMsMEJBQTBCLEVBQUUsQ0FBQyxDQUFDLENBQUM7d0JBQy9DLENBQUM7b0JBQ0gsQ0FBQztnQkFDSCxDQUFDO2dCQUVELG1EQUFtRDtnQkFDbkQsSUFBSSxjQUFjLEVBQUUsQ0FBQztvQkFDbkIsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDO3dCQUNoRSxLQUFLLEVBQUUsT0FBTzt3QkFDZCxRQUFRLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxjQUFjLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxjQUFjLENBQUMsT0FBTyxFQUFFLENBQUM7d0JBQzFFLE1BQU0sRUFBRSxJQUFJO3FCQUNiLENBQUMsQ0FBQztvQkFFSCxpQ0FBaUM7b0JBQ2pDLElBQUksS0FBSyxFQUFFLE1BQU0sS0FBSyxJQUFJLE1BQU0sRUFBRSxDQUFDO3dCQUNqQyxNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxPQUFPLENBQUM7d0JBQ2pELElBQUksT0FBTyxFQUFFLENBQUM7NEJBQ1osVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQzt3QkFDOUIsQ0FBQztvQkFDSCxDQUFDO29CQUVELGNBQWMsR0FBRyxJQUFJLENBQUM7Z0JBQ3hCLENBQUM7WUFDSCxDQUFDO1lBRUQsS0FBSyxDQUFDLFVBQVU7Z0JBQ2QsSUFBSSxNQUFNLEVBQUUsQ0FBQztvQkFDWCxJQUFJLENBQUM7d0JBQ0gsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQzt3QkFDbkMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQyxDQUFDO29CQUM1QyxDQUFDO29CQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7d0JBQ1gsT0FBTyxDQUFDLEtBQUssQ0FBQyxtQ0FBbUMsRUFBRSxDQUFDLENBQUMsQ0FBQztvQkFDeEQsQ0FBQztnQkFDSCxDQUFDO1lBQ0gsQ0FBQztTQUNGLENBQUMsQ0FBQztRQUVILDRDQUE0QztRQUM1QyxPQUFPLEtBQUssQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELGdEQUFnRDtJQUN6QyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBT2pCO1FBQ0MsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDO1lBQ2hFLEtBQUssRUFBRSxRQUFRO1lBRWYsUUFBUSxFQUFFO2dCQUNSLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsVUFBVSxDQUFDLGFBQWEsRUFBRTtnQkFDckQsR0FBRyxVQUFVLENBQUMsY0FBYztnQkFDNUIsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxVQUFVLENBQUMsV0FBVyxFQUFFO2FBQ2xEO1NBQ0YsQ0FBQyxDQUFDO1FBQ0gsT0FBTztZQUNMLElBQUksRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFtQjtZQUNuRCxPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTztTQUMzQyxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxLQUFLLENBQUMsVUFBK0I7UUFDaEQsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQXlCLENBQUM7UUFDakUsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDO1lBQzVELEtBQUssRUFBRSxVQUFVO1lBQ2pCLEtBQUssRUFBRSxVQUFVLENBQUMsT0FBTztZQUN6QixLQUFLLEVBQUUsTUFBTTtZQUNiLGVBQWUsRUFBRSxLQUFLO1lBQ3RCLEtBQUssRUFBRSxDQUFDO1NBQ1QsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUMzQixJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRU0sS0FBSyxDQUFDLFFBQVEsQ0FBQyxVQVFyQjtRQUNDLElBQUksMEJBQTBCLEdBQWlCLEVBQUUsQ0FBQztRQUVsRCxLQUFLLE1BQU0sV0FBVyxJQUFJLFVBQVUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUNsRCxNQUFNLGtCQUFrQixHQUFHLE1BQU0sSUFBSSxDQUFDLGdCQUFnQixDQUFDLG9CQUFvQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ3pGLDBCQUEwQixHQUFHLDBCQUEwQixDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3JGLENBQUM7UUFFRCxPQUFPLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDckMsT0FBTyxDQUFDLEdBQUcsQ0FBQywwQkFBMEIsQ0FBQyxHQUFHLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTdFLE1BQU0sY0FBYyxHQUFHLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQ2pELDBCQUEwQixFQUMxQixLQUFLLEVBQUUscUJBQXFCLEVBQUUsRUFBRTtZQUM5QixPQUFPLE9BQU8sQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FDM0Msc0JBQXNCLEVBQ3RCLE1BQU0sQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FDbkMsQ0FBQztRQUNKLENBQUMsQ0FDRixDQUFDO1FBRUYsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDO1lBQ2hFLEtBQUssRUFBRSxRQUFRO1lBQ2YscUVBQXFFO1lBQ3JFLFFBQVEsRUFBRTtnQkFDUixFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLFVBQVUsQ0FBQyxhQUFhLEVBQUU7Z0JBQ3JELEdBQUcsVUFBVSxDQUFDLGNBQWM7Z0JBQzVCO29CQUNFLElBQUksRUFBRSxNQUFNO29CQUNaLE9BQU8sRUFBRTt3QkFDUCxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLFVBQVUsQ0FBQyxXQUFXLEVBQUU7d0JBQzlDLEdBQUcsQ0FBQyxHQUFHLEVBQUU7NEJBQ1AsTUFBTSxXQUFXLEdBQUcsRUFBRSxDQUFDOzRCQUN2QixLQUFLLE1BQU0sVUFBVSxJQUFJLDBCQUEwQixFQUFFLENBQUM7Z0NBQ3BELFdBQVcsQ0FBQyxJQUFJLENBQUM7b0NBQ2YsSUFBSSxFQUFFLFdBQVc7b0NBQ2pCLFNBQVMsRUFBRTt3Q0FDVCxHQUFHLEVBQUUsd0JBQXdCLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDO3FDQUMzRTtpQ0FDRixDQUFDLENBQUM7NEJBQ0wsQ0FBQzs0QkFDRCxPQUFPLFdBQVcsQ0FBQzt3QkFDckIsQ0FBQyxDQUFDLEVBQUU7cUJBQ0w7aUJBQ0Y7YUFDRjtTQUNGLENBQUMsQ0FBQztRQUNILE9BQU87WUFDTCxPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPO1NBQ25DLENBQUM7SUFDSixDQUFDO0NBQ0YifQ==
|
|
@@ -1,2 +1,16 @@
|
|
|
1
|
-
|
|
1
|
+
import { MultiModalModel } from './abstract.classes.multimodal.js';
|
|
2
|
+
import type { ChatOptions, ChatResponse } from './abstract.classes.multimodal.js';
|
|
3
|
+
export interface IPerplexityProviderOptions {
|
|
4
|
+
perplexityToken: string;
|
|
5
|
+
}
|
|
6
|
+
export declare class PerplexityProvider extends MultiModalModel {
|
|
7
|
+
private options;
|
|
8
|
+
constructor(optionsArg: IPerplexityProviderOptions);
|
|
9
|
+
start(): Promise<void>;
|
|
10
|
+
stop(): Promise<void>;
|
|
11
|
+
chatStream(input: ReadableStream<Uint8Array>): Promise<ReadableStream<string>>;
|
|
12
|
+
chat(optionsArg: ChatOptions): Promise<ChatResponse>;
|
|
13
|
+
audio(optionsArg: {
|
|
14
|
+
message: string;
|
|
15
|
+
}): Promise<NodeJS.ReadableStream>;
|
|
2
16
|
}
|
|
@@ -1,4 +1,138 @@
|
|
|
1
1
|
import * as plugins from './plugins.js';
|
|
2
|
-
|
|
2
|
+
import * as paths from './paths.js';
|
|
3
|
+
import { MultiModalModel } from './abstract.classes.multimodal.js';
|
|
4
|
+
export class PerplexityProvider extends MultiModalModel {
|
|
5
|
+
constructor(optionsArg) {
|
|
6
|
+
super();
|
|
7
|
+
this.options = optionsArg;
|
|
8
|
+
}
|
|
9
|
+
async start() {
|
|
10
|
+
// Initialize any necessary clients or resources
|
|
11
|
+
}
|
|
12
|
+
async stop() { }
|
|
13
|
+
async chatStream(input) {
|
|
14
|
+
// Create a TextDecoder to handle incoming chunks
|
|
15
|
+
const decoder = new TextDecoder();
|
|
16
|
+
let buffer = '';
|
|
17
|
+
let currentMessage = null;
|
|
18
|
+
// Create a TransformStream to process the input
|
|
19
|
+
const transform = new TransformStream({
|
|
20
|
+
async transform(chunk, controller) {
|
|
21
|
+
buffer += decoder.decode(chunk, { stream: true });
|
|
22
|
+
// Try to parse complete JSON messages from the buffer
|
|
23
|
+
while (true) {
|
|
24
|
+
const newlineIndex = buffer.indexOf('\n');
|
|
25
|
+
if (newlineIndex === -1)
|
|
26
|
+
break;
|
|
27
|
+
const line = buffer.slice(0, newlineIndex);
|
|
28
|
+
buffer = buffer.slice(newlineIndex + 1);
|
|
29
|
+
if (line.trim()) {
|
|
30
|
+
try {
|
|
31
|
+
const message = JSON.parse(line);
|
|
32
|
+
currentMessage = {
|
|
33
|
+
role: message.role || 'user',
|
|
34
|
+
content: message.content || '',
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
catch (e) {
|
|
38
|
+
console.error('Failed to parse message:', e);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
// If we have a complete message, send it to Perplexity
|
|
43
|
+
if (currentMessage) {
|
|
44
|
+
const response = await fetch('https://api.perplexity.ai/chat/completions', {
|
|
45
|
+
method: 'POST',
|
|
46
|
+
headers: {
|
|
47
|
+
'Authorization': `Bearer ${this.options.perplexityToken}`,
|
|
48
|
+
'Content-Type': 'application/json',
|
|
49
|
+
},
|
|
50
|
+
body: JSON.stringify({
|
|
51
|
+
model: 'mixtral-8x7b-instruct',
|
|
52
|
+
messages: [{ role: currentMessage.role, content: currentMessage.content }],
|
|
53
|
+
stream: true,
|
|
54
|
+
}),
|
|
55
|
+
});
|
|
56
|
+
// Process each chunk from Perplexity
|
|
57
|
+
const reader = response.body?.getReader();
|
|
58
|
+
if (reader) {
|
|
59
|
+
try {
|
|
60
|
+
while (true) {
|
|
61
|
+
const { done, value } = await reader.read();
|
|
62
|
+
if (done)
|
|
63
|
+
break;
|
|
64
|
+
const chunk = new TextDecoder().decode(value);
|
|
65
|
+
const lines = chunk.split('\n');
|
|
66
|
+
for (const line of lines) {
|
|
67
|
+
if (line.startsWith('data: ')) {
|
|
68
|
+
const data = line.slice(6);
|
|
69
|
+
if (data === '[DONE]')
|
|
70
|
+
break;
|
|
71
|
+
try {
|
|
72
|
+
const parsed = JSON.parse(data);
|
|
73
|
+
const content = parsed.choices[0]?.delta?.content;
|
|
74
|
+
if (content) {
|
|
75
|
+
controller.enqueue(content);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
catch (e) {
|
|
79
|
+
console.error('Failed to parse SSE data:', e);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
finally {
|
|
86
|
+
reader.releaseLock();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
currentMessage = null;
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
flush(controller) {
|
|
93
|
+
if (buffer) {
|
|
94
|
+
try {
|
|
95
|
+
const message = JSON.parse(buffer);
|
|
96
|
+
controller.enqueue(message.content || '');
|
|
97
|
+
}
|
|
98
|
+
catch (e) {
|
|
99
|
+
console.error('Failed to parse remaining buffer:', e);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
// Connect the input to our transform stream
|
|
105
|
+
return input.pipeThrough(transform);
|
|
106
|
+
}
|
|
107
|
+
// Implementing the synchronous chat interaction
|
|
108
|
+
async chat(optionsArg) {
|
|
109
|
+
// Make API call to Perplexity
|
|
110
|
+
const response = await fetch('https://api.perplexity.ai/chat/completions', {
|
|
111
|
+
method: 'POST',
|
|
112
|
+
headers: {
|
|
113
|
+
'Authorization': `Bearer ${this.options.perplexityToken}`,
|
|
114
|
+
'Content-Type': 'application/json',
|
|
115
|
+
},
|
|
116
|
+
body: JSON.stringify({
|
|
117
|
+
model: 'mixtral-8x7b-instruct', // Using Mixtral model
|
|
118
|
+
messages: [
|
|
119
|
+
{ role: 'system', content: optionsArg.systemMessage },
|
|
120
|
+
...optionsArg.messageHistory,
|
|
121
|
+
{ role: 'user', content: optionsArg.userMessage }
|
|
122
|
+
],
|
|
123
|
+
}),
|
|
124
|
+
});
|
|
125
|
+
if (!response.ok) {
|
|
126
|
+
throw new Error(`Perplexity API error: ${response.statusText}`);
|
|
127
|
+
}
|
|
128
|
+
const result = await response.json();
|
|
129
|
+
return {
|
|
130
|
+
role: 'assistant',
|
|
131
|
+
message: result.choices[0].message.content,
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
async audio(optionsArg) {
|
|
135
|
+
throw new Error('Audio generation is not supported by Perplexity.');
|
|
136
|
+
}
|
|
3
137
|
}
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIucGVycGxleGl0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3Byb3ZpZGVyLnBlcnBsZXhpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxjQUFjLENBQUM7QUFDeEMsT0FBTyxLQUFLLEtBQUssTUFBTSxZQUFZLENBQUM7QUFDcEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBT25FLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxlQUFlO0lBR3JELFlBQVksVUFBc0M7UUFDaEQsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsT0FBTyxHQUFHLFVBQVUsQ0FBQztJQUM1QixDQUFDO0lBRUQsS0FBSyxDQUFDLEtBQUs7UUFDVCxnREFBZ0Q7SUFDbEQsQ0FBQztJQUVELEtBQUssQ0FBQyxJQUFJLEtBQUksQ0FBQztJQUVSLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBaUM7UUFDdkQsaURBQWlEO1FBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUksV0FBVyxFQUFFLENBQUM7UUFDbEMsSUFBSSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLElBQUksY0FBYyxHQUE4QyxJQUFJLENBQUM7UUFFckUsZ0RBQWdEO1FBQ2hELE1BQU0sU0FBUyxHQUFHLElBQUksZUFBZSxDQUFxQjtZQUN4RCxLQUFLLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxVQUFVO2dCQUMvQixNQUFNLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQkFFbEQsc0RBQXNEO2dCQUN0RCxPQUFPLElBQUksRUFBRSxDQUFDO29CQUNaLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7b0JBQzFDLElBQUksWUFBWSxLQUFLLENBQUMsQ0FBQzt3QkFBRSxNQUFNO29CQUUvQixN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
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@push.rocks/smartai",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.19",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "A TypeScript library for integrating and interacting with multiple AI models, offering capabilities for chat and potentially audio responses.",
|
|
6
6
|
"main": "dist_ts/index.js",
|
|
@@ -9,33 +9,33 @@
|
|
|
9
9
|
"author": "Task Venture Capital GmbH",
|
|
10
10
|
"license": "MIT",
|
|
11
11
|
"devDependencies": {
|
|
12
|
-
"@git.zone/tsbuild": "^2.1.
|
|
12
|
+
"@git.zone/tsbuild": "^2.1.84",
|
|
13
13
|
"@git.zone/tsbundle": "^2.0.5",
|
|
14
|
-
"@git.zone/tsrun": "^1.2.
|
|
14
|
+
"@git.zone/tsrun": "^1.2.49",
|
|
15
15
|
"@git.zone/tstest": "^1.0.90",
|
|
16
16
|
"@push.rocks/qenv": "^6.0.5",
|
|
17
|
-
"@push.rocks/tapbundle": "^5.0
|
|
18
|
-
"@types/node": "^
|
|
17
|
+
"@push.rocks/tapbundle": "^5.3.0",
|
|
18
|
+
"@types/node": "^22.5.5"
|
|
19
19
|
},
|
|
20
20
|
"dependencies": {
|
|
21
|
-
"@anthropic-ai/sdk": "^0.
|
|
21
|
+
"@anthropic-ai/sdk": "^0.27.3",
|
|
22
22
|
"@push.rocks/smartarray": "^1.0.8",
|
|
23
|
-
"@push.rocks/smartfile": "^11.0.
|
|
23
|
+
"@push.rocks/smartfile": "^11.0.21",
|
|
24
24
|
"@push.rocks/smartpath": "^5.0.18",
|
|
25
|
-
"@push.rocks/smartpdf": "^3.1.
|
|
26
|
-
"@push.rocks/smartpromise": "^4.0.
|
|
25
|
+
"@push.rocks/smartpdf": "^3.1.6",
|
|
26
|
+
"@push.rocks/smartpromise": "^4.0.4",
|
|
27
27
|
"@push.rocks/smartrequest": "^2.0.22",
|
|
28
|
-
"@push.rocks/webstream": "^1.0.
|
|
29
|
-
"openai": "^4.
|
|
28
|
+
"@push.rocks/webstream": "^1.0.10",
|
|
29
|
+
"openai": "^4.62.1"
|
|
30
30
|
},
|
|
31
31
|
"repository": {
|
|
32
32
|
"type": "git",
|
|
33
|
-
"url": "
|
|
33
|
+
"url": "https://code.foss.global/push.rocks/smartai.git"
|
|
34
34
|
},
|
|
35
35
|
"bugs": {
|
|
36
36
|
"url": "https://code.foss.global/push.rocks/smartai/issues"
|
|
37
37
|
},
|
|
38
|
-
"homepage": "https://code.foss.global/push.rocks/smartai
|
|
38
|
+
"homepage": "https://code.foss.global/push.rocks/smartai",
|
|
39
39
|
"browserslist": [
|
|
40
40
|
"last 1 chrome versions"
|
|
41
41
|
],
|
package/readme.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
# @push.rocks/smartai
|
|
2
2
|
|
|
3
|
-
Provides a standardized interface for integrating and conversing with multiple AI models, supporting operations like chat and
|
|
3
|
+
Provides a standardized interface for integrating and conversing with multiple AI models, supporting operations like chat, streaming interactions, and audio responses.
|
|
4
4
|
|
|
5
5
|
## Install
|
|
6
6
|
|
|
@@ -12,84 +12,167 @@ npm install @push.rocks/smartai
|
|
|
12
12
|
|
|
13
13
|
This command installs the package and adds it to your project's dependencies.
|
|
14
14
|
|
|
15
|
+
## Supported AI Providers
|
|
16
|
+
|
|
17
|
+
@push.rocks/smartai supports multiple AI providers, each with its own unique capabilities:
|
|
18
|
+
|
|
19
|
+
### OpenAI
|
|
20
|
+
- Models: GPT-4, GPT-3.5-turbo
|
|
21
|
+
- Features: Chat, Streaming, Audio Generation
|
|
22
|
+
- Configuration:
|
|
23
|
+
```typescript
|
|
24
|
+
openaiToken: 'your-openai-token'
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
### Anthropic
|
|
28
|
+
- Models: Claude-3-opus-20240229
|
|
29
|
+
- Features: Chat, Streaming
|
|
30
|
+
- Configuration:
|
|
31
|
+
```typescript
|
|
32
|
+
anthropicToken: 'your-anthropic-token'
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
### Perplexity
|
|
36
|
+
- Models: Mixtral-8x7b-instruct
|
|
37
|
+
- Features: Chat, Streaming
|
|
38
|
+
- Configuration:
|
|
39
|
+
```typescript
|
|
40
|
+
perplexityToken: 'your-perplexity-token'
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
### Groq
|
|
44
|
+
- Models: Llama-3.3-70b-versatile
|
|
45
|
+
- Features: Chat, Streaming
|
|
46
|
+
- Configuration:
|
|
47
|
+
```typescript
|
|
48
|
+
groqToken: 'your-groq-token'
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Ollama
|
|
52
|
+
- Models: Configurable (default: llama2)
|
|
53
|
+
- Features: Chat, Streaming
|
|
54
|
+
- Configuration:
|
|
55
|
+
```typescript
|
|
56
|
+
baseUrl: 'http://localhost:11434' // Optional
|
|
57
|
+
model: 'llama2' // Optional
|
|
58
|
+
```
|
|
59
|
+
|
|
15
60
|
## Usage
|
|
16
61
|
|
|
17
|
-
The `@push.rocks/smartai` package is a comprehensive solution for integrating and interacting with various AI models, designed to support operations ranging from chat interactions to
|
|
62
|
+
The `@push.rocks/smartai` package is a comprehensive solution for integrating and interacting with various AI models, designed to support operations ranging from chat interactions to audio responses. This documentation will guide you through the process of utilizing `@push.rocks/smartai` in your applications.
|
|
18
63
|
|
|
19
64
|
### Getting Started
|
|
20
65
|
|
|
21
|
-
Before you begin, ensure you have installed the package
|
|
66
|
+
Before you begin, ensure you have installed the package as described in the **Install** section above. Once installed, you can start integrating AI functionalities into your application.
|
|
22
67
|
|
|
23
68
|
### Initializing SmartAi
|
|
24
69
|
|
|
25
|
-
The first step is to import and initialize the `SmartAi` class with appropriate options
|
|
70
|
+
The first step is to import and initialize the `SmartAi` class with appropriate options for the AI services you plan to use:
|
|
26
71
|
|
|
27
72
|
```typescript
|
|
28
73
|
import { SmartAi } from '@push.rocks/smartai';
|
|
29
74
|
|
|
30
75
|
const smartAi = new SmartAi({
|
|
31
|
-
openaiToken: 'your-openai-
|
|
32
|
-
anthropicToken: 'your-anthropic-
|
|
76
|
+
openaiToken: 'your-openai-token',
|
|
77
|
+
anthropicToken: 'your-anthropic-token',
|
|
78
|
+
perplexityToken: 'your-perplexity-token',
|
|
79
|
+
groqToken: 'your-groq-token',
|
|
80
|
+
ollama: {
|
|
81
|
+
baseUrl: 'http://localhost:11434',
|
|
82
|
+
model: 'llama2'
|
|
83
|
+
}
|
|
33
84
|
});
|
|
34
85
|
|
|
35
86
|
await smartAi.start();
|
|
36
87
|
```
|
|
37
88
|
|
|
38
|
-
###
|
|
89
|
+
### Chat Interactions
|
|
39
90
|
|
|
40
|
-
|
|
91
|
+
#### Synchronous Chat
|
|
92
|
+
|
|
93
|
+
For simple question-answer interactions:
|
|
41
94
|
|
|
42
95
|
```typescript
|
|
43
|
-
const
|
|
44
|
-
|
|
96
|
+
const response = await smartAi.openaiProvider.chat({
|
|
97
|
+
systemMessage: 'You are a helpful assistant.',
|
|
98
|
+
userMessage: 'What is the capital of France?',
|
|
99
|
+
messageHistory: [] // Previous messages in the conversation
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
console.log(response.message);
|
|
45
103
|
```
|
|
46
104
|
|
|
47
|
-
|
|
105
|
+
#### Streaming Chat
|
|
48
106
|
|
|
49
|
-
|
|
107
|
+
For real-time, streaming interactions:
|
|
108
|
+
|
|
109
|
+
```typescript
|
|
110
|
+
const textEncoder = new TextEncoder();
|
|
111
|
+
const textDecoder = new TextDecoder();
|
|
112
|
+
|
|
113
|
+
// Create input and output streams
|
|
114
|
+
const { writable, readable } = new TransformStream();
|
|
115
|
+
const writer = writable.getWriter();
|
|
116
|
+
|
|
117
|
+
// Send a message
|
|
118
|
+
const message = {
|
|
119
|
+
role: 'user',
|
|
120
|
+
content: 'Tell me a story about a brave knight'
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
writer.write(textEncoder.encode(JSON.stringify(message) + '\n'));
|
|
124
|
+
|
|
125
|
+
// Process the response stream
|
|
126
|
+
const stream = await smartAi.openaiProvider.chatStream(readable);
|
|
127
|
+
const reader = stream.getReader();
|
|
128
|
+
|
|
129
|
+
while (true) {
|
|
130
|
+
const { done, value } = await reader.read();
|
|
131
|
+
if (done) break;
|
|
132
|
+
console.log('AI:', value); // Process each chunk of the response
|
|
133
|
+
}
|
|
134
|
+
```
|
|
50
135
|
|
|
51
|
-
|
|
136
|
+
### Audio Generation
|
|
52
137
|
|
|
53
|
-
|
|
138
|
+
For providers that support audio generation (currently OpenAI):
|
|
54
139
|
|
|
55
140
|
```typescript
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
userMessage: 'Hello, AI! How are you today?',
|
|
59
|
-
messageHistory: [] // Previous messages in the conversation
|
|
141
|
+
const audioStream = await smartAi.openaiProvider.audio({
|
|
142
|
+
message: 'Hello, this is a test of text-to-speech'
|
|
60
143
|
});
|
|
61
144
|
|
|
62
|
-
|
|
145
|
+
// Handle the audio stream (e.g., save to file or play)
|
|
63
146
|
```
|
|
64
147
|
|
|
65
|
-
|
|
148
|
+
### Document Processing
|
|
66
149
|
|
|
67
|
-
For
|
|
150
|
+
For providers that support document processing (currently OpenAI):
|
|
68
151
|
|
|
69
152
|
```typescript
|
|
70
|
-
const
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
const reader = outputStream.getReader();
|
|
76
|
-
reader.read().then(function processText({done, value}) {
|
|
77
|
-
if (done) {
|
|
78
|
-
console.log('Stream finished.');
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
console.log('AI says:', value);
|
|
82
|
-
reader.read().then(processText); // Continue reading messages
|
|
153
|
+
const result = await smartAi.openaiProvider.document({
|
|
154
|
+
systemMessage: 'Classify the document type',
|
|
155
|
+
userMessage: 'What type of document is this?',
|
|
156
|
+
messageHistory: [],
|
|
157
|
+
pdfDocuments: [pdfBuffer] // Uint8Array of PDF content
|
|
83
158
|
});
|
|
84
159
|
```
|
|
85
160
|
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
The modular design of `@push.rocks/smartai` allows you to extend conversations with additional features, such as handling audio responses or integrating other AI-powered functionalities. Utilize the provided AI providers' APIs to explore and implement a wide range of AI interactions within your conversations.
|
|
161
|
+
## Error Handling
|
|
89
162
|
|
|
90
|
-
|
|
163
|
+
All providers implement proper error handling. It's recommended to wrap API calls in try-catch blocks:
|
|
91
164
|
|
|
92
|
-
|
|
165
|
+
```typescript
|
|
166
|
+
try {
|
|
167
|
+
const response = await smartAi.openaiProvider.chat({
|
|
168
|
+
systemMessage: 'You are a helpful assistant.',
|
|
169
|
+
userMessage: 'Hello!',
|
|
170
|
+
messageHistory: []
|
|
171
|
+
});
|
|
172
|
+
} catch (error) {
|
|
173
|
+
console.error('AI provider error:', error.message);
|
|
174
|
+
}
|
|
175
|
+
```
|
|
93
176
|
|
|
94
177
|
## License and Legal Information
|
|
95
178
|
|
package/ts/00_commitinfo_data.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* autocreated commitinfo by @
|
|
2
|
+
* autocreated commitinfo by @push.rocks/commitinfo
|
|
3
3
|
*/
|
|
4
4
|
export const commitinfo = {
|
|
5
5
|
name: '@push.rocks/smartai',
|
|
6
|
-
version: '0.0.
|
|
6
|
+
version: '0.0.19',
|
|
7
7
|
description: 'A TypeScript library for integrating and interacting with multiple AI models, offering capabilities for chat and potentially audio responses.'
|
|
8
8
|
}
|
|
@@ -1,32 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Message format for chat interactions
|
|
3
|
+
*/
|
|
4
|
+
export interface ChatMessage {
|
|
5
|
+
role: 'assistant' | 'user' | 'system';
|
|
6
|
+
content: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Options for chat interactions
|
|
11
|
+
*/
|
|
12
|
+
export interface ChatOptions {
|
|
13
|
+
systemMessage: string;
|
|
14
|
+
userMessage: string;
|
|
15
|
+
messageHistory: ChatMessage[];
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Response format for chat interactions
|
|
20
|
+
*/
|
|
21
|
+
export interface ChatResponse {
|
|
22
|
+
role: 'assistant';
|
|
23
|
+
message: string;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Abstract base class for multi-modal AI models.
|
|
28
|
+
* Provides a common interface for different AI providers (OpenAI, Anthropic, Perplexity, Ollama)
|
|
29
|
+
*/
|
|
1
30
|
export abstract class MultiModalModel {
|
|
2
31
|
/**
|
|
3
|
-
*
|
|
32
|
+
* Initializes the model and any necessary resources
|
|
33
|
+
* Should be called before using any other methods
|
|
4
34
|
*/
|
|
5
35
|
abstract start(): Promise<void>;
|
|
6
36
|
|
|
7
37
|
/**
|
|
8
|
-
*
|
|
38
|
+
* Cleans up any resources used by the model
|
|
39
|
+
* Should be called when the model is no longer needed
|
|
9
40
|
*/
|
|
10
41
|
abstract stop(): Promise<void>;
|
|
11
42
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
}[]
|
|
19
|
-
}): Promise<{
|
|
20
|
-
role: 'assistant';
|
|
21
|
-
message: string;
|
|
22
|
-
}>
|
|
43
|
+
/**
|
|
44
|
+
* Synchronous chat interaction with the model
|
|
45
|
+
* @param optionsArg Options containing system message, user message, and message history
|
|
46
|
+
* @returns Promise resolving to the assistant's response
|
|
47
|
+
*/
|
|
48
|
+
public abstract chat(optionsArg: ChatOptions): Promise<ChatResponse>;
|
|
23
49
|
|
|
24
50
|
/**
|
|
25
|
-
*
|
|
26
|
-
*
|
|
27
|
-
* @param input
|
|
51
|
+
* Streaming interface for chat interactions
|
|
52
|
+
* Allows for real-time responses from the model
|
|
53
|
+
* @param input Stream of user messages
|
|
54
|
+
* @returns Stream of model responses
|
|
28
55
|
*/
|
|
29
|
-
public abstract chatStream(input: ReadableStream<
|
|
30
|
-
|
|
56
|
+
public abstract chatStream(input: ReadableStream<Uint8Array>): Promise<ReadableStream<string>>;
|
|
31
57
|
|
|
58
|
+
/**
|
|
59
|
+
* Text-to-speech conversion
|
|
60
|
+
* @param optionsArg Options containing the message to convert to speech
|
|
61
|
+
* @returns Promise resolving to a readable stream of audio data
|
|
62
|
+
* @throws Error if the provider doesn't support audio generation
|
|
63
|
+
*/
|
|
64
|
+
public abstract audio(optionsArg: { message: string }): Promise<NodeJS.ReadableStream>;
|
|
32
65
|
}
|