@ngxs/websocket-plugin 3.7.3-dev.master-5175b98 → 3.7.3

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.
@@ -1,304 +1,275 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
- */
5
- import * as tslib_1 from "tslib";
6
- import { Injectable, Inject } from '@angular/core';
7
- import { Actions, Store, getValue, ofActionDispatched } from '@ngxs/store';
8
- import { Subscription } from 'rxjs';
9
- import { WebSocketSubject } from 'rxjs/webSocket';
10
- import { ConnectWebSocket, DisconnectWebSocket, SendWebSocketMessage, NGXS_WEBSOCKET_OPTIONS, WebsocketMessageError, WebSocketDisconnected, TypeKeyPropertyMissingError, WebSocketConnectionUpdated, WebSocketConnected } from './symbols';
11
- var WebSocketHandler = /** @class */ (function () {
12
- function WebSocketHandler(store, actions$, options) {
13
- var _this = this;
14
- this.store = store;
15
- this.actions$ = actions$;
16
- this.options = options;
17
- this.socket = null;
18
- this.config = {
19
- url: (/** @type {?} */ (this.options.url)),
20
- protocol: this.options.protocol,
21
- // Default binary type is `blob` for the global `WebSocket`
22
- binaryType: this.options.binaryType,
23
- serializer: this.options.serializer,
24
- deserializer: this.options.deserializer,
25
- closeObserver: {
26
- next: (/**
27
- * @return {?}
28
- */
29
- function () {
30
- // ATTENTION!
31
- // See https://github.com/ReactiveX/rxjs/blob/master/src/internal/observable/dom/WebSocketSubject.ts#L340
32
- // RxJS socket emits `onComplete` event only if `event.wasClean` is truthy
33
- // and doesn't complete socket subject if it's falsy
34
- _this.disconnect();
35
- })
36
- },
37
- openObserver: {
38
- next: (/**
39
- * @return {?}
40
- */
41
- function () { return _this.store.dispatch(new WebSocketConnected()); })
42
- }
43
- };
44
- this.typeKey = (/** @type {?} */ (this.options.typeKey));
45
- this.subscription = new Subscription();
46
- this.setupActionsListeners();
47
- }
48
- /**
49
- * @return {?}
50
- */
51
- WebSocketHandler.prototype.ngOnDestroy = /**
52
- * @return {?}
53
- */
54
- function () {
55
- this.closeConnection();
56
- this.subscription.unsubscribe();
57
- };
58
- /**
59
- * @private
60
- * @return {?}
61
- */
62
- WebSocketHandler.prototype.setupActionsListeners = /**
63
- * @private
64
- * @return {?}
65
- */
66
- function () {
67
- var _this = this;
68
- this.subscription.add(this.actions$.pipe(ofActionDispatched(ConnectWebSocket)).subscribe((/**
69
- * @param {?} __0
70
- * @return {?}
71
- */
72
- function (_a) {
73
- var payload = _a.payload;
74
- _this.connect(payload);
75
- })));
76
- this.subscription.add(this.actions$.pipe(ofActionDispatched(DisconnectWebSocket)).subscribe((/**
77
- * @return {?}
78
- */
79
- function () {
80
- _this.disconnect();
81
- })));
82
- this.subscription.add(this.actions$.pipe(ofActionDispatched(SendWebSocketMessage)).subscribe((/**
83
- * @param {?} __0
84
- * @return {?}
85
- */
86
- function (_a) {
87
- var payload = _a.payload;
88
- _this.send(payload);
89
- })));
90
- };
91
- /**
92
- * @private
93
- * @param {?=} options
94
- * @return {?}
95
- */
96
- WebSocketHandler.prototype.connect = /**
97
- * @private
98
- * @param {?=} options
99
- * @return {?}
100
- */
101
- function (options) {
102
- var _this = this;
103
- this.updateConnection();
104
- // Users can pass the options in the connect method so
105
- // if options aren't available at DI bootstrap they have access
106
- // to pass them here
107
- if (options) {
108
- this.mergeConfigWithOptions(options);
109
- }
110
- this.socket = new WebSocketSubject(this.config);
111
- this.socket.subscribe({
112
- next: (/**
113
- * @param {?} message
114
- * @return {?}
115
- */
116
- function (message) {
117
- /** @type {?} */
118
- var type = getValue(message, _this.typeKey);
119
- if (!type) {
120
- throw new TypeKeyPropertyMissingError(_this.typeKey);
121
- }
122
- _this.store.dispatch(tslib_1.__assign({}, message, { type: type }));
123
- }),
124
- error: (/**
125
- * @param {?} error
126
- * @return {?}
127
- */
128
- function (error) {
129
- if (error instanceof CloseEvent) {
130
- _this.dispatchWebSocketDisconnected();
131
- }
132
- else {
133
- _this.store.dispatch(new WebsocketMessageError(error));
134
- }
135
- })
136
- });
137
- };
138
- /**
139
- * @private
140
- * @return {?}
141
- */
142
- WebSocketHandler.prototype.disconnect = /**
143
- * @private
144
- * @return {?}
145
- */
146
- function () {
147
- if (this.socket) {
148
- this.closeConnection();
149
- this.dispatchWebSocketDisconnected();
150
- }
151
- };
152
- /**
153
- * @private
154
- * @param {?} data
155
- * @return {?}
156
- */
157
- WebSocketHandler.prototype.send = /**
158
- * @private
159
- * @param {?} data
160
- * @return {?}
161
- */
162
- function (data) {
163
- if (!this.socket) {
164
- throw new Error('You must connect to the socket before sending any data');
165
- }
166
- this.socket.next(data);
167
- };
168
- /**
169
- * Don't enlarge the `connect` method
170
- */
171
- /**
172
- * Don't enlarge the `connect` method
173
- * @private
174
- * @param {?} options
175
- * @return {?}
176
- */
177
- WebSocketHandler.prototype.mergeConfigWithOptions = /**
178
- * Don't enlarge the `connect` method
179
- * @private
180
- * @param {?} options
181
- * @return {?}
182
- */
183
- function (options) {
184
- if (options.url) {
185
- this.config.url = options.url;
186
- }
187
- if (options.serializer) {
188
- this.config.serializer = options.serializer;
189
- }
190
- if (options.deserializer) {
191
- this.config.deserializer = options.deserializer;
192
- }
193
- };
194
- /**
195
- * To ensure we don't have any memory leaks
196
- * e.g. if the user occasionally dispatched `ConnectWebSocket` twice
197
- * then the previous subscription will still live in the memory
198
- * to prevent such behavior - we close the previous connection if it exists
199
- */
200
- /**
201
- * To ensure we don't have any memory leaks
202
- * e.g. if the user occasionally dispatched `ConnectWebSocket` twice
203
- * then the previous subscription will still live in the memory
204
- * to prevent such behavior - we close the previous connection if it exists
205
- * @private
206
- * @return {?}
207
- */
208
- WebSocketHandler.prototype.updateConnection = /**
209
- * To ensure we don't have any memory leaks
210
- * e.g. if the user occasionally dispatched `ConnectWebSocket` twice
211
- * then the previous subscription will still live in the memory
212
- * to prevent such behavior - we close the previous connection if it exists
213
- * @private
214
- * @return {?}
215
- */
216
- function () {
217
- if (this.socket) {
218
- this.closeConnection();
219
- this.store.dispatch(new WebSocketConnectionUpdated());
220
- }
221
- };
222
- /**
223
- * Used in many places so it's better to move the code into function
224
- */
225
- /**
226
- * Used in many places so it's better to move the code into function
227
- * @private
228
- * @return {?}
229
- */
230
- WebSocketHandler.prototype.dispatchWebSocketDisconnected = /**
231
- * Used in many places so it's better to move the code into function
232
- * @private
233
- * @return {?}
234
- */
235
- function () {
236
- this.store.dispatch(new WebSocketDisconnected());
237
- };
238
- /**
239
- * @private
240
- * @return {?}
241
- */
242
- WebSocketHandler.prototype.closeConnection = /**
243
- * @private
244
- * @return {?}
245
- */
246
- function () {
247
- // `socket.complete()` closes the connection
248
- // also it doesn't invoke the `onComplete` callback that we passed
249
- // into `socket.subscribe(...)`
250
- if (this.socket !== null) {
251
- this.socket.complete();
252
- this.socket = null;
253
- }
254
- };
255
- WebSocketHandler.decorators = [
256
- { type: Injectable }
257
- ];
258
- /** @nocollapse */
259
- WebSocketHandler.ctorParameters = function () { return [
260
- { type: Store },
261
- { type: Actions },
262
- { type: undefined, decorators: [{ type: Inject, args: [NGXS_WEBSOCKET_OPTIONS,] }] }
263
- ]; };
264
- return WebSocketHandler;
265
- }());
266
- export { WebSocketHandler };
267
- if (false) {
268
- /**
269
- * @type {?}
270
- * @private
271
- */
272
- WebSocketHandler.prototype.socket;
273
- /**
274
- * @type {?}
275
- * @private
276
- */
277
- WebSocketHandler.prototype.config;
278
- /**
279
- * @type {?}
280
- * @private
281
- */
282
- WebSocketHandler.prototype.typeKey;
283
- /**
284
- * @type {?}
285
- * @private
286
- */
287
- WebSocketHandler.prototype.subscription;
288
- /**
289
- * @type {?}
290
- * @private
291
- */
292
- WebSocketHandler.prototype.store;
293
- /**
294
- * @type {?}
295
- * @private
296
- */
297
- WebSocketHandler.prototype.actions$;
298
- /**
299
- * @type {?}
300
- * @private
301
- */
302
- WebSocketHandler.prototype.options;
303
- }
304
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"websocket-handler.js","sourceRoot":"ng://@ngxs/websocket-plugin/","sources":["src/websocket-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, OnDestroy } from '@angular/core';\nimport { Actions, Store, getValue, ofActionDispatched } from '@ngxs/store';\nimport { Subscription } from 'rxjs';\n\nimport { WebSocketSubject, WebSocketSubjectConfig } from 'rxjs/webSocket';\n\nimport {\n  ConnectWebSocket,\n  DisconnectWebSocket,\n  SendWebSocketMessage,\n  NGXS_WEBSOCKET_OPTIONS,\n  NgxsWebsocketPluginOptions,\n  WebsocketMessageError,\n  WebSocketDisconnected,\n  TypeKeyPropertyMissingError,\n  WebSocketConnectionUpdated,\n  WebSocketConnected\n} from './symbols';\n\n@Injectable()\nexport class WebSocketHandler implements OnDestroy {\n  private socket: WebSocketSubject<any> | null = null;\n\n  private config: WebSocketSubjectConfig<any> = {\n    url: this.options.url!,\n    protocol: this.options.protocol,\n    // Default binary type is `blob` for the global `WebSocket`\n    binaryType: this.options.binaryType,\n    serializer: this.options.serializer,\n    deserializer: this.options.deserializer,\n    closeObserver: {\n      next: () => {\n        // ATTENTION!\n        // See https://github.com/ReactiveX/rxjs/blob/master/src/internal/observable/dom/WebSocketSubject.ts#L340\n        // RxJS socket emits `onComplete` event only if `event.wasClean` is truthy\n        // and doesn't complete socket subject if it's falsy\n        this.disconnect();\n      }\n    },\n    openObserver: {\n      next: () => this.store.dispatch(new WebSocketConnected())\n    }\n  };\n\n  private typeKey = this.options.typeKey!;\n\n  private subscription = new Subscription();\n\n  constructor(\n    private store: Store,\n    private actions$: Actions,\n    @Inject(NGXS_WEBSOCKET_OPTIONS) private options: NgxsWebsocketPluginOptions\n  ) {\n    this.setupActionsListeners();\n  }\n\n  ngOnDestroy(): void {\n    this.closeConnection();\n    this.subscription.unsubscribe();\n  }\n\n  private setupActionsListeners(): void {\n    this.subscription.add(\n      this.actions$.pipe(ofActionDispatched(ConnectWebSocket)).subscribe(({ payload }) => {\n        this.connect(payload);\n      })\n    );\n\n    this.subscription.add(\n      this.actions$.pipe(ofActionDispatched(DisconnectWebSocket)).subscribe(() => {\n        this.disconnect();\n      })\n    );\n\n    this.subscription.add(\n      this.actions$.pipe(ofActionDispatched(SendWebSocketMessage)).subscribe(({ payload }) => {\n        this.send(payload);\n      })\n    );\n  }\n\n  private connect(options?: NgxsWebsocketPluginOptions): void {\n    this.updateConnection();\n\n    // Users can pass the options in the connect method so\n    // if options aren't available at DI bootstrap they have access\n    // to pass them here\n    if (options) {\n      this.mergeConfigWithOptions(options);\n    }\n\n    this.socket = new WebSocketSubject(this.config);\n\n    this.socket.subscribe({\n      next: (message: any) => {\n        const type = getValue(message, this.typeKey);\n        if (!type) {\n          throw new TypeKeyPropertyMissingError(this.typeKey);\n        }\n        this.store.dispatch({ ...message, type });\n      },\n      error: (error: any) => {\n        if (error instanceof CloseEvent) {\n          this.dispatchWebSocketDisconnected();\n        } else {\n          this.store.dispatch(new WebsocketMessageError(error));\n        }\n      }\n    });\n  }\n\n  private disconnect(): void {\n    if (this.socket) {\n      this.closeConnection();\n      this.dispatchWebSocketDisconnected();\n    }\n  }\n\n  private send(data: any): void {\n    if (!this.socket) {\n      throw new Error('You must connect to the socket before sending any data');\n    }\n\n    this.socket.next(data);\n  }\n\n  /**\n   * Don't enlarge the `connect` method\n   */\n  private mergeConfigWithOptions(options: NgxsWebsocketPluginOptions): void {\n    if (options.url) {\n      this.config.url = options.url;\n    }\n\n    if (options.serializer) {\n      this.config.serializer = options.serializer;\n    }\n\n    if (options.deserializer) {\n      this.config.deserializer = options.deserializer;\n    }\n  }\n\n  /**\n   * To ensure we don't have any memory leaks\n   * e.g. if the user occasionally dispatched `ConnectWebSocket` twice\n   * then the previous subscription will still live in the memory\n   * to prevent such behavior - we close the previous connection if it exists\n   */\n  private updateConnection(): void {\n    if (this.socket) {\n      this.closeConnection();\n      this.store.dispatch(new WebSocketConnectionUpdated());\n    }\n  }\n\n  /**\n   * Used in many places so it's better to move the code into function\n   */\n  private dispatchWebSocketDisconnected(): void {\n    this.store.dispatch(new WebSocketDisconnected());\n  }\n\n  private closeConnection(): void {\n    // `socket.complete()` closes the connection\n    // also it doesn't invoke the `onComplete` callback that we passed\n    // into `socket.subscribe(...)`\n    if (this.socket !== null) {\n      this.socket.complete();\n      this.socket = null;\n    }\n  }\n}\n"]}
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ import * as tslib_1 from "tslib";
6
+ import { Injectable, Inject } from '@angular/core';
7
+ import { Actions, Store, getValue, ofActionDispatched } from '@ngxs/store';
8
+ import { WebSocketSubject } from 'rxjs/webSocket';
9
+ import { ConnectWebSocket, DisconnectWebSocket, SendWebSocketMessage, NGXS_WEBSOCKET_OPTIONS, WebsocketMessageError, WebSocketDisconnected, TypeKeyPropertyMissingError, WebSocketConnectionUpdated, WebSocketConnected } from './symbols';
10
+ var WebSocketHandler = /** @class */ (function () {
11
+ function WebSocketHandler(store, actions$, options) {
12
+ var _this = this;
13
+ this.store = store;
14
+ this.actions$ = actions$;
15
+ this.options = options;
16
+ this.socket = null;
17
+ this.config = {
18
+ url: (/** @type {?} */ (this.options.url)),
19
+ protocol: this.options.protocol,
20
+ // Default binary type is `blob` for the global `WebSocket`
21
+ binaryType: this.options.binaryType,
22
+ serializer: this.options.serializer,
23
+ deserializer: this.options.deserializer,
24
+ closeObserver: {
25
+ next: (/**
26
+ * @return {?}
27
+ */
28
+ function () {
29
+ // ATTENTION!
30
+ // See https://github.com/ReactiveX/rxjs/blob/master/src/internal/observable/dom/WebSocketSubject.ts#L340
31
+ // RxJS socket emits `onComplete` event only if `event.wasClean` is truthy
32
+ // and doesn't complete socket subject if it's falsy
33
+ _this.disconnect();
34
+ })
35
+ },
36
+ openObserver: {
37
+ next: (/**
38
+ * @return {?}
39
+ */
40
+ function () { return _this.store.dispatch(new WebSocketConnected()); })
41
+ }
42
+ };
43
+ this.typeKey = (/** @type {?} */ (this.options.typeKey));
44
+ this.setupActionsListeners();
45
+ }
46
+ /**
47
+ * @private
48
+ * @return {?}
49
+ */
50
+ WebSocketHandler.prototype.setupActionsListeners = /**
51
+ * @private
52
+ * @return {?}
53
+ */
54
+ function () {
55
+ var _this = this;
56
+ this.actions$.pipe(ofActionDispatched(ConnectWebSocket)).subscribe((/**
57
+ * @param {?} __0
58
+ * @return {?}
59
+ */
60
+ function (_a) {
61
+ var payload = _a.payload;
62
+ _this.connect(payload);
63
+ }));
64
+ this.actions$.pipe(ofActionDispatched(DisconnectWebSocket)).subscribe((/**
65
+ * @return {?}
66
+ */
67
+ function () {
68
+ _this.disconnect();
69
+ }));
70
+ this.actions$.pipe(ofActionDispatched(SendWebSocketMessage)).subscribe((/**
71
+ * @param {?} __0
72
+ * @return {?}
73
+ */
74
+ function (_a) {
75
+ var payload = _a.payload;
76
+ _this.send(payload);
77
+ }));
78
+ };
79
+ /**
80
+ * @private
81
+ * @param {?=} options
82
+ * @return {?}
83
+ */
84
+ WebSocketHandler.prototype.connect = /**
85
+ * @private
86
+ * @param {?=} options
87
+ * @return {?}
88
+ */
89
+ function (options) {
90
+ var _this = this;
91
+ this.updateConnection();
92
+ // Users can pass the options in the connect method so
93
+ // if options aren't available at DI bootstrap they have access
94
+ // to pass them here
95
+ if (options) {
96
+ this.mergeConfigWithOptions(options);
97
+ }
98
+ this.socket = new WebSocketSubject(this.config);
99
+ this.socket.subscribe({
100
+ next: (/**
101
+ * @param {?} message
102
+ * @return {?}
103
+ */
104
+ function (message) {
105
+ /** @type {?} */
106
+ var type = getValue(message, _this.typeKey);
107
+ if (!type) {
108
+ throw new TypeKeyPropertyMissingError(_this.typeKey);
109
+ }
110
+ _this.store.dispatch(tslib_1.__assign({}, message, { type: type }));
111
+ }),
112
+ error: (/**
113
+ * @param {?} error
114
+ * @return {?}
115
+ */
116
+ function (error) {
117
+ if (error instanceof CloseEvent) {
118
+ _this.dispatchWebSocketDisconnected();
119
+ }
120
+ else {
121
+ _this.store.dispatch(new WebsocketMessageError(error));
122
+ }
123
+ })
124
+ });
125
+ };
126
+ /**
127
+ * @private
128
+ * @return {?}
129
+ */
130
+ WebSocketHandler.prototype.disconnect = /**
131
+ * @private
132
+ * @return {?}
133
+ */
134
+ function () {
135
+ if (this.socket) {
136
+ // `socket.complete()` closes the connection
137
+ // also it doesn't invoke the `onComplete` callback that we passed
138
+ // into `socket.subscribe(...)`
139
+ this.socket.complete();
140
+ this.socket = null;
141
+ this.dispatchWebSocketDisconnected();
142
+ }
143
+ };
144
+ /**
145
+ * @private
146
+ * @param {?} data
147
+ * @return {?}
148
+ */
149
+ WebSocketHandler.prototype.send = /**
150
+ * @private
151
+ * @param {?} data
152
+ * @return {?}
153
+ */
154
+ function (data) {
155
+ if (!this.socket) {
156
+ throw new Error('You must connect to the socket before sending any data');
157
+ }
158
+ this.socket.next(data);
159
+ };
160
+ /**
161
+ * Don't enlarge the `connect` method
162
+ */
163
+ /**
164
+ * Don't enlarge the `connect` method
165
+ * @private
166
+ * @param {?} options
167
+ * @return {?}
168
+ */
169
+ WebSocketHandler.prototype.mergeConfigWithOptions = /**
170
+ * Don't enlarge the `connect` method
171
+ * @private
172
+ * @param {?} options
173
+ * @return {?}
174
+ */
175
+ function (options) {
176
+ if (options.url) {
177
+ this.config.url = options.url;
178
+ }
179
+ if (options.serializer) {
180
+ this.config.serializer = options.serializer;
181
+ }
182
+ if (options.deserializer) {
183
+ this.config.deserializer = options.deserializer;
184
+ }
185
+ };
186
+ /**
187
+ * To ensure we don't have any memory leaks
188
+ * e.g. if the user occasionally dispatched `ConnectWebSocket` twice
189
+ * then the previous subscription will still live in the memory
190
+ * to prevent such behavior - we close the previous connection if it exists
191
+ */
192
+ /**
193
+ * To ensure we don't have any memory leaks
194
+ * e.g. if the user occasionally dispatched `ConnectWebSocket` twice
195
+ * then the previous subscription will still live in the memory
196
+ * to prevent such behavior - we close the previous connection if it exists
197
+ * @private
198
+ * @return {?}
199
+ */
200
+ WebSocketHandler.prototype.updateConnection = /**
201
+ * To ensure we don't have any memory leaks
202
+ * e.g. if the user occasionally dispatched `ConnectWebSocket` twice
203
+ * then the previous subscription will still live in the memory
204
+ * to prevent such behavior - we close the previous connection if it exists
205
+ * @private
206
+ * @return {?}
207
+ */
208
+ function () {
209
+ if (this.socket) {
210
+ this.socket.complete();
211
+ this.socket = null;
212
+ this.store.dispatch(new WebSocketConnectionUpdated());
213
+ }
214
+ };
215
+ /**
216
+ * Used in many places so it's better to move the code into function
217
+ */
218
+ /**
219
+ * Used in many places so it's better to move the code into function
220
+ * @private
221
+ * @return {?}
222
+ */
223
+ WebSocketHandler.prototype.dispatchWebSocketDisconnected = /**
224
+ * Used in many places so it's better to move the code into function
225
+ * @private
226
+ * @return {?}
227
+ */
228
+ function () {
229
+ this.store.dispatch(new WebSocketDisconnected());
230
+ };
231
+ WebSocketHandler.decorators = [
232
+ { type: Injectable }
233
+ ];
234
+ /** @nocollapse */
235
+ WebSocketHandler.ctorParameters = function () { return [
236
+ { type: Store },
237
+ { type: Actions },
238
+ { type: undefined, decorators: [{ type: Inject, args: [NGXS_WEBSOCKET_OPTIONS,] }] }
239
+ ]; };
240
+ return WebSocketHandler;
241
+ }());
242
+ export { WebSocketHandler };
243
+ if (false) {
244
+ /**
245
+ * @type {?}
246
+ * @private
247
+ */
248
+ WebSocketHandler.prototype.socket;
249
+ /**
250
+ * @type {?}
251
+ * @private
252
+ */
253
+ WebSocketHandler.prototype.config;
254
+ /**
255
+ * @type {?}
256
+ * @private
257
+ */
258
+ WebSocketHandler.prototype.typeKey;
259
+ /**
260
+ * @type {?}
261
+ * @private
262
+ */
263
+ WebSocketHandler.prototype.store;
264
+ /**
265
+ * @type {?}
266
+ * @private
267
+ */
268
+ WebSocketHandler.prototype.actions$;
269
+ /**
270
+ * @type {?}
271
+ * @private
272
+ */
273
+ WebSocketHandler.prototype.options;
274
+ }
275
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"websocket-handler.js","sourceRoot":"ng://@ngxs/websocket-plugin/","sources":["src/websocket-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\r\nimport { Actions, Store, getValue, ofActionDispatched } from '@ngxs/store';\r\n\r\nimport { WebSocketSubject, WebSocketSubjectConfig } from 'rxjs/webSocket';\r\n\r\nimport {\r\n  ConnectWebSocket,\r\n  DisconnectWebSocket,\r\n  SendWebSocketMessage,\r\n  NGXS_WEBSOCKET_OPTIONS,\r\n  NgxsWebsocketPluginOptions,\r\n  WebsocketMessageError,\r\n  WebSocketDisconnected,\r\n  TypeKeyPropertyMissingError,\r\n  WebSocketConnectionUpdated,\r\n  WebSocketConnected\r\n} from './symbols';\r\n\r\n@Injectable()\r\nexport class WebSocketHandler {\r\n  private socket: WebSocketSubject<any> | null = null;\r\n\r\n  private config: WebSocketSubjectConfig<any> = {\r\n    url: this.options.url!,\r\n    protocol: this.options.protocol,\r\n    // Default binary type is `blob` for the global `WebSocket`\r\n    binaryType: this.options.binaryType,\r\n    serializer: this.options.serializer,\r\n    deserializer: this.options.deserializer,\r\n    closeObserver: {\r\n      next: () => {\r\n        // ATTENTION!\r\n        // See https://github.com/ReactiveX/rxjs/blob/master/src/internal/observable/dom/WebSocketSubject.ts#L340\r\n        // RxJS socket emits `onComplete` event only if `event.wasClean` is truthy\r\n        // and doesn't complete socket subject if it's falsy\r\n        this.disconnect();\r\n      }\r\n    },\r\n    openObserver: {\r\n      next: () => this.store.dispatch(new WebSocketConnected())\r\n    }\r\n  };\r\n\r\n  private typeKey = this.options.typeKey!;\r\n\r\n  constructor(\r\n    private store: Store,\r\n    private actions$: Actions,\r\n    @Inject(NGXS_WEBSOCKET_OPTIONS) private options: NgxsWebsocketPluginOptions\r\n  ) {\r\n    this.setupActionsListeners();\r\n  }\r\n\r\n  private setupActionsListeners(): void {\r\n    this.actions$.pipe(ofActionDispatched(ConnectWebSocket)).subscribe(({ payload }) => {\r\n      this.connect(payload);\r\n    });\r\n\r\n    this.actions$.pipe(ofActionDispatched(DisconnectWebSocket)).subscribe(() => {\r\n      this.disconnect();\r\n    });\r\n\r\n    this.actions$.pipe(ofActionDispatched(SendWebSocketMessage)).subscribe(({ payload }) => {\r\n      this.send(payload);\r\n    });\r\n  }\r\n\r\n  private connect(options?: NgxsWebsocketPluginOptions): void {\r\n    this.updateConnection();\r\n\r\n    // Users can pass the options in the connect method so\r\n    // if options aren't available at DI bootstrap they have access\r\n    // to pass them here\r\n    if (options) {\r\n      this.mergeConfigWithOptions(options);\r\n    }\r\n\r\n    this.socket = new WebSocketSubject(this.config);\r\n\r\n    this.socket.subscribe({\r\n      next: (message: any) => {\r\n        const type = getValue(message, this.typeKey);\r\n        if (!type) {\r\n          throw new TypeKeyPropertyMissingError(this.typeKey);\r\n        }\r\n        this.store.dispatch({ ...message, type });\r\n      },\r\n      error: (error: any) => {\r\n        if (error instanceof CloseEvent) {\r\n          this.dispatchWebSocketDisconnected();\r\n        } else {\r\n          this.store.dispatch(new WebsocketMessageError(error));\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private disconnect(): void {\r\n    if (this.socket) {\r\n      // `socket.complete()` closes the connection\r\n      // also it doesn't invoke the `onComplete` callback that we passed\r\n      // into `socket.subscribe(...)`\r\n      this.socket.complete();\r\n      this.socket = null;\r\n      this.dispatchWebSocketDisconnected();\r\n    }\r\n  }\r\n\r\n  private send(data: any): void {\r\n    if (!this.socket) {\r\n      throw new Error('You must connect to the socket before sending any data');\r\n    }\r\n\r\n    this.socket.next(data);\r\n  }\r\n\r\n  /**\r\n   * Don't enlarge the `connect` method\r\n   */\r\n  private mergeConfigWithOptions(options: NgxsWebsocketPluginOptions): void {\r\n    if (options.url) {\r\n      this.config.url = options.url;\r\n    }\r\n\r\n    if (options.serializer) {\r\n      this.config.serializer = options.serializer;\r\n    }\r\n\r\n    if (options.deserializer) {\r\n      this.config.deserializer = options.deserializer;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * To ensure we don't have any memory leaks\r\n   * e.g. if the user occasionally dispatched `ConnectWebSocket` twice\r\n   * then the previous subscription will still live in the memory\r\n   * to prevent such behavior - we close the previous connection if it exists\r\n   */\r\n  private updateConnection(): void {\r\n    if (this.socket) {\r\n      this.socket.complete();\r\n      this.socket = null;\r\n      this.store.dispatch(new WebSocketConnectionUpdated());\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Used in many places so it's better to move the code into function\r\n   */\r\n  private dispatchWebSocketDisconnected(): void {\r\n    this.store.dispatch(new WebSocketDisconnected());\r\n  }\r\n}\r\n"]}