vani-meeting-client 1.5.4 → 1.5.6
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.
- package/lib/MeetingHandler.d.ts +1 -0
- package/lib/MeetingHandler.js +5 -0
- package/lib/inter-communication-handler/CommunicationHandler.d.ts +2 -0
- package/lib/inter-communication-handler/CommunicationHandler.js +12 -1
- package/lib/model/Event.d.ts +1 -0
- package/lib/model/Event.js +1 -0
- package/lib/video-call-handler/SFUHandler.js +28 -19
- package/lib/websocket-handler/WebsocketHandler.d.ts +2 -0
- package/lib/websocket-handler/WebsocketHandler.js +16 -0
- package/package.json +1 -1
package/lib/MeetingHandler.d.ts
CHANGED
|
@@ -12,6 +12,7 @@ export declare class MeetingHandler {
|
|
|
12
12
|
private userMediaHandler?;
|
|
13
13
|
meetingStartRequestObject(roomId: string, userId: string, appId: string, wssUrl: string): MeetingStartRequest;
|
|
14
14
|
endAndDestory(): void;
|
|
15
|
+
requestToCloseTheRoom: () => void;
|
|
15
16
|
init(): Promise<void>;
|
|
16
17
|
switchCamera(): void;
|
|
17
18
|
startLocalStream(isVideoRequired: boolean, isAudioRequired: boolean, shouldAddTrackImmediately?: boolean, userMediaPayload?: any): Promise<void>;
|
package/lib/MeetingHandler.js
CHANGED
|
@@ -44,7 +44,12 @@ import { UserMediaHandler } from "./user-media-handler/UserMediaHandler";
|
|
|
44
44
|
// import googleAnalytics from '@analytics/google-analytics'
|
|
45
45
|
var MeetingHandler = /** @class */ (function () {
|
|
46
46
|
function MeetingHandler() {
|
|
47
|
+
var _this = this;
|
|
47
48
|
this.communicationHandler = new CommunicationHandler(this);
|
|
49
|
+
this.requestToCloseTheRoom = function () {
|
|
50
|
+
var _a;
|
|
51
|
+
(_a = _this.communicationHandler) === null || _a === void 0 ? void 0 : _a.requestToCloseTheRoom();
|
|
52
|
+
};
|
|
48
53
|
}
|
|
49
54
|
MeetingHandler.prototype.meetingStartRequestObject = function (roomId, userId, appId, wssUrl) {
|
|
50
55
|
if (!this.meetingStartRequest) {
|
|
@@ -46,6 +46,7 @@ export declare class CommunicationHandler {
|
|
|
46
46
|
addUpdateRemoteTrack(track: Track, participant: Participant, shouldInfromIfNotExist?: boolean): Track;
|
|
47
47
|
addUpdateLocalTrack(track: Track): void;
|
|
48
48
|
onOldMessages(data: any): void;
|
|
49
|
+
requestToCloseTheRoom: () => Promise<void>;
|
|
49
50
|
onMessage(message: any, shouldInfromSource?: boolean): MessagePayload;
|
|
50
51
|
sendWebSocketMessage(type: WebSocketEvents, data: any): void;
|
|
51
52
|
onVideoCallWebSocketMessage(websocketMessage: WebSocketMessageBody): Promise<void>;
|
|
@@ -55,6 +56,7 @@ export declare class CommunicationHandler {
|
|
|
55
56
|
onAudioUnblocked(data: any): void;
|
|
56
57
|
onVideoBlocked(data: any): void;
|
|
57
58
|
onVideoUnblocked(data: any): void;
|
|
59
|
+
destoryRoomForcefully: () => void;
|
|
58
60
|
onIceCandidateDisconnected(): void;
|
|
59
61
|
checkIfInternetReachable: (count: number) => void;
|
|
60
62
|
private onApiResponded;
|
|
@@ -50,6 +50,18 @@ var CommunicationHandler = /** @class */ (function () {
|
|
|
50
50
|
this.selfTracks = [];
|
|
51
51
|
this.allTracks = [];
|
|
52
52
|
this.isReachable = true;
|
|
53
|
+
this.requestToCloseTheRoom = function () { return __awaiter(_this, void 0, void 0, function () {
|
|
54
|
+
var _a;
|
|
55
|
+
return __generator(this, function (_b) {
|
|
56
|
+
(_a = this.websocketCallHandler) === null || _a === void 0 ? void 0 : _a.sendSocketMessage(WebSocketBasicEvents.CloseRoomForceFully, {});
|
|
57
|
+
return [2 /*return*/];
|
|
58
|
+
});
|
|
59
|
+
}); };
|
|
60
|
+
//Connection Recheck
|
|
61
|
+
this.destoryRoomForcefully = function () {
|
|
62
|
+
var _a;
|
|
63
|
+
(_a = _this.meetingHandler) === null || _a === void 0 ? void 0 : _a.endAndDestory();
|
|
64
|
+
};
|
|
53
65
|
this.checkIfInternetReachable = function (count) {
|
|
54
66
|
var _a;
|
|
55
67
|
console.log("checkIfInternetReachable pre", _this.meetingStartRequest);
|
|
@@ -458,7 +470,6 @@ var CommunicationHandler = /** @class */ (function () {
|
|
|
458
470
|
}
|
|
459
471
|
}
|
|
460
472
|
};
|
|
461
|
-
//Connection Recheck
|
|
462
473
|
CommunicationHandler.prototype.onIceCandidateDisconnected = function () {
|
|
463
474
|
console.log("onIceCandidateDisconnected", this.internetReachbilityTimeout);
|
|
464
475
|
if (this.internetReachbilityTimeout) {
|
package/lib/model/Event.d.ts
CHANGED
|
@@ -7,6 +7,7 @@ export declare enum VaniEvent {
|
|
|
7
7
|
OnSocketConnected = "onConnected",
|
|
8
8
|
OnSocketReconnectTimeOut = "onReconnectTimeOut",
|
|
9
9
|
OnSocketDisconnected = "onSocketDisconnected",
|
|
10
|
+
OnAskedToCloseTheRoom = "OnAskedToCloseTheRoom",
|
|
10
11
|
OnConnected = "onConnected",
|
|
11
12
|
OnConnectionBack = "connectionBack",
|
|
12
13
|
OnMeetingStartTime = "meetingStartTime",
|
package/lib/model/Event.js
CHANGED
|
@@ -5,6 +5,7 @@ export var VaniEvent;
|
|
|
5
5
|
VaniEvent["OnSocketConnected"] = "onConnected";
|
|
6
6
|
VaniEvent["OnSocketReconnectTimeOut"] = "onReconnectTimeOut";
|
|
7
7
|
VaniEvent["OnSocketDisconnected"] = "onSocketDisconnected";
|
|
8
|
+
VaniEvent["OnAskedToCloseTheRoom"] = "OnAskedToCloseTheRoom";
|
|
8
9
|
VaniEvent["OnConnected"] = "onConnected";
|
|
9
10
|
VaniEvent["OnConnectionBack"] = "connectionBack";
|
|
10
11
|
VaniEvent["OnMeetingStartTime"] = "meetingStartTime";
|
|
@@ -142,14 +142,13 @@ var SFUHandler = /** @class */ (function (_super) {
|
|
|
142
142
|
});
|
|
143
143
|
};
|
|
144
144
|
SFUHandler.prototype.stopTrack = function (track) {
|
|
145
|
-
var _a;
|
|
146
145
|
var producer = this.producers.find(function (producer) { return producer.appData.trackId === track.trackId; });
|
|
147
146
|
if (producer) {
|
|
148
|
-
try {
|
|
149
|
-
|
|
150
|
-
}
|
|
151
|
-
catch (err) {
|
|
152
|
-
}
|
|
147
|
+
// try {
|
|
148
|
+
// producer.track?.stop()
|
|
149
|
+
// }
|
|
150
|
+
// catch (err) {
|
|
151
|
+
// }
|
|
153
152
|
producer.close();
|
|
154
153
|
var messageJson = { to: "self", type: SFUMessageType.OnProducerClosed, message: { producerId: producer.id } };
|
|
155
154
|
this.sendSFUMessageToSocket(messageJson);
|
|
@@ -274,8 +273,18 @@ var SFUHandler = /** @class */ (function (_super) {
|
|
|
274
273
|
this.stopTrack(track);
|
|
275
274
|
}
|
|
276
275
|
if (!(producer && producer.closed === false && ((_b = this.meetingStartRequest) === null || _b === void 0 ? void 0 : _b.isMobileApp) === false)) return [3 /*break*/, 2];
|
|
276
|
+
// try {
|
|
277
|
+
// producer.track?.stop()
|
|
278
|
+
// }
|
|
279
|
+
// catch (err) {
|
|
280
|
+
// }
|
|
277
281
|
return [4 /*yield*/, producer.replaceTrack({ track: track.track })];
|
|
278
282
|
case 1:
|
|
283
|
+
// try {
|
|
284
|
+
// producer.track?.stop()
|
|
285
|
+
// }
|
|
286
|
+
// catch (err) {
|
|
287
|
+
// }
|
|
279
288
|
_f.sent();
|
|
280
289
|
this.resumeTrack(track);
|
|
281
290
|
return [3 /*break*/, 4];
|
|
@@ -371,26 +380,26 @@ var SFUHandler = /** @class */ (function (_super) {
|
|
|
371
380
|
});
|
|
372
381
|
};
|
|
373
382
|
SFUHandler.prototype.onTransportNotFound = function (data) {
|
|
374
|
-
var _a
|
|
383
|
+
var _a;
|
|
375
384
|
return __awaiter(this, void 0, void 0, function () {
|
|
376
|
-
var _i,
|
|
377
|
-
return __generator(this, function (
|
|
378
|
-
for (_i = 0,
|
|
379
|
-
producer =
|
|
385
|
+
var _i, _b, producer, _c, _d, consumer, messageJson;
|
|
386
|
+
return __generator(this, function (_e) {
|
|
387
|
+
for (_i = 0, _b = this.producers; _i < _b.length; _i++) {
|
|
388
|
+
producer = _b[_i];
|
|
380
389
|
if (producer) {
|
|
381
|
-
try {
|
|
382
|
-
|
|
383
|
-
}
|
|
384
|
-
catch (err) {
|
|
385
|
-
}
|
|
390
|
+
// try {
|
|
391
|
+
// producer.track?.stop()
|
|
392
|
+
// }
|
|
393
|
+
// catch (err) {
|
|
394
|
+
// }
|
|
386
395
|
producer.close();
|
|
387
396
|
}
|
|
388
397
|
}
|
|
389
|
-
for (
|
|
390
|
-
consumer =
|
|
398
|
+
for (_c = 0, _d = this.consumers; _c < _d.length; _c++) {
|
|
399
|
+
consumer = _d[_c];
|
|
391
400
|
if (consumer) {
|
|
392
401
|
try {
|
|
393
|
-
(
|
|
402
|
+
(_a = consumer.track) === null || _a === void 0 ? void 0 : _a.stop();
|
|
394
403
|
}
|
|
395
404
|
catch (err) {
|
|
396
405
|
}
|
|
@@ -5,6 +5,7 @@ export declare enum WebSocketBasicEvents {
|
|
|
5
5
|
IsSetupDone = "setupDone",
|
|
6
6
|
Ping = "ping",
|
|
7
7
|
Pong = "pong",
|
|
8
|
+
CloseRoomForceFully = "CloseRoomForceFully",
|
|
8
9
|
AudioVideoPauseResume = "audioVideoPauseResume",
|
|
9
10
|
OnStartMeetingCalled = "startMeetingCalled",
|
|
10
11
|
OnAudioVideoPauseResume = "audioVideoPauseResume",
|
|
@@ -91,6 +92,7 @@ export declare class WebsocketHandler extends Base {
|
|
|
91
92
|
private socketSubscribeToTopic;
|
|
92
93
|
private askIfSetupDone;
|
|
93
94
|
private onMessage;
|
|
95
|
+
onCloseTheRoomForcefully: (data: any) => Promise<void>;
|
|
94
96
|
private onSetupDone;
|
|
95
97
|
private checkIfPingIsRunning;
|
|
96
98
|
private isVideoCallControllerMessageType;
|
|
@@ -60,6 +60,7 @@ export var WebSocketBasicEvents;
|
|
|
60
60
|
WebSocketBasicEvents["IsSetupDone"] = "setupDone";
|
|
61
61
|
WebSocketBasicEvents["Ping"] = "ping";
|
|
62
62
|
WebSocketBasicEvents["Pong"] = "pong";
|
|
63
|
+
WebSocketBasicEvents["CloseRoomForceFully"] = "CloseRoomForceFully";
|
|
63
64
|
WebSocketBasicEvents["AudioVideoPauseResume"] = "audioVideoPauseResume";
|
|
64
65
|
WebSocketBasicEvents["OnStartMeetingCalled"] = "startMeetingCalled";
|
|
65
66
|
WebSocketBasicEvents["OnAudioVideoPauseResume"] = "audioVideoPauseResume";
|
|
@@ -133,6 +134,18 @@ var WebsocketHandler = /** @class */ (function (_super) {
|
|
|
133
134
|
_this.setUpTry = 0;
|
|
134
135
|
_this.pongData = undefined;
|
|
135
136
|
_this.lastPingTimeStamp = 0;
|
|
137
|
+
_this.onCloseTheRoomForcefully = function (data) { return __awaiter(_this, void 0, void 0, function () {
|
|
138
|
+
var _a, _b;
|
|
139
|
+
return __generator(this, function (_c) {
|
|
140
|
+
switch (_c.label) {
|
|
141
|
+
case 0: return [4 /*yield*/, ((_a = this.communicationHandler) === null || _a === void 0 ? void 0 : _a.emitMessageToSource(VaniEvent.OnAskedToCloseTheRoom, {}))];
|
|
142
|
+
case 1:
|
|
143
|
+
_c.sent();
|
|
144
|
+
(_b = this.communicationHandler) === null || _b === void 0 ? void 0 : _b.destoryRoomForcefully();
|
|
145
|
+
return [2 /*return*/];
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
}); };
|
|
136
149
|
return _this;
|
|
137
150
|
}
|
|
138
151
|
WebsocketHandler.prototype.onObjectCreated = function () {
|
|
@@ -398,6 +411,9 @@ var WebsocketHandler = /** @class */ (function (_super) {
|
|
|
398
411
|
else if (type === WebSocketBasicEvents.IsSetupDone) {
|
|
399
412
|
this.onSetupDone(data);
|
|
400
413
|
}
|
|
414
|
+
else if (type === WebSocketBasicEvents.CloseRoomForceFully) {
|
|
415
|
+
this.onCloseTheRoomForcefully(data);
|
|
416
|
+
}
|
|
401
417
|
else if (type === WebSocketBasicEvents.OnUserOnFoundWhileReconnect) {
|
|
402
418
|
(_b = this.communicationHandler) === null || _b === void 0 ? void 0 : _b.emitMessageToSource(VaniEvent.OnUserOnFoundWhileReconnect, {});
|
|
403
419
|
}
|