2018-04-18 14:29:07 +02:00
|
|
|
/*
|
2018-05-06 02:20:25 +02:00
|
|
|
* (C) Copyright 2017-2018 OpenVidu (https://openvidu.io/)
|
2018-04-18 14:29:07 +02:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-04-23 11:06:16 +02:00
|
|
|
import { Session } from './Session';
|
|
|
|
import { SessionProperties } from './SessionProperties';
|
|
|
|
import { Recording } from './Recording';
|
|
|
|
import { RecordingProperties } from './RecordingProperties';
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-07-13 12:56:27 +02:00
|
|
|
import axios from 'axios';
|
2017-06-10 01:44:31 +02:00
|
|
|
|
|
|
|
export class OpenVidu {
|
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
private Buffer = require('buffer/').Buffer;
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-07-22 22:13:45 +02:00
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static hostname: string;
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static port: number;
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static basicAuth: string;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static readonly API_RECORDINGS: string = '/api/recordings';
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static readonly API_RECORDINGS_START: string = '/start';
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static readonly API_RECORDINGS_STOP: string = '/stop';
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static readonly API_SESSIONS = '/api/sessions';
|
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static readonly API_TOKENS = '/api/tokens';
|
|
|
|
|
|
|
|
private static o: OpenVidu;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Array of active sessions. **This value will remain unchanged since the last time method [[OpenVidu.fetch]]
|
|
|
|
* was called**. Exceptions to this rule are:
|
|
|
|
*
|
|
|
|
* - Calling [[Session.fetch]] updates that specific Session status
|
|
|
|
* - Calling [[Session.close]] automatically removes the Session from the list of active Sessions
|
|
|
|
* - Calling [[Session.forceDisconnect]] automatically updates the inner affected connections for that specific Session
|
|
|
|
* - Calling [[Session.forceUnpublish]] also automatically updates the inner affected connections for that specific Session
|
|
|
|
* - Calling [[OpenVidu.startRecording]] and [[OpenVidu.stopRecording]] automatically updates the recording status of the
|
|
|
|
* Session ([[Session.recording]])
|
|
|
|
*
|
|
|
|
* To get the array of active sessions with their current actual value, you must call [[OpenVidu.fetch]] before consulting
|
|
|
|
* property [[activeSessions]]
|
|
|
|
*/
|
|
|
|
activeSessions: Session[] = [];
|
|
|
|
|
2018-04-24 15:42:23 +02:00
|
|
|
/**
|
|
|
|
* @param urlOpenViduServer Public accessible IP where your instance of OpenVidu Server is up an running
|
|
|
|
* @param secret Secret used on OpenVidu Server initialization
|
|
|
|
*/
|
2018-03-14 18:48:29 +01:00
|
|
|
constructor(private urlOpenViduServer: string, secret: string) {
|
|
|
|
this.setHostnameAndPort();
|
2018-07-22 22:13:45 +02:00
|
|
|
OpenVidu.basicAuth = this.getBasicAuth(secret);
|
|
|
|
OpenVidu.o = this;
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2017-06-10 01:44:31 +02:00
|
|
|
|
2018-04-25 17:50:55 +02:00
|
|
|
/**
|
2018-07-22 22:13:45 +02:00
|
|
|
* Creates an OpenVidu session. You can call [[Session.getSessionId]] inside the resolved promise to retrieve the `sessionId`
|
2018-04-25 17:50:55 +02:00
|
|
|
*
|
2018-05-03 10:58:26 +02:00
|
|
|
* @returns A Promise that is resolved to the [[Session]] if success and rejected with an Error object if not.
|
2018-04-25 17:50:55 +02:00
|
|
|
*/
|
|
|
|
public createSession(properties?: SessionProperties): Promise<Session> {
|
|
|
|
return new Promise<Session>((resolve, reject) => {
|
2018-07-22 22:13:45 +02:00
|
|
|
const session = new Session(properties);
|
2018-04-25 17:50:55 +02:00
|
|
|
session.getSessionIdHttp()
|
|
|
|
.then(sessionId => {
|
2018-07-22 22:13:45 +02:00
|
|
|
this.activeSessions.push(session);
|
2018-04-25 17:50:55 +02:00
|
|
|
resolve(session);
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
reject(error);
|
|
|
|
});
|
|
|
|
});
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
|
|
|
|
2018-04-18 14:23:16 +02:00
|
|
|
public startRecording(sessionId: string): Promise<Recording>;
|
|
|
|
public startRecording(sessionId: string, name: string): Promise<Recording>;
|
|
|
|
public startRecording(sessionId: string, properties: RecordingProperties): Promise<Recording>;
|
|
|
|
|
2018-04-24 15:42:23 +02:00
|
|
|
/**
|
|
|
|
* Starts the recording of a [[Session]]
|
|
|
|
*
|
|
|
|
* @param sessionId The `sessionId` of the [[Session]] you want to start recording
|
|
|
|
* @param name The name you want to give to the video file. You can access this same value in your clients on recording events (`recordingStarted`, `recordingStopped`)
|
2018-07-22 22:13:45 +02:00
|
|
|
* **WARNING: this parameter follows an overwriting policy.** If you name two recordings the same, the newest MP4 file will overwrite the oldest one
|
2018-04-24 15:42:23 +02:00
|
|
|
*
|
2018-04-25 11:03:30 +02:00
|
|
|
* @returns A Promise that is resolved to the [[Recording]] if it successfully started (the recording can be stopped with guarantees) and rejected with an Error object if not. This Error object has as `message` property with the following values:
|
2018-04-24 15:42:23 +02:00
|
|
|
* - `404`: no session exists for the passed `sessionId`
|
|
|
|
* - `400`: the session has no connected participants
|
|
|
|
* - `409`: the session is not configured for using [[MediaMode.ROUTED]] or it is already being recorded
|
2018-05-03 12:27:27 +02:00
|
|
|
* - `501`: OpenVidu Server recording module is disabled (`openvidu.recording` property set to `false`)
|
2018-04-24 15:42:23 +02:00
|
|
|
*/
|
2018-04-18 14:23:16 +02:00
|
|
|
public startRecording(sessionId: string, param2?: string | RecordingProperties): Promise<Recording> {
|
2018-04-18 10:39:39 +02:00
|
|
|
return new Promise<Recording>((resolve, reject) => {
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
let data;
|
2018-04-18 14:23:16 +02:00
|
|
|
|
|
|
|
if (!!param2) {
|
|
|
|
if (!(typeof param2 === 'string')) {
|
2018-04-20 12:04:56 +02:00
|
|
|
const properties = <RecordingProperties>param2;
|
2018-06-04 14:14:17 +02:00
|
|
|
data = JSON.stringify({
|
2018-04-18 14:23:16 +02:00
|
|
|
session: sessionId,
|
2018-04-23 11:06:16 +02:00
|
|
|
name: !!properties.name ? properties.name : '',
|
|
|
|
recordingLayout: !!properties.recordingLayout ? properties.recordingLayout : '',
|
|
|
|
customLayout: !!properties.customLayout ? properties.customLayout : ''
|
2018-04-18 14:23:16 +02:00
|
|
|
});
|
|
|
|
} else {
|
2018-06-04 14:14:17 +02:00
|
|
|
data = JSON.stringify({
|
2018-04-18 14:23:16 +02:00
|
|
|
session: sessionId,
|
2018-04-20 12:04:56 +02:00
|
|
|
name: param2,
|
2018-04-20 15:50:56 +02:00
|
|
|
recordingLayout: '',
|
|
|
|
customLayout: ''
|
2018-04-18 14:23:16 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
} else {
|
2018-06-04 14:14:17 +02:00
|
|
|
data = JSON.stringify({
|
2018-04-18 14:23:16 +02:00
|
|
|
session: sessionId,
|
2018-04-20 12:04:56 +02:00
|
|
|
name: '',
|
2018-04-20 15:50:56 +02:00
|
|
|
recordingLayout: '',
|
|
|
|
customLayout: ''
|
2018-04-18 14:23:16 +02:00
|
|
|
});
|
|
|
|
}
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
axios.post(
|
2018-07-22 22:13:45 +02:00
|
|
|
'https://' + OpenVidu.hostname + ':' + OpenVidu.port + OpenVidu.API_RECORDINGS + OpenVidu.API_RECORDINGS_START,
|
2018-06-04 14:14:17 +02:00
|
|
|
data,
|
|
|
|
{
|
|
|
|
headers: {
|
2018-07-22 22:13:45 +02:00
|
|
|
'Authorization': OpenVidu.basicAuth,
|
2018-06-04 14:14:17 +02:00
|
|
|
'Content-Type': 'application/json'
|
|
|
|
}
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2018-06-04 14:14:17 +02:00
|
|
|
)
|
|
|
|
.then(res => {
|
|
|
|
if (res.status === 200) {
|
2018-04-18 10:39:39 +02:00
|
|
|
// SUCCESS response from openvidu-server (Recording in JSON format). Resolve new Recording
|
2018-07-22 22:13:45 +02:00
|
|
|
const r: Recording = new Recording(res.data);
|
2018-07-23 00:36:45 +02:00
|
|
|
const activeSession = this.activeSessions.find(s => s.sessionId === r.sessionId);
|
|
|
|
if (!!activeSession) {
|
|
|
|
activeSession.recording = true;
|
|
|
|
} else {
|
|
|
|
console.warn("No active session found for sessionId '" + r.sessionId + "'. This instance of OpenVidu Node Client didn't create this session");
|
|
|
|
}
|
2018-07-22 22:13:45 +02:00
|
|
|
resolve(r);
|
2018-03-14 18:48:29 +01:00
|
|
|
} else {
|
|
|
|
// ERROR response from openvidu-server. Resolve HTTP status
|
2018-06-04 14:14:17 +02:00
|
|
|
reject(new Error(res.status.toString()));
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code (not 2xx)
|
|
|
|
reject(new Error(error.response.status.toString()));
|
|
|
|
} else if (error.request) {
|
|
|
|
// The request was made but no response was received
|
|
|
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
|
|
|
// http.ClientRequest in node.js
|
|
|
|
console.error(error.request);
|
|
|
|
} else {
|
|
|
|
// Something happened in setting up the request that triggered an Error
|
|
|
|
console.error('Error', error.message);
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-04-24 15:42:23 +02:00
|
|
|
/**
|
|
|
|
* Stops the recording of a [[Session]]
|
|
|
|
*
|
|
|
|
* @param recordingId The `id` property of the [[Recording]] you want to stop
|
|
|
|
*
|
|
|
|
* @returns A Promise that is resolved to the [[Recording]] if it successfully stopped and rejected with an Error object if not. This Error object has as `message` property with the following values:
|
|
|
|
* - `404`: no recording exists for the passed `recordingId`
|
|
|
|
* - `406`: recording has `starting` status. Wait until `started` status before stopping the recording
|
|
|
|
*/
|
2018-04-18 10:39:39 +02:00
|
|
|
public stopRecording(recordingId: string): Promise<Recording> {
|
|
|
|
return new Promise<Recording>((resolve, reject) => {
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
axios.post(
|
2018-07-22 22:13:45 +02:00
|
|
|
'https://' + OpenVidu.hostname + ':' + OpenVidu.port + OpenVidu.API_RECORDINGS + OpenVidu.API_RECORDINGS_STOP + '/' + recordingId,
|
2018-06-04 14:14:17 +02:00
|
|
|
undefined,
|
|
|
|
{
|
|
|
|
headers: {
|
2018-07-22 22:13:45 +02:00
|
|
|
'Authorization': OpenVidu.basicAuth,
|
2018-06-04 14:14:17 +02:00
|
|
|
'Content-Type': 'application/x-www-form-urlencoded'
|
|
|
|
}
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2018-06-04 14:14:17 +02:00
|
|
|
)
|
|
|
|
.then(res => {
|
|
|
|
if (res.status === 200) {
|
2018-04-18 10:39:39 +02:00
|
|
|
// SUCCESS response from openvidu-server (Recording in JSON format). Resolve new Recording
|
2018-07-22 22:13:45 +02:00
|
|
|
const r: Recording = new Recording(res.data);
|
2018-07-23 00:36:45 +02:00
|
|
|
const activeSession = this.activeSessions.find(s => s.sessionId === r.sessionId);
|
|
|
|
if (!!activeSession) {
|
|
|
|
activeSession.recording = false;
|
|
|
|
} else {
|
|
|
|
console.warn("No active session found for sessionId '" + r.sessionId + "'. This instance of OpenVidu Node Client didn't create this session");
|
|
|
|
}
|
2018-07-22 22:13:45 +02:00
|
|
|
resolve(r);
|
2018-03-14 18:48:29 +01:00
|
|
|
} else {
|
|
|
|
// ERROR response from openvidu-server. Resolve HTTP status
|
2018-06-04 14:14:17 +02:00
|
|
|
reject(new Error(res.status.toString()));
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code (not 2xx)
|
|
|
|
reject(new Error(error.response.status.toString()));
|
|
|
|
} else if (error.request) {
|
2018-07-22 22:13:45 +02:00
|
|
|
// The request was made but no response was received `error.request` is an instance of XMLHttpRequest
|
|
|
|
// in the browser and an instance of http.ClientRequest in node.js
|
2018-06-04 14:14:17 +02:00
|
|
|
console.error(error.request);
|
|
|
|
} else {
|
|
|
|
// Something happened in setting up the request that triggered an Error
|
|
|
|
console.error('Error', error.message);
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-04-24 15:42:23 +02:00
|
|
|
/**
|
|
|
|
* Gets an existing [[Recording]]
|
|
|
|
*
|
|
|
|
* @param recordingId The `id` property of the [[Recording]] you want to retrieve
|
|
|
|
*
|
|
|
|
* @returns A Promise that is resolved to the [[Recording]] if it successfully stopped and rejected with an Error object if not. This Error object has as `message` property with the following values:
|
|
|
|
* - `404`: no recording exists for the passed `recordingId`
|
|
|
|
*/
|
2018-04-18 10:39:39 +02:00
|
|
|
public getRecording(recordingId: string): Promise<Recording> {
|
|
|
|
return new Promise<Recording>((resolve, reject) => {
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
axios.get(
|
2018-07-22 22:13:45 +02:00
|
|
|
'https://' + OpenVidu.hostname + ':' + OpenVidu.port + OpenVidu.API_RECORDINGS + '/' + recordingId,
|
2018-06-04 14:14:17 +02:00
|
|
|
{
|
|
|
|
headers: {
|
2018-07-22 22:13:45 +02:00
|
|
|
'Authorization': OpenVidu.basicAuth,
|
2018-06-04 14:14:17 +02:00
|
|
|
'Content-Type': 'application/x-www-form-urlencoded'
|
|
|
|
}
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2018-06-04 14:14:17 +02:00
|
|
|
)
|
|
|
|
.then(res => {
|
|
|
|
if (res.status === 200) {
|
2018-04-18 10:39:39 +02:00
|
|
|
// SUCCESS response from openvidu-server (Recording in JSON format). Resolve new Recording
|
2018-06-04 14:14:17 +02:00
|
|
|
resolve(new Recording(res.data));
|
2018-03-14 18:48:29 +01:00
|
|
|
} else {
|
|
|
|
// ERROR response from openvidu-server. Resolve HTTP status
|
2018-06-04 14:14:17 +02:00
|
|
|
reject(new Error(res.status.toString()));
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code (not 2xx)
|
|
|
|
reject(new Error(error.response.status.toString()));
|
|
|
|
} else if (error.request) {
|
|
|
|
// The request was made but no response was received
|
|
|
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
|
|
|
// http.ClientRequest in node.js
|
|
|
|
console.error(error.request);
|
|
|
|
} else {
|
|
|
|
// Something happened in setting up the request that triggered an Error
|
|
|
|
console.error('Error', error.message);
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-04-24 15:42:23 +02:00
|
|
|
/**
|
|
|
|
* Lists all existing recordings
|
|
|
|
*
|
|
|
|
* @returns A Promise that is resolved to an array with all existing recordings
|
|
|
|
*/
|
2018-04-18 10:39:39 +02:00
|
|
|
public listRecordings(): Promise<Recording[]> {
|
|
|
|
return new Promise<Recording[]>((resolve, reject) => {
|
2018-03-14 18:48:29 +01:00
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
axios.get(
|
2018-07-22 22:13:45 +02:00
|
|
|
'https://' + OpenVidu.hostname + ':' + OpenVidu.port + OpenVidu.API_RECORDINGS,
|
2018-06-04 14:14:17 +02:00
|
|
|
{
|
|
|
|
headers: {
|
2018-07-22 22:13:45 +02:00
|
|
|
Authorization: OpenVidu.basicAuth
|
2018-06-04 14:14:17 +02:00
|
|
|
}
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2018-06-04 14:14:17 +02:00
|
|
|
)
|
|
|
|
.then(res => {
|
|
|
|
if (res.status === 200) {
|
2018-04-18 10:39:39 +02:00
|
|
|
// SUCCESS response from openvidu-server (JSON arrays of recordings in JSON format). Resolve list of new recordings
|
2018-04-23 11:06:16 +02:00
|
|
|
const recordingArray: Recording[] = [];
|
2018-06-04 14:14:17 +02:00
|
|
|
const responseItems = res.data.items;
|
2018-04-23 11:06:16 +02:00
|
|
|
for (const item of responseItems) {
|
|
|
|
recordingArray.push(new Recording(item));
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2018-04-18 10:39:39 +02:00
|
|
|
resolve(recordingArray);
|
2018-03-14 18:48:29 +01:00
|
|
|
} else {
|
|
|
|
// ERROR response from openvidu-server. Resolve HTTP status
|
2018-06-04 14:14:17 +02:00
|
|
|
reject(new Error(res.status.toString()));
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code (not 2xx)
|
|
|
|
reject(new Error(error.response.status.toString()));
|
|
|
|
} else if (error.request) {
|
|
|
|
// The request was made but no response was received
|
|
|
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
|
|
|
// http.ClientRequest in node.js
|
|
|
|
console.error(error.request);
|
|
|
|
} else {
|
|
|
|
// Something happened in setting up the request that triggered an Error
|
|
|
|
console.error('Error', error.message);
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-04-24 15:42:23 +02:00
|
|
|
/**
|
|
|
|
* Deletes a [[Recording]]. The recording must have status `stopped` or `available`
|
|
|
|
*
|
|
|
|
* @param recordingId
|
|
|
|
*
|
|
|
|
* @returns A Promise that is resolved if the Recording was successfully deleted and rejected with an Error object if not. This Error object has as `message` property with the following values:
|
|
|
|
* - `404`: no recording exists for the passed `recordingId`
|
|
|
|
* - `409`: the recording has `started` status. Stop it before deletion
|
|
|
|
*/
|
2018-03-14 18:48:29 +01:00
|
|
|
public deleteRecording(recordingId: string): Promise<Error> {
|
|
|
|
return new Promise<Error>((resolve, reject) => {
|
|
|
|
|
2018-06-04 14:14:17 +02:00
|
|
|
axios.delete(
|
2018-07-22 22:13:45 +02:00
|
|
|
'https://' + OpenVidu.hostname + ':' + OpenVidu.port + OpenVidu.API_RECORDINGS + '/' + recordingId,
|
2018-06-04 14:14:17 +02:00
|
|
|
{
|
|
|
|
headers: {
|
2018-07-22 22:13:45 +02:00
|
|
|
'Authorization': OpenVidu.basicAuth,
|
2018-06-04 14:14:17 +02:00
|
|
|
'Content-Type': 'application/x-www-form-urlencoded'
|
|
|
|
}
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
2018-06-04 14:14:17 +02:00
|
|
|
)
|
|
|
|
.then(res => {
|
|
|
|
if (res.status === 204) {
|
2018-03-14 18:48:29 +01:00
|
|
|
// SUCCESS response from openvidu-server. Resolve undefined
|
|
|
|
resolve(undefined);
|
|
|
|
} else {
|
|
|
|
// ERROR response from openvidu-server. Resolve HTTP status
|
2018-06-04 14:14:17 +02:00
|
|
|
reject(new Error(res.status.toString()));
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code (not 2xx)
|
|
|
|
reject(new Error(error.response.status.toString()));
|
|
|
|
} else if (error.request) {
|
|
|
|
// The request was made but no response was received
|
|
|
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
|
|
|
// http.ClientRequest in node.js
|
|
|
|
console.error(error.request);
|
|
|
|
} else {
|
|
|
|
// Something happened in setting up the request that triggered an Error
|
|
|
|
console.error('Error', error.message);
|
2018-03-14 18:48:29 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2018-01-27 19:39:49 +01:00
|
|
|
}
|
|
|
|
|
2018-07-22 22:13:45 +02:00
|
|
|
/**
|
|
|
|
* Updates every property of every active Session with the current status they have in OpenVidu Server.
|
|
|
|
* After calling this method you can access the updated array of active sessions in [[activeSessions]]
|
|
|
|
*
|
|
|
|
* @returns A promise resolved to true if any Session status has changed with respect to the server, or to false if not.
|
|
|
|
* This applies to any property or sub-property of any of the sessions locally stored in OpenVidu Node Client
|
|
|
|
*/
|
|
|
|
public fetch(): Promise<boolean> {
|
|
|
|
return new Promise<boolean>((resolve, reject) => {
|
|
|
|
axios.get(
|
|
|
|
'https://' + OpenVidu.hostname + ':' + OpenVidu.port + OpenVidu.API_SESSIONS,
|
|
|
|
{
|
|
|
|
headers: {
|
|
|
|
Authorization: OpenVidu.basicAuth
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
.then(res => {
|
|
|
|
if (res.status === 200) {
|
|
|
|
|
|
|
|
// Array to store fetched sessionIds and later remove closed sessions
|
|
|
|
const fetchedSessionIds: string[] = [];
|
|
|
|
// Boolean to store if any Session has changed
|
|
|
|
let hasChanged = false;
|
|
|
|
|
|
|
|
res.data.content.forEach(session => {
|
|
|
|
fetchedSessionIds.push(session.sessionId);
|
|
|
|
let storedSession = this.activeSessions.find(s => s.sessionId === session.sessionId);
|
|
|
|
if (!!storedSession) {
|
|
|
|
const beforeJSON: string = JSON.stringify(storedSession);
|
|
|
|
storedSession = storedSession.resetSessionWithJson(session);
|
|
|
|
const afterJSON: string = JSON.stringify(storedSession);
|
|
|
|
const changed: boolean = !(beforeJSON === afterJSON);
|
|
|
|
console.log("Available session '" + storedSession.sessionId + "' info fetched. Any change: " + changed);
|
|
|
|
hasChanged = hasChanged || changed;
|
|
|
|
} else {
|
|
|
|
this.activeSessions.push(new Session(session));
|
|
|
|
console.log("New session '" + session.sessionId + "' info fetched");
|
|
|
|
hasChanged = true;
|
|
|
|
}
|
|
|
|
});
|
2018-07-22 22:48:09 +02:00
|
|
|
// Remove closed sessions from activeSessions array
|
|
|
|
this.activeSessions = this.activeSessions.filter(session => (!!fetchedSessionIds.find(sId => sId === session.sessionId)));
|
|
|
|
console.log('Active sessions info fetched: ', fetchedSessionIds);
|
2018-07-22 22:13:45 +02:00
|
|
|
resolve(hasChanged);
|
|
|
|
} else {
|
|
|
|
// ERROR response from openvidu-server. Resolve HTTP status
|
|
|
|
reject(new Error(res.status.toString()));
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
if (error.response) {
|
|
|
|
// The request was made and the server responded with a status code (not 2xx)
|
|
|
|
reject(new Error(error.response.status.toString()));
|
|
|
|
} else if (error.request) {
|
|
|
|
// The request was made but no response was received
|
|
|
|
// `error.request` is an instance of XMLHttpRequest in the browser and an instance of
|
|
|
|
// http.ClientRequest in node.js
|
|
|
|
console.error(error.request);
|
|
|
|
} else {
|
|
|
|
// Something happened in setting up the request that triggered an Error
|
|
|
|
console.error('Error', error.message);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-03-14 18:48:29 +01:00
|
|
|
private getBasicAuth(secret: string): string {
|
2018-06-04 14:14:17 +02:00
|
|
|
return 'Basic ' + this.Buffer('OPENVIDUAPP:' + secret).toString('base64');
|
2018-01-27 19:39:49 +01:00
|
|
|
}
|
|
|
|
|
2018-03-14 18:48:29 +01:00
|
|
|
private setHostnameAndPort(): void {
|
2018-04-23 11:06:16 +02:00
|
|
|
const urlSplitted = this.urlOpenViduServer.split(':');
|
2018-03-14 18:48:29 +01:00
|
|
|
if (urlSplitted.length === 3) { // URL has format: http:// + hostname + :port
|
2018-07-22 22:13:45 +02:00
|
|
|
OpenVidu.hostname = this.urlOpenViduServer.split(':')[1].replace(/\//g, '');
|
|
|
|
OpenVidu.port = parseInt(this.urlOpenViduServer.split(':')[2].replace(/\//g, ''));
|
2018-04-23 11:06:16 +02:00
|
|
|
} else if (urlSplitted.length === 2) { // URL has format: hostname + :port
|
2018-07-22 22:13:45 +02:00
|
|
|
OpenVidu.hostname = this.urlOpenViduServer.split(':')[0].replace(/\//g, '');
|
|
|
|
OpenVidu.port = parseInt(this.urlOpenViduServer.split(':')[1].replace(/\//g, ''));
|
2018-03-14 18:48:29 +01:00
|
|
|
} else {
|
|
|
|
console.error("URL format incorrect: it must contain hostname and port (current value: '" + this.urlOpenViduServer + "')");
|
|
|
|
}
|
2017-06-10 01:44:31 +02:00
|
|
|
}
|
|
|
|
|
2018-07-22 22:13:45 +02:00
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
|
|
|
static getActiveSessions(): Session[] {
|
|
|
|
return this.o.activeSessions;
|
|
|
|
}
|
|
|
|
|
2017-06-10 01:44:31 +02:00
|
|
|
}
|