openvidu/openvidu-node-client/src/Recording.ts

145 lines
3.9 KiB
TypeScript
Raw Normal View History

/*
* (C) Copyright 2017-2018 OpenVidu (https://openvidu.io/)
*
* 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.
*
*/
import { RecordingProperties } from './RecordingProperties';
import { RecordingLayout } from './RecordingLayout';
/**
* See [[OpenVidu.startRecording]]
*/
export class Recording {
2018-03-14 18:48:29 +01:00
/**
* Recording unique identifier
*/
id: string;
/**
* Session associated to the recording
*/
sessionId: string;
/**
* Time when the recording started in UTC milliseconds
*/
createdAt: number;
/**
* Size of the recording in bytes (0 until the recording is stopped)
*/
size = 0;
/**
* Duration of the recording in seconds (0 until the recording is stopped)
*/
duration = 0;
/**
* URL of the recording. You can access the file from there. It is `null` until recording is stopped or if OpenVidu Server configuration property `openvidu.recording.public-access` is false
*/
url: string;
/**
* Status of the recording
*/
status: Recording.Status;
/**
* Technical properties of the recorded file
*/
properties: RecordingProperties;
2018-03-14 18:48:29 +01:00
/* tslint:disable:no-string-literal */
/**
* @hidden
*/
2018-03-14 18:48:29 +01:00
constructor(json: JSON) {
this.id = json['id'];
this.sessionId = json['sessionId'];
this.createdAt = json['createdAt'];
this.size = json['size'];
this.duration = json['duration'];
this.url = json['url'];
this.status = json['status'];
this.properties = {
name: !!(json['name']) ? json['name'] : this.id,
outputMode: !!(json['outputMode']) ? json['outputMode'] : Recording.OutputMode.COMPOSED,
hasAudio: !!(json['hasAudio']),
hasVideo: !!json['hasVideo']
};
if (this.properties.outputMode.toString() === Recording.OutputMode[Recording.OutputMode.COMPOSED]) {
this.properties.recordingLayout = !!(json['recordingLayout']) ? json['recordingLayout'] : RecordingLayout.BEST_FIT;
if (this.properties.recordingLayout.toString() === RecordingLayout[RecordingLayout.CUSTOM]) {
this.properties.customLayout = json['customLayout'];
}
}
2018-03-14 18:48:29 +01:00
}
/* tslint:enable:no-string-literal */
2018-03-14 18:48:29 +01:00
}
export namespace Recording {
/**
* See [[Recording.status]]
*/
2018-03-14 18:48:29 +01:00
export enum Status {
2018-04-25 11:03:30 +02:00
/**
* The recording is starting (cannot be stopped)
*/
starting = 'starting',
2018-04-25 11:03:30 +02:00
/**
* The recording has started and is going on
*/
started = 'started',
2018-04-25 11:03:30 +02:00
/**
* The recording has finished OK
*/
stopped = 'stopped',
2018-04-25 11:03:30 +02:00
/**
* The recording is available for downloading. This status is reached for all
* stopped recordings if [OpenVidu Server configuration](https://openvidu.io/docs/reference-docs/openvidu-server-params/)
* property `openvidu.recording.public-access` is true
2018-04-25 11:03:30 +02:00
*/
available = 'available',
2018-04-25 11:03:30 +02:00
/**
* The recording has failed
*/
failed = 'failed'
2018-03-14 18:48:29 +01:00
}
/**
* See [[RecordingProperties.outputMode]]
*/
export enum OutputMode {
/**
* Record all streams in a grid layout in a single archive
*/
COMPOSED = 'COMPOSED',
/**
* Record each stream individually
*/
INDIVIDUAL = 'INDIVIDUAL'
}
2018-03-14 18:48:29 +01:00
}