@epam/statgpt-dial-toolkit 0.2.0-rc.0 → 0.2.0-rc.2
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/api/chat-streaming-api.d.ts +1 -1
- package/index.cjs +3 -3
- package/index.mjs +23 -21
- package/package.json +2 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { CustomFields, MessageStreamResponse, RequestStreamBody } from '../models/chat-stream';
|
|
2
1
|
import { Message } from '../models/message';
|
|
2
|
+
import { CustomFields, MessageStreamResponse, RequestStreamBody } from '../models/chat-stream';
|
|
3
3
|
import { ModelInfo } from '../models/model';
|
|
4
4
|
interface SSEOptions {
|
|
5
5
|
signal?: AbortSignal;
|
package/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m="v1",R=`/${m}/ops/resource/share`,u={VERSION:`/${m}`,BUCKET:`/${m}/bucket`,CONVERSATIONS:`/${m}/metadata/conversations`,CONVERSATION_BY_ID:s=>`/${m}/metadata/conversations/${s}`,CHAT:s=>`/openai/deployments/${s}/chat/completions`,MODELS:"/openai/models",CONFIGURATION:s=>`/${m}/deployments/${s}/configuration`,SHARE_CONVERSATION:`${R}/create`,SHARE_CONVERSATION_ACCEPT:s=>`/${m}/invitations/${s}?accept=true`,SHARE_CONVERSATION_DETAILS:s=>`/${m}/invitations/${s}`,SHARE_CONVERSATION_LIST:`${R}/list`,SHARE_CONVERSATION_DISCARD:`${R}/discard`,SHARE_CONVERSATION_REVOKE:`${R}/revoke`,RATE:`/${m}/rate`,RENAME:`/${m}/ops/resource/move`};var
|
|
2
|
-
`);e=c.pop()||"";for(const d of c)this.parseSSEDataLine(d,r)}}finally{t.releaseLock()}}handleStreamError(t,r){const e=t instanceof Error?t:new Error(String(t));throw r==null||r(e),e}parseSSEDataLine(t,r){const e=t.trim();if(!(!e||e.startsWith(":"))&&e.startsWith("data: ")){const n=e.slice(6);if(n==="[DONE]"){console.info("SSE: Stream completed");return}try{const o=JSON.parse(n);
|
|
3
|
-
`);return await this.client.request(o,n,{method:"PUT",body:d,headers:M(a),isFormData:!0})}catch(o){if(h(o))return null;throw o}}async getOnboardingFile(t,r){try{const e=`${u.VERSION}/${f(t)}`;return await this.client.getRequest(e,r)}catch(e){if(h(e))return null;throw e}}async getFileBlob(t,r){try{const e=`${u.VERSION}/${f(t)}`;return await this.client.requestBlob(e,r,{method:"GET"})}catch(e){if(h(e))return null;throw e}}async createConversation(t,r){const e=(t==null?void 0:t.id)||N(t),{name:n,folderId:o,model:a,messages:c,custom_fields:d}=t,i={id:e,name:n,folderId:o,model:a,messages:c||[],selectedAddons:t.selectedAddons||[],prompt:t.prompt||"",temperature:t.temperature||.7,createdAt:Date.now(),updatedAt:Date.now(),custom_fields:d};return await this.client.request(S(e),r,{method:"PUT",body:i}),{id:e,name:n,folderId:o,model:a,createdAt:i.createdAt,updatedAt:i.updatedAt}}async generateConversationLink(t,r){return await this.client.postRequest(u.SHARE_CONVERSATION,t,{body:r})}async getSharedConversations(t,r){return await this.client.postRequest(u.SHARE_CONVERSATION_LIST,t,{body:r})}async revokeSharedConversations(t,r){await this.client.postRequest(u.SHARE_CONVERSATION_REVOKE,t,{body:r})}async updateConversation(t,r,e){const n=await this.getConversation(t,e);if(!n)throw new Error(`Conversation with id ${t} not found`);const o={...n,...r,updatedAt:Date.now()};return await this.client.request(S(t),e,{method:"PUT",body:o})}async deleteConversation(t,r){t!=null&&t.isShared?await this.client.postRequest(u.SHARE_CONVERSATION_DISCARD,r,{body:{resources:[{url:t==null?void 0:t.url}]}}):await this.client.request(S(decodeURI(t==null?void 0:t.id)),r,{method:"DELETE"})}async streamChat(t,r){const e=t.model.id,n=encodeURIComponent(e),o=`${u.CHAT(n)}?api-version=${this.client.config.version}`,a={messages:t.messages,stream:!0,temperature:.7,max_tokens:4096,custom_fields:t.custom_fields};return await this.client.stream(o,r,{method:"POST",body:a,chatReference:t.conversationId})}async rateResponse(t,r,e){return await this.client.postRequest(u.RATE,e,{body:{responseId:t,rate:r}})}async renameConversation(t,r,e){return await this.client.postRequest(u.RENAME,e,{body:{sourceUrl:t,destinationUrl:r,overwrite:!0}})}}class
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m="v1",R=`/${m}/ops/resource/share`,u={VERSION:`/${m}`,BUCKET:`/${m}/bucket`,CONVERSATIONS:`/${m}/metadata/conversations`,CONVERSATION_BY_ID:s=>`/${m}/metadata/conversations/${s}`,CHAT:s=>`/openai/deployments/${s}/chat/completions`,MODELS:"/openai/models",CONFIGURATION:s=>`/${m}/deployments/${s}/configuration`,SHARE_CONVERSATION:`${R}/create`,SHARE_CONVERSATION_ACCEPT:s=>`/${m}/invitations/${s}?accept=true`,SHARE_CONVERSATION_DETAILS:s=>`/${m}/invitations/${s}`,SHARE_CONVERSATION_LIST:`${R}/list`,SHARE_CONVERSATION_DISCARD:`${R}/discard`,SHARE_CONVERSATION_REVOKE:`${R}/revoke`,RATE:`/${m}/rate`,RENAME:`/${m}/ops/resource/move`};var O=(s=>(s.CONVERSATION="CONVERSATION",s))(O||{}),_=(s=>(s.ME="me",s.OTHERS="others",s))(_||{}),T=(s=>(s.CSV="text/csv",s.TABLE="application/dial-ttyd-table",s.PLOTLY="application/vnd.plotly.v1+json",s.MARKDOWN="text/markdown",s.JSON="application/json",s.JPEG="image/jpeg",s.PNG="image/png",s.CUSTOM_DATA_GRID="custom_data_grid",s.CUSTOM_CHART="custom_chart",s))(T||{}),I=(s=>(s.LINK="link",s))(I||{});const b=s=>{var t,r,e,n,o,a;return s.content?(console.info(`Using direct content format: ${s.content}`),s.content):(e=(r=(t=s.choices)==null?void 0:t[0])==null?void 0:r.delta)!=null&&e.content?(console.info(`Using OpenAI delta format: ${s.choices[0].delta.content}`),s.choices[0].delta.content):(a=(o=(n=s.choices)==null?void 0:n[0])==null?void 0:o.message)!=null&&a.content?(console.info(`Using complete message format: ${s.choices[0].message.content}`),s.choices[0].message.content):(console.info("Unknown SSE data format:",s),null)},g=(s,t,r)=>{if(t==null||t(s),r){const e=b(s);e&&r(e)}},p=(s,t)=>s.error||s.message||`${t.status} ${t.statusText}`,x=(s,t)=>{const r=s==null?void 0:s.reduce((e,n)=>(e[n.index]=n,e),{});return t.forEach(e=>{r[e.index]?(e.attachments&&(r[e.index].attachments=(r[e.index].attachments||[]).concat(e.attachments)),e.content&&(r[e.index].content=(r[e.index].content||"")+e.content),e.name&&(r[e.index].name=(r[e.index].name||"")+e.name),e.status&&(r[e.index].status=e.status)):r[e.index]=e}),Object.values(r)},P=(s,t)=>{const r=structuredClone(s);return t.forEach(e=>{e.errorMessage&&(r.errorMessage=e.errorMessage),e.role&&(r.role=e.role),e.responseId&&(r.responseId=e.responseId),e.content&&(r.content=`${r.content||""}${e.content}`),e.custom_content&&(r.custom_content||(r.custom_content={}),e.custom_content.attachments&&(r.custom_content.attachments||(r.custom_content.attachments=[]),r.custom_content.attachments=r.custom_content.attachments.concat(e.custom_content.attachments)),e.custom_content.stages&&(r.custom_content.stages||(r.custom_content.stages=[]),r.custom_content.stages=x(r.custom_content.stages,e.custom_content.stages)),e.custom_content.state&&(r.custom_content.state=e.custom_content.state),e.custom_content.form_schema&&(r.custom_content.form_schema=e.custom_content.form_schema),e.custom_content.form_value&&(r.custom_content.form_value=e.custom_content.form_value))}),r},V={CHAT:"/api/chat"},H="application/json",D="Content-Type",A="Api-Key",L="X-CONVERSATION-ID",U=s=>(s==null?void 0:s.toLowerCase().replace(/[^\p{L}\p{N}]+/gu,"-").replace(/^-+|-+$/g,"").replace(/-/g," "))||"",C=(s,t,r)=>{const e={[D]:(t==null?void 0:t.contentType)||H};return t!=null&&t.jwt?e.Authorization=`Bearer ${t.jwt}`:s&&(e[A]=s),t!=null&&t.chatReference&&(e[L]=t.chatReference),{...e,...r}},j=s=>{const t={...s};return t[A]&&(t[A]=t[A].substring(0,8)+"...[REDACTED]"),t.Authorization&&(t.Authorization="Bearer [REDACTED]"),t},M=s=>({"Content-Type":`multipart/form-data; boundary=${s}`}),$=s=>{var n;const t=((n=s.name)==null?void 0:n.split("__"))||[],r=t.length>1?t.slice(1).join("__"):s.name;return{modelId:t[0],conversationName:r}},N=s=>{const t=Date.now(),r=U(s.name);return`${s.folderId}/${r}-${t}`},k=s=>({resourceTypes:[O.CONVERSATION],with:s}),E=async(s,t,r)=>await fetch(s,{method:r.method||"GET",headers:t,body:r!=null&&r.isFormData&&typeof(r==null?void 0:r.body)=="string"?r.body:JSON.stringify(r.body),signal:r==null?void 0:r.signal});function f(s){return s.split("/").map(t=>encodeURIComponent(t)).join("/")}function F(s){return s.split("/").map(t=>decodeURIComponent(t)).join("/")}class w{constructor(){this.decoder=new TextDecoder}async streamChat(t,r,e={},n){const{onMessage:o,onError:a,onComplete:c,signal:d}=e;try{const i=await this.initializeStreamRequest(t,r,d,n);await this.processStreamData(i,o),c==null||c()}catch(i){this.handleStreamError(i,a)}}async initializeStreamRequest(t,r,e,n){const o=C(void 0,{jwt:n}),a=await E(t,{Accept:"text/event-stream",...o},{method:"POST",body:r,signal:e});if(!a.ok){const c=await a.text();throw new Error(JSON.stringify({status:a.status,message:c}))}if(!a.body)throw new Error("No response body");return a.body.getReader()}async processStreamData(t,r){let e="";try{for(;;){const{done:n,value:o}=await t.read();if(n){e.trim()&&this.parseSSEDataLine(e,r);break}const a=this.decoder.decode(o,{stream:!0});e+=a;const c=e.split(`
|
|
2
|
+
`);e=c.pop()||"";for(const d of c)this.parseSSEDataLine(d,r)}}finally{t.releaseLock()}}handleStreamError(t,r){const e=t instanceof Error?t:new Error(String(t));throw r==null||r(e),e}parseSSEDataLine(t,r){const e=t.trim();if(!(!e||e.startsWith(":"))&&e.startsWith("data: ")){const n=e.slice(6);if(n==="[DONE]"){console.info("SSE: Stream completed");return}try{const o=JSON.parse(n);r==null||r(o)}catch(o){console.error(`Failed to parse SSE data: ${n} ${o}`)}}}}const q=new w,K=async(s,t,r,e,n)=>{const{onMessage:o,onToken:a,onComplete:c,onError:d,model:i,signal:l}=r,y={conversationId:s,messages:t,model:i,custom_fields:n};await q.streamChat(V.CHAT,y,{onMessage:v=>g(v,o,a),onComplete:c,onError:d,signal:l},e)},h=s=>s instanceof Error&&s.message.includes("404"),S=s=>`/v1/conversations/${f(s)}`;class B{constructor(t){this.client=t}async getConversations(t,r,e){const n=`${r?e?`${r}/${e}`:`${r}`:""}`,o=`${u.CONVERSATIONS}/${n}`;try{return(await this.client.getRequest(o+"/?limit=1000&recursive=false",t).then(c=>c.items||[])).map(c=>{var l;const{conversationName:d,modelId:i}=$(c);return{id:((l=c.url)==null?void 0:l.replace("conversations/",""))||c.name,name:d,folderId:n,createdAt:c.createdAt,updatedAt:c.updatedAt,model:{id:i,name:i}}})}catch(a){if(h(a))return[];throw a}}async getConversation(t,r){try{return await this.client.getRequest(S(t),r)}catch(e){if(h(e))return null;throw e}}async getFile(t,r){try{const e=`${u.VERSION}/${f(t)}`;return await this.client.getRequest(e,r)}catch(e){if(h(e))return null;throw e}}async putOnboardingFile(t,r,e,n){try{const o=`${u.VERSION}/${f(r)}`,a="----NodeMultipartBoundary",d=[`--${a}`,`Content-Disposition: form-data; name="file"; filename="${t}"`,"Content-Type: application/json","",JSON.stringify(e),`--${a}--`,""].join(`\r
|
|
3
|
+
`);return await this.client.request(o,n,{method:"PUT",body:d,headers:M(a),isFormData:!0})}catch(o){if(h(o))return null;throw o}}async getOnboardingFile(t,r){try{const e=`${u.VERSION}/${f(t)}`;return await this.client.getRequest(e,r)}catch(e){if(h(e))return null;throw e}}async getFileBlob(t,r){try{const e=`${u.VERSION}/${f(t)}`;return await this.client.requestBlob(e,r,{method:"GET"})}catch(e){if(h(e))return null;throw e}}async createConversation(t,r){const e=(t==null?void 0:t.id)||N(t),{name:n,folderId:o,model:a,messages:c,custom_fields:d}=t,i={id:e,name:n,folderId:o,model:a,messages:c||[],selectedAddons:t.selectedAddons||[],prompt:t.prompt||"",temperature:t.temperature||.7,createdAt:Date.now(),updatedAt:Date.now(),custom_fields:d};return await this.client.request(S(e),r,{method:"PUT",body:i}),{id:e,name:n,folderId:o,model:a,createdAt:i.createdAt,updatedAt:i.updatedAt}}async generateConversationLink(t,r){return await this.client.postRequest(u.SHARE_CONVERSATION,t,{body:r})}async getSharedConversations(t,r){return await this.client.postRequest(u.SHARE_CONVERSATION_LIST,t,{body:r})}async revokeSharedConversations(t,r){await this.client.postRequest(u.SHARE_CONVERSATION_REVOKE,t,{body:r})}async updateConversation(t,r,e){const n=await this.getConversation(t,e);if(!n)throw new Error(`Conversation with id ${t} not found`);const o={...n,...r,updatedAt:Date.now()};return await this.client.request(S(t),e,{method:"PUT",body:o})}async deleteConversation(t,r){t!=null&&t.isShared?await this.client.postRequest(u.SHARE_CONVERSATION_DISCARD,r,{body:{resources:[{url:t==null?void 0:t.url}]}}):await this.client.request(S(decodeURI(t==null?void 0:t.id)),r,{method:"DELETE"})}async streamChat(t,r){const e=t.model.id,n=encodeURIComponent(e),o=`${u.CHAT(n)}?api-version=${this.client.config.version}`,a={messages:t.messages,stream:!0,temperature:.7,max_tokens:4096,custom_fields:t.custom_fields};return await this.client.stream(o,r,{method:"POST",body:a,chatReference:t.conversationId})}async rateResponse(t,r,e){return await this.client.postRequest(u.RATE,e,{body:{responseId:t,rate:r}})}async renameConversation(t,r,e){return await this.client.postRequest(u.RENAME,e,{body:{sourceUrl:t,destinationUrl:r,overwrite:!0}})}}class J{constructor(t){this.config=t,console.info("DialApiClient initialized",{host:t.host||"NOT SET",hasApiKey:!!t.apiKey,version:t.version})}async getRequest(t,r,e){return this.request(t,r,{...e,method:"GET"})}async postRequest(t,r,e){return this.request(t,r,{...e,method:"POST"})}async requestBlob(t,r,e){const n=`${this.config.host}${t}`,o={...C(this.config.apiKey,{jwt:r,chatReference:e.chatReference}),...e.headers};try{return(await E(n,o,e)).blob()}catch(a){throw console.error("API Request Exception",{method:e.method,url:n,error:a instanceof Error?a.message:String(a)}),a}}async request(t,r,e){const n=Date.now(),o=`${this.config.host}${t}`,a={...C(this.config.apiKey,{jwt:r,chatReference:e.chatReference}),...e.headers};this.addInfoRequestLog("API Request",o,e,a);try{const c=await E(o,a,e),d=Date.now()-n;let i;const l=await c.text();try{i=l?JSON.parse(l):{}}catch{if(this.addErrorRequestParsing(o,e,c,d,l),!c.ok)throw new Error(`API request failed: ${c.status} ${c.statusText} - ${l.substring(0,100)}`);i={data:l}}if(!c.ok){this.addErrorRequestLog(o,e,c,d,i);const y=p(i,c);throw new Error(`API request failed: ${y}`)}return i}catch(c){const d=Date.now()-n;throw console.error("API Request Exception",{method:e.method,url:o,duration:`${d}ms`,error:c instanceof Error?c.message:String(c)}),c}}async stream(t,r,e){const n=`${this.config.host}${t}`,o=C(this.config.apiKey,{jwt:r,chatReference:e.chatReference},e.headers);this.addInfoRequestLog("Stream Request",n,e,o);const a=await E(n,o,e);if(!a.ok)throw console.error("Stream Request Failed",{method:e.method||"POST",url:n,status:a.status,statusText:a.statusText}),new Error(`Stream request failed: ${a.status} ${a.statusText}`);if(!a.body)throw new Error("No response body for stream");return a.body}addInfoRequestLog(t,r,e,n){const o={method:e.method||"GET",url:r,headers:j(n)};e.body&&(o.body=e.body),console.info(t,o)}addErrorRequestLog(t,r,e,n,o){console.error("API Request Failed",{method:r.method,url:t,status:e.status,statusText:e.statusText,duration:`${n}ms`,response:o})}addErrorRequestParsing(t,r,e,n,o){console.error("API Response Parse Error",{method:r.method,url:t,status:e.status,statusText:e.statusText,duration:`${n}ms`,responseText:o.substring(0,200),error:"Response is not valid JSON"})}}exports.AttachmentType=T;exports.ChatStreamSSEClient=w;exports.ConversationApi=B;exports.DIAL_API_ROUTES=u;exports.DialApiClient=J;exports.InvitationType=I;exports.ResourceTypes=O;exports.ShareTarget=_;exports.chatStreamSSEClient=q;exports.decodeApiUrl=F;exports.encodeApiUrl=f;exports.generateConversationId=N;exports.getErrorMessage=p;exports.getSharedConversationsRequest=k;exports.handleStreamMessage=g;exports.mergeMessages=P;exports.parseConversationName=$;exports.sendRequest=E;exports.streamChatResponse=K;
|
package/index.mjs
CHANGED
|
@@ -15,7 +15,7 @@ const E = "/v1/ops/resource/share", u = {
|
|
|
15
15
|
RATE: "/v1/rate",
|
|
16
16
|
RENAME: "/v1/ops/resource/move"
|
|
17
17
|
};
|
|
18
|
-
var I = /* @__PURE__ */ ((s) => (s.CONVERSATION = "CONVERSATION", s))(I || {}),
|
|
18
|
+
var I = /* @__PURE__ */ ((s) => (s.CONVERSATION = "CONVERSATION", s))(I || {}), y = /* @__PURE__ */ ((s) => (s.ME = "me", s.OTHERS = "others", s))(y || {}), _ = /* @__PURE__ */ ((s) => (s.CSV = "text/csv", s.TABLE = "application/dial-ttyd-table", s.PLOTLY = "application/vnd.plotly.v1+json", s.MARKDOWN = "text/markdown", s.JSON = "application/json", s.JPEG = "image/jpeg", s.PNG = "image/png", s.CUSTOM_DATA_GRID = "custom_data_grid", s.CUSTOM_CHART = "custom_chart", s))(_ || {}), C = /* @__PURE__ */ ((s) => (s.LINK = "link", s))(C || {});
|
|
19
19
|
const T = (s) => {
|
|
20
20
|
var t, r, e, n, o, c;
|
|
21
21
|
return s.content ? (console.info(`Using direct content format: ${s.content}`), s.content) : (e = (r = (t = s.choices) == null ? void 0 : t[0]) == null ? void 0 : r.delta) != null && e.content ? (console.info(`Using OpenAI delta format: ${s.choices[0].delta.content}`), s.choices[0].delta.content) : (c = (o = (n = s.choices) == null ? void 0 : n[0]) == null ? void 0 : o.message) != null && c.content ? (console.info(
|
|
@@ -110,7 +110,9 @@ class D {
|
|
|
110
110
|
);
|
|
111
111
|
if (!c.ok) {
|
|
112
112
|
const a = await c.text();
|
|
113
|
-
throw new Error(
|
|
113
|
+
throw new Error(
|
|
114
|
+
JSON.stringify({ status: c.status, message: a })
|
|
115
|
+
);
|
|
114
116
|
}
|
|
115
117
|
if (!c.body)
|
|
116
118
|
throw new Error("No response body");
|
|
@@ -151,7 +153,7 @@ class D {
|
|
|
151
153
|
}
|
|
152
154
|
try {
|
|
153
155
|
const o = JSON.parse(n);
|
|
154
|
-
|
|
156
|
+
r == null || r(o);
|
|
155
157
|
} catch (o) {
|
|
156
158
|
console.error(`Failed to parse SSE data: ${n} ${o}`);
|
|
157
159
|
}
|
|
@@ -159,7 +161,7 @@ class D {
|
|
|
159
161
|
}
|
|
160
162
|
}
|
|
161
163
|
const U = new D(), K = async (s, t, r, e, n) => {
|
|
162
|
-
const { onMessage: o, onToken: c, onComplete: a, onError: d, model: i, signal:
|
|
164
|
+
const { onMessage: o, onToken: c, onComplete: a, onError: d, model: i, signal: m } = r, A = {
|
|
163
165
|
conversationId: s,
|
|
164
166
|
messages: t,
|
|
165
167
|
model: i,
|
|
@@ -172,11 +174,11 @@ const U = new D(), K = async (s, t, r, e, n) => {
|
|
|
172
174
|
onMessage: (N) => $(N, o, c),
|
|
173
175
|
onComplete: a,
|
|
174
176
|
onError: d,
|
|
175
|
-
signal:
|
|
177
|
+
signal: m
|
|
176
178
|
},
|
|
177
179
|
e
|
|
178
180
|
);
|
|
179
|
-
},
|
|
181
|
+
}, l = (s) => s instanceof Error && s.message.includes("404"), R = (s) => `/v1/conversations/${h(s)}`;
|
|
180
182
|
class B {
|
|
181
183
|
constructor(t) {
|
|
182
184
|
this.client = t;
|
|
@@ -185,10 +187,10 @@ class B {
|
|
|
185
187
|
const n = `${r ? e ? `${r}/${e}` : `${r}` : ""}`, o = `${u.CONVERSATIONS}/${n}`;
|
|
186
188
|
try {
|
|
187
189
|
return (await this.client.getRequest(o + "/?limit=1000&recursive=false", t).then((a) => a.items || [])).map((a) => {
|
|
188
|
-
var
|
|
190
|
+
var m;
|
|
189
191
|
const { conversationName: d, modelId: i } = H(a);
|
|
190
192
|
return {
|
|
191
|
-
id: ((
|
|
193
|
+
id: ((m = a.url) == null ? void 0 : m.replace("conversations/", "")) || a.name,
|
|
192
194
|
name: d,
|
|
193
195
|
folderId: n,
|
|
194
196
|
createdAt: a.createdAt,
|
|
@@ -197,7 +199,7 @@ class B {
|
|
|
197
199
|
};
|
|
198
200
|
});
|
|
199
201
|
} catch (c) {
|
|
200
|
-
if (
|
|
202
|
+
if (l(c))
|
|
201
203
|
return [];
|
|
202
204
|
throw c;
|
|
203
205
|
}
|
|
@@ -209,7 +211,7 @@ class B {
|
|
|
209
211
|
r
|
|
210
212
|
);
|
|
211
213
|
} catch (e) {
|
|
212
|
-
if (
|
|
214
|
+
if (l(e))
|
|
213
215
|
return null;
|
|
214
216
|
throw e;
|
|
215
217
|
}
|
|
@@ -219,7 +221,7 @@ class B {
|
|
|
219
221
|
const e = `${u.VERSION}/${h(t)}`;
|
|
220
222
|
return await this.client.getRequest(e, r);
|
|
221
223
|
} catch (e) {
|
|
222
|
-
if (
|
|
224
|
+
if (l(e))
|
|
223
225
|
return null;
|
|
224
226
|
throw e;
|
|
225
227
|
}
|
|
@@ -243,7 +245,7 @@ class B {
|
|
|
243
245
|
isFormData: !0
|
|
244
246
|
});
|
|
245
247
|
} catch (o) {
|
|
246
|
-
if (
|
|
248
|
+
if (l(o))
|
|
247
249
|
return null;
|
|
248
250
|
throw o;
|
|
249
251
|
}
|
|
@@ -253,7 +255,7 @@ class B {
|
|
|
253
255
|
const e = `${u.VERSION}/${h(t)}`;
|
|
254
256
|
return await this.client.getRequest(e, r);
|
|
255
257
|
} catch (e) {
|
|
256
|
-
if (
|
|
258
|
+
if (l(e))
|
|
257
259
|
return null;
|
|
258
260
|
throw e;
|
|
259
261
|
}
|
|
@@ -263,7 +265,7 @@ class B {
|
|
|
263
265
|
const e = `${u.VERSION}/${h(t)}`;
|
|
264
266
|
return await this.client.requestBlob(e, r, { method: "GET" });
|
|
265
267
|
} catch (e) {
|
|
266
|
-
if (
|
|
268
|
+
if (l(e))
|
|
267
269
|
return null;
|
|
268
270
|
throw e;
|
|
269
271
|
}
|
|
@@ -440,21 +442,21 @@ class M {
|
|
|
440
442
|
try {
|
|
441
443
|
const a = await O(o, c, e), d = Date.now() - n;
|
|
442
444
|
let i;
|
|
443
|
-
const
|
|
445
|
+
const m = await a.text();
|
|
444
446
|
try {
|
|
445
|
-
i =
|
|
447
|
+
i = m ? JSON.parse(m) : {};
|
|
446
448
|
} catch {
|
|
447
449
|
if (this.addErrorRequestParsing(
|
|
448
450
|
o,
|
|
449
451
|
e,
|
|
450
452
|
a,
|
|
451
453
|
d,
|
|
452
|
-
|
|
454
|
+
m
|
|
453
455
|
), !a.ok)
|
|
454
456
|
throw new Error(
|
|
455
|
-
`API request failed: ${a.status} ${a.statusText} - ${
|
|
457
|
+
`API request failed: ${a.status} ${a.statusText} - ${m.substring(0, 100)}`
|
|
456
458
|
);
|
|
457
|
-
i = { data:
|
|
459
|
+
i = { data: m };
|
|
458
460
|
}
|
|
459
461
|
if (!a.ok) {
|
|
460
462
|
this.addErrorRequestLog(o, e, a, d, i);
|
|
@@ -528,14 +530,14 @@ class M {
|
|
|
528
530
|
}
|
|
529
531
|
}
|
|
530
532
|
export {
|
|
531
|
-
|
|
533
|
+
_ as AttachmentType,
|
|
532
534
|
D as ChatStreamSSEClient,
|
|
533
535
|
B as ConversationApi,
|
|
534
536
|
u as DIAL_API_ROUTES,
|
|
535
537
|
M as DialApiClient,
|
|
536
538
|
C as InvitationType,
|
|
537
539
|
I as ResourceTypes,
|
|
538
|
-
|
|
540
|
+
y as ShareTarget,
|
|
539
541
|
U as chatStreamSSEClient,
|
|
540
542
|
F as decodeApiUrl,
|
|
541
543
|
h as encodeApiUrl,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@epam/statgpt-dial-toolkit",
|
|
3
|
-
"version": "0.2.0-rc.
|
|
3
|
+
"version": "0.2.0-rc.2",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"exports": {
|
|
6
6
|
".": {
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"module": "./index.mjs",
|
|
15
15
|
"types": "./index.d.ts",
|
|
16
16
|
"dependencies": {
|
|
17
|
-
"@epam/statgpt-shared-toolkit": "0.2.0-rc.
|
|
17
|
+
"@epam/statgpt-shared-toolkit": "0.2.0-rc.2",
|
|
18
18
|
"@epam/ai-dial-shared": "^0.34.0"
|
|
19
19
|
}
|
|
20
20
|
}
|