UNPKG

@aws-cdk/aws-ivs-alpha

Version:

The CDK Construct Library for AWS::IVS

277 lines 34.1 kB
"use strict"; 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"]}