Skip to content

Commit

Permalink
Merge pull request #6 from Mahad-10/implement-subscribe
Browse files Browse the repository at this point in the history
Implement subscribe
  • Loading branch information
Mahad-10 authored Oct 8, 2024
2 parents 5a7fa0e + 4a21e36 commit f916f04
Show file tree
Hide file tree
Showing 2 changed files with 88 additions and 2 deletions.
64 changes: 62 additions & 2 deletions lib/session.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,25 @@ import {
Unregister, UnregisterFields,
Unregistered,
Publish, PublishFields,
Published
Published,
Subscribe, SubscribeFields,
Subscribed,
Event as EventMsg
} from "wampproto";

import {wampErrorString} from "./helpers";
import {ApplicationError, ProtocolError} from "./exception";
import {IBaseSession, Result, Invocation, RegisterRequest, Registration, UnregisterRequest} from "./types";
import {
IBaseSession,
Result,
Invocation,
RegisterRequest,
Registration,
UnregisterRequest,
Event,
SubscribeRequest,
Subscription
} from "./types";


export class Session {
Expand All @@ -36,6 +49,8 @@ export class Session {
resolve: () => void,
reject: (reason: ApplicationError) => void
}> = new Map();
private _subscribeRequests: Map<number, SubscribeRequest> = new Map();
private _subscriptions: Map<number, (event: Event) => void> = new Map();

constructor(baseSession: IBaseSession) {
this._baseSession = baseSession;
Expand Down Expand Up @@ -89,6 +104,18 @@ export class Session {
request.resolve();
this._publishRequests.delete(message.requestID);
}
} else if (message instanceof Subscribed) {
const request = this._subscribeRequests.get(message.requestID);
if (request) {
this._subscriptions.set(message.subscriptionID, request.endpoint);
request.promise.resolve(new Subscription(message.subscriptionID));
this._subscribeRequests.delete(message.requestID);
}
} else if (message instanceof EventMsg) {
const endpoint = this._subscriptions.get(message.subscriptionID);
if (endpoint) {
endpoint(new Event(message.args, message.kwargs, message.details));
}
} else if (message instanceof ErrorMsg) {
switch (message.messageType) {
case Call.TYPE: {
Expand Down Expand Up @@ -123,6 +150,16 @@ export class Session {
this._publishRequests.delete(message.requestID);
break;
}
case Subscribe.TYPE: {
const subscribeRequest = this._subscribeRequests.get(message.requestID);
if (subscribeRequest) {
subscribeRequest.promise.reject(
new ApplicationError(message.uri, {args: message.args, kwargs: message.kwargs})
)
this._subscribeRequests.delete(message.requestID);
}
break;
}
default:
throw new ProtocolError(wampErrorString(message));
}
Expand Down Expand Up @@ -223,4 +260,27 @@ export class Session {

return null;
}

async subscribe(
topic: string,
endpoint: (event: Event) => void,
options?: { [key: string]: any } | null
): Promise<Subscription> {
const subscribe = new Subscribe(new SubscribeFields(this._nextID, topic, options));

let promiseHandler: {
resolve: (value: Subscription | PromiseLike<Subscription>) => void;
reject: (reason: ApplicationError) => void;
};

const promise = new Promise<Subscription>((resolve, reject) => {
promiseHandler = {resolve, reject};
});

const request = new SubscribeRequest(promiseHandler, endpoint);
this._subscribeRequests.set(subscribe.requestID, request);
this._baseSession.send(this._wampSession.sendMessage(subscribe));

return promise;
}
}
26 changes: 26 additions & 0 deletions lib/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -165,3 +165,29 @@ export class UnregisterRequest {
) {
}
}

export class Subscription {
constructor(public readonly subscriptionID: number) {
this.subscriptionID = subscriptionID;
}
}

export class SubscribeRequest {
constructor(
public readonly promise: {
resolve: (value: Subscription) => void,
reject: (reason: ApplicationError) => void
},
public readonly endpoint: (event: Event) => void
) {
}
}

export class Event {
constructor(
public readonly args: any[] = [],
public readonly kwargs: { [key: string]: any } = {},
public readonly details: { [key: string]: any } = {}
) {
}
}

0 comments on commit f916f04

Please sign in to comment.