You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
171 lines
6.6 KiB
171 lines
6.6 KiB
5 years ago
|
import { Subject, AnonymousSubject } from '../../Subject';
|
||
|
import { Subscriber } from '../../Subscriber';
|
||
|
import { Observable } from '../../Observable';
|
||
|
import { Subscription } from '../../Subscription';
|
||
|
import { Operator } from '../../Operator';
|
||
|
import { Observer, NextObserver } from '../../types';
|
||
|
/**
|
||
|
* WebSocketSubjectConfig is a plain Object that allows us to make our
|
||
|
* webSocket configurable.
|
||
|
*
|
||
|
* <span class="informal">Provides flexibility to {@link webSocket}</span>
|
||
|
*
|
||
|
* It defines a set of properties to provide custom behavior in specific
|
||
|
* moments of the socket's lifecycle. When the connection opens we can
|
||
|
* use `openObserver`, when the connection is closed `closeObserver`, if we
|
||
|
* are interested in listening for data comming from server: `deserializer`,
|
||
|
* which allows us to customize the deserialization strategy of data before passing it
|
||
|
* to the socket client. By default `deserializer` is going to apply `JSON.parse` to each message comming
|
||
|
* from the Server.
|
||
|
*
|
||
|
* ## Example
|
||
|
* **deserializer**, the default for this property is `JSON.parse` but since there are just two options
|
||
|
* for incomming data, either be text or binarydata. We can apply a custom deserialization strategy
|
||
|
* or just simply skip the default behaviour.
|
||
|
* ```ts
|
||
|
* import { webSocket } from 'rxjs/webSocket';
|
||
|
*
|
||
|
* const wsSubject = webSocket({
|
||
|
* url: 'ws://localhost:8081',
|
||
|
* //Apply any transformation of your choice.
|
||
|
* deserializer: ({data}) => data
|
||
|
* });
|
||
|
*
|
||
|
* wsSubject.subscribe(console.log);
|
||
|
*
|
||
|
* // Let's suppose we have this on the Server: ws.send("This is a msg from the server")
|
||
|
* //output
|
||
|
* //
|
||
|
* // This is a msg from the server
|
||
|
* ```
|
||
|
*
|
||
|
* **serializer** allows us tom apply custom serialization strategy but for the outgoing messages
|
||
|
* ```ts
|
||
|
* import { webSocket } from 'rxjs/webSocket';
|
||
|
*
|
||
|
* const wsSubject = webSocket({
|
||
|
* url: 'ws://localhost:8081',
|
||
|
* //Apply any transformation of your choice.
|
||
|
* serializer: msg => JSON.stringify({channel: "webDevelopment", msg: msg})
|
||
|
* });
|
||
|
*
|
||
|
* wsSubject.subscribe(() => subject.next("msg to the server"));
|
||
|
*
|
||
|
* // Let's suppose we have this on the Server: ws.send("This is a msg from the server")
|
||
|
* //output
|
||
|
* //
|
||
|
* // {"channel":"webDevelopment","msg":"msg to the server"}
|
||
|
* ```
|
||
|
*
|
||
|
* **closeObserver** allows us to set a custom error when an error raise up.
|
||
|
* ```ts
|
||
|
* import { webSocket } from 'rxjs/webSocket';
|
||
|
*
|
||
|
* const wsSubject = webSocket({
|
||
|
* url: 'ws://localhost:8081',
|
||
|
* closeObserver: {
|
||
|
next(closeEvent) {
|
||
|
const customError = { code: 6666, reason: "Custom evil reason" }
|
||
|
console.log(`code: ${customError.code}, reason: ${customError.reason}`);
|
||
|
}
|
||
|
}
|
||
|
* });
|
||
|
*
|
||
|
* //output
|
||
|
* // code: 6666, reason: Custom evil reason
|
||
|
* ```
|
||
|
*
|
||
|
* **openObserver**, Let's say we need to make some kind of init task before sending/receiving msgs to the
|
||
|
* webSocket or sending notification that the connection was successful, this is when
|
||
|
* openObserver is usefull for.
|
||
|
* ```ts
|
||
|
* import { webSocket } from 'rxjs/webSocket';
|
||
|
*
|
||
|
* const wsSubject = webSocket({
|
||
|
* url: 'ws://localhost:8081',
|
||
|
* openObserver: {
|
||
|
* next: () => {
|
||
|
* console.log('connetion ok');
|
||
|
* }
|
||
|
* },
|
||
|
* });
|
||
|
*
|
||
|
* //output
|
||
|
* // connetion ok`
|
||
|
* ```
|
||
|
* */
|
||
|
export interface WebSocketSubjectConfig<T> {
|
||
|
/** The url of the socket server to connect to */
|
||
|
url: string;
|
||
|
/** The protocol to use to connect */
|
||
|
protocol?: string | Array<string>;
|
||
|
/** @deprecated use {@link deserializer} */
|
||
|
resultSelector?: (e: MessageEvent) => T;
|
||
|
/**
|
||
|
* A serializer used to create messages from passed values before the
|
||
|
* messages are sent to the server. Defaults to JSON.stringify.
|
||
|
*/
|
||
|
serializer?: (value: T) => WebSocketMessage;
|
||
|
/**
|
||
|
* A deserializer used for messages arriving on the socket from the
|
||
|
* server. Defaults to JSON.parse.
|
||
|
*/
|
||
|
deserializer?: (e: MessageEvent) => T;
|
||
|
/**
|
||
|
* An Observer that watches when open events occur on the underlying web socket.
|
||
|
*/
|
||
|
openObserver?: NextObserver<Event>;
|
||
|
/**
|
||
|
* An Observer than watches when close events occur on the underlying webSocket
|
||
|
*/
|
||
|
closeObserver?: NextObserver<CloseEvent>;
|
||
|
/**
|
||
|
* An Observer that watches when a close is about to occur due to
|
||
|
* unsubscription.
|
||
|
*/
|
||
|
closingObserver?: NextObserver<void>;
|
||
|
/**
|
||
|
* A WebSocket constructor to use. This is useful for situations like using a
|
||
|
* WebSocket impl in Node (WebSocket is a DOM API), or for mocking a WebSocket
|
||
|
* for testing purposes
|
||
|
*/
|
||
|
WebSocketCtor?: {
|
||
|
new (url: string, protocols?: string | string[]): WebSocket;
|
||
|
};
|
||
|
/** Sets the `binaryType` property of the underlying WebSocket. */
|
||
|
binaryType?: 'blob' | 'arraybuffer';
|
||
|
}
|
||
|
export declare type WebSocketMessage = string | ArrayBuffer | Blob | ArrayBufferView;
|
||
|
export declare class WebSocketSubject<T> extends AnonymousSubject<T> {
|
||
|
private _config;
|
||
|
/** @deprecated This is an internal implementation detail, do not use. */
|
||
|
_output: Subject<T>;
|
||
|
private _socket;
|
||
|
constructor(urlConfigOrSource: string | WebSocketSubjectConfig<T> | Observable<T>, destination?: Observer<T>);
|
||
|
lift<R>(operator: Operator<T, R>): WebSocketSubject<R>;
|
||
|
private _resetState;
|
||
|
/**
|
||
|
* Creates an {@link Observable}, that when subscribed to, sends a message,
|
||
|
* defined by the `subMsg` function, to the server over the socket to begin a
|
||
|
* subscription to data over that socket. Once data arrives, the
|
||
|
* `messageFilter` argument will be used to select the appropriate data for
|
||
|
* the resulting Observable. When teardown occurs, either due to
|
||
|
* unsubscription, completion or error, a message defined by the `unsubMsg`
|
||
|
* argument will be send to the server over the WebSocketSubject.
|
||
|
*
|
||
|
* @param subMsg A function to generate the subscription message to be sent to
|
||
|
* the server. This will still be processed by the serializer in the
|
||
|
* WebSocketSubject's config. (Which defaults to JSON serialization)
|
||
|
* @param unsubMsg A function to generate the unsubscription message to be
|
||
|
* sent to the server at teardown. This will still be processed by the
|
||
|
* serializer in the WebSocketSubject's config.
|
||
|
* @param messageFilter A predicate for selecting the appropriate messages
|
||
|
* from the server for the output stream.
|
||
|
*/
|
||
|
multiplex(subMsg: () => any, unsubMsg: () => any, messageFilter: (value: T) => boolean): Observable<any>;
|
||
|
private _connectSocket;
|
||
|
/** @deprecated This is an internal implementation detail, do not use. */
|
||
|
_subscribe(subscriber: Subscriber<T>): Subscription;
|
||
|
unsubscribe(): void;
|
||
|
}
|