@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.
@@ -15,14 +15,70 @@ export class OpenAiProvider extends MultiModalModel {
15
15
  }
16
16
  async stop() { }
17
17
  async chatStream(input) {
18
- // TODO: implement for OpenAI
19
- const returnStream = new ReadableStream();
20
- return returnStream;
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-4-turbo-preview',
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-4-vision-preview',
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIub3BlbmFpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvcHJvdmlkZXIub3BlbmFpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sS0FBSyxLQUFLLE1BQU0sWUFBWSxDQUFDO0FBRXBDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQU1uRSxNQUFNLE9BQU8sY0FBZSxTQUFRLGVBQWU7SUFLakQsWUFBWSxVQUFrQztRQUM1QyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFDO0lBQzVCLENBQUM7SUFFTSxLQUFLLENBQUMsS0FBSztRQUNoQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDaEQsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVztZQUNoQyx1QkFBdUIsRUFBRSxJQUFJO1NBQzlCLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDMUQsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLEtBQUksQ0FBQztJQUVmLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBNkI7UUFDbkQsNkJBQTZCO1FBRTdCLE1BQU0sWUFBWSxHQUFHLElBQUksY0FBYyxFQUFFLENBQUM7UUFDMUMsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQztJQUVELGdEQUFnRDtJQUN6QyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBT2pCO1FBQ0MsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDO1lBQ2hFLEtBQUssRUFBRSxxQkFBcUI7WUFFNUIsUUFBUSxFQUFFO2dCQUNSLEVB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
148
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIub3BlbmFpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvcHJvdmlkZXIub3BlbmFpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sS0FBSyxLQUFLLE1BQU0sWUFBWSxDQUFDO0FBRXBDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQU1uRSxNQUFNLE9BQU8sY0FBZSxTQUFRLGVBQWU7SUFLakQsWUFBWSxVQUFrQztRQUM1QyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFDO0lBQzVCLENBQUM7SUFFTSxLQUFLLENBQUMsS0FBSztRQUNoQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDaEQsTUFBTSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVztZQUNoQyx1QkFBdUIsRUFBRSxJQUFJO1NBQzlCLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDMUQsQ0FBQztJQUVNLEtBQUssQ0FBQyxJQUFJLEtBQUksQ0FBQztJQUVmLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBaUM7UUFDdkQsaURBQWlEO1FBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUksV0FBVyxFQUFFLENBQUM7UUFDbEMsSUFBSSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLElBQUksY0FBYyxHQUE4QyxJQUFJLENBQUM7UUFFckUsZ0RBQWdEO1FBQ2hELE1BQU0sU0FBUyxHQUFHLElBQUksZUFBZSxDQUFxQjtZQUN4RCxLQUFLLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxVQUFVO2dCQUMvQixNQUFNLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVB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
@@ -1,2 +1,16 @@
1
- export declare class PerplexityProvider {
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
- export class PerplexityProvider {
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIucGVycGxleGl0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3Byb3ZpZGVyLnBlcnBsZXhpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxjQUFjLENBQUM7QUFFeEMsTUFBTSxPQUFPLGtCQUFrQjtDQUFHIn0=
138
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZXIucGVycGxleGl0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3Byb3ZpZGVyLnBlcnBsZXhpdHkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxjQUFjLENBQUM7QUFDeEMsT0FBTyxLQUFLLEtBQUssTUFBTSxZQUFZLENBQUM7QUFDcEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBT25FLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxlQUFlO0lBR3JELFlBQVksVUFBc0M7UUFDaEQsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsT0FBTyxHQUFHLFVBQVUsQ0FBQztJQUM1QixDQUFDO0lBRUQsS0FBSyxDQUFDLEtBQUs7UUFDVCxnREFBZ0Q7SUFDbEQsQ0FBQztJQUVELEtBQUssQ0FBQyxJQUFJLEtBQUksQ0FBQztJQUVSLEtBQUssQ0FBQyxVQUFVLENBQUMsS0FBaUM7UUFDdkQsaURBQWlEO1FBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUksV0FBVyxFQUFFLENBQUM7UUFDbEMsSUFBSSxNQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLElBQUksY0FBYyxHQUE4QyxJQUFJLENBQUM7UUFFckUsZ0RBQWdEO1FBQ2hELE1BQU0sU0FBUyxHQUFHLElBQUksZUFBZSxDQUFxQjtZQUN4RCxLQUFLLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxVQUFVO2dCQUMvQixNQUFNLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztnQkFFbEQsc0RBQXNEO2dCQUN0RCxPQUFPLElBQUksRUFBRSxDQUFDO29CQUNaLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7b0JBQzFDLElBQUksWUFBWSxLQUFLLENBQUMsQ0FBQzt3QkFBRSxNQUFNO29CQUUvQixNQUFNLElBQUksR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQztvQkFDM0MsTUFBTSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUV4QyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDO3dCQUNoQixJQUFJLENBQUM7NEJBQ0gsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQzs0QkFDakMsY0FBYyxHQUFHO2dDQUNmLElBQUksRUFBRSxPQUFPLENBQUMsSUFBSSxJQUFJLE1BQU07Z0NBQzVCLE9BQU8sRUFBRSxPQUFPLENBQUMsT0FBTyxJQUFJLEVBQUU7NkJBQy9CLENBQUM7d0JBQ0osQ0FBQzt3QkFBQyxPQUFPLENBQUMsRUFBRSxDQUFDOzRCQUNYLE9BQU8sQ0FBQyxLQUFLLENBQUMsMEJBQTBCLEVBQUUsQ0FBQyxDQUFDLENBQUM7d0JBQy9DLENBQUM7b0JBQ0gsQ0FBQztnQkFDSCxDQUFDO2dCQUVELHVEQUF1RDtnQkFDdkQsSUFBSSxjQUFjLEVBQUUsQ0FBQztvQkFDbkIsTUFBTSxRQUFRLEdBQUcsTUFBTSxLQUFLLENBQUMsNENBQTRDLEVBQUU7d0JBQ3pFLE1BQU0sRUFBRSxNQUFNO3dCQUNkLE9BQU8sRUFBRTs0QkFDUCxlQUFlLEVBQUUsVUFBVSxJQUFJLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRTs0QkFDekQsY0FBYyxFQUFFLGtCQUFrQjt5QkFDbkM7d0JBQ0QsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUM7NEJBQ25CLEtBQUssRUFBRSx1QkFBdUI7NEJBQzlCLFFBQVEsRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLGNBQWMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLGNBQWMsQ0FBQyxPQUFPLEVBQUUsQ0FBQzs0QkFDMUUsTUFBTSxFQUFFLElBQUk7eUJBQ2IsQ0FBQztxQkFDSCxDQUFDLENBQUM7b0JBRUgscUNBQXFDO29CQUNyQyxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDO29CQUMxQyxJQUFJLE1BQU0sRUFBRSxDQUFDO3dCQUNYLElBQUksQ0FBQzs0QkFDSCxPQUFPLElBQUksRUFBRSxDQUFDO2dDQUNaLE1BQU0sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEdBQUcsTUFBTSxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7Z0NBQzVDLElBQUksSUFBSTtvQ0FBRSxNQUFNO2dDQUVoQixNQUFNLEtBQUssR0FBRyxJQUFJLFdBQVcsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztnQ0FDOUMsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztnQ0FFaEMsS0FBSyxNQUFNLElBQUksSUFBSSxLQUFLLEVBQUUsQ0FBQztvQ0FDekIsSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7d0NBQzlCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7d0NBQzNCLElBQUksSUFBSSxLQUFLLFFBQVE7NENBQUUsTUFBTTt3Q0FFN0IsSUFBSSxDQUFDOzRDQUNILE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7NENBQ2hDLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQzs0Q0FDbEQsSUFBSSxPQUFPLEVBQUUsQ0FBQztnREFDWixVQUFVLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDOzRDQUM5QixDQUFDO3dDQUNILENBQUM7d0NBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQzs0Q0FDWCxPQUFPLENBQUMsS0FBSyxDQUFDLDJCQUEyQixFQUFFLENBQUMsQ0FBQyxDQUFDO3dDQUNoRCxDQUFDO29DQUNILENBQUM7Z0NBQ0gsQ0FBQzs0QkFDSCxDQUFDO3dCQUNILENBQUM7Z0NBQVMsQ0FBQzs0QkFDVCxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7d0JBQ3ZCLENBQUM7b0JBQ0gsQ0FBQztvQkFFRCxjQUFjLEdBQUcsSUFBSSxDQUFDO2dCQUN4QixDQUFDO1lBQ0gsQ0FBQztZQUVELEtBQUssQ0FBQyxVQUFVO2dCQUNkLElBQUksTUFBTSxFQUFFLENBQUM7b0JBQ1gsSUFBSSxDQUFDO3dCQUNILE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7d0JBQ25DLFVBQVUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztvQkFDNUMsQ0FBQztvQkFBQyxPQUFPLENBQUMsRUFBRSxDQUFDO3dCQUNYLE9BQU8sQ0FBQyxLQUFLLENBQUMsbUNBQW1DLEVBQUUsQ0FBQyxDQUFDLENBQUM7b0JBQ3hELENBQUM7Z0JBQ0gsQ0FBQztZQUNILENBQUM7U0FDRixDQUFDLENBQUM7UUFFSCw0Q0FBNEM7UUFDNUMsT0FBTyxLQUFLLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxnREFBZ0Q7SUFDekMsS0FBSyxDQUFDLElBQUksQ0FBQyxVQUF1QjtRQUN2Qyw4QkFBOEI7UUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxLQUFLLENBQUMsNENBQTRDLEVBQUU7WUFDekUsTUFBTSxFQUFFLE1BQU07WUFDZCxPQUFPLEVBQUU7Z0JBQ1AsZUFBZSxFQUFFLFVBQVUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUU7Z0JBQ3pELGNBQWMsRUFBRSxrQkFBa0I7YUFDbkM7WUFDRCxJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQztnQkFDbkIsS0FBSyxFQUFFLHVCQUF1QixFQUFHLHNCQUFzQjtnQkFDdkQsUUFBUSxFQUFFO29CQUNSLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsVUFBVSxDQUFDLGFBQWEsRUFBRTtvQkFDckQsR0FBRyxVQUFVLENBQUMsY0FBYztvQkFDNUIsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxVQUFVLENBQUMsV0FBVyxFQUFFO2lCQUNsRDthQUNGLENBQUM7U0FDSCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLFFBQVEsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBQ2xFLENBQUM7UUFFRCxNQUFNLE1BQU0sR0FBRyxNQUFNLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUVyQyxPQUFPO1lBQ0wsSUFBSSxFQUFFLFdBQW9CO1lBQzFCLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPO1NBQzNDLENBQUM7SUFDSixDQUFDO0lBRU0sS0FBSyxDQUFDLEtBQUssQ0FBQyxVQUErQjtRQUNoRCxNQUFNLElBQUksS0FBSyxDQUFDLGtEQUFrRCxDQUFDLENBQUM7SUFDdEUsQ0FBQztDQUNGIn0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@push.rocks/smartai",
3
- "version": "0.0.14",
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.25",
12
+ "@git.zone/tsbuild": "^2.1.84",
13
13
  "@git.zone/tsbundle": "^2.0.5",
14
- "@git.zone/tsrun": "^1.2.46",
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.23",
18
- "@types/node": "^20.12.7"
17
+ "@push.rocks/tapbundle": "^5.3.0",
18
+ "@types/node": "^22.5.5"
19
19
  },
20
20
  "dependencies": {
21
- "@anthropic-ai/sdk": "^0.20.7",
21
+ "@anthropic-ai/sdk": "^0.27.3",
22
22
  "@push.rocks/smartarray": "^1.0.8",
23
- "@push.rocks/smartfile": "^11.0.14",
23
+ "@push.rocks/smartfile": "^11.0.21",
24
24
  "@push.rocks/smartpath": "^5.0.18",
25
- "@push.rocks/smartpdf": "^3.1.5",
26
- "@push.rocks/smartpromise": "^4.0.3",
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.8",
29
- "openai": "^4.38.5"
28
+ "@push.rocks/webstream": "^1.0.10",
29
+ "openai": "^4.62.1"
30
30
  },
31
31
  "repository": {
32
32
  "type": "git",
33
- "url": "git+https://code.foss.global/push.rocks/smartai.git"
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#readme",
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 potentially audio responses.
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 possibly handling audio responses. This documentation will guide you through the process of utilizing `@push.rocks/smartai` in your applications, focusing on TypeScript and ESM syntax to demonstrate its full capabilities.
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 in your project as described in the **Install** section above. Once installed, you can start integrating AI functionalities into your application.
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, including tokens for the AI services you plan to use:
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-access-token',
32
- anthropicToken: 'your-anthropic-access-token'
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
- ### Creating Conversations with AI
89
+ ### Chat Interactions
39
90
 
40
- `SmartAi` provides a flexible interface to create and manage conversations with different AI providers. You can create a conversation with any supported AI provider like OpenAI or Anthropic by specifying the provider you want to use:
91
+ #### Synchronous Chat
92
+
93
+ For simple question-answer interactions:
41
94
 
42
95
  ```typescript
43
- const openAiConversation = await smartAi.createConversation('openai');
44
- const anthropicConversation = await smartAi.createConversation('anthropic');
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
- ### Chatting with AI
105
+ #### Streaming Chat
48
106
 
49
- Once you have a conversation instance, you can start sending messages to the AI and receive responses. Each conversation object provides methods to interact in a synchronous or asynchronous manner, depending on your use case.
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
- #### Synchronous Chat Example
136
+ ### Audio Generation
52
137
 
53
- Here's how you can have a synchronous chat with OpenAI:
138
+ For providers that support audio generation (currently OpenAI):
54
139
 
55
140
  ```typescript
56
- const response = await openAiConversation.chat({
57
- systemMessage: 'This is a greeting from the system.',
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
- console.log(response.message); // Log the response from AI
145
+ // Handle the audio stream (e.g., save to file or play)
63
146
  ```
64
147
 
65
- #### Streaming Chat Example
148
+ ### Document Processing
66
149
 
67
- For real-time, streaming interactions, you can utilize the streaming capabilities provided by the conversation object. This enables a continuous exchange of messages between your application and the AI:
150
+ For providers that support document processing (currently OpenAI):
68
151
 
69
152
  ```typescript
70
- const inputStreamWriter = openAiConversation.getInputStreamWriter();
71
- const outputStream = openAiConversation.getOutputStream();
72
-
73
- inputStreamWriter.write('Hello, AI! Can you stream responses?');
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
- ### Extending Conversations
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
- ### Conclusion
163
+ All providers implement proper error handling. It's recommended to wrap API calls in try-catch blocks:
91
164
 
92
- With `@push.rocks/smartai`, integrating AI functionalities into your applications becomes streamlined and efficient. By leveraging the standardized interface provided by the package, you can easily converse with multiple AI models, expanding the capabilities of your applications with cutting-edge AI features. Whether you're implementing simple chat interactions or complex, real-time communication flows, `@push.rocks/smartai` offers the tools and flexibility needed to create engaging, AI-enhanced experiences.
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
 
@@ -1,8 +1,8 @@
1
1
  /**
2
- * autocreated commitinfo by @pushrocks/commitinfo
2
+ * autocreated commitinfo by @push.rocks/commitinfo
3
3
  */
4
4
  export const commitinfo = {
5
5
  name: '@push.rocks/smartai',
6
- version: '0.0.14',
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
- * starts the model
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
- * stops the model
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
- public abstract chat(optionsArg: {
13
- systemMessage: string,
14
- userMessage: string,
15
- messageHistory: {
16
- role: 'assistant' | 'user';
17
- content: string;
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
- * Defines a streaming interface for chat interactions.
26
- * The implementation will vary based on the specific AI model.
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<string>): Promise<ReadableStream<string>>;
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
  }