@aws-cdk/aws-mediapackagev2-alpha 2.247.0-alpha.0
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/.jsii +18480 -0
- package/.jsii.tabl.json.gz +0 -0
- package/.warnings.jsii.js +561 -0
- package/LICENSE +201 -0
- package/NOTICE +2 -0
- package/README.md +663 -0
- package/awslint.json +25 -0
- package/eslint-suppressions.json +2 -0
- package/grants.json +15 -0
- package/lib/channel-policy.d.ts +48 -0
- package/lib/channel-policy.js +113 -0
- package/lib/channel.d.ts +420 -0
- package/lib/channel.js +426 -0
- package/lib/endpoint.d.ts +1968 -0
- package/lib/endpoint.js +2010 -0
- package/lib/group.d.ts +253 -0
- package/lib/group.js +281 -0
- package/lib/index.d.ts +6 -0
- package/lib/index.js +23 -0
- package/lib/mediapackagev2-grants.generated.d.ts +23 -0
- package/lib/mediapackagev2-grants.generated.js +53 -0
- package/lib/origin-endpoint-policy.d.ts +76 -0
- package/lib/origin-endpoint-policy.js +148 -0
- package/lib/shared-helpers.d.ts +1 -0
- package/lib/shared-helpers.js +25 -0
- package/package.json +119 -0
- package/rosetta/_generated.ts-fixture +6 -0
- package/rosetta/default.ts-fixture +27 -0
package/lib/endpoint.js
ADDED
|
@@ -0,0 +1,2010 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
|
|
3
|
+
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
|
|
4
|
+
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
|
|
5
|
+
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
|
|
6
|
+
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
|
|
7
|
+
var _, done = false;
|
|
8
|
+
for (var i = decorators.length - 1; i >= 0; i--) {
|
|
9
|
+
var context = {};
|
|
10
|
+
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
|
|
11
|
+
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
|
|
12
|
+
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
|
|
13
|
+
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
|
|
14
|
+
if (kind === "accessor") {
|
|
15
|
+
if (result === void 0) continue;
|
|
16
|
+
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
|
|
17
|
+
if (_ = accept(result.get)) descriptor.get = _;
|
|
18
|
+
if (_ = accept(result.set)) descriptor.set = _;
|
|
19
|
+
if (_ = accept(result.init)) initializers.unshift(_);
|
|
20
|
+
}
|
|
21
|
+
else if (_ = accept(result)) {
|
|
22
|
+
if (kind === "field") initializers.unshift(_);
|
|
23
|
+
else descriptor[key] = _;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
if (target) Object.defineProperty(target, contextIn.name, descriptor);
|
|
27
|
+
done = true;
|
|
28
|
+
};
|
|
29
|
+
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
|
|
30
|
+
var useValue = arguments.length > 2;
|
|
31
|
+
for (var i = 0; i < initializers.length; i++) {
|
|
32
|
+
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
|
|
33
|
+
}
|
|
34
|
+
return useValue ? value : void 0;
|
|
35
|
+
};
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
exports.OriginEndpoint = exports.Segment = exports.IsmEncryption = exports.TsEncryption = exports.CmafEncryption = exports.EncryptionConfiguration = exports.IsmDrmSystem = exports.TsDrmSystem = exports.CmafDrmSystem = exports.MssManifestLayout = exports.TtmlProfile = exports.DashManifestCompactness = exports.DrmSignalling = exports.DashPeriodTriggers = exports.DashUtcTimingMode = exports.SegmentTemplateFormat = exports.AdMarkerHls = exports.AdMarkerDash = exports.StartTag = exports.DrmSettingsKey = exports.ScteInSegments = exports.ScteMessageType = exports.EndpointErrorConfiguration = exports.PresetSpeke20Video = exports.PresetSpeke20Audio = exports.TsEncryptionMethod = exports.CmafEncryptionMethod = exports.ContainerType = exports.Manifest = exports.ManifestFilter = exports.BitrateExpression = exports.NumericExpression = exports.BitrateFilterKey = exports.TextFilterKey = exports.NumericFilterKey = exports.TrickplayType = exports.VideoDynamicRange = exports.VideoCodec = exports.AudioCodec = void 0;
|
|
38
|
+
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
|
39
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
40
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
41
|
+
const aws_cloudwatch_1 = require("aws-cdk-lib/aws-cloudwatch");
|
|
42
|
+
const aws_mediapackagev2_1 = require("aws-cdk-lib/aws-mediapackagev2");
|
|
43
|
+
const core_1 = require("aws-cdk-lib/core");
|
|
44
|
+
const helpers_internal_1 = require("aws-cdk-lib/core/lib/helpers-internal");
|
|
45
|
+
const metadata_resource_1 = require("aws-cdk-lib/core/lib/metadata-resource");
|
|
46
|
+
const prop_injectable_1 = require("aws-cdk-lib/core/lib/prop-injectable");
|
|
47
|
+
const origin_endpoint_policy_1 = require("./origin-endpoint-policy");
|
|
48
|
+
const shared_helpers_1 = require("./shared-helpers");
|
|
49
|
+
/**
|
|
50
|
+
* Accepted audio codec values for manifest filtering.
|
|
51
|
+
*
|
|
52
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
53
|
+
*/
|
|
54
|
+
var AudioCodec;
|
|
55
|
+
(function (AudioCodec) {
|
|
56
|
+
/** AAC-LC audio codec */
|
|
57
|
+
AudioCodec["AACL"] = "AACL";
|
|
58
|
+
/** HE-AAC audio codec */
|
|
59
|
+
AudioCodec["AACH"] = "AACH";
|
|
60
|
+
/** Dolby Digital audio codec (include the hyphen) */
|
|
61
|
+
AudioCodec["AC_3"] = "AC-3";
|
|
62
|
+
/** Dolby Digital Plus audio codec (include the hyphen) */
|
|
63
|
+
AudioCodec["EC_3"] = "EC-3";
|
|
64
|
+
})(AudioCodec || (exports.AudioCodec = AudioCodec = {}));
|
|
65
|
+
/**
|
|
66
|
+
* Accepted video codec values for manifest filtering.
|
|
67
|
+
*
|
|
68
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
69
|
+
*/
|
|
70
|
+
var VideoCodec;
|
|
71
|
+
(function (VideoCodec) {
|
|
72
|
+
/** H.264/AVC */
|
|
73
|
+
VideoCodec["H264"] = "H264";
|
|
74
|
+
/** H.265/HEVC */
|
|
75
|
+
VideoCodec["H265"] = "H265";
|
|
76
|
+
/** AV1 */
|
|
77
|
+
VideoCodec["AV1"] = "AV1";
|
|
78
|
+
})(VideoCodec || (exports.VideoCodec = VideoCodec = {}));
|
|
79
|
+
/**
|
|
80
|
+
* Accepted video dynamic range values for manifest filtering.
|
|
81
|
+
*
|
|
82
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
83
|
+
*/
|
|
84
|
+
var VideoDynamicRange;
|
|
85
|
+
(function (VideoDynamicRange) {
|
|
86
|
+
/** Dolby Vision */
|
|
87
|
+
VideoDynamicRange["DV"] = "dv";
|
|
88
|
+
/** HDR10 */
|
|
89
|
+
VideoDynamicRange["HDR10"] = "hdr10";
|
|
90
|
+
/** Hybrid Log-Gamma */
|
|
91
|
+
VideoDynamicRange["HLG"] = "hlg";
|
|
92
|
+
/** Standard Dynamic Range */
|
|
93
|
+
VideoDynamicRange["SDR"] = "sdr";
|
|
94
|
+
})(VideoDynamicRange || (exports.VideoDynamicRange = VideoDynamicRange = {}));
|
|
95
|
+
/**
|
|
96
|
+
* Accepted trickplay type values for manifest filtering.
|
|
97
|
+
*
|
|
98
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
99
|
+
*/
|
|
100
|
+
var TrickplayType;
|
|
101
|
+
(function (TrickplayType) {
|
|
102
|
+
/** I-frame only trick-play */
|
|
103
|
+
TrickplayType["IFRAME"] = "iframe";
|
|
104
|
+
/** Image-based trick-play */
|
|
105
|
+
TrickplayType["IMAGE"] = "image";
|
|
106
|
+
/** No trick-play */
|
|
107
|
+
TrickplayType["NONE"] = "none";
|
|
108
|
+
})(TrickplayType || (exports.TrickplayType = TrickplayType = {}));
|
|
109
|
+
/**
|
|
110
|
+
* Numeric manifest filter keys.
|
|
111
|
+
*
|
|
112
|
+
* Use with `ManifestFilter.numeric()`, `ManifestFilter.numericList()`, and `ManifestFilter.numericRange()`.
|
|
113
|
+
*
|
|
114
|
+
* Audio and video bitrate filters are not included here because they use the
|
|
115
|
+
* `Bitrate` class directly via dedicated methods on `ManifestFilter`.
|
|
116
|
+
*
|
|
117
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
118
|
+
*/
|
|
119
|
+
var NumericFilterKey;
|
|
120
|
+
(function (NumericFilterKey) {
|
|
121
|
+
/**
|
|
122
|
+
* The number of audio channels.
|
|
123
|
+
*
|
|
124
|
+
* Accepted values: range 1–32767, or individual integers.
|
|
125
|
+
*/
|
|
126
|
+
NumericFilterKey["AUDIO_CHANNELS"] = "audio_channels";
|
|
127
|
+
/**
|
|
128
|
+
* The audio sample rate in Hz.
|
|
129
|
+
*
|
|
130
|
+
* Accepted values: range 0–2147483647, or individual integers.
|
|
131
|
+
*/
|
|
132
|
+
NumericFilterKey["AUDIO_SAMPLE_RATE"] = "audio_sample_rate";
|
|
133
|
+
/**
|
|
134
|
+
* The height of the trick-play image in pixels (I-frame and image-based trick-play).
|
|
135
|
+
*
|
|
136
|
+
* If using with I-frame only trick-play, `TRICKPLAY_HEIGHT` and `VIDEO_HEIGHT`
|
|
137
|
+
* should have similar values. If they differ, I-frame only tracks might be
|
|
138
|
+
* removed from the manifest.
|
|
139
|
+
*
|
|
140
|
+
* Accepted values: range 1–2147483647, or individual integers.
|
|
141
|
+
*/
|
|
142
|
+
NumericFilterKey["TRICKPLAY_HEIGHT"] = "trickplay_height";
|
|
143
|
+
/**
|
|
144
|
+
* The video frame rate range in NTSC format.
|
|
145
|
+
*
|
|
146
|
+
* When filtering for a single value, MediaPackage uses an approximate equals
|
|
147
|
+
* comparison with an epsilon tolerance of 0.0005.
|
|
148
|
+
*
|
|
149
|
+
* Accepted values: range 1–999.999 (up to three decimal places), or individual values.
|
|
150
|
+
*/
|
|
151
|
+
NumericFilterKey["VIDEO_FRAMERATE"] = "video_framerate";
|
|
152
|
+
/**
|
|
153
|
+
* The height of the video in pixels.
|
|
154
|
+
*
|
|
155
|
+
* If using with I-frame only trick-play, `TRICKPLAY_HEIGHT` and `VIDEO_HEIGHT`
|
|
156
|
+
* should have similar values. If they differ, I-frame only tracks might be
|
|
157
|
+
* removed from the manifest.
|
|
158
|
+
*
|
|
159
|
+
* Accepted values: range 1–32767, or individual integers.
|
|
160
|
+
*/
|
|
161
|
+
NumericFilterKey["VIDEO_HEIGHT"] = "video_height";
|
|
162
|
+
})(NumericFilterKey || (exports.NumericFilterKey = NumericFilterKey = {}));
|
|
163
|
+
/**
|
|
164
|
+
* Text manifest filter keys for free-form string values.
|
|
165
|
+
*
|
|
166
|
+
* Use with `ManifestFilter.text()` and `ManifestFilter.textList()`.
|
|
167
|
+
*
|
|
168
|
+
* For keys with fixed accepted values, use the dedicated methods on `ManifestFilter` instead:
|
|
169
|
+
* - Audio codec: `ManifestFilter.audioCodec()` / `ManifestFilter.audioCodecList()`
|
|
170
|
+
* - Video codec: `ManifestFilter.videoCodec()` / `ManifestFilter.videoCodecList()`
|
|
171
|
+
* - Video dynamic range: `ManifestFilter.videoDynamicRange()` / `ManifestFilter.videoDynamicRangeList()`
|
|
172
|
+
* - Trickplay type: `ManifestFilter.trickplayType()` / `ManifestFilter.trickplayTypeList()`
|
|
173
|
+
*
|
|
174
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
175
|
+
*/
|
|
176
|
+
var TextFilterKey;
|
|
177
|
+
(function (TextFilterKey) {
|
|
178
|
+
/**
|
|
179
|
+
* Audio languages or functional codes derived from encoder passthrough.
|
|
180
|
+
*
|
|
181
|
+
* Accepted values: arbitrary strings such as ISO-639-1 language codes (not case-sensitive).
|
|
182
|
+
*/
|
|
183
|
+
TextFilterKey["AUDIO_LANGUAGE"] = "audio_language";
|
|
184
|
+
/**
|
|
185
|
+
* The subtitle language or functional codes derived from encoder passthrough.
|
|
186
|
+
*
|
|
187
|
+
* Accepted values: arbitrary strings such as ISO-639-1 language codes (not case-sensitive).
|
|
188
|
+
*/
|
|
189
|
+
TextFilterKey["SUBTITLE_LANGUAGE"] = "subtitle_language";
|
|
190
|
+
})(TextFilterKey || (exports.TextFilterKey = TextFilterKey = {}));
|
|
191
|
+
/**
|
|
192
|
+
* Bitrate manifest filter keys.
|
|
193
|
+
*
|
|
194
|
+
* Use with `ManifestFilter.bitrate()` and `ManifestFilter.bitrateRange()`.
|
|
195
|
+
*
|
|
196
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html
|
|
197
|
+
*/
|
|
198
|
+
var BitrateFilterKey;
|
|
199
|
+
(function (BitrateFilterKey) {
|
|
200
|
+
/**
|
|
201
|
+
* The audio bitrate in bits per second.
|
|
202
|
+
*
|
|
203
|
+
* Accepted values: range 0–2147483647, or individual integers.
|
|
204
|
+
*/
|
|
205
|
+
BitrateFilterKey["AUDIO_BITRATE"] = "audio_bitrate";
|
|
206
|
+
/**
|
|
207
|
+
* The video bitrate in bits per second.
|
|
208
|
+
*
|
|
209
|
+
* We recommend using only this filter parameter to set the video bitrate.
|
|
210
|
+
* Do not also set the minimum and maximum video bitrate via the MediaPackage
|
|
211
|
+
* console or AWS CLI, as your output might be skewed.
|
|
212
|
+
*
|
|
213
|
+
* This parameter cannot be used with trick-play streams.
|
|
214
|
+
*
|
|
215
|
+
* Accepted values: range 0–2147483647, or individual integers.
|
|
216
|
+
*/
|
|
217
|
+
BitrateFilterKey["VIDEO_BITRATE"] = "video_bitrate";
|
|
218
|
+
})(BitrateFilterKey || (exports.BitrateFilterKey = BitrateFilterKey = {}));
|
|
219
|
+
/**
|
|
220
|
+
* Represents a numeric filter expression segment — either a single value or a range.
|
|
221
|
+
*
|
|
222
|
+
* Use with `ManifestFilter.numericCombo()` to build filters that combine
|
|
223
|
+
* ranges and individual values (e.g. `video_height:240-360,720-1080,1440`).
|
|
224
|
+
*/
|
|
225
|
+
class NumericExpression {
|
|
226
|
+
_expression;
|
|
227
|
+
_values;
|
|
228
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.NumericExpression", version: "2.247.0-alpha.0" };
|
|
229
|
+
/**
|
|
230
|
+
* A single numeric value.
|
|
231
|
+
*/
|
|
232
|
+
static value(v) {
|
|
233
|
+
return new NumericExpression(`${v}`, [v]);
|
|
234
|
+
}
|
|
235
|
+
/**
|
|
236
|
+
* An inclusive numeric range.
|
|
237
|
+
*/
|
|
238
|
+
static range(start, end) {
|
|
239
|
+
return new NumericExpression(`${start}-${end}`, [start, end]);
|
|
240
|
+
}
|
|
241
|
+
constructor(
|
|
242
|
+
/** @internal */
|
|
243
|
+
_expression,
|
|
244
|
+
/** @internal */
|
|
245
|
+
_values) {
|
|
246
|
+
this._expression = _expression;
|
|
247
|
+
this._values = _values;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
exports.NumericExpression = NumericExpression;
|
|
251
|
+
/**
|
|
252
|
+
* Represents a bitrate filter expression segment — either a single value or a range.
|
|
253
|
+
*
|
|
254
|
+
* Use with `ManifestFilter.bitrateCombo()` to build filters that combine
|
|
255
|
+
* ranges and individual bitrate values.
|
|
256
|
+
*/
|
|
257
|
+
class BitrateExpression {
|
|
258
|
+
_expression;
|
|
259
|
+
_values;
|
|
260
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.BitrateExpression", version: "2.247.0-alpha.0" };
|
|
261
|
+
/**
|
|
262
|
+
* A single bitrate value.
|
|
263
|
+
*/
|
|
264
|
+
static value(v) {
|
|
265
|
+
return new BitrateExpression(`${v.toBps()}`, [v.toBps()]);
|
|
266
|
+
}
|
|
267
|
+
/**
|
|
268
|
+
* An inclusive bitrate range.
|
|
269
|
+
*/
|
|
270
|
+
static range(start, end) {
|
|
271
|
+
return new BitrateExpression(`${start.toBps()}-${end.toBps()}`, [start.toBps(), end.toBps()]);
|
|
272
|
+
}
|
|
273
|
+
constructor(
|
|
274
|
+
/** @internal */
|
|
275
|
+
_expression,
|
|
276
|
+
/** @internal */
|
|
277
|
+
_values) {
|
|
278
|
+
this._expression = _expression;
|
|
279
|
+
this._values = _values;
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
exports.BitrateExpression = BitrateExpression;
|
|
283
|
+
/**
|
|
284
|
+
* Enables you to create filters for your Origin Endpoint.
|
|
285
|
+
*
|
|
286
|
+
* @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filtering.html
|
|
287
|
+
*/
|
|
288
|
+
class ManifestFilter {
|
|
289
|
+
filterString;
|
|
290
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.ManifestFilter", version: "2.247.0-alpha.0" };
|
|
291
|
+
/**
|
|
292
|
+
* Filter by a single bitrate value.
|
|
293
|
+
*/
|
|
294
|
+
static bitrate(key, value) {
|
|
295
|
+
try {
|
|
296
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_BitrateFilterKey(key);
|
|
297
|
+
}
|
|
298
|
+
catch (error) {
|
|
299
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
300
|
+
Error.captureStackTrace(error, this.bitrate);
|
|
301
|
+
}
|
|
302
|
+
throw error;
|
|
303
|
+
}
|
|
304
|
+
const bps = value.toBps();
|
|
305
|
+
validateBitrateFilterValue(bps, key);
|
|
306
|
+
return new ManifestFilter(`${key}:${bps}`);
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Filter by a bitrate range (inclusive).
|
|
310
|
+
*/
|
|
311
|
+
static bitrateRange(key, start, end) {
|
|
312
|
+
try {
|
|
313
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_BitrateFilterKey(key);
|
|
314
|
+
}
|
|
315
|
+
catch (error) {
|
|
316
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
317
|
+
Error.captureStackTrace(error, this.bitrateRange);
|
|
318
|
+
}
|
|
319
|
+
throw error;
|
|
320
|
+
}
|
|
321
|
+
const startBps = start.toBps();
|
|
322
|
+
const endBps = end.toBps();
|
|
323
|
+
validateBitrateFilterValue(startBps, key);
|
|
324
|
+
validateBitrateFilterValue(endBps, key);
|
|
325
|
+
return new ManifestFilter(`${key}:${startBps}-${endBps}`);
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Specify a single numeric filter value.
|
|
329
|
+
*/
|
|
330
|
+
static numeric(key, value) {
|
|
331
|
+
try {
|
|
332
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_NumericFilterKey(key);
|
|
333
|
+
}
|
|
334
|
+
catch (error) {
|
|
335
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
336
|
+
Error.captureStackTrace(error, this.numeric);
|
|
337
|
+
}
|
|
338
|
+
throw error;
|
|
339
|
+
}
|
|
340
|
+
validateNumericFilterValue(value, key);
|
|
341
|
+
return new ManifestFilter(`${key}:${value}`);
|
|
342
|
+
}
|
|
343
|
+
/**
|
|
344
|
+
* Specify multiple numeric filter values.
|
|
345
|
+
*/
|
|
346
|
+
static numericList(key, values) {
|
|
347
|
+
try {
|
|
348
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_NumericFilterKey(key);
|
|
349
|
+
}
|
|
350
|
+
catch (error) {
|
|
351
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
352
|
+
Error.captureStackTrace(error, this.numericList);
|
|
353
|
+
}
|
|
354
|
+
throw error;
|
|
355
|
+
}
|
|
356
|
+
values.forEach(v => validateNumericFilterValue(v, key));
|
|
357
|
+
return new ManifestFilter(`${key}:${values.join(',')}`);
|
|
358
|
+
}
|
|
359
|
+
/**
|
|
360
|
+
* Specify a numeric filter range (inclusive).
|
|
361
|
+
*/
|
|
362
|
+
static numericRange(key, start, end) {
|
|
363
|
+
try {
|
|
364
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_NumericFilterKey(key);
|
|
365
|
+
}
|
|
366
|
+
catch (error) {
|
|
367
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
368
|
+
Error.captureStackTrace(error, this.numericRange);
|
|
369
|
+
}
|
|
370
|
+
throw error;
|
|
371
|
+
}
|
|
372
|
+
validateNumericFilterValue(start, key);
|
|
373
|
+
validateNumericFilterValue(end, key);
|
|
374
|
+
return new ManifestFilter(`${key}:${start}-${end}`);
|
|
375
|
+
}
|
|
376
|
+
/**
|
|
377
|
+
* Specify a free-form text filter value (for language keys).
|
|
378
|
+
*/
|
|
379
|
+
static text(key, value) {
|
|
380
|
+
try {
|
|
381
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_TextFilterKey(key);
|
|
382
|
+
}
|
|
383
|
+
catch (error) {
|
|
384
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
385
|
+
Error.captureStackTrace(error, this.text);
|
|
386
|
+
}
|
|
387
|
+
throw error;
|
|
388
|
+
}
|
|
389
|
+
return new ManifestFilter(`${key}:${value}`);
|
|
390
|
+
}
|
|
391
|
+
/**
|
|
392
|
+
* Specify multiple free-form text filter values (for language keys).
|
|
393
|
+
*/
|
|
394
|
+
static textList(key, values) {
|
|
395
|
+
try {
|
|
396
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_TextFilterKey(key);
|
|
397
|
+
}
|
|
398
|
+
catch (error) {
|
|
399
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
400
|
+
Error.captureStackTrace(error, this.textList);
|
|
401
|
+
}
|
|
402
|
+
throw error;
|
|
403
|
+
}
|
|
404
|
+
return new ManifestFilter(`${key}:${values.join(',')}`);
|
|
405
|
+
}
|
|
406
|
+
/**
|
|
407
|
+
* Filter by a single audio codec.
|
|
408
|
+
*/
|
|
409
|
+
static audioCodec(value) {
|
|
410
|
+
try {
|
|
411
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_AudioCodec(value);
|
|
412
|
+
}
|
|
413
|
+
catch (error) {
|
|
414
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
415
|
+
Error.captureStackTrace(error, this.audioCodec);
|
|
416
|
+
}
|
|
417
|
+
throw error;
|
|
418
|
+
}
|
|
419
|
+
return new ManifestFilter(`audio_codec:${value}`);
|
|
420
|
+
}
|
|
421
|
+
/**
|
|
422
|
+
* Filter by multiple audio codecs.
|
|
423
|
+
*/
|
|
424
|
+
static audioCodecList(values) {
|
|
425
|
+
return new ManifestFilter(`audio_codec:${values.join(',')}`);
|
|
426
|
+
}
|
|
427
|
+
/**
|
|
428
|
+
* Filter by a single video codec.
|
|
429
|
+
*/
|
|
430
|
+
static videoCodec(value) {
|
|
431
|
+
try {
|
|
432
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_VideoCodec(value);
|
|
433
|
+
}
|
|
434
|
+
catch (error) {
|
|
435
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
436
|
+
Error.captureStackTrace(error, this.videoCodec);
|
|
437
|
+
}
|
|
438
|
+
throw error;
|
|
439
|
+
}
|
|
440
|
+
return new ManifestFilter(`video_codec:${value}`);
|
|
441
|
+
}
|
|
442
|
+
/**
|
|
443
|
+
* Filter by multiple video codecs.
|
|
444
|
+
*/
|
|
445
|
+
static videoCodecList(values) {
|
|
446
|
+
return new ManifestFilter(`video_codec:${values.join(',')}`);
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* Filter by a single video dynamic range.
|
|
450
|
+
*/
|
|
451
|
+
static videoDynamicRange(value) {
|
|
452
|
+
try {
|
|
453
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_VideoDynamicRange(value);
|
|
454
|
+
}
|
|
455
|
+
catch (error) {
|
|
456
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
457
|
+
Error.captureStackTrace(error, this.videoDynamicRange);
|
|
458
|
+
}
|
|
459
|
+
throw error;
|
|
460
|
+
}
|
|
461
|
+
return new ManifestFilter(`video_dynamic_range:${value}`);
|
|
462
|
+
}
|
|
463
|
+
/**
|
|
464
|
+
* Filter by multiple video dynamic ranges.
|
|
465
|
+
*/
|
|
466
|
+
static videoDynamicRangeList(values) {
|
|
467
|
+
return new ManifestFilter(`video_dynamic_range:${values.join(',')}`);
|
|
468
|
+
}
|
|
469
|
+
/**
|
|
470
|
+
* Filter by a single trickplay type.
|
|
471
|
+
*/
|
|
472
|
+
static trickplayType(value) {
|
|
473
|
+
try {
|
|
474
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_TrickplayType(value);
|
|
475
|
+
}
|
|
476
|
+
catch (error) {
|
|
477
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
478
|
+
Error.captureStackTrace(error, this.trickplayType);
|
|
479
|
+
}
|
|
480
|
+
throw error;
|
|
481
|
+
}
|
|
482
|
+
return new ManifestFilter(`trickplay_type:${value}`);
|
|
483
|
+
}
|
|
484
|
+
/**
|
|
485
|
+
* Filter by multiple trickplay types.
|
|
486
|
+
*/
|
|
487
|
+
static trickplayTypeList(values) {
|
|
488
|
+
return new ManifestFilter(`trickplay_type:${values.join(',')}`);
|
|
489
|
+
}
|
|
490
|
+
/**
|
|
491
|
+
* Filter by a combination of numeric ranges and individual values.
|
|
492
|
+
*
|
|
493
|
+
* Use this for advanced patterns like `video_height:240-360,720-1080,1440`.
|
|
494
|
+
*
|
|
495
|
+
* @example
|
|
496
|
+
* ManifestFilter.numericCombo(NumericFilterKey.VIDEO_HEIGHT, [
|
|
497
|
+
* NumericExpression.range(240, 360),
|
|
498
|
+
* NumericExpression.range(720, 1080),
|
|
499
|
+
* NumericExpression.value(1440),
|
|
500
|
+
* ])
|
|
501
|
+
*/
|
|
502
|
+
static numericCombo(key, expressions) {
|
|
503
|
+
try {
|
|
504
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_NumericFilterKey(key);
|
|
505
|
+
}
|
|
506
|
+
catch (error) {
|
|
507
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
508
|
+
Error.captureStackTrace(error, this.numericCombo);
|
|
509
|
+
}
|
|
510
|
+
throw error;
|
|
511
|
+
}
|
|
512
|
+
expressions.forEach(expr => expr._values.forEach(v => validateNumericFilterValue(v, key)));
|
|
513
|
+
return new ManifestFilter(`${key}:${expressions.map(e => e._expression).join(',')}`);
|
|
514
|
+
}
|
|
515
|
+
/**
|
|
516
|
+
* Filter by a combination of bitrate ranges and individual values.
|
|
517
|
+
*
|
|
518
|
+
* @example
|
|
519
|
+
* ManifestFilter.bitrateCombo(BitrateFilterKey.VIDEO_BITRATE, [
|
|
520
|
+
* BitrateExpression.range(Bitrate.mbps(1), Bitrate.mbps(3)),
|
|
521
|
+
* BitrateExpression.value(Bitrate.mbps(5)),
|
|
522
|
+
* ])
|
|
523
|
+
*/
|
|
524
|
+
static bitrateCombo(key, expressions) {
|
|
525
|
+
try {
|
|
526
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_BitrateFilterKey(key);
|
|
527
|
+
}
|
|
528
|
+
catch (error) {
|
|
529
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
530
|
+
Error.captureStackTrace(error, this.bitrateCombo);
|
|
531
|
+
}
|
|
532
|
+
throw error;
|
|
533
|
+
}
|
|
534
|
+
expressions.forEach(expr => expr._values.forEach(v => validateBitrateFilterValue(v, key)));
|
|
535
|
+
return new ManifestFilter(`${key}:${expressions.map(e => e._expression).join(',')}`);
|
|
536
|
+
}
|
|
537
|
+
/**
|
|
538
|
+
* Specify a custom manifest filter string.
|
|
539
|
+
*/
|
|
540
|
+
static custom(custom) {
|
|
541
|
+
return new ManifestFilter(custom);
|
|
542
|
+
}
|
|
543
|
+
/**
|
|
544
|
+
* @param filterString Normalised manifest filter string
|
|
545
|
+
*/
|
|
546
|
+
constructor(filterString) {
|
|
547
|
+
this.filterString = filterString;
|
|
548
|
+
}
|
|
549
|
+
}
|
|
550
|
+
exports.ManifestFilter = ManifestFilter;
|
|
551
|
+
/**
|
|
552
|
+
* Manifest to add to Origin Endpoint
|
|
553
|
+
*/
|
|
554
|
+
class Manifest {
|
|
555
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.Manifest", version: "2.247.0-alpha.0" };
|
|
556
|
+
/**
|
|
557
|
+
* Specify a manifest configuration for Low Latency HLS.
|
|
558
|
+
*
|
|
559
|
+
* **Note:** Low Latency HLS manifests require TS or CMAF container type.
|
|
560
|
+
* Use with `Segment.ts()` or `Segment.cmaf()`.
|
|
561
|
+
*/
|
|
562
|
+
static lowLatencyHLS(manifest) {
|
|
563
|
+
try {
|
|
564
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_LowLatencyHlsManifestConfiguration(manifest);
|
|
565
|
+
}
|
|
566
|
+
catch (error) {
|
|
567
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
568
|
+
Error.captureStackTrace(error, this.lowLatencyHLS);
|
|
569
|
+
}
|
|
570
|
+
throw error;
|
|
571
|
+
}
|
|
572
|
+
return new LowLatencyHlsManifest(manifest);
|
|
573
|
+
}
|
|
574
|
+
/**
|
|
575
|
+
* Specify a manifest configuration for HLS.
|
|
576
|
+
*
|
|
577
|
+
* **Note:** HLS manifests require TS or CMAF container type.
|
|
578
|
+
* Use with `Segment.ts()` or `Segment.cmaf()`.
|
|
579
|
+
*/
|
|
580
|
+
static hls(manifest) {
|
|
581
|
+
try {
|
|
582
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_HlsManifestConfiguration(manifest);
|
|
583
|
+
}
|
|
584
|
+
catch (error) {
|
|
585
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
586
|
+
Error.captureStackTrace(error, this.hls);
|
|
587
|
+
}
|
|
588
|
+
throw error;
|
|
589
|
+
}
|
|
590
|
+
return new HlsManifest(manifest);
|
|
591
|
+
}
|
|
592
|
+
/**
|
|
593
|
+
* Specify a manifest configuration for DASH.
|
|
594
|
+
*
|
|
595
|
+
* **Note:** DASH manifests require CMAF container type.
|
|
596
|
+
* Use with `Segment.cmaf()`.
|
|
597
|
+
*/
|
|
598
|
+
static dash(manifest) {
|
|
599
|
+
try {
|
|
600
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_DashManifestConfiguration(manifest);
|
|
601
|
+
}
|
|
602
|
+
catch (error) {
|
|
603
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
604
|
+
Error.captureStackTrace(error, this.dash);
|
|
605
|
+
}
|
|
606
|
+
throw error;
|
|
607
|
+
}
|
|
608
|
+
return new DashManifest(manifest);
|
|
609
|
+
}
|
|
610
|
+
/**
|
|
611
|
+
* Specify a manifest configuration for MSS.
|
|
612
|
+
*
|
|
613
|
+
* **Note:** MSS manifests require ISM container type.
|
|
614
|
+
* Use with `Segment.ism()`.
|
|
615
|
+
*/
|
|
616
|
+
static mss(manifest) {
|
|
617
|
+
try {
|
|
618
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_MssManifestConfiguration(manifest);
|
|
619
|
+
}
|
|
620
|
+
catch (error) {
|
|
621
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
622
|
+
Error.captureStackTrace(error, this.mss);
|
|
623
|
+
}
|
|
624
|
+
throw error;
|
|
625
|
+
}
|
|
626
|
+
return new MssManifest(manifest);
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
exports.Manifest = Manifest;
|
|
630
|
+
/**
|
|
631
|
+
* Validate a numeric filter value is an integer within the accepted range for its key.
|
|
632
|
+
* VIDEO_FRAMERATE is excluded — it uses `validateFramerateValue` instead.
|
|
633
|
+
* @internal
|
|
634
|
+
*/
|
|
635
|
+
function validateIntegerFilterValue(value, key, min, max) {
|
|
636
|
+
if (!Number.isInteger(value)) {
|
|
637
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `NumericFilterMustBeInteger`, `Numeric filter value for '${key}' must be an integer, got ${value}`);
|
|
638
|
+
}
|
|
639
|
+
if (value < min || value > max) {
|
|
640
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `NumericFilterOutOfRange`, `Numeric filter value for '${key}' must be between ${min} and ${max}, got ${value}`);
|
|
641
|
+
}
|
|
642
|
+
}
|
|
643
|
+
/**
|
|
644
|
+
* Validate a video framerate filter value (1–999.999, up to 3 decimal places).
|
|
645
|
+
* @internal
|
|
646
|
+
*/
|
|
647
|
+
function validateFramerateValue(value) {
|
|
648
|
+
if (value < 1 || value > 999.999) {
|
|
649
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `NumericFilterOutOfRange`, `Numeric filter value for 'video_framerate' must be between 1 and 999.999, got ${value}`);
|
|
650
|
+
}
|
|
651
|
+
const decimalPart = value.toString().split('.')[1];
|
|
652
|
+
if (decimalPart && decimalPart.length > 3) {
|
|
653
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `NumericFilterMaxDecimalPlaces`, `Numeric filter value for 'video_framerate' allows up to 3 decimal places, got ${value}`);
|
|
654
|
+
}
|
|
655
|
+
}
|
|
656
|
+
/**
|
|
657
|
+
* Route numeric validation to the correct helper based on key.
|
|
658
|
+
* @internal
|
|
659
|
+
*/
|
|
660
|
+
function validateNumericFilterValue(value, key) {
|
|
661
|
+
switch (key) {
|
|
662
|
+
case NumericFilterKey.AUDIO_CHANNELS:
|
|
663
|
+
return validateIntegerFilterValue(value, key, 1, 32_767);
|
|
664
|
+
case NumericFilterKey.AUDIO_SAMPLE_RATE:
|
|
665
|
+
return validateIntegerFilterValue(value, key, 0, 2_147_483_647);
|
|
666
|
+
case NumericFilterKey.TRICKPLAY_HEIGHT:
|
|
667
|
+
return validateIntegerFilterValue(value, key, 1, 2_147_483_647);
|
|
668
|
+
case NumericFilterKey.VIDEO_FRAMERATE:
|
|
669
|
+
return validateFramerateValue(value);
|
|
670
|
+
case NumericFilterKey.VIDEO_HEIGHT:
|
|
671
|
+
return validateIntegerFilterValue(value, key, 1, 32_767);
|
|
672
|
+
}
|
|
673
|
+
}
|
|
674
|
+
/**
|
|
675
|
+
* Validate a bitrate filter value is an integer within the accepted range.
|
|
676
|
+
* @internal
|
|
677
|
+
*/
|
|
678
|
+
function validateBitrateFilterValue(bps, key) {
|
|
679
|
+
if (!Number.isInteger(bps)) {
|
|
680
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `BitrateFilterMustBeInteger`, `Bitrate filter value for '${key}' must resolve to a whole number of bits per second, got ${bps}`);
|
|
681
|
+
}
|
|
682
|
+
if (bps < 0 || bps > 2_147_483_647) {
|
|
683
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `BitrateFilterOutOfRange`, `Bitrate filter value for '${key}' must be between 0 and 2147483647, got ${bps}`);
|
|
684
|
+
}
|
|
685
|
+
}
|
|
686
|
+
/**
|
|
687
|
+
* Validates common manifest configuration properties
|
|
688
|
+
*/
|
|
689
|
+
function validateManifestConfiguration(config) {
|
|
690
|
+
if (config.manifestWindow && config.manifestWindow.toSeconds() < 30) {
|
|
691
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `ManifestWindowMinimum`, 'Manifest Window has a minimum value of 30 seconds');
|
|
692
|
+
}
|
|
693
|
+
}
|
|
694
|
+
/**
|
|
695
|
+
* Validate and modify filter configuration
|
|
696
|
+
* @internal
|
|
697
|
+
*/
|
|
698
|
+
function validateFilterConfiguration(filterConfig) {
|
|
699
|
+
if (!filterConfig)
|
|
700
|
+
return undefined;
|
|
701
|
+
if (filterConfig.clipStartTime && (filterConfig.start || filterConfig.end)) {
|
|
702
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `ClipStartTimeConflict`, 'You cannot specify both ClipStartTime with Start or End in a FilterConfiguration.');
|
|
703
|
+
}
|
|
704
|
+
if (filterConfig.timeDelay && (filterConfig.timeDelay.toSeconds() < 0 || filterConfig.timeDelay.toSeconds() > 1209600)) {
|
|
705
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `TimeDelayRange`, 'Time Delay setting should be defined between 0-1209600 seconds.');
|
|
706
|
+
}
|
|
707
|
+
if (filterConfig.start && filterConfig.end && (filterConfig.end <= filterConfig.start)) {
|
|
708
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `EndBeforeStart`, 'The End parameter needs to be after the Start parameter in a FilterConfiguration.');
|
|
709
|
+
}
|
|
710
|
+
const manifestFilter = filterConfig.manifestFilter ? filterConfig.manifestFilter.map(filter => filter.filterString).join(';') : undefined;
|
|
711
|
+
if (manifestFilter != undefined && (manifestFilter.length < 1 || manifestFilter.length > 1024)) {
|
|
712
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `ManifestFilterLength`, 'Manifest filter needs to be between 1-1024 characters in length.');
|
|
713
|
+
}
|
|
714
|
+
if (filterConfig.manifestFilter && filterConfig.manifestFilter.length > 1) {
|
|
715
|
+
const keys = filterConfig.manifestFilter.map(f => f.filterString.split(':')[0]);
|
|
716
|
+
keys.forEach((key, i) => {
|
|
717
|
+
if (keys.indexOf(key) !== i) {
|
|
718
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `DuplicateManifestFilterKey`, `Duplicate manifest filter key '${key}'. Use a single filter with comma-separated values instead (e.g. ManifestFilter.numericList() or ManifestFilter.custom()).`);
|
|
719
|
+
}
|
|
720
|
+
});
|
|
721
|
+
}
|
|
722
|
+
return {
|
|
723
|
+
manifestFilter,
|
|
724
|
+
drmSettings: filterConfig.drmSettings ? filterConfig.drmSettings.filter((v, i, a) => a.indexOf(v) === i).join(';') : undefined,
|
|
725
|
+
clipStartTime: filterConfig.clipStartTime ? (0, shared_helpers_1.convertDateToString)(filterConfig.clipStartTime) : undefined,
|
|
726
|
+
start: filterConfig.start ? (0, shared_helpers_1.convertDateToString)(filterConfig.start) : undefined,
|
|
727
|
+
end: filterConfig.end ? (0, shared_helpers_1.convertDateToString)(filterConfig.end) : undefined,
|
|
728
|
+
timeDelaySeconds: filterConfig.timeDelay?.toSeconds(),
|
|
729
|
+
};
|
|
730
|
+
}
|
|
731
|
+
/**
|
|
732
|
+
* Validate startTag configuration
|
|
733
|
+
* @internal
|
|
734
|
+
*/
|
|
735
|
+
function validateStartTag(startTag, manifestWindow, segmentDuration) {
|
|
736
|
+
const timeOffset = startTag.timeOffset;
|
|
737
|
+
// Get segment duration (default is 6 seconds if not specified)
|
|
738
|
+
const segmentDurationSec = segmentDuration?.toSeconds() ?? 6;
|
|
739
|
+
// Get manifest duration (default is 60 seconds if not specified)
|
|
740
|
+
const manifestDurationSec = manifestWindow?.toSeconds() ?? 60;
|
|
741
|
+
// Validate positive offset (from start)
|
|
742
|
+
if (timeOffset > 0) {
|
|
743
|
+
const maxPositiveOffset = manifestDurationSec - (3 * segmentDurationSec);
|
|
744
|
+
if (timeOffset >= maxPositiveOffset) {
|
|
745
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `StartTagPositiveOffsetExceeded`, `StartTag timeOffset (${timeOffset}s) must be less than manifest duration (${manifestDurationSec}s) minus 3 times segment duration (${segmentDurationSec}s). Maximum allowed: ${maxPositiveOffset}s`);
|
|
746
|
+
}
|
|
747
|
+
}
|
|
748
|
+
// Validate negative offset (from live edge)
|
|
749
|
+
if (timeOffset < 0) {
|
|
750
|
+
const absOffset = Math.abs(timeOffset);
|
|
751
|
+
const minNegativeOffset = 3 * segmentDurationSec;
|
|
752
|
+
if (absOffset <= minNegativeOffset) {
|
|
753
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `StartTagNegativeOffsetTooSmall`, `StartTag timeOffset (${timeOffset}s) absolute value must be greater than 3 times segment duration (${segmentDurationSec}s). Minimum allowed: -${minNegativeOffset + 0.01}s`);
|
|
754
|
+
}
|
|
755
|
+
if (absOffset >= manifestDurationSec) {
|
|
756
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `StartTagNegativeOffsetExceedsManifest`, `StartTag timeOffset (${timeOffset}s) absolute value must be less than manifest duration (${manifestDurationSec}s)`);
|
|
757
|
+
}
|
|
758
|
+
}
|
|
759
|
+
}
|
|
760
|
+
/**
|
|
761
|
+
* Build HLS manifest configuration
|
|
762
|
+
* @internal
|
|
763
|
+
*/
|
|
764
|
+
function buildHlsManifestConfiguration(config, segmentDuration) {
|
|
765
|
+
if (config.startTag) {
|
|
766
|
+
validateStartTag(config.startTag, config.manifestWindow, segmentDuration);
|
|
767
|
+
}
|
|
768
|
+
return {
|
|
769
|
+
manifestName: config.manifestName,
|
|
770
|
+
childManifestName: config.childManifestName,
|
|
771
|
+
manifestWindowSeconds: config.manifestWindow?.toSeconds(),
|
|
772
|
+
programDateTimeIntervalSeconds: config.programDateTimeInterval?.toSeconds(),
|
|
773
|
+
scteHls: config.scteAdMarkerHls ? { adMarkerHls: config.scteAdMarkerHls } : undefined,
|
|
774
|
+
startTag: config.startTag,
|
|
775
|
+
urlEncodeChildManifest: config.urlEncodeChildManifest,
|
|
776
|
+
filterConfiguration: validateFilterConfiguration(config.filterConfiguration),
|
|
777
|
+
};
|
|
778
|
+
}
|
|
779
|
+
/**
|
|
780
|
+
* Build DASH manifest configuration
|
|
781
|
+
* @internal
|
|
782
|
+
*/
|
|
783
|
+
function buildDashManifestConfiguration(config, segment) {
|
|
784
|
+
if (config.minBufferTime && (config.minBufferTime.toSeconds() < 1 || config.minBufferTime.toSeconds() > 3600)) {
|
|
785
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `MinBufferTimeRange`, 'Min buffer time has a range from 1 sec. to 3600 sec.');
|
|
786
|
+
}
|
|
787
|
+
if (config.minUpdatePeriod && (config.minUpdatePeriod.toSeconds() < 1 || config.minUpdatePeriod.toSeconds() > 3600)) {
|
|
788
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `MinUpdatePeriodRange`, 'Min update period option has a range from 1 sec. to 3600 sec.');
|
|
789
|
+
}
|
|
790
|
+
if (config.scteDashAdMarker && (!segment?.scteFilter || segment.scteFilter?.length === 0)) {
|
|
791
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `ScteFilterRequired`, 'SCTE Filter must be configured with DashAdMarker Configuration');
|
|
792
|
+
}
|
|
793
|
+
return {
|
|
794
|
+
manifestName: config.manifestName,
|
|
795
|
+
baseUrls: config.baseUrls,
|
|
796
|
+
compactness: config.compactness,
|
|
797
|
+
drmSignaling: config.drmSignalling,
|
|
798
|
+
dvbSettings: config.dvbSettings,
|
|
799
|
+
profiles: config.profiles,
|
|
800
|
+
programInformation: config.programInformation,
|
|
801
|
+
subtitleConfiguration: config.subtitleConfiguration,
|
|
802
|
+
manifestWindowSeconds: config.manifestWindow?.toSeconds(),
|
|
803
|
+
minBufferTimeSeconds: config.minBufferTime?.toSeconds(),
|
|
804
|
+
minUpdatePeriodSeconds: config.minUpdatePeriod?.toSeconds(),
|
|
805
|
+
suggestedPresentationDelaySeconds: config.suggestedPresentationDelay?.toSeconds(),
|
|
806
|
+
segmentTemplateFormat: config.segmentTemplateFormat,
|
|
807
|
+
periodTriggers: config.periodTriggers,
|
|
808
|
+
scteDash: segment?.scteFilter ? {
|
|
809
|
+
adMarkerDash: config.scteDashAdMarker,
|
|
810
|
+
} : undefined,
|
|
811
|
+
utcTiming: config.utcTimingMode || config.utcTimingSource ? {
|
|
812
|
+
timingMode: config.utcTimingMode,
|
|
813
|
+
timingSource: config.utcTimingSource,
|
|
814
|
+
} : undefined,
|
|
815
|
+
filterConfiguration: validateFilterConfiguration(config.filterConfiguration),
|
|
816
|
+
};
|
|
817
|
+
}
|
|
818
|
+
/**
|
|
819
|
+
* Build MSS manifest configuration
|
|
820
|
+
* @internal
|
|
821
|
+
*/
|
|
822
|
+
function buildMssManifestConfiguration(config) {
|
|
823
|
+
return {
|
|
824
|
+
manifestName: config.manifestName,
|
|
825
|
+
manifestLayout: config.manifestLayout,
|
|
826
|
+
manifestWindowSeconds: config.manifestWindow?.toSeconds(),
|
|
827
|
+
filterConfiguration: validateFilterConfiguration(config.filterConfiguration),
|
|
828
|
+
};
|
|
829
|
+
}
|
|
830
|
+
/**
|
|
831
|
+
* HLS Manifest implementation
|
|
832
|
+
*/
|
|
833
|
+
class HlsManifest extends Manifest {
|
|
834
|
+
config;
|
|
835
|
+
constructor(config) {
|
|
836
|
+
super();
|
|
837
|
+
this.config = config;
|
|
838
|
+
}
|
|
839
|
+
_bind(context) {
|
|
840
|
+
validateManifestConfiguration(this.config);
|
|
841
|
+
context.hlsManifests.push(buildHlsManifestConfiguration(this.config, context.segment?.segmentDuration));
|
|
842
|
+
}
|
|
843
|
+
}
|
|
844
|
+
/**
|
|
845
|
+
* Low Latency HLS Manifest implementation
|
|
846
|
+
*/
|
|
847
|
+
class LowLatencyHlsManifest extends Manifest {
|
|
848
|
+
config;
|
|
849
|
+
constructor(config) {
|
|
850
|
+
super();
|
|
851
|
+
this.config = config;
|
|
852
|
+
}
|
|
853
|
+
_bind(context) {
|
|
854
|
+
validateManifestConfiguration(this.config);
|
|
855
|
+
context.llHlsManifests.push(buildHlsManifestConfiguration(this.config, context.segment?.segmentDuration));
|
|
856
|
+
}
|
|
857
|
+
}
|
|
858
|
+
/**
|
|
859
|
+
* DASH Manifest implementation
|
|
860
|
+
*/
|
|
861
|
+
class DashManifest extends Manifest {
|
|
862
|
+
config;
|
|
863
|
+
constructor(config) {
|
|
864
|
+
super();
|
|
865
|
+
this.config = config;
|
|
866
|
+
}
|
|
867
|
+
_bind(context) {
|
|
868
|
+
validateManifestConfiguration(this.config);
|
|
869
|
+
if (this.config.utcTimingMode === DashUtcTimingMode.UTC_DIRECT && this.config.utcTimingSource) {
|
|
870
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `UtcDirectTimingSource`, 'UTC Direct configured with a timing source, ensure timing source is undefined to use UTC Direct.');
|
|
871
|
+
}
|
|
872
|
+
context.dashManifests.push(buildDashManifestConfiguration(this.config, context.segment));
|
|
873
|
+
}
|
|
874
|
+
}
|
|
875
|
+
/**
|
|
876
|
+
* MSS Manifest implementation
|
|
877
|
+
*/
|
|
878
|
+
class MssManifest extends Manifest {
|
|
879
|
+
config;
|
|
880
|
+
constructor(config) {
|
|
881
|
+
super();
|
|
882
|
+
this.config = config;
|
|
883
|
+
}
|
|
884
|
+
_bind(context) {
|
|
885
|
+
validateManifestConfiguration(this.config);
|
|
886
|
+
context.mssManifests.push(buildMssManifestConfiguration(this.config));
|
|
887
|
+
}
|
|
888
|
+
}
|
|
889
|
+
/**
|
|
890
|
+
* The type of container to attach to this origin endpoint.
|
|
891
|
+
* A container type is a file format that encapsulates one or more media streams, such as audio and video, into a single file. You can't change the container type after you create the endpoint.
|
|
892
|
+
*/
|
|
893
|
+
var ContainerType;
|
|
894
|
+
(function (ContainerType) {
|
|
895
|
+
/**
|
|
896
|
+
* TS Container Type
|
|
897
|
+
*/
|
|
898
|
+
ContainerType["TS"] = "TS";
|
|
899
|
+
/**
|
|
900
|
+
* CMAF Container Type
|
|
901
|
+
*/
|
|
902
|
+
ContainerType["CMAF"] = "CMAF";
|
|
903
|
+
/**
|
|
904
|
+
* ISM Container Type (Microsoft Smooth Streaming)
|
|
905
|
+
*/
|
|
906
|
+
ContainerType["ISM"] = "ISM";
|
|
907
|
+
})(ContainerType || (exports.ContainerType = ContainerType = {}));
|
|
908
|
+
/**
|
|
909
|
+
* Encryption methods for CMAF container type.
|
|
910
|
+
*/
|
|
911
|
+
var CmafEncryptionMethod;
|
|
912
|
+
(function (CmafEncryptionMethod) {
|
|
913
|
+
/**
|
|
914
|
+
* Common Encryption Scheme (CENC) - compatible with PlayReady, Widevine, and Irdeto DRM systems.
|
|
915
|
+
*/
|
|
916
|
+
CmafEncryptionMethod["CENC"] = "CENC";
|
|
917
|
+
/**
|
|
918
|
+
* Common Encryption Scheme with CBCS mode - compatible with PlayReady, Widevine, and FairPlay DRM systems.
|
|
919
|
+
*/
|
|
920
|
+
CmafEncryptionMethod["CBCS"] = "CBCS";
|
|
921
|
+
})(CmafEncryptionMethod || (exports.CmafEncryptionMethod = CmafEncryptionMethod = {}));
|
|
922
|
+
/**
|
|
923
|
+
* Encryption methods for TS container type.
|
|
924
|
+
*/
|
|
925
|
+
var TsEncryptionMethod;
|
|
926
|
+
(function (TsEncryptionMethod) {
|
|
927
|
+
/**
|
|
928
|
+
* AES-128 encryption - requires Clear Key AES 128 DRM system.
|
|
929
|
+
*/
|
|
930
|
+
TsEncryptionMethod["AES_128"] = "AES_128";
|
|
931
|
+
/**
|
|
932
|
+
* Sample-level AES encryption - requires FairPlay DRM system.
|
|
933
|
+
*/
|
|
934
|
+
TsEncryptionMethod["SAMPLE_AES"] = "SAMPLE_AES";
|
|
935
|
+
})(TsEncryptionMethod || (exports.TsEncryptionMethod = TsEncryptionMethod = {}));
|
|
936
|
+
/**
|
|
937
|
+
* A collection of audio encryption presets.
|
|
938
|
+
*/
|
|
939
|
+
var PresetSpeke20Audio;
|
|
940
|
+
(function (PresetSpeke20Audio) {
|
|
941
|
+
/**
|
|
942
|
+
* Use one content key to encrypt all of the audio tracks in your stream.
|
|
943
|
+
*/
|
|
944
|
+
PresetSpeke20Audio["PRESET_AUDIO_1"] = "PRESET_AUDIO_1";
|
|
945
|
+
/**
|
|
946
|
+
* Use one content key to encrypt all of the stereo audio tracks and one content key to encrypt all of the multichannel audio tracks.
|
|
947
|
+
*/
|
|
948
|
+
PresetSpeke20Audio["PRESET_AUDIO_2"] = "PRESET_AUDIO_2";
|
|
949
|
+
/**
|
|
950
|
+
* Use one content key to encrypt all of the stereo audio tracks, one content key to encrypt all of the multichannel audio tracks with 3 to 6 channels,
|
|
951
|
+
* and one content key to encrypt all of the multichannel audio tracks with more than 6 channels.
|
|
952
|
+
*/
|
|
953
|
+
PresetSpeke20Audio["PRESET_AUDIO_3"] = "PRESET_AUDIO_3";
|
|
954
|
+
/**
|
|
955
|
+
* Use the same content key for all of the audio and video tracks in your stream.
|
|
956
|
+
*/
|
|
957
|
+
PresetSpeke20Audio["SHARED"] = "SHARED";
|
|
958
|
+
/**
|
|
959
|
+
* Don't encrypt any of the audio tracks in your stream.
|
|
960
|
+
*/
|
|
961
|
+
PresetSpeke20Audio["UNENCRYPTED"] = "UNENCRYPTED";
|
|
962
|
+
})(PresetSpeke20Audio || (exports.PresetSpeke20Audio = PresetSpeke20Audio = {}));
|
|
963
|
+
/**
|
|
964
|
+
* The SPEKE Version 2.0 preset video associated with the encryption contract configuration of the origin endpoint.
|
|
965
|
+
*
|
|
966
|
+
* A collection of video encryption presets.
|
|
967
|
+
*/
|
|
968
|
+
var PresetSpeke20Video;
|
|
969
|
+
(function (PresetSpeke20Video) {
|
|
970
|
+
/**
|
|
971
|
+
* Use one content key to encrypt all of the video tracks in your stream.
|
|
972
|
+
*/
|
|
973
|
+
PresetSpeke20Video["PRESET_VIDEO_1"] = "PRESET_VIDEO_1";
|
|
974
|
+
/**
|
|
975
|
+
* Use one content key to encrypt all of the SD video tracks and one content key for all HD and higher resolutions video tracks.
|
|
976
|
+
*/
|
|
977
|
+
PresetSpeke20Video["PRESET_VIDEO_2"] = "PRESET_VIDEO_2";
|
|
978
|
+
/**
|
|
979
|
+
* Use one content key to encrypt all of the SD video tracks, one content key for HD video tracks and one content key for all UHD video tracks.
|
|
980
|
+
*/
|
|
981
|
+
PresetSpeke20Video["PRESET_VIDEO_3"] = "PRESET_VIDEO_3";
|
|
982
|
+
/**
|
|
983
|
+
* Use one content key to encrypt all of the SD video tracks, one content key for HD video tracks,
|
|
984
|
+
* one content key for all UHD1 video tracks and one content key for all UHD2 video tracks.
|
|
985
|
+
*/
|
|
986
|
+
PresetSpeke20Video["PRESET_VIDEO_4"] = "PRESET_VIDEO_4";
|
|
987
|
+
/**
|
|
988
|
+
* Use one content key to encrypt all of the SD video tracks, one content key for HD1 video tracks, one content key for HD2 video tracks,
|
|
989
|
+
* one content key for all UHD1 video tracks and one content key for all UHD2 video tracks.
|
|
990
|
+
*/
|
|
991
|
+
PresetSpeke20Video["PRESET_VIDEO_5"] = "PRESET_VIDEO_5";
|
|
992
|
+
/**
|
|
993
|
+
* Use one content key to encrypt all of the SD video tracks, one content key for HD1 video tracks, one content key for HD2 video tracks
|
|
994
|
+
* and one content key for all UHD video tracks.
|
|
995
|
+
*/
|
|
996
|
+
PresetSpeke20Video["PRESET_VIDEO_6"] = "PRESET_VIDEO_6";
|
|
997
|
+
/**
|
|
998
|
+
* Use one content key to encrypt all of the SD+HD1 video tracks, one content key for HD2 video tracks and one content key for all UHD video tracks.
|
|
999
|
+
*/
|
|
1000
|
+
PresetSpeke20Video["PRESET_VIDEO_7"] = "PRESET_VIDEO_7";
|
|
1001
|
+
/**
|
|
1002
|
+
* Use one content key to encrypt all of the SD+HD1 video tracks, one content key for HD2 video tracks, one content key for all UHD1
|
|
1003
|
+
* video tracks and one content key for all UHD2 video tracks.
|
|
1004
|
+
*/
|
|
1005
|
+
PresetSpeke20Video["PRESET_VIDEO_8"] = "PRESET_VIDEO_8";
|
|
1006
|
+
/**
|
|
1007
|
+
* Use the same content key for all of the video and audio tracks in your stream.
|
|
1008
|
+
*/
|
|
1009
|
+
PresetSpeke20Video["SHARED"] = "SHARED";
|
|
1010
|
+
/**
|
|
1011
|
+
* Don't encrypt any of the video tracks in your stream.
|
|
1012
|
+
*/
|
|
1013
|
+
PresetSpeke20Video["UNENCRYPTED"] = "UNENCRYPTED";
|
|
1014
|
+
})(PresetSpeke20Video || (exports.PresetSpeke20Video = PresetSpeke20Video = {}));
|
|
1015
|
+
/**
|
|
1016
|
+
* Endpoint error configuration options.
|
|
1017
|
+
*/
|
|
1018
|
+
var EndpointErrorConfiguration;
|
|
1019
|
+
(function (EndpointErrorConfiguration) {
|
|
1020
|
+
/**
|
|
1021
|
+
* The manifest stalled and there are no new segments or parts.
|
|
1022
|
+
*/
|
|
1023
|
+
EndpointErrorConfiguration["STALE_MANIFEST"] = "STALE_MANIFEST";
|
|
1024
|
+
/**
|
|
1025
|
+
* There is a gap in the manifest.
|
|
1026
|
+
*/
|
|
1027
|
+
EndpointErrorConfiguration["INCOMPLETE_MANIFEST"] = "INCOMPLETE_MANIFEST";
|
|
1028
|
+
/**
|
|
1029
|
+
* Key rotation is enabled but we're unable to fetch the key for the current key period.
|
|
1030
|
+
*/
|
|
1031
|
+
EndpointErrorConfiguration["MISSING_DRM_KEY"] = "MISSING_DRM_KEY";
|
|
1032
|
+
/**
|
|
1033
|
+
* The segments which contain slate content are considered to be missing content.
|
|
1034
|
+
*/
|
|
1035
|
+
EndpointErrorConfiguration["SLATE_INPUT"] = "SLATE_INPUT";
|
|
1036
|
+
})(EndpointErrorConfiguration || (exports.EndpointErrorConfiguration = EndpointErrorConfiguration = {}));
|
|
1037
|
+
/**
|
|
1038
|
+
* SCTE-35 message type options available.
|
|
1039
|
+
*/
|
|
1040
|
+
var ScteMessageType;
|
|
1041
|
+
(function (ScteMessageType) {
|
|
1042
|
+
/**
|
|
1043
|
+
* Option for SPLICE_INSERT.
|
|
1044
|
+
*/
|
|
1045
|
+
ScteMessageType["SPLICE_INSERT"] = "SPLICE_INSERT";
|
|
1046
|
+
/**
|
|
1047
|
+
* Option for BREAK.
|
|
1048
|
+
*/
|
|
1049
|
+
ScteMessageType["BREAK"] = "BREAK";
|
|
1050
|
+
/**
|
|
1051
|
+
* Option for PROVIDER_ADVERTISEMENT.
|
|
1052
|
+
*/
|
|
1053
|
+
ScteMessageType["PROVIDER_ADVERTISEMENT"] = "PROVIDER_ADVERTISEMENT";
|
|
1054
|
+
/**
|
|
1055
|
+
* Option for DISTRIBUTOR_ADVERTISEMENT.
|
|
1056
|
+
*/
|
|
1057
|
+
ScteMessageType["DISTRIBUTOR_ADVERTISEMENT"] = "DISTRIBUTOR_ADVERTISEMENT";
|
|
1058
|
+
/**
|
|
1059
|
+
* Option for PROVIDER_PLACEMENT_OPPORTUNITY.
|
|
1060
|
+
*/
|
|
1061
|
+
ScteMessageType["PROVIDER_PLACEMENT_OPPORTUNITY"] = "PROVIDER_PLACEMENT_OPPORTUNITY";
|
|
1062
|
+
/**
|
|
1063
|
+
* Option for DISTRIBUTOR_PLACEMENT_OPPORTUNITY.
|
|
1064
|
+
*/
|
|
1065
|
+
ScteMessageType["DISTRIBUTOR_PLACEMENT_OPPORTUNITY"] = "DISTRIBUTOR_PLACEMENT_OPPORTUNITY";
|
|
1066
|
+
/**
|
|
1067
|
+
* Option for PROVIDER_OVERLAY_PLACEMENT_OPPORTUNITY.
|
|
1068
|
+
*/
|
|
1069
|
+
ScteMessageType["PROVIDER_OVERLAY_PLACEMENT_OPPORTUNITY"] = "PROVIDER_OVERLAY_PLACEMENT_OPPORTUNITY";
|
|
1070
|
+
/**
|
|
1071
|
+
* Option for DISTRIBUTOR_OVERLAY_PLACEMENT_OPPORTUNITY.
|
|
1072
|
+
*/
|
|
1073
|
+
ScteMessageType["DISTRIBUTOR_OVERLAY_PLACEMENT_OPPORTUNITY"] = "DISTRIBUTOR_OVERLAY_PLACEMENT_OPPORTUNITY";
|
|
1074
|
+
/**
|
|
1075
|
+
* Option for PROGRAM.
|
|
1076
|
+
*/
|
|
1077
|
+
ScteMessageType["PROGRAM"] = "PROGRAM";
|
|
1078
|
+
})(ScteMessageType || (exports.ScteMessageType = ScteMessageType = {}));
|
|
1079
|
+
/**
|
|
1080
|
+
* Controls whether SCTE-35 messages are included in segment files.
|
|
1081
|
+
*/
|
|
1082
|
+
var ScteInSegments;
|
|
1083
|
+
(function (ScteInSegments) {
|
|
1084
|
+
/**
|
|
1085
|
+
* SCTE-35 messages are not included in segments.
|
|
1086
|
+
*/
|
|
1087
|
+
ScteInSegments["NONE"] = "NONE";
|
|
1088
|
+
/**
|
|
1089
|
+
* SCTE-35 messages are embedded in segment data.
|
|
1090
|
+
*
|
|
1091
|
+
* For DASH manifests, when set to ALL, an InbandEventStream tag signals
|
|
1092
|
+
* that SCTE messages are present in segments.
|
|
1093
|
+
*/
|
|
1094
|
+
ScteInSegments["ALL"] = "ALL";
|
|
1095
|
+
})(ScteInSegments || (exports.ScteInSegments = ScteInSegments = {}));
|
|
1096
|
+
/**
|
|
1097
|
+
* DRM settings keys for manifest filter configuration.
|
|
1098
|
+
*/
|
|
1099
|
+
var DrmSettingsKey;
|
|
1100
|
+
(function (DrmSettingsKey) {
|
|
1101
|
+
/**
|
|
1102
|
+
* Exclude EXT-X-SESSION-KEY tags from HLS and LL-HLS multivariant playlists.
|
|
1103
|
+
*
|
|
1104
|
+
* This can improve compatibility with legacy HLS clients that have issues
|
|
1105
|
+
* processing session keys, or provide more granular access control when
|
|
1106
|
+
* using manifest filtering.
|
|
1107
|
+
*/
|
|
1108
|
+
DrmSettingsKey["EXCLUDE_SESSION_KEYS"] = "exclude_session_keys";
|
|
1109
|
+
})(DrmSettingsKey || (exports.DrmSettingsKey = DrmSettingsKey = {}));
|
|
1110
|
+
/**
|
|
1111
|
+
* Helper class for creating EXT-X-START tags in HLS playlists.
|
|
1112
|
+
*
|
|
1113
|
+
* The EXT-X-START tag indicates a preferred point at which to start playing a playlist.
|
|
1114
|
+
*/
|
|
1115
|
+
class StartTag {
|
|
1116
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.StartTag", version: "2.247.0-alpha.0" };
|
|
1117
|
+
/**
|
|
1118
|
+
* Create a start tag with a time offset.
|
|
1119
|
+
*
|
|
1120
|
+
* @param timeOffset The time offset in seconds. Can be positive (forward from start) or negative (back from live edge).
|
|
1121
|
+
* - If positive: must be less than (manifest duration - 3 × segment duration)
|
|
1122
|
+
* - If negative: absolute value must be greater than (3 × segment duration) and less than manifest duration
|
|
1123
|
+
* @param options Additional options
|
|
1124
|
+
*/
|
|
1125
|
+
static of(timeOffset, options) {
|
|
1126
|
+
try {
|
|
1127
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_StartTagOptions(options);
|
|
1128
|
+
}
|
|
1129
|
+
catch (error) {
|
|
1130
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1131
|
+
Error.captureStackTrace(error, this.of);
|
|
1132
|
+
}
|
|
1133
|
+
throw error;
|
|
1134
|
+
}
|
|
1135
|
+
return {
|
|
1136
|
+
timeOffset,
|
|
1137
|
+
precise: options && options.precise !== undefined ? options.precise : undefined,
|
|
1138
|
+
};
|
|
1139
|
+
}
|
|
1140
|
+
/**
|
|
1141
|
+
* Create a start tag with precise positioning enabled (PRECISE=YES).
|
|
1142
|
+
*
|
|
1143
|
+
* @param timeOffset The time offset in seconds (positive or negative)
|
|
1144
|
+
*/
|
|
1145
|
+
static withPrecise(timeOffset) {
|
|
1146
|
+
return {
|
|
1147
|
+
timeOffset,
|
|
1148
|
+
precise: true,
|
|
1149
|
+
};
|
|
1150
|
+
}
|
|
1151
|
+
}
|
|
1152
|
+
exports.StartTag = StartTag;
|
|
1153
|
+
/**
|
|
1154
|
+
* Choose how ad markers are included in the packaged content.
|
|
1155
|
+
*/
|
|
1156
|
+
var AdMarkerDash;
|
|
1157
|
+
(function (AdMarkerDash) {
|
|
1158
|
+
/**
|
|
1159
|
+
* Option for BINARY - The SCTE-35 marker is expressed as a hex-string (Base64 string) rather than full XML.
|
|
1160
|
+
*/
|
|
1161
|
+
AdMarkerDash["BINARY"] = "BINARY";
|
|
1162
|
+
/**
|
|
1163
|
+
* Option for XML - The SCTE marker is expressed fully in XML.
|
|
1164
|
+
*/
|
|
1165
|
+
AdMarkerDash["XML"] = "XML";
|
|
1166
|
+
})(AdMarkerDash || (exports.AdMarkerDash = AdMarkerDash = {}));
|
|
1167
|
+
/**
|
|
1168
|
+
* Choose how SCTE-35 ad markers are included in HLS and LL-HLS manifests.
|
|
1169
|
+
*/
|
|
1170
|
+
var AdMarkerHls;
|
|
1171
|
+
(function (AdMarkerHls) {
|
|
1172
|
+
/**
|
|
1173
|
+
* Insert EXT-X-DATERANGE tags to signal ad content.
|
|
1174
|
+
*/
|
|
1175
|
+
AdMarkerHls["DATERANGE"] = "DATERANGE";
|
|
1176
|
+
/**
|
|
1177
|
+
* Insert enhanced SCTE-35 tags for ad content.
|
|
1178
|
+
*/
|
|
1179
|
+
AdMarkerHls["SCTE35_ENHANCED"] = "SCTE35_ENHANCED";
|
|
1180
|
+
})(AdMarkerHls || (exports.AdMarkerHls = AdMarkerHls = {}));
|
|
1181
|
+
/**
|
|
1182
|
+
* The type of variable that MediaPackage uses in the media attribute of the SegmentTemplate tag.
|
|
1183
|
+
*/
|
|
1184
|
+
var SegmentTemplateFormat;
|
|
1185
|
+
(function (SegmentTemplateFormat) {
|
|
1186
|
+
/**
|
|
1187
|
+
* Option for number with timeline.
|
|
1188
|
+
*/
|
|
1189
|
+
SegmentTemplateFormat["NUMBER_WITH_TIMELINE"] = "NUMBER_WITH_TIMELINE";
|
|
1190
|
+
})(SegmentTemplateFormat || (exports.SegmentTemplateFormat = SegmentTemplateFormat = {}));
|
|
1191
|
+
/**
|
|
1192
|
+
* The UTC timing mode for DASH.
|
|
1193
|
+
*/
|
|
1194
|
+
var DashUtcTimingMode;
|
|
1195
|
+
(function (DashUtcTimingMode) {
|
|
1196
|
+
/**
|
|
1197
|
+
* Option for HTTP_HEAD.
|
|
1198
|
+
*/
|
|
1199
|
+
DashUtcTimingMode["HTTP_HEAD"] = "HTTP_HEAD";
|
|
1200
|
+
/**
|
|
1201
|
+
* Option for HTTP_ISO.
|
|
1202
|
+
*/
|
|
1203
|
+
DashUtcTimingMode["HTTP_ISO"] = "HTTP_ISO";
|
|
1204
|
+
/**
|
|
1205
|
+
* Option for HTTP_XSDATE.
|
|
1206
|
+
*/
|
|
1207
|
+
DashUtcTimingMode["HTTP_XSDATE"] = "HTTP_XSDATE";
|
|
1208
|
+
/**
|
|
1209
|
+
* Option for UTC_DIRECT.
|
|
1210
|
+
*/
|
|
1211
|
+
DashUtcTimingMode["UTC_DIRECT"] = "UTC_DIRECT";
|
|
1212
|
+
})(DashUtcTimingMode || (exports.DashUtcTimingMode = DashUtcTimingMode = {}));
|
|
1213
|
+
/**
|
|
1214
|
+
* Options for triggers which cause AWS Elemental MediaPackage to create media presentation description (MPD) periods in the output manifest.
|
|
1215
|
+
*/
|
|
1216
|
+
var DashPeriodTriggers;
|
|
1217
|
+
(function (DashPeriodTriggers) {
|
|
1218
|
+
/**
|
|
1219
|
+
* Option for AVAILS.
|
|
1220
|
+
*/
|
|
1221
|
+
DashPeriodTriggers["AVAILS"] = "AVAILS";
|
|
1222
|
+
/**
|
|
1223
|
+
* Option for DRM_KEY_ROTATION.
|
|
1224
|
+
*/
|
|
1225
|
+
DashPeriodTriggers["DRM_KEY_ROTATION"] = "DRM_KEY_ROTATION";
|
|
1226
|
+
/**
|
|
1227
|
+
* Option for SOURCE_CHANGES.
|
|
1228
|
+
*/
|
|
1229
|
+
DashPeriodTriggers["SOURCE_CHANGES"] = "SOURCE_CHANGES";
|
|
1230
|
+
/**
|
|
1231
|
+
* Option for SOURCE_DISRUPTIONS.
|
|
1232
|
+
*/
|
|
1233
|
+
DashPeriodTriggers["SOURCE_DISRUPTIONS"] = "SOURCE_DISRUPTIONS";
|
|
1234
|
+
/**
|
|
1235
|
+
* Option for NONE.
|
|
1236
|
+
*/
|
|
1237
|
+
DashPeriodTriggers["NONE"] = "NONE";
|
|
1238
|
+
})(DashPeriodTriggers || (exports.DashPeriodTriggers = DashPeriodTriggers = {}));
|
|
1239
|
+
/**
|
|
1240
|
+
* DRM signaling determines the way DASH manifest signals the DRM content.
|
|
1241
|
+
*/
|
|
1242
|
+
var DrmSignalling;
|
|
1243
|
+
(function (DrmSignalling) {
|
|
1244
|
+
/**
|
|
1245
|
+
* Option for INDIVIDUAL.
|
|
1246
|
+
*/
|
|
1247
|
+
DrmSignalling["INDIVIDUAL"] = "INDIVIDUAL";
|
|
1248
|
+
/**
|
|
1249
|
+
* Option for REFERENCED.
|
|
1250
|
+
*/
|
|
1251
|
+
DrmSignalling["REFERENCED"] = "REFERENCED";
|
|
1252
|
+
})(DrmSignalling || (exports.DrmSignalling = DrmSignalling = {}));
|
|
1253
|
+
/**
|
|
1254
|
+
* STANDARD indicates a default manifest, which is compacted. NONE indicates a full manifest.
|
|
1255
|
+
*/
|
|
1256
|
+
var DashManifestCompactness;
|
|
1257
|
+
(function (DashManifestCompactness) {
|
|
1258
|
+
/**
|
|
1259
|
+
* STANDARD
|
|
1260
|
+
*/
|
|
1261
|
+
DashManifestCompactness["STANDARD"] = "STANDARD";
|
|
1262
|
+
/**
|
|
1263
|
+
* NONE
|
|
1264
|
+
*/
|
|
1265
|
+
DashManifestCompactness["NONE"] = "NONE";
|
|
1266
|
+
})(DashManifestCompactness || (exports.DashManifestCompactness = DashManifestCompactness = {}));
|
|
1267
|
+
/**
|
|
1268
|
+
* Options for TTML Profile
|
|
1269
|
+
*/
|
|
1270
|
+
var TtmlProfile;
|
|
1271
|
+
(function (TtmlProfile) {
|
|
1272
|
+
/**
|
|
1273
|
+
* IMSC_1
|
|
1274
|
+
*/
|
|
1275
|
+
TtmlProfile["IMSC_1"] = "IMSC_1";
|
|
1276
|
+
/**
|
|
1277
|
+
* EBU_TT_D_101
|
|
1278
|
+
*/
|
|
1279
|
+
TtmlProfile["EBU_TT_D_101"] = "EBU_TT_D_101";
|
|
1280
|
+
})(TtmlProfile || (exports.TtmlProfile = TtmlProfile = {}));
|
|
1281
|
+
/**
|
|
1282
|
+
* The layout of the MSS manifest.
|
|
1283
|
+
*/
|
|
1284
|
+
var MssManifestLayout;
|
|
1285
|
+
(function (MssManifestLayout) {
|
|
1286
|
+
/**
|
|
1287
|
+
* Full manifest layout.
|
|
1288
|
+
*/
|
|
1289
|
+
MssManifestLayout["FULL"] = "FULL";
|
|
1290
|
+
/**
|
|
1291
|
+
* Compact manifest layout.
|
|
1292
|
+
*/
|
|
1293
|
+
MssManifestLayout["COMPACT"] = "COMPACT";
|
|
1294
|
+
})(MssManifestLayout || (exports.MssManifestLayout = MssManifestLayout = {}));
|
|
1295
|
+
/**
|
|
1296
|
+
* DRM systems available for CMAF encryption.
|
|
1297
|
+
*
|
|
1298
|
+
* CENC supports PlayReady, Widevine, and Irdeto.
|
|
1299
|
+
* CBCS supports PlayReady, Widevine, and FairPlay.
|
|
1300
|
+
*/
|
|
1301
|
+
var CmafDrmSystem;
|
|
1302
|
+
(function (CmafDrmSystem) {
|
|
1303
|
+
/**
|
|
1304
|
+
* FairPlay DRM - used with CBCS encryption.
|
|
1305
|
+
*/
|
|
1306
|
+
CmafDrmSystem["FAIRPLAY"] = "FAIRPLAY";
|
|
1307
|
+
/**
|
|
1308
|
+
* PlayReady DRM - used with CENC and CBCS encryption.
|
|
1309
|
+
*/
|
|
1310
|
+
CmafDrmSystem["PLAYREADY"] = "PLAYREADY";
|
|
1311
|
+
/**
|
|
1312
|
+
* Widevine DRM - used with CENC and CBCS encryption.
|
|
1313
|
+
*/
|
|
1314
|
+
CmafDrmSystem["WIDEVINE"] = "WIDEVINE";
|
|
1315
|
+
/**
|
|
1316
|
+
* Irdeto DRM - used with CENC encryption.
|
|
1317
|
+
*/
|
|
1318
|
+
CmafDrmSystem["IRDETO"] = "IRDETO";
|
|
1319
|
+
})(CmafDrmSystem || (exports.CmafDrmSystem = CmafDrmSystem = {}));
|
|
1320
|
+
/**
|
|
1321
|
+
* DRM systems available for TS encryption.
|
|
1322
|
+
*
|
|
1323
|
+
* SAMPLE_AES uses FairPlay, AES_128 uses Clear Key AES 128.
|
|
1324
|
+
*/
|
|
1325
|
+
var TsDrmSystem;
|
|
1326
|
+
(function (TsDrmSystem) {
|
|
1327
|
+
/**
|
|
1328
|
+
* FairPlay DRM - used with SAMPLE_AES encryption.
|
|
1329
|
+
*/
|
|
1330
|
+
TsDrmSystem["FAIRPLAY"] = "FAIRPLAY";
|
|
1331
|
+
/**
|
|
1332
|
+
* Clear Key AES 128 - used with AES_128 encryption.
|
|
1333
|
+
*/
|
|
1334
|
+
TsDrmSystem["CLEAR_KEY_AES_128"] = "CLEAR_KEY_AES_128";
|
|
1335
|
+
})(TsDrmSystem || (exports.TsDrmSystem = TsDrmSystem = {}));
|
|
1336
|
+
/**
|
|
1337
|
+
* DRM systems available for ISM encryption.
|
|
1338
|
+
*
|
|
1339
|
+
* ISM only supports PlayReady with CENC.
|
|
1340
|
+
*/
|
|
1341
|
+
var IsmDrmSystem;
|
|
1342
|
+
(function (IsmDrmSystem) {
|
|
1343
|
+
/**
|
|
1344
|
+
* PlayReady DRM.
|
|
1345
|
+
*/
|
|
1346
|
+
IsmDrmSystem["PLAYREADY"] = "PLAYREADY";
|
|
1347
|
+
})(IsmDrmSystem || (exports.IsmDrmSystem = IsmDrmSystem = {}));
|
|
1348
|
+
/**
|
|
1349
|
+
* Base class for encryption configurations.
|
|
1350
|
+
*
|
|
1351
|
+
* Use `CmafEncryption.speke()`, `TsEncryption.speke()`, or `IsmEncryption.speke()` to create instances.
|
|
1352
|
+
*/
|
|
1353
|
+
class EncryptionConfiguration {
|
|
1354
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.EncryptionConfiguration", version: "2.247.0-alpha.0" };
|
|
1355
|
+
}
|
|
1356
|
+
exports.EncryptionConfiguration = EncryptionConfiguration;
|
|
1357
|
+
/**
|
|
1358
|
+
* Encryption configuration for CMAF segments.
|
|
1359
|
+
*
|
|
1360
|
+
* Use `CmafEncryption.speke()` to create an instance.
|
|
1361
|
+
*/
|
|
1362
|
+
class CmafEncryption extends EncryptionConfiguration {
|
|
1363
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.CmafEncryption", version: "2.247.0-alpha.0" };
|
|
1364
|
+
/**
|
|
1365
|
+
* Create a SPEKE-based encryption configuration for CMAF segments.
|
|
1366
|
+
*/
|
|
1367
|
+
static speke(props) {
|
|
1368
|
+
try {
|
|
1369
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_CmafSpekeEncryptionProps(props);
|
|
1370
|
+
}
|
|
1371
|
+
catch (error) {
|
|
1372
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1373
|
+
Error.captureStackTrace(error, this.speke);
|
|
1374
|
+
}
|
|
1375
|
+
throw error;
|
|
1376
|
+
}
|
|
1377
|
+
if (!props.url.startsWith('https://')) {
|
|
1378
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `SpekeUrlHttpsRequired`, 'SPEKE key provider URL must use HTTPS.');
|
|
1379
|
+
}
|
|
1380
|
+
if (props.method === CmafEncryptionMethod.CENC && props.drmSystems.includes(CmafDrmSystem.FAIRPLAY)) {
|
|
1381
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `CencFairPlayIncompatible`, 'CENC encryption method does not support FairPlay. Use CBCS for FairPlay.');
|
|
1382
|
+
}
|
|
1383
|
+
if (props.method === CmafEncryptionMethod.CBCS && props.drmSystems.includes(CmafDrmSystem.IRDETO)) {
|
|
1384
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `CbcsIrdetoIncompatible`, 'CBCS encryption method does not support Irdeto. Use CENC for Irdeto.');
|
|
1385
|
+
}
|
|
1386
|
+
return new CmafEncryption(props);
|
|
1387
|
+
}
|
|
1388
|
+
config;
|
|
1389
|
+
constructor(props) {
|
|
1390
|
+
super();
|
|
1391
|
+
this.config = props;
|
|
1392
|
+
}
|
|
1393
|
+
/** @internal */
|
|
1394
|
+
_bind(scope) {
|
|
1395
|
+
const p = this.config;
|
|
1396
|
+
if (p.constantInitializationVector && p.constantInitializationVector.length !== 32) {
|
|
1397
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `ConstantInitVectorLength`, 'Constant Initialization Vector needs to be 32 characters in length.', scope);
|
|
1398
|
+
}
|
|
1399
|
+
if (p.keyRotationInterval && (p.keyRotationInterval.toSeconds() < 300 || p.keyRotationInterval.toSeconds() > 31536000)) {
|
|
1400
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `KeyRotationIntervalRange`, 'Key Rotation Interval needs to be between 300-31536000 seconds.', scope);
|
|
1401
|
+
}
|
|
1402
|
+
return {
|
|
1403
|
+
cmafExcludeSegmentDrmMetadata: p.excludeSegmentDrmMetadata,
|
|
1404
|
+
constantInitializationVector: p.constantInitializationVector,
|
|
1405
|
+
keyRotationIntervalSeconds: p.keyRotationInterval?.toSeconds(),
|
|
1406
|
+
encryptionMethod: { cmafEncryptionMethod: p.method },
|
|
1407
|
+
spekeKeyProvider: {
|
|
1408
|
+
certificateArn: p.certificate?.certificateArn,
|
|
1409
|
+
drmSystems: p.drmSystems,
|
|
1410
|
+
encryptionContractConfiguration: {
|
|
1411
|
+
presetSpeke20Audio: p.audioPreset ?? PresetSpeke20Audio.PRESET_AUDIO_1,
|
|
1412
|
+
presetSpeke20Video: p.videoPreset ?? PresetSpeke20Video.PRESET_VIDEO_1,
|
|
1413
|
+
},
|
|
1414
|
+
url: p.url,
|
|
1415
|
+
resourceId: p.resourceId,
|
|
1416
|
+
roleArn: p.role.roleArn,
|
|
1417
|
+
},
|
|
1418
|
+
};
|
|
1419
|
+
}
|
|
1420
|
+
/** @internal */
|
|
1421
|
+
_getRole() { return this.config.role; }
|
|
1422
|
+
/** @internal */
|
|
1423
|
+
_getCertificate() { return this.config.certificate; }
|
|
1424
|
+
}
|
|
1425
|
+
exports.CmafEncryption = CmafEncryption;
|
|
1426
|
+
/**
|
|
1427
|
+
* Encryption configuration for TS segments.
|
|
1428
|
+
*
|
|
1429
|
+
* Use `TsEncryption.speke()` to create an instance.
|
|
1430
|
+
*/
|
|
1431
|
+
class TsEncryption extends EncryptionConfiguration {
|
|
1432
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.TsEncryption", version: "2.247.0-alpha.0" };
|
|
1433
|
+
/**
|
|
1434
|
+
* Create a SPEKE-based encryption configuration for TS segments.
|
|
1435
|
+
*/
|
|
1436
|
+
static speke(props) {
|
|
1437
|
+
try {
|
|
1438
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_TsSpekeEncryptionProps(props);
|
|
1439
|
+
}
|
|
1440
|
+
catch (error) {
|
|
1441
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1442
|
+
Error.captureStackTrace(error, this.speke);
|
|
1443
|
+
}
|
|
1444
|
+
throw error;
|
|
1445
|
+
}
|
|
1446
|
+
if (!props.url.startsWith('https://')) {
|
|
1447
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `SpekeUrlHttpsRequired`, 'SPEKE key provider URL must use HTTPS.');
|
|
1448
|
+
}
|
|
1449
|
+
return new TsEncryption(props);
|
|
1450
|
+
}
|
|
1451
|
+
config;
|
|
1452
|
+
constructor(props) {
|
|
1453
|
+
super();
|
|
1454
|
+
this.config = props;
|
|
1455
|
+
}
|
|
1456
|
+
/** @internal */
|
|
1457
|
+
_bind(scope) {
|
|
1458
|
+
const p = this.config;
|
|
1459
|
+
const defaultDrm = p.method === TsEncryptionMethod.SAMPLE_AES
|
|
1460
|
+
? [TsDrmSystem.FAIRPLAY] : [TsDrmSystem.CLEAR_KEY_AES_128];
|
|
1461
|
+
if (p.constantInitializationVector && p.constantInitializationVector.length !== 32) {
|
|
1462
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `ConstantInitVectorLength`, 'Constant Initialization Vector needs to be 32 characters in length.', scope);
|
|
1463
|
+
}
|
|
1464
|
+
if (p.keyRotationInterval && (p.keyRotationInterval.toSeconds() < 300 || p.keyRotationInterval.toSeconds() > 31536000)) {
|
|
1465
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `KeyRotationIntervalRange`, 'Key Rotation Interval needs to be between 300-31536000 seconds.', scope);
|
|
1466
|
+
}
|
|
1467
|
+
return {
|
|
1468
|
+
constantInitializationVector: p.constantInitializationVector,
|
|
1469
|
+
keyRotationIntervalSeconds: p.keyRotationInterval?.toSeconds(),
|
|
1470
|
+
encryptionMethod: { tsEncryptionMethod: p.method },
|
|
1471
|
+
spekeKeyProvider: {
|
|
1472
|
+
certificateArn: p.certificate?.certificateArn,
|
|
1473
|
+
drmSystems: (p.drmSystems ?? defaultDrm).map(d => d.toString()),
|
|
1474
|
+
encryptionContractConfiguration: {
|
|
1475
|
+
presetSpeke20Audio: p.audioPreset ?? PresetSpeke20Audio.PRESET_AUDIO_1,
|
|
1476
|
+
presetSpeke20Video: p.videoPreset ?? PresetSpeke20Video.PRESET_VIDEO_1,
|
|
1477
|
+
},
|
|
1478
|
+
url: p.url,
|
|
1479
|
+
resourceId: p.resourceId,
|
|
1480
|
+
roleArn: p.role.roleArn,
|
|
1481
|
+
},
|
|
1482
|
+
};
|
|
1483
|
+
}
|
|
1484
|
+
/** @internal */
|
|
1485
|
+
_getRole() { return this.config.role; }
|
|
1486
|
+
/** @internal */
|
|
1487
|
+
_getCertificate() { return this.config.certificate; }
|
|
1488
|
+
}
|
|
1489
|
+
exports.TsEncryption = TsEncryption;
|
|
1490
|
+
/**
|
|
1491
|
+
* Encryption configuration for ISM (Microsoft Smooth Streaming) segments.
|
|
1492
|
+
*
|
|
1493
|
+
* ISM only supports CENC encryption with PlayReady DRM.
|
|
1494
|
+
* Audio and video presets are always SHARED.
|
|
1495
|
+
*
|
|
1496
|
+
* Use `IsmEncryption.speke()` to create an instance.
|
|
1497
|
+
*/
|
|
1498
|
+
class IsmEncryption extends EncryptionConfiguration {
|
|
1499
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.IsmEncryption", version: "2.247.0-alpha.0" };
|
|
1500
|
+
/**
|
|
1501
|
+
* Create a SPEKE-based encryption configuration for ISM segments.
|
|
1502
|
+
*/
|
|
1503
|
+
static speke(props) {
|
|
1504
|
+
try {
|
|
1505
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_IsmSpekeEncryptionProps(props);
|
|
1506
|
+
}
|
|
1507
|
+
catch (error) {
|
|
1508
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1509
|
+
Error.captureStackTrace(error, this.speke);
|
|
1510
|
+
}
|
|
1511
|
+
throw error;
|
|
1512
|
+
}
|
|
1513
|
+
if (!props.url.startsWith('https://')) {
|
|
1514
|
+
throw new core_1.UnscopedValidationError((0, helpers_internal_1.lit) `SpekeUrlHttpsRequired`, 'SPEKE key provider URL must use HTTPS.');
|
|
1515
|
+
}
|
|
1516
|
+
return new IsmEncryption(props);
|
|
1517
|
+
}
|
|
1518
|
+
config;
|
|
1519
|
+
constructor(props) {
|
|
1520
|
+
super();
|
|
1521
|
+
this.config = props;
|
|
1522
|
+
}
|
|
1523
|
+
/** @internal */
|
|
1524
|
+
_bind(_scope) {
|
|
1525
|
+
const p = this.config;
|
|
1526
|
+
return {
|
|
1527
|
+
encryptionMethod: { ismEncryptionMethod: 'CENC' },
|
|
1528
|
+
spekeKeyProvider: {
|
|
1529
|
+
certificateArn: p.certificate?.certificateArn,
|
|
1530
|
+
drmSystems: (p.drmSystems ?? [IsmDrmSystem.PLAYREADY]).map(d => d.toString()),
|
|
1531
|
+
encryptionContractConfiguration: {
|
|
1532
|
+
presetSpeke20Audio: PresetSpeke20Audio.SHARED,
|
|
1533
|
+
presetSpeke20Video: PresetSpeke20Video.SHARED,
|
|
1534
|
+
},
|
|
1535
|
+
url: p.url,
|
|
1536
|
+
resourceId: p.resourceId,
|
|
1537
|
+
roleArn: p.role.roleArn,
|
|
1538
|
+
},
|
|
1539
|
+
};
|
|
1540
|
+
}
|
|
1541
|
+
/** @internal */
|
|
1542
|
+
_getRole() { return this.config.role; }
|
|
1543
|
+
/** @internal */
|
|
1544
|
+
_getCertificate() { return this.config.certificate; }
|
|
1545
|
+
}
|
|
1546
|
+
exports.IsmEncryption = IsmEncryption;
|
|
1547
|
+
/**
|
|
1548
|
+
* Helper class for creating segment configurations.
|
|
1549
|
+
*/
|
|
1550
|
+
class Segment {
|
|
1551
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.Segment", version: "2.247.0-alpha.0" };
|
|
1552
|
+
/**
|
|
1553
|
+
* Create a TS (Transport Stream) segment configuration.
|
|
1554
|
+
*
|
|
1555
|
+
* Use this for endpoints with ContainerType.TS.
|
|
1556
|
+
*/
|
|
1557
|
+
static ts(props = {}) {
|
|
1558
|
+
try {
|
|
1559
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_TsSegmentProps(props);
|
|
1560
|
+
}
|
|
1561
|
+
catch (error) {
|
|
1562
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1563
|
+
Error.captureStackTrace(error, this.ts);
|
|
1564
|
+
}
|
|
1565
|
+
throw error;
|
|
1566
|
+
}
|
|
1567
|
+
return {
|
|
1568
|
+
containerType: ContainerType.TS,
|
|
1569
|
+
includeIframeOnlyStreams: props.includeIframeOnlyStreams,
|
|
1570
|
+
scteFilter: props.scteFilter,
|
|
1571
|
+
scteInSegments: props.scteInSegments,
|
|
1572
|
+
segmentDuration: props.duration,
|
|
1573
|
+
segmentName: props.name,
|
|
1574
|
+
tsIncludeDvbSubtitles: props.includeDvbSubtitles,
|
|
1575
|
+
tsUseAudioRenditionGroup: props.useAudioRenditionGroup,
|
|
1576
|
+
encryption: props.encryption,
|
|
1577
|
+
};
|
|
1578
|
+
}
|
|
1579
|
+
/**
|
|
1580
|
+
* Create a CMAF segment configuration.
|
|
1581
|
+
*
|
|
1582
|
+
* Use this for endpoints with ContainerType.CMAF.
|
|
1583
|
+
*/
|
|
1584
|
+
static cmaf(props = {}) {
|
|
1585
|
+
try {
|
|
1586
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_CmafSegmentProps(props);
|
|
1587
|
+
}
|
|
1588
|
+
catch (error) {
|
|
1589
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1590
|
+
Error.captureStackTrace(error, this.cmaf);
|
|
1591
|
+
}
|
|
1592
|
+
throw error;
|
|
1593
|
+
}
|
|
1594
|
+
return {
|
|
1595
|
+
containerType: ContainerType.CMAF,
|
|
1596
|
+
includeIframeOnlyStreams: props.includeIframeOnlyStreams,
|
|
1597
|
+
scteFilter: props.scteFilter,
|
|
1598
|
+
scteInSegments: props.scteInSegments,
|
|
1599
|
+
segmentDuration: props.duration,
|
|
1600
|
+
segmentName: props.name,
|
|
1601
|
+
encryption: props.encryption,
|
|
1602
|
+
};
|
|
1603
|
+
}
|
|
1604
|
+
/**
|
|
1605
|
+
* Create an ISM (Microsoft Smooth Streaming) segment configuration.
|
|
1606
|
+
*
|
|
1607
|
+
* Use this for endpoints with ContainerType.ISM.
|
|
1608
|
+
*/
|
|
1609
|
+
static ism(props = {}) {
|
|
1610
|
+
try {
|
|
1611
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_IsmSegmentProps(props);
|
|
1612
|
+
}
|
|
1613
|
+
catch (error) {
|
|
1614
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1615
|
+
Error.captureStackTrace(error, this.ism);
|
|
1616
|
+
}
|
|
1617
|
+
throw error;
|
|
1618
|
+
}
|
|
1619
|
+
return {
|
|
1620
|
+
containerType: ContainerType.ISM,
|
|
1621
|
+
includeIframeOnlyStreams: props.includeIframeOnlyStreams,
|
|
1622
|
+
segmentDuration: props.duration,
|
|
1623
|
+
segmentName: props.name,
|
|
1624
|
+
encryption: props.encryption,
|
|
1625
|
+
};
|
|
1626
|
+
}
|
|
1627
|
+
}
|
|
1628
|
+
exports.Segment = Segment;
|
|
1629
|
+
class OriginEndpointBase extends aws_cdk_lib_1.Resource {
|
|
1630
|
+
/**
|
|
1631
|
+
* Creates an OriginEndpoint construct that represents an external (imported) Origin Endpoint.
|
|
1632
|
+
*/
|
|
1633
|
+
static fromOriginEndpointAttributes(scope, id, attrs) {
|
|
1634
|
+
class Import extends OriginEndpointBase {
|
|
1635
|
+
hlsManifests = [];
|
|
1636
|
+
llHlsManifests = [];
|
|
1637
|
+
dashManifests = [];
|
|
1638
|
+
mssManifests = [];
|
|
1639
|
+
segment;
|
|
1640
|
+
policy = undefined;
|
|
1641
|
+
channelGroupName = attrs.channelGroupName;
|
|
1642
|
+
channelName = attrs.channelName;
|
|
1643
|
+
originEndpointName = attrs.originEndpointName;
|
|
1644
|
+
createdAt = undefined;
|
|
1645
|
+
modifiedAt = undefined;
|
|
1646
|
+
hlsManifestUrls = undefined;
|
|
1647
|
+
lowLatencyHlsManifestUrls = undefined;
|
|
1648
|
+
dashManifestUrls = undefined;
|
|
1649
|
+
mssManifestUrls = undefined;
|
|
1650
|
+
autoCreatePolicy = false;
|
|
1651
|
+
originEndpointArn = aws_cdk_lib_1.Stack.of(this).formatArn({
|
|
1652
|
+
service: 'mediapackagev2',
|
|
1653
|
+
resource: `channelGroup/${attrs.channelGroupName}/channel/${this.channelName}/originEndpoint`,
|
|
1654
|
+
arnFormat: aws_cdk_lib_1.ArnFormat.SLASH_RESOURCE_NAME,
|
|
1655
|
+
resourceName: this.originEndpointName,
|
|
1656
|
+
});
|
|
1657
|
+
}
|
|
1658
|
+
return new Import(scope, id);
|
|
1659
|
+
}
|
|
1660
|
+
/**
|
|
1661
|
+
* A reference to this Origin Endpoint resource.
|
|
1662
|
+
* Required by the auto-generated IOriginEndpointRef interface.
|
|
1663
|
+
*/
|
|
1664
|
+
get originEndpointRef() {
|
|
1665
|
+
return {
|
|
1666
|
+
originEndpointArn: this.originEndpointArn,
|
|
1667
|
+
};
|
|
1668
|
+
}
|
|
1669
|
+
/**
|
|
1670
|
+
* CDN authorization configuration to be applied when the policy is created.
|
|
1671
|
+
*/
|
|
1672
|
+
cdnAuthConfig;
|
|
1673
|
+
/**
|
|
1674
|
+
* Set CDN auth config. Used by subclass constructors.
|
|
1675
|
+
* @internal
|
|
1676
|
+
*/
|
|
1677
|
+
_setCdnAuth(cdnAuth) {
|
|
1678
|
+
if (!this.cdnAuthConfig) {
|
|
1679
|
+
this.cdnAuthConfig = cdnAuth;
|
|
1680
|
+
}
|
|
1681
|
+
}
|
|
1682
|
+
/**
|
|
1683
|
+
* Configure origin endpoint policy.
|
|
1684
|
+
*
|
|
1685
|
+
* You can only add 1 OriginEndpointPolicy to an OriginEndpoint.
|
|
1686
|
+
* If you have already defined one, it will append to the policy already created.
|
|
1687
|
+
*
|
|
1688
|
+
* @param statement - The policy statement to add
|
|
1689
|
+
* @param cdnAuth - Optional CDN authorization configuration. If provided, the policy will be
|
|
1690
|
+
* created with CDN authentication enabled using secrets from AWS Secrets Manager.
|
|
1691
|
+
* If cdnAuth is provided multiple times, only the first configuration is used.
|
|
1692
|
+
*/
|
|
1693
|
+
addToResourcePolicy(statement, cdnAuth) {
|
|
1694
|
+
// Store CDN auth config if provided (only if not already set)
|
|
1695
|
+
if (cdnAuth && !this.cdnAuthConfig) {
|
|
1696
|
+
this.cdnAuthConfig = cdnAuth;
|
|
1697
|
+
}
|
|
1698
|
+
if (!this.policy && this.autoCreatePolicy) {
|
|
1699
|
+
this.policy = new origin_endpoint_policy_1.OriginEndpointPolicy(this, 'Policy', {
|
|
1700
|
+
originEndpoint: this,
|
|
1701
|
+
cdnAuth: this.cdnAuthConfig,
|
|
1702
|
+
});
|
|
1703
|
+
}
|
|
1704
|
+
if (this.policy) {
|
|
1705
|
+
this.policy.document.addStatements(statement);
|
|
1706
|
+
return { statementAdded: true, policyDependable: this.policy };
|
|
1707
|
+
}
|
|
1708
|
+
return { statementAdded: false };
|
|
1709
|
+
}
|
|
1710
|
+
/**
|
|
1711
|
+
* Validate and modify Segment configuration for endpoint.
|
|
1712
|
+
*/
|
|
1713
|
+
segmentValidation(segmentContainerType, segment) {
|
|
1714
|
+
if (segment?.segmentDuration && (segment.segmentDuration?.toSeconds() < 1 || segment.segmentDuration?.toSeconds() > 30)) {
|
|
1715
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `SegmentDurationRange`, 'Segment Duration needs to be between 1-30 seconds.', this);
|
|
1716
|
+
}
|
|
1717
|
+
if (segmentContainerType != ContainerType.TS && (segment?.tsIncludeDvbSubtitles || segment?.tsUseAudioRenditionGroup)) {
|
|
1718
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `TsOptionsIncompatible`, 'Disable TS Segment options for DvbSubtitles and AudioRenditionGroups when using CMAF.', this);
|
|
1719
|
+
}
|
|
1720
|
+
return {
|
|
1721
|
+
includeIframeOnlyStreams: segment?.includeIframeOnlyStreams,
|
|
1722
|
+
segmentDurationSeconds: segment?.segmentDuration?.toSeconds(),
|
|
1723
|
+
segmentName: segment?.segmentName,
|
|
1724
|
+
tsIncludeDvbSubtitles: segment?.tsIncludeDvbSubtitles,
|
|
1725
|
+
tsUseAudioRenditionGroup: segment?.tsUseAudioRenditionGroup,
|
|
1726
|
+
scte: (segment?.scteFilter || segment?.scteInSegments) ? {
|
|
1727
|
+
scteFilter: segment?.scteFilter,
|
|
1728
|
+
scteInSegments: segment?.scteInSegments,
|
|
1729
|
+
} : undefined,
|
|
1730
|
+
encryption: segment?.encryption?._bind(this),
|
|
1731
|
+
};
|
|
1732
|
+
}
|
|
1733
|
+
/**
|
|
1734
|
+
* Create a CloudWatch metric.
|
|
1735
|
+
*
|
|
1736
|
+
* @param metricName name of the metric.
|
|
1737
|
+
* @param props metric options.
|
|
1738
|
+
*/
|
|
1739
|
+
metric(metricName, props) {
|
|
1740
|
+
return new aws_cloudwatch_1.Metric({
|
|
1741
|
+
metricName,
|
|
1742
|
+
namespace: 'AWS/MediaPackage',
|
|
1743
|
+
dimensionsMap: {
|
|
1744
|
+
ChannelGroup: this.channelGroupName,
|
|
1745
|
+
Channel: this.channelName,
|
|
1746
|
+
OriginEndpoint: this.originEndpointName,
|
|
1747
|
+
},
|
|
1748
|
+
...props,
|
|
1749
|
+
}).attachTo(this);
|
|
1750
|
+
}
|
|
1751
|
+
/**
|
|
1752
|
+
* Returns Metric for Ingress Bytes
|
|
1753
|
+
*
|
|
1754
|
+
* @default - sum over 60 seconds
|
|
1755
|
+
*/
|
|
1756
|
+
metricIngressBytes(props) {
|
|
1757
|
+
return this.metric('IngressBytes', {
|
|
1758
|
+
statistic: 'sum',
|
|
1759
|
+
period: aws_cdk_lib_1.Duration.seconds(60),
|
|
1760
|
+
unit: aws_cloudwatch_1.Unit.BYTES,
|
|
1761
|
+
...props,
|
|
1762
|
+
});
|
|
1763
|
+
}
|
|
1764
|
+
/**
|
|
1765
|
+
* Returns Metric for Egress Bytes
|
|
1766
|
+
*
|
|
1767
|
+
* @default - sum over 60 seconds
|
|
1768
|
+
*/
|
|
1769
|
+
metricEgressBytes(props) {
|
|
1770
|
+
return this.metric('EgressBytes', {
|
|
1771
|
+
statistic: 'sum',
|
|
1772
|
+
period: aws_cdk_lib_1.Duration.seconds(60),
|
|
1773
|
+
unit: aws_cloudwatch_1.Unit.BYTES,
|
|
1774
|
+
...props,
|
|
1775
|
+
});
|
|
1776
|
+
}
|
|
1777
|
+
/**
|
|
1778
|
+
* Returns Metric for Ingress response time
|
|
1779
|
+
*
|
|
1780
|
+
* @default - average over 60 seconds
|
|
1781
|
+
*/
|
|
1782
|
+
metricIngressResponseTime(props) {
|
|
1783
|
+
return this.metric('IngressResponseTime', {
|
|
1784
|
+
statistic: 'avg',
|
|
1785
|
+
period: aws_cdk_lib_1.Duration.seconds(60),
|
|
1786
|
+
unit: aws_cloudwatch_1.Unit.MILLISECONDS,
|
|
1787
|
+
...props,
|
|
1788
|
+
});
|
|
1789
|
+
}
|
|
1790
|
+
/**
|
|
1791
|
+
* Returns Metric for Egress Response time
|
|
1792
|
+
*
|
|
1793
|
+
* @default - average over 60 seconds
|
|
1794
|
+
*/
|
|
1795
|
+
metricEgressResponseTime(props) {
|
|
1796
|
+
return this.metric('EgressResponseTime', {
|
|
1797
|
+
statistic: 'avg',
|
|
1798
|
+
period: aws_cdk_lib_1.Duration.seconds(60),
|
|
1799
|
+
unit: aws_cloudwatch_1.Unit.MILLISECONDS,
|
|
1800
|
+
...props,
|
|
1801
|
+
});
|
|
1802
|
+
}
|
|
1803
|
+
/**
|
|
1804
|
+
* Returns Metric for Egress Request Count
|
|
1805
|
+
*
|
|
1806
|
+
* @default - sum over 60 seconds
|
|
1807
|
+
*/
|
|
1808
|
+
metricEgressRequestCount(props) {
|
|
1809
|
+
return this.metric('EgressRequestCount', {
|
|
1810
|
+
statistic: 'sum',
|
|
1811
|
+
period: aws_cdk_lib_1.Duration.seconds(60),
|
|
1812
|
+
unit: aws_cloudwatch_1.Unit.COUNT,
|
|
1813
|
+
...props,
|
|
1814
|
+
});
|
|
1815
|
+
}
|
|
1816
|
+
/**
|
|
1817
|
+
* Returns Metric for Ingress Request Count
|
|
1818
|
+
*
|
|
1819
|
+
* @default - sum over 60 seconds
|
|
1820
|
+
*/
|
|
1821
|
+
metricIngressRequestCount(props) {
|
|
1822
|
+
return this.metric('IngressRequestCount', {
|
|
1823
|
+
statistic: 'sum',
|
|
1824
|
+
period: aws_cdk_lib_1.Duration.seconds(60),
|
|
1825
|
+
unit: aws_cloudwatch_1.Unit.COUNT,
|
|
1826
|
+
...props,
|
|
1827
|
+
});
|
|
1828
|
+
}
|
|
1829
|
+
}
|
|
1830
|
+
/**
|
|
1831
|
+
* Defines an AWS Elemental MediaPackage V2 Origin Endpoint
|
|
1832
|
+
*/
|
|
1833
|
+
let OriginEndpoint = (() => {
|
|
1834
|
+
let _classDecorators = [prop_injectable_1.propertyInjectable];
|
|
1835
|
+
let _classDescriptor;
|
|
1836
|
+
let _classExtraInitializers = [];
|
|
1837
|
+
let _classThis;
|
|
1838
|
+
let _classSuper = OriginEndpointBase;
|
|
1839
|
+
var OriginEndpoint = class extends _classSuper {
|
|
1840
|
+
static { _classThis = this; }
|
|
1841
|
+
static {
|
|
1842
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
1843
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
1844
|
+
OriginEndpoint = _classThis = _classDescriptor.value;
|
|
1845
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
1846
|
+
}
|
|
1847
|
+
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-mediapackagev2-alpha.OriginEndpoint", version: "2.247.0-alpha.0" };
|
|
1848
|
+
/** Uniquely identifies this class. */
|
|
1849
|
+
static PROPERTY_INJECTION_ID = '@aws-cdk.aws-mediapackagev2-alpha.OriginEndpoint';
|
|
1850
|
+
channelGroupName;
|
|
1851
|
+
channelName;
|
|
1852
|
+
originEndpointName;
|
|
1853
|
+
originEndpointArn;
|
|
1854
|
+
/**
|
|
1855
|
+
* The timestamp of the creation of the origin endpoint.
|
|
1856
|
+
*/
|
|
1857
|
+
createdAt;
|
|
1858
|
+
/**
|
|
1859
|
+
* The timestamp of the modification of the origin endpoint.
|
|
1860
|
+
*/
|
|
1861
|
+
modifiedAt;
|
|
1862
|
+
/**
|
|
1863
|
+
* Array containing Low Latency HLS Manifests created by the OriginEndpoint.
|
|
1864
|
+
*/
|
|
1865
|
+
lowLatencyHlsManifestUrls;
|
|
1866
|
+
/**
|
|
1867
|
+
* Array containing HLS Manifests created by the OriginEndpoint.
|
|
1868
|
+
*/
|
|
1869
|
+
hlsManifestUrls;
|
|
1870
|
+
/**
|
|
1871
|
+
* Array containing DASH Manifests created by the OriginEndpoint.
|
|
1872
|
+
*/
|
|
1873
|
+
dashManifestUrls;
|
|
1874
|
+
/**
|
|
1875
|
+
* Array containing MSS Manifests created by the OriginEndpoint.
|
|
1876
|
+
*/
|
|
1877
|
+
mssManifestUrls;
|
|
1878
|
+
/**
|
|
1879
|
+
* The resource policy associated with this origin endpoint.
|
|
1880
|
+
*
|
|
1881
|
+
* If `autoCreatePolicy` is true, an `OriginEndpointPolicy` will be created upon the
|
|
1882
|
+
* first call to addToResourcePolicy(s).
|
|
1883
|
+
*/
|
|
1884
|
+
policy;
|
|
1885
|
+
autoCreatePolicy = true;
|
|
1886
|
+
hlsManifests = [];
|
|
1887
|
+
llHlsManifests = [];
|
|
1888
|
+
dashManifests = [];
|
|
1889
|
+
mssManifests = [];
|
|
1890
|
+
segment;
|
|
1891
|
+
constructor(scope, id, props) {
|
|
1892
|
+
super(scope, id, {
|
|
1893
|
+
physicalName: props?.originEndpointName ?? aws_cdk_lib_1.Lazy.string({
|
|
1894
|
+
produce: () => aws_cdk_lib_1.Names.uniqueResourceName(this, {
|
|
1895
|
+
maxLength: 256,
|
|
1896
|
+
}),
|
|
1897
|
+
}),
|
|
1898
|
+
});
|
|
1899
|
+
try {
|
|
1900
|
+
jsiiDeprecationWarnings._aws_cdk_aws_mediapackagev2_alpha_OriginEndpointProps(props);
|
|
1901
|
+
}
|
|
1902
|
+
catch (error) {
|
|
1903
|
+
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
|
1904
|
+
Error.captureStackTrace(error, OriginEndpoint);
|
|
1905
|
+
}
|
|
1906
|
+
throw error;
|
|
1907
|
+
}
|
|
1908
|
+
// Enhanced CDK Analytics Telemetry
|
|
1909
|
+
(0, metadata_resource_1.addConstructMetadata)(this, props);
|
|
1910
|
+
// Validate originEndpointName if provided
|
|
1911
|
+
if (props.originEndpointName != null && !aws_cdk_lib_1.Token.isUnresolved(props.originEndpointName)) {
|
|
1912
|
+
if (props.originEndpointName.length < 1 || props.originEndpointName.length > 256) {
|
|
1913
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `OriginEndpointNameLength`, 'Origin endpoint name must be between 1 and 256 characters in length.', this);
|
|
1914
|
+
}
|
|
1915
|
+
if (!props.originEndpointName.match(/^[a-zA-Z0-9_-]+$/)) {
|
|
1916
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `OriginEndpointNamePattern`, 'Origin endpoint name must only contain alphanumeric characters, hyphens, and underscores.', this);
|
|
1917
|
+
}
|
|
1918
|
+
}
|
|
1919
|
+
// Validate description if provided
|
|
1920
|
+
if (props.description && !aws_cdk_lib_1.Token.isUnresolved(props.description) && props.description.length > 1024) {
|
|
1921
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `OriginEndpointDescriptionLength`, 'Origin endpoint description must not exceed 1024 characters.', this);
|
|
1922
|
+
}
|
|
1923
|
+
this.segment = props.segment;
|
|
1924
|
+
// Get container type from segment
|
|
1925
|
+
const containerType = props.segment.containerType;
|
|
1926
|
+
if (props?.startoverWindow && (props.startoverWindow.toSeconds() < 60 || props.startoverWindow.toSeconds() > 1209600)) {
|
|
1927
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `StartoverWindowRange`, 'Startover Window needs to be between 60-1209600 seconds.', this);
|
|
1928
|
+
}
|
|
1929
|
+
props.manifests.forEach(manifest => {
|
|
1930
|
+
manifest._bind({
|
|
1931
|
+
hlsManifests: this.hlsManifests,
|
|
1932
|
+
llHlsManifests: this.llHlsManifests,
|
|
1933
|
+
dashManifests: this.dashManifests,
|
|
1934
|
+
mssManifests: this.mssManifests,
|
|
1935
|
+
segment: props.segment,
|
|
1936
|
+
});
|
|
1937
|
+
});
|
|
1938
|
+
// Validate manifest and container type compatibility
|
|
1939
|
+
if (this.mssManifests.length > 0 && containerType !== ContainerType.ISM) {
|
|
1940
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `MssRequiresIsm`, 'MSS manifests require ISM container type. Use Segment.ism() for MSS manifests.', this);
|
|
1941
|
+
}
|
|
1942
|
+
if (this.dashManifests.length > 0 && containerType !== ContainerType.CMAF) {
|
|
1943
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `DashRequiresCmaf`, 'DASH manifests require CMAF container type. Use Segment.cmaf() for DASH manifests.', this);
|
|
1944
|
+
}
|
|
1945
|
+
if ((this.hlsManifests.length > 0 || this.llHlsManifests.length > 0) && containerType === ContainerType.ISM) {
|
|
1946
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `HlsIncompatibleWithIsm`, 'HLS and Low Latency HLS manifests are not supported with ISM container type. Use Segment.cmaf() or Segment.ts() for HLS manifests.', this);
|
|
1947
|
+
}
|
|
1948
|
+
// Validate DRM signalling requires encryption
|
|
1949
|
+
if (this.dashManifests.some(m => m.drmSignaling) && !props.segment.encryption) {
|
|
1950
|
+
throw new core_1.ValidationError((0, helpers_internal_1.lit) `DrmSignallingRequiresEncryption`, 'DRM signalling requires encryption to be configured on the endpoint.', this);
|
|
1951
|
+
}
|
|
1952
|
+
const origin = new aws_mediapackagev2_1.CfnOriginEndpoint(this, 'Resource', {
|
|
1953
|
+
channelName: props.channel.channelName,
|
|
1954
|
+
channelGroupName: props.channel.channelGroupName,
|
|
1955
|
+
originEndpointName: this.physicalName,
|
|
1956
|
+
description: props.description,
|
|
1957
|
+
tags: props?.tags ? (0, shared_helpers_1.renderTags)(props.tags) : undefined,
|
|
1958
|
+
hlsManifests: aws_cdk_lib_1.Lazy.any({ produce: () => this.hlsManifests }, { omitEmptyArray: true }),
|
|
1959
|
+
lowLatencyHlsManifests: aws_cdk_lib_1.Lazy.any({ produce: () => this.llHlsManifests }, { omitEmptyArray: true }),
|
|
1960
|
+
dashManifests: aws_cdk_lib_1.Lazy.any({ produce: () => this.dashManifests }, { omitEmptyArray: true }),
|
|
1961
|
+
mssManifests: aws_cdk_lib_1.Lazy.any({ produce: () => this.mssManifests }, { omitEmptyArray: true }),
|
|
1962
|
+
containerType: containerType,
|
|
1963
|
+
startoverWindowSeconds: props.startoverWindow?.toSeconds(),
|
|
1964
|
+
segment: this.segmentValidation(containerType, props.segment),
|
|
1965
|
+
forceEndpointErrorConfiguration: props.forceEndpointConfigurationConditions ? {
|
|
1966
|
+
endpointErrorConditions: props.forceEndpointConfigurationConditions,
|
|
1967
|
+
} : undefined,
|
|
1968
|
+
});
|
|
1969
|
+
// The channelName/channelGroupName are rendered as literal strings (not CFN Refs), so
|
|
1970
|
+
// CloudFormation cannot infer the dependency. We add direct CfnResource-level DependsOn
|
|
1971
|
+
// to guarantee deploy ordering without triggering CDK's subtree-level cycle detection.
|
|
1972
|
+
// For imported constructs, defaultChild is undefined (no CFN resource to order against).
|
|
1973
|
+
const encryptionRole = props.segment.encryption?._getRole();
|
|
1974
|
+
if (encryptionRole)
|
|
1975
|
+
origin.node.addDependency(encryptionRole);
|
|
1976
|
+
const encryptionCert = props.segment.encryption?._getCertificate();
|
|
1977
|
+
if (encryptionCert)
|
|
1978
|
+
origin.node.addDependency(encryptionCert);
|
|
1979
|
+
const channelCfn = props.channel.node.defaultChild;
|
|
1980
|
+
if (channelCfn && core_1.CfnResource.isCfnResource(channelCfn)) {
|
|
1981
|
+
origin.addDependency(channelCfn);
|
|
1982
|
+
}
|
|
1983
|
+
const groupCfn = props.channel.channelGroup?.node.defaultChild;
|
|
1984
|
+
if (groupCfn && core_1.CfnResource.isCfnResource(groupCfn)) {
|
|
1985
|
+
origin.addDependency(groupCfn);
|
|
1986
|
+
}
|
|
1987
|
+
this.lowLatencyHlsManifestUrls = this.llHlsManifests.map((_, i) => aws_cdk_lib_1.Fn.select(i, origin.attrLowLatencyHlsManifestUrls));
|
|
1988
|
+
this.hlsManifestUrls = this.hlsManifests.map((_, i) => aws_cdk_lib_1.Fn.select(i, origin.attrHlsManifestUrls));
|
|
1989
|
+
this.dashManifestUrls = this.dashManifests.map((_, i) => aws_cdk_lib_1.Fn.select(i, origin.attrDashManifestUrls));
|
|
1990
|
+
this.mssManifestUrls = this.mssManifests.map((_, i) => aws_cdk_lib_1.Fn.select(i, origin.attrMssManifestUrls));
|
|
1991
|
+
this.createdAt = origin.attrCreatedAt;
|
|
1992
|
+
this.modifiedAt = origin.attrModifiedAt;
|
|
1993
|
+
this.channelGroupName = origin.channelGroupName;
|
|
1994
|
+
this.channelName = origin.channelName;
|
|
1995
|
+
this.originEndpointName = origin.originEndpointName;
|
|
1996
|
+
this.originEndpointArn = origin.attrArn;
|
|
1997
|
+
origin.applyRemovalPolicy(props?.removalPolicy ?? aws_cdk_lib_1.RemovalPolicy.DESTROY);
|
|
1998
|
+
// Pre-set CDN auth config if provided in props
|
|
1999
|
+
if (props.cdnAuth) {
|
|
2000
|
+
this._setCdnAuth(props.cdnAuth);
|
|
2001
|
+
}
|
|
2002
|
+
}
|
|
2003
|
+
static {
|
|
2004
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
2005
|
+
}
|
|
2006
|
+
};
|
|
2007
|
+
return OriginEndpoint = _classThis;
|
|
2008
|
+
})();
|
|
2009
|
+
exports.OriginEndpoint = OriginEndpoint;
|
|
2010
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"endpoint.js","sourceRoot":"","sources":["endpoint.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Bitrate, IResource } from 'aws-cdk-lib';\nimport { RemovalPolicy, ArnFormat, Duration, Fn, Lazy, Names, Resource, Stack, Token } from 'aws-cdk-lib';\nimport type { ICertificate } from 'aws-cdk-lib/aws-certificatemanager';\nimport type { MetricOptions } from 'aws-cdk-lib/aws-cloudwatch';\nimport { Metric, Unit } from 'aws-cdk-lib/aws-cloudwatch';\nimport type { IRole, PolicyStatement, AddToResourcePolicyResult } from 'aws-cdk-lib/aws-iam';\nimport { CfnOriginEndpoint } from 'aws-cdk-lib/aws-mediapackagev2';\nimport type { IOriginEndpointRef, OriginEndpointReference } from 'aws-cdk-lib/aws-mediapackagev2';\nimport { ValidationError, UnscopedValidationError, CfnResource } from 'aws-cdk-lib/core';\nimport { lit } from 'aws-cdk-lib/core/lib/helpers-internal';\nimport { addConstructMetadata } from 'aws-cdk-lib/core/lib/metadata-resource';\nimport { propertyInjectable } from 'aws-cdk-lib/core/lib/prop-injectable';\nimport type { Construct } from 'constructs';\nimport type { IChannel } from './channel';\nimport type { CdnAuthConfiguration } from './origin-endpoint-policy';\nimport { OriginEndpointPolicy } from './origin-endpoint-policy';\nimport { convertDateToString, renderTags } from './shared-helpers';\n\n/**\n * Accepted audio codec values for manifest filtering.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum AudioCodec {\n  /** AAC-LC audio codec */\n  AACL = 'AACL',\n  /** HE-AAC audio codec */\n  AACH = 'AACH',\n  /** Dolby Digital audio codec (include the hyphen) */\n  AC_3 = 'AC-3',\n  /** Dolby Digital Plus audio codec (include the hyphen) */\n  EC_3 = 'EC-3',\n}\n\n/**\n * Accepted video codec values for manifest filtering.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum VideoCodec {\n  /** H.264/AVC */\n  H264 = 'H264',\n  /** H.265/HEVC */\n  H265 = 'H265',\n  /** AV1 */\n  AV1 = 'AV1',\n}\n\n/**\n * Accepted video dynamic range values for manifest filtering.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum VideoDynamicRange {\n  /** Dolby Vision */\n  DV = 'dv',\n  /** HDR10 */\n  HDR10 = 'hdr10',\n  /** Hybrid Log-Gamma */\n  HLG = 'hlg',\n  /** Standard Dynamic Range */\n  SDR = 'sdr',\n}\n\n/**\n * Accepted trickplay type values for manifest filtering.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum TrickplayType {\n  /** I-frame only trick-play */\n  IFRAME = 'iframe',\n  /** Image-based trick-play */\n  IMAGE = 'image',\n  /** No trick-play */\n  NONE = 'none',\n}\n\n/**\n * Numeric manifest filter keys.\n *\n * Use with `ManifestFilter.numeric()`, `ManifestFilter.numericList()`, and `ManifestFilter.numericRange()`.\n *\n * Audio and video bitrate filters are not included here because they use the\n * `Bitrate` class directly via dedicated methods on `ManifestFilter`.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum NumericFilterKey {\n  /**\n   * The number of audio channels.\n   *\n   * Accepted values: range 1–32767, or individual integers.\n   */\n  AUDIO_CHANNELS='audio_channels',\n  /**\n   * The audio sample rate in Hz.\n   *\n   * Accepted values: range 0–2147483647, or individual integers.\n   */\n  AUDIO_SAMPLE_RATE='audio_sample_rate',\n  /**\n   * The height of the trick-play image in pixels (I-frame and image-based trick-play).\n   *\n   * If using with I-frame only trick-play, `TRICKPLAY_HEIGHT` and `VIDEO_HEIGHT`\n   * should have similar values. If they differ, I-frame only tracks might be\n   * removed from the manifest.\n   *\n   * Accepted values: range 1–2147483647, or individual integers.\n   */\n  TRICKPLAY_HEIGHT='trickplay_height',\n  /**\n   * The video frame rate range in NTSC format.\n   *\n   * When filtering for a single value, MediaPackage uses an approximate equals\n   * comparison with an epsilon tolerance of 0.0005.\n   *\n   * Accepted values: range 1–999.999 (up to three decimal places), or individual values.\n   */\n  VIDEO_FRAMERATE='video_framerate',\n  /**\n   * The height of the video in pixels.\n   *\n   * If using with I-frame only trick-play, `TRICKPLAY_HEIGHT` and `VIDEO_HEIGHT`\n   * should have similar values. If they differ, I-frame only tracks might be\n   * removed from the manifest.\n   *\n   * Accepted values: range 1–32767, or individual integers.\n   */\n  VIDEO_HEIGHT='video_height',\n}\n\n/**\n * Text manifest filter keys for free-form string values.\n *\n * Use with `ManifestFilter.text()` and `ManifestFilter.textList()`.\n *\n * For keys with fixed accepted values, use the dedicated methods on `ManifestFilter` instead:\n * - Audio codec: `ManifestFilter.audioCodec()` / `ManifestFilter.audioCodecList()`\n * - Video codec: `ManifestFilter.videoCodec()` / `ManifestFilter.videoCodecList()`\n * - Video dynamic range: `ManifestFilter.videoDynamicRange()` / `ManifestFilter.videoDynamicRangeList()`\n * - Trickplay type: `ManifestFilter.trickplayType()` / `ManifestFilter.trickplayTypeList()`\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum TextFilterKey {\n  /**\n   * Audio languages or functional codes derived from encoder passthrough.\n   *\n   * Accepted values: arbitrary strings such as ISO-639-1 language codes (not case-sensitive).\n   */\n  AUDIO_LANGUAGE='audio_language',\n  /**\n   * The subtitle language or functional codes derived from encoder passthrough.\n   *\n   * Accepted values: arbitrary strings such as ISO-639-1 language codes (not case-sensitive).\n   */\n  SUBTITLE_LANGUAGE='subtitle_language',\n}\n\n/**\n * Bitrate manifest filter keys.\n *\n * Use with `ManifestFilter.bitrate()` and `ManifestFilter.bitrateRange()`.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n */\nexport enum BitrateFilterKey {\n  /**\n   * The audio bitrate in bits per second.\n   *\n   * Accepted values: range 0–2147483647, or individual integers.\n   */\n  AUDIO_BITRATE='audio_bitrate',\n  /**\n   * The video bitrate in bits per second.\n   *\n   * We recommend using only this filter parameter to set the video bitrate.\n   * Do not also set the minimum and maximum video bitrate via the MediaPackage\n   * console or AWS CLI, as your output might be skewed.\n   *\n   * This parameter cannot be used with trick-play streams.\n   *\n   * Accepted values: range 0–2147483647, or individual integers.\n   */\n  VIDEO_BITRATE='video_bitrate',\n}\n\n/**\n * Represents a numeric filter expression segment — either a single value or a range.\n *\n * Use with `ManifestFilter.numericCombo()` to build filters that combine\n * ranges and individual values (e.g. `video_height:240-360,720-1080,1440`).\n */\nexport class NumericExpression {\n  /**\n   * A single numeric value.\n   */\n  public static value(v: number): NumericExpression {\n    return new NumericExpression(`${v}`, [v]);\n  }\n\n  /**\n   * An inclusive numeric range.\n   */\n  public static range(start: number, end: number): NumericExpression {\n    return new NumericExpression(`${start}-${end}`, [start, end]);\n  }\n\n  protected constructor(\n    /** @internal */\n    public readonly _expression: string,\n    /** @internal */\n    public readonly _values: number[],\n  ) {}\n}\n\n/**\n * Represents a bitrate filter expression segment — either a single value or a range.\n *\n * Use with `ManifestFilter.bitrateCombo()` to build filters that combine\n * ranges and individual bitrate values.\n */\nexport class BitrateExpression {\n  /**\n   * A single bitrate value.\n   */\n  public static value(v: Bitrate): BitrateExpression {\n    return new BitrateExpression(`${v.toBps()}`, [v.toBps()]);\n  }\n\n  /**\n   * An inclusive bitrate range.\n   */\n  public static range(start: Bitrate, end: Bitrate): BitrateExpression {\n    return new BitrateExpression(`${start.toBps()}-${end.toBps()}`, [start.toBps(), end.toBps()]);\n  }\n\n  protected constructor(\n    /** @internal */\n    public readonly _expression: string,\n    /** @internal */\n    public readonly _values: number[],\n  ) {}\n}\n\n/**\n * Enables you to create filters for your Origin Endpoint.\n *\n * @see https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filtering.html\n */\nexport class ManifestFilter {\n  /**\n   * Filter by a single bitrate value.\n   */\n  public static bitrate(key: BitrateFilterKey, value: Bitrate) {\n    const bps = value.toBps();\n    validateBitrateFilterValue(bps, key);\n    return new ManifestFilter(`${key}:${bps}`);\n  }\n\n  /**\n   * Filter by a bitrate range (inclusive).\n   */\n  public static bitrateRange(key: BitrateFilterKey, start: Bitrate, end: Bitrate) {\n    const startBps = start.toBps();\n    const endBps = end.toBps();\n    validateBitrateFilterValue(startBps, key);\n    validateBitrateFilterValue(endBps, key);\n    return new ManifestFilter(`${key}:${startBps}-${endBps}`);\n  }\n\n  /**\n   * Specify a single numeric filter value.\n   */\n  public static numeric(key: NumericFilterKey, value: number) {\n    validateNumericFilterValue(value, key);\n    return new ManifestFilter(`${key}:${value}`);\n  }\n\n  /**\n   * Specify multiple numeric filter values.\n   */\n  public static numericList(key: NumericFilterKey, values: number[]) {\n    values.forEach(v => validateNumericFilterValue(v, key));\n    return new ManifestFilter(`${key}:${values.join(',')}`);\n  }\n\n  /**\n   * Specify a numeric filter range (inclusive).\n   */\n  public static numericRange(key: NumericFilterKey, start: number, end: number) {\n    validateNumericFilterValue(start, key);\n    validateNumericFilterValue(end, key);\n    return new ManifestFilter(`${key}:${start}-${end}`);\n  }\n\n  /**\n   * Specify a free-form text filter value (for language keys).\n   */\n  public static text(key: TextFilterKey, value: string) {\n    return new ManifestFilter(`${key}:${value}`);\n  }\n\n  /**\n   * Specify multiple free-form text filter values (for language keys).\n   */\n  public static textList(key: TextFilterKey, values: string[]) {\n    return new ManifestFilter(`${key}:${values.join(',')}`);\n  }\n\n  /**\n   * Filter by a single audio codec.\n   */\n  public static audioCodec(value: AudioCodec) {\n    return new ManifestFilter(`audio_codec:${value}`);\n  }\n\n  /**\n   * Filter by multiple audio codecs.\n   */\n  public static audioCodecList(values: AudioCodec[]) {\n    return new ManifestFilter(`audio_codec:${values.join(',')}`);\n  }\n\n  /**\n   * Filter by a single video codec.\n   */\n  public static videoCodec(value: VideoCodec) {\n    return new ManifestFilter(`video_codec:${value}`);\n  }\n\n  /**\n   * Filter by multiple video codecs.\n   */\n  public static videoCodecList(values: VideoCodec[]) {\n    return new ManifestFilter(`video_codec:${values.join(',')}`);\n  }\n\n  /**\n   * Filter by a single video dynamic range.\n   */\n  public static videoDynamicRange(value: VideoDynamicRange) {\n    return new ManifestFilter(`video_dynamic_range:${value}`);\n  }\n\n  /**\n   * Filter by multiple video dynamic ranges.\n   */\n  public static videoDynamicRangeList(values: VideoDynamicRange[]) {\n    return new ManifestFilter(`video_dynamic_range:${values.join(',')}`);\n  }\n\n  /**\n   * Filter by a single trickplay type.\n   */\n  public static trickplayType(value: TrickplayType) {\n    return new ManifestFilter(`trickplay_type:${value}`);\n  }\n\n  /**\n   * Filter by multiple trickplay types.\n   */\n  public static trickplayTypeList(values: TrickplayType[]) {\n    return new ManifestFilter(`trickplay_type:${values.join(',')}`);\n  }\n\n  /**\n   * Filter by a combination of numeric ranges and individual values.\n   *\n   * Use this for advanced patterns like `video_height:240-360,720-1080,1440`.\n   *\n   * @example\n   * ManifestFilter.numericCombo(NumericFilterKey.VIDEO_HEIGHT, [\n   *   NumericExpression.range(240, 360),\n   *   NumericExpression.range(720, 1080),\n   *   NumericExpression.value(1440),\n   * ])\n   */\n  public static numericCombo(key: NumericFilterKey, expressions: NumericExpression[]) {\n    expressions.forEach(expr => expr._values.forEach(v => validateNumericFilterValue(v, key)));\n    return new ManifestFilter(`${key}:${expressions.map(e => e._expression).join(',')}`);\n  }\n\n  /**\n   * Filter by a combination of bitrate ranges and individual values.\n   *\n   * @example\n   * ManifestFilter.bitrateCombo(BitrateFilterKey.VIDEO_BITRATE, [\n   *   BitrateExpression.range(Bitrate.mbps(1), Bitrate.mbps(3)),\n   *   BitrateExpression.value(Bitrate.mbps(5)),\n   * ])\n   */\n  public static bitrateCombo(key: BitrateFilterKey, expressions: BitrateExpression[]) {\n    expressions.forEach(expr => expr._values.forEach(v => validateBitrateFilterValue(v, key)));\n    return new ManifestFilter(`${key}:${expressions.map(e => e._expression).join(',')}`);\n  }\n\n  /**\n   * Specify a custom manifest filter string.\n   */\n  public static custom(custom: string) {\n    return new ManifestFilter(custom);\n  }\n\n  /**\n   * @param filterString Normalised manifest filter string\n   */\n  protected constructor(public readonly filterString: string) { }\n}\n\n/**\n * Context passed to Manifest._bind() method\n * @internal\n */\nexport interface ManifestBindContext {\n  readonly hlsManifests: CfnOriginEndpoint.HlsManifestConfigurationProperty[];\n  readonly llHlsManifests: CfnOriginEndpoint.LowLatencyHlsManifestConfigurationProperty[];\n  readonly dashManifests: CfnOriginEndpoint.DashManifestConfigurationProperty[];\n  readonly mssManifests: CfnOriginEndpoint.MssManifestConfigurationProperty[];\n  readonly segment?: SegmentConfiguration;\n}\n\n/**\n * Manifest to add to Origin Endpoint\n */\nexport abstract class Manifest {\n  /**\n   * Specify a manifest configuration for Low Latency HLS.\n   *\n   * **Note:** Low Latency HLS manifests require TS or CMAF container type.\n   * Use with `Segment.ts()` or `Segment.cmaf()`.\n   */\n  public static lowLatencyHLS(manifest: LowLatencyHlsManifestConfiguration): Manifest {\n    return new LowLatencyHlsManifest(manifest);\n  }\n\n  /**\n   * Specify a manifest configuration for HLS.\n   *\n   * **Note:** HLS manifests require TS or CMAF container type.\n   * Use with `Segment.ts()` or `Segment.cmaf()`.\n   */\n  public static hls(manifest: HlsManifestConfiguration): Manifest {\n    return new HlsManifest(manifest);\n  }\n\n  /**\n   * Specify a manifest configuration for DASH.\n   *\n   * **Note:** DASH manifests require CMAF container type.\n   * Use with `Segment.cmaf()`.\n   */\n  public static dash(manifest: DashManifestConfiguration): Manifest {\n    return new DashManifest(manifest);\n  }\n\n  /**\n   * Specify a manifest configuration for MSS.\n   *\n   * **Note:** MSS manifests require ISM container type.\n   * Use with `Segment.ism()`.\n   */\n  public static mss(manifest: MssManifestConfiguration): Manifest {\n    return new MssManifest(manifest);\n  }\n\n  /**\n   * Called when the manifest is bound to an OriginEndpoint.\n   *\n   * This is an internal method used by the construct library and should not be\n   * called or implemented by external consumers. It may change without notice.\n   *\n   * @internal\n   */\n  public abstract _bind(context: ManifestBindContext): void;\n}\n\n/**\n * Validate a numeric filter value is an integer within the accepted range for its key.\n * VIDEO_FRAMERATE is excluded — it uses `validateFramerateValue` instead.\n * @internal\n */\nfunction validateIntegerFilterValue(value: number, key: NumericFilterKey, min: number, max: number): void {\n  if (!Number.isInteger(value)) {\n    throw new UnscopedValidationError(lit`NumericFilterMustBeInteger`, `Numeric filter value for '${key}' must be an integer, got ${value}`);\n  }\n  if (value < min || value > max) {\n    throw new UnscopedValidationError(lit`NumericFilterOutOfRange`, `Numeric filter value for '${key}' must be between ${min} and ${max}, got ${value}`);\n  }\n}\n\n/**\n * Validate a video framerate filter value (1–999.999, up to 3 decimal places).\n * @internal\n */\nfunction validateFramerateValue(value: number): void {\n  if (value < 1 || value > 999.999) {\n    throw new UnscopedValidationError(lit`NumericFilterOutOfRange`, `Numeric filter value for 'video_framerate' must be between 1 and 999.999, got ${value}`);\n  }\n  const decimalPart = value.toString().split('.')[1];\n  if (decimalPart && decimalPart.length > 3) {\n    throw new UnscopedValidationError(lit`NumericFilterMaxDecimalPlaces`, `Numeric filter value for 'video_framerate' allows up to 3 decimal places, got ${value}`);\n  }\n}\n\n/**\n * Route numeric validation to the correct helper based on key.\n * @internal\n */\nfunction validateNumericFilterValue(value: number, key: NumericFilterKey): void {\n  switch (key) {\n    case NumericFilterKey.AUDIO_CHANNELS:\n      return validateIntegerFilterValue(value, key, 1, 32_767);\n    case NumericFilterKey.AUDIO_SAMPLE_RATE:\n      return validateIntegerFilterValue(value, key, 0, 2_147_483_647);\n    case NumericFilterKey.TRICKPLAY_HEIGHT:\n      return validateIntegerFilterValue(value, key, 1, 2_147_483_647);\n    case NumericFilterKey.VIDEO_FRAMERATE:\n      return validateFramerateValue(value);\n    case NumericFilterKey.VIDEO_HEIGHT:\n      return validateIntegerFilterValue(value, key, 1, 32_767);\n  }\n}\n\n/**\n * Validate a bitrate filter value is an integer within the accepted range.\n * @internal\n */\nfunction validateBitrateFilterValue(bps: number, key: BitrateFilterKey): void {\n  if (!Number.isInteger(bps)) {\n    throw new UnscopedValidationError(lit`BitrateFilterMustBeInteger`, `Bitrate filter value for '${key}' must resolve to a whole number of bits per second, got ${bps}`);\n  }\n  if (bps < 0 || bps > 2_147_483_647) {\n    throw new UnscopedValidationError(lit`BitrateFilterOutOfRange`, `Bitrate filter value for '${key}' must be between 0 and 2147483647, got ${bps}`);\n  }\n}\n\n/**\n * Validates common manifest configuration properties\n */\nfunction validateManifestConfiguration(config: ManifestConfigurationBase): void {\n  if (config.manifestWindow && config.manifestWindow.toSeconds() < 30) {\n    throw new UnscopedValidationError(lit`ManifestWindowMinimum`, 'Manifest Window has a minimum value of 30 seconds');\n  }\n}\n\n/**\n * Validate and modify filter configuration\n * @internal\n */\nfunction validateFilterConfiguration(filterConfig?: FilterConfiguration): CfnOriginEndpoint.FilterConfigurationProperty | undefined {\n  if (!filterConfig) return undefined;\n\n  if (filterConfig.clipStartTime && (filterConfig.start || filterConfig.end)) {\n    throw new UnscopedValidationError(lit`ClipStartTimeConflict`, 'You cannot specify both ClipStartTime with Start or End in a FilterConfiguration.');\n  }\n\n  if (filterConfig.timeDelay && (filterConfig.timeDelay.toSeconds() < 0 || filterConfig.timeDelay.toSeconds() > 1209600)) {\n    throw new UnscopedValidationError(lit`TimeDelayRange`, 'Time Delay setting should be defined between 0-1209600 seconds.');\n  }\n\n  if (filterConfig.start && filterConfig.end && (filterConfig.end <= filterConfig.start)) {\n    throw new UnscopedValidationError(lit`EndBeforeStart`, 'The End parameter needs to be after the Start parameter in a FilterConfiguration.');\n  }\n\n  const manifestFilter = filterConfig.manifestFilter ? filterConfig.manifestFilter.map(filter => filter.filterString).join(';') : undefined;\n  if (manifestFilter != undefined && (manifestFilter.length < 1 || manifestFilter.length > 1024)) {\n    throw new UnscopedValidationError(lit`ManifestFilterLength`, 'Manifest filter needs to be between 1-1024 characters in length.');\n  }\n\n  if (filterConfig.manifestFilter && filterConfig.manifestFilter.length > 1) {\n    const keys = filterConfig.manifestFilter.map(f => f.filterString.split(':')[0]);\n    keys.forEach((key, i) => {\n      if (keys.indexOf(key) !== i) {\n        throw new UnscopedValidationError(lit`DuplicateManifestFilterKey`, `Duplicate manifest filter key '${key}'. Use a single filter with comma-separated values instead (e.g. ManifestFilter.numericList() or ManifestFilter.custom()).`);\n      }\n    });\n  }\n\n  return {\n    manifestFilter,\n    drmSettings: filterConfig.drmSettings ? filterConfig.drmSettings.filter((v, i, a) => a.indexOf(v) === i).join(';') : undefined,\n    clipStartTime: filterConfig.clipStartTime ? convertDateToString(filterConfig.clipStartTime) : undefined,\n    start: filterConfig.start ? convertDateToString(filterConfig.start) : undefined,\n    end: filterConfig.end ? convertDateToString(filterConfig.end) : undefined,\n    timeDelaySeconds: filterConfig.timeDelay?.toSeconds(),\n  };\n}\n\n/**\n * Validate startTag configuration\n * @internal\n */\nfunction validateStartTag(startTag: StartTag, manifestWindow?: Duration, segmentDuration?: Duration): void {\n  const timeOffset = startTag.timeOffset;\n\n  // Get segment duration (default is 6 seconds if not specified)\n  const segmentDurationSec = segmentDuration?.toSeconds() ?? 6;\n\n  // Get manifest duration (default is 60 seconds if not specified)\n  const manifestDurationSec = manifestWindow?.toSeconds() ?? 60;\n\n  // Validate positive offset (from start)\n  if (timeOffset > 0) {\n    const maxPositiveOffset = manifestDurationSec - (3 * segmentDurationSec);\n    if (timeOffset >= maxPositiveOffset) {\n      throw new UnscopedValidationError(lit`StartTagPositiveOffsetExceeded`, `StartTag timeOffset (${timeOffset}s) must be less than manifest duration (${manifestDurationSec}s) minus 3 times segment duration (${segmentDurationSec}s). Maximum allowed: ${maxPositiveOffset}s`);\n    }\n  }\n\n  // Validate negative offset (from live edge)\n  if (timeOffset < 0) {\n    const absOffset = Math.abs(timeOffset);\n    const minNegativeOffset = 3 * segmentDurationSec;\n\n    if (absOffset <= minNegativeOffset) {\n      throw new UnscopedValidationError(lit`StartTagNegativeOffsetTooSmall`, `StartTag timeOffset (${timeOffset}s) absolute value must be greater than 3 times segment duration (${segmentDurationSec}s). Minimum allowed: -${minNegativeOffset + 0.01}s`);\n    }\n\n    if (absOffset >= manifestDurationSec) {\n      throw new UnscopedValidationError(lit`StartTagNegativeOffsetExceedsManifest`, `StartTag timeOffset (${timeOffset}s) absolute value must be less than manifest duration (${manifestDurationSec}s)`);\n    }\n  }\n}\n\n/**\n * Build HLS manifest configuration\n * @internal\n */\nfunction buildHlsManifestConfiguration(\n  config: HlsManifestConfiguration,\n  segmentDuration?: Duration,\n): CfnOriginEndpoint.HlsManifestConfigurationProperty {\n  if (config.startTag) {\n    validateStartTag(config.startTag, config.manifestWindow, segmentDuration);\n  }\n\n  return {\n    manifestName: config.manifestName,\n    childManifestName: config.childManifestName,\n    manifestWindowSeconds: config.manifestWindow?.toSeconds(),\n    programDateTimeIntervalSeconds: config.programDateTimeInterval?.toSeconds(),\n    scteHls: config.scteAdMarkerHls ? { adMarkerHls: config.scteAdMarkerHls } : undefined,\n    startTag: config.startTag,\n    urlEncodeChildManifest: config.urlEncodeChildManifest,\n    filterConfiguration: validateFilterConfiguration(config.filterConfiguration),\n  };\n}\n\n/**\n * Build DASH manifest configuration\n * @internal\n */\nfunction buildDashManifestConfiguration(\n  config: DashManifestConfiguration,\n  segment?: SegmentConfiguration,\n): CfnOriginEndpoint.DashManifestConfigurationProperty {\n  if (config.minBufferTime && (config.minBufferTime.toSeconds() < 1 || config.minBufferTime.toSeconds() > 3600)) {\n    throw new UnscopedValidationError(lit`MinBufferTimeRange`, 'Min buffer time has a range from 1 sec. to 3600 sec.');\n  }\n  if (config.minUpdatePeriod && (config.minUpdatePeriod.toSeconds() < 1 || config.minUpdatePeriod.toSeconds() > 3600)) {\n    throw new UnscopedValidationError(lit`MinUpdatePeriodRange`, 'Min update period option has a range from 1 sec. to 3600 sec.');\n  }\n  if (config.scteDashAdMarker && (!segment?.scteFilter || segment.scteFilter?.length === 0)) {\n    throw new UnscopedValidationError(lit`ScteFilterRequired`, 'SCTE Filter must be configured with DashAdMarker Configuration');\n  }\n\n  return {\n    manifestName: config.manifestName,\n    baseUrls: config.baseUrls,\n    compactness: config.compactness,\n    drmSignaling: config.drmSignalling,\n    dvbSettings: config.dvbSettings,\n    profiles: config.profiles,\n    programInformation: config.programInformation,\n    subtitleConfiguration: config.subtitleConfiguration,\n    manifestWindowSeconds: config.manifestWindow?.toSeconds(),\n    minBufferTimeSeconds: config.minBufferTime?.toSeconds(),\n    minUpdatePeriodSeconds: config.minUpdatePeriod?.toSeconds(),\n    suggestedPresentationDelaySeconds: config.suggestedPresentationDelay?.toSeconds(),\n    segmentTemplateFormat: config.segmentTemplateFormat,\n    periodTriggers: config.periodTriggers,\n    scteDash: segment?.scteFilter ? {\n      adMarkerDash: config.scteDashAdMarker,\n    } : undefined,\n    utcTiming: config.utcTimingMode || config.utcTimingSource ? {\n      timingMode: config.utcTimingMode,\n      timingSource: config.utcTimingSource,\n    } : undefined,\n    filterConfiguration: validateFilterConfiguration(config.filterConfiguration),\n  };\n}\n\n/**\n * Build MSS manifest configuration\n * @internal\n */\nfunction buildMssManifestConfiguration(config: MssManifestConfiguration): CfnOriginEndpoint.MssManifestConfigurationProperty {\n  return {\n    manifestName: config.manifestName,\n    manifestLayout: config.manifestLayout,\n    manifestWindowSeconds: config.manifestWindow?.toSeconds(),\n    filterConfiguration: validateFilterConfiguration(config.filterConfiguration),\n  };\n}\n\n/**\n * HLS Manifest implementation\n */\nclass HlsManifest extends Manifest {\n  constructor(private readonly config: HlsManifestConfiguration) {\n    super();\n  }\n\n  public _bind(context: ManifestBindContext): void {\n    validateManifestConfiguration(this.config);\n    context.hlsManifests.push(buildHlsManifestConfiguration(this.config, context.segment?.segmentDuration));\n  }\n}\n\n/**\n * Low Latency HLS Manifest implementation\n */\nclass LowLatencyHlsManifest extends Manifest {\n  constructor(private readonly config: LowLatencyHlsManifestConfiguration) {\n    super();\n  }\n\n  public _bind(context: ManifestBindContext): void {\n    validateManifestConfiguration(this.config);\n    context.llHlsManifests.push(buildHlsManifestConfiguration(this.config, context.segment?.segmentDuration));\n  }\n}\n\n/**\n * DASH Manifest implementation\n */\nclass DashManifest extends Manifest {\n  constructor(private readonly config: DashManifestConfiguration) {\n    super();\n  }\n\n  public _bind(context: ManifestBindContext): void {\n    validateManifestConfiguration(this.config);\n\n    if (this.config.utcTimingMode === DashUtcTimingMode.UTC_DIRECT && this.config.utcTimingSource) {\n      throw new UnscopedValidationError(lit`UtcDirectTimingSource`, 'UTC Direct configured with a timing source, ensure timing source is undefined to use UTC Direct.');\n    }\n\n    context.dashManifests.push(buildDashManifestConfiguration(this.config, context.segment));\n  }\n}\n\n/**\n * MSS Manifest implementation\n */\nclass MssManifest extends Manifest {\n  constructor(private readonly config: MssManifestConfiguration) {\n    super();\n  }\n\n  public _bind(context: ManifestBindContext): void {\n    validateManifestConfiguration(this.config);\n    context.mssManifests.push(buildMssManifestConfiguration(this.config));\n  }\n}\n\n/**\n * The type of container to attach to this origin endpoint.\n * A container type is a file format that encapsulates one or more media streams, such as audio and video, into a single file. You can't change the container type after you create the endpoint.\n */\nexport enum ContainerType {\n  /**\n   * TS Container Type\n   */\n  TS='TS',\n  /**\n   * CMAF Container Type\n   */\n  CMAF='CMAF',\n  /**\n   * ISM Container Type (Microsoft Smooth Streaming)\n   */\n  ISM='ISM',\n}\n\n/**\n * Encryption methods for CMAF container type.\n */\nexport enum CmafEncryptionMethod {\n  /**\n   * Common Encryption Scheme (CENC) - compatible with PlayReady, Widevine, and Irdeto DRM systems.\n   */\n  CENC = 'CENC',\n  /**\n   * Common Encryption Scheme with CBCS mode - compatible with PlayReady, Widevine, and FairPlay DRM systems.\n   */\n  CBCS = 'CBCS',\n}\n\n/**\n * Encryption methods for TS container type.\n */\nexport enum TsEncryptionMethod {\n  /**\n   * AES-128 encryption - requires Clear Key AES 128 DRM system.\n   */\n  AES_128 = 'AES_128',\n  /**\n   * Sample-level AES encryption - requires FairPlay DRM system.\n   */\n  SAMPLE_AES = 'SAMPLE_AES',\n}\n\n/**\n * A collection of audio encryption presets.\n */\nexport enum PresetSpeke20Audio {\n  /**\n   * Use one content key to encrypt all of the audio tracks in your stream.\n   */\n  PRESET_AUDIO_1='PRESET_AUDIO_1',\n  /**\n   * Use one content key to encrypt all of the stereo audio tracks and one content key to encrypt all of the multichannel audio tracks.\n   */\n  PRESET_AUDIO_2='PRESET_AUDIO_2',\n  /**\n   * Use one content key to encrypt all of the stereo audio tracks, one content key to encrypt all of the multichannel audio tracks with 3 to 6 channels,\n   * and one content key to encrypt all of the multichannel audio tracks with more than 6 channels.\n   */\n  PRESET_AUDIO_3='PRESET_AUDIO_3',\n  /**\n   * Use the same content key for all of the audio and video tracks in your stream.\n   */\n  SHARED='SHARED',\n  /**\n   * Don't encrypt any of the audio tracks in your stream.\n   */\n  UNENCRYPTED='UNENCRYPTED',\n}\n\n/**\n * The SPEKE Version 2.0 preset video associated with the encryption contract configuration of the origin endpoint.\n *\n * A collection of video encryption presets.\n */\nexport enum PresetSpeke20Video {\n  /**\n   * Use one content key to encrypt all of the video tracks in your stream.\n   */\n  PRESET_VIDEO_1='PRESET_VIDEO_1',\n  /**\n   * Use one content key to encrypt all of the SD video tracks and one content key for all HD and higher resolutions video tracks.\n   */\n  PRESET_VIDEO_2='PRESET_VIDEO_2',\n  /**\n   * Use one content key to encrypt all of the SD video tracks, one content key for HD video tracks and one content key for all UHD video tracks.\n   */\n  PRESET_VIDEO_3='PRESET_VIDEO_3',\n  /**\n   * Use one content key to encrypt all of the SD video tracks, one content key for HD video tracks,\n   * one content key for all UHD1 video tracks and one content key for all UHD2 video tracks.\n   */\n  PRESET_VIDEO_4='PRESET_VIDEO_4',\n  /**\n   * Use one content key to encrypt all of the SD video tracks, one content key for HD1 video tracks, one content key for HD2 video tracks,\n   * one content key for all UHD1 video tracks and one content key for all UHD2 video tracks.\n   */\n  PRESET_VIDEO_5='PRESET_VIDEO_5',\n  /**\n   * Use one content key to encrypt all of the SD video tracks, one content key for HD1 video tracks, one content key for HD2 video tracks\n   * and one content key for all UHD video tracks.\n   */\n  PRESET_VIDEO_6='PRESET_VIDEO_6',\n  /**\n   * Use one content key to encrypt all of the SD+HD1 video tracks, one content key for HD2 video tracks and one content key for all UHD video tracks.\n   */\n  PRESET_VIDEO_7='PRESET_VIDEO_7',\n  /**\n   * Use one content key to encrypt all of the SD+HD1 video tracks, one content key for HD2 video tracks, one content key for all UHD1\n   * video tracks and one content key for all UHD2 video tracks.\n   */\n  PRESET_VIDEO_8='PRESET_VIDEO_8',\n  /**\n   * Use the same content key for all of the video and audio tracks in your stream.\n   */\n  SHARED='SHARED',\n  /**\n   * Don't encrypt any of the video tracks in your stream.\n   */\n  UNENCRYPTED='UNENCRYPTED',\n}\n\n/**\n * Endpoint error configuration options.\n */\nexport enum EndpointErrorConfiguration {\n  /**\n   * The manifest stalled and there are no new segments or parts.\n   */\n  STALE_MANIFEST='STALE_MANIFEST',\n  /**\n   * There is a gap in the manifest.\n   */\n  INCOMPLETE_MANIFEST='INCOMPLETE_MANIFEST',\n  /**\n   * Key rotation is enabled but we're unable to fetch the key for the current key period.\n   */\n  MISSING_DRM_KEY='MISSING_DRM_KEY',\n  /**\n   * The segments which contain slate content are considered to be missing content.\n   */\n  SLATE_INPUT='SLATE_INPUT',\n}\n\n/**\n * SCTE-35 message type options available.\n */\nexport enum ScteMessageType {\n  /**\n   * Option for SPLICE_INSERT.\n   */\n  SPLICE_INSERT='SPLICE_INSERT',\n  /**\n   * Option for BREAK.\n   */\n  BREAK='BREAK',\n  /**\n   * Option for PROVIDER_ADVERTISEMENT.\n   */\n  PROVIDER_ADVERTISEMENT='PROVIDER_ADVERTISEMENT',\n  /**\n   * Option for DISTRIBUTOR_ADVERTISEMENT.\n   */\n  DISTRIBUTOR_ADVERTISEMENT='DISTRIBUTOR_ADVERTISEMENT',\n  /**\n   * Option for PROVIDER_PLACEMENT_OPPORTUNITY.\n   */\n  PROVIDER_PLACEMENT_OPPORTUNITY='PROVIDER_PLACEMENT_OPPORTUNITY',\n  /**\n   * Option for DISTRIBUTOR_PLACEMENT_OPPORTUNITY.\n   */\n  DISTRIBUTOR_PLACEMENT_OPPORTUNITY='DISTRIBUTOR_PLACEMENT_OPPORTUNITY',\n  /**\n   * Option for PROVIDER_OVERLAY_PLACEMENT_OPPORTUNITY.\n   */\n  PROVIDER_OVERLAY_PLACEMENT_OPPORTUNITY='PROVIDER_OVERLAY_PLACEMENT_OPPORTUNITY',\n  /**\n   * Option for DISTRIBUTOR_OVERLAY_PLACEMENT_OPPORTUNITY.\n   */\n  DISTRIBUTOR_OVERLAY_PLACEMENT_OPPORTUNITY='DISTRIBUTOR_OVERLAY_PLACEMENT_OPPORTUNITY',\n  /**\n   * Option for PROGRAM.\n   */\n  PROGRAM='PROGRAM',\n}\n\n/**\n * Controls whether SCTE-35 messages are included in segment files.\n */\nexport enum ScteInSegments {\n  /**\n   * SCTE-35 messages are not included in segments.\n   */\n  NONE = 'NONE',\n  /**\n   * SCTE-35 messages are embedded in segment data.\n   *\n   * For DASH manifests, when set to ALL, an InbandEventStream tag signals\n   * that SCTE messages are present in segments.\n   */\n  ALL = 'ALL',\n}\n\n/**\n * Origin Endpoint interface\n */\nexport interface IOriginEndpoint extends IResource, IOriginEndpointRef {\n  /**\n   * The name of the channel group associated with the origin endpoint configuration.\n   *\n   * @attribute\n   */\n  readonly channelGroupName: string;\n\n  /**\n   * The channel name associated with the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly channelName: string;\n\n  /**\n   * The name of the origin endpoint associated with the origin endpoint configuration.\n   *\n   * @attribute\n   */\n  readonly originEndpointName: string;\n\n  /**\n   * The Amazon Resource Name (ARN) of the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly originEndpointArn: string;\n\n  /**\n   * The date and time the origin endpoint was created.\n   *\n   * @attribute\n   */\n  readonly createdAt?: string;\n\n  /**\n   * The date and time the origin endpoint was modified.\n   *\n   * @attribute\n   */\n  readonly modifiedAt?: string;\n\n  /**\n   * The HLS manifest URLs for the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly hlsManifestUrls?: string[];\n\n  /**\n   * The Low Latency HLS manifest URLs for the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly lowLatencyHlsManifestUrls?: string[];\n\n  /**\n   * The DASH manifest URLs for the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly dashManifestUrls?: string[];\n\n  /**\n   * The MSS manifest URLs for the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly mssManifestUrls?: string[];\n\n  /**\n   * Configure origin endpoint policy.\n   *\n   * You can only add 1 OriginEndpointPolicy to an OriginEndpoint.\n   * If you have already defined one, it will append to the policy already created.\n   *\n   * @param statement - The policy statement to add\n   * @param cdnAuth - Optional CDN authorization configuration. Only the first CDN auth configuration is used if provided multiple times.\n   */\n  addToResourcePolicy(statement: PolicyStatement, cdnAuth?: CdnAuthConfiguration): AddToResourcePolicyResult;\n\n  /**\n   * Create a CloudWatch metric.\n   *\n   * @param metricName name of the metric.\n   * @param props metric options.\n   */\n  metric(metricName: string, props?: MetricOptions): Metric;\n\n  /**\n   * Returns Metric for Ingress Bytes\n   *\n   * @default - sum over 60 seconds\n   */\n  metricIngressBytes(options?: MetricOptions): Metric;\n\n  /**\n   * Returns Metric for Egress Bytes\n   *\n   * @default - sum over 60 seconds\n   */\n  metricEgressBytes(props?: MetricOptions): Metric;\n\n  /**\n   * Returns Metric for Ingress response time\n   *\n   * @default - average over 60 seconds\n   */\n  metricIngressResponseTime(props?: MetricOptions): Metric;\n\n  /**\n   * Returns Metric for Egress Response time\n   *\n   * @default - average over 60 seconds\n   */\n  metricEgressResponseTime(props?: MetricOptions): Metric;\n\n  /**\n   * Returns Metric for Egress Request Count\n   *\n   * @default - sum over 60 seconds\n   */\n  metricEgressRequestCount(props?: MetricOptions): Metric;\n\n  /**\n   * Returns Metric for Ingress Request Count\n   *\n   * @default - sum over 60 seconds\n   */\n  metricIngressRequestCount(props?: MetricOptions): Metric;\n}\n\n/**\n * DRM settings keys for manifest filter configuration.\n */\nexport enum DrmSettingsKey {\n  /**\n   * Exclude EXT-X-SESSION-KEY tags from HLS and LL-HLS multivariant playlists.\n   *\n   * This can improve compatibility with legacy HLS clients that have issues\n   * processing session keys, or provide more granular access control when\n   * using manifest filtering.\n   */\n  EXCLUDE_SESSION_KEYS = 'exclude_session_keys',\n}\n\n/**\n * Filter configuration includes settings for manifest filtering, start and end times, and time delay that apply to all of your egress requests for this manifest.\n */\nexport interface FilterConfiguration {\n  /**\n   * Optionally specify the clip start time for all of your manifest egress requests.\n   * When you include clip start time, note that you cannot use clip start time query parameters for this manifest's endpoint URL.\n   *\n   * This will be converted to a UTC timestamp.\n   *\n   * @default - No clip start time\n   */\n  readonly clipStartTime?: Date;\n  /**\n   * Optionally specify the end time for all of your manifest egress requests.\n   * When you include end time, note that you cannot use end time query parameters for this manifest's endpoint URL.\n   *\n   * This will be converted to a UTC timestamp.\n   *\n   * @default - No end time\n   */\n  readonly end?: Date;\n  /**\n   * Optionally specify the start time for all of your manifest egress requests.\n   * When you include start time, note that you cannot use start time query parameters for this manifest's endpoint URL.\n   *\n   * This will be converted to a UTC timestamp.\n   *\n   * @default - No start time\n   */\n  readonly start?: Date;\n  /**\n   * Optionally specify one or more manifest filters for all of your manifest egress requests.\n   * When you include a manifest filter, note that you cannot use an identical manifest filter query parameter for this manifest's endpoint URL.\n   *\n   * @default - No manifest filters\n   */\n  readonly manifestFilter?: ManifestFilter[];\n  /**\n   * Optionally specify the time delay for all of your manifest egress requests. Enter a value that is smaller than your endpoint's startover window.\n   * When you include time delay, note that you cannot use time delay query parameters for this manifest's endpoint URL.\n   *\n   * @default - No time delay\n   */\n  readonly timeDelay?: Duration;\n  /**\n   * DRM settings for manifest egress requests.\n   *\n   * When you include a DRM setting, note that you cannot use an identical\n   * DRM setting query parameter for this manifest's endpoint URL.\n   *\n   * @default - No DRM settings\n   */\n  readonly drmSettings?: DrmSettingsKey[];\n}\n\n/**\n * Options for configuring a StartTag.\n */\nexport interface StartTagOptions {\n  /**\n   * Specify the value for PRECISE within your EXT-X-START tag.\n   *\n   * Leave blank, or choose false, to use the default value NO. Choose true to use the value YES.\n   *\n   * @default false\n   */\n  readonly precise?: boolean;\n}\n\n/**\n * Helper class for creating EXT-X-START tags in HLS playlists.\n *\n * The EXT-X-START tag indicates a preferred point at which to start playing a playlist.\n */\nexport class StartTag {\n  /**\n   * Create a start tag with a time offset.\n   *\n   * @param timeOffset The time offset in seconds. Can be positive (forward from start) or negative (back from live edge).\n   *   - If positive: must be less than (manifest duration - 3 × segment duration)\n   *   - If negative: absolute value must be greater than (3 × segment duration) and less than manifest duration\n   * @param options Additional options\n   */\n  public static of(timeOffset: number, options?: StartTagOptions): StartTag {\n    return {\n      timeOffset,\n      precise: options && options.precise !== undefined ? options.precise : undefined,\n    };\n  }\n\n  /**\n   * Create a start tag with precise positioning enabled (PRECISE=YES).\n   *\n   * @param timeOffset The time offset in seconds (positive or negative)\n   */\n  public static withPrecise(timeOffset: number): StartTag {\n    return {\n      timeOffset,\n      precise: true,\n    };\n  }\n}\n\n/**\n * Configuration for EXT-X-START tag in HLS playlists.\n *\n * Use the `StartTag` helper class to create instances with validation.\n */\nexport interface StartTag {\n  /**\n   * Specify the value for PRECISE within your EXT-X-START tag.\n   *\n   * Leave blank, or choose false, to use the default value NO. Choose true to use the value YES.\n   */\n  readonly precise?: boolean;\n  /**\n   * Specify the value for TIME-OFFSET within your EXT-X-START tag.\n   *\n   * Enter a signed floating point value which, if positive, must be less than the configured\n   * manifest duration minus three times the configured segment target duration. If negative,\n   * the absolute value must be larger than three times the configured segment target duration,\n   * and the absolute value must be smaller than the configured manifest duration.\n   */\n  readonly timeOffset: number;\n}\n\n/**\n * Base manifest configuration.\n */\ninterface ManifestConfigurationBase {\n  /**\n   * Filter configuration includes settings for manifest filtering, start and end times, and time delay that apply to all of your egress requests for this manifest.\n   *\n   * https://docs.aws.amazon.com/mediapackage/latest/userguide/manifest-filter-query-parameters.html\n   * @default - No filter configuration\n   */\n  readonly filterConfiguration?: FilterConfiguration;\n  /**\n   * The total duration (in seconds) of the manifest's content.\n   *\n   * @default 60\n   */\n  readonly manifestWindow?: Duration;\n}\n\n/**\n * Choose how ad markers are included in the packaged content.\n */\nexport enum AdMarkerDash {\n  /**\n   * Option for BINARY - The SCTE-35 marker is expressed as a hex-string (Base64 string) rather than full XML.\n   */\n  BINARY='BINARY',\n  /**\n   * Option for XML - The SCTE marker is expressed fully in XML.\n   */\n  XML='XML',\n}\n\n/**\n * Choose how SCTE-35 ad markers are included in HLS and LL-HLS manifests.\n */\nexport enum AdMarkerHls {\n  /**\n   * Insert EXT-X-DATERANGE tags to signal ad content.\n   */\n  DATERANGE = 'DATERANGE',\n  /**\n   * Insert enhanced SCTE-35 tags for ad content.\n   */\n  SCTE35_ENHANCED = 'SCTE35_ENHANCED',\n}\n\n/**\n * The type of variable that MediaPackage uses in the media attribute of the SegmentTemplate tag.\n */\nexport enum SegmentTemplateFormat {\n  /**\n   * Option for number with timeline.\n   */\n  NUMBER_WITH_TIMELINE='NUMBER_WITH_TIMELINE',\n}\n\n/**\n * The UTC timing mode for DASH.\n */\nexport enum DashUtcTimingMode {\n  /**\n   * Option for HTTP_HEAD.\n   */\n  HTTP_HEAD='HTTP_HEAD',\n  /**\n   * Option for HTTP_ISO.\n   */\n  HTTP_ISO='HTTP_ISO',\n  /**\n   * Option for HTTP_XSDATE.\n   */\n  HTTP_XSDATE='HTTP_XSDATE',\n  /**\n   * Option for UTC_DIRECT.\n   */\n  UTC_DIRECT='UTC_DIRECT',\n}\n\n/**\n * Options for triggers which cause AWS Elemental MediaPackage to create media presentation description (MPD) periods in the output manifest.\n */\nexport enum DashPeriodTriggers {\n  /**\n   * Option for AVAILS.\n   */\n  AVAILS='AVAILS',\n  /**\n   * Option for DRM_KEY_ROTATION.\n   */\n  DRM_KEY_ROTATION='DRM_KEY_ROTATION',\n  /**\n   * Option for SOURCE_CHANGES.\n   */\n  SOURCE_CHANGES='SOURCE_CHANGES',\n  /**\n   * Option for SOURCE_DISRUPTIONS.\n   */\n  SOURCE_DISRUPTIONS='SOURCE_DISRUPTIONS',\n  /**\n   * Option for NONE.\n   */\n  NONE='NONE',\n}\n\n/**\n * DRM signaling determines the way DASH manifest signals the DRM content.\n */\nexport enum DrmSignalling {\n  /**\n   * Option for INDIVIDUAL.\n   */\n  INDIVIDUAL='INDIVIDUAL',\n  /**\n   * Option for REFERENCED.\n   */\n  REFERENCED='REFERENCED',\n}\n\n/**\n * STANDARD indicates a default manifest, which is compacted. NONE indicates a full manifest.\n */\nexport enum DashManifestCompactness {\n  /**\n   * STANDARD\n   */\n  STANDARD='STANDARD',\n  /**\n   * NONE\n   */\n  NONE='NONE',\n}\n\n/**\n * The base URLs to use for retrieving segments. You can specify multiple locations and indicate the\n * priority and weight for when each should be used, for use in multi-CDN workflows.\n */\nexport interface DashBaseUrlProperty {\n  /**\n   * For use with DVB-DASH profiles only. The priority of this location for serving segments. The lower the number, the higher the priority.\n   *\n   * @default - No priority specified\n   */\n  readonly dvbPriority?: number;\n  /**\n   * For use with DVB-DASH profiles only. The weighting for source locations that have the same priority.\n   *\n   * @default - No weight specified\n   */\n  readonly dvbWeight?: number;\n  /**\n   * The name of the source location.\n   *\n   * @default - No service location specified\n   */\n  readonly serviceLocation?: string;\n  /**\n   * A source location for segments.\n   */\n  readonly url: string;\n}\n\n/**\n * For use with DVB-DASH profiles only. The settings for error reporting from the playback device\n * that you want AWS Elemental MediaPackage to pass through to the manifest.\n */\nexport interface DashDvbMetricsReporting {\n  /**\n   * The number of playback devices per 1000 that will send error reports to the reporting URL.\n   * This represents the probability that a playback device will be a reporting player for this session.\n   *\n   * @default - No probability specified\n   */\n  readonly probability?: number;\n  /**\n   * The URL where playback devices send error reports.\n   */\n  readonly reportingUrl: string;\n}\n\n/**\n * For use with DVB-DASH profiles only. The settings for font downloads that you want AWS Elemental MediaPackage to pass through to the manifest.\n */\nexport interface DashDvbFontDownload {\n  /**\n   * The fontFamily name for subtitles, as described in EBU-TT-D Subtitling Distribution Format.\n   * @external https://tech.ebu.ch/publications/tech3380\n   *\n   * @default - No font family specified\n   */\n  readonly fontFamily?: string;\n  /**\n   * The mimeType of the resource that's at the font download URL.\n   * For information about font MIME types, see the MPEG-DASH Profile for Transport of ISO BMFF Based DVB Services over IP Based Networks document.\n   *\n   * @external https://dvb.org/wp-content/uploads/2021/06/A168r4_MPEG-DASH-Profile-for-Transport-of-ISO-BMFF-Based-DVB-Services_Draft-ts_103-285-v140_November_2021.pdf\n   * @default - No MIME type specified\n   */\n  readonly mimeType?: string;\n  /**\n   * The URL for downloading fonts for subtitles.\n   *\n   * @default - No font download URL specified\n   */\n  readonly url?: string;\n}\n\n/**\n * The font download and error reporting information that you want MediaPackage to pass through to the manifest.\n */\nexport interface DashDvbSettings {\n  /**\n   * Playback device error reporting settings.\n   *\n   * @default - No error metrics configured\n   */\n  readonly errorMetrics?: DashDvbMetricsReporting[];\n  /**\n   * Subtitle font settings.\n   *\n   * @default - No font download configured\n   */\n  readonly fontDownload?: DashDvbFontDownload;\n}\n\n/**\n * Details about the content that you want MediaPackage to pass through in the manifest to the playback device.\n */\nexport interface DashProgramInformation {\n  /**\n   * A copyright statement about the content.\n   *\n   * @default - No copyright information\n   */\n  readonly copyright?: string;\n  /**\n   * The language code for this manifest.\n   *\n   * @default - No language code specified\n   */\n  readonly languageCode?: string;\n  /**\n   * An absolute URL that contains more information about this content.\n   *\n   * @default - No additional information URL\n   */\n  readonly moreInformationUrl?: string;\n  /**\n   * Information about the content provider.\n   *\n   * @default - No source information\n   */\n  readonly source?: string;\n  /**\n   * The title for the manifest.\n   *\n   * @default - No title specified\n   */\n  readonly title?: string;\n}\n\n/**\n * Options for TTML Profile\n */\nexport enum TtmlProfile {\n  /**\n   * IMSC_1\n   */\n  IMSC_1='IMSC_1',\n  /**\n   * EBU_TT_D_101\n   */\n  EBU_TT_D_101='EBU_TT_D_101',\n}\n/**\n * Configuration for TTML subtitles in DASH manifests.\n */\nexport interface DashTtmlConfiguration {\n  /**\n   * The profile that MediaPackage uses when signaling subtitles in the manifest. IMSC is the default profile. EBU-TT-D produces subtitles that are compliant with the EBU-TT-D TTML profile. MediaPackage passes through subtitle styles to the manifest.\n   * For more information about EBU-TT-D subtitles, see EBU-TT-D Subtitling Distribution Format.\n   *\n   * @external https://tech.ebu.ch/publications/tech3380\n   */\n  readonly ttmlProfile: TtmlProfile;\n\n}\n/**\n * Configuration for subtitles in DASH manifests.\n */\nexport interface DashSubtitleConfiguration {\n  /**\n   * Settings for TTML subtitles.\n   *\n   * @default - No TTML configuration\n   */\n  readonly ttmlConfiguration?: DashTtmlConfiguration;\n}\n\n/**\n * The layout of the MSS manifest.\n */\nexport enum MssManifestLayout {\n  /**\n   * Full manifest layout.\n   */\n  FULL = 'FULL',\n  /**\n   * Compact manifest layout.\n   */\n  COMPACT = 'COMPACT',\n}\n\n/**\n * The MSS manifest configuration associated with the origin endpoint.\n */\nexport interface MssManifestConfiguration extends ManifestConfigurationBase {\n  /**\n   * The name of the manifest associated with the MSS manifest configuration.\n   */\n  readonly manifestName: string;\n  /**\n   * The layout of the MSS manifest.\n   *\n   * @default MssManifestLayout.FULL\n   */\n  readonly manifestLayout?: MssManifestLayout;\n}\n\n/**\n * The DASH manifest configuration associated with the origin endpoint.\n */\nexport interface DashManifestConfiguration extends ManifestConfigurationBase {\n  /**\n   * The base URLs to use for retrieving segments.\n   *\n   * @default - No base URLs specified\n   */\n  readonly baseUrls?: DashBaseUrlProperty[];\n  /**\n   * The layout of the DASH manifest that MediaPackage produces.\n   *\n   * @default DashManifestCompactness.STANDARD\n   */\n  readonly compactness?: DashManifestCompactness;\n  /**\n   * For endpoints that use the DVB-DASH profile only.\n   *\n   * @default - No DVB settings\n   */\n  readonly dvbSettings?: DashDvbSettings;\n  /**\n   * The profile that the output is compliant with.\n   *\n   * @default - No profiles specified\n   */\n  readonly profiles?: string[];\n  /**\n   * Details about the content that you want MediaPackage to pass through in the manifest to the playback device.\n   *\n   * @default - No program information\n   */\n  readonly programInformation?: DashProgramInformation;\n  /**\n   * The configuration for DASH subtitles.\n   *\n   * @default - No subtitle configuration\n   */\n  readonly subtitleConfiguration?: DashSubtitleConfiguration;\n  /**\n   * The name of the manifest associated with the DASH manifest configuration.\n   */\n  readonly manifestName: string;\n  /**\n   * DRM signaling determines the way DASH manifest signals the DRM content.\n   *\n   * @default - No DRM signaling specified\n   */\n  readonly drmSignalling?: DrmSignalling;\n  /**\n   * The minimum amount of content that the player must keep available in the buffer.\n   *\n   * @default 5\n   */\n  readonly minBufferTime?: Duration;\n  /**\n   * The minimum amount of time for the player to wait before requesting an updated manifest.\n   *\n   * @default 2\n   */\n  readonly minUpdatePeriod?: Duration;\n  /**\n   * Specify what triggers cause AWS Elemental MediaPackage to create media presentation description (MPD) periods in the output manifest.\n   *\n   * @default [DashPeriodTriggers.AVAILS, DashPeriodTriggers.DRM_KEY_ROTATION, DashPeriodTriggers.SOURCE_CHANGES, DashPeriodTriggers.SOURCE_DISRUPTIONS]\n   */\n  readonly periodTriggers?: DashPeriodTriggers[];\n  /**\n   * Choose how ad markers are included in the packaged content. If you include ad markers in the content stream in your upstream encoders,\n   * then you need to inform MediaPackage what to do with the ad markers in the output.\n   *\n   * To choose this option STCE filtering needs to be enabled.\n   *\n   * @default AdMarkerDash.XML\n   */\n  readonly scteDashAdMarker?: AdMarkerDash;\n  /**\n   * The type of variable that MediaPackage uses in the media attribute of the SegmentTemplate tag.\n   *\n   * @default SegmentTemplateFormat.NUMBER_WITH_TIMELINE\n   */\n  readonly segmentTemplateFormat?: SegmentTemplateFormat;\n  /**\n   * The amount of time that the player should be from the end of the manifest.\n   *\n   * @default 10\n   */\n  readonly suggestedPresentationDelay?: Duration;\n  /**\n   * The UTC timing mode.\n   *\n   * @default DashUtcTimingMode.UTC_DIRECT\n   */\n  readonly utcTimingMode?: DashUtcTimingMode;\n  /**\n   * The method that the player uses to synchronize to coordinated universal time (UTC) wall clock time.\n   *\n   * @default undefined - No value is specified\n   */\n  readonly utcTimingSource?: string;\n}\n\n/**\n * The HLS manifest configuration associated with the origin endpoint.\n */\nexport interface HlsManifestConfiguration extends ManifestConfigurationBase {\n  /**\n   * The name of the manifest associated with the HLS manifest configuration.\n   */\n  readonly manifestName: string;\n  /**\n   * The name of the child manifest associated with the HLS manifest configuration.\n   *\n   * @default - No child manifest name specified\n   */\n  readonly childManifestName?: string;\n  /**\n   * Inserts EXT-X-PROGRAM-DATE-TIME tags in the output manifest at the interval that you specify.\n   * If you don't enter an interval, EXT-X-PROGRAM-DATE-TIME tags aren't included in the manifest.\n   * The tags sync the stream to the wall clock so that viewers can seek to a specific time in the playback timeline on the player.\n   *\n   * @default - No program date time interval\n   */\n  readonly programDateTimeInterval?: Duration;\n  /**\n   * The SCTE-35 HLS configuration associated with the HLS manifest configuration of the origin endpoint.\n   *\n   * @default - No SCTE ad marker configuration\n   */\n  readonly scteAdMarkerHls?: AdMarkerHls;\n  /**\n   * Insert EXT-X-START tag in the manifest with the configured settings\n   *\n   * @default - No start tag\n   */\n  readonly startTag?: StartTag;\n  /**\n   * When enabled, MediaPackage URL-encodes the query string for API requests for HLS child manifests to comply with AWS Signature Version 4 (SigV4) signature signing protocol.\n   * For more information, see AWS Signature Version 4 for API requests in AWS Identity and Access Management User Guide.\n   *\n   * @external https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_sigv.html\n   * @default false\n   */\n  readonly urlEncodeChildManifest?: boolean;\n}\n\n/**\n * Specify a low-latency HTTP live streaming (LL-HLS) manifest configuration.\n */\nexport interface LowLatencyHlsManifestConfiguration extends ManifestConfigurationBase {\n  /**\n   * A short string that's appended to the endpoint URL. The manifest name creates a unique path to this endpoint.\n   * If you don't enter a value, MediaPackage uses the default manifest name, index. MediaPackage automatically inserts the format extension, such as .m3u8.\n   * You can't use the same manifest name if you use HLS manifest and low-latency HLS manifest.\n   * The manifestName on the HLSManifest object overrides the manifestName you provided on the originEndpoint object.\n   */\n  readonly manifestName: string;\n  /**\n   * The name of the child manifest associated with the low-latency HLS (LL-HLS) manifest configuration of the origin endpoint.\n   *\n   * @default - No child manifest name specified\n   */\n  readonly childManifestName?: string;\n  /**\n   * Inserts EXT-X-PROGRAM-DATE-TIME tags in the output manifest at the interval that you specify.\n   * If you don't enter an interval, EXT-X-PROGRAM-DATE-TIME tags aren't included in the manifest.\n   * The tags sync the stream to the wall clock so that viewers can seek to a specific time in the playback timeline on the player.\n   *\n   * @default - No program date time interval\n   */\n  readonly programDateTimeInterval?: Duration;\n  /**\n   * The SCTE-35 HLS configuration associated with the low-latency HLS (LL-HLS) manifest configuration of the origin endpoint.\n   *\n   * @default - No SCTE ad marker configuration\n   */\n  readonly scteAdMarkerHls?: AdMarkerHls;\n  /**\n   * Insert EXT-X-START tag in the manifest with the configured settings\n   *\n   * @default - No start tag\n   */\n  readonly startTag?: StartTag;\n  /**\n   * When enabled, MediaPackage URL-encodes the query string for API requests for LL-HLS child manifests to comply with AWS Signature Version 4 (SigV4) signature signing protocol.\n   * For more information, see AWS Signature Version 4 for API requests in AWS Identity and Access Management User Guide.\n   *\n   * @external https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_sigv.html\n   * @default false\n   */\n  readonly urlEncodeChildManifest?: boolean;\n}\n\n/**\n * Configuration parameters for an AWS Elemental MediaPackage V2 Origin Endpoint.\n */\nexport interface OriginEndpointOptions {\n  /**\n   * The name of the origin endpoint associated with the origin endpoint configuration.\n   * @default autogenerated\n   */\n  readonly originEndpointName?: string;\n\n  /**\n   * The description associated with the origin endpoint.\n   *\n   * @default undefined - No description is added to Origin Endpoint\n   */\n  readonly description?: string;\n\n  /**\n   * The tags associated with the origin endpoint.\n   *\n   * @default - No tagging\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * Manifests configuration for HLS, Low Latency HLS and DASH.\n   */\n  readonly manifests: Manifest[];\n\n  /**\n   * The size of the window to specify a window of the live stream that's available for on-demand viewing. Viewers can start-over or catch-up on content that falls within the window.\n   *\n   * @default 900\n   */\n  readonly startoverWindow?: Duration;\n\n  /**\n   * The segment associated with the origin endpoint.\n   *\n   * Inside the segment configuration you can define options such as encryption, SPEKE parameters and other\n   * general segment configurations.\n   *\n   * Use Segment.ts() or Segment.cmaf() to create the configuration.\n   */\n  readonly segment: SegmentConfiguration;\n\n  /**\n   * The failover settings for the endpoint.\n   *\n   * @default undefined - No force endpoint configuration is configured\n   */\n  readonly forceEndpointConfigurationConditions?: EndpointErrorConfiguration[];\n\n  /**\n   * Provide access to MediaPackage V2 Origin Endpoint via secret header.\n   *\n   * @default undefined - Not configured on endpoint\n   */\n  readonly cdnAuth?: CdnAuthConfiguration;\n\n  /**\n   * Policy to apply when the origin endpoint is removed from the stack\n   *\n   * Even though MediaPackage ChannelGroups, Channels and OriginEndpoints are technically stateful,\n   * their contents are transient and it is common to add and remove these while rearchitecting your application.\n   * The default is therefore `DESTROY`. Change it to `RETAIN` if the content (in a lookback window) are so\n   * valuable that accidentally losing it would be unacceptable.\n   *\n   * @default RemovalPolicy.DESTROY\n   */\n  readonly removalPolicy?: RemovalPolicy;\n}\n\n/**\n * Properties to set on an Origin Endpoint.\n */\nexport interface OriginEndpointProps extends OriginEndpointOptions {\n  /**\n   * The channel associated with the origin endpoint.\n   */\n  readonly channel: IChannel;\n}\n\n/**\n * Represents an Origin Endpoint defined outside of this stack.\n */\nexport interface OriginEndpointAttributes {\n  /**\n   * The name that describes the channel group. The name is the primary identifier for the channel group.\n   *\n   * @attribute\n   */\n  readonly channelGroupName: string;\n\n  /**\n   * The name that describes the channel. The name is the primary identifier for the channel.\n   *\n   * @attribute\n   */\n  readonly channelName: string;\n\n  /**\n   * The name that describes the origin endpoint.\n   *\n   * @attribute\n   */\n  readonly originEndpointName: string;\n}\n\n/**\n * DRM systems available for CMAF encryption.\n *\n * CENC supports PlayReady, Widevine, and Irdeto.\n * CBCS supports PlayReady, Widevine, and FairPlay.\n */\nexport enum CmafDrmSystem {\n  /**\n   * FairPlay DRM - used with CBCS encryption.\n   */\n  FAIRPLAY = 'FAIRPLAY',\n  /**\n   * PlayReady DRM - used with CENC and CBCS encryption.\n   */\n  PLAYREADY = 'PLAYREADY',\n  /**\n   * Widevine DRM - used with CENC and CBCS encryption.\n   */\n  WIDEVINE = 'WIDEVINE',\n  /**\n   * Irdeto DRM - used with CENC encryption.\n   */\n  IRDETO = 'IRDETO',\n}\n\n/**\n * DRM systems available for TS encryption.\n *\n * SAMPLE_AES uses FairPlay, AES_128 uses Clear Key AES 128.\n */\nexport enum TsDrmSystem {\n  /**\n   * FairPlay DRM - used with SAMPLE_AES encryption.\n   */\n  FAIRPLAY = 'FAIRPLAY',\n  /**\n   * Clear Key AES 128 - used with AES_128 encryption.\n   */\n  CLEAR_KEY_AES_128 = 'CLEAR_KEY_AES_128',\n}\n\n/**\n * DRM systems available for ISM encryption.\n *\n * ISM only supports PlayReady with CENC.\n */\nexport enum IsmDrmSystem {\n  /**\n   * PlayReady DRM.\n   */\n  PLAYREADY = 'PLAYREADY',\n}\n\n/**\n * Base properties common to all SPEKE encryption configurations.\n */\ninterface SpekeEncryptionPropsBase {\n  /**\n   * The unique identifier for the content.\n   *\n   * The service sends this identifier to the key server to identify the current endpoint.\n   * How unique you make this identifier depends on how fine-grained you want access controls to be.\n   * The service does not permit you to use the same ID for two simultaneous encryption processes.\n   */\n  readonly resourceId: string;\n\n  /**\n   * IAM role for accessing the key provider API.\n   *\n   * This role must have a trust policy that allows MediaPackage to assume the role,\n   * and it must have sufficient permissions to access the key retrieval URL.\n   */\n  readonly role: IRole;\n\n  /**\n   * URL of the SPEKE key provider.\n   */\n  readonly url: string;\n\n  /**\n   * The ARN of the certificate that you imported to AWS Certificate Manager\n   * to add content key encryption to this endpoint.\n   *\n   * For this feature to work, your DRM key provider must support content key encryption.\n   *\n   * @default - no content key encryption\n   */\n  readonly certificate?: ICertificate;\n\n  /**\n   * Audio encryption preset.\n   *\n   * @default PresetSpeke20Audio.PRESET_AUDIO_1\n   */\n  readonly audioPreset?: PresetSpeke20Audio;\n\n  /**\n   * Video encryption preset.\n   *\n   * @default PresetSpeke20Video.PRESET_VIDEO_1\n   */\n  readonly videoPreset?: PresetSpeke20Video;\n}\n\n/**\n * Properties for CMAF SPEKE encryption configuration.\n */\nexport interface CmafSpekeEncryptionProps extends SpekeEncryptionPropsBase {\n  /**\n   * The encryption method to use.\n   */\n  readonly method: CmafEncryptionMethod;\n\n  /**\n   * The DRM systems to use for content protection.\n   *\n   * CENC supports PlayReady, Widevine, and Irdeto.\n   * CBCS supports PlayReady, Widevine, and FairPlay.\n   */\n  readonly drmSystems: CmafDrmSystem[];\n\n  /**\n   * Constant initialization vector (32-character hex string).\n   *\n   * A 128-bit, 16-byte hex value represented by a 32-character string,\n   * used in conjunction with the key for encrypting content.\n   *\n   * @default - MediaPackage generates the IV\n   */\n  readonly constantInitializationVector?: string;\n\n  /**\n   * Key rotation interval.\n   *\n   * @default - no rotation\n   */\n  readonly keyRotationInterval?: Duration;\n\n  /**\n   * When enabled, DRM metadata is excluded from CMAF segments.\n   *\n   * @default false\n   */\n  readonly excludeSegmentDrmMetadata?: boolean;\n}\n\n/**\n * Properties for TS SPEKE encryption configuration.\n */\nexport interface TsSpekeEncryptionProps extends SpekeEncryptionPropsBase {\n  /**\n   * The encryption method to use.\n   */\n  readonly method: TsEncryptionMethod;\n\n  /**\n   * The DRM systems to use for content protection.\n   *\n   * @default - FairPlay for SAMPLE_AES, Clear Key AES 128 for AES_128\n   */\n  readonly drmSystems?: TsDrmSystem[];\n\n  /**\n   * Constant initialization vector (32-character hex string).\n   *\n   * A 128-bit, 16-byte hex value represented by a 32-character string,\n   * used in conjunction with the key for encrypting content.\n   *\n   * @default - MediaPackage generates the IV\n   */\n  readonly constantInitializationVector?: string;\n\n  /**\n   * Key rotation interval.\n   *\n   * @default - no rotation\n   */\n  readonly keyRotationInterval?: Duration;\n}\n\n/**\n * Properties for ISM SPEKE encryption configuration.\n *\n * ISM only supports CENC encryption with PlayReady DRM.\n * Key rotation and constant initialization vectors are not supported.\n * Audio and video presets default to SHARED.\n */\nexport interface IsmSpekeEncryptionProps {\n  /**\n   * The DRM systems to use for content protection.\n   *\n   * @default - [IsmDrmSystem.PLAYREADY]\n   */\n  readonly drmSystems?: IsmDrmSystem[];\n\n  /**\n   * The unique identifier for the content.\n   */\n  readonly resourceId: string;\n\n  /**\n   * IAM role for accessing the key provider API.\n   */\n  readonly role: IRole;\n\n  /**\n   * URL of the SPEKE key provider.\n   */\n  readonly url: string;\n\n  /**\n   * The ARN of the certificate that you imported to AWS Certificate Manager\n   * to add content key encryption to this endpoint.\n   *\n   * @default - no content key encryption\n   */\n  readonly certificate?: ICertificate;\n}\n\n/**\n * Base class for encryption configurations.\n *\n * Use `CmafEncryption.speke()`, `TsEncryption.speke()`, or `IsmEncryption.speke()` to create instances.\n */\nexport abstract class EncryptionConfiguration {\n  /**\n   * Binds the encryption configuration to produce the CloudFormation property.\n   *\n   * This is an internal method used by the construct library and should not be\n   * called or implemented by external consumers. It may change without notice.\n   *\n   * @internal\n   */\n  public abstract _bind(scope: Construct): CfnOriginEndpoint.EncryptionProperty;\n\n  /**\n   * Returns the IAM role used for encryption, if any.\n   *\n   * This is an internal method used by the construct library and should not be\n   * called or implemented by external consumers. It may change without notice.\n   *\n   * @internal\n   */\n  public abstract _getRole(): IRole | undefined;\n\n  /**\n   * Returns the ACM certificate used for content key encryption, if any.\n   *\n   * This is an internal method used by the construct library and should not be\n   * called or implemented by external consumers. It may change without notice.\n   *\n   * @internal\n   */\n  public abstract _getCertificate(): ICertificate | undefined;\n}\n\n/**\n * Encryption configuration for CMAF segments.\n *\n * Use `CmafEncryption.speke()` to create an instance.\n */\nexport class CmafEncryption extends EncryptionConfiguration {\n  /**\n   * Create a SPEKE-based encryption configuration for CMAF segments.\n   */\n  public static speke(props: CmafSpekeEncryptionProps): CmafEncryption {\n    if (!props.url.startsWith('https://')) {\n      throw new UnscopedValidationError(lit`SpekeUrlHttpsRequired`, 'SPEKE key provider URL must use HTTPS.');\n    }\n    if (props.method === CmafEncryptionMethod.CENC && props.drmSystems.includes(CmafDrmSystem.FAIRPLAY)) {\n      throw new UnscopedValidationError(lit`CencFairPlayIncompatible`, 'CENC encryption method does not support FairPlay. Use CBCS for FairPlay.');\n    }\n    if (props.method === CmafEncryptionMethod.CBCS && props.drmSystems.includes(CmafDrmSystem.IRDETO)) {\n      throw new UnscopedValidationError(lit`CbcsIrdetoIncompatible`, 'CBCS encryption method does not support Irdeto. Use CENC for Irdeto.');\n    }\n    return new CmafEncryption(props);\n  }\n\n  private readonly config: CmafSpekeEncryptionProps;\n  private constructor(props: CmafSpekeEncryptionProps) {\n    super();\n    this.config = props;\n  }\n\n  /** @internal */\n  public _bind(scope: Construct): CfnOriginEndpoint.EncryptionProperty {\n    const p = this.config;\n    if (p.constantInitializationVector && p.constantInitializationVector.length !== 32) {\n      throw new ValidationError(lit`ConstantInitVectorLength`, 'Constant Initialization Vector needs to be 32 characters in length.', scope);\n    }\n    if (p.keyRotationInterval && (p.keyRotationInterval.toSeconds() < 300 || p.keyRotationInterval.toSeconds() > 31536000)) {\n      throw new ValidationError(lit`KeyRotationIntervalRange`, 'Key Rotation Interval needs to be between 300-31536000 seconds.', scope);\n    }\n    return {\n      cmafExcludeSegmentDrmMetadata: p.excludeSegmentDrmMetadata,\n      constantInitializationVector: p.constantInitializationVector,\n      keyRotationIntervalSeconds: p.keyRotationInterval?.toSeconds(),\n      encryptionMethod: { cmafEncryptionMethod: p.method },\n      spekeKeyProvider: {\n        certificateArn: p.certificate?.certificateArn,\n        drmSystems: p.drmSystems,\n        encryptionContractConfiguration: {\n          presetSpeke20Audio: p.audioPreset ?? PresetSpeke20Audio.PRESET_AUDIO_1,\n          presetSpeke20Video: p.videoPreset ?? PresetSpeke20Video.PRESET_VIDEO_1,\n        },\n        url: p.url,\n        resourceId: p.resourceId,\n        roleArn: p.role.roleArn,\n      },\n    };\n  }\n\n  /** @internal */\n  public _getRole(): IRole | undefined { return this.config.role; }\n\n  /** @internal */\n  public _getCertificate(): ICertificate | undefined { return this.config.certificate; }\n}\n\n/**\n * Encryption configuration for TS segments.\n *\n * Use `TsEncryption.speke()` to create an instance.\n */\nexport class TsEncryption extends EncryptionConfiguration {\n  /**\n   * Create a SPEKE-based encryption configuration for TS segments.\n   */\n  public static speke(props: TsSpekeEncryptionProps): TsEncryption {\n    if (!props.url.startsWith('https://')) {\n      throw new UnscopedValidationError(lit`SpekeUrlHttpsRequired`, 'SPEKE key provider URL must use HTTPS.');\n    }\n    return new TsEncryption(props);\n  }\n\n  private readonly config: TsSpekeEncryptionProps;\n  private constructor(props: TsSpekeEncryptionProps) {\n    super();\n    this.config = props;\n  }\n\n  /** @internal */\n  public _bind(scope: Construct): CfnOriginEndpoint.EncryptionProperty {\n    const p = this.config;\n    const defaultDrm: TsDrmSystem[] = p.method === TsEncryptionMethod.SAMPLE_AES\n      ? [TsDrmSystem.FAIRPLAY] : [TsDrmSystem.CLEAR_KEY_AES_128];\n    if (p.constantInitializationVector && p.constantInitializationVector.length !== 32) {\n      throw new ValidationError(lit`ConstantInitVectorLength`, 'Constant Initialization Vector needs to be 32 characters in length.', scope);\n    }\n    if (p.keyRotationInterval && (p.keyRotationInterval.toSeconds() < 300 || p.keyRotationInterval.toSeconds() > 31536000)) {\n      throw new ValidationError(lit`KeyRotationIntervalRange`, 'Key Rotation Interval needs to be between 300-31536000 seconds.', scope);\n    }\n    return {\n      constantInitializationVector: p.constantInitializationVector,\n      keyRotationIntervalSeconds: p.keyRotationInterval?.toSeconds(),\n      encryptionMethod: { tsEncryptionMethod: p.method },\n      spekeKeyProvider: {\n        certificateArn: p.certificate?.certificateArn,\n        drmSystems: (p.drmSystems ?? defaultDrm).map(d => d.toString()),\n        encryptionContractConfiguration: {\n          presetSpeke20Audio: p.audioPreset ?? PresetSpeke20Audio.PRESET_AUDIO_1,\n          presetSpeke20Video: p.videoPreset ?? PresetSpeke20Video.PRESET_VIDEO_1,\n        },\n        url: p.url,\n        resourceId: p.resourceId,\n        roleArn: p.role.roleArn,\n      },\n    };\n  }\n\n  /** @internal */\n  public _getRole(): IRole | undefined { return this.config.role; }\n\n  /** @internal */\n  public _getCertificate(): ICertificate | undefined { return this.config.certificate; }\n}\n\n/**\n * Encryption configuration for ISM (Microsoft Smooth Streaming) segments.\n *\n * ISM only supports CENC encryption with PlayReady DRM.\n * Audio and video presets are always SHARED.\n *\n * Use `IsmEncryption.speke()` to create an instance.\n */\nexport class IsmEncryption extends EncryptionConfiguration {\n  /**\n   * Create a SPEKE-based encryption configuration for ISM segments.\n   */\n  public static speke(props: IsmSpekeEncryptionProps): IsmEncryption {\n    if (!props.url.startsWith('https://')) {\n      throw new UnscopedValidationError(lit`SpekeUrlHttpsRequired`, 'SPEKE key provider URL must use HTTPS.');\n    }\n    return new IsmEncryption(props);\n  }\n\n  private readonly config: IsmSpekeEncryptionProps;\n  private constructor(props: IsmSpekeEncryptionProps) {\n    super();\n    this.config = props;\n  }\n\n  /** @internal */\n  public _bind(_scope: Construct): CfnOriginEndpoint.EncryptionProperty {\n    const p = this.config;\n    return {\n      encryptionMethod: { ismEncryptionMethod: 'CENC' },\n      spekeKeyProvider: {\n        certificateArn: p.certificate?.certificateArn,\n        drmSystems: (p.drmSystems ?? [IsmDrmSystem.PLAYREADY]).map(d => d.toString()),\n        encryptionContractConfiguration: {\n          presetSpeke20Audio: PresetSpeke20Audio.SHARED,\n          presetSpeke20Video: PresetSpeke20Video.SHARED,\n        },\n        url: p.url,\n        resourceId: p.resourceId,\n        roleArn: p.role.roleArn,\n      },\n    };\n  }\n\n  /** @internal */\n  public _getRole(): IRole | undefined { return this.config.role; }\n\n  /** @internal */\n  public _getCertificate(): ICertificate | undefined { return this.config.certificate; }\n}\n\n/**\n * The segment configuration, including the segment name, duration, and other configuration values.\n */\nexport interface SegmentConfiguration {\n  /**\n   * The container type for this segment (TS or CMAF)\n   */\n  readonly containerType: ContainerType;\n  /**\n   * Whether the segment includes I-frame-only streams.\n   *\n   * @default undefined - Not specified.\n   */\n  readonly includeIframeOnlyStreams?: boolean;\n  /**\n   * The SCTE-35 configuration associated with the segment.\n   *\n   * The SCTE-35 message types that you want to be treated as ad markers in the output.\n   *\n   * @default - No SCTE filtering\n   */\n  readonly scteFilter?: ScteMessageType[];\n  /**\n   * Controls whether SCTE-35 messages are included in segment files.\n   *\n   * @default - SCTE-35 messages are not included in segments\n   */\n  readonly scteInSegments?: ScteInSegments;\n  /**\n   * The duration of the segments.\n   *\n   * @default 6\n   */\n  readonly segmentDuration?: Duration;\n  /**\n   * The name of the segment associated with the origin endpoint.\n   *\n   * @default segment\n   */\n  readonly segmentName?: string;\n  /**\n   * Whether the segment includes DVB subtitles.\n   *\n   * @default false\n   */\n  readonly tsIncludeDvbSubtitles?: boolean;\n  /**\n   * Whether the segment is an audio rendition group.\n   *\n   * @default false\n   */\n  readonly tsUseAudioRenditionGroup?: boolean;\n  /**\n   * Encryption configuration for the segment.\n   *\n   * @default - No encryption\n   */\n  readonly encryption?: EncryptionConfiguration;\n}\n\n/**\n * Base properties common to all segment configurations.\n */\nexport interface SegmentPropsBase {\n  /**\n   * Whether to include I-frame-only streams.\n   *\n   * @default false\n   */\n  readonly includeIframeOnlyStreams?: boolean;\n\n  /**\n   * Duration of each segment.\n   *\n   * @default Duration.seconds(6)\n   */\n  readonly duration?: Duration;\n\n  /**\n   * Name of the segment.\n   *\n   * @default 'segment'\n   */\n  readonly name?: string;\n}\n\n/**\n * Properties for TS (Transport Stream) segment configuration.\n */\nexport interface TsSegmentProps extends SegmentPropsBase {\n  /**\n   * SCTE-35 message types to treat as ad markers.\n   *\n   * @default - no filtering\n   */\n  readonly scteFilter?: ScteMessageType[];\n\n  /**\n   * Controls whether SCTE-35 messages are included in segment files.\n   *\n   * @default - SCTE-35 messages are not included in segments\n   */\n  readonly scteInSegments?: ScteInSegments;\n\n  /**\n   * Whether to include DVB subtitles.\n   *\n   * @default false\n   */\n  readonly includeDvbSubtitles?: boolean;\n\n  /**\n   * Whether to use audio rendition groups.\n   *\n   * @default false\n   */\n  readonly useAudioRenditionGroup?: boolean;\n\n  /**\n   * Encryption configuration for the TS segment.\n   *\n   * Use `TsEncryption.speke()` to create the configuration.\n   *\n   * @default - No encryption\n   */\n  readonly encryption?: TsEncryption;\n}\n\n/**\n * Properties for CMAF segment configuration.\n */\nexport interface CmafSegmentProps extends SegmentPropsBase {\n  /**\n   * SCTE-35 message types to treat as ad markers.\n   *\n   * @default - no filtering\n   */\n  readonly scteFilter?: ScteMessageType[];\n\n  /**\n   * Controls whether SCTE-35 messages are included in segment files.\n   *\n   * @default - SCTE-35 messages are not included in segments\n   */\n  readonly scteInSegments?: ScteInSegments;\n\n  /**\n   * Encryption configuration for the CMAF segment.\n   *\n   * Use `CmafEncryption.speke()` to create the configuration.\n   *\n   * @default - No encryption\n   */\n  readonly encryption?: CmafEncryption;\n}\n\n/**\n * Properties for ISM (Microsoft Smooth Streaming) segment configuration.\n */\nexport interface IsmSegmentProps extends SegmentPropsBase {\n  /**\n   * Encryption configuration for the ISM segment.\n   *\n   * Use `IsmEncryption.speke()` to create the configuration.\n   *\n   * @default - No encryption\n   */\n  readonly encryption?: IsmEncryption;\n}\n\n/**\n * Helper class for creating segment configurations.\n */\nexport class Segment {\n  /**\n   * Create a TS (Transport Stream) segment configuration.\n   *\n   * Use this for endpoints with ContainerType.TS.\n   */\n  public static ts(props: TsSegmentProps = {}): SegmentConfiguration {\n    return {\n      containerType: ContainerType.TS,\n      includeIframeOnlyStreams: props.includeIframeOnlyStreams,\n      scteFilter: props.scteFilter,\n      scteInSegments: props.scteInSegments,\n      segmentDuration: props.duration,\n      segmentName: props.name,\n      tsIncludeDvbSubtitles: props.includeDvbSubtitles,\n      tsUseAudioRenditionGroup: props.useAudioRenditionGroup,\n      encryption: props.encryption,\n    };\n  }\n\n  /**\n   * Create a CMAF segment configuration.\n   *\n   * Use this for endpoints with ContainerType.CMAF.\n   */\n  public static cmaf(props: CmafSegmentProps = {}): SegmentConfiguration {\n    return {\n      containerType: ContainerType.CMAF,\n      includeIframeOnlyStreams: props.includeIframeOnlyStreams,\n      scteFilter: props.scteFilter,\n      scteInSegments: props.scteInSegments,\n      segmentDuration: props.duration,\n      segmentName: props.name,\n      encryption: props.encryption,\n    };\n  }\n\n  /**\n   * Create an ISM (Microsoft Smooth Streaming) segment configuration.\n   *\n   * Use this for endpoints with ContainerType.ISM.\n   */\n  public static ism(props: IsmSegmentProps = {}): SegmentConfiguration {\n    return {\n      containerType: ContainerType.ISM,\n      includeIframeOnlyStreams: props.includeIframeOnlyStreams,\n      segmentDuration: props.duration,\n      segmentName: props.name,\n      encryption: props.encryption,\n    };\n  }\n}\n\nabstract class OriginEndpointBase extends Resource implements IOriginEndpoint {\n  /**\n   * Creates an OriginEndpoint construct that represents an external (imported) Origin Endpoint.\n   */\n  public static fromOriginEndpointAttributes(scope: Construct, id: string, attrs: OriginEndpointAttributes): IOriginEndpoint {\n    class Import extends OriginEndpointBase implements IOriginEndpoint {\n      protected hlsManifests: CfnOriginEndpoint.HlsManifestConfigurationProperty[] = [];\n      protected llHlsManifests: CfnOriginEndpoint.LowLatencyHlsManifestConfigurationProperty[] = [];\n      protected dashManifests: CfnOriginEndpoint.DashManifestConfigurationProperty[] = [];\n      protected mssManifests: CfnOriginEndpoint.MssManifestConfigurationProperty[] = [];\n      protected segment?: SegmentConfiguration | undefined;\n      public readonly policy = undefined;\n      public readonly channelGroupName = attrs.channelGroupName;\n      public readonly channelName = attrs.channelName;\n      public readonly originEndpointName = attrs.originEndpointName;\n      public readonly createdAt = undefined;\n      public readonly modifiedAt = undefined;\n      public readonly hlsManifestUrls = undefined;\n      public readonly lowLatencyHlsManifestUrls = undefined;\n      public readonly dashManifestUrls = undefined;\n      public readonly mssManifestUrls = undefined;\n      protected autoCreatePolicy = false;\n      public readonly originEndpointArn = Stack.of(this).formatArn({\n        service: 'mediapackagev2',\n        resource: `channelGroup/${attrs.channelGroupName}/channel/${this.channelName}/originEndpoint`,\n        arnFormat: ArnFormat.SLASH_RESOURCE_NAME,\n        resourceName: this.originEndpointName,\n      });\n    }\n\n    return new Import(scope, id);\n  }\n\n  public abstract readonly channelGroupName: string;\n  public abstract readonly channelName: string;\n  public abstract readonly originEndpointName: string;\n  public abstract readonly originEndpointArn: string;\n  public abstract readonly createdAt?: string;\n  public abstract readonly modifiedAt?: string;\n  public abstract readonly hlsManifestUrls?: string[];\n  public abstract readonly lowLatencyHlsManifestUrls?: string[];\n  public abstract readonly dashManifestUrls?: string[];\n  public abstract readonly mssManifestUrls?: string[];\n\n  /**\n   * A reference to this Origin Endpoint resource.\n   * Required by the auto-generated IOriginEndpointRef interface.\n   */\n  public get originEndpointRef(): OriginEndpointReference {\n    return {\n      originEndpointArn: this.originEndpointArn,\n    };\n  }\n\n  protected abstract hlsManifests: CfnOriginEndpoint.HlsManifestConfigurationProperty[];\n  protected abstract llHlsManifests: CfnOriginEndpoint.LowLatencyHlsManifestConfigurationProperty[];\n  protected abstract dashManifests: CfnOriginEndpoint.DashManifestConfigurationProperty[];\n  protected abstract mssManifests: CfnOriginEndpoint.MssManifestConfigurationProperty[];\n  protected abstract segment?: SegmentConfiguration;\n  /**\n   * The resource policy associated with this origin endpoint.\n   *\n   * If `autoCreatePolicy` is true, an `OriginEndpointPolicy` will be created upon the\n   * first call to addToResourcePolicy(s).\n   */\n  public abstract policy?: OriginEndpointPolicy;\n\n  /**\n   * Indicates if an origin endpoint resource policy should automatically be created upon\n   * the first call to `addToResourcePolicy`.\n   */\n  protected abstract autoCreatePolicy: boolean;\n\n  /**\n   * CDN authorization configuration to be applied when the policy is created.\n   */\n  private cdnAuthConfig?: CdnAuthConfiguration;\n\n  /**\n   * Set CDN auth config. Used by subclass constructors.\n   * @internal\n   */\n  protected _setCdnAuth(cdnAuth: CdnAuthConfiguration): void {\n    if (!this.cdnAuthConfig) {\n      this.cdnAuthConfig = cdnAuth;\n    }\n  }\n\n  /**\n   * Configure origin endpoint policy.\n   *\n   * You can only add 1 OriginEndpointPolicy to an OriginEndpoint.\n   * If you have already defined one, it will append to the policy already created.\n   *\n   * @param statement - The policy statement to add\n   * @param cdnAuth - Optional CDN authorization configuration. If provided, the policy will be\n   *                  created with CDN authentication enabled using secrets from AWS Secrets Manager.\n   *                  If cdnAuth is provided multiple times, only the first configuration is used.\n   */\n  public addToResourcePolicy(statement: PolicyStatement, cdnAuth?: CdnAuthConfiguration): AddToResourcePolicyResult {\n    // Store CDN auth config if provided (only if not already set)\n    if (cdnAuth && !this.cdnAuthConfig) {\n      this.cdnAuthConfig = cdnAuth;\n    }\n\n    if (!this.policy && this.autoCreatePolicy) {\n      this.policy = new OriginEndpointPolicy(this, 'Policy', {\n        originEndpoint: this,\n        cdnAuth: this.cdnAuthConfig,\n      });\n    }\n\n    if (this.policy) {\n      this.policy.document.addStatements(statement);\n      return { statementAdded: true, policyDependable: this.policy };\n    }\n\n    return { statementAdded: false };\n  }\n\n  /**\n   * Validate and modify Segment configuration for endpoint.\n   */\n  protected segmentValidation(segmentContainerType: ContainerType, segment?: SegmentConfiguration): CfnOriginEndpoint.SegmentProperty | undefined {\n    if (segment?.segmentDuration && (segment.segmentDuration?.toSeconds() < 1 || segment.segmentDuration?.toSeconds() > 30)) {\n      throw new ValidationError(lit`SegmentDurationRange`, 'Segment Duration needs to be between 1-30 seconds.', this);\n    }\n\n    if (segmentContainerType != ContainerType.TS && (segment?.tsIncludeDvbSubtitles || segment?.tsUseAudioRenditionGroup)) {\n      throw new ValidationError(lit`TsOptionsIncompatible`, 'Disable TS Segment options for DvbSubtitles and AudioRenditionGroups when using CMAF.', this);\n    }\n\n    return {\n      includeIframeOnlyStreams: segment?.includeIframeOnlyStreams,\n      segmentDurationSeconds: segment?.segmentDuration?.toSeconds(),\n      segmentName: segment?.segmentName,\n      tsIncludeDvbSubtitles: segment?.tsIncludeDvbSubtitles,\n      tsUseAudioRenditionGroup: segment?.tsUseAudioRenditionGroup,\n      scte: (segment?.scteFilter || segment?.scteInSegments) ? {\n        scteFilter: segment?.scteFilter,\n        scteInSegments: segment?.scteInSegments,\n      } : undefined,\n      encryption: segment?.encryption?._bind(this),\n    };\n  }\n\n  /**\n   * Create a CloudWatch metric.\n   *\n   * @param metricName name of the metric.\n   * @param props metric options.\n   */\n  public metric(metricName: string, props?: MetricOptions): Metric {\n    return new Metric({\n      metricName,\n      namespace: 'AWS/MediaPackage',\n      dimensionsMap: {\n        ChannelGroup: this.channelGroupName,\n        Channel: this.channelName,\n        OriginEndpoint: this.originEndpointName,\n      },\n      ...props,\n    }).attachTo(this);\n  }\n\n  /**\n   * Returns Metric for Ingress Bytes\n   *\n   * @default - sum over 60 seconds\n   */\n  public metricIngressBytes(props?: MetricOptions): Metric {\n    return this.metric('IngressBytes', {\n      statistic: 'sum',\n      period: Duration.seconds(60),\n      unit: Unit.BYTES,\n      ...props,\n    });\n  }\n\n  /**\n   * Returns Metric for Egress Bytes\n   *\n   * @default - sum over 60 seconds\n   */\n  public metricEgressBytes(props?: MetricOptions): Metric {\n    return this.metric('EgressBytes', {\n      statistic: 'sum',\n      period: Duration.seconds(60),\n      unit: Unit.BYTES,\n      ...props,\n    });\n  }\n\n  /**\n   * Returns Metric for Ingress response time\n   *\n   * @default - average over 60 seconds\n   */\n  public metricIngressResponseTime(props?: MetricOptions): Metric {\n    return this.metric('IngressResponseTime', {\n      statistic: 'avg',\n      period: Duration.seconds(60),\n      unit: Unit.MILLISECONDS,\n      ...props,\n    });\n  }\n\n  /**\n   * Returns Metric for Egress Response time\n   *\n   * @default - average over 60 seconds\n   */\n  public metricEgressResponseTime(props?: MetricOptions): Metric {\n    return this.metric('EgressResponseTime', {\n      statistic: 'avg',\n      period: Duration.seconds(60),\n      unit: Unit.MILLISECONDS,\n      ...props,\n    });\n  }\n\n  /**\n   * Returns Metric for Egress Request Count\n   *\n   * @default - sum over 60 seconds\n   */\n  public metricEgressRequestCount(props?: MetricOptions): Metric {\n    return this.metric('EgressRequestCount', {\n      statistic: 'sum',\n      period: Duration.seconds(60),\n      unit: Unit.COUNT,\n      ...props,\n    });\n  }\n\n  /**\n   * Returns Metric for Ingress Request Count\n   *\n   * @default - sum over 60 seconds\n   */\n  public metricIngressRequestCount(props?: MetricOptions): Metric {\n    return this.metric('IngressRequestCount', {\n      statistic: 'sum',\n      period: Duration.seconds(60),\n      unit: Unit.COUNT,\n      ...props,\n    });\n  }\n}\n\n/**\n * Defines an AWS Elemental MediaPackage V2 Origin Endpoint\n */\n@propertyInjectable\nexport class OriginEndpoint extends OriginEndpointBase implements IOriginEndpoint {\n  /** Uniquely identifies this class. */\n  public static readonly PROPERTY_INJECTION_ID: string = '@aws-cdk.aws-mediapackagev2-alpha.OriginEndpoint';\n\n  public readonly channelGroupName: string;\n  public readonly channelName: string;\n  public readonly originEndpointName: string;\n  public readonly originEndpointArn: string;\n\n  /**\n   * The timestamp of the creation of the origin endpoint.\n   */\n  public readonly createdAt?: string;\n\n  /**\n   * The timestamp of the modification of the origin endpoint.\n   */\n  public readonly modifiedAt?: string;\n\n  /**\n   * Array containing Low Latency HLS Manifests created by the OriginEndpoint.\n   */\n  public readonly lowLatencyHlsManifestUrls?: string[];\n\n  /**\n   * Array containing HLS Manifests created by the OriginEndpoint.\n   */\n  public readonly hlsManifestUrls?: string[];\n\n  /**\n   * Array containing DASH Manifests created by the OriginEndpoint.\n   */\n  public readonly dashManifestUrls?: string[];\n  /**\n   * Array containing MSS Manifests created by the OriginEndpoint.\n   */\n  public readonly mssManifestUrls?: string[];\n  /**\n   * The resource policy associated with this origin endpoint.\n   *\n   * If `autoCreatePolicy` is true, an `OriginEndpointPolicy` will be created upon the\n   * first call to addToResourcePolicy(s).\n   */\n  public policy?: OriginEndpointPolicy;\n  protected autoCreatePolicy = true;\n  protected hlsManifests: CfnOriginEndpoint.HlsManifestConfigurationProperty[] = [];\n  protected llHlsManifests: CfnOriginEndpoint.LowLatencyHlsManifestConfigurationProperty[] = [];\n  protected dashManifests: CfnOriginEndpoint.DashManifestConfigurationProperty[] = [];\n  protected mssManifests: CfnOriginEndpoint.MssManifestConfigurationProperty[] = [];\n  protected segment?: SegmentConfiguration;\n\n  constructor(scope: Construct, id: string, props: OriginEndpointProps) {\n    super(scope, id, {\n      physicalName: props?.originEndpointName ?? Lazy.string({\n        produce: () => Names.uniqueResourceName(this, {\n          maxLength: 256,\n        }),\n      }),\n    });\n\n    // Enhanced CDK Analytics Telemetry\n    addConstructMetadata(this, props);\n\n    // Validate originEndpointName if provided\n    if (props.originEndpointName != null && !Token.isUnresolved(props.originEndpointName)) {\n      if (props.originEndpointName.length < 1 || props.originEndpointName.length > 256) {\n        throw new ValidationError(lit`OriginEndpointNameLength`, 'Origin endpoint name must be between 1 and 256 characters in length.', this);\n      }\n      if (!props.originEndpointName.match(/^[a-zA-Z0-9_-]+$/)) {\n        throw new ValidationError(lit`OriginEndpointNamePattern`, 'Origin endpoint name must only contain alphanumeric characters, hyphens, and underscores.', this);\n      }\n    }\n\n    // Validate description if provided\n    if (props.description && !Token.isUnresolved(props.description) && props.description.length > 1024) {\n      throw new ValidationError(lit`OriginEndpointDescriptionLength`, 'Origin endpoint description must not exceed 1024 characters.', this);\n    }\n\n    this.segment = props.segment;\n\n    // Get container type from segment\n    const containerType = props.segment.containerType;\n\n    if (props?.startoverWindow && (props.startoverWindow.toSeconds() < 60 || props.startoverWindow.toSeconds() > 1209600)) {\n      throw new ValidationError(lit`StartoverWindowRange`, 'Startover Window needs to be between 60-1209600 seconds.', this);\n    }\n\n    props.manifests.forEach(manifest => {\n      manifest._bind({\n        hlsManifests: this.hlsManifests,\n        llHlsManifests: this.llHlsManifests,\n        dashManifests: this.dashManifests,\n        mssManifests: this.mssManifests,\n        segment: props.segment,\n      });\n    });\n\n    // Validate manifest and container type compatibility\n    if (this.mssManifests.length > 0 && containerType !== ContainerType.ISM) {\n      throw new ValidationError(lit`MssRequiresIsm`, 'MSS manifests require ISM container type. Use Segment.ism() for MSS manifests.', this);\n    }\n\n    if (this.dashManifests.length > 0 && containerType !== ContainerType.CMAF) {\n      throw new ValidationError(lit`DashRequiresCmaf`, 'DASH manifests require CMAF container type. Use Segment.cmaf() for DASH manifests.', this);\n    }\n\n    if ((this.hlsManifests.length > 0 || this.llHlsManifests.length > 0) && containerType === ContainerType.ISM) {\n      throw new ValidationError(lit`HlsIncompatibleWithIsm`, 'HLS and Low Latency HLS manifests are not supported with ISM container type. Use Segment.cmaf() or Segment.ts() for HLS manifests.', this);\n    }\n\n    // Validate DRM signalling requires encryption\n    if (this.dashManifests.some(m => m.drmSignaling) && !props.segment.encryption) {\n      throw new ValidationError(lit`DrmSignallingRequiresEncryption`, 'DRM signalling requires encryption to be configured on the endpoint.', this);\n    }\n\n    const origin = new CfnOriginEndpoint(this, 'Resource', {\n      channelName: props.channel.channelName,\n      channelGroupName: props.channel.channelGroupName,\n      originEndpointName: this.physicalName,\n      description: props.description,\n      tags: props?.tags ? renderTags(props.tags) : undefined,\n      hlsManifests: Lazy.any({ produce: () => this.hlsManifests }, { omitEmptyArray: true }),\n      lowLatencyHlsManifests: Lazy.any({ produce: () => this.llHlsManifests }, { omitEmptyArray: true }),\n      dashManifests: Lazy.any({ produce: () => this.dashManifests }, { omitEmptyArray: true }),\n      mssManifests: Lazy.any({ produce: () => this.mssManifests }, { omitEmptyArray: true }),\n      containerType: containerType,\n      startoverWindowSeconds: props.startoverWindow?.toSeconds(),\n      segment: this.segmentValidation(containerType, props.segment),\n      forceEndpointErrorConfiguration: props.forceEndpointConfigurationConditions ? {\n        endpointErrorConditions: props.forceEndpointConfigurationConditions,\n      }: undefined,\n    });\n\n    // The channelName/channelGroupName are rendered as literal strings (not CFN Refs), so\n    // CloudFormation cannot infer the dependency. We add direct CfnResource-level DependsOn\n    // to guarantee deploy ordering without triggering CDK's subtree-level cycle detection.\n    // For imported constructs, defaultChild is undefined (no CFN resource to order against).\n    const encryptionRole = props.segment.encryption?._getRole();\n    if (encryptionRole) origin.node.addDependency(encryptionRole);\n    const encryptionCert = props.segment.encryption?._getCertificate();\n    if (encryptionCert) origin.node.addDependency(encryptionCert);\n    const channelCfn = props.channel.node.defaultChild as CfnResource | undefined;\n    if (channelCfn && CfnResource.isCfnResource(channelCfn)) {\n      origin.addDependency(channelCfn);\n    }\n    const groupCfn = props.channel.channelGroup?.node.defaultChild as CfnResource | undefined;\n    if (groupCfn && CfnResource.isCfnResource(groupCfn)) {\n      origin.addDependency(groupCfn);\n    }\n\n    this.lowLatencyHlsManifestUrls = this.llHlsManifests.map((_, i) => Fn.select(i, origin.attrLowLatencyHlsManifestUrls));\n    this.hlsManifestUrls = this.hlsManifests.map((_, i) => Fn.select(i, origin.attrHlsManifestUrls));\n    this.dashManifestUrls = this.dashManifests.map((_, i) => Fn.select(i, origin.attrDashManifestUrls));\n    this.mssManifestUrls = this.mssManifests.map((_, i) => Fn.select(i, origin.attrMssManifestUrls));\n    this.createdAt = origin.attrCreatedAt;\n    this.modifiedAt = origin.attrModifiedAt;\n    this.channelGroupName = origin.channelGroupName;\n    this.channelName = origin.channelName;\n    this.originEndpointName = origin.originEndpointName;\n    this.originEndpointArn = origin.attrArn;\n\n    origin.applyRemovalPolicy(props?.removalPolicy ?? RemovalPolicy.DESTROY);\n\n    // Pre-set CDN auth config if provided in props\n    if (props.cdnAuth) {\n      this._setCdnAuth(props.cdnAuth);\n    }\n  }\n}\n"]}
|