Skip to content

Commit

Permalink
Merge pull request #7 from Mahad-10/implement-unsubscribe
Browse files Browse the repository at this point in the history
Implement unsubscribe
  • Loading branch information
Mahad-10 authored Oct 8, 2024
2 parents f916f04 + 6eac196 commit 8842240
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 2 deletions.
42 changes: 40 additions & 2 deletions lib/session.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,9 @@ import {
Published,
Subscribe, SubscribeFields,
Subscribed,
Event as EventMsg
Event as EventMsg,
Unsubscribe, UnsubscribeFields,
Unsubscribed
} from "wampproto";

import {wampErrorString} from "./helpers";
Expand All @@ -29,7 +31,8 @@ import {
UnregisterRequest,
Event,
SubscribeRequest,
Subscription
Subscription,
UnsubscribeRequest
} from "./types";


Expand All @@ -51,6 +54,7 @@ export class Session {
}> = new Map();
private _subscribeRequests: Map<number, SubscribeRequest> = new Map();
private _subscriptions: Map<number, (event: Event) => void> = new Map();
private _unsubscribeRequests: Map<number, UnsubscribeRequest> = new Map();

constructor(baseSession: IBaseSession) {
this._baseSession = baseSession;
Expand Down Expand Up @@ -116,6 +120,13 @@ export class Session {
if (endpoint) {
endpoint(new Event(message.args, message.kwargs, message.details));
}
} else if (message instanceof Unsubscribed) {
const request = this._unsubscribeRequests.get(message.requestID);
if (request) {
this._subscriptions.delete(request.subscriptionID);
request.promise.resolve();
this._unsubscribeRequests.delete(message.requestID);
}
} else if (message instanceof ErrorMsg) {
switch (message.messageType) {
case Call.TYPE: {
Expand Down Expand Up @@ -160,6 +171,16 @@ export class Session {
}
break;
}
case Unsubscribe.TYPE: {
const unsubscribeRequest = this._unsubscribeRequests.get(message.requestID);
if (unsubscribeRequest) {
unsubscribeRequest.promise.reject(
new ApplicationError(message.uri, {args: message.args, kwargs: message.kwargs})
)
this._unsubscribeRequests.delete(message.requestID);
}
break;
}
default:
throw new ProtocolError(wampErrorString(message));
}
Expand Down Expand Up @@ -283,4 +304,21 @@ export class Session {

return promise;
}

async unsubscribe(sub: Subscription): Promise<void> {
const unsubscribe = new Unsubscribe(new UnsubscribeFields(this._nextID, sub.subscriptionID));
let promiseHandler: {
resolve: () => void;
reject: (reason: ApplicationError) => void
};

const promise = new Promise<void>((resolve, reject) => {
promiseHandler = {resolve, reject};
});
const request = new UnsubscribeRequest(promiseHandler, sub.subscriptionID);
this._unsubscribeRequests.set(unsubscribe.requestID, request);
this._baseSession.send(this._wampSession.sendMessage(unsubscribe));

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

export class UnsubscribeRequest {
constructor(
public readonly promise: { resolve: () => void; reject: (reason: ApplicationError) => void },
public readonly subscriptionID: number
) {
}
}

0 comments on commit 8842240

Please sign in to comment.