1{
2    "smithy": "1.0",
3    "metadata": {
4        "suppressions": [
5            {
6                "id": "HttpMethodSemantics",
7                "namespace": "*"
8            },
9            {
10                "id": "HttpResponseCodeSemantics",
11                "namespace": "*"
12            },
13            {
14                "id": "PaginatedTrait",
15                "namespace": "*"
16            },
17            {
18                "id": "HttpHeaderTrait",
19                "namespace": "*"
20            },
21            {
22                "id": "HttpUriConflict",
23                "namespace": "*"
24            },
25            {
26                "id": "Service",
27                "namespace": "*"
28            }
29        ]
30    },
31    "shapes": {
32        "com.amazonaws.mediatailor#AccessConfiguration": {
33            "type": "structure",
34            "members": {
35                "AccessType": {
36                    "target": "com.amazonaws.mediatailor#AccessType",
37                    "traits": {
38                        "smithy.api#documentation": "<p>The type of authentication used to access content from HttpConfiguration::BaseUrl on your source location. Accepted value: S3_SIGV4.</p> <p>S3_SIGV4 - AWS Signature Version 4 authentication for Amazon S3 hosted virtual-style access. If your source location base URL is an Amazon S3 bucket, MediaTailor can use AWS Signature Version 4 (SigV4) authentication to access the bucket where your source content is stored. Your MediaTailor source location baseURL must follow the S3 virtual hosted-style request URL format. For example, https://bucket-name.s3.Region.amazonaws.com/key-name.</p> <p>Before you can use S3_SIGV4, you must meet these requirements:</p> <p>• You must allow MediaTailor to access your S3 bucket by granting mediatailor.amazonaws.com principal access in IAM. For information about configuring access in IAM, see Access management in the IAM User Guide.</p> <p>• The mediatailor.amazonaws.com service principal must have permissions to read all top level manifests referenced by the VodSource packaging configurations.</p> <p>• The caller of the API must have s3:GetObject IAM permissions to read all top level manifests referenced by your MediaTailor VodSource packaging configurations.</p>"
39                    }
40                }
41            },
42            "traits": {
43                "smithy.api#documentation": "<p>Access configuration parameters.</p>"
44            }
45        },
46        "com.amazonaws.mediatailor#AccessType": {
47            "type": "string",
48            "traits": {
49                "smithy.api#enum": [
50                    {
51                        "value": "S3_SIGV4",
52                        "name": "S3_SIGV4"
53                    }
54                ]
55            }
56        },
57        "com.amazonaws.mediatailor#AdBreak": {
58            "type": "structure",
59            "members": {
60                "MessageType": {
61                    "target": "com.amazonaws.mediatailor#MessageType",
62                    "traits": {
63                        "smithy.api#documentation": "<p>The SCTE-35 ad insertion type. Accepted value: SPLICE_INSERT.</p>"
64                    }
65                },
66                "OffsetMillis": {
67                    "target": "com.amazonaws.mediatailor#__long",
68                    "traits": {
69                        "smithy.api#documentation": "<p>How long (in milliseconds) after the beginning of the program that an ad starts. This value must fall within 100ms of a segment boundary, otherwise the ad break will be skipped.</p>"
70                    }
71                },
72                "Slate": {
73                    "target": "com.amazonaws.mediatailor#SlateSource",
74                    "traits": {
75                        "smithy.api#documentation": "<p>Ad break slate configuration.</p>"
76                    }
77                },
78                "SpliceInsertMessage": {
79                    "target": "com.amazonaws.mediatailor#SpliceInsertMessage",
80                    "traits": {
81                        "smithy.api#documentation": "<p>This defines the SCTE-35 splice_insert() message inserted around the ad. For information about using splice_insert(), see the SCTE-35 specficiaiton, section 9.7.3.1.</p>"
82                    }
83                }
84            },
85            "traits": {
86                "smithy.api#documentation": "<p>Ad break configuration parameters.</p>"
87            }
88        },
89        "com.amazonaws.mediatailor#AdMarkerPassthrough": {
90            "type": "structure",
91            "members": {
92                "Enabled": {
93                    "target": "com.amazonaws.mediatailor#__boolean",
94                    "traits": {
95                        "smithy.api#documentation": "<p>Enables ad marker passthrough for your configuration.</p>"
96                    }
97                }
98            },
99            "traits": {
100                "smithy.api#documentation": "<p>For HLS, when set to true, MediaTailor passes through EXT-X-CUE-IN, EXT-X-CUE-OUT, and EXT-X-SPLICEPOINT-SCTE35 ad markers from the origin manifest to the MediaTailor personalized manifest.</p> <p>No logic is applied to these ad markers. For example, if EXT-X-CUE-OUT has a value of 60, but no ads are filled for that ad break, MediaTailor will not set the value to 0.</p>"
101            }
102        },
103        "com.amazonaws.mediatailor#AvailSuppression": {
104            "type": "structure",
105            "members": {
106                "Mode": {
107                    "target": "com.amazonaws.mediatailor#Mode",
108                    "traits": {
109                        "smithy.api#documentation": "<p>Sets the ad suppression mode. By default, ad suppression is off and all ad breaks are filled with ads or slate. When Mode is set to BEHIND_LIVE_EDGE, ad suppression is active and MediaTailor won't fill ad breaks on or behind the ad suppression Value time in the manifest lookback window.</p>"
110                    }
111                },
112                "Value": {
113                    "target": "com.amazonaws.mediatailor#__string",
114                    "traits": {
115                        "smithy.api#documentation": "<p>A live edge offset time in HH:MM:SS. MediaTailor won't fill ad breaks on or behind this time in the manifest lookback window. If Value is set to 00:00:00, it is in sync with the live edge, and MediaTailor won't fill any ad breaks on or behind the live edge. If you set a Value time, MediaTailor won't fill any ad breaks on or behind this time in the manifest lookback window. For example, if you set 00:45:00, then MediaTailor will fill ad breaks that occur within 45 minutes behind the live edge, but won't fill ad breaks on or behind 45 minutes behind the live edge.</p>"
116                    }
117                }
118            },
119            "traits": {
120                "smithy.api#documentation": "<p>The configuration for avail suppression, also known as ad suppression. For more information about ad suppression, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Suppression</a>.</p>"
121            }
122        },
123        "com.amazonaws.mediatailor#BadRequestException": {
124            "type": "structure",
125            "members": {
126                "Message": {
127                    "target": "com.amazonaws.mediatailor#__string"
128                }
129            },
130            "traits": {
131                "smithy.api#documentation": "Invalid request parameters.",
132                "smithy.api#error": "client",
133                "smithy.api#httpError": 400
134            }
135        },
136        "com.amazonaws.mediatailor#Bumper": {
137            "type": "structure",
138            "members": {
139                "EndUrl": {
140                    "target": "com.amazonaws.mediatailor#__string",
141                    "traits": {
142                        "smithy.api#documentation": "<p>The URL for the end bumper asset.</p>"
143                    }
144                },
145                "StartUrl": {
146                    "target": "com.amazonaws.mediatailor#__string",
147                    "traits": {
148                        "smithy.api#documentation": "<p>The URL for the start bumper asset.</p>"
149                    }
150                }
151            },
152            "traits": {
153                "smithy.api#documentation": "<p>The configuration for bumpers. Bumpers are short audio or video clips that play at the start or before the end of an ad break. To learn more about bumpers, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/bumpers.html\">Bumpers</a>.</p>"
154            }
155        },
156        "com.amazonaws.mediatailor#CdnConfiguration": {
157            "type": "structure",
158            "members": {
159                "AdSegmentUrlPrefix": {
160                    "target": "com.amazonaws.mediatailor#__string",
161                    "traits": {
162                        "smithy.api#documentation": "<p>A non-default content delivery network (CDN) to serve ad segments. By default, AWS Elemental MediaTailor uses Amazon CloudFront with default cache settings as its CDN for ad segments. To set up an alternate CDN, create a rule in your CDN for the origin ads.mediatailor.&amp;lt;region&gt;.amazonaws.com. Then specify the rule's name in this AdSegmentUrlPrefix. When AWS Elemental MediaTailor serves a manifest, it reports your CDN as the source for ad segments.</p>"
163                    }
164                },
165                "ContentSegmentUrlPrefix": {
166                    "target": "com.amazonaws.mediatailor#__string",
167                    "traits": {
168                        "smithy.api#documentation": "<p>A content delivery network (CDN) to cache content segments, so that content requests don’t always have to go to the origin server. First, create a rule in your CDN for the content segment origin server. Then specify the rule's name in this ContentSegmentUrlPrefix. When AWS Elemental MediaTailor serves a manifest, it reports your CDN as the source for content segments.</p>"
169                    }
170                }
171            },
172            "traits": {
173                "smithy.api#documentation": "<p>The configuration for using a content delivery network (CDN), like Amazon CloudFront, for content and ad segment management.</p>"
174            }
175        },
176        "com.amazonaws.mediatailor#Channel": {
177            "type": "structure",
178            "members": {
179                "Arn": {
180                    "target": "com.amazonaws.mediatailor#__string",
181                    "traits": {
182                        "smithy.api#documentation": "<p>The ARN of the channel.</p>",
183                        "smithy.api#required": {}
184                    }
185                },
186                "ChannelName": {
187                    "target": "com.amazonaws.mediatailor#__string",
188                    "traits": {
189                        "smithy.api#documentation": "<p>The name of the channel.</p>",
190                        "smithy.api#required": {}
191                    }
192                },
193                "ChannelState": {
194                    "target": "com.amazonaws.mediatailor#__string",
195                    "traits": {
196                        "smithy.api#documentation": "<p>Returns the state whether the channel is running or not.</p>",
197                        "smithy.api#required": {}
198                    }
199                },
200                "CreationTime": {
201                    "target": "com.amazonaws.mediatailor#__timestampUnix",
202                    "traits": {
203                        "smithy.api#documentation": "<p>The timestamp of when the channel was created.</p>"
204                    }
205                },
206                "LastModifiedTime": {
207                    "target": "com.amazonaws.mediatailor#__timestampUnix",
208                    "traits": {
209                        "smithy.api#documentation": "<p>The timestamp of when the channel was last modified.</p>"
210                    }
211                },
212                "Outputs": {
213                    "target": "com.amazonaws.mediatailor#ResponseOutputs",
214                    "traits": {
215                        "smithy.api#documentation": "<p>The channel's output properties.</p>",
216                        "smithy.api#required": {}
217                    }
218                },
219                "PlaybackMode": {
220                    "target": "com.amazonaws.mediatailor#__string",
221                    "traits": {
222                        "smithy.api#documentation": "<p>The type of playback mode for this channel. Possible values: ONCE or LOOP.</p>",
223                        "smithy.api#required": {}
224                    }
225                },
226                "Tags": {
227                    "target": "com.amazonaws.mediatailor#__mapOf__string",
228                    "traits": {
229                        "smithy.api#documentation": "<p>The tags to assign to the channel.</p>",
230                        "smithy.api#jsonName": "tags"
231                    }
232                }
233            },
234            "traits": {
235                "smithy.api#documentation": "<p>The configuration parameters for a channel.</p>"
236            }
237        },
238        "com.amazonaws.mediatailor#ChannelState": {
239            "type": "string",
240            "traits": {
241                "smithy.api#enum": [
242                    {
243                        "value": "RUNNING",
244                        "name": "RUNNING"
245                    },
246                    {
247                        "value": "STOPPED",
248                        "name": "STOPPED"
249                    }
250                ]
251            }
252        },
253        "com.amazonaws.mediatailor#ConfigurationAliasesRequest": {
254            "type": "map",
255            "key": {
256                "target": "com.amazonaws.mediatailor#__string",
257                "traits": {
258                    "smithy.api#documentation": "<p>The dynamic variable that has aliases.</p>"
259                }
260            },
261            "value": {
262                "target": "com.amazonaws.mediatailor#__mapOf__string",
263                "traits": {
264                    "smithy.api#documentation": "<p>Map of aliases to the value to be used at request time.</p>"
265                }
266            },
267            "traits": {
268                "smithy.api#documentation": "<p>The predefined aliases for dynamic variables.</p>"
269            }
270        },
271        "com.amazonaws.mediatailor#ConfigurationAliasesResponse": {
272            "type": "map",
273            "key": {
274                "target": "com.amazonaws.mediatailor#__string",
275                "traits": {
276                    "smithy.api#documentation": "<p>The dynamic variable that has aliases.</p>"
277                }
278            },
279            "value": {
280                "target": "com.amazonaws.mediatailor#__mapOf__string",
281                "traits": {
282                    "smithy.api#documentation": "<p>Map of aliases to the value to be used at request time.</p>"
283                }
284            },
285            "traits": {
286                "smithy.api#documentation": "<p>The predefined aliases for dynamic variables.</p>"
287            }
288        },
289        "com.amazonaws.mediatailor#CreateChannel": {
290            "type": "operation",
291            "input": {
292                "target": "com.amazonaws.mediatailor#CreateChannelRequest"
293            },
294            "output": {
295                "target": "com.amazonaws.mediatailor#CreateChannelResponse"
296            },
297            "traits": {
298                "smithy.api#documentation": "<p>Creates a channel.</p>",
299                "smithy.api#http": {
300                    "method": "POST",
301                    "uri": "/channel/{ChannelName}",
302                    "code": 200
303                }
304            }
305        },
306        "com.amazonaws.mediatailor#CreateChannelRequest": {
307            "type": "structure",
308            "members": {
309                "ChannelName": {
310                    "target": "com.amazonaws.mediatailor#__string",
311                    "traits": {
312                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
313                        "smithy.api#httpLabel": {},
314                        "smithy.api#required": {}
315                    }
316                },
317                "Outputs": {
318                    "target": "com.amazonaws.mediatailor#RequestOutputs",
319                    "traits": {
320                        "smithy.api#documentation": "<p>The channel's output properties.</p>",
321                        "smithy.api#required": {}
322                    }
323                },
324                "PlaybackMode": {
325                    "target": "com.amazonaws.mediatailor#PlaybackMode",
326                    "traits": {
327                        "smithy.api#documentation": "<p>The type of playback mode for this channel. The only supported value is LOOP.</p>",
328                        "smithy.api#required": {}
329                    }
330                },
331                "Tags": {
332                    "target": "com.amazonaws.mediatailor#__mapOf__string",
333                    "traits": {
334                        "smithy.api#documentation": "<p>The tags to assign to the channel.</p>",
335                        "smithy.api#jsonName": "tags"
336                    }
337                }
338            }
339        },
340        "com.amazonaws.mediatailor#CreateChannelResponse": {
341            "type": "structure",
342            "members": {
343                "Arn": {
344                    "target": "com.amazonaws.mediatailor#__string",
345                    "traits": {
346                        "smithy.api#documentation": "<p>The ARN of the channel.</p>"
347                    }
348                },
349                "ChannelName": {
350                    "target": "com.amazonaws.mediatailor#__string",
351                    "traits": {
352                        "smithy.api#documentation": "<p>The name of the channel.</p>"
353                    }
354                },
355                "ChannelState": {
356                    "target": "com.amazonaws.mediatailor#ChannelState",
357                    "traits": {
358                        "smithy.api#documentation": "<p>Indicates whether the channel is in a running state or not.</p>"
359                    }
360                },
361                "CreationTime": {
362                    "target": "com.amazonaws.mediatailor#__timestampUnix",
363                    "traits": {
364                        "smithy.api#documentation": "<p>The timestamp of when the channel was created.</p>"
365                    }
366                },
367                "LastModifiedTime": {
368                    "target": "com.amazonaws.mediatailor#__timestampUnix",
369                    "traits": {
370                        "smithy.api#documentation": "<p>The timestamp of when the channel was last modified.</p>"
371                    }
372                },
373                "Outputs": {
374                    "target": "com.amazonaws.mediatailor#ResponseOutputs",
375                    "traits": {
376                        "smithy.api#documentation": "<p>The channel's output properties.</p>"
377                    }
378                },
379                "PlaybackMode": {
380                    "target": "com.amazonaws.mediatailor#__string",
381                    "traits": {
382                        "smithy.api#documentation": "<p>The type of playback for this channel. The only supported value is LOOP.</p>"
383                    }
384                },
385                "Tags": {
386                    "target": "com.amazonaws.mediatailor#__mapOf__string",
387                    "traits": {
388                        "smithy.api#documentation": "<p>The tags assigned to the channel.</p>",
389                        "smithy.api#jsonName": "tags"
390                    }
391                }
392            }
393        },
394        "com.amazonaws.mediatailor#CreateProgram": {
395            "type": "operation",
396            "input": {
397                "target": "com.amazonaws.mediatailor#CreateProgramRequest"
398            },
399            "output": {
400                "target": "com.amazonaws.mediatailor#CreateProgramResponse"
401            },
402            "traits": {
403                "smithy.api#documentation": "<p>Creates a program.</p>",
404                "smithy.api#http": {
405                    "method": "POST",
406                    "uri": "/channel/{ChannelName}/program/{ProgramName}",
407                    "code": 200
408                }
409            }
410        },
411        "com.amazonaws.mediatailor#CreateProgramRequest": {
412            "type": "structure",
413            "members": {
414                "AdBreaks": {
415                    "target": "com.amazonaws.mediatailor#__listOfAdBreak",
416                    "traits": {
417                        "smithy.api#documentation": "<p>The ad break configuration settings.</p>"
418                    }
419                },
420                "ChannelName": {
421                    "target": "com.amazonaws.mediatailor#__string",
422                    "traits": {
423                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
424                        "smithy.api#httpLabel": {},
425                        "smithy.api#required": {}
426                    }
427                },
428                "ProgramName": {
429                    "target": "com.amazonaws.mediatailor#__string",
430                    "traits": {
431                        "smithy.api#documentation": "<p>The identifier for the program you are working on.</p>",
432                        "smithy.api#httpLabel": {},
433                        "smithy.api#required": {}
434                    }
435                },
436                "ScheduleConfiguration": {
437                    "target": "com.amazonaws.mediatailor#ScheduleConfiguration",
438                    "traits": {
439                        "smithy.api#documentation": "<p>The schedule configuration settings.</p>",
440                        "smithy.api#required": {}
441                    }
442                },
443                "SourceLocationName": {
444                    "target": "com.amazonaws.mediatailor#__string",
445                    "traits": {
446                        "smithy.api#documentation": "<p>The name of the source location.</p>",
447                        "smithy.api#required": {}
448                    }
449                },
450                "VodSourceName": {
451                    "target": "com.amazonaws.mediatailor#__string",
452                    "traits": {
453                        "smithy.api#documentation": "<p>The name that's used to refer to a VOD source.</p>",
454                        "smithy.api#required": {}
455                    }
456                }
457            }
458        },
459        "com.amazonaws.mediatailor#CreateProgramResponse": {
460            "type": "structure",
461            "members": {
462                "AdBreaks": {
463                    "target": "com.amazonaws.mediatailor#__listOfAdBreak",
464                    "traits": {
465                        "smithy.api#documentation": "<p>The ad break configuration settings.</p>"
466                    }
467                },
468                "Arn": {
469                    "target": "com.amazonaws.mediatailor#__string",
470                    "traits": {
471                        "smithy.api#documentation": "<p>The ARN of the program.</p>"
472                    }
473                },
474                "ChannelName": {
475                    "target": "com.amazonaws.mediatailor#__string",
476                    "traits": {
477                        "smithy.api#documentation": "<p>The name of the channel that the program belongs to.</p>"
478                    }
479                },
480                "CreationTime": {
481                    "target": "com.amazonaws.mediatailor#__timestampUnix",
482                    "traits": {
483                        "smithy.api#documentation": "<p>The timestamp of when the program was created.</p>"
484                    }
485                },
486                "ProgramName": {
487                    "target": "com.amazonaws.mediatailor#__string",
488                    "traits": {
489                        "smithy.api#documentation": "<p>The name of the program.</p>"
490                    }
491                },
492                "SourceLocationName": {
493                    "target": "com.amazonaws.mediatailor#__string",
494                    "traits": {
495                        "smithy.api#documentation": "<p>The source location name.</p>"
496                    }
497                },
498                "VodSourceName": {
499                    "target": "com.amazonaws.mediatailor#__string",
500                    "traits": {
501                        "smithy.api#documentation": "<p>The name that's used to refer to a VOD source.</p>"
502                    }
503                }
504            }
505        },
506        "com.amazonaws.mediatailor#CreateSourceLocation": {
507            "type": "operation",
508            "input": {
509                "target": "com.amazonaws.mediatailor#CreateSourceLocationRequest"
510            },
511            "output": {
512                "target": "com.amazonaws.mediatailor#CreateSourceLocationResponse"
513            },
514            "traits": {
515                "smithy.api#documentation": "<p>Creates a source location on a specific channel.</p>",
516                "smithy.api#http": {
517                    "method": "POST",
518                    "uri": "/sourceLocation/{SourceLocationName}",
519                    "code": 200
520                }
521            }
522        },
523        "com.amazonaws.mediatailor#CreateSourceLocationRequest": {
524            "type": "structure",
525            "members": {
526                "AccessConfiguration": {
527                    "target": "com.amazonaws.mediatailor#AccessConfiguration",
528                    "traits": {
529                        "smithy.api#documentation": "<p>Access configuration parameters. Configures the type of authentication used to access content from your source location.</p>"
530                    }
531                },
532                "DefaultSegmentDeliveryConfiguration": {
533                    "target": "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration",
534                    "traits": {
535                        "smithy.api#documentation": "<p>The optional configuration for the server that serves segments.</p>"
536                    }
537                },
538                "HttpConfiguration": {
539                    "target": "com.amazonaws.mediatailor#HttpConfiguration",
540                    "traits": {
541                        "smithy.api#documentation": "<p>The source's HTTP package configurations.</p>",
542                        "smithy.api#required": {}
543                    }
544                },
545                "SourceLocationName": {
546                    "target": "com.amazonaws.mediatailor#__string",
547                    "traits": {
548                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
549                        "smithy.api#httpLabel": {},
550                        "smithy.api#required": {}
551                    }
552                },
553                "Tags": {
554                    "target": "com.amazonaws.mediatailor#__mapOf__string",
555                    "traits": {
556                        "smithy.api#documentation": "<p>The tags to assign to the source location.</p>",
557                        "smithy.api#jsonName": "tags"
558                    }
559                }
560            }
561        },
562        "com.amazonaws.mediatailor#CreateSourceLocationResponse": {
563            "type": "structure",
564            "members": {
565                "AccessConfiguration": {
566                    "target": "com.amazonaws.mediatailor#AccessConfiguration",
567                    "traits": {
568                        "smithy.api#documentation": "<p>The access configuration for the source location.</p>"
569                    }
570                },
571                "Arn": {
572                    "target": "com.amazonaws.mediatailor#__string",
573                    "traits": {
574                        "smithy.api#documentation": "<p>The ARN of the source location.</p>"
575                    }
576                },
577                "CreationTime": {
578                    "target": "com.amazonaws.mediatailor#__timestampUnix",
579                    "traits": {
580                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was created.</p>"
581                    }
582                },
583                "DefaultSegmentDeliveryConfiguration": {
584                    "target": "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration",
585                    "traits": {
586                        "smithy.api#documentation": "<p>The default segment delivery configuration settings.</p>"
587                    }
588                },
589                "HttpConfiguration": {
590                    "target": "com.amazonaws.mediatailor#HttpConfiguration",
591                    "traits": {
592                        "smithy.api#documentation": "<p>The HTTP package configuration settings for the source location.</p>"
593                    }
594                },
595                "LastModifiedTime": {
596                    "target": "com.amazonaws.mediatailor#__timestampUnix",
597                    "traits": {
598                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was last modified.</p>"
599                    }
600                },
601                "SourceLocationName": {
602                    "target": "com.amazonaws.mediatailor#__string",
603                    "traits": {
604                        "smithy.api#documentation": "<p>The name of the source location.</p>"
605                    }
606                },
607                "Tags": {
608                    "target": "com.amazonaws.mediatailor#__mapOf__string",
609                    "traits": {
610                        "smithy.api#documentation": "<p>The tags assigned to the source location.</p>",
611                        "smithy.api#jsonName": "tags"
612                    }
613                }
614            }
615        },
616        "com.amazonaws.mediatailor#CreateVodSource": {
617            "type": "operation",
618            "input": {
619                "target": "com.amazonaws.mediatailor#CreateVodSourceRequest"
620            },
621            "output": {
622                "target": "com.amazonaws.mediatailor#CreateVodSourceResponse"
623            },
624            "traits": {
625                "smithy.api#documentation": "<p>Creates name for a specific VOD source in a source location.</p>",
626                "smithy.api#http": {
627                    "method": "POST",
628                    "uri": "/sourceLocation/{SourceLocationName}/vodSource/{VodSourceName}",
629                    "code": 200
630                }
631            }
632        },
633        "com.amazonaws.mediatailor#CreateVodSourceRequest": {
634            "type": "structure",
635            "members": {
636                "HttpPackageConfigurations": {
637                    "target": "com.amazonaws.mediatailor#HttpPackageConfigurations",
638                    "traits": {
639                        "smithy.api#documentation": "<p>An array of HTTP package configuration parameters for this VOD source.</p>",
640                        "smithy.api#required": {}
641                    }
642                },
643                "SourceLocationName": {
644                    "target": "com.amazonaws.mediatailor#__string",
645                    "traits": {
646                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
647                        "smithy.api#httpLabel": {},
648                        "smithy.api#required": {}
649                    }
650                },
651                "Tags": {
652                    "target": "com.amazonaws.mediatailor#__mapOf__string",
653                    "traits": {
654                        "smithy.api#documentation": "<p>The tags to assign to the VOD source.</p>",
655                        "smithy.api#jsonName": "tags"
656                    }
657                },
658                "VodSourceName": {
659                    "target": "com.amazonaws.mediatailor#__string",
660                    "traits": {
661                        "smithy.api#documentation": "<p>The identifier for the VOD source you are working on.</p>",
662                        "smithy.api#httpLabel": {},
663                        "smithy.api#required": {}
664                    }
665                }
666            }
667        },
668        "com.amazonaws.mediatailor#CreateVodSourceResponse": {
669            "type": "structure",
670            "members": {
671                "Arn": {
672                    "target": "com.amazonaws.mediatailor#__string",
673                    "traits": {
674                        "smithy.api#documentation": "<p>The ARN of the VOD source.</p>"
675                    }
676                },
677                "CreationTime": {
678                    "target": "com.amazonaws.mediatailor#__timestampUnix",
679                    "traits": {
680                        "smithy.api#documentation": "<p>The timestamp that indicates when the VOD source was created.</p>"
681                    }
682                },
683                "HttpPackageConfigurations": {
684                    "target": "com.amazonaws.mediatailor#HttpPackageConfigurations",
685                    "traits": {
686                        "smithy.api#documentation": "<p>The HTTP package configurations.</p>"
687                    }
688                },
689                "LastModifiedTime": {
690                    "target": "com.amazonaws.mediatailor#__timestampUnix",
691                    "traits": {
692                        "smithy.api#documentation": "<p>The ARN for the VOD source.</p>"
693                    }
694                },
695                "SourceLocationName": {
696                    "target": "com.amazonaws.mediatailor#__string",
697                    "traits": {
698                        "smithy.api#documentation": "<p>The name of the source location associated with the VOD source.</p>"
699                    }
700                },
701                "Tags": {
702                    "target": "com.amazonaws.mediatailor#__mapOf__string",
703                    "traits": {
704                        "smithy.api#documentation": "<p>The tags assigned to the VOD source.</p>",
705                        "smithy.api#jsonName": "tags"
706                    }
707                },
708                "VodSourceName": {
709                    "target": "com.amazonaws.mediatailor#__string",
710                    "traits": {
711                        "smithy.api#documentation": "<p>The name of the VOD source.</p>"
712                    }
713                }
714            }
715        },
716        "com.amazonaws.mediatailor#DashConfiguration": {
717            "type": "structure",
718            "members": {
719                "ManifestEndpointPrefix": {
720                    "target": "com.amazonaws.mediatailor#__string",
721                    "traits": {
722                        "smithy.api#documentation": "<p>The URL generated by MediaTailor to initiate a playback session. The session uses server-side reporting. This setting is ignored in PUT operations.</p>"
723                    }
724                },
725                "MpdLocation": {
726                    "target": "com.amazonaws.mediatailor#__string",
727                    "traits": {
728                        "smithy.api#documentation": "<p>The setting that controls whether MediaTailor includes the Location tag in DASH manifests. MediaTailor populates the Location tag with the URL for manifest update requests, to be used by players that don't support sticky redirects. Disable this if you have CDN routing rules set up for accessing MediaTailor manifests, and you are either using client-side reporting or your players support sticky HTTP redirects. Valid values are DISABLED and EMT_DEFAULT. The EMT_DEFAULT setting enables the inclusion of the tag and is the default value.</p>"
729                    }
730                },
731                "OriginManifestType": {
732                    "target": "com.amazonaws.mediatailor#OriginManifestType",
733                    "traits": {
734                        "smithy.api#documentation": "<p>The setting that controls whether MediaTailor handles manifests from the origin server as multi-period manifests or single-period manifests. If your origin server produces single-period manifests, set this to SINGLE_PERIOD. The default setting is MULTI_PERIOD. For multi-period manifests, omit this setting or set it to MULTI_PERIOD.</p>"
735                    }
736                }
737            },
738            "traits": {
739                "smithy.api#documentation": "<p>The configuration for DASH content.</p>"
740            }
741        },
742        "com.amazonaws.mediatailor#DashConfigurationForPut": {
743            "type": "structure",
744            "members": {
745                "MpdLocation": {
746                    "target": "com.amazonaws.mediatailor#__string",
747                    "traits": {
748                        "smithy.api#documentation": "<p>The setting that controls whether MediaTailor includes the Location tag in DASH manifests. MediaTailor populates the Location tag with the URL for manifest update requests, to be used by players that don't support sticky redirects. Disable this if you have CDN routing rules set up for accessing MediaTailor manifests, and you are either using client-side reporting or your players support sticky HTTP redirects. Valid values are DISABLED and EMT_DEFAULT. The EMT_DEFAULT setting enables the inclusion of the tag and is the default value.</p>"
749                    }
750                },
751                "OriginManifestType": {
752                    "target": "com.amazonaws.mediatailor#OriginManifestType",
753                    "traits": {
754                        "smithy.api#documentation": "<p>The setting that controls whether MediaTailor handles manifests from the origin server as multi-period manifests or single-period manifests. If your origin server produces single-period manifests, set this to SINGLE_PERIOD. The default setting is MULTI_PERIOD. For multi-period manifests, omit this setting or set it to MULTI_PERIOD.</p>"
755                    }
756                }
757            },
758            "traits": {
759                "smithy.api#documentation": "<p>The configuration for DASH PUT operations.</p>"
760            }
761        },
762        "com.amazonaws.mediatailor#DashPlaylistSettings": {
763            "type": "structure",
764            "members": {
765                "ManifestWindowSeconds": {
766                    "target": "com.amazonaws.mediatailor#__integer",
767                    "traits": {
768                        "smithy.api#documentation": "<p>The total duration (in seconds) of each manifest. Minimum value: 30 seconds. Maximum value: 3600 seconds.</p>"
769                    }
770                },
771                "MinBufferTimeSeconds": {
772                    "target": "com.amazonaws.mediatailor#__integer",
773                    "traits": {
774                        "smithy.api#documentation": "<p>Minimum amount of content (measured in seconds) that a player must keep available in the buffer. Minimum value: 2 seconds. Maximum value: 60 seconds.</p>"
775                    }
776                },
777                "MinUpdatePeriodSeconds": {
778                    "target": "com.amazonaws.mediatailor#__integer",
779                    "traits": {
780                        "smithy.api#documentation": "<p>Minimum amount of time (in seconds) that the player should wait before requesting updates to the manifest. Minimum value: 2 seconds. Maximum value: 60 seconds.</p>"
781                    }
782                },
783                "SuggestedPresentationDelaySeconds": {
784                    "target": "com.amazonaws.mediatailor#__integer",
785                    "traits": {
786                        "smithy.api#documentation": "<p>Amount of time (in seconds) that the player should be from the live point at the end of the manifest. Minimum value: 2 seconds. Maximum value: 60 seconds.</p>"
787                    }
788                }
789            },
790            "traits": {
791                "smithy.api#documentation": "<p>Dash manifest configuration parameters.</p>"
792            }
793        },
794        "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration": {
795            "type": "structure",
796            "members": {
797                "BaseUrl": {
798                    "target": "com.amazonaws.mediatailor#__string",
799                    "traits": {
800                        "smithy.api#documentation": "<p>The hostname of the server that will be used to serve segments. This string must include the protocol, such as <b>https://</b>.</p>"
801                    }
802                }
803            },
804            "traits": {
805                "smithy.api#documentation": "<p>The optional configuration for a server that serves segments. Use this if you want the segment delivery server to be different from the source location server. For example, you can configure your source location server to be an origination server, such as MediaPackage, and the segment delivery server to be a content delivery network (CDN), such as CloudFront. If you don't specify a segment delivery server, then the source location server is used.</p>"
806            }
807        },
808        "com.amazonaws.mediatailor#DeleteChannel": {
809            "type": "operation",
810            "input": {
811                "target": "com.amazonaws.mediatailor#DeleteChannelRequest"
812            },
813            "output": {
814                "target": "com.amazonaws.mediatailor#DeleteChannelResponse"
815            },
816            "traits": {
817                "smithy.api#documentation": "<p>Deletes a channel. You must stop the channel before it can be deleted.</p>",
818                "smithy.api#http": {
819                    "method": "DELETE",
820                    "uri": "/channel/{ChannelName}",
821                    "code": 200
822                }
823            }
824        },
825        "com.amazonaws.mediatailor#DeleteChannelPolicy": {
826            "type": "operation",
827            "input": {
828                "target": "com.amazonaws.mediatailor#DeleteChannelPolicyRequest"
829            },
830            "output": {
831                "target": "com.amazonaws.mediatailor#DeleteChannelPolicyResponse"
832            },
833            "traits": {
834                "smithy.api#documentation": "<p>Deletes a channel's IAM policy.</p>",
835                "smithy.api#http": {
836                    "method": "DELETE",
837                    "uri": "/channel/{ChannelName}/policy",
838                    "code": 200
839                }
840            }
841        },
842        "com.amazonaws.mediatailor#DeleteChannelPolicyRequest": {
843            "type": "structure",
844            "members": {
845                "ChannelName": {
846                    "target": "com.amazonaws.mediatailor#__string",
847                    "traits": {
848                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
849                        "smithy.api#httpLabel": {},
850                        "smithy.api#required": {}
851                    }
852                }
853            }
854        },
855        "com.amazonaws.mediatailor#DeleteChannelPolicyResponse": {
856            "type": "structure",
857            "members": {}
858        },
859        "com.amazonaws.mediatailor#DeleteChannelRequest": {
860            "type": "structure",
861            "members": {
862                "ChannelName": {
863                    "target": "com.amazonaws.mediatailor#__string",
864                    "traits": {
865                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
866                        "smithy.api#httpLabel": {},
867                        "smithy.api#required": {}
868                    }
869                }
870            }
871        },
872        "com.amazonaws.mediatailor#DeleteChannelResponse": {
873            "type": "structure",
874            "members": {}
875        },
876        "com.amazonaws.mediatailor#DeletePlaybackConfiguration": {
877            "type": "operation",
878            "input": {
879                "target": "com.amazonaws.mediatailor#DeletePlaybackConfigurationRequest"
880            },
881            "output": {
882                "target": "com.amazonaws.mediatailor#DeletePlaybackConfigurationResponse"
883            },
884            "traits": {
885                "smithy.api#documentation": "<p>Deletes the playback configuration for the specified name.</p>",
886                "smithy.api#http": {
887                    "method": "DELETE",
888                    "uri": "/playbackConfiguration/{Name}",
889                    "code": 204
890                }
891            }
892        },
893        "com.amazonaws.mediatailor#DeletePlaybackConfigurationRequest": {
894            "type": "structure",
895            "members": {
896                "Name": {
897                    "target": "com.amazonaws.mediatailor#__string",
898                    "traits": {
899                        "smithy.api#documentation": "<p>The identifier for the playback configuration.</p>",
900                        "smithy.api#httpLabel": {},
901                        "smithy.api#required": {}
902                    }
903                }
904            }
905        },
906        "com.amazonaws.mediatailor#DeletePlaybackConfigurationResponse": {
907            "type": "structure",
908            "members": {}
909        },
910        "com.amazonaws.mediatailor#DeleteProgram": {
911            "type": "operation",
912            "input": {
913                "target": "com.amazonaws.mediatailor#DeleteProgramRequest"
914            },
915            "output": {
916                "target": "com.amazonaws.mediatailor#DeleteProgramResponse"
917            },
918            "traits": {
919                "smithy.api#documentation": "<p>Deletes a specific program on a specific channel.</p>",
920                "smithy.api#http": {
921                    "method": "DELETE",
922                    "uri": "/channel/{ChannelName}/program/{ProgramName}",
923                    "code": 200
924                }
925            }
926        },
927        "com.amazonaws.mediatailor#DeleteProgramRequest": {
928            "type": "structure",
929            "members": {
930                "ChannelName": {
931                    "target": "com.amazonaws.mediatailor#__string",
932                    "traits": {
933                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
934                        "smithy.api#httpLabel": {},
935                        "smithy.api#required": {}
936                    }
937                },
938                "ProgramName": {
939                    "target": "com.amazonaws.mediatailor#__string",
940                    "traits": {
941                        "smithy.api#documentation": "<p>The identifier for the program you are working on.</p>",
942                        "smithy.api#httpLabel": {},
943                        "smithy.api#required": {}
944                    }
945                }
946            }
947        },
948        "com.amazonaws.mediatailor#DeleteProgramResponse": {
949            "type": "structure",
950            "members": {}
951        },
952        "com.amazonaws.mediatailor#DeleteSourceLocation": {
953            "type": "operation",
954            "input": {
955                "target": "com.amazonaws.mediatailor#DeleteSourceLocationRequest"
956            },
957            "output": {
958                "target": "com.amazonaws.mediatailor#DeleteSourceLocationResponse"
959            },
960            "traits": {
961                "smithy.api#documentation": "<p>Deletes a source location on a specific channel.</p>",
962                "smithy.api#http": {
963                    "method": "DELETE",
964                    "uri": "/sourceLocation/{SourceLocationName}",
965                    "code": 200
966                }
967            }
968        },
969        "com.amazonaws.mediatailor#DeleteSourceLocationRequest": {
970            "type": "structure",
971            "members": {
972                "SourceLocationName": {
973                    "target": "com.amazonaws.mediatailor#__string",
974                    "traits": {
975                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
976                        "smithy.api#httpLabel": {},
977                        "smithy.api#required": {}
978                    }
979                }
980            }
981        },
982        "com.amazonaws.mediatailor#DeleteSourceLocationResponse": {
983            "type": "structure",
984            "members": {}
985        },
986        "com.amazonaws.mediatailor#DeleteVodSource": {
987            "type": "operation",
988            "input": {
989                "target": "com.amazonaws.mediatailor#DeleteVodSourceRequest"
990            },
991            "output": {
992                "target": "com.amazonaws.mediatailor#DeleteVodSourceResponse"
993            },
994            "traits": {
995                "smithy.api#documentation": "<p>Deletes a specific VOD source in a specific source location.</p>",
996                "smithy.api#http": {
997                    "method": "DELETE",
998                    "uri": "/sourceLocation/{SourceLocationName}/vodSource/{VodSourceName}",
999                    "code": 200
1000                }
1001            }
1002        },
1003        "com.amazonaws.mediatailor#DeleteVodSourceRequest": {
1004            "type": "structure",
1005            "members": {
1006                "SourceLocationName": {
1007                    "target": "com.amazonaws.mediatailor#__string",
1008                    "traits": {
1009                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
1010                        "smithy.api#httpLabel": {},
1011                        "smithy.api#required": {}
1012                    }
1013                },
1014                "VodSourceName": {
1015                    "target": "com.amazonaws.mediatailor#__string",
1016                    "traits": {
1017                        "smithy.api#documentation": "<p>The identifier for the VOD source you are working on.</p>",
1018                        "smithy.api#httpLabel": {},
1019                        "smithy.api#required": {}
1020                    }
1021                }
1022            }
1023        },
1024        "com.amazonaws.mediatailor#DeleteVodSourceResponse": {
1025            "type": "structure",
1026            "members": {}
1027        },
1028        "com.amazonaws.mediatailor#DescribeChannel": {
1029            "type": "operation",
1030            "input": {
1031                "target": "com.amazonaws.mediatailor#DescribeChannelRequest"
1032            },
1033            "output": {
1034                "target": "com.amazonaws.mediatailor#DescribeChannelResponse"
1035            },
1036            "traits": {
1037                "smithy.api#documentation": "<p>Describes the properties of a specific channel.</p>",
1038                "smithy.api#http": {
1039                    "method": "GET",
1040                    "uri": "/channel/{ChannelName}",
1041                    "code": 200
1042                }
1043            }
1044        },
1045        "com.amazonaws.mediatailor#DescribeChannelRequest": {
1046            "type": "structure",
1047            "members": {
1048                "ChannelName": {
1049                    "target": "com.amazonaws.mediatailor#__string",
1050                    "traits": {
1051                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
1052                        "smithy.api#httpLabel": {},
1053                        "smithy.api#required": {}
1054                    }
1055                }
1056            }
1057        },
1058        "com.amazonaws.mediatailor#DescribeChannelResponse": {
1059            "type": "structure",
1060            "members": {
1061                "Arn": {
1062                    "target": "com.amazonaws.mediatailor#__string",
1063                    "traits": {
1064                        "smithy.api#documentation": "<p>The ARN of the channel.</p>"
1065                    }
1066                },
1067                "ChannelName": {
1068                    "target": "com.amazonaws.mediatailor#__string",
1069                    "traits": {
1070                        "smithy.api#documentation": "<p>The name of the channel.</p>"
1071                    }
1072                },
1073                "ChannelState": {
1074                    "target": "com.amazonaws.mediatailor#ChannelState",
1075                    "traits": {
1076                        "smithy.api#documentation": "<p>Indicates whether the channel is in a running state or not.</p>"
1077                    }
1078                },
1079                "CreationTime": {
1080                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1081                    "traits": {
1082                        "smithy.api#documentation": "<p>The timestamp of when the channel was created.</p>"
1083                    }
1084                },
1085                "LastModifiedTime": {
1086                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1087                    "traits": {
1088                        "smithy.api#documentation": "<p>The timestamp of when the channel was last modified.</p>"
1089                    }
1090                },
1091                "Outputs": {
1092                    "target": "com.amazonaws.mediatailor#ResponseOutputs",
1093                    "traits": {
1094                        "smithy.api#documentation": "<p>The channel's output properties.</p>"
1095                    }
1096                },
1097                "PlaybackMode": {
1098                    "target": "com.amazonaws.mediatailor#__string",
1099                    "traits": {
1100                        "smithy.api#documentation": "<p>The type of playback for this channel. The only supported value is LOOP.</p>"
1101                    }
1102                },
1103                "Tags": {
1104                    "target": "com.amazonaws.mediatailor#__mapOf__string",
1105                    "traits": {
1106                        "smithy.api#documentation": "<p>The tags assigned to the channel.</p>",
1107                        "smithy.api#jsonName": "tags"
1108                    }
1109                }
1110            }
1111        },
1112        "com.amazonaws.mediatailor#DescribeProgram": {
1113            "type": "operation",
1114            "input": {
1115                "target": "com.amazonaws.mediatailor#DescribeProgramRequest"
1116            },
1117            "output": {
1118                "target": "com.amazonaws.mediatailor#DescribeProgramResponse"
1119            },
1120            "traits": {
1121                "smithy.api#documentation": "<p>Retrieves the properties of the requested program.</p>",
1122                "smithy.api#http": {
1123                    "method": "GET",
1124                    "uri": "/channel/{ChannelName}/program/{ProgramName}",
1125                    "code": 200
1126                }
1127            }
1128        },
1129        "com.amazonaws.mediatailor#DescribeProgramRequest": {
1130            "type": "structure",
1131            "members": {
1132                "ChannelName": {
1133                    "target": "com.amazonaws.mediatailor#__string",
1134                    "traits": {
1135                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
1136                        "smithy.api#httpLabel": {},
1137                        "smithy.api#required": {}
1138                    }
1139                },
1140                "ProgramName": {
1141                    "target": "com.amazonaws.mediatailor#__string",
1142                    "traits": {
1143                        "smithy.api#documentation": "<p>The identifier for the program you are working on.</p>",
1144                        "smithy.api#httpLabel": {},
1145                        "smithy.api#required": {}
1146                    }
1147                }
1148            }
1149        },
1150        "com.amazonaws.mediatailor#DescribeProgramResponse": {
1151            "type": "structure",
1152            "members": {
1153                "AdBreaks": {
1154                    "target": "com.amazonaws.mediatailor#__listOfAdBreak",
1155                    "traits": {
1156                        "smithy.api#documentation": "<p>The ad break configuration settings.</p>"
1157                    }
1158                },
1159                "Arn": {
1160                    "target": "com.amazonaws.mediatailor#__string",
1161                    "traits": {
1162                        "smithy.api#documentation": "<p>The ARN of the program.</p>"
1163                    }
1164                },
1165                "ChannelName": {
1166                    "target": "com.amazonaws.mediatailor#__string",
1167                    "traits": {
1168                        "smithy.api#documentation": "<p>The name of the channel that the program belongs to.</p>"
1169                    }
1170                },
1171                "CreationTime": {
1172                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1173                    "traits": {
1174                        "smithy.api#documentation": "<p>The timestamp of when the program was created.</p>"
1175                    }
1176                },
1177                "ProgramName": {
1178                    "target": "com.amazonaws.mediatailor#__string",
1179                    "traits": {
1180                        "smithy.api#documentation": "<p>The name of the program.</p>"
1181                    }
1182                },
1183                "SourceLocationName": {
1184                    "target": "com.amazonaws.mediatailor#__string",
1185                    "traits": {
1186                        "smithy.api#documentation": "<p>The source location name.</p>"
1187                    }
1188                },
1189                "VodSourceName": {
1190                    "target": "com.amazonaws.mediatailor#__string",
1191                    "traits": {
1192                        "smithy.api#documentation": "<p>The name that's used to refer to a VOD source.</p>"
1193                    }
1194                }
1195            }
1196        },
1197        "com.amazonaws.mediatailor#DescribeSourceLocation": {
1198            "type": "operation",
1199            "input": {
1200                "target": "com.amazonaws.mediatailor#DescribeSourceLocationRequest"
1201            },
1202            "output": {
1203                "target": "com.amazonaws.mediatailor#DescribeSourceLocationResponse"
1204            },
1205            "traits": {
1206                "smithy.api#documentation": "<p>Retrieves the properties of the requested source location.</p>",
1207                "smithy.api#http": {
1208                    "method": "GET",
1209                    "uri": "/sourceLocation/{SourceLocationName}",
1210                    "code": 200
1211                }
1212            }
1213        },
1214        "com.amazonaws.mediatailor#DescribeSourceLocationRequest": {
1215            "type": "structure",
1216            "members": {
1217                "SourceLocationName": {
1218                    "target": "com.amazonaws.mediatailor#__string",
1219                    "traits": {
1220                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
1221                        "smithy.api#httpLabel": {},
1222                        "smithy.api#required": {}
1223                    }
1224                }
1225            }
1226        },
1227        "com.amazonaws.mediatailor#DescribeSourceLocationResponse": {
1228            "type": "structure",
1229            "members": {
1230                "AccessConfiguration": {
1231                    "target": "com.amazonaws.mediatailor#AccessConfiguration",
1232                    "traits": {
1233                        "smithy.api#documentation": "<p>The access configuration for the source location.</p>"
1234                    }
1235                },
1236                "Arn": {
1237                    "target": "com.amazonaws.mediatailor#__string",
1238                    "traits": {
1239                        "smithy.api#documentation": "<p>The ARN of the source location.</p>"
1240                    }
1241                },
1242                "CreationTime": {
1243                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1244                    "traits": {
1245                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was created.</p>"
1246                    }
1247                },
1248                "DefaultSegmentDeliveryConfiguration": {
1249                    "target": "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration",
1250                    "traits": {
1251                        "smithy.api#documentation": "<p>The default segment delivery configuration settings.</p>"
1252                    }
1253                },
1254                "HttpConfiguration": {
1255                    "target": "com.amazonaws.mediatailor#HttpConfiguration",
1256                    "traits": {
1257                        "smithy.api#documentation": "<p>The HTTP package configuration settings for the source location.</p>"
1258                    }
1259                },
1260                "LastModifiedTime": {
1261                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1262                    "traits": {
1263                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was last modified.</p>"
1264                    }
1265                },
1266                "SourceLocationName": {
1267                    "target": "com.amazonaws.mediatailor#__string",
1268                    "traits": {
1269                        "smithy.api#documentation": "<p>The name of the source location.</p>"
1270                    }
1271                },
1272                "Tags": {
1273                    "target": "com.amazonaws.mediatailor#__mapOf__string",
1274                    "traits": {
1275                        "smithy.api#documentation": "<p>The tags assigned to the source location.</p>",
1276                        "smithy.api#jsonName": "tags"
1277                    }
1278                }
1279            }
1280        },
1281        "com.amazonaws.mediatailor#DescribeVodSource": {
1282            "type": "operation",
1283            "input": {
1284                "target": "com.amazonaws.mediatailor#DescribeVodSourceRequest"
1285            },
1286            "output": {
1287                "target": "com.amazonaws.mediatailor#DescribeVodSourceResponse"
1288            },
1289            "traits": {
1290                "smithy.api#documentation": "<p>Provides details about a specific VOD source in a specific source location.</p>",
1291                "smithy.api#http": {
1292                    "method": "GET",
1293                    "uri": "/sourceLocation/{SourceLocationName}/vodSource/{VodSourceName}",
1294                    "code": 200
1295                }
1296            }
1297        },
1298        "com.amazonaws.mediatailor#DescribeVodSourceRequest": {
1299            "type": "structure",
1300            "members": {
1301                "SourceLocationName": {
1302                    "target": "com.amazonaws.mediatailor#__string",
1303                    "traits": {
1304                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
1305                        "smithy.api#httpLabel": {},
1306                        "smithy.api#required": {}
1307                    }
1308                },
1309                "VodSourceName": {
1310                    "target": "com.amazonaws.mediatailor#__string",
1311                    "traits": {
1312                        "smithy.api#documentation": "<p>The identifier for the VOD source you are working on.</p>",
1313                        "smithy.api#httpLabel": {},
1314                        "smithy.api#required": {}
1315                    }
1316                }
1317            }
1318        },
1319        "com.amazonaws.mediatailor#DescribeVodSourceResponse": {
1320            "type": "structure",
1321            "members": {
1322                "Arn": {
1323                    "target": "com.amazonaws.mediatailor#__string",
1324                    "traits": {
1325                        "smithy.api#documentation": "<p>The ARN of the VOD source.</p>"
1326                    }
1327                },
1328                "CreationTime": {
1329                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1330                    "traits": {
1331                        "smithy.api#documentation": "<p>The timestamp that indicates when the VOD source was created.</p>"
1332                    }
1333                },
1334                "HttpPackageConfigurations": {
1335                    "target": "com.amazonaws.mediatailor#HttpPackageConfigurations",
1336                    "traits": {
1337                        "smithy.api#documentation": "<p>The HTTP package configurations.</p>"
1338                    }
1339                },
1340                "LastModifiedTime": {
1341                    "target": "com.amazonaws.mediatailor#__timestampUnix",
1342                    "traits": {
1343                        "smithy.api#documentation": "<p>The ARN for the VOD source.</p>"
1344                    }
1345                },
1346                "SourceLocationName": {
1347                    "target": "com.amazonaws.mediatailor#__string",
1348                    "traits": {
1349                        "smithy.api#documentation": "<p>The name of the source location associated with the VOD source.</p>"
1350                    }
1351                },
1352                "Tags": {
1353                    "target": "com.amazonaws.mediatailor#__mapOf__string",
1354                    "traits": {
1355                        "smithy.api#documentation": "<p>The tags assigned to the VOD source.</p>",
1356                        "smithy.api#jsonName": "tags"
1357                    }
1358                },
1359                "VodSourceName": {
1360                    "target": "com.amazonaws.mediatailor#__string",
1361                    "traits": {
1362                        "smithy.api#documentation": "<p>The name of the VOD source.</p>"
1363                    }
1364                }
1365            }
1366        },
1367        "com.amazonaws.mediatailor#GetChannelPolicy": {
1368            "type": "operation",
1369            "input": {
1370                "target": "com.amazonaws.mediatailor#GetChannelPolicyRequest"
1371            },
1372            "output": {
1373                "target": "com.amazonaws.mediatailor#GetChannelPolicyResponse"
1374            },
1375            "traits": {
1376                "smithy.api#documentation": "<p>Retrieves information about a channel's IAM policy.</p>",
1377                "smithy.api#http": {
1378                    "method": "GET",
1379                    "uri": "/channel/{ChannelName}/policy",
1380                    "code": 200
1381                }
1382            }
1383        },
1384        "com.amazonaws.mediatailor#GetChannelPolicyRequest": {
1385            "type": "structure",
1386            "members": {
1387                "ChannelName": {
1388                    "target": "com.amazonaws.mediatailor#__string",
1389                    "traits": {
1390                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
1391                        "smithy.api#httpLabel": {},
1392                        "smithy.api#required": {}
1393                    }
1394                }
1395            }
1396        },
1397        "com.amazonaws.mediatailor#GetChannelPolicyResponse": {
1398            "type": "structure",
1399            "members": {
1400                "Policy": {
1401                    "target": "com.amazonaws.mediatailor#__string",
1402                    "traits": {
1403                        "smithy.api#documentation": "<p>The IAM policy for the channel.</p>"
1404                    }
1405                }
1406            }
1407        },
1408        "com.amazonaws.mediatailor#GetChannelSchedule": {
1409            "type": "operation",
1410            "input": {
1411                "target": "com.amazonaws.mediatailor#GetChannelScheduleRequest"
1412            },
1413            "output": {
1414                "target": "com.amazonaws.mediatailor#GetChannelScheduleResponse"
1415            },
1416            "traits": {
1417                "smithy.api#documentation": "<p>Retrieves information about your channel's schedule.</p>",
1418                "smithy.api#http": {
1419                    "method": "GET",
1420                    "uri": "/channel/{ChannelName}/schedule",
1421                    "code": 200
1422                },
1423                "smithy.api#paginated": {
1424                    "inputToken": "NextToken",
1425                    "outputToken": "NextToken",
1426                    "items": "Items",
1427                    "pageSize": "MaxResults"
1428                }
1429            }
1430        },
1431        "com.amazonaws.mediatailor#GetChannelScheduleRequest": {
1432            "type": "structure",
1433            "members": {
1434                "ChannelName": {
1435                    "target": "com.amazonaws.mediatailor#__string",
1436                    "traits": {
1437                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
1438                        "smithy.api#httpLabel": {},
1439                        "smithy.api#required": {}
1440                    }
1441                },
1442                "DurationMinutes": {
1443                    "target": "com.amazonaws.mediatailor#__string",
1444                    "traits": {
1445                        "smithy.api#documentation": "<p>The schedule duration in minutes. The maximum duration is 4320 minutes (three days).</p>",
1446                        "smithy.api#httpQuery": "durationMinutes"
1447                    }
1448                },
1449                "MaxResults": {
1450                    "target": "com.amazonaws.mediatailor#MaxResults",
1451                    "traits": {
1452                        "smithy.api#documentation": "<p>Upper bound on number of records to return. The maximum number of results is 100.</p>",
1453                        "smithy.api#httpQuery": "maxResults"
1454                    }
1455                },
1456                "NextToken": {
1457                    "target": "com.amazonaws.mediatailor#__string",
1458                    "traits": {
1459                        "smithy.api#documentation": "<p>Pagination token from the GET list request. Use the token to fetch the next page of results.</p>",
1460                        "smithy.api#httpQuery": "nextToken"
1461                    }
1462                }
1463            }
1464        },
1465        "com.amazonaws.mediatailor#GetChannelScheduleResponse": {
1466            "type": "structure",
1467            "members": {
1468                "Items": {
1469                    "target": "com.amazonaws.mediatailor#__listOfScheduleEntry",
1470                    "traits": {
1471                        "smithy.api#documentation": "<p>An array of schedule entries for the channel.</p>"
1472                    }
1473                },
1474                "NextToken": {
1475                    "target": "com.amazonaws.mediatailor#__string",
1476                    "traits": {
1477                        "smithy.api#documentation": "<p>Pagination token from the GET list request. Use the token to fetch the next page of results.</p>"
1478                    }
1479                }
1480            }
1481        },
1482        "com.amazonaws.mediatailor#GetPlaybackConfiguration": {
1483            "type": "operation",
1484            "input": {
1485                "target": "com.amazonaws.mediatailor#GetPlaybackConfigurationRequest"
1486            },
1487            "output": {
1488                "target": "com.amazonaws.mediatailor#GetPlaybackConfigurationResponse"
1489            },
1490            "traits": {
1491                "smithy.api#documentation": "<p>Returns the playback configuration for the specified name.</p>",
1492                "smithy.api#http": {
1493                    "method": "GET",
1494                    "uri": "/playbackConfiguration/{Name}",
1495                    "code": 200
1496                }
1497            }
1498        },
1499        "com.amazonaws.mediatailor#GetPlaybackConfigurationRequest": {
1500            "type": "structure",
1501            "members": {
1502                "Name": {
1503                    "target": "com.amazonaws.mediatailor#__string",
1504                    "traits": {
1505                        "smithy.api#documentation": "<p>The identifier for the playback configuration.</p>",
1506                        "smithy.api#httpLabel": {},
1507                        "smithy.api#required": {}
1508                    }
1509                }
1510            }
1511        },
1512        "com.amazonaws.mediatailor#GetPlaybackConfigurationResponse": {
1513            "type": "structure",
1514            "members": {
1515                "AdDecisionServerUrl": {
1516                    "target": "com.amazonaws.mediatailor#__string",
1517                    "traits": {
1518                        "smithy.api#documentation": "<p>The URL for the ad decision server (ADS). This includes the specification of static parameters and placeholders for dynamic parameters. AWS Elemental MediaTailor substitutes player-specific and session-specific parameters as needed when calling the ADS. Alternately, for testing, you can provide a static VAST URL. The maximum length is 25,000 characters.</p>"
1519                    }
1520                },
1521                "AvailSuppression": {
1522                    "target": "com.amazonaws.mediatailor#AvailSuppression",
1523                    "traits": {
1524                        "smithy.api#documentation": "<p>The configuration for avail suppression, also known as ad suppression. For more information about ad suppression, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Suppression</a>.</p>"
1525                    }
1526                },
1527                "Bumper": {
1528                    "target": "com.amazonaws.mediatailor#Bumper",
1529                    "traits": {
1530                        "smithy.api#documentation": "<p>The configuration for bumpers. Bumpers are short audio or video clips that play at the start or before the end of an ad break. To learn more about bumpers, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/bumpers.html\">Bumpers</a>.</p>"
1531                    }
1532                },
1533                "CdnConfiguration": {
1534                    "target": "com.amazonaws.mediatailor#CdnConfiguration",
1535                    "traits": {
1536                        "smithy.api#documentation": "<p>The configuration for using a content delivery network (CDN), like Amazon CloudFront, for content and ad segment management.</p>"
1537                    }
1538                },
1539                "ConfigurationAliases": {
1540                    "target": "com.amazonaws.mediatailor#ConfigurationAliasesResponse",
1541                    "traits": {
1542                        "smithy.api#documentation": "<p>The player parameters and aliases used as dynamic variables during session initialization. For more information, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/variables-domain.html\">Domain Variables</a>.</p>"
1543                    }
1544                },
1545                "DashConfiguration": {
1546                    "target": "com.amazonaws.mediatailor#DashConfiguration",
1547                    "traits": {
1548                        "smithy.api#documentation": "<p>The configuration for DASH content.</p>"
1549                    }
1550                },
1551                "HlsConfiguration": {
1552                    "target": "com.amazonaws.mediatailor#HlsConfiguration",
1553                    "traits": {
1554                        "smithy.api#documentation": "<p>The configuration for HLS content.</p>"
1555                    }
1556                },
1557                "LivePreRollConfiguration": {
1558                    "target": "com.amazonaws.mediatailor#LivePreRollConfiguration",
1559                    "traits": {
1560                        "smithy.api#documentation": "<p>The configuration for pre-roll ad insertion.</p>"
1561                    }
1562                },
1563                "ManifestProcessingRules": {
1564                    "target": "com.amazonaws.mediatailor#ManifestProcessingRules",
1565                    "traits": {
1566                        "smithy.api#documentation": "<p>The configuration for manifest processing rules. Manifest processing rules enable customization of the personalized manifests created by MediaTailor.</p>"
1567                    }
1568                },
1569                "Name": {
1570                    "target": "com.amazonaws.mediatailor#__string",
1571                    "traits": {
1572                        "smithy.api#documentation": "<p>The identifier for the playback configuration.</p>"
1573                    }
1574                },
1575                "PersonalizationThresholdSeconds": {
1576                    "target": "com.amazonaws.mediatailor#__integerMin1",
1577                    "traits": {
1578                        "smithy.api#documentation": "<p>Defines the maximum duration of underfilled ad time (in seconds) allowed in an ad break. If the duration of underfilled ad time exceeds the personalization threshold, then the personalization of the ad break is abandoned and the underlying content is shown. This feature applies to <i>ad replacement</i> in live and VOD streams, rather than ad insertion, because it relies on an underlying content stream. For more information about ad break behavior, including ad replacement and insertion, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Behavior in AWS Elemental MediaTailor</a>.</p>"
1579                    }
1580                },
1581                "PlaybackConfigurationArn": {
1582                    "target": "com.amazonaws.mediatailor#__string",
1583                    "traits": {
1584                        "smithy.api#documentation": "<p>The Amazon Resource Name (ARN) for the playback configuration.</p>"
1585                    }
1586                },
1587                "PlaybackEndpointPrefix": {
1588                    "target": "com.amazonaws.mediatailor#__string",
1589                    "traits": {
1590                        "smithy.api#documentation": "<p>The URL that the player accesses to get a manifest from AWS Elemental MediaTailor. This session will use server-side reporting.</p>"
1591                    }
1592                },
1593                "SessionInitializationEndpointPrefix": {
1594                    "target": "com.amazonaws.mediatailor#__string",
1595                    "traits": {
1596                        "smithy.api#documentation": "<p>The URL that the player uses to initialize a session that uses client-side reporting.</p>"
1597                    }
1598                },
1599                "SlateAdUrl": {
1600                    "target": "com.amazonaws.mediatailor#__string",
1601                    "traits": {
1602                        "smithy.api#documentation": "<p>The URL for a high-quality video asset to transcode and use to fill in time that's not used by ads. AWS Elemental MediaTailor shows the slate to fill in gaps in media content. Configuring the slate is optional for non-VPAID playback configurations. For VPAID, the slate is required because MediaTailor provides it in the slots designated for dynamic ad content. The slate must be a high-quality asset that contains both audio and video.</p>"
1603                    }
1604                },
1605                "Tags": {
1606                    "target": "com.amazonaws.mediatailor#__mapOf__string",
1607                    "traits": {
1608                        "smithy.api#documentation": "<p>The tags assigned to the playback configuration.</p>",
1609                        "smithy.api#jsonName": "tags"
1610                    }
1611                },
1612                "TranscodeProfileName": {
1613                    "target": "com.amazonaws.mediatailor#__string",
1614                    "traits": {
1615                        "smithy.api#documentation": "<p>The name that is used to associate this playback configuration with a custom transcode profile. This overrides the dynamic transcoding defaults of MediaTailor. Use this only if you have already set up custom profiles with the help of AWS Support.</p>"
1616                    }
1617                },
1618                "VideoContentSourceUrl": {
1619                    "target": "com.amazonaws.mediatailor#__string",
1620                    "traits": {
1621                        "smithy.api#documentation": "<p>The URL prefix for the parent manifest for the stream, minus the asset ID. The maximum length is 512 characters.</p>"
1622                    }
1623                }
1624            }
1625        },
1626        "com.amazonaws.mediatailor#HlsConfiguration": {
1627            "type": "structure",
1628            "members": {
1629                "ManifestEndpointPrefix": {
1630                    "target": "com.amazonaws.mediatailor#__string",
1631                    "traits": {
1632                        "smithy.api#documentation": "<p>The URL that is used to initiate a playback session for devices that support Apple HLS. The session uses server-side reporting.</p>"
1633                    }
1634                }
1635            },
1636            "traits": {
1637                "smithy.api#documentation": "<p>The configuration for HLS content.</p>"
1638            }
1639        },
1640        "com.amazonaws.mediatailor#HlsPlaylistSettings": {
1641            "type": "structure",
1642            "members": {
1643                "ManifestWindowSeconds": {
1644                    "target": "com.amazonaws.mediatailor#__integer",
1645                    "traits": {
1646                        "smithy.api#documentation": "<p>The total duration (in seconds) of each manifest. Minimum value: 30 seconds. Maximum value: 3600 seconds.</p>"
1647                    }
1648                }
1649            },
1650            "traits": {
1651                "smithy.api#documentation": "<p>HLS playlist configuration parameters.</p>"
1652            }
1653        },
1654        "com.amazonaws.mediatailor#HttpConfiguration": {
1655            "type": "structure",
1656            "members": {
1657                "BaseUrl": {
1658                    "target": "com.amazonaws.mediatailor#__string",
1659                    "traits": {
1660                        "smithy.api#documentation": "<p>The base URL for the source location host server. This string must include the protocol, such as <b>https://</b>.</p>",
1661                        "smithy.api#required": {}
1662                    }
1663                }
1664            },
1665            "traits": {
1666                "smithy.api#documentation": "<p>The HTTP configuration for the source location.</p>"
1667            }
1668        },
1669        "com.amazonaws.mediatailor#HttpPackageConfiguration": {
1670            "type": "structure",
1671            "members": {
1672                "Path": {
1673                    "target": "com.amazonaws.mediatailor#__string",
1674                    "traits": {
1675                        "smithy.api#documentation": "<p>The relative path to the URL for this VOD source. This is combined with SourceLocation::HttpConfiguration::BaseUrl to form a valid URL.</p>",
1676                        "smithy.api#required": {}
1677                    }
1678                },
1679                "SourceGroup": {
1680                    "target": "com.amazonaws.mediatailor#__string",
1681                    "traits": {
1682                        "smithy.api#documentation": "<p>The name of the source group. This has to match one of the Channel::Outputs::SourceGroup.</p>",
1683                        "smithy.api#required": {}
1684                    }
1685                },
1686                "Type": {
1687                    "target": "com.amazonaws.mediatailor#Type",
1688                    "traits": {
1689                        "smithy.api#documentation": "<p>The streaming protocol for this package configuration. Supported values are HLS and DASH.</p>",
1690                        "smithy.api#required": {}
1691                    }
1692                }
1693            },
1694            "traits": {
1695                "smithy.api#documentation": "<p>The HTTP package configuration properties for the requested VOD source.</p>"
1696            }
1697        },
1698        "com.amazonaws.mediatailor#HttpPackageConfigurations": {
1699            "type": "list",
1700            "member": {
1701                "target": "com.amazonaws.mediatailor#HttpPackageConfiguration"
1702            },
1703            "traits": {
1704                "smithy.api#documentation": "<p>The VOD source's HTTP package configuration settings.</p>"
1705            }
1706        },
1707        "com.amazonaws.mediatailor#ListChannels": {
1708            "type": "operation",
1709            "input": {
1710                "target": "com.amazonaws.mediatailor#ListChannelsRequest"
1711            },
1712            "output": {
1713                "target": "com.amazonaws.mediatailor#ListChannelsResponse"
1714            },
1715            "traits": {
1716                "smithy.api#documentation": "<p>Retrieves a list of channels that are associated with this account.</p>",
1717                "smithy.api#http": {
1718                    "method": "GET",
1719                    "uri": "/channels",
1720                    "code": 200
1721                },
1722                "smithy.api#paginated": {
1723                    "inputToken": "NextToken",
1724                    "outputToken": "NextToken",
1725                    "items": "Items",
1726                    "pageSize": "MaxResults"
1727                }
1728            }
1729        },
1730        "com.amazonaws.mediatailor#ListChannelsRequest": {
1731            "type": "structure",
1732            "members": {
1733                "MaxResults": {
1734                    "target": "com.amazonaws.mediatailor#MaxResults",
1735                    "traits": {
1736                        "smithy.api#documentation": "<p>Upper bound on number of records to return. The maximum number of results is 100.</p>",
1737                        "smithy.api#httpQuery": "maxResults"
1738                    }
1739                },
1740                "NextToken": {
1741                    "target": "com.amazonaws.mediatailor#__string",
1742                    "traits": {
1743                        "smithy.api#documentation": "<p>Pagination token from the GET list request. Use the token to fetch the next page of results.</p>",
1744                        "smithy.api#httpQuery": "nextToken"
1745                    }
1746                }
1747            }
1748        },
1749        "com.amazonaws.mediatailor#ListChannelsResponse": {
1750            "type": "structure",
1751            "members": {
1752                "Items": {
1753                    "target": "com.amazonaws.mediatailor#__listOfChannel",
1754                    "traits": {
1755                        "smithy.api#documentation": "<p>An array of channels that are associated with this account.</p>"
1756                    }
1757                },
1758                "NextToken": {
1759                    "target": "com.amazonaws.mediatailor#__string",
1760                    "traits": {
1761                        "smithy.api#documentation": "<p>Pagination token returned by the list request when results exceed the maximum allowed. Use the token to fetch the next page of results.</p>"
1762                    }
1763                }
1764            }
1765        },
1766        "com.amazonaws.mediatailor#ListPlaybackConfigurations": {
1767            "type": "operation",
1768            "input": {
1769                "target": "com.amazonaws.mediatailor#ListPlaybackConfigurationsRequest"
1770            },
1771            "output": {
1772                "target": "com.amazonaws.mediatailor#ListPlaybackConfigurationsResponse"
1773            },
1774            "traits": {
1775                "smithy.api#documentation": "<p>Returns a list of the playback configurations defined in AWS Elemental MediaTailor. You can specify a maximum number of configurations to return at a time. The default maximum is 50. Results are returned in pagefuls. If MediaTailor has more configurations than the specified maximum, it provides parameters in the response that you can use to retrieve the next pageful.</p>",
1776                "smithy.api#http": {
1777                    "method": "GET",
1778                    "uri": "/playbackConfigurations",
1779                    "code": 200
1780                },
1781                "smithy.api#paginated": {
1782                    "inputToken": "NextToken",
1783                    "outputToken": "NextToken",
1784                    "items": "Items",
1785                    "pageSize": "MaxResults"
1786                }
1787            }
1788        },
1789        "com.amazonaws.mediatailor#ListPlaybackConfigurationsRequest": {
1790            "type": "structure",
1791            "members": {
1792                "MaxResults": {
1793                    "target": "com.amazonaws.mediatailor#MaxResults",
1794                    "traits": {
1795                        "smithy.api#documentation": "<p>Maximum number of records to return.</p>",
1796                        "smithy.api#httpQuery": "MaxResults"
1797                    }
1798                },
1799                "NextToken": {
1800                    "target": "com.amazonaws.mediatailor#__string",
1801                    "traits": {
1802                        "smithy.api#documentation": "<p>Pagination token returned by the GET list request when results exceed the maximum allowed. Use the token to fetch the next page of results.</p>",
1803                        "smithy.api#httpQuery": "NextToken"
1804                    }
1805                }
1806            }
1807        },
1808        "com.amazonaws.mediatailor#ListPlaybackConfigurationsResponse": {
1809            "type": "structure",
1810            "members": {
1811                "Items": {
1812                    "target": "com.amazonaws.mediatailor#__listOfPlaybackConfiguration",
1813                    "traits": {
1814                        "smithy.api#documentation": "<p>Array of playback configurations. This might be all the available configurations or a subset, depending on the settings that you provide and the total number of configurations stored.</p>"
1815                    }
1816                },
1817                "NextToken": {
1818                    "target": "com.amazonaws.mediatailor#__string",
1819                    "traits": {
1820                        "smithy.api#documentation": "<p>Pagination token returned by the GET list request when results exceed the maximum allowed. Use the token to fetch the next page of results.</p>"
1821                    }
1822                }
1823            }
1824        },
1825        "com.amazonaws.mediatailor#ListSourceLocations": {
1826            "type": "operation",
1827            "input": {
1828                "target": "com.amazonaws.mediatailor#ListSourceLocationsRequest"
1829            },
1830            "output": {
1831                "target": "com.amazonaws.mediatailor#ListSourceLocationsResponse"
1832            },
1833            "traits": {
1834                "smithy.api#documentation": "<p>Retrieves a list of source locations.</p>",
1835                "smithy.api#http": {
1836                    "method": "GET",
1837                    "uri": "/sourceLocations",
1838                    "code": 200
1839                },
1840                "smithy.api#paginated": {
1841                    "inputToken": "NextToken",
1842                    "outputToken": "NextToken",
1843                    "items": "Items",
1844                    "pageSize": "MaxResults"
1845                }
1846            }
1847        },
1848        "com.amazonaws.mediatailor#ListSourceLocationsRequest": {
1849            "type": "structure",
1850            "members": {
1851                "MaxResults": {
1852                    "target": "com.amazonaws.mediatailor#MaxResults",
1853                    "traits": {
1854                        "smithy.api#documentation": "<p>Upper bound on number of records to return. The maximum number of results is 100.</p>",
1855                        "smithy.api#httpQuery": "maxResults"
1856                    }
1857                },
1858                "NextToken": {
1859                    "target": "com.amazonaws.mediatailor#__string",
1860                    "traits": {
1861                        "smithy.api#documentation": "<p>Pagination token from the GET list request. Use the token to fetch the next page of results.</p>",
1862                        "smithy.api#httpQuery": "nextToken"
1863                    }
1864                }
1865            }
1866        },
1867        "com.amazonaws.mediatailor#ListSourceLocationsResponse": {
1868            "type": "structure",
1869            "members": {
1870                "Items": {
1871                    "target": "com.amazonaws.mediatailor#__listOfSourceLocation",
1872                    "traits": {
1873                        "smithy.api#documentation": "<p>An array of source locations.</p>"
1874                    }
1875                },
1876                "NextToken": {
1877                    "target": "com.amazonaws.mediatailor#__string",
1878                    "traits": {
1879                        "smithy.api#documentation": "<p>Pagination token from the list request. Use the token to fetch the next page of results.</p>"
1880                    }
1881                }
1882            }
1883        },
1884        "com.amazonaws.mediatailor#ListTagsForResource": {
1885            "type": "operation",
1886            "input": {
1887                "target": "com.amazonaws.mediatailor#ListTagsForResourceRequest"
1888            },
1889            "output": {
1890                "target": "com.amazonaws.mediatailor#ListTagsForResourceResponse"
1891            },
1892            "errors": [
1893                {
1894                    "target": "com.amazonaws.mediatailor#BadRequestException"
1895                }
1896            ],
1897            "traits": {
1898                "smithy.api#documentation": "<p>Returns a list of the tags assigned to the specified playback configuration resource.</p>",
1899                "smithy.api#http": {
1900                    "method": "GET",
1901                    "uri": "/tags/{ResourceArn}",
1902                    "code": 200
1903                }
1904            }
1905        },
1906        "com.amazonaws.mediatailor#ListTagsForResourceRequest": {
1907            "type": "structure",
1908            "members": {
1909                "ResourceArn": {
1910                    "target": "com.amazonaws.mediatailor#__string",
1911                    "traits": {
1912                        "smithy.api#documentation": "<p>The Amazon Resource Name (ARN) for the playback configuration. You can get this from the response to any playback configuration request.</p>",
1913                        "smithy.api#httpLabel": {},
1914                        "smithy.api#required": {}
1915                    }
1916                }
1917            }
1918        },
1919        "com.amazonaws.mediatailor#ListTagsForResourceResponse": {
1920            "type": "structure",
1921            "members": {
1922                "Tags": {
1923                    "target": "com.amazonaws.mediatailor#__mapOf__string",
1924                    "traits": {
1925                        "smithy.api#documentation": "<p>A comma-separated list of tag key:value pairs.</p>",
1926                        "smithy.api#jsonName": "tags"
1927                    }
1928                }
1929            }
1930        },
1931        "com.amazonaws.mediatailor#ListVodSources": {
1932            "type": "operation",
1933            "input": {
1934                "target": "com.amazonaws.mediatailor#ListVodSourcesRequest"
1935            },
1936            "output": {
1937                "target": "com.amazonaws.mediatailor#ListVodSourcesResponse"
1938            },
1939            "traits": {
1940                "smithy.api#documentation": "<p>Lists all the VOD sources in a source location.</p>",
1941                "smithy.api#http": {
1942                    "method": "GET",
1943                    "uri": "/sourceLocation/{SourceLocationName}/vodSources",
1944                    "code": 200
1945                },
1946                "smithy.api#paginated": {
1947                    "inputToken": "NextToken",
1948                    "outputToken": "NextToken",
1949                    "items": "Items",
1950                    "pageSize": "MaxResults"
1951                }
1952            }
1953        },
1954        "com.amazonaws.mediatailor#ListVodSourcesRequest": {
1955            "type": "structure",
1956            "members": {
1957                "MaxResults": {
1958                    "target": "com.amazonaws.mediatailor#MaxResults",
1959                    "traits": {
1960                        "smithy.api#documentation": "<p>Upper bound on number of records to return. The maximum number of results is 100.</p>",
1961                        "smithy.api#httpQuery": "maxResults"
1962                    }
1963                },
1964                "NextToken": {
1965                    "target": "com.amazonaws.mediatailor#__string",
1966                    "traits": {
1967                        "smithy.api#documentation": "<p>Pagination token from the GET list request. Use the token to fetch the next page of results.</p>",
1968                        "smithy.api#httpQuery": "nextToken"
1969                    }
1970                },
1971                "SourceLocationName": {
1972                    "target": "com.amazonaws.mediatailor#__string",
1973                    "traits": {
1974                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
1975                        "smithy.api#httpLabel": {},
1976                        "smithy.api#required": {}
1977                    }
1978                }
1979            }
1980        },
1981        "com.amazonaws.mediatailor#ListVodSourcesResponse": {
1982            "type": "structure",
1983            "members": {
1984                "Items": {
1985                    "target": "com.amazonaws.mediatailor#__listOfVodSource",
1986                    "traits": {
1987                        "smithy.api#documentation": "<p>Lists the VOD sources.</p>"
1988                    }
1989                },
1990                "NextToken": {
1991                    "target": "com.amazonaws.mediatailor#__string",
1992                    "traits": {
1993                        "smithy.api#documentation": "<p>Pagination token from the list request. Use the token to fetch the next page of results.</p>"
1994                    }
1995                }
1996            }
1997        },
1998        "com.amazonaws.mediatailor#LivePreRollConfiguration": {
1999            "type": "structure",
2000            "members": {
2001                "AdDecisionServerUrl": {
2002                    "target": "com.amazonaws.mediatailor#__string",
2003                    "traits": {
2004                        "smithy.api#documentation": "<p>The URL for the ad decision server (ADS) for pre-roll ads. This includes the specification of static parameters and placeholders for dynamic parameters. AWS Elemental MediaTailor substitutes player-specific and session-specific parameters as needed when calling the ADS. Alternately, for testing, you can provide a static VAST URL. The maximum length is 25,000 characters.</p>"
2005                    }
2006                },
2007                "MaxDurationSeconds": {
2008                    "target": "com.amazonaws.mediatailor#__integer",
2009                    "traits": {
2010                        "smithy.api#documentation": "The maximum allowed duration for the pre-roll ad avail. AWS Elemental MediaTailor won't play pre-roll ads to exceed this duration, regardless of the total duration of ads that the ADS returns."
2011                    }
2012                }
2013            },
2014            "traits": {
2015                "smithy.api#documentation": "<p>The configuration for pre-roll ad insertion.</p>"
2016            }
2017        },
2018        "com.amazonaws.mediatailor#ManifestProcessingRules": {
2019            "type": "structure",
2020            "members": {
2021                "AdMarkerPassthrough": {
2022                    "target": "com.amazonaws.mediatailor#AdMarkerPassthrough",
2023                    "traits": {
2024                        "smithy.api#documentation": "<p>For HLS, when set to true, MediaTailor passes through EXT-X-CUE-IN, EXT-X-CUE-OUT, and EXT-X-SPLICEPOINT-SCTE35 ad markers from the origin manifest to the MediaTailor personalized manifest.</p> <p>No logic is applied to these ad markers. For example, if EXT-X-CUE-OUT has a value of 60, but no ads are filled for that ad break, MediaTailor will not set the value to 0.</p>"
2025                    }
2026                }
2027            },
2028            "traits": {
2029                "smithy.api#documentation": "<p>The configuration for manifest processing rules. Manifest processing rules enable customization of the personalized manifests created by MediaTailor.</p>"
2030            }
2031        },
2032        "com.amazonaws.mediatailor#MaxResults": {
2033            "type": "integer",
2034            "traits": {
2035                "smithy.api#range": {
2036                    "min": 1,
2037                    "max": 100
2038                }
2039            }
2040        },
2041        "com.amazonaws.mediatailor#MediaTailor": {
2042            "type": "service",
2043            "version": "2018-04-23",
2044            "operations": [
2045                {
2046                    "target": "com.amazonaws.mediatailor#CreateChannel"
2047                },
2048                {
2049                    "target": "com.amazonaws.mediatailor#CreateProgram"
2050                },
2051                {
2052                    "target": "com.amazonaws.mediatailor#CreateSourceLocation"
2053                },
2054                {
2055                    "target": "com.amazonaws.mediatailor#CreateVodSource"
2056                },
2057                {
2058                    "target": "com.amazonaws.mediatailor#DeleteChannel"
2059                },
2060                {
2061                    "target": "com.amazonaws.mediatailor#DeleteChannelPolicy"
2062                },
2063                {
2064                    "target": "com.amazonaws.mediatailor#DeletePlaybackConfiguration"
2065                },
2066                {
2067                    "target": "com.amazonaws.mediatailor#DeleteProgram"
2068                },
2069                {
2070                    "target": "com.amazonaws.mediatailor#DeleteSourceLocation"
2071                },
2072                {
2073                    "target": "com.amazonaws.mediatailor#DeleteVodSource"
2074                },
2075                {
2076                    "target": "com.amazonaws.mediatailor#DescribeChannel"
2077                },
2078                {
2079                    "target": "com.amazonaws.mediatailor#DescribeProgram"
2080                },
2081                {
2082                    "target": "com.amazonaws.mediatailor#DescribeSourceLocation"
2083                },
2084                {
2085                    "target": "com.amazonaws.mediatailor#DescribeVodSource"
2086                },
2087                {
2088                    "target": "com.amazonaws.mediatailor#GetChannelPolicy"
2089                },
2090                {
2091                    "target": "com.amazonaws.mediatailor#GetChannelSchedule"
2092                },
2093                {
2094                    "target": "com.amazonaws.mediatailor#GetPlaybackConfiguration"
2095                },
2096                {
2097                    "target": "com.amazonaws.mediatailor#ListChannels"
2098                },
2099                {
2100                    "target": "com.amazonaws.mediatailor#ListPlaybackConfigurations"
2101                },
2102                {
2103                    "target": "com.amazonaws.mediatailor#ListSourceLocations"
2104                },
2105                {
2106                    "target": "com.amazonaws.mediatailor#ListTagsForResource"
2107                },
2108                {
2109                    "target": "com.amazonaws.mediatailor#ListVodSources"
2110                },
2111                {
2112                    "target": "com.amazonaws.mediatailor#PutChannelPolicy"
2113                },
2114                {
2115                    "target": "com.amazonaws.mediatailor#PutPlaybackConfiguration"
2116                },
2117                {
2118                    "target": "com.amazonaws.mediatailor#StartChannel"
2119                },
2120                {
2121                    "target": "com.amazonaws.mediatailor#StopChannel"
2122                },
2123                {
2124                    "target": "com.amazonaws.mediatailor#TagResource"
2125                },
2126                {
2127                    "target": "com.amazonaws.mediatailor#UntagResource"
2128                },
2129                {
2130                    "target": "com.amazonaws.mediatailor#UpdateChannel"
2131                },
2132                {
2133                    "target": "com.amazonaws.mediatailor#UpdateSourceLocation"
2134                },
2135                {
2136                    "target": "com.amazonaws.mediatailor#UpdateVodSource"
2137                }
2138            ],
2139            "traits": {
2140                "aws.api#service": {
2141                    "sdkId": "MediaTailor",
2142                    "arnNamespace": "mediatailor",
2143                    "cloudFormationName": "MediaTailor",
2144                    "cloudTrailEventSource": "mediatailor.amazonaws.com",
2145                    "endpointPrefix": "api.mediatailor"
2146                },
2147                "aws.auth#sigv4": {
2148                    "name": "mediatailor"
2149                },
2150                "aws.protocols#restJson1": {},
2151                "smithy.api#documentation": "<p>Use the AWS Elemental MediaTailor SDKs and CLI to configure scalable ad insertion and linear channels. With MediaTailor, you can assemble existing content into a linear stream and serve targeted ads to viewers while maintaining broadcast quality in over-the-top (OTT) video applications. For information about using the service, including detailed information about the settings covered in this guide, see the <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/\">AWS Elemental MediaTailor User Guide</a>.</p> <p>Through the SDKs and the CLI you manage AWS Elemental MediaTailor configurations and channels the same as you do through the console. For example, you specify ad insertion behavior and mapping information for the origin server and the ad decision server (ADS).</p>",
2152                "smithy.api#title": "AWS MediaTailor"
2153            }
2154        },
2155        "com.amazonaws.mediatailor#MessageType": {
2156            "type": "string",
2157            "traits": {
2158                "smithy.api#enum": [
2159                    {
2160                        "value": "SPLICE_INSERT",
2161                        "name": "SPLICE_INSERT"
2162                    }
2163                ]
2164            }
2165        },
2166        "com.amazonaws.mediatailor#Mode": {
2167            "type": "string",
2168            "traits": {
2169                "smithy.api#enum": [
2170                    {
2171                        "value": "OFF",
2172                        "name": "OFF"
2173                    },
2174                    {
2175                        "value": "BEHIND_LIVE_EDGE",
2176                        "name": "BEHIND_LIVE_EDGE"
2177                    }
2178                ]
2179            }
2180        },
2181        "com.amazonaws.mediatailor#OriginManifestType": {
2182            "type": "string",
2183            "traits": {
2184                "smithy.api#enum": [
2185                    {
2186                        "value": "SINGLE_PERIOD",
2187                        "name": "SINGLE_PERIOD"
2188                    },
2189                    {
2190                        "value": "MULTI_PERIOD",
2191                        "name": "MULTI_PERIOD"
2192                    }
2193                ]
2194            }
2195        },
2196        "com.amazonaws.mediatailor#PlaybackConfiguration": {
2197            "type": "structure",
2198            "members": {
2199                "AdDecisionServerUrl": {
2200                    "target": "com.amazonaws.mediatailor#__string",
2201                    "traits": {
2202                        "smithy.api#documentation": "<p>The URL for the ad decision server (ADS). This includes the specification of static parameters and placeholders for dynamic parameters. AWS Elemental MediaTailor substitutes player-specific and session-specific parameters as needed when calling the ADS. Alternately, for testing you can provide a static VAST URL. The maximum length is 25,000 characters.</p>"
2203                    }
2204                },
2205                "AvailSuppression": {
2206                    "target": "com.amazonaws.mediatailor#AvailSuppression",
2207                    "traits": {
2208                        "smithy.api#documentation": "<p>The configuration for avail suppression, also known as ad suppression. For more information about ad suppression, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Suppression</a>.</p>"
2209                    }
2210                },
2211                "Bumper": {
2212                    "target": "com.amazonaws.mediatailor#Bumper",
2213                    "traits": {
2214                        "smithy.api#documentation": "<p>The configuration for bumpers. Bumpers are short audio or video clips that play at the start or before the end of an ad break. To learn more about bumpers, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/bumpers.html\">Bumpers</a>.</p>"
2215                    }
2216                },
2217                "CdnConfiguration": {
2218                    "target": "com.amazonaws.mediatailor#CdnConfiguration",
2219                    "traits": {
2220                        "smithy.api#documentation": "<p>The configuration for using a content delivery network (CDN), like Amazon CloudFront, for content and ad segment management.</p>"
2221                    }
2222                },
2223                "ConfigurationAliases": {
2224                    "target": "com.amazonaws.mediatailor#ConfigurationAliasesResponse",
2225                    "traits": {
2226                        "smithy.api#documentation": "<p>The player parameters and aliases used as dynamic variables during session initialization. For more information, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/variables-domain.html\">Domain Variables</a>.</p>"
2227                    }
2228                },
2229                "DashConfiguration": {
2230                    "target": "com.amazonaws.mediatailor#DashConfiguration",
2231                    "traits": {
2232                        "smithy.api#documentation": "<p>The configuration for a DASH source.</p>"
2233                    }
2234                },
2235                "HlsConfiguration": {
2236                    "target": "com.amazonaws.mediatailor#HlsConfiguration",
2237                    "traits": {
2238                        "smithy.api#documentation": "<p>The configuration for HLS content.</p>"
2239                    }
2240                },
2241                "LivePreRollConfiguration": {
2242                    "target": "com.amazonaws.mediatailor#LivePreRollConfiguration",
2243                    "traits": {
2244                        "smithy.api#documentation": "<p>The configuration for pre-roll ad insertion.</p>"
2245                    }
2246                },
2247                "ManifestProcessingRules": {
2248                    "target": "com.amazonaws.mediatailor#ManifestProcessingRules",
2249                    "traits": {
2250                        "smithy.api#documentation": "<p>The configuration for manifest processing rules. Manifest processing rules enable customization of the personalized manifests created by MediaTailor.</p>"
2251                    }
2252                },
2253                "Name": {
2254                    "target": "com.amazonaws.mediatailor#__string",
2255                    "traits": {
2256                        "smithy.api#documentation": "<p>The identifier for the playback configuration.</p>"
2257                    }
2258                },
2259                "PersonalizationThresholdSeconds": {
2260                    "target": "com.amazonaws.mediatailor#__integerMin1",
2261                    "traits": {
2262                        "smithy.api#documentation": "<p>Defines the maximum duration of underfilled ad time (in seconds) allowed in an ad break. If the duration of underfilled ad time exceeds the personalization threshold, then the personalization of the ad break is abandoned and the underlying content is shown. This feature applies to <i>ad replacement</i> in live and VOD streams, rather than ad insertion, because it relies on an underlying content stream. For more information about ad break behavior, including ad replacement and insertion, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Behavior in AWS Elemental MediaTailor</a>.</p>"
2263                    }
2264                },
2265                "PlaybackConfigurationArn": {
2266                    "target": "com.amazonaws.mediatailor#__string",
2267                    "traits": {
2268                        "smithy.api#documentation": "<p>The Amazon Resource Name (ARN) for the playback configuration.</p>"
2269                    }
2270                },
2271                "PlaybackEndpointPrefix": {
2272                    "target": "com.amazonaws.mediatailor#__string",
2273                    "traits": {
2274                        "smithy.api#documentation": "<p>The URL that the player accesses to get a manifest from AWS Elemental MediaTailor.</p>"
2275                    }
2276                },
2277                "SessionInitializationEndpointPrefix": {
2278                    "target": "com.amazonaws.mediatailor#__string",
2279                    "traits": {
2280                        "smithy.api#documentation": "<p>The URL that the player uses to initialize a session that uses client-side reporting.</p>"
2281                    }
2282                },
2283                "SlateAdUrl": {
2284                    "target": "com.amazonaws.mediatailor#__string",
2285                    "traits": {
2286                        "smithy.api#documentation": "<p>The URL for a video asset to transcode and use to fill in time that's not used by ads. AWS Elemental MediaTailor shows the slate to fill in gaps in media content. Configuring the slate is optional for non-VPAID playback configurations. For VPAID, the slate is required because MediaTailor provides it in the slots designated for dynamic ad content. The slate must be a high-quality asset that contains both audio and video.</p>"
2287                    }
2288                },
2289                "Tags": {
2290                    "target": "com.amazonaws.mediatailor#__mapOf__string",
2291                    "traits": {
2292                        "smithy.api#documentation": "<p>The tags to assign to the playback configuration.</p>",
2293                        "smithy.api#jsonName": "tags"
2294                    }
2295                },
2296                "TranscodeProfileName": {
2297                    "target": "com.amazonaws.mediatailor#__string",
2298                    "traits": {
2299                        "smithy.api#documentation": "<p>The name that is used to associate this playback configuration with a custom transcode profile. This overrides the dynamic transcoding defaults of MediaTailor. Use this only if you have already set up custom profiles with the help of AWS Support.</p>"
2300                    }
2301                },
2302                "VideoContentSourceUrl": {
2303                    "target": "com.amazonaws.mediatailor#__string",
2304                    "traits": {
2305                        "smithy.api#documentation": "<p>The URL prefix for the parent manifest for the stream, minus the asset ID. The maximum length is 512 characters.</p>"
2306                    }
2307                }
2308            },
2309            "traits": {
2310                "smithy.api#documentation": "<p>Creates a playback configuration. For information about MediaTailor configurations, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/configurations.html\">Working with configurations in AWS Elemental MediaTailor</a>.</p>"
2311            }
2312        },
2313        "com.amazonaws.mediatailor#PlaybackMode": {
2314            "type": "string",
2315            "traits": {
2316                "smithy.api#enum": [
2317                    {
2318                        "value": "LOOP",
2319                        "name": "LOOP"
2320                    }
2321                ]
2322            }
2323        },
2324        "com.amazonaws.mediatailor#PutChannelPolicy": {
2325            "type": "operation",
2326            "input": {
2327                "target": "com.amazonaws.mediatailor#PutChannelPolicyRequest"
2328            },
2329            "output": {
2330                "target": "com.amazonaws.mediatailor#PutChannelPolicyResponse"
2331            },
2332            "traits": {
2333                "smithy.api#documentation": "<p>Creates an IAM policy for the channel.</p>",
2334                "smithy.api#http": {
2335                    "method": "PUT",
2336                    "uri": "/channel/{ChannelName}/policy",
2337                    "code": 200
2338                }
2339            }
2340        },
2341        "com.amazonaws.mediatailor#PutChannelPolicyRequest": {
2342            "type": "structure",
2343            "members": {
2344                "ChannelName": {
2345                    "target": "com.amazonaws.mediatailor#__string",
2346                    "traits": {
2347                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
2348                        "smithy.api#httpLabel": {},
2349                        "smithy.api#required": {}
2350                    }
2351                },
2352                "Policy": {
2353                    "target": "com.amazonaws.mediatailor#__string",
2354                    "traits": {
2355                        "smithy.api#documentation": "<p>Adds an IAM role that determines the permissions of your channel.</p>",
2356                        "smithy.api#required": {}
2357                    }
2358                }
2359            }
2360        },
2361        "com.amazonaws.mediatailor#PutChannelPolicyResponse": {
2362            "type": "structure",
2363            "members": {}
2364        },
2365        "com.amazonaws.mediatailor#PutPlaybackConfiguration": {
2366            "type": "operation",
2367            "input": {
2368                "target": "com.amazonaws.mediatailor#PutPlaybackConfigurationRequest"
2369            },
2370            "output": {
2371                "target": "com.amazonaws.mediatailor#PutPlaybackConfigurationResponse"
2372            },
2373            "traits": {
2374                "smithy.api#documentation": "<p>Adds a new playback configuration to AWS Elemental MediaTailor.</p>",
2375                "smithy.api#http": {
2376                    "method": "PUT",
2377                    "uri": "/playbackConfiguration",
2378                    "code": 200
2379                }
2380            }
2381        },
2382        "com.amazonaws.mediatailor#PutPlaybackConfigurationRequest": {
2383            "type": "structure",
2384            "members": {
2385                "AdDecisionServerUrl": {
2386                    "target": "com.amazonaws.mediatailor#__string",
2387                    "traits": {
2388                        "smithy.api#documentation": "<p>The URL for the ad decision server (ADS). This includes the specification of static parameters and placeholders for dynamic parameters. AWS Elemental MediaTailor substitutes player-specific and session-specific parameters as needed when calling the ADS. Alternately, for testing you can provide a static VAST URL. The maximum length is 25,000 characters.</p>"
2389                    }
2390                },
2391                "AvailSuppression": {
2392                    "target": "com.amazonaws.mediatailor#AvailSuppression",
2393                    "traits": {
2394                        "smithy.api#documentation": "<p>The configuration for avail suppression, also known as ad suppression. For more information about ad suppression, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Suppression</a>.</p>"
2395                    }
2396                },
2397                "Bumper": {
2398                    "target": "com.amazonaws.mediatailor#Bumper",
2399                    "traits": {
2400                        "smithy.api#documentation": "<p>The configuration for bumpers. Bumpers are short audio or video clips that play at the start or before the end of an ad break. To learn more about bumpers, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/bumpers.html\">Bumpers</a>.</p>"
2401                    }
2402                },
2403                "CdnConfiguration": {
2404                    "target": "com.amazonaws.mediatailor#CdnConfiguration",
2405                    "traits": {
2406                        "smithy.api#documentation": "<p>The configuration for using a content delivery network (CDN), like Amazon CloudFront, for content and ad segment management.</p>"
2407                    }
2408                },
2409                "ConfigurationAliases": {
2410                    "target": "com.amazonaws.mediatailor#ConfigurationAliasesRequest",
2411                    "traits": {
2412                        "smithy.api#documentation": "<p>The player parameters and aliases used as dynamic variables during session initialization. For more information, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/variables-domain.html\">Domain Variables</a>.</p>"
2413                    }
2414                },
2415                "DashConfiguration": {
2416                    "target": "com.amazonaws.mediatailor#DashConfigurationForPut",
2417                    "traits": {
2418                        "smithy.api#documentation": "<p>The configuration for DASH content.</p>"
2419                    }
2420                },
2421                "LivePreRollConfiguration": {
2422                    "target": "com.amazonaws.mediatailor#LivePreRollConfiguration",
2423                    "traits": {
2424                        "smithy.api#documentation": "<p>The configuration for pre-roll ad insertion.</p>"
2425                    }
2426                },
2427                "ManifestProcessingRules": {
2428                    "target": "com.amazonaws.mediatailor#ManifestProcessingRules",
2429                    "traits": {
2430                        "smithy.api#documentation": "<p>The configuration for manifest processing rules. Manifest processing rules enable customization of the personalized manifests created by MediaTailor.</p>"
2431                    }
2432                },
2433                "Name": {
2434                    "target": "com.amazonaws.mediatailor#__string",
2435                    "traits": {
2436                        "smithy.api#documentation": "<p>The identifier for the playback configuration.</p>"
2437                    }
2438                },
2439                "PersonalizationThresholdSeconds": {
2440                    "target": "com.amazonaws.mediatailor#__integerMin1",
2441                    "traits": {
2442                        "smithy.api#documentation": "<p>Defines the maximum duration of underfilled ad time (in seconds) allowed in an ad break. If the duration of underfilled ad time exceeds the personalization threshold, then the personalization of the ad break is abandoned and the underlying content is shown. This feature applies to <i>ad replacement</i> in live and VOD streams, rather than ad insertion, because it relies on an underlying content stream. For more information about ad break behavior, including ad replacement and insertion, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Behavior in AWS Elemental MediaTailor</a>.</p>"
2443                    }
2444                },
2445                "SlateAdUrl": {
2446                    "target": "com.amazonaws.mediatailor#__string",
2447                    "traits": {
2448                        "smithy.api#documentation": "<p>The URL for a high-quality video asset to transcode and use to fill in time that's not used by ads. AWS Elemental MediaTailor shows the slate to fill in gaps in media content. Configuring the slate is optional for non-VPAID configurations. For VPAID, the slate is required because MediaTailor provides it in the slots that are designated for dynamic ad content. The slate must be a high-quality asset that contains both audio and video.</p>"
2449                    }
2450                },
2451                "Tags": {
2452                    "target": "com.amazonaws.mediatailor#__mapOf__string",
2453                    "traits": {
2454                        "smithy.api#documentation": "<p>The tags to assign to the playback configuration.</p>",
2455                        "smithy.api#jsonName": "tags"
2456                    }
2457                },
2458                "TranscodeProfileName": {
2459                    "target": "com.amazonaws.mediatailor#__string",
2460                    "traits": {
2461                        "smithy.api#documentation": "<p>The name that is used to associate this playback configuration with a custom transcode profile. This overrides the dynamic transcoding defaults of MediaTailor. Use this only if you have already set up custom profiles with the help of AWS Support.</p>"
2462                    }
2463                },
2464                "VideoContentSourceUrl": {
2465                    "target": "com.amazonaws.mediatailor#__string",
2466                    "traits": {
2467                        "smithy.api#documentation": "<p>The URL prefix for the parent manifest for the stream, minus the asset ID. The maximum length is 512 characters.</p>"
2468                    }
2469                }
2470            }
2471        },
2472        "com.amazonaws.mediatailor#PutPlaybackConfigurationResponse": {
2473            "type": "structure",
2474            "members": {
2475                "AdDecisionServerUrl": {
2476                    "target": "com.amazonaws.mediatailor#__string",
2477                    "traits": {
2478                        "smithy.api#documentation": "<p>The URL for the ad decision server (ADS). This includes the specification of static parameters and placeholders for dynamic parameters. AWS Elemental MediaTailor substitutes player-specific and session-specific parameters as needed when calling the ADS. Alternately, for testing, you can provide a static VAST URL. The maximum length is 25,000 characters.</p>"
2479                    }
2480                },
2481                "AvailSuppression": {
2482                    "target": "com.amazonaws.mediatailor#AvailSuppression",
2483                    "traits": {
2484                        "smithy.api#documentation": "<p>The configuration for avail suppression, also known as ad suppression. For more information about ad suppression, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Suppression</a>.</p>"
2485                    }
2486                },
2487                "Bumper": {
2488                    "target": "com.amazonaws.mediatailor#Bumper",
2489                    "traits": {
2490                        "smithy.api#documentation": "<p>The configuration for bumpers. Bumpers are short audio or video clips that play at the start or before the end of an ad break. To learn more about bumpers, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/bumpers.html\">Bumpers</a>.</p>"
2491                    }
2492                },
2493                "CdnConfiguration": {
2494                    "target": "com.amazonaws.mediatailor#CdnConfiguration",
2495                    "traits": {
2496                        "smithy.api#documentation": "<p>The configuration for using a content delivery network (CDN), like Amazon CloudFront, for content and ad segment management.</p>"
2497                    }
2498                },
2499                "ConfigurationAliases": {
2500                    "target": "com.amazonaws.mediatailor#ConfigurationAliasesResponse",
2501                    "traits": {
2502                        "smithy.api#documentation": "<p>The player parameters and aliases used as dynamic variables during session initialization. For more information, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/variables-domain.html\">Domain Variables</a>.</p>"
2503                    }
2504                },
2505                "DashConfiguration": {
2506                    "target": "com.amazonaws.mediatailor#DashConfiguration",
2507                    "traits": {
2508                        "smithy.api#documentation": "<p>The configuration for DASH content.</p>"
2509                    }
2510                },
2511                "HlsConfiguration": {
2512                    "target": "com.amazonaws.mediatailor#HlsConfiguration",
2513                    "traits": {
2514                        "smithy.api#documentation": "<p>The configuration for HLS content.</p>"
2515                    }
2516                },
2517                "LivePreRollConfiguration": {
2518                    "target": "com.amazonaws.mediatailor#LivePreRollConfiguration",
2519                    "traits": {
2520                        "smithy.api#documentation": "<p>The configuration for pre-roll ad insertion.</p>"
2521                    }
2522                },
2523                "ManifestProcessingRules": {
2524                    "target": "com.amazonaws.mediatailor#ManifestProcessingRules",
2525                    "traits": {
2526                        "smithy.api#documentation": "<p>The configuration for manifest processing rules. Manifest processing rules enable customization of the personalized manifests created by MediaTailor.</p>"
2527                    }
2528                },
2529                "Name": {
2530                    "target": "com.amazonaws.mediatailor#__string",
2531                    "traits": {
2532                        "smithy.api#documentation": "<p>The identifier for the playback configuration.</p>"
2533                    }
2534                },
2535                "PersonalizationThresholdSeconds": {
2536                    "target": "com.amazonaws.mediatailor#__integerMin1",
2537                    "traits": {
2538                        "smithy.api#documentation": "<p>Defines the maximum duration of underfilled ad time (in seconds) allowed in an ad break. If the duration of underfilled ad time exceeds the personalization threshold, then the personalization of the ad break is abandoned and the underlying content is shown. This feature applies to <i>ad replacement</i> in live and VOD streams, rather than ad insertion, because it relies on an underlying content stream. For more information about ad break behavior, including ad replacement and insertion, see <a href=\"https://docs.aws.amazon.com/mediatailor/latest/ug/ad-behavior.html\">Ad Behavior in AWS Elemental MediaTailor</a>.</p>"
2539                    }
2540                },
2541                "PlaybackConfigurationArn": {
2542                    "target": "com.amazonaws.mediatailor#__string",
2543                    "traits": {
2544                        "smithy.api#documentation": "<p>The Amazon Resource Name (ARN) for the playback configuration.</p>"
2545                    }
2546                },
2547                "PlaybackEndpointPrefix": {
2548                    "target": "com.amazonaws.mediatailor#__string",
2549                    "traits": {
2550                        "smithy.api#documentation": "<p>The URL that the player accesses to get a manifest from AWS Elemental MediaTailor. This session will use server-side reporting.</p>"
2551                    }
2552                },
2553                "SessionInitializationEndpointPrefix": {
2554                    "target": "com.amazonaws.mediatailor#__string",
2555                    "traits": {
2556                        "smithy.api#documentation": "<p>The URL that the player uses to initialize a session that uses client-side reporting.</p>"
2557                    }
2558                },
2559                "SlateAdUrl": {
2560                    "target": "com.amazonaws.mediatailor#__string",
2561                    "traits": {
2562                        "smithy.api#documentation": "<p>The URL for a high-quality video asset to transcode and use to fill in time that's not used by ads. AWS Elemental MediaTailor shows the slate to fill in gaps in media content. Configuring the slate is optional for non-VPAID playback configurations. For VPAID, the slate is required because MediaTailor provides it in the slots designated for dynamic ad content. The slate must be a high-quality asset that contains both audio and video.</p>"
2563                    }
2564                },
2565                "Tags": {
2566                    "target": "com.amazonaws.mediatailor#__mapOf__string",
2567                    "traits": {
2568                        "smithy.api#documentation": "<p>The tags assigned to the playback configuration.</p>",
2569                        "smithy.api#jsonName": "tags"
2570                    }
2571                },
2572                "TranscodeProfileName": {
2573                    "target": "com.amazonaws.mediatailor#__string",
2574                    "traits": {
2575                        "smithy.api#documentation": "<p>The name that is used to associate this playback configuration with a custom transcode profile. This overrides the dynamic transcoding defaults of MediaTailor. Use this only if you have already set up custom profiles with the help of AWS Support.</p>"
2576                    }
2577                },
2578                "VideoContentSourceUrl": {
2579                    "target": "com.amazonaws.mediatailor#__string",
2580                    "traits": {
2581                        "smithy.api#documentation": "<p>The URL prefix for the parent manifest for the stream, minus the asset ID. The maximum length is 512 characters.</p>"
2582                    }
2583                }
2584            }
2585        },
2586        "com.amazonaws.mediatailor#RelativePosition": {
2587            "type": "string",
2588            "traits": {
2589                "smithy.api#enum": [
2590                    {
2591                        "value": "BEFORE_PROGRAM",
2592                        "name": "BEFORE_PROGRAM"
2593                    },
2594                    {
2595                        "value": "AFTER_PROGRAM",
2596                        "name": "AFTER_PROGRAM"
2597                    }
2598                ]
2599            }
2600        },
2601        "com.amazonaws.mediatailor#RequestOutputItem": {
2602            "type": "structure",
2603            "members": {
2604                "DashPlaylistSettings": {
2605                    "target": "com.amazonaws.mediatailor#DashPlaylistSettings",
2606                    "traits": {
2607                        "smithy.api#documentation": "<p>DASH manifest configuration parameters.</p>"
2608                    }
2609                },
2610                "HlsPlaylistSettings": {
2611                    "target": "com.amazonaws.mediatailor#HlsPlaylistSettings",
2612                    "traits": {
2613                        "smithy.api#documentation": "<p>HLS playlist configuration parameters.</p>"
2614                    }
2615                },
2616                "ManifestName": {
2617                    "target": "com.amazonaws.mediatailor#__string",
2618                    "traits": {
2619                        "smithy.api#documentation": "<p>The name of the manifest for the channel. The name appears in the PlaybackUrl.</p>",
2620                        "smithy.api#required": {}
2621                    }
2622                },
2623                "SourceGroup": {
2624                    "target": "com.amazonaws.mediatailor#__string",
2625                    "traits": {
2626                        "smithy.api#documentation": "<p>A string used to match which HttpPackageConfiguration is used for each VodSource.</p>",
2627                        "smithy.api#required": {}
2628                    }
2629                }
2630            },
2631            "traits": {
2632                "smithy.api#documentation": "<p>The ouput configuration for this channel.</p>"
2633            }
2634        },
2635        "com.amazonaws.mediatailor#RequestOutputs": {
2636            "type": "list",
2637            "member": {
2638                "target": "com.amazonaws.mediatailor#RequestOutputItem"
2639            },
2640            "traits": {
2641                "smithy.api#documentation": "<p>An object that represents an object in the CreateChannel request.</p>"
2642            }
2643        },
2644        "com.amazonaws.mediatailor#ResponseOutputItem": {
2645            "type": "structure",
2646            "members": {
2647                "DashPlaylistSettings": {
2648                    "target": "com.amazonaws.mediatailor#DashPlaylistSettings",
2649                    "traits": {
2650                        "smithy.api#documentation": "<p>DASH manifest configuration settings.</p>"
2651                    }
2652                },
2653                "HlsPlaylistSettings": {
2654                    "target": "com.amazonaws.mediatailor#HlsPlaylistSettings",
2655                    "traits": {
2656                        "smithy.api#documentation": "<p>HLS manifest configuration settings.</p>"
2657                    }
2658                },
2659                "ManifestName": {
2660                    "target": "com.amazonaws.mediatailor#__string",
2661                    "traits": {
2662                        "smithy.api#documentation": "<p>The name of the manifest for the channel that will appear in the channel output's playback URL.</p>",
2663                        "smithy.api#required": {}
2664                    }
2665                },
2666                "PlaybackUrl": {
2667                    "target": "com.amazonaws.mediatailor#__string",
2668                    "traits": {
2669                        "smithy.api#documentation": "<p>The URL used for playback by content players.</p>",
2670                        "smithy.api#required": {}
2671                    }
2672                },
2673                "SourceGroup": {
2674                    "target": "com.amazonaws.mediatailor#__string",
2675                    "traits": {
2676                        "smithy.api#documentation": "<p>A string used to associate a package configuration source group with a channel output.</p>",
2677                        "smithy.api#required": {}
2678                    }
2679                }
2680            },
2681            "traits": {
2682                "smithy.api#documentation": "<p>This response includes only the \"property\" : \"type\" property.</p>"
2683            }
2684        },
2685        "com.amazonaws.mediatailor#ResponseOutputs": {
2686            "type": "list",
2687            "member": {
2688                "target": "com.amazonaws.mediatailor#ResponseOutputItem"
2689            }
2690        },
2691        "com.amazonaws.mediatailor#ScheduleConfiguration": {
2692            "type": "structure",
2693            "members": {
2694                "Transition": {
2695                    "target": "com.amazonaws.mediatailor#Transition",
2696                    "traits": {
2697                        "smithy.api#documentation": "<p>Program transition configurations.</p>",
2698                        "smithy.api#required": {}
2699                    }
2700                }
2701            },
2702            "traits": {
2703                "smithy.api#documentation": "<p>Schedule configuration parameters. A channel must be stopped before changes can be made to the schedule.</p>"
2704            }
2705        },
2706        "com.amazonaws.mediatailor#ScheduleEntry": {
2707            "type": "structure",
2708            "members": {
2709                "ApproximateDurationSeconds": {
2710                    "target": "com.amazonaws.mediatailor#__long",
2711                    "traits": {
2712                        "smithy.api#documentation": "<p>The approximate duration of this program, in seconds.</p>"
2713                    }
2714                },
2715                "ApproximateStartTime": {
2716                    "target": "com.amazonaws.mediatailor#__timestampUnix",
2717                    "traits": {
2718                        "smithy.api#documentation": "<p>The approximate time that the program will start playing.</p>"
2719                    }
2720                },
2721                "Arn": {
2722                    "target": "com.amazonaws.mediatailor#__string",
2723                    "traits": {
2724                        "smithy.api#documentation": "<p>The ARN of the program.</p>",
2725                        "smithy.api#required": {}
2726                    }
2727                },
2728                "ChannelName": {
2729                    "target": "com.amazonaws.mediatailor#__string",
2730                    "traits": {
2731                        "smithy.api#documentation": "<p>The name of the channel that uses this schedule.</p>",
2732                        "smithy.api#required": {}
2733                    }
2734                },
2735                "ProgramName": {
2736                    "target": "com.amazonaws.mediatailor#__string",
2737                    "traits": {
2738                        "smithy.api#documentation": "<p>The name of the program.</p>",
2739                        "smithy.api#required": {}
2740                    }
2741                },
2742                "SourceLocationName": {
2743                    "target": "com.amazonaws.mediatailor#__string",
2744                    "traits": {
2745                        "smithy.api#documentation": "<p>The name of the source location.</p>",
2746                        "smithy.api#required": {}
2747                    }
2748                },
2749                "VodSourceName": {
2750                    "target": "com.amazonaws.mediatailor#__string",
2751                    "traits": {
2752                        "smithy.api#documentation": "<p>The name of the VOD source.</p>",
2753                        "smithy.api#required": {}
2754                    }
2755                }
2756            },
2757            "traits": {
2758                "smithy.api#documentation": "<p>The properties for a schedule.</p>"
2759            }
2760        },
2761        "com.amazonaws.mediatailor#SlateSource": {
2762            "type": "structure",
2763            "members": {
2764                "SourceLocationName": {
2765                    "target": "com.amazonaws.mediatailor#__string",
2766                    "traits": {
2767                        "smithy.api#documentation": "<p>The name of the source location where the slate VOD source is stored.</p>"
2768                    }
2769                },
2770                "VodSourceName": {
2771                    "target": "com.amazonaws.mediatailor#__string",
2772                    "traits": {
2773                        "smithy.api#documentation": "<p>The slate VOD source name. The VOD source must already exist in a source location before it can be used for slate.</p>"
2774                    }
2775                }
2776            },
2777            "traits": {
2778                "smithy.api#documentation": "<p>Slate VOD source configuration.</p>"
2779            }
2780        },
2781        "com.amazonaws.mediatailor#SourceLocation": {
2782            "type": "structure",
2783            "members": {
2784                "AccessConfiguration": {
2785                    "target": "com.amazonaws.mediatailor#AccessConfiguration",
2786                    "traits": {
2787                        "smithy.api#documentation": "<p>The access configuration for the source location.</p>"
2788                    }
2789                },
2790                "Arn": {
2791                    "target": "com.amazonaws.mediatailor#__string",
2792                    "traits": {
2793                        "smithy.api#documentation": "<p>The ARN of the SourceLocation.</p>",
2794                        "smithy.api#required": {}
2795                    }
2796                },
2797                "CreationTime": {
2798                    "target": "com.amazonaws.mediatailor#__timestampUnix",
2799                    "traits": {
2800                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was created.</p>"
2801                    }
2802                },
2803                "DefaultSegmentDeliveryConfiguration": {
2804                    "target": "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration",
2805                    "traits": {
2806                        "smithy.api#documentation": "<p>The default segment delivery configuration.</p>"
2807                    }
2808                },
2809                "HttpConfiguration": {
2810                    "target": "com.amazonaws.mediatailor#HttpConfiguration",
2811                    "traits": {
2812                        "smithy.api#documentation": "<p>The HTTP configuration for the source location.</p>",
2813                        "smithy.api#required": {}
2814                    }
2815                },
2816                "LastModifiedTime": {
2817                    "target": "com.amazonaws.mediatailor#__timestampUnix",
2818                    "traits": {
2819                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was last modified.</p>"
2820                    }
2821                },
2822                "SourceLocationName": {
2823                    "target": "com.amazonaws.mediatailor#__string",
2824                    "traits": {
2825                        "smithy.api#documentation": "<p>The name of the source location.</p>",
2826                        "smithy.api#required": {}
2827                    }
2828                },
2829                "Tags": {
2830                    "target": "com.amazonaws.mediatailor#__mapOf__string",
2831                    "traits": {
2832                        "smithy.api#documentation": "<p>The tags assigned to the source location.</p>",
2833                        "smithy.api#jsonName": "tags"
2834                    }
2835                }
2836            },
2837            "traits": {
2838                "smithy.api#documentation": "<p>This response includes only the \"type\" : \"object\" property.</p>"
2839            }
2840        },
2841        "com.amazonaws.mediatailor#SpliceInsertMessage": {
2842            "type": "structure",
2843            "members": {
2844                "AvailNum": {
2845                    "target": "com.amazonaws.mediatailor#__integer",
2846                    "traits": {
2847                        "smithy.api#documentation": "<p>This is written to splice_insert.avail_num, as defined in section 9.7.3.1 of the SCTE-35 specification. The default value is 0. Values must be between 0 and 256, inclusive.</p>"
2848                    }
2849                },
2850                "AvailsExpected": {
2851                    "target": "com.amazonaws.mediatailor#__integer",
2852                    "traits": {
2853                        "smithy.api#documentation": "<p>This is written to splice_insert.avails_expected, as defined in section 9.7.3.1 of the SCTE-35 specification. The default value is 0. Values must be between 0 and 256, inclusive.</p>"
2854                    }
2855                },
2856                "SpliceEventId": {
2857                    "target": "com.amazonaws.mediatailor#__integer",
2858                    "traits": {
2859                        "smithy.api#documentation": "<p>This is written to splice_insert.splice_event_id, as defined in section 9.7.3.1 of the SCTE-35 specification. The default value is 1.</p>"
2860                    }
2861                },
2862                "UniqueProgramId": {
2863                    "target": "com.amazonaws.mediatailor#__integer",
2864                    "traits": {
2865                        "smithy.api#documentation": "<p>This is written to splice_insert.unique_program_id, as defined in section 9.7.3.1 of the SCTE-35 specification. The default value is 0. Values must be between 0 and 256, inclusive.</p>"
2866                    }
2867                }
2868            },
2869            "traits": {
2870                "smithy.api#documentation": "<p>Splice insert message configuration.</p>"
2871            }
2872        },
2873        "com.amazonaws.mediatailor#StartChannel": {
2874            "type": "operation",
2875            "input": {
2876                "target": "com.amazonaws.mediatailor#StartChannelRequest"
2877            },
2878            "output": {
2879                "target": "com.amazonaws.mediatailor#StartChannelResponse"
2880            },
2881            "traits": {
2882                "smithy.api#documentation": "<p>Starts a specific channel.</p>",
2883                "smithy.api#http": {
2884                    "method": "PUT",
2885                    "uri": "/channel/{ChannelName}/start",
2886                    "code": 200
2887                }
2888            }
2889        },
2890        "com.amazonaws.mediatailor#StartChannelRequest": {
2891            "type": "structure",
2892            "members": {
2893                "ChannelName": {
2894                    "target": "com.amazonaws.mediatailor#__string",
2895                    "traits": {
2896                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
2897                        "smithy.api#httpLabel": {},
2898                        "smithy.api#required": {}
2899                    }
2900                }
2901            }
2902        },
2903        "com.amazonaws.mediatailor#StartChannelResponse": {
2904            "type": "structure",
2905            "members": {}
2906        },
2907        "com.amazonaws.mediatailor#StopChannel": {
2908            "type": "operation",
2909            "input": {
2910                "target": "com.amazonaws.mediatailor#StopChannelRequest"
2911            },
2912            "output": {
2913                "target": "com.amazonaws.mediatailor#StopChannelResponse"
2914            },
2915            "traits": {
2916                "smithy.api#documentation": "<p>Stops a specific channel.</p>",
2917                "smithy.api#http": {
2918                    "method": "PUT",
2919                    "uri": "/channel/{ChannelName}/stop",
2920                    "code": 200
2921                }
2922            }
2923        },
2924        "com.amazonaws.mediatailor#StopChannelRequest": {
2925            "type": "structure",
2926            "members": {
2927                "ChannelName": {
2928                    "target": "com.amazonaws.mediatailor#__string",
2929                    "traits": {
2930                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
2931                        "smithy.api#httpLabel": {},
2932                        "smithy.api#required": {}
2933                    }
2934                }
2935            }
2936        },
2937        "com.amazonaws.mediatailor#StopChannelResponse": {
2938            "type": "structure",
2939            "members": {}
2940        },
2941        "com.amazonaws.mediatailor#TagResource": {
2942            "type": "operation",
2943            "input": {
2944                "target": "com.amazonaws.mediatailor#TagResourceRequest"
2945            },
2946            "errors": [
2947                {
2948                    "target": "com.amazonaws.mediatailor#BadRequestException"
2949                }
2950            ],
2951            "traits": {
2952                "smithy.api#documentation": "<p>Adds tags to the specified playback configuration resource. You can specify one or more tags to add.</p>",
2953                "smithy.api#http": {
2954                    "method": "POST",
2955                    "uri": "/tags/{ResourceArn}",
2956                    "code": 204
2957                }
2958            }
2959        },
2960        "com.amazonaws.mediatailor#TagResourceRequest": {
2961            "type": "structure",
2962            "members": {
2963                "ResourceArn": {
2964                    "target": "com.amazonaws.mediatailor#__string",
2965                    "traits": {
2966                        "smithy.api#documentation": "<p>The Amazon Resource Name (ARN) for the playback configuration. You can get this from the response to any playback configuration request.</p>",
2967                        "smithy.api#httpLabel": {},
2968                        "smithy.api#required": {}
2969                    }
2970                },
2971                "Tags": {
2972                    "target": "com.amazonaws.mediatailor#__mapOf__string",
2973                    "traits": {
2974                        "smithy.api#documentation": "<p>A comma-separated list of tag key:value pairs.</p>",
2975                        "smithy.api#jsonName": "tags",
2976                        "smithy.api#required": {}
2977                    }
2978                }
2979            }
2980        },
2981        "com.amazonaws.mediatailor#Transition": {
2982            "type": "structure",
2983            "members": {
2984                "RelativePosition": {
2985                    "target": "com.amazonaws.mediatailor#RelativePosition",
2986                    "traits": {
2987                        "smithy.api#documentation": "<p>The position where this program will be inserted relative to the RelativeProgram. Possible values are: AFTER_PROGRAM, and BEFORE_PROGRAM.</p>",
2988                        "smithy.api#required": {}
2989                    }
2990                },
2991                "RelativeProgram": {
2992                    "target": "com.amazonaws.mediatailor#__string",
2993                    "traits": {
2994                        "smithy.api#documentation": "<p>The name of the program that this program will be inserted next to, as defined by RelativePosition.</p>"
2995                    }
2996                },
2997                "Type": {
2998                    "target": "com.amazonaws.mediatailor#__string",
2999                    "traits": {
3000                        "smithy.api#documentation": "<p>When the program should be played. RELATIVE means that programs will be played back-to-back.</p>",
3001                        "smithy.api#required": {}
3002                    }
3003                }
3004            },
3005            "traits": {
3006                "smithy.api#documentation": "<p>Program transition configuration.</p>"
3007            }
3008        },
3009        "com.amazonaws.mediatailor#Type": {
3010            "type": "string",
3011            "traits": {
3012                "smithy.api#enum": [
3013                    {
3014                        "value": "DASH",
3015                        "name": "DASH"
3016                    },
3017                    {
3018                        "value": "HLS",
3019                        "name": "HLS"
3020                    }
3021                ]
3022            }
3023        },
3024        "com.amazonaws.mediatailor#UntagResource": {
3025            "type": "operation",
3026            "input": {
3027                "target": "com.amazonaws.mediatailor#UntagResourceRequest"
3028            },
3029            "errors": [
3030                {
3031                    "target": "com.amazonaws.mediatailor#BadRequestException"
3032                }
3033            ],
3034            "traits": {
3035                "smithy.api#documentation": "<p>Removes tags from the specified playback configuration resource. You can specify one or more tags to remove.</p>",
3036                "smithy.api#http": {
3037                    "method": "DELETE",
3038                    "uri": "/tags/{ResourceArn}",
3039                    "code": 204
3040                }
3041            }
3042        },
3043        "com.amazonaws.mediatailor#UntagResourceRequest": {
3044            "type": "structure",
3045            "members": {
3046                "ResourceArn": {
3047                    "target": "com.amazonaws.mediatailor#__string",
3048                    "traits": {
3049                        "smithy.api#documentation": "<p>The Amazon Resource Name (ARN) for the playback configuration. You can get this from the response to any playback configuration request.</p>",
3050                        "smithy.api#httpLabel": {},
3051                        "smithy.api#required": {}
3052                    }
3053                },
3054                "TagKeys": {
3055                    "target": "com.amazonaws.mediatailor#__listOf__string",
3056                    "traits": {
3057                        "smithy.api#documentation": "<p>A comma-separated list of the tag keys to remove from the playback configuration.</p>",
3058                        "smithy.api#httpQuery": "tagKeys",
3059                        "smithy.api#required": {}
3060                    }
3061                }
3062            }
3063        },
3064        "com.amazonaws.mediatailor#UpdateChannel": {
3065            "type": "operation",
3066            "input": {
3067                "target": "com.amazonaws.mediatailor#UpdateChannelRequest"
3068            },
3069            "output": {
3070                "target": "com.amazonaws.mediatailor#UpdateChannelResponse"
3071            },
3072            "traits": {
3073                "smithy.api#documentation": "<p>Updates an existing channel.</p>",
3074                "smithy.api#http": {
3075                    "method": "PUT",
3076                    "uri": "/channel/{ChannelName}",
3077                    "code": 200
3078                }
3079            }
3080        },
3081        "com.amazonaws.mediatailor#UpdateChannelRequest": {
3082            "type": "structure",
3083            "members": {
3084                "ChannelName": {
3085                    "target": "com.amazonaws.mediatailor#__string",
3086                    "traits": {
3087                        "smithy.api#documentation": "<p>The identifier for the channel you are working on.</p>",
3088                        "smithy.api#httpLabel": {},
3089                        "smithy.api#required": {}
3090                    }
3091                },
3092                "Outputs": {
3093                    "target": "com.amazonaws.mediatailor#RequestOutputs",
3094                    "traits": {
3095                        "smithy.api#documentation": "<p>The channel's output properties.</p>",
3096                        "smithy.api#required": {}
3097                    }
3098                }
3099            }
3100        },
3101        "com.amazonaws.mediatailor#UpdateChannelResponse": {
3102            "type": "structure",
3103            "members": {
3104                "Arn": {
3105                    "target": "com.amazonaws.mediatailor#__string",
3106                    "traits": {
3107                        "smithy.api#documentation": "<p>The ARN of the channel.</p>"
3108                    }
3109                },
3110                "ChannelName": {
3111                    "target": "com.amazonaws.mediatailor#__string",
3112                    "traits": {
3113                        "smithy.api#documentation": "<p>The name of the channel.</p>"
3114                    }
3115                },
3116                "ChannelState": {
3117                    "target": "com.amazonaws.mediatailor#ChannelState",
3118                    "traits": {
3119                        "smithy.api#documentation": "<p>Indicates whether the channel is in a running state or not.</p>"
3120                    }
3121                },
3122                "CreationTime": {
3123                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3124                    "traits": {
3125                        "smithy.api#documentation": "<p>The timestamp of when the channel was created.</p>"
3126                    }
3127                },
3128                "LastModifiedTime": {
3129                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3130                    "traits": {
3131                        "smithy.api#documentation": "<p>The timestamp of when the channel was last modified.</p>"
3132                    }
3133                },
3134                "Outputs": {
3135                    "target": "com.amazonaws.mediatailor#ResponseOutputs",
3136                    "traits": {
3137                        "smithy.api#documentation": "<p>The channel's output properties.</p>"
3138                    }
3139                },
3140                "PlaybackMode": {
3141                    "target": "com.amazonaws.mediatailor#__string",
3142                    "traits": {
3143                        "smithy.api#documentation": "<p>The type of playback for this channel. The only supported value is LOOP.</p>"
3144                    }
3145                },
3146                "Tags": {
3147                    "target": "com.amazonaws.mediatailor#__mapOf__string",
3148                    "traits": {
3149                        "smithy.api#documentation": "<p>The tags assigned to the channel.</p>",
3150                        "smithy.api#jsonName": "tags"
3151                    }
3152                }
3153            }
3154        },
3155        "com.amazonaws.mediatailor#UpdateSourceLocation": {
3156            "type": "operation",
3157            "input": {
3158                "target": "com.amazonaws.mediatailor#UpdateSourceLocationRequest"
3159            },
3160            "output": {
3161                "target": "com.amazonaws.mediatailor#UpdateSourceLocationResponse"
3162            },
3163            "traits": {
3164                "smithy.api#documentation": "<p>Updates a source location on a specific channel.</p>",
3165                "smithy.api#http": {
3166                    "method": "PUT",
3167                    "uri": "/sourceLocation/{SourceLocationName}",
3168                    "code": 200
3169                }
3170            }
3171        },
3172        "com.amazonaws.mediatailor#UpdateSourceLocationRequest": {
3173            "type": "structure",
3174            "members": {
3175                "AccessConfiguration": {
3176                    "target": "com.amazonaws.mediatailor#AccessConfiguration",
3177                    "traits": {
3178                        "smithy.api#documentation": "<p>Access configuration parameters. Configures the type of authentication used to access content from your source location.</p>"
3179                    }
3180                },
3181                "DefaultSegmentDeliveryConfiguration": {
3182                    "target": "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration",
3183                    "traits": {
3184                        "smithy.api#documentation": "<p>The optional configuration for the host server that serves segments.</p>"
3185                    }
3186                },
3187                "HttpConfiguration": {
3188                    "target": "com.amazonaws.mediatailor#HttpConfiguration",
3189                    "traits": {
3190                        "smithy.api#documentation": "<p>The HTTP configuration for the source location.</p>",
3191                        "smithy.api#required": {}
3192                    }
3193                },
3194                "SourceLocationName": {
3195                    "target": "com.amazonaws.mediatailor#__string",
3196                    "traits": {
3197                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
3198                        "smithy.api#httpLabel": {},
3199                        "smithy.api#required": {}
3200                    }
3201                }
3202            }
3203        },
3204        "com.amazonaws.mediatailor#UpdateSourceLocationResponse": {
3205            "type": "structure",
3206            "members": {
3207                "AccessConfiguration": {
3208                    "target": "com.amazonaws.mediatailor#AccessConfiguration",
3209                    "traits": {
3210                        "smithy.api#documentation": "<p>The access configuration for the source location.</p>"
3211                    }
3212                },
3213                "Arn": {
3214                    "target": "com.amazonaws.mediatailor#__string",
3215                    "traits": {
3216                        "smithy.api#documentation": "<p>The ARN of the source location.</p>"
3217                    }
3218                },
3219                "CreationTime": {
3220                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3221                    "traits": {
3222                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was created.</p>"
3223                    }
3224                },
3225                "DefaultSegmentDeliveryConfiguration": {
3226                    "target": "com.amazonaws.mediatailor#DefaultSegmentDeliveryConfiguration",
3227                    "traits": {
3228                        "smithy.api#documentation": "<p>The default segment delivery configuration settings.</p>"
3229                    }
3230                },
3231                "HttpConfiguration": {
3232                    "target": "com.amazonaws.mediatailor#HttpConfiguration",
3233                    "traits": {
3234                        "smithy.api#documentation": "<p>The HTTP package configuration settings for the source location.</p>"
3235                    }
3236                },
3237                "LastModifiedTime": {
3238                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3239                    "traits": {
3240                        "smithy.api#documentation": "<p>The timestamp that indicates when the source location was last modified.</p>"
3241                    }
3242                },
3243                "SourceLocationName": {
3244                    "target": "com.amazonaws.mediatailor#__string",
3245                    "traits": {
3246                        "smithy.api#documentation": "<p>The name of the source location.</p>"
3247                    }
3248                },
3249                "Tags": {
3250                    "target": "com.amazonaws.mediatailor#__mapOf__string",
3251                    "traits": {
3252                        "smithy.api#documentation": "<p>The tags assigned to the source location.</p>",
3253                        "smithy.api#jsonName": "tags"
3254                    }
3255                }
3256            }
3257        },
3258        "com.amazonaws.mediatailor#UpdateVodSource": {
3259            "type": "operation",
3260            "input": {
3261                "target": "com.amazonaws.mediatailor#UpdateVodSourceRequest"
3262            },
3263            "output": {
3264                "target": "com.amazonaws.mediatailor#UpdateVodSourceResponse"
3265            },
3266            "traits": {
3267                "smithy.api#documentation": "<p>Updates a specific VOD source in a specific source location.</p>",
3268                "smithy.api#http": {
3269                    "method": "PUT",
3270                    "uri": "/sourceLocation/{SourceLocationName}/vodSource/{VodSourceName}",
3271                    "code": 200
3272                }
3273            }
3274        },
3275        "com.amazonaws.mediatailor#UpdateVodSourceRequest": {
3276            "type": "structure",
3277            "members": {
3278                "HttpPackageConfigurations": {
3279                    "target": "com.amazonaws.mediatailor#HttpPackageConfigurations",
3280                    "traits": {
3281                        "smithy.api#documentation": "<p>An array of HTTP package configurations for the VOD source on this account.</p>",
3282                        "smithy.api#required": {}
3283                    }
3284                },
3285                "SourceLocationName": {
3286                    "target": "com.amazonaws.mediatailor#__string",
3287                    "traits": {
3288                        "smithy.api#documentation": "<p>The identifier for the source location you are working on.</p>",
3289                        "smithy.api#httpLabel": {},
3290                        "smithy.api#required": {}
3291                    }
3292                },
3293                "VodSourceName": {
3294                    "target": "com.amazonaws.mediatailor#__string",
3295                    "traits": {
3296                        "smithy.api#documentation": "<p>The identifier for the VOD source you are working on.</p>",
3297                        "smithy.api#httpLabel": {},
3298                        "smithy.api#required": {}
3299                    }
3300                }
3301            }
3302        },
3303        "com.amazonaws.mediatailor#UpdateVodSourceResponse": {
3304            "type": "structure",
3305            "members": {
3306                "Arn": {
3307                    "target": "com.amazonaws.mediatailor#__string",
3308                    "traits": {
3309                        "smithy.api#documentation": "<p>The ARN of the VOD source.</p>"
3310                    }
3311                },
3312                "CreationTime": {
3313                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3314                    "traits": {
3315                        "smithy.api#documentation": "<p>The timestamp that indicates when the VOD source was created.</p>"
3316                    }
3317                },
3318                "HttpPackageConfigurations": {
3319                    "target": "com.amazonaws.mediatailor#HttpPackageConfigurations",
3320                    "traits": {
3321                        "smithy.api#documentation": "<p>The HTTP package configurations.</p>"
3322                    }
3323                },
3324                "LastModifiedTime": {
3325                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3326                    "traits": {
3327                        "smithy.api#documentation": "<p>The ARN for the VOD source.</p>"
3328                    }
3329                },
3330                "SourceLocationName": {
3331                    "target": "com.amazonaws.mediatailor#__string",
3332                    "traits": {
3333                        "smithy.api#documentation": "<p>The name of the source location associated with the VOD source.</p>"
3334                    }
3335                },
3336                "Tags": {
3337                    "target": "com.amazonaws.mediatailor#__mapOf__string",
3338                    "traits": {
3339                        "smithy.api#documentation": "<p>The tags assigned to the VOD source.</p>",
3340                        "smithy.api#jsonName": "tags"
3341                    }
3342                },
3343                "VodSourceName": {
3344                    "target": "com.amazonaws.mediatailor#__string",
3345                    "traits": {
3346                        "smithy.api#documentation": "<p>The name of the VOD source.</p>"
3347                    }
3348                }
3349            }
3350        },
3351        "com.amazonaws.mediatailor#VodSource": {
3352            "type": "structure",
3353            "members": {
3354                "Arn": {
3355                    "target": "com.amazonaws.mediatailor#__string",
3356                    "traits": {
3357                        "smithy.api#documentation": "<p>The ARN for the VOD source.</p>",
3358                        "smithy.api#required": {}
3359                    }
3360                },
3361                "CreationTime": {
3362                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3363                    "traits": {
3364                        "smithy.api#documentation": "<p>The timestamp that indicates when the VOD source was created.</p>"
3365                    }
3366                },
3367                "HttpPackageConfigurations": {
3368                    "target": "com.amazonaws.mediatailor#HttpPackageConfigurations",
3369                    "traits": {
3370                        "smithy.api#documentation": "<p>The HTTP package configurations for the VOD source.</p>",
3371                        "smithy.api#required": {}
3372                    }
3373                },
3374                "LastModifiedTime": {
3375                    "target": "com.amazonaws.mediatailor#__timestampUnix",
3376                    "traits": {
3377                        "smithy.api#documentation": "<p>The timestamp that indicates when the VOD source was last modified.</p>"
3378                    }
3379                },
3380                "SourceLocationName": {
3381                    "target": "com.amazonaws.mediatailor#__string",
3382                    "traits": {
3383                        "smithy.api#documentation": "<p>The name of the source location that the VOD source is associated with.</p>",
3384                        "smithy.api#required": {}
3385                    }
3386                },
3387                "Tags": {
3388                    "target": "com.amazonaws.mediatailor#__mapOf__string",
3389                    "traits": {
3390                        "smithy.api#documentation": "<p>The tags assigned to the VOD source.</p>",
3391                        "smithy.api#jsonName": "tags"
3392                    }
3393                },
3394                "VodSourceName": {
3395                    "target": "com.amazonaws.mediatailor#__string",
3396                    "traits": {
3397                        "smithy.api#documentation": "<p>The name of the VOD source.</p>",
3398                        "smithy.api#required": {}
3399                    }
3400                }
3401            },
3402            "traits": {
3403                "smithy.api#documentation": "<p>VOD source configuration parameters.</p>"
3404            }
3405        },
3406        "com.amazonaws.mediatailor#__boolean": {
3407            "type": "boolean"
3408        },
3409        "com.amazonaws.mediatailor#__integer": {
3410            "type": "integer"
3411        },
3412        "com.amazonaws.mediatailor#__integerMin1": {
3413            "type": "integer",
3414            "traits": {
3415                "smithy.api#range": {
3416                    "min": 1
3417                }
3418            }
3419        },
3420        "com.amazonaws.mediatailor#__listOfAdBreak": {
3421            "type": "list",
3422            "member": {
3423                "target": "com.amazonaws.mediatailor#AdBreak"
3424            }
3425        },
3426        "com.amazonaws.mediatailor#__listOfChannel": {
3427            "type": "list",
3428            "member": {
3429                "target": "com.amazonaws.mediatailor#Channel"
3430            }
3431        },
3432        "com.amazonaws.mediatailor#__listOfPlaybackConfiguration": {
3433            "type": "list",
3434            "member": {
3435                "target": "com.amazonaws.mediatailor#PlaybackConfiguration"
3436            }
3437        },
3438        "com.amazonaws.mediatailor#__listOfScheduleEntry": {
3439            "type": "list",
3440            "member": {
3441                "target": "com.amazonaws.mediatailor#ScheduleEntry"
3442            }
3443        },
3444        "com.amazonaws.mediatailor#__listOfSourceLocation": {
3445            "type": "list",
3446            "member": {
3447                "target": "com.amazonaws.mediatailor#SourceLocation"
3448            }
3449        },
3450        "com.amazonaws.mediatailor#__listOfVodSource": {
3451            "type": "list",
3452            "member": {
3453                "target": "com.amazonaws.mediatailor#VodSource"
3454            }
3455        },
3456        "com.amazonaws.mediatailor#__listOf__string": {
3457            "type": "list",
3458            "member": {
3459                "target": "com.amazonaws.mediatailor#__string"
3460            }
3461        },
3462        "com.amazonaws.mediatailor#__long": {
3463            "type": "long"
3464        },
3465        "com.amazonaws.mediatailor#__mapOf__string": {
3466            "type": "map",
3467            "key": {
3468                "target": "com.amazonaws.mediatailor#__string"
3469            },
3470            "value": {
3471                "target": "com.amazonaws.mediatailor#__string"
3472            }
3473        },
3474        "com.amazonaws.mediatailor#__string": {
3475            "type": "string"
3476        },
3477        "com.amazonaws.mediatailor#__timestampUnix": {
3478            "type": "timestamp",
3479            "traits": {
3480                "smithy.api#timestampFormat": "epoch-seconds"
3481            }
3482        }
3483    }
3484}
3485