@aws-cdk/aws-ivs-alpha
Version:
The CDK Construct Library for AWS::IVS
277 lines • 34.1 kB
JavaScript
;
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
var _, done = false;
for (var i = decorators.length - 1; i >= 0; i--) {
var context = {};
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
if (kind === "accessor") {
if (result === void 0) continue;
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
if (_ = accept(result.get)) descriptor.get = _;
if (_ = accept(result.set)) descriptor.set = _;
if (_ = accept(result.init)) initializers.unshift(_);
}
else if (_ = accept(result)) {
if (kind === "field") initializers.unshift(_);
else descriptor[key] = _;
}
}
if (target) Object.defineProperty(target, contextIn.name, descriptor);
done = true;
};
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
var useValue = arguments.length > 2;
for (var i = 0; i < initializers.length; i++) {
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
}
return useValue ? value : void 0;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Channel = exports.Policy = exports.MaximumResolution = exports.Preset = exports.ChannelType = exports.LatencyMode = exports.ContainerFormat = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const core = require("aws-cdk-lib/core");
const core_1 = require("aws-cdk-lib/core");
const aws_ivs_1 = require("aws-cdk-lib/aws-ivs");
const stream_key_1 = require("./stream-key");
const metadata_resource_1 = require("aws-cdk-lib/core/lib/metadata-resource");
const prop_injectable_1 = require("aws-cdk-lib/core/lib/prop-injectable");
/**
* Reference to a new or existing IVS Channel
*/
class ChannelBase extends core.Resource {
addStreamKey(id) {
return new stream_key_1.StreamKey(this, id, {
channel: this,
});
}
}
/**
* Container Format
*/
var ContainerFormat;
(function (ContainerFormat) {
/**
* Use MPEG-TS.
*/
ContainerFormat["TS"] = "TS";
/**
* Use fMP4.
*/
ContainerFormat["FRAGMENTED_MP4"] = "FRAGMENTED_MP4";
})(ContainerFormat || (exports.ContainerFormat = ContainerFormat = {}));
/**
* Channel latency mode
*/
var LatencyMode;
(function (LatencyMode) {
/**
* Use LOW to minimize broadcaster-to-viewer latency for interactive broadcasts.
*/
LatencyMode["LOW"] = "LOW";
/**
* Use NORMAL for broadcasts that do not require viewer interaction.
*/
LatencyMode["NORMAL"] = "NORMAL";
})(LatencyMode || (exports.LatencyMode = LatencyMode = {}));
/**
* The channel type, which determines the allowable resolution and bitrate.
* If you exceed the allowable resolution or bitrate, the stream probably will disconnect immediately.
*
* @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ivs-channel.html
*/
var ChannelType;
(function (ChannelType) {
/**
* Multiple qualities are generated from the original input, to automatically give viewers the best experience for their devices and network conditions.
* Transcoding allows higher playback quality across a range of download speeds. Resolution can be up to 1080p and bitrate can be up to 8.5 Mbps.
* Audio is transcoded only for renditions 360p and below; above that, audio is passed through.
*/
ChannelType["STANDARD"] = "STANDARD";
/**
* Delivers the original input to viewers. The viewer’s video-quality choice is limited to the original input.
*/
ChannelType["BASIC"] = "BASIC";
/**
* Multiple qualities are generated from the original input, to automatically give viewers the best experience for their devices and network conditions.
* Input resolution can be up to 1080p and bitrate can be up to 8.5 Mbps; output is capped at SD quality (480p).
* Audio for all renditions is transcoded, and an audio-only rendition is available.
*/
ChannelType["ADVANCED_SD"] = "ADVANCED_SD";
/**
* Multiple qualities are generated from the original input, to automatically give viewers the best experience for their devices and network conditions.
* Input resolution can be up to 1080p and bitrate can be up to 8.5 Mbps; output is capped at HD quality (720p).
* Audio for all renditions is transcoded, and an audio-only rendition is available.
*/
ChannelType["ADVANCED_HD"] = "ADVANCED_HD";
})(ChannelType || (exports.ChannelType = ChannelType = {}));
/**
* An optional transcode preset for the channel. This is selectable only for ADVANCED_HD and ADVANCED_SD channel types.
*
* @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ivs-channel.html
*/
var Preset;
(function (Preset) {
/**
* Use a lower bitrate than STANDARD for each quality level. Use it if you have low download bandwidth and/or simple video content (e.g., talking heads).
*/
Preset["CONSTRAINED_BANDWIDTH_DELIVERY"] = "CONSTRAINED_BANDWIDTH_DELIVERY";
/**
* Use a higher bitrate for each quality level. Use it if you have high download bandwidth and/or complex video content (e.g., flashes and quick scene changes).
*/
Preset["HIGHER_BANDWIDTH_DELIVERY"] = "HIGHER_BANDWIDTH_DELIVERY";
})(Preset || (exports.Preset = Preset = {}));
/**
* Maximum resolution for multitrack input.
*/
var MaximumResolution;
(function (MaximumResolution) {
/**
* Full HD (1080p)
*/
MaximumResolution["FULL_HD"] = "FULL_HD";
/**
* HD (720p)
*/
MaximumResolution["HD"] = "HD";
/**
* SD (480p)
*/
MaximumResolution["SD"] = "SD";
})(MaximumResolution || (exports.MaximumResolution = MaximumResolution = {}));
/**
* Whether multitrack input is allowed or required.
*/
var Policy;
(function (Policy) {
/**
* Multitrack input is allowed.
*/
Policy["ALLOW"] = "ALLOW";
/**
* Multitrack input is required.
*/
Policy["REQUIRE"] = "REQUIRE";
})(Policy || (exports.Policy = Policy = {}));
/**
A new IVS channel
*/
let Channel = (() => {
let _classDecorators = [prop_injectable_1.propertyInjectable];
let _classDescriptor;
let _classExtraInitializers = [];
let _classThis;
let _classSuper = ChannelBase;
var Channel = class extends _classSuper {
static { _classThis = this; }
static {
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
Channel = _classThis = _classDescriptor.value;
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
}
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-ivs-alpha.Channel", version: "2.223.0-alpha.0" };
/** Uniquely identifies this class. */
static PROPERTY_INJECTION_ID = '@aws-cdk.aws-ivs-alpha.Channel';
/**
* Import an existing channel
*/
static fromChannelArn(scope, id, channelArn) {
// This will throw an error if the arn cannot be parsed
let arnComponents = core.Arn.split(channelArn, core.ArnFormat.SLASH_RESOURCE_NAME);
if (!core.Token.isUnresolved(arnComponents.service) && arnComponents.service !== 'ivs') {
throw new Error(`Invalid service, expected 'ivs', got '${arnComponents.service}'`);
}
if (!core.Token.isUnresolved(arnComponents.resource) && arnComponents.resource !== 'channel') {
throw new Error(`Invalid resource, expected 'channel', got '${arnComponents.resource}'`);
}
class Import extends ChannelBase {
channelArn = channelArn;
}
return new Import(scope, id);
}
channelArn;
/**
* Channel ingest endpoint, part of the definition of an ingest server, used when you set up streaming software.
* For example: a1b2c3d4e5f6.global-contribute.live-video.net
* @attribute
*/
channelIngestEndpoint;
/**
* Channel playback URL. For example:
* https://a1b2c3d4e5f6.us-west-2.playback.live-video.net/api/video/v1/us-west-2.123456789012.channel.abcdEFGH.m3u8
* @attribute
*/
channelPlaybackUrl;
constructor(scope, id, props = {}) {
super(scope, id, {
physicalName: props.channelName ?? core_1.Lazy.string({
produce: () => core_1.Names.uniqueResourceName(this, { maxLength: 128, allowedSpecialCharacters: '-_' }),
}),
});
try {
jsiiDeprecationWarnings._aws_cdk_aws_ivs_alpha_ChannelProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, Channel);
}
throw error;
}
// Enhanced CDK Analytics Telemetry
(0, metadata_resource_1.addConstructMetadata)(this, props);
if (this.physicalName && !core.Token.isUnresolved(this.physicalName) && !/^[a-zA-Z0-9-_]*$/.test(this.physicalName)) {
throw new Error(`channelName must contain only numbers, letters, hyphens and underscores, got: '${this.physicalName}'`);
}
let preset;
if (props.type && [ChannelType.STANDARD, ChannelType.BASIC].includes(props.type) && props.preset) {
preset = '';
}
else {
preset = props.preset;
}
if (props.multitrackInputConfiguration !== undefined) {
if (props.type !== undefined && props.type !== ChannelType.STANDARD) {
throw new Error(`\`multitrackInputConfiguration\` is only supported for \`ChannelType.STANDARD\`, got: ${props.type}.`);
}
if (props.containerFormat !== undefined && props.containerFormat !== ContainerFormat.FRAGMENTED_MP4) {
throw new Error(`\`containerFormat\` must be set to \`ContainerFormat.FRAGMENTED_MP4\` when \`multitrackInputConfiguration\` is specified, got: ${props.containerFormat}.`);
}
}
const resource = new aws_ivs_1.CfnChannel(this, 'Resource', {
authorized: props.authorized,
insecureIngest: props.insecureIngest,
latencyMode: props.latencyMode,
name: this.physicalName,
type: props.type,
preset,
recordingConfigurationArn: props.recordingConfiguration?.recordingConfigurationArn,
containerFormat: props.containerFormat ??
(props.multitrackInputConfiguration ? ContainerFormat.FRAGMENTED_MP4 : undefined),
multitrackInputConfiguration: props.multitrackInputConfiguration ?
{
enabled: true,
maximumResolution: props.multitrackInputConfiguration.maximumResolution,
policy: props.multitrackInputConfiguration.policy,
}
: undefined,
});
this.channelArn = resource.attrArn;
this.channelIngestEndpoint = resource.attrIngestEndpoint;
this.channelPlaybackUrl = resource.attrPlaybackUrl;
}
static {
__runInitializers(_classThis, _classExtraInitializers);
}
};
return Channel = _classThis;
})();
exports.Channel = Channel;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"channel.js","sourceRoot":"","sources":["channel.ts"],"names":[],"mappings":"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","sourcesContent":["import * as core from 'aws-cdk-lib/core';\nimport { Lazy, Names } from 'aws-cdk-lib/core';\nimport { Construct } from 'constructs';\nimport { CfnChannel } from 'aws-cdk-lib/aws-ivs';\nimport { StreamKey } from './stream-key';\nimport { IRecordingConfiguration } from './recording-configuration';\nimport { addConstructMetadata } from 'aws-cdk-lib/core/lib/metadata-resource';\nimport { propertyInjectable } from 'aws-cdk-lib/core/lib/prop-injectable';\n\n/**\n * Represents an IVS Channel\n */\nexport interface IChannel extends core.IResource {\n  /**\n   * The channel ARN. For example: arn:aws:ivs:us-west-2:123456789012:channel/abcdABCDefgh\n   *\n   * @attribute\n   */\n  readonly channelArn: string;\n\n  /**\n   * Adds a stream key for this IVS Channel.\n   * @param id construct ID\n   */\n  addStreamKey(id: string): StreamKey;\n}\n\n/**\n * Reference to a new or existing IVS Channel\n */\nabstract class ChannelBase extends core.Resource implements IChannel {\n  public abstract readonly channelArn: string;\n\n  public addStreamKey(id: string): StreamKey {\n    return new StreamKey(this, id, {\n      channel: this,\n    });\n  }\n}\n\n/**\n * Container Format\n */\nexport enum ContainerFormat {\n  /**\n   * Use MPEG-TS.\n   */\n  TS = 'TS',\n\n  /**\n   * Use fMP4.\n   */\n  FRAGMENTED_MP4 = 'FRAGMENTED_MP4',\n}\n\n/**\n * Channel latency mode\n */\nexport enum LatencyMode {\n  /**\n   * Use LOW to minimize broadcaster-to-viewer latency for interactive broadcasts.\n   */\n  LOW = 'LOW',\n\n  /**\n   * Use NORMAL for broadcasts that do not require viewer interaction.\n   */\n  NORMAL = 'NORMAL',\n}\n\n/**\n * The channel type, which determines the allowable resolution and bitrate.\n * If you exceed the allowable resolution or bitrate, the stream probably will disconnect immediately.\n *\n * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ivs-channel.html\n */\nexport enum ChannelType {\n  /**\n   * Multiple qualities are generated from the original input, to automatically give viewers the best experience for their devices and network conditions.\n   * Transcoding allows higher playback quality across a range of download speeds. Resolution can be up to 1080p and bitrate can be up to 8.5 Mbps.\n   * Audio is transcoded only for renditions 360p and below; above that, audio is passed through.\n   */\n  STANDARD = 'STANDARD',\n\n  /**\n   * Delivers the original input to viewers. The viewer’s video-quality choice is limited to the original input.\n   */\n  BASIC = 'BASIC',\n\n  /**\n   * Multiple qualities are generated from the original input, to automatically give viewers the best experience for their devices and network conditions.\n   * Input resolution can be up to 1080p and bitrate can be up to 8.5 Mbps; output is capped at SD quality (480p).\n   * Audio for all renditions is transcoded, and an audio-only rendition is available.\n   */\n  ADVANCED_SD = 'ADVANCED_SD',\n\n  /**\n   * Multiple qualities are generated from the original input, to automatically give viewers the best experience for their devices and network conditions.\n   * Input resolution can be up to 1080p and bitrate can be up to 8.5 Mbps; output is capped at HD quality (720p).\n   * Audio for all renditions is transcoded, and an audio-only rendition is available.\n   */\n  ADVANCED_HD = 'ADVANCED_HD',\n}\n\n/**\n * An optional transcode preset for the channel. This is selectable only for ADVANCED_HD and ADVANCED_SD channel types.\n *\n * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-ivs-channel.html\n */\nexport enum Preset {\n  /**\n   * Use a lower bitrate than STANDARD for each quality level. Use it if you have low download bandwidth and/or simple video content (e.g., talking heads).\n   */\n  CONSTRAINED_BANDWIDTH_DELIVERY = 'CONSTRAINED_BANDWIDTH_DELIVERY',\n\n  /**\n   * Use a higher bitrate for each quality level. Use it if you have high download bandwidth and/or complex video content (e.g., flashes and quick scene changes).\n   */\n  HIGHER_BANDWIDTH_DELIVERY = 'HIGHER_BANDWIDTH_DELIVERY',\n\n}\n\n/**\n * Properties for creating a new Channel\n */\nexport interface ChannelProps {\n  /**\n   * Whether the channel is authorized.\n   *\n   * If you wish to make an authorized channel, you will need to ensure that\n   * a PlaybackKeyPair has been uploaded to your account as this is used to\n   * validate the signed JWT that is required for authorization\n   *\n   * @default false\n   */\n  readonly authorized?: boolean;\n\n  /**\n   * Indicates which content-packaging format is used (MPEG-TS or fMP4).\n   *\n   * If `multitrackInputConfiguration` is specified, only fMP4 can be used.\n   * Otherwise, `containerFormat` may be set to `ContainerFormat.TS` or `ContainerFormat.FRAGMENTED_MP4`.\n   *\n   * @default - `ContainerFormat.FRAGMENTED_MP4` is automatically set when the `multitrackInputConfiguration` is specified. If not specified, it remains undefined and uses the IVS default setting (TS).\n   */\n  readonly containerFormat?: ContainerFormat;\n\n  /**\n   * Whether the channel allows insecure RTMP ingest.\n   *\n   * @default false\n   */\n  readonly insecureIngest?: boolean;\n\n  /**\n   * Channel latency mode.\n   *\n   * @default LatencyMode.LOW\n   */\n  readonly latencyMode?: LatencyMode;\n\n  /**\n   * A name for the channel.\n   *\n   * @default Automatically generated name\n   */\n  readonly channelName?: string;\n\n  /**\n   * Object specifying multitrack input configuration.\n   * You must specify `multitrackInputConfiguration` if you want to use MultiTrack Video.\n   *\n   * `multitrackInputConfiguration` is only supported for `ChannelType.STANDARD`.\n   *\n   * @default undefined - IVS default setting is not use MultiTrack Video.\n   * @see https://docs.aws.amazon.com/ivs/latest/LowLatencyUserGuide/multitrack-video.html\n   */\n  readonly multitrackInputConfiguration?: MultitrackInputConfiguration;\n\n  /**\n   * The channel type, which determines the allowable resolution and bitrate.\n   * If you exceed the allowable resolution or bitrate, the stream will disconnect immediately\n   *\n   * @default ChannelType.STANDARD\n   */\n  readonly type?: ChannelType;\n\n  /**\n   * An optional transcode preset for the channel. Can be used for ADVANCED_HD and ADVANCED_SD channel types.\n   * When LOW or STANDARD is used, the preset will be overridden and set to none regardless of the value provided.\n   *\n   * @default - Preset.HIGHER_BANDWIDTH_DELIVERY if channelType is ADVANCED_SD or ADVANCED_HD, none otherwise\n   */\n  readonly preset?: Preset;\n\n  /**\n   * A recording configuration for the channel.\n   *\n   * @default - recording is disabled\n   */\n  readonly recordingConfiguration?: IRecordingConfiguration;\n}\n\n/**\n * Maximum resolution for multitrack input.\n */\nexport enum MaximumResolution {\n  /**\n   * Full HD (1080p)\n   */\n  FULL_HD = 'FULL_HD',\n\n  /**\n   * HD (720p)\n   */\n  HD = 'HD',\n\n  /**\n   * SD (480p)\n   */\n  SD = 'SD',\n}\n\n/**\n * Whether multitrack input is allowed or required.\n */\nexport enum Policy {\n  /**\n   * Multitrack input is allowed.\n   */\n  ALLOW = 'ALLOW',\n\n  /**\n   * Multitrack input is required.\n   */\n  REQUIRE = 'REQUIRE',\n}\n\n/**\n * A complex type that specifies multitrack input configuration.\n */\nexport interface MultitrackInputConfiguration {\n  /**\n   * Maximum resolution for multitrack input.\n   */\n  readonly maximumResolution: MaximumResolution;\n\n  /**\n   * Indicates whether multitrack input is allowed or required.\n   */\n  readonly policy: Policy;\n}\n\n/**\n  A new IVS channel\n */\n@propertyInjectable\nexport class Channel extends ChannelBase {\n  /** Uniquely identifies this class. */\n  public static readonly PROPERTY_INJECTION_ID: string = '@aws-cdk.aws-ivs-alpha.Channel';\n\n  /**\n   * Import an existing channel\n   */\n  public static fromChannelArn(scope: Construct, id: string, channelArn: string): IChannel {\n    // This will throw an error if the arn cannot be parsed\n    let arnComponents = core.Arn.split(channelArn, core.ArnFormat.SLASH_RESOURCE_NAME);\n\n    if (!core.Token.isUnresolved(arnComponents.service) && arnComponents.service !== 'ivs') {\n      throw new Error(`Invalid service, expected 'ivs', got '${arnComponents.service}'`);\n    }\n\n    if (!core.Token.isUnresolved(arnComponents.resource) && arnComponents.resource !== 'channel') {\n      throw new Error(`Invalid resource, expected 'channel', got '${arnComponents.resource}'`);\n    }\n\n    class Import extends ChannelBase {\n      public readonly channelArn = channelArn;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly channelArn: string;\n\n  /**\n   * Channel ingest endpoint, part of the definition of an ingest server, used when you set up streaming software.\n   * For example: a1b2c3d4e5f6.global-contribute.live-video.net\n   * @attribute\n   */\n  public readonly channelIngestEndpoint: string;\n\n  /**\n   * Channel playback URL. For example:\n   * https://a1b2c3d4e5f6.us-west-2.playback.live-video.net/api/video/v1/us-west-2.123456789012.channel.abcdEFGH.m3u8\n   * @attribute\n   */\n  public readonly channelPlaybackUrl: string;\n\n  constructor(scope: Construct, id: string, props: ChannelProps = {}) {\n    super(scope, id, {\n      physicalName: props.channelName ?? Lazy.string({\n        produce: () => Names.uniqueResourceName(this, { maxLength: 128, allowedSpecialCharacters: '-_' }),\n      }),\n    });\n    // Enhanced CDK Analytics Telemetry\n    addConstructMetadata(this, props);\n\n    if (this.physicalName && !core.Token.isUnresolved(this.physicalName) && !/^[a-zA-Z0-9-_]*$/.test(this.physicalName)) {\n      throw new Error(`channelName must contain only numbers, letters, hyphens and underscores, got: '${this.physicalName}'`);\n    }\n\n    let preset;\n\n    if (props.type && [ChannelType.STANDARD, ChannelType.BASIC].includes(props.type) && props.preset) {\n      preset = '';\n    } else {\n      preset = props.preset;\n    }\n\n    if (props.multitrackInputConfiguration !== undefined) {\n      if (props.type !== undefined && props.type !== ChannelType.STANDARD) {\n        throw new Error(`\\`multitrackInputConfiguration\\` is only supported for \\`ChannelType.STANDARD\\`, got: ${props.type}.`);\n      }\n\n      if (props.containerFormat !== undefined && props.containerFormat !== ContainerFormat.FRAGMENTED_MP4) {\n        throw new Error(`\\`containerFormat\\` must be set to \\`ContainerFormat.FRAGMENTED_MP4\\` when \\`multitrackInputConfiguration\\` is specified, got: ${props.containerFormat}.`);\n      }\n    }\n\n    const resource = new CfnChannel(this, 'Resource', {\n      authorized: props.authorized,\n      insecureIngest: props.insecureIngest,\n      latencyMode: props.latencyMode,\n      name: this.physicalName,\n      type: props.type,\n      preset,\n      recordingConfigurationArn: props.recordingConfiguration?.recordingConfigurationArn,\n      containerFormat: props.containerFormat ??\n        (props.multitrackInputConfiguration ? ContainerFormat.FRAGMENTED_MP4 : undefined),\n      multitrackInputConfiguration: props.multitrackInputConfiguration ?\n        {\n          enabled: true,\n          maximumResolution: props.multitrackInputConfiguration.maximumResolution,\n          policy: props.multitrackInputConfiguration.policy,\n        }\n        : undefined,\n    });\n\n    this.channelArn = resource.attrArn;\n    this.channelIngestEndpoint = resource.attrIngestEndpoint;\n    this.channelPlaybackUrl = resource.attrPlaybackUrl;\n  }\n}\n"]}