@sogni-ai/sogni-client 4.0.0-alpha.11 → 4.0.0-alpha.13

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.
Files changed (44) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/Account/index.d.ts +1 -0
  3. package/dist/Account/index.js +11 -2
  4. package/dist/Account/index.js.map +1 -1
  5. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/BrowserWebSocketClient.d.ts +34 -0
  6. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/BrowserWebSocketClient.js +195 -0
  7. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/BrowserWebSocketClient.js.map +1 -0
  8. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/WSCoordinator.d.ts +101 -0
  9. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/WSCoordinator.js +359 -0
  10. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/WSCoordinator.js.map +1 -0
  11. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/types.d.ts +101 -0
  12. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/types.js +3 -0
  13. package/dist/ApiClient/WebSocketClient/BrowserWebSocketClient/types.js.map +1 -0
  14. package/dist/ApiClient/WebSocketClient/events.d.ts +1 -0
  15. package/dist/ApiClient/WebSocketClient/index.d.ts +2 -2
  16. package/dist/ApiClient/WebSocketClient/types.d.ts +13 -0
  17. package/dist/ApiClient/index.d.ts +2 -3
  18. package/dist/ApiClient/index.js +20 -2
  19. package/dist/ApiClient/index.js.map +1 -1
  20. package/dist/Projects/Job.d.ts +1 -1
  21. package/dist/Projects/index.d.ts +3 -9
  22. package/dist/Projects/index.js +3 -1
  23. package/dist/Projects/index.js.map +1 -1
  24. package/dist/Projects/types/EstimationResponse.d.ts +2 -0
  25. package/dist/Projects/types/index.d.ts +13 -0
  26. package/dist/index.d.ts +1 -1
  27. package/dist/index.js +6 -2
  28. package/dist/index.js.map +1 -1
  29. package/dist/lib/DataEntity.js +4 -2
  30. package/dist/lib/DataEntity.js.map +1 -1
  31. package/package.json +1 -1
  32. package/src/Account/index.ts +11 -2
  33. package/src/ApiClient/WebSocketClient/BrowserWebSocketClient/BrowserWebSocketClient.ts +206 -0
  34. package/src/ApiClient/WebSocketClient/BrowserWebSocketClient/WSCoordinator.ts +425 -0
  35. package/src/ApiClient/WebSocketClient/BrowserWebSocketClient/types.ts +107 -0
  36. package/src/ApiClient/WebSocketClient/events.ts +2 -0
  37. package/src/ApiClient/WebSocketClient/index.ts +2 -2
  38. package/src/ApiClient/WebSocketClient/types.ts +16 -0
  39. package/src/ApiClient/index.ts +25 -6
  40. package/src/Projects/index.ts +5 -2
  41. package/src/Projects/types/EstimationResponse.ts +2 -0
  42. package/src/Projects/types/index.ts +14 -0
  43. package/src/index.ts +7 -3
  44. package/src/lib/DataEntity.ts +4 -2
@@ -0,0 +1,359 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ const getUUID_1 = __importDefault(require("../../../lib/getUUID"));
16
+ class WSCoordinator {
17
+ constructor(callbacks, logger) {
18
+ this._isConnected = false;
19
+ this.lastPrimaryHeartbeat = 0;
20
+ this.heartbeatInterval = null;
21
+ this.primaryCheckInterval = null;
22
+ this.startingEvents = {};
23
+ this.ackCallbacks = {};
24
+ /**
25
+ * Handle tab closing event
26
+ */
27
+ this.handleBeforeUnload = () => {
28
+ if (this._isPrimary) {
29
+ this.logger.info(`Client ${this.id} closing, releasing primary role`);
30
+ this.releasePrimary();
31
+ }
32
+ };
33
+ this.id = (0, getUUID_1.default)();
34
+ this.logger = logger;
35
+ this.callbacks = callbacks;
36
+ this.channel = new BroadcastChannel(WSCoordinator.CHANNEL_NAME);
37
+ this.channel.onmessage = this.handleMessage.bind(this);
38
+ this._isPrimary = false;
39
+ // Listen for tab closing to gracefully release primary role
40
+ if (typeof window !== 'undefined') {
41
+ window.addEventListener('beforeunload', this.handleBeforeUnload.bind(this));
42
+ }
43
+ }
44
+ /**
45
+ * Initialize tab coordination and determine role
46
+ */
47
+ initialize() {
48
+ return __awaiter(this, void 0, void 0, function* () {
49
+ this.logger.info(`WSCoordinator ${this.id} initializing...`);
50
+ // Announce our presence
51
+ this.broadcast({
52
+ type: 'announce'
53
+ });
54
+ // Wait to see if there's an existing primary
55
+ yield this.waitForPrimaryResponse();
56
+ if (!this._isPrimary) {
57
+ this.logger.info(`Client ${this.id} is secondary, primary exists`);
58
+ this.startPrimaryCheck();
59
+ }
60
+ else {
61
+ this.logger.info(`Client ${this.id} becoming primary`);
62
+ this.becomePrimary();
63
+ }
64
+ return this._isPrimary;
65
+ });
66
+ }
67
+ connect() {
68
+ if (this._isPrimary) {
69
+ throw new Error('Primary should connect the socket directly.');
70
+ }
71
+ this.broadcast({
72
+ type: 'connection-toggle',
73
+ payload: { connected: true }
74
+ });
75
+ }
76
+ disconnect() {
77
+ if (this._isPrimary) {
78
+ throw new Error('Primary should disconnect socket directly.');
79
+ }
80
+ this.broadcast({
81
+ type: 'connection-toggle',
82
+ payload: { connected: false }
83
+ });
84
+ }
85
+ changeAuthState(isAuthenticated) {
86
+ return __awaiter(this, void 0, void 0, function* () {
87
+ this.broadcast({
88
+ type: 'authentication',
89
+ payload: { authenticated: isAuthenticated }
90
+ });
91
+ });
92
+ }
93
+ /**
94
+ * Wait briefly to see if a primary tab responds
95
+ */
96
+ waitForPrimaryResponse() {
97
+ return new Promise((resolve) => {
98
+ const timeout = setTimeout(() => {
99
+ // No primary responded, we become primary
100
+ this._isPrimary = true;
101
+ resolve();
102
+ }, 500);
103
+ const messageHandler = (e) => {
104
+ const envelope = e.data;
105
+ const message = envelope.payload;
106
+ if (message.type === 'primary-present' || message.type === 'primary-claim') {
107
+ // Primary exists
108
+ this._isPrimary = false;
109
+ this.lastPrimaryHeartbeat = envelope.timestamp;
110
+ clearTimeout(timeout);
111
+ this.channel.removeEventListener('message', messageHandler);
112
+ resolve();
113
+ }
114
+ };
115
+ this.channel.addEventListener('message', messageHandler);
116
+ });
117
+ }
118
+ /**
119
+ * Become the primary tab
120
+ */
121
+ becomePrimary() {
122
+ this._isPrimary = true;
123
+ this.callbacks.onRoleChange(true);
124
+ // Broadcast that we're claiming primary role
125
+ this.broadcast({
126
+ type: 'primary-claim'
127
+ });
128
+ // Start sending heartbeats
129
+ this.startHeartbeat();
130
+ }
131
+ /**
132
+ * Release primary role (when closing)
133
+ */
134
+ releasePrimary() {
135
+ if (this._isPrimary) {
136
+ this.broadcast({
137
+ type: 'primary-release'
138
+ });
139
+ this.stopHeartbeat();
140
+ }
141
+ }
142
+ /**
143
+ * Start sending heartbeat messages as primary
144
+ */
145
+ startHeartbeat() {
146
+ if (this.heartbeatInterval)
147
+ throw new Error('Heartbeat interval already started. This should never happen.');
148
+ this.heartbeatInterval = setInterval(() => {
149
+ this.broadcast({
150
+ type: 'primary-present',
151
+ payload: { connected: this._isConnected }
152
+ });
153
+ }, WSCoordinator.HEARTBEAT_INTERVAL);
154
+ }
155
+ /**
156
+ * Stop sending heartbeat messages
157
+ */
158
+ stopHeartbeat() {
159
+ if (this.heartbeatInterval) {
160
+ clearInterval(this.heartbeatInterval);
161
+ this.heartbeatInterval = null;
162
+ }
163
+ }
164
+ /**
165
+ * Start checking for primary heartbeat (as secondary)
166
+ */
167
+ startPrimaryCheck() {
168
+ this.primaryCheckInterval = setInterval(() => {
169
+ const timeSinceLastHeartbeat = Date.now() - this.lastPrimaryHeartbeat;
170
+ if (timeSinceLastHeartbeat > WSCoordinator.PRIMARY_TIMEOUT) {
171
+ this.logger.warn(`Primary tab timeout, becoming primary`);
172
+ this.stopPrimaryCheck();
173
+ this.becomePrimary();
174
+ }
175
+ }, 1000);
176
+ }
177
+ /**
178
+ * Stop checking for primary heartbeat
179
+ */
180
+ stopPrimaryCheck() {
181
+ if (this.primaryCheckInterval) {
182
+ clearInterval(this.primaryCheckInterval);
183
+ this.primaryCheckInterval = null;
184
+ }
185
+ }
186
+ handleMessage(e) {
187
+ const envelope = e.data;
188
+ const message = envelope.payload;
189
+ // If a message sent to specific recipient and not to us, ignore it
190
+ if (!!envelope.recipientId && envelope.recipientId !== this.id) {
191
+ return;
192
+ }
193
+ switch (message.type) {
194
+ case 'announce':
195
+ if (this._isPrimary) {
196
+ this.broadcast({
197
+ type: 'primary-present',
198
+ payload: { connected: this._isConnected }
199
+ });
200
+ // Re-broadcast starting events for the new tab
201
+ Object.entries(this.startingEvents).forEach(([eventType, payload]) => {
202
+ this.broadcast({
203
+ type: 'socket-event',
204
+ payload: { eventType: eventType, payload }
205
+ }, envelope.senderId);
206
+ });
207
+ }
208
+ return;
209
+ case 'primary-claim':
210
+ case 'primary-present':
211
+ this.lastPrimaryHeartbeat = envelope.timestamp;
212
+ if (this._isPrimary) {
213
+ this.logger.info(`Stepping down from primary, ${envelope.senderId} claimed it`);
214
+ this.stopHeartbeat();
215
+ this._isPrimary = false;
216
+ this.callbacks.onRoleChange(false);
217
+ this.startPrimaryCheck();
218
+ }
219
+ return;
220
+ case 'primary-release':
221
+ if (!this._isPrimary) {
222
+ // Wait random time (0 - 300ms) before claiming "primary" role, so not all tabs try to claim at the same time
223
+ setTimeout(() => {
224
+ const timeSinceRelease = Date.now() - envelope.timestamp;
225
+ const timeSinceLastHeartbeat = Date.now() - this.lastPrimaryHeartbeat;
226
+ if (timeSinceLastHeartbeat > timeSinceRelease) {
227
+ this.logger.info(`Primary released, becoming primary`);
228
+ this.stopPrimaryCheck();
229
+ this.becomePrimary();
230
+ }
231
+ else {
232
+ this.logger.info(`Another primary exists, do nothing`);
233
+ }
234
+ }, Math.round(Math.random() * 300));
235
+ }
236
+ return;
237
+ case 'authentication':
238
+ this.callbacks.onAuthChanged(message.payload.authenticated);
239
+ return;
240
+ case 'connection-toggle':
241
+ if (this._isPrimary) {
242
+ this.logger.info(`Should ${message.payload.connected ? 'connect' : 'disconnect'} socket.`);
243
+ this.callbacks.onConnectionToggle(message.payload.connected);
244
+ }
245
+ return;
246
+ case 'socket-event': {
247
+ if (!this._isPrimary) {
248
+ this.callbacks.onMessageFromPrimary(message);
249
+ }
250
+ return;
251
+ }
252
+ case 'socket-send': {
253
+ if (this._isPrimary) {
254
+ this.callbacks.onSendRequest(message).then(() => {
255
+ //Acknowledge the request
256
+ this.broadcast({
257
+ type: 'socket-ack',
258
+ payload: {
259
+ envelopeId: envelope.id
260
+ }
261
+ });
262
+ });
263
+ }
264
+ return;
265
+ }
266
+ case 'socket-ack': {
267
+ if (!this._isPrimary) {
268
+ if (this.ackCallbacks[message.payload.envelopeId]) {
269
+ this.ackCallbacks[message.payload.envelopeId]();
270
+ }
271
+ }
272
+ }
273
+ }
274
+ }
275
+ broadcast(message, recipientId) {
276
+ const envelope = {
277
+ id: (0, getUUID_1.default)(),
278
+ senderId: this.id,
279
+ timestamp: Date.now(),
280
+ payload: message
281
+ };
282
+ if (recipientId) {
283
+ envelope.recipientId = recipientId;
284
+ }
285
+ this.channel.postMessage(envelope);
286
+ return envelope.id;
287
+ }
288
+ /**
289
+ * Send a message to be transmitted over the socket (from secondary to primary)
290
+ */
291
+ sendToSocket(messageType, data) {
292
+ if (this._isPrimary) {
293
+ throw new Error('Primary tab should send directly');
294
+ }
295
+ this.logger.debug(`Sending socket message ${messageType}`, data);
296
+ const messageId = this.broadcast({
297
+ type: 'socket-send',
298
+ payload: { messageType, data }
299
+ });
300
+ return new Promise((resolve, reject) => {
301
+ const ackTimeout = setTimeout(() => {
302
+ //If callback is not called within 5 seconds, call it with an error
303
+ if (this.ackCallbacks[messageId]) {
304
+ this.ackCallbacks[messageId](new Error('Message delivery timeout'));
305
+ }
306
+ }, WSCoordinator.ACK_TIMEOUT);
307
+ this.ackCallbacks[messageId] = (error) => {
308
+ delete this.ackCallbacks[messageId];
309
+ clearTimeout(ackTimeout);
310
+ if (error) {
311
+ reject(error);
312
+ }
313
+ else {
314
+ resolve();
315
+ }
316
+ };
317
+ });
318
+ }
319
+ /**
320
+ * Broadcast a socket event from primary to all secondaries
321
+ */
322
+ broadcastSocketEvent(eventType, payload) {
323
+ if (!this._isPrimary) {
324
+ throw new Error('Only primary tab can broadcast socket events');
325
+ }
326
+ if (eventType === 'connected') {
327
+ this._isConnected = true;
328
+ }
329
+ else if (eventType === 'disconnected') {
330
+ this._isConnected = false;
331
+ }
332
+ this.updateStartingState(eventType, payload);
333
+ this.logger.debug(`Broadcasting socket event ${eventType}`, payload);
334
+ this.broadcast({
335
+ type: 'socket-event',
336
+ payload: { eventType, payload }
337
+ });
338
+ }
339
+ updateStartingState(eventType, payload) {
340
+ if (eventType === 'authenticated') {
341
+ this.startingEvents.authenticated = payload;
342
+ }
343
+ else if (eventType === 'balanceUpdate') {
344
+ this.startingEvents.balanceUpdate = payload;
345
+ }
346
+ else if (eventType === 'swarmModels') {
347
+ this.startingEvents.swarmModels = payload;
348
+ }
349
+ }
350
+ isPrimary() {
351
+ return this._isPrimary;
352
+ }
353
+ }
354
+ WSCoordinator.HEARTBEAT_INTERVAL = 2000;
355
+ WSCoordinator.PRIMARY_TIMEOUT = 3000;
356
+ WSCoordinator.CHANNEL_NAME = 'sogni-websocket-clients';
357
+ WSCoordinator.ACK_TIMEOUT = 5000;
358
+ exports.default = WSCoordinator;
359
+ //# sourceMappingURL=WSCoordinator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WSCoordinator.js","sourceRoot":"","sources":["../../../../src/ApiClient/WebSocketClient/BrowserWebSocketClient/WSCoordinator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,101 @@
1
+ import { SocketEventMap, SocketEventName } from '../events';
2
+ import { MessageType, SocketMessageMap } from '../messages';
3
+ /**
4
+ * Primary tab to broadcast socket events to secondary tabs.
5
+ * @param eventType - The event type.
6
+ * @param payload - The event payload. See {@link SocketEventMap} for the list of available events.
7
+ */
8
+ export interface SocketEventReceived<T extends SocketEventName = SocketEventName> {
9
+ type: 'socket-event';
10
+ payload: {
11
+ eventType: T;
12
+ payload: SocketEventMap[T];
13
+ };
14
+ }
15
+ /**
16
+ * Sent by secondary tabs to the primary tab to send a message to WebSocket.
17
+ * @param messageType - The message type.
18
+ * @param data - The message payload. See {@link SocketMessageMap} for the list of available messages.
19
+ */
20
+ export interface SendSocketMessage<T extends MessageType = MessageType> {
21
+ type: 'socket-send';
22
+ payload: {
23
+ messageType: T;
24
+ data: SocketMessageMap[T];
25
+ };
26
+ }
27
+ /**
28
+ * Sent by the primary tab to acknowledge that a message was sent to WebSocket.
29
+ */
30
+ export interface SocketMessageAck {
31
+ type: 'socket-ack';
32
+ payload: {
33
+ envelopeId: string;
34
+ };
35
+ }
36
+ /**
37
+ * Sent by the primary tab to notify the secondary tabs that the primary tab is still alive.
38
+ * @param connected - true if the primary tab is connected to the server, false otherwise.
39
+ */
40
+ export interface Heartbeat {
41
+ type: 'primary-present';
42
+ payload: {
43
+ connected: boolean;
44
+ };
45
+ }
46
+ /**
47
+ * Used to tell the primary tab to connect/disconnect socket.
48
+ * @param connected - true to connect, false to disconnect.
49
+ */
50
+ export interface ConnectionToggle {
51
+ type: 'connection-toggle';
52
+ payload: {
53
+ connected: boolean;
54
+ };
55
+ }
56
+ /**
57
+ * Sent by tab when it is opened to notify other tabs. If another tab is present,
58
+ * it will respond with {@link Heartbeat}.
59
+ */
60
+ export interface ClientAnnounce {
61
+ type: 'announce';
62
+ }
63
+ /**
64
+ * Sent by the client to let other know that it is claiming the primary role.
65
+ */
66
+ export interface PrimaryClaim {
67
+ type: 'primary-claim';
68
+ }
69
+ /**
70
+ * Sent by the client to let other know that it is releasing the primary role.
71
+ * This usually happens when the tab is closed.
72
+ */
73
+ export interface PrimaryRelease {
74
+ type: 'primary-release';
75
+ }
76
+ /**
77
+ * Sent by the tab where user has auth state changed.
78
+ * @param authenticated - true if the user is authenticated, false otherwise.
79
+ */
80
+ export interface AuthenticationChange {
81
+ type: 'authentication';
82
+ payload: {
83
+ authenticated: boolean;
84
+ };
85
+ }
86
+ export type ChannelMessage = AuthenticationChange | SocketEventReceived | SendSocketMessage | SocketMessageAck | ConnectionToggle | Heartbeat | ClientAnnounce | PrimaryClaim | PrimaryRelease;
87
+ /**
88
+ * Envelope for messages sent between tabs.
89
+ * @param id - Unique message ID.
90
+ * @param senderId - ID of the tab that sent the message.
91
+ * @param recipientId - ID of the tab that should receive the message. If not specified, the message will be broadcasted to all tabs.
92
+ * @param timestamp - Timestamp of the message.
93
+ * @param payload - Message payload.
94
+ */
95
+ export interface MessageEnvelope {
96
+ id: string;
97
+ senderId: string;
98
+ recipientId?: string;
99
+ timestamp: number;
100
+ payload: ChannelMessage;
101
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/ApiClient/WebSocketClient/BrowserWebSocketClient/types.ts"],"names":[],"mappings":""}
@@ -135,3 +135,4 @@ export type SocketEventMap = {
135
135
  toastMessage: ToastMessage;
136
136
  artistCancelConfirmation: ArtistCancelConfirmation;
137
137
  };
138
+ export type SocketEventName = keyof SocketEventMap;
@@ -1,10 +1,10 @@
1
1
  import { MessageType, SocketMessageMap } from './messages';
2
2
  import { SocketEventMap } from './events';
3
3
  import RestClient from '../../lib/RestClient';
4
- import { SupernetType } from './types';
4
+ import { IWebSocketClient, SupernetType } from './types';
5
5
  import { Logger } from '../../lib/DefaultLogger';
6
6
  import { AuthManager } from '../../lib/AuthManager';
7
- declare class WebSocketClient extends RestClient<SocketEventMap> {
7
+ declare class WebSocketClient extends RestClient<SocketEventMap> implements IWebSocketClient {
8
8
  appId: string;
9
9
  baseUrl: string;
10
10
  private socket;
@@ -1 +1,14 @@
1
+ import { MessageType, SocketMessageMap } from './messages';
2
+ import RestClient from '../../lib/RestClient';
3
+ import { SocketEventMap } from './events';
1
4
  export type SupernetType = 'relaxed' | 'fast';
5
+ export interface IWebSocketClient extends RestClient<SocketEventMap> {
6
+ appId: string;
7
+ baseUrl: string;
8
+ isConnected: boolean;
9
+ supernetType: SupernetType;
10
+ connect(): Promise<void>;
11
+ disconnect(): void;
12
+ send<T extends MessageType>(messageType: T, data: SocketMessageMap[T]): Promise<void>;
13
+ switchNetwork(supernetType: SupernetType): Promise<SupernetType>;
14
+ }
@@ -1,10 +1,9 @@
1
1
  import RestClient from '../lib/RestClient';
2
- import WebSocketClient from './WebSocketClient';
3
2
  import TypedEventEmitter from '../lib/TypedEventEmitter';
4
3
  import { ApiClientEvents } from './events';
5
4
  import { ServerConnectData, ServerDisconnectData } from './WebSocketClient/events';
6
5
  import { JSONValue } from '../types/json';
7
- import { SupernetType } from './WebSocketClient/types';
6
+ import { IWebSocketClient, SupernetType } from './WebSocketClient/types';
8
7
  import { Logger } from '../lib/DefaultLogger';
9
8
  import { AuthManager } from '../lib/AuthManager';
10
9
  export interface ApiResponse<D = JSONValue> {
@@ -42,7 +41,7 @@ declare class ApiClient extends TypedEventEmitter<ApiClientEvents> {
42
41
  constructor({ baseUrl, socketUrl, appId, networkType, authType, logger, disableSocket }: ApiClientOptions);
43
42
  get isAuthenticated(): boolean;
44
43
  get auth(): AuthManager;
45
- get socket(): WebSocketClient;
44
+ get socket(): IWebSocketClient;
46
45
  get rest(): RestClient;
47
46
  get socketEnabled(): boolean;
48
47
  handleSocketConnect({ network }: ServerConnectData): void;
@@ -10,6 +10,8 @@ const TypedEventEmitter_1 = __importDefault(require("../lib/TypedEventEmitter"))
10
10
  const ErrorCode_1 = require("./WebSocketClient/ErrorCode");
11
11
  const CookieAuthManager_1 = __importDefault(require("../lib/AuthManager/CookieAuthManager"));
12
12
  const AuthManager_1 = require("../lib/AuthManager");
13
+ const isNodejs_1 = __importDefault(require("../lib/isNodejs"));
14
+ const BrowserWebSocketClient_1 = __importDefault(require("./WebSocketClient/BrowserWebSocketClient/BrowserWebSocketClient"));
13
15
  const WS_RECONNECT_ATTEMPTS = 5;
14
16
  class ApiError extends Error {
15
17
  constructor(status, payload) {
@@ -29,7 +31,13 @@ class ApiClient extends TypedEventEmitter_1.default {
29
31
  this._auth =
30
32
  authType === 'token' ? new AuthManager_1.TokenAuthManager(baseUrl, logger) : new CookieAuthManager_1.default(logger);
31
33
  this._rest = new RestClient_1.default(baseUrl, this._auth, logger);
32
- this._socket = new WebSocketClient_1.default(socketUrl, this._auth, appId, networkType, logger);
34
+ // Use coordinated WebSocket client in browser, regular in Node.js
35
+ if (this._auth instanceof AuthManager_1.TokenAuthManager || isNodejs_1.default) {
36
+ this._socket = new WebSocketClient_1.default(socketUrl, this._auth, appId, networkType, logger);
37
+ }
38
+ else {
39
+ this._socket = new BrowserWebSocketClient_1.default(socketUrl, this._auth, appId, networkType, logger);
40
+ }
33
41
  this._disableSocket = disableSocket;
34
42
  this._auth.on('updated', this.handleAuthUpdated.bind(this));
35
43
  this._socket.on('connected', this.handleSocketConnect.bind(this));
@@ -55,14 +63,24 @@ class ApiClient extends TypedEventEmitter_1.default {
55
63
  this.emit('connected', { network });
56
64
  }
57
65
  handleSocketDisconnect(data) {
66
+ // If user is not authenticated, we don't need to reconnect
67
+ if (!this.auth.isAuthenticated) {
68
+ this.emit('disconnected', data);
69
+ return;
70
+ }
58
71
  if (!data.code || (0, ErrorCode_1.isNotRecoverable)(data.code)) {
72
+ // If this is browser, another tab is probably claiming the connection, so we don't need to reconnect
73
+ if (this._socket instanceof BrowserWebSocketClient_1.default &&
74
+ data.code === ErrorCode_1.ErrorCode.SWITCH_CONNECTION) {
75
+ this.logger.debug('Switching network connection, not reconnecting');
76
+ return;
77
+ }
59
78
  this.auth.clear();
60
79
  this.emit('disconnected', data);
61
80
  this.logger.error('Not recoverable socket error', data);
62
81
  return;
63
82
  }
64
83
  if (this._reconnectAttempts <= 0) {
65
- this.auth.clear();
66
84
  this.emit('disconnected', data);
67
85
  this._reconnectAttempts = WS_RECONNECT_ATTEMPTS;
68
86
  return;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ApiClient/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ApiClient/index.ts"],"names":[],"mappings":"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"}
@@ -122,7 +122,7 @@ declare class Job extends DataEntity<JobData, JobEventMap> {
122
122
  _syncWithRestData(data: RawJob): Promise<void>;
123
123
  private handleUpdated;
124
124
  private handleEnhancementUpdate;
125
- getResultData(): Promise<import("buffer").Blob>;
125
+ getResultData(): Promise<Blob>;
126
126
  /**
127
127
  * Enhance the image using the Flux model. This method will create a new project with the
128
128
  * enhancement parameters and use the result image of the current job as the starting image.
@@ -1,5 +1,5 @@
1
1
  import ApiGroup, { ApiConfig } from '../ApiGroup';
2
- import { AvailableModel, EnhancementStrength, EstimateRequest, ImageUrlParams, ProjectParams, SizePreset, SupportedModel } from './types';
2
+ import { AvailableModel, EnhancementStrength, EstimateRequest, ImageUrlParams, CostEstimation, ProjectParams, SizePreset, SupportedModel } from './types';
3
3
  import Project from './Project';
4
4
  import { ProjectApiEvents } from './types/events';
5
5
  import { RawProject } from './types/RawProject';
@@ -52,14 +52,8 @@ declare class ProjectsApi extends ApiGroup<ProjectApiEvents> {
52
52
  /**
53
53
  * Estimate project cost
54
54
  */
55
- estimateCost({ network, tokenType, model, imageCount, stepCount, previewCount, cnEnabled, startingImageStrength, width, height, sizePreset, guidance, sampler, contextImages }: EstimateRequest): Promise<{
56
- token: string;
57
- usd: string;
58
- }>;
59
- estimateEnhancementCost(strength: EnhancementStrength, tokenType?: TokenType): Promise<{
60
- token: string;
61
- usd: string;
62
- }>;
55
+ estimateCost({ network, tokenType, model, imageCount, stepCount, previewCount, cnEnabled, startingImageStrength, width, height, sizePreset, guidance, sampler, contextImages }: EstimateRequest): Promise<CostEstimation>;
56
+ estimateEnhancementCost(strength: EnhancementStrength, tokenType?: TokenType): Promise<CostEstimation>;
63
57
  /**
64
58
  * Get upload URL for image
65
59
  * @internal
@@ -528,7 +528,9 @@ class ProjectsApi extends ApiGroup_1.default {
528
528
  const r = yield this.client.socket.get(`/api/v${apiVersion}/job/estimate/${pathParams.join('/')}`);
529
529
  return {
530
530
  token: r.quote.project.costInToken,
531
- usd: r.quote.project.costInUSD
531
+ usd: r.quote.project.costInUSD,
532
+ spark: r.quote.project.costInSpark,
533
+ sogni: r.quote.project.costInSogni
532
534
  };
533
535
  });
534
536
  }