1{
2  "version":"2.0",
3  "metadata":{
4    "apiVersion":"2017-10-26",
5    "endpointPrefix":"transcribe",
6    "jsonVersion":"1.1",
7    "protocol":"json",
8    "serviceFullName":"Amazon Transcribe Service",
9    "serviceId":"Transcribe",
10    "signatureVersion":"v4",
11    "signingName":"transcribe",
12    "targetPrefix":"Transcribe",
13    "uid":"transcribe-2017-10-26"
14  },
15  "operations":{
16    "CreateCallAnalyticsCategory":{
17      "name":"CreateCallAnalyticsCategory",
18      "http":{
19        "method":"POST",
20        "requestUri":"/"
21      },
22      "input":{"shape":"CreateCallAnalyticsCategoryRequest"},
23      "output":{"shape":"CreateCallAnalyticsCategoryResponse"},
24      "errors":[
25        {"shape":"BadRequestException"},
26        {"shape":"LimitExceededException"},
27        {"shape":"InternalFailureException"},
28        {"shape":"ConflictException"}
29      ],
30      "documentation":"<p>Creates an analytics category. Amazon Transcribe applies the conditions specified by your analytics categories to your call analytics jobs. For each analytics category, you specify one or more rules. For example, you can specify a rule that the customer sentiment was neutral or negative within that category. If you start a call analytics job, Amazon Transcribe applies the category to the analytics job that you've specified.</p>"
31    },
32    "CreateLanguageModel":{
33      "name":"CreateLanguageModel",
34      "http":{
35        "method":"POST",
36        "requestUri":"/"
37      },
38      "input":{"shape":"CreateLanguageModelRequest"},
39      "output":{"shape":"CreateLanguageModelResponse"},
40      "errors":[
41        {"shape":"BadRequestException"},
42        {"shape":"LimitExceededException"},
43        {"shape":"InternalFailureException"},
44        {"shape":"ConflictException"}
45      ],
46      "documentation":"<p>Creates a new custom language model. Use Amazon S3 prefixes to provide the location of your input files. The time it takes to create your model depends on the size of your training data.</p>"
47    },
48    "CreateMedicalVocabulary":{
49      "name":"CreateMedicalVocabulary",
50      "http":{
51        "method":"POST",
52        "requestUri":"/"
53      },
54      "input":{"shape":"CreateMedicalVocabularyRequest"},
55      "output":{"shape":"CreateMedicalVocabularyResponse"},
56      "errors":[
57        {"shape":"BadRequestException"},
58        {"shape":"LimitExceededException"},
59        {"shape":"InternalFailureException"},
60        {"shape":"ConflictException"}
61      ],
62      "documentation":"<p>Creates a new custom vocabulary that you can use to modify how Amazon Transcribe Medical transcribes your audio file.</p>"
63    },
64    "CreateVocabulary":{
65      "name":"CreateVocabulary",
66      "http":{
67        "method":"POST",
68        "requestUri":"/"
69      },
70      "input":{"shape":"CreateVocabularyRequest"},
71      "output":{"shape":"CreateVocabularyResponse"},
72      "errors":[
73        {"shape":"BadRequestException"},
74        {"shape":"LimitExceededException"},
75        {"shape":"InternalFailureException"},
76        {"shape":"ConflictException"}
77      ],
78      "documentation":"<p>Creates a new custom vocabulary that you can use to change the way Amazon Transcribe handles transcription of an audio file.</p>"
79    },
80    "CreateVocabularyFilter":{
81      "name":"CreateVocabularyFilter",
82      "http":{
83        "method":"POST",
84        "requestUri":"/"
85      },
86      "input":{"shape":"CreateVocabularyFilterRequest"},
87      "output":{"shape":"CreateVocabularyFilterResponse"},
88      "errors":[
89        {"shape":"BadRequestException"},
90        {"shape":"LimitExceededException"},
91        {"shape":"InternalFailureException"},
92        {"shape":"ConflictException"}
93      ],
94      "documentation":"<p>Creates a new vocabulary filter that you can use to filter words, such as profane words, from the output of a transcription job.</p>"
95    },
96    "DeleteCallAnalyticsCategory":{
97      "name":"DeleteCallAnalyticsCategory",
98      "http":{
99        "method":"POST",
100        "requestUri":"/"
101      },
102      "input":{"shape":"DeleteCallAnalyticsCategoryRequest"},
103      "output":{"shape":"DeleteCallAnalyticsCategoryResponse"},
104      "errors":[
105        {"shape":"NotFoundException"},
106        {"shape":"LimitExceededException"},
107        {"shape":"BadRequestException"},
108        {"shape":"InternalFailureException"}
109      ],
110      "documentation":"<p>Deletes a call analytics category using its name.</p>"
111    },
112    "DeleteCallAnalyticsJob":{
113      "name":"DeleteCallAnalyticsJob",
114      "http":{
115        "method":"POST",
116        "requestUri":"/"
117      },
118      "input":{"shape":"DeleteCallAnalyticsJobRequest"},
119      "output":{"shape":"DeleteCallAnalyticsJobResponse"},
120      "errors":[
121        {"shape":"LimitExceededException"},
122        {"shape":"BadRequestException"},
123        {"shape":"InternalFailureException"}
124      ],
125      "documentation":"<p>Deletes a call analytics job using its name.</p>"
126    },
127    "DeleteLanguageModel":{
128      "name":"DeleteLanguageModel",
129      "http":{
130        "method":"POST",
131        "requestUri":"/"
132      },
133      "input":{"shape":"DeleteLanguageModelRequest"},
134      "errors":[
135        {"shape":"BadRequestException"},
136        {"shape":"LimitExceededException"},
137        {"shape":"InternalFailureException"}
138      ],
139      "documentation":"<p>Deletes a custom language model using its name.</p>"
140    },
141    "DeleteMedicalTranscriptionJob":{
142      "name":"DeleteMedicalTranscriptionJob",
143      "http":{
144        "method":"POST",
145        "requestUri":"/"
146      },
147      "input":{"shape":"DeleteMedicalTranscriptionJobRequest"},
148      "errors":[
149        {"shape":"LimitExceededException"},
150        {"shape":"BadRequestException"},
151        {"shape":"InternalFailureException"}
152      ],
153      "documentation":"<p>Deletes a transcription job generated by Amazon Transcribe Medical and any related information.</p>"
154    },
155    "DeleteMedicalVocabulary":{
156      "name":"DeleteMedicalVocabulary",
157      "http":{
158        "method":"POST",
159        "requestUri":"/"
160      },
161      "input":{"shape":"DeleteMedicalVocabularyRequest"},
162      "errors":[
163        {"shape":"NotFoundException"},
164        {"shape":"LimitExceededException"},
165        {"shape":"BadRequestException"},
166        {"shape":"InternalFailureException"}
167      ],
168      "documentation":"<p>Deletes a vocabulary from Amazon Transcribe Medical.</p>"
169    },
170    "DeleteTranscriptionJob":{
171      "name":"DeleteTranscriptionJob",
172      "http":{
173        "method":"POST",
174        "requestUri":"/"
175      },
176      "input":{"shape":"DeleteTranscriptionJobRequest"},
177      "errors":[
178        {"shape":"LimitExceededException"},
179        {"shape":"BadRequestException"},
180        {"shape":"InternalFailureException"}
181      ],
182      "documentation":"<p>Deletes a previously submitted transcription job along with any other generated results such as the transcription, models, and so on.</p>"
183    },
184    "DeleteVocabulary":{
185      "name":"DeleteVocabulary",
186      "http":{
187        "method":"POST",
188        "requestUri":"/"
189      },
190      "input":{"shape":"DeleteVocabularyRequest"},
191      "errors":[
192        {"shape":"NotFoundException"},
193        {"shape":"LimitExceededException"},
194        {"shape":"BadRequestException"},
195        {"shape":"InternalFailureException"}
196      ],
197      "documentation":"<p>Deletes a vocabulary from Amazon Transcribe. </p>"
198    },
199    "DeleteVocabularyFilter":{
200      "name":"DeleteVocabularyFilter",
201      "http":{
202        "method":"POST",
203        "requestUri":"/"
204      },
205      "input":{"shape":"DeleteVocabularyFilterRequest"},
206      "errors":[
207        {"shape":"NotFoundException"},
208        {"shape":"LimitExceededException"},
209        {"shape":"BadRequestException"},
210        {"shape":"InternalFailureException"}
211      ],
212      "documentation":"<p>Removes a vocabulary filter.</p>"
213    },
214    "DescribeLanguageModel":{
215      "name":"DescribeLanguageModel",
216      "http":{
217        "method":"POST",
218        "requestUri":"/"
219      },
220      "input":{"shape":"DescribeLanguageModelRequest"},
221      "output":{"shape":"DescribeLanguageModelResponse"},
222      "errors":[
223        {"shape":"BadRequestException"},
224        {"shape":"LimitExceededException"},
225        {"shape":"InternalFailureException"},
226        {"shape":"NotFoundException"}
227      ],
228      "documentation":"<p>Gets information about a single custom language model. Use this information to see details about the language model in your Amazon Web Services account. You can also see whether the base language model used to create your custom language model has been updated. If Amazon Transcribe has updated the base model, you can create a new custom language model using the updated base model. If the language model wasn't created, you can use this operation to understand why Amazon Transcribe couldn't create it. </p>"
229    },
230    "GetCallAnalyticsCategory":{
231      "name":"GetCallAnalyticsCategory",
232      "http":{
233        "method":"POST",
234        "requestUri":"/"
235      },
236      "input":{"shape":"GetCallAnalyticsCategoryRequest"},
237      "output":{"shape":"GetCallAnalyticsCategoryResponse"},
238      "errors":[
239        {"shape":"NotFoundException"},
240        {"shape":"LimitExceededException"},
241        {"shape":"InternalFailureException"},
242        {"shape":"BadRequestException"}
243      ],
244      "documentation":"<p>Retrieves information about a call analytics category.</p>"
245    },
246    "GetCallAnalyticsJob":{
247      "name":"GetCallAnalyticsJob",
248      "http":{
249        "method":"POST",
250        "requestUri":"/"
251      },
252      "input":{"shape":"GetCallAnalyticsJobRequest"},
253      "output":{"shape":"GetCallAnalyticsJobResponse"},
254      "errors":[
255        {"shape":"BadRequestException"},
256        {"shape":"LimitExceededException"},
257        {"shape":"InternalFailureException"},
258        {"shape":"NotFoundException"}
259      ],
260      "documentation":"<p>Returns information about a call analytics job. To see the status of the job, check the <code>CallAnalyticsJobStatus</code> field. If the status is <code>COMPLETED</code>, the job is finished and you can find the results at the location specified in the <code>TranscriptFileUri</code> field. If you enable personally identifiable information (PII) redaction, the redacted transcript appears in the <code>RedactedTranscriptFileUri</code> field.</p>"
261    },
262    "GetMedicalTranscriptionJob":{
263      "name":"GetMedicalTranscriptionJob",
264      "http":{
265        "method":"POST",
266        "requestUri":"/"
267      },
268      "input":{"shape":"GetMedicalTranscriptionJobRequest"},
269      "output":{"shape":"GetMedicalTranscriptionJobResponse"},
270      "errors":[
271        {"shape":"BadRequestException"},
272        {"shape":"LimitExceededException"},
273        {"shape":"InternalFailureException"},
274        {"shape":"NotFoundException"}
275      ],
276      "documentation":"<p>Returns information about a transcription job from Amazon Transcribe Medical. To see the status of the job, check the <code>TranscriptionJobStatus</code> field. If the status is <code>COMPLETED</code>, the job is finished. You find the results of the completed job in the <code>TranscriptFileUri</code> field.</p>"
277    },
278    "GetMedicalVocabulary":{
279      "name":"GetMedicalVocabulary",
280      "http":{
281        "method":"POST",
282        "requestUri":"/"
283      },
284      "input":{"shape":"GetMedicalVocabularyRequest"},
285      "output":{"shape":"GetMedicalVocabularyResponse"},
286      "errors":[
287        {"shape":"NotFoundException"},
288        {"shape":"LimitExceededException"},
289        {"shape":"InternalFailureException"},
290        {"shape":"BadRequestException"}
291      ],
292      "documentation":"<p>Retrieves information about a medical vocabulary.</p>"
293    },
294    "GetTranscriptionJob":{
295      "name":"GetTranscriptionJob",
296      "http":{
297        "method":"POST",
298        "requestUri":"/"
299      },
300      "input":{"shape":"GetTranscriptionJobRequest"},
301      "output":{"shape":"GetTranscriptionJobResponse"},
302      "errors":[
303        {"shape":"BadRequestException"},
304        {"shape":"LimitExceededException"},
305        {"shape":"InternalFailureException"},
306        {"shape":"NotFoundException"}
307      ],
308      "documentation":"<p>Returns information about a transcription job. To see the status of the job, check the <code>TranscriptionJobStatus</code> field. If the status is <code>COMPLETED</code>, the job is finished and you can find the results at the location specified in the <code>TranscriptFileUri</code> field. If you enable content redaction, the redacted transcript appears in <code>RedactedTranscriptFileUri</code>.</p>"
309    },
310    "GetVocabulary":{
311      "name":"GetVocabulary",
312      "http":{
313        "method":"POST",
314        "requestUri":"/"
315      },
316      "input":{"shape":"GetVocabularyRequest"},
317      "output":{"shape":"GetVocabularyResponse"},
318      "errors":[
319        {"shape":"NotFoundException"},
320        {"shape":"LimitExceededException"},
321        {"shape":"InternalFailureException"},
322        {"shape":"BadRequestException"}
323      ],
324      "documentation":"<p>Gets information about a vocabulary. </p>"
325    },
326    "GetVocabularyFilter":{
327      "name":"GetVocabularyFilter",
328      "http":{
329        "method":"POST",
330        "requestUri":"/"
331      },
332      "input":{"shape":"GetVocabularyFilterRequest"},
333      "output":{"shape":"GetVocabularyFilterResponse"},
334      "errors":[
335        {"shape":"NotFoundException"},
336        {"shape":"LimitExceededException"},
337        {"shape":"InternalFailureException"},
338        {"shape":"BadRequestException"}
339      ],
340      "documentation":"<p>Returns information about a vocabulary filter.</p>"
341    },
342    "ListCallAnalyticsCategories":{
343      "name":"ListCallAnalyticsCategories",
344      "http":{
345        "method":"POST",
346        "requestUri":"/"
347      },
348      "input":{"shape":"ListCallAnalyticsCategoriesRequest"},
349      "output":{"shape":"ListCallAnalyticsCategoriesResponse"},
350      "errors":[
351        {"shape":"BadRequestException"},
352        {"shape":"LimitExceededException"},
353        {"shape":"InternalFailureException"}
354      ],
355      "documentation":"<p>Provides more information about the call analytics categories that you've created. You can use the information in this list to find a specific category. You can then use the operation to get more information about it.</p>"
356    },
357    "ListCallAnalyticsJobs":{
358      "name":"ListCallAnalyticsJobs",
359      "http":{
360        "method":"POST",
361        "requestUri":"/"
362      },
363      "input":{"shape":"ListCallAnalyticsJobsRequest"},
364      "output":{"shape":"ListCallAnalyticsJobsResponse"},
365      "errors":[
366        {"shape":"BadRequestException"},
367        {"shape":"LimitExceededException"},
368        {"shape":"InternalFailureException"}
369      ],
370      "documentation":"<p>List call analytics jobs with a specified status or substring that matches their names.</p>"
371    },
372    "ListLanguageModels":{
373      "name":"ListLanguageModels",
374      "http":{
375        "method":"POST",
376        "requestUri":"/"
377      },
378      "input":{"shape":"ListLanguageModelsRequest"},
379      "output":{"shape":"ListLanguageModelsResponse"},
380      "errors":[
381        {"shape":"BadRequestException"},
382        {"shape":"LimitExceededException"},
383        {"shape":"InternalFailureException"}
384      ],
385      "documentation":"<p>Provides more information about the custom language models you've created. You can use the information in this list to find a specific custom language model. You can then use the operation to get more information about it.</p>"
386    },
387    "ListMedicalTranscriptionJobs":{
388      "name":"ListMedicalTranscriptionJobs",
389      "http":{
390        "method":"POST",
391        "requestUri":"/"
392      },
393      "input":{"shape":"ListMedicalTranscriptionJobsRequest"},
394      "output":{"shape":"ListMedicalTranscriptionJobsResponse"},
395      "errors":[
396        {"shape":"BadRequestException"},
397        {"shape":"LimitExceededException"},
398        {"shape":"InternalFailureException"}
399      ],
400      "documentation":"<p>Lists medical transcription jobs with a specified status or substring that matches their names.</p>"
401    },
402    "ListMedicalVocabularies":{
403      "name":"ListMedicalVocabularies",
404      "http":{
405        "method":"POST",
406        "requestUri":"/"
407      },
408      "input":{"shape":"ListMedicalVocabulariesRequest"},
409      "output":{"shape":"ListMedicalVocabulariesResponse"},
410      "errors":[
411        {"shape":"BadRequestException"},
412        {"shape":"LimitExceededException"},
413        {"shape":"InternalFailureException"}
414      ],
415      "documentation":"<p>Returns a list of vocabularies that match the specified criteria. If you don't enter a value in any of the request parameters, returns the entire list of vocabularies.</p>"
416    },
417    "ListTagsForResource":{
418      "name":"ListTagsForResource",
419      "http":{
420        "method":"POST",
421        "requestUri":"/"
422      },
423      "input":{"shape":"ListTagsForResourceRequest"},
424      "output":{"shape":"ListTagsForResourceResponse"},
425      "errors":[
426        {"shape":"BadRequestException"},
427        {"shape":"NotFoundException"},
428        {"shape":"LimitExceededException"},
429        {"shape":"InternalFailureException"}
430      ],
431      "documentation":"<p>Lists all tags associated with a given transcription job, vocabulary, or resource.</p>"
432    },
433    "ListTranscriptionJobs":{
434      "name":"ListTranscriptionJobs",
435      "http":{
436        "method":"POST",
437        "requestUri":"/"
438      },
439      "input":{"shape":"ListTranscriptionJobsRequest"},
440      "output":{"shape":"ListTranscriptionJobsResponse"},
441      "errors":[
442        {"shape":"BadRequestException"},
443        {"shape":"LimitExceededException"},
444        {"shape":"InternalFailureException"}
445      ],
446      "documentation":"<p>Lists transcription jobs with the specified status.</p>"
447    },
448    "ListVocabularies":{
449      "name":"ListVocabularies",
450      "http":{
451        "method":"POST",
452        "requestUri":"/"
453      },
454      "input":{"shape":"ListVocabulariesRequest"},
455      "output":{"shape":"ListVocabulariesResponse"},
456      "errors":[
457        {"shape":"BadRequestException"},
458        {"shape":"LimitExceededException"},
459        {"shape":"InternalFailureException"}
460      ],
461      "documentation":"<p>Returns a list of vocabularies that match the specified criteria. If no criteria are specified, returns the entire list of vocabularies.</p>"
462    },
463    "ListVocabularyFilters":{
464      "name":"ListVocabularyFilters",
465      "http":{
466        "method":"POST",
467        "requestUri":"/"
468      },
469      "input":{"shape":"ListVocabularyFiltersRequest"},
470      "output":{"shape":"ListVocabularyFiltersResponse"},
471      "errors":[
472        {"shape":"BadRequestException"},
473        {"shape":"LimitExceededException"},
474        {"shape":"InternalFailureException"}
475      ],
476      "documentation":"<p>Gets information about vocabulary filters.</p>"
477    },
478    "StartCallAnalyticsJob":{
479      "name":"StartCallAnalyticsJob",
480      "http":{
481        "method":"POST",
482        "requestUri":"/"
483      },
484      "input":{"shape":"StartCallAnalyticsJobRequest"},
485      "output":{"shape":"StartCallAnalyticsJobResponse"},
486      "errors":[
487        {"shape":"BadRequestException"},
488        {"shape":"LimitExceededException"},
489        {"shape":"InternalFailureException"},
490        {"shape":"ConflictException"}
491      ],
492      "documentation":"<p>Starts an asynchronous analytics job that not only transcribes the audio recording of a caller and agent, but also returns additional insights. These insights include how quickly or loudly the caller or agent was speaking. To retrieve additional insights with your analytics jobs, create categories. A category is a way to classify analytics jobs based on attributes, such as a customer's sentiment or a particular phrase being used during the call. For more information, see the operation. </p>"
493    },
494    "StartMedicalTranscriptionJob":{
495      "name":"StartMedicalTranscriptionJob",
496      "http":{
497        "method":"POST",
498        "requestUri":"/"
499      },
500      "input":{"shape":"StartMedicalTranscriptionJobRequest"},
501      "output":{"shape":"StartMedicalTranscriptionJobResponse"},
502      "errors":[
503        {"shape":"BadRequestException"},
504        {"shape":"LimitExceededException"},
505        {"shape":"InternalFailureException"},
506        {"shape":"ConflictException"}
507      ],
508      "documentation":"<p>Starts a batch job to transcribe medical speech to text.</p>"
509    },
510    "StartTranscriptionJob":{
511      "name":"StartTranscriptionJob",
512      "http":{
513        "method":"POST",
514        "requestUri":"/"
515      },
516      "input":{"shape":"StartTranscriptionJobRequest"},
517      "output":{"shape":"StartTranscriptionJobResponse"},
518      "errors":[
519        {"shape":"BadRequestException"},
520        {"shape":"LimitExceededException"},
521        {"shape":"InternalFailureException"},
522        {"shape":"ConflictException"}
523      ],
524      "documentation":"<p>Starts an asynchronous job to transcribe speech to text.</p>"
525    },
526    "TagResource":{
527      "name":"TagResource",
528      "http":{
529        "method":"POST",
530        "requestUri":"/"
531      },
532      "input":{"shape":"TagResourceRequest"},
533      "output":{"shape":"TagResourceResponse"},
534      "errors":[
535        {"shape":"BadRequestException"},
536        {"shape":"ConflictException"},
537        {"shape":"NotFoundException"},
538        {"shape":"LimitExceededException"},
539        {"shape":"InternalFailureException"}
540      ],
541      "documentation":"<p>Tags a Amazon Transcribe resource with the given list of tags.</p>"
542    },
543    "UntagResource":{
544      "name":"UntagResource",
545      "http":{
546        "method":"POST",
547        "requestUri":"/"
548      },
549      "input":{"shape":"UntagResourceRequest"},
550      "output":{"shape":"UntagResourceResponse"},
551      "errors":[
552        {"shape":"LimitExceededException"},
553        {"shape":"BadRequestException"},
554        {"shape":"ConflictException"},
555        {"shape":"NotFoundException"},
556        {"shape":"InternalFailureException"}
557      ],
558      "documentation":"<p>Removes specified tags from a specified Amazon Transcribe resource.</p>"
559    },
560    "UpdateCallAnalyticsCategory":{
561      "name":"UpdateCallAnalyticsCategory",
562      "http":{
563        "method":"POST",
564        "requestUri":"/"
565      },
566      "input":{"shape":"UpdateCallAnalyticsCategoryRequest"},
567      "output":{"shape":"UpdateCallAnalyticsCategoryResponse"},
568      "errors":[
569        {"shape":"BadRequestException"},
570        {"shape":"LimitExceededException"},
571        {"shape":"InternalFailureException"},
572        {"shape":"NotFoundException"},
573        {"shape":"ConflictException"}
574      ],
575      "documentation":"<p>Updates the call analytics category with new values. The <code>UpdateCallAnalyticsCategory</code> operation overwrites all of the existing information with the values that you provide in the request. </p>"
576    },
577    "UpdateMedicalVocabulary":{
578      "name":"UpdateMedicalVocabulary",
579      "http":{
580        "method":"POST",
581        "requestUri":"/"
582      },
583      "input":{"shape":"UpdateMedicalVocabularyRequest"},
584      "output":{"shape":"UpdateMedicalVocabularyResponse"},
585      "errors":[
586        {"shape":"BadRequestException"},
587        {"shape":"LimitExceededException"},
588        {"shape":"InternalFailureException"},
589        {"shape":"NotFoundException"},
590        {"shape":"ConflictException"}
591      ],
592      "documentation":"<p>Updates a vocabulary with new values that you provide in a different text file from the one you used to create the vocabulary. The <code>UpdateMedicalVocabulary</code> operation overwrites all of the existing information with the values that you provide in the request.</p>"
593    },
594    "UpdateVocabulary":{
595      "name":"UpdateVocabulary",
596      "http":{
597        "method":"POST",
598        "requestUri":"/"
599      },
600      "input":{"shape":"UpdateVocabularyRequest"},
601      "output":{"shape":"UpdateVocabularyResponse"},
602      "errors":[
603        {"shape":"BadRequestException"},
604        {"shape":"LimitExceededException"},
605        {"shape":"InternalFailureException"},
606        {"shape":"NotFoundException"},
607        {"shape":"ConflictException"}
608      ],
609      "documentation":"<p>Updates an existing vocabulary with new values. The <code>UpdateVocabulary</code> operation overwrites all of the existing information with the values that you provide in the request. </p>"
610    },
611    "UpdateVocabularyFilter":{
612      "name":"UpdateVocabularyFilter",
613      "http":{
614        "method":"POST",
615        "requestUri":"/"
616      },
617      "input":{"shape":"UpdateVocabularyFilterRequest"},
618      "output":{"shape":"UpdateVocabularyFilterResponse"},
619      "errors":[
620        {"shape":"BadRequestException"},
621        {"shape":"LimitExceededException"},
622        {"shape":"InternalFailureException"},
623        {"shape":"NotFoundException"}
624      ],
625      "documentation":"<p>Updates a vocabulary filter with a new list of filtered words.</p>"
626    }
627  },
628  "shapes":{
629    "AbsoluteTimeRange":{
630      "type":"structure",
631      "members":{
632        "StartTime":{
633          "shape":"TimestampMilliseconds",
634          "documentation":"<p>A value that indicates the beginning of the time range in seconds. To set absolute time range, you must specify a start time and an end time. For example, if you specify the following values:</p> <ul> <li> <p>StartTime - 10000</p> </li> <li> <p>Endtime - 50000</p> </li> </ul> <p>The time range is set between 10,000 milliseconds and 50,000 milliseconds into the call.</p>"
635        },
636        "EndTime":{
637          "shape":"TimestampMilliseconds",
638          "documentation":"<p>A value that indicates the end of the time range in milliseconds. To set absolute time range, you must specify a start time and an end time. For example, if you specify the following values:</p> <ul> <li> <p>StartTime - 10000</p> </li> <li> <p>Endtime - 50000</p> </li> </ul> <p>The time range is set between 10,000 milliseconds and 50,000 milliseconds into the call. </p>"
639        },
640        "First":{
641          "shape":"TimestampMilliseconds",
642          "documentation":"<p>A time range from the beginning of the call to the value that you've specified. For example, if you specify 100000, the time range is set to the first 100,000 milliseconds of the call.</p>"
643        },
644        "Last":{
645          "shape":"TimestampMilliseconds",
646          "documentation":"<p>A time range from the value that you've specified to the end of the call. For example, if you specify 100000, the time range is set to the last 100,000 milliseconds of the call.</p>"
647        }
648      },
649      "documentation":"<p>A time range, set in seconds, between two points in the call.</p>"
650    },
651    "BadRequestException":{
652      "type":"structure",
653      "members":{
654        "Message":{"shape":"FailureReason"}
655      },
656      "documentation":"<p>Your request didn't pass one or more validation tests. For example, if the entity that you're trying to delete doesn't exist or if it is in a non-terminal state (for example, it's \"in progress\"). See the exception <code>Message</code> field for more information.</p>",
657      "exception":true
658    },
659    "BaseModelName":{
660      "type":"string",
661      "enum":[
662        "NarrowBand",
663        "WideBand"
664      ]
665    },
666    "Boolean":{"type":"boolean"},
667    "CLMLanguageCode":{
668      "type":"string",
669      "enum":[
670        "en-US",
671        "hi-IN",
672        "es-US",
673        "en-GB",
674        "en-AU"
675      ]
676    },
677    "CallAnalyticsJob":{
678      "type":"structure",
679      "members":{
680        "CallAnalyticsJobName":{
681          "shape":"CallAnalyticsJobName",
682          "documentation":"<p>The name of the call analytics job.</p>"
683        },
684        "CallAnalyticsJobStatus":{
685          "shape":"CallAnalyticsJobStatus",
686          "documentation":"<p>The status of the analytics job.</p>"
687        },
688        "LanguageCode":{
689          "shape":"LanguageCode",
690          "documentation":"<p>If you know the language spoken between the customer and the agent, specify a language code for this field.</p> <p>If you don't know the language, you can leave this field blank, and Amazon Transcribe will use machine learning to automatically identify the language. To improve the accuracy of language identification, you can provide an array containing the possible language codes for the language spoken in your audio. Refer to <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-it-works.html\">Supported languages and language-specific features</a> for additional information.</p>"
691        },
692        "MediaSampleRateHertz":{
693          "shape":"MediaSampleRateHertz",
694          "documentation":"<p>The sample rate, in Hertz, of the audio.</p>"
695        },
696        "MediaFormat":{
697          "shape":"MediaFormat",
698          "documentation":"<p>The format of the input audio file. Note: for call analytics jobs, only the following media formats are supported: MP3, MP4, WAV, FLAC, OGG, and WebM. </p>"
699        },
700        "Media":{"shape":"Media"},
701        "Transcript":{"shape":"Transcript"},
702        "StartTime":{
703          "shape":"DateTime",
704          "documentation":"<p>A timestamp that shows when the analytics job started processing.</p>"
705        },
706        "CreationTime":{
707          "shape":"DateTime",
708          "documentation":"<p>A timestamp that shows when the analytics job was created.</p>"
709        },
710        "CompletionTime":{
711          "shape":"DateTime",
712          "documentation":"<p>A timestamp that shows when the analytics job was completed.</p>"
713        },
714        "FailureReason":{
715          "shape":"FailureReason",
716          "documentation":"<p>If the <code>AnalyticsJobStatus</code> is <code>FAILED</code>, this field contains information about why the job failed.</p> <p>The <code>FailureReason</code> field can contain one of the following values:</p> <ul> <li> <p> <code>Unsupported media format</code>: The media format specified in the <code>MediaFormat</code> field of the request isn't valid. See the description of the <code>MediaFormat</code> field for a list of valid values.</p> </li> <li> <p> <code>The media format provided does not match the detected media format</code>: The media format of the audio file doesn't match the format specified in the <code>MediaFormat</code> field in the request. Check the media format of your media file and make sure the two values match.</p> </li> <li> <p> <code>Invalid sample rate for audio file</code>: The sample rate specified in the <code>MediaSampleRateHertz</code> of the request isn't valid. The sample rate must be between 8,000 and 48,000 Hertz.</p> </li> <li> <p> <code>The sample rate provided does not match the detected sample rate</code>: The sample rate in the audio file doesn't match the sample rate specified in the <code>MediaSampleRateHertz</code> field in the request. Check the sample rate of your media file and make sure that the two values match.</p> </li> <li> <p> <code>Invalid file size: file size too large</code>: The size of your audio file is larger than what Amazon Transcribe Medical can process. For more information, see <i>Guidelines and Quotas</i> in the Amazon Transcribe Medical Guide.</p> </li> <li> <p> <code>Invalid number of channels: number of channels too large</code>: Your audio contains more channels than Amazon Transcribe Medical is configured to process. To request additional channels, see Amazon Transcribe Medical Endpoints and Quotas in the <a href=\"https://docs.aws.amazon.com/general/latest/gr/Welcome.html\">Amazon Web Services General Reference</a>.</p> </li> </ul>"
717        },
718        "DataAccessRoleArn":{
719          "shape":"DataAccessRoleArn",
720          "documentation":"<p>The Amazon Resource Number (ARN) that you use to get access to the analytics job.</p>"
721        },
722        "IdentifiedLanguageScore":{
723          "shape":"IdentifiedLanguageScore",
724          "documentation":"<p>A value between zero and one that Amazon Transcribe assigned to the language that it identified in the source audio. This value appears only when you don't provide a single language code. Larger values indicate that Amazon Transcribe has higher confidence in the language that it identified</p>"
725        },
726        "Settings":{
727          "shape":"CallAnalyticsJobSettings",
728          "documentation":"<p>Provides information about the settings used to run a transcription job.</p>"
729        },
730        "ChannelDefinitions":{
731          "shape":"ChannelDefinitions",
732          "documentation":"<p>Shows numeric values to indicate the channel assigned to the agent's audio and the channel assigned to the customer's audio. </p>"
733        }
734      },
735      "documentation":"<p>Describes an asynchronous analytics job that was created with the <code>StartAnalyticsJob</code> operation.</p>"
736    },
737    "CallAnalyticsJobName":{
738      "type":"string",
739      "max":200,
740      "min":1,
741      "pattern":"^[0-9a-zA-Z._-]+"
742    },
743    "CallAnalyticsJobSettings":{
744      "type":"structure",
745      "members":{
746        "VocabularyName":{
747          "shape":"VocabularyName",
748          "documentation":"<p>The name of a vocabulary to use when processing the call analytics job.</p>"
749        },
750        "VocabularyFilterName":{
751          "shape":"VocabularyFilterName",
752          "documentation":"<p>The name of the vocabulary filter to use when running a call analytics job. The filter that you specify must have the same language code as the analytics job.</p>"
753        },
754        "VocabularyFilterMethod":{
755          "shape":"VocabularyFilterMethod",
756          "documentation":"<p>Set to mask to remove filtered text from the transcript and replace it with three asterisks (\"***\") as placeholder text. Set to <code>remove</code> to remove filtered text from the transcript without using placeholder text. Set to <code>tag</code> to mark the word in the transcription output that matches the vocabulary filter. When you set the filter method to <code>tag</code>, the words matching your vocabulary filter are not masked or removed.</p>"
757        },
758        "LanguageModelName":{
759          "shape":"ModelName",
760          "documentation":"<p>The structure used to describe a custom language model.</p>"
761        },
762        "ContentRedaction":{"shape":"ContentRedaction"},
763        "LanguageOptions":{
764          "shape":"LanguageOptions",
765          "documentation":"<p>When you run a call analytics job, you can specify the language spoken in the audio, or you can have Amazon Transcribe identify the language for you.</p> <p>To specify a language, specify an array with one language code. If you don't know the language, you can leave this field blank and Amazon Transcribe will use machine learning to identify the language for you. To improve the ability of Amazon Transcribe to correctly identify the language, you can provide an array of the languages that can be present in the audio. Refer to <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-it-works.html\">Supported languages and language-specific features</a> for additional information.</p>"
766        }
767      },
768      "documentation":"<p>Provides optional settings for the <code>CallAnalyticsJob</code> operation. </p>"
769    },
770    "CallAnalyticsJobStatus":{
771      "type":"string",
772      "enum":[
773        "QUEUED",
774        "IN_PROGRESS",
775        "FAILED",
776        "COMPLETED"
777      ]
778    },
779    "CallAnalyticsJobSummaries":{
780      "type":"list",
781      "member":{"shape":"CallAnalyticsJobSummary"}
782    },
783    "CallAnalyticsJobSummary":{
784      "type":"structure",
785      "members":{
786        "CallAnalyticsJobName":{
787          "shape":"CallAnalyticsJobName",
788          "documentation":"<p>The name of the call analytics job.</p>"
789        },
790        "CreationTime":{
791          "shape":"DateTime",
792          "documentation":"<p>A timestamp that shows when the call analytics job was created.</p>"
793        },
794        "StartTime":{
795          "shape":"DateTime",
796          "documentation":"<p>A timestamp that shows when the job began processing.</p>"
797        },
798        "CompletionTime":{
799          "shape":"DateTime",
800          "documentation":"<p>A timestamp that shows when the job was completed.</p>"
801        },
802        "LanguageCode":{
803          "shape":"LanguageCode",
804          "documentation":"<p>The language of the transcript in the source audio file.</p>"
805        },
806        "CallAnalyticsJobStatus":{
807          "shape":"CallAnalyticsJobStatus",
808          "documentation":"<p>The status of the call analytics job.</p>"
809        },
810        "FailureReason":{
811          "shape":"FailureReason",
812          "documentation":"<p>If the <code>CallAnalyticsJobStatus</code> is <code>FAILED</code>, a description of the error.</p>"
813        }
814      },
815      "documentation":"<p>Provides summary information about a call analytics job.</p>"
816    },
817    "CategoryName":{
818      "type":"string",
819      "max":200,
820      "min":1,
821      "pattern":"^[0-9a-zA-Z._-]+"
822    },
823    "CategoryProperties":{
824      "type":"structure",
825      "members":{
826        "CategoryName":{
827          "shape":"CategoryName",
828          "documentation":"<p>The name of the call analytics category.</p>"
829        },
830        "Rules":{
831          "shape":"RuleList",
832          "documentation":"<p>The rules used to create a call analytics category.</p>"
833        },
834        "CreateTime":{
835          "shape":"DateTime",
836          "documentation":"<p>A timestamp that shows when the call analytics category was created.</p>"
837        },
838        "LastUpdateTime":{
839          "shape":"DateTime",
840          "documentation":"<p>A timestamp that shows when the call analytics category was most recently updated.</p>"
841        }
842      },
843      "documentation":"<p>An object that contains the rules and additional information about a call analytics category.</p>"
844    },
845    "CategoryPropertiesList":{
846      "type":"list",
847      "member":{"shape":"CategoryProperties"}
848    },
849    "ChannelDefinition":{
850      "type":"structure",
851      "members":{
852        "ChannelId":{
853          "shape":"ChannelId",
854          "documentation":"<p>A value that indicates the audio channel.</p>"
855        },
856        "ParticipantRole":{
857          "shape":"ParticipantRole",
858          "documentation":"<p>Indicates whether the person speaking on the audio channel is the agent or customer.</p>"
859        }
860      },
861      "documentation":"<p>For a call analytics job, an object that indicates the audio channel that belongs to the agent and the audio channel that belongs to the customer.</p>"
862    },
863    "ChannelDefinitions":{
864      "type":"list",
865      "member":{"shape":"ChannelDefinition"},
866      "max":2,
867      "min":2
868    },
869    "ChannelId":{
870      "type":"integer",
871      "max":1,
872      "min":0
873    },
874    "ConflictException":{
875      "type":"structure",
876      "members":{
877        "Message":{"shape":"String"}
878      },
879      "documentation":"<p>There is already a resource with that name.</p>",
880      "exception":true
881    },
882    "ContentRedaction":{
883      "type":"structure",
884      "required":[
885        "RedactionType",
886        "RedactionOutput"
887      ],
888      "members":{
889        "RedactionType":{
890          "shape":"RedactionType",
891          "documentation":"<p>Request parameter that defines the entities to be redacted. The only accepted value is <code>PII</code>.</p>"
892        },
893        "RedactionOutput":{
894          "shape":"RedactionOutput",
895          "documentation":"<p>The output transcript file stored in either the default S3 bucket or in a bucket you specify.</p> <p>When you choose <code>redacted</code> Amazon Transcribe outputs only the redacted transcript.</p> <p>When you choose <code>redacted_and_unredacted</code> Amazon Transcribe outputs both the redacted and unredacted transcripts.</p>"
896        }
897      },
898      "documentation":"<p>Settings for content redaction within a transcription job.</p>"
899    },
900    "CreateCallAnalyticsCategoryRequest":{
901      "type":"structure",
902      "required":[
903        "CategoryName",
904        "Rules"
905      ],
906      "members":{
907        "CategoryName":{
908          "shape":"CategoryName",
909          "documentation":"<p>The name that you choose for your category when you create it. </p>"
910        },
911        "Rules":{
912          "shape":"RuleList",
913          "documentation":"<p>To create a category, you must specify between 1 and 20 rules. For each rule, you specify a filter to be applied to the attributes of the call. For example, you can specify a sentiment filter to detect if the customer's sentiment was negative or neutral. </p>"
914        }
915      }
916    },
917    "CreateCallAnalyticsCategoryResponse":{
918      "type":"structure",
919      "members":{
920        "CategoryProperties":{
921          "shape":"CategoryProperties",
922          "documentation":"<p>The rules and associated metadata used to create a category.</p>"
923        }
924      }
925    },
926    "CreateLanguageModelRequest":{
927      "type":"structure",
928      "required":[
929        "LanguageCode",
930        "BaseModelName",
931        "ModelName",
932        "InputDataConfig"
933      ],
934      "members":{
935        "LanguageCode":{
936          "shape":"CLMLanguageCode",
937          "documentation":"<p>The language of the input text you're using to train your custom language model.</p>"
938        },
939        "BaseModelName":{
940          "shape":"BaseModelName",
941          "documentation":"<p>The Amazon Transcribe standard language model, or base model used to create your custom language model.</p> <p>If you want to use your custom language model to transcribe audio with a sample rate of 16,000 Hz or greater, choose <code>Wideband</code>.</p> <p>If you want to use your custom language model to transcribe audio with a sample rate that is less than 16,000 Hz, choose <code>Narrowband</code>.</p>"
942        },
943        "ModelName":{
944          "shape":"ModelName",
945          "documentation":"<p>The name you choose for your custom language model when you create it.</p>"
946        },
947        "InputDataConfig":{
948          "shape":"InputDataConfig",
949          "documentation":"<p>Contains the data access role and the Amazon S3 prefixes to read the required input files to create a custom language model.</p>"
950        },
951        "Tags":{
952          "shape":"TagList",
953          "documentation":"<p>Adds one or more tags, each in the form of a key:value pair, to a new language model at the time you create this new model.</p>"
954        }
955      }
956    },
957    "CreateLanguageModelResponse":{
958      "type":"structure",
959      "members":{
960        "LanguageCode":{
961          "shape":"CLMLanguageCode",
962          "documentation":"<p>The language code of the text you've used to create a custom language model.</p>"
963        },
964        "BaseModelName":{
965          "shape":"BaseModelName",
966          "documentation":"<p>The Amazon Transcribe standard language model, or base model you've used to create a custom language model.</p>"
967        },
968        "ModelName":{
969          "shape":"ModelName",
970          "documentation":"<p>The name you've chosen for your custom language model.</p>"
971        },
972        "InputDataConfig":{
973          "shape":"InputDataConfig",
974          "documentation":"<p>The data access role and Amazon S3 prefixes you've chosen to create your custom language model.</p>"
975        },
976        "ModelStatus":{
977          "shape":"ModelStatus",
978          "documentation":"<p>The status of the custom language model. When the status is <code>COMPLETED</code> the model is ready to use.</p>"
979        }
980      }
981    },
982    "CreateMedicalVocabularyRequest":{
983      "type":"structure",
984      "required":[
985        "VocabularyName",
986        "LanguageCode",
987        "VocabularyFileUri"
988      ],
989      "members":{
990        "VocabularyName":{
991          "shape":"VocabularyName",
992          "documentation":"<p>The name of the custom vocabulary. This case-sensitive name must be unique within an Amazon Web Services account. If you try to create a vocabulary with the same name as a previous vocabulary, you get a <code>ConflictException</code> error.</p>"
993        },
994        "LanguageCode":{
995          "shape":"LanguageCode",
996          "documentation":"<p>The language code for the language used for the entries in your custom vocabulary. The language code of your custom vocabulary must match the language code of your transcription job. US English (en-US) is the only language code available for Amazon Transcribe Medical.</p>"
997        },
998        "VocabularyFileUri":{
999          "shape":"Uri",
1000          "documentation":"<p>The location in Amazon S3 of the text file you use to define your custom vocabulary. The URI must be in the same Amazon Web Services Region as the resource that you're calling. Enter information about your <code>VocabularyFileUri</code> in the following format:</p> <p> <code> https://s3.&lt;aws-region&gt;.amazonaws.com/&lt;bucket-name&gt;/&lt;keyprefix&gt;/&lt;objectkey&gt; </code> </p> <p>The following is an example URI for a vocabulary file that is stored in Amazon S3:</p> <p> <code>https://s3.us-east-1.amazonaws.com/AWSDOC-EXAMPLE-BUCKET/vocab.txt</code> </p> <p>For more information about Amazon S3 object names, see <a href=\"https://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html#object-keys\">Object Keys</a> in the <i>Amazon S3 Developer Guide</i>.</p> <p>For more information about custom vocabularies, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-it-works.html#how-vocabulary-med\">Medical Custom Vocabularies</a>.</p>"
1001        },
1002        "Tags":{
1003          "shape":"TagList",
1004          "documentation":"<p>Adds one or more tags, each in the form of a key:value pair, to a new medical vocabulary at the time you create this new vocabulary.</p>"
1005        }
1006      }
1007    },
1008    "CreateMedicalVocabularyResponse":{
1009      "type":"structure",
1010      "members":{
1011        "VocabularyName":{
1012          "shape":"VocabularyName",
1013          "documentation":"<p>The name of the vocabulary. The name must be unique within an Amazon Web Services account and is case sensitive.</p>"
1014        },
1015        "LanguageCode":{
1016          "shape":"LanguageCode",
1017          "documentation":"<p>The language code for the entries in your custom vocabulary. US English (en-US) is the only valid language code for Amazon Transcribe Medical.</p>"
1018        },
1019        "VocabularyState":{
1020          "shape":"VocabularyState",
1021          "documentation":"<p>The processing state of your custom vocabulary in Amazon Transcribe Medical. If the state is <code>READY</code>, you can use the vocabulary in a <code>StartMedicalTranscriptionJob</code> request.</p>"
1022        },
1023        "LastModifiedTime":{
1024          "shape":"DateTime",
1025          "documentation":"<p>The date and time that you created the vocabulary.</p>"
1026        },
1027        "FailureReason":{
1028          "shape":"FailureReason",
1029          "documentation":"<p>If the <code>VocabularyState</code> field is <code>FAILED</code>, this field contains information about why the job failed.</p>"
1030        }
1031      }
1032    },
1033    "CreateVocabularyFilterRequest":{
1034      "type":"structure",
1035      "required":[
1036        "VocabularyFilterName",
1037        "LanguageCode"
1038      ],
1039      "members":{
1040        "VocabularyFilterName":{
1041          "shape":"VocabularyFilterName",
1042          "documentation":"<p>The vocabulary filter name. The name must be unique within the account that contains it. If you try to create a vocabulary filter with the same name as another vocabulary filter, you get a <code>ConflictException</code> error.</p>"
1043        },
1044        "LanguageCode":{
1045          "shape":"LanguageCode",
1046          "documentation":"<p>The language code of the words in the vocabulary filter. All words in the filter must be in the same language. The vocabulary filter can only be used with transcription jobs in the specified language.</p>"
1047        },
1048        "Words":{
1049          "shape":"Words",
1050          "documentation":"<p>The words to use in the vocabulary filter. Only use characters from the character set defined for custom vocabularies. For a list of character sets, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-vocabulary.html#charsets\">Character Sets for Custom Vocabularies</a>.</p> <p>If you provide a list of words in the <code>Words</code> parameter, you can't use the <code>VocabularyFilterFileUri</code> parameter.</p>"
1051        },
1052        "VocabularyFilterFileUri":{
1053          "shape":"Uri",
1054          "documentation":"<p>The Amazon S3 location of a text file used as input to create the vocabulary filter. Only use characters from the character set defined for custom vocabularies. For a list of character sets, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-vocabulary.html#charsets\">Character Sets for Custom Vocabularies</a>.</p> <p>The specified file must be less than 50 KB of UTF-8 characters.</p> <p>If you provide the location of a list of words in the <code>VocabularyFilterFileUri</code> parameter, you can't use the <code>Words</code> parameter.</p>"
1055        },
1056        "Tags":{
1057          "shape":"TagList",
1058          "documentation":"<p>Adds one or more tags, each in the form of a key:value pair, to a new Amazon Transcribe vocabulary filter at the time you create this new vocabulary filter.</p>"
1059        }
1060      }
1061    },
1062    "CreateVocabularyFilterResponse":{
1063      "type":"structure",
1064      "members":{
1065        "VocabularyFilterName":{
1066          "shape":"VocabularyFilterName",
1067          "documentation":"<p>The name of the vocabulary filter.</p>"
1068        },
1069        "LanguageCode":{
1070          "shape":"LanguageCode",
1071          "documentation":"<p>The language code of the words in the collection.</p>"
1072        },
1073        "LastModifiedTime":{
1074          "shape":"DateTime",
1075          "documentation":"<p>The date and time that the vocabulary filter was modified.</p>"
1076        }
1077      }
1078    },
1079    "CreateVocabularyRequest":{
1080      "type":"structure",
1081      "required":[
1082        "VocabularyName",
1083        "LanguageCode"
1084      ],
1085      "members":{
1086        "VocabularyName":{
1087          "shape":"VocabularyName",
1088          "documentation":"<p>The name of the vocabulary. The name must be unique within an Amazon Web Services account. The name is case sensitive. If you try to create a vocabulary with the same name as a previous vocabulary you will receive a <code>ConflictException</code> error.</p>"
1089        },
1090        "LanguageCode":{
1091          "shape":"LanguageCode",
1092          "documentation":"<p>The language code of the vocabulary entries. For a list of languages and their corresponding language codes, see <a>transcribe-whatis</a>.</p>"
1093        },
1094        "Phrases":{
1095          "shape":"Phrases",
1096          "documentation":"<p>An array of strings that contains the vocabulary entries. </p>"
1097        },
1098        "VocabularyFileUri":{
1099          "shape":"Uri",
1100          "documentation":"<p>The S3 location of the text file that contains the definition of the custom vocabulary. The URI must be in the same region as the API endpoint that you are calling. The general form is:</p> <p>For more information about S3 object names, see <a href=\"https://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html#object-keys\">Object Keys</a> in the <i>Amazon S3 Developer Guide</i>.</p> <p>For more information about custom vocabularies, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-vocabulary\">Custom vocabularies</a>.</p>"
1101        },
1102        "Tags":{
1103          "shape":"TagList",
1104          "documentation":"<p>Adds one or more tags, each in the form of a key:value pair, to a new Amazon Transcribe vocabulary at the time you create this new vocabulary.</p>"
1105        }
1106      }
1107    },
1108    "CreateVocabularyResponse":{
1109      "type":"structure",
1110      "members":{
1111        "VocabularyName":{
1112          "shape":"VocabularyName",
1113          "documentation":"<p>The name of the vocabulary.</p>"
1114        },
1115        "LanguageCode":{
1116          "shape":"LanguageCode",
1117          "documentation":"<p>The language code of the vocabulary entries.</p>"
1118        },
1119        "VocabularyState":{
1120          "shape":"VocabularyState",
1121          "documentation":"<p>The processing state of the vocabulary. When the <code>VocabularyState</code> field contains <code>READY</code> the vocabulary is ready to be used in a <code>StartTranscriptionJob</code> request.</p>"
1122        },
1123        "LastModifiedTime":{
1124          "shape":"DateTime",
1125          "documentation":"<p>The date and time that the vocabulary was created.</p>"
1126        },
1127        "FailureReason":{
1128          "shape":"FailureReason",
1129          "documentation":"<p>If the <code>VocabularyState</code> field is <code>FAILED</code>, this field contains information about why the job failed.</p>"
1130        }
1131      }
1132    },
1133    "DataAccessRoleArn":{
1134      "type":"string",
1135      "max":2048,
1136      "min":20,
1137      "pattern":"^arn:(aws|aws-cn|aws-us-gov|aws-iso-{0,1}[a-z]{0,1}):iam::[0-9]{0,63}:role/[A-Za-z0-9:_/+=,@.-]{0,1024}$"
1138    },
1139    "DateTime":{"type":"timestamp"},
1140    "DeleteCallAnalyticsCategoryRequest":{
1141      "type":"structure",
1142      "required":["CategoryName"],
1143      "members":{
1144        "CategoryName":{
1145          "shape":"CategoryName",
1146          "documentation":"<p>The name of the call analytics category that you're choosing to delete. The value is case sensitive. </p>"
1147        }
1148      }
1149    },
1150    "DeleteCallAnalyticsCategoryResponse":{
1151      "type":"structure",
1152      "members":{
1153      }
1154    },
1155    "DeleteCallAnalyticsJobRequest":{
1156      "type":"structure",
1157      "required":["CallAnalyticsJobName"],
1158      "members":{
1159        "CallAnalyticsJobName":{
1160          "shape":"CallAnalyticsJobName",
1161          "documentation":"<p>The name of the call analytics job you want to delete.</p>"
1162        }
1163      }
1164    },
1165    "DeleteCallAnalyticsJobResponse":{
1166      "type":"structure",
1167      "members":{
1168      }
1169    },
1170    "DeleteLanguageModelRequest":{
1171      "type":"structure",
1172      "required":["ModelName"],
1173      "members":{
1174        "ModelName":{
1175          "shape":"ModelName",
1176          "documentation":"<p>The name of the model you're choosing to delete.</p>"
1177        }
1178      }
1179    },
1180    "DeleteMedicalTranscriptionJobRequest":{
1181      "type":"structure",
1182      "required":["MedicalTranscriptionJobName"],
1183      "members":{
1184        "MedicalTranscriptionJobName":{
1185          "shape":"TranscriptionJobName",
1186          "documentation":"<p>The name you provide to the <code>DeleteMedicalTranscriptionJob</code> object to delete a transcription job.</p>"
1187        }
1188      }
1189    },
1190    "DeleteMedicalVocabularyRequest":{
1191      "type":"structure",
1192      "required":["VocabularyName"],
1193      "members":{
1194        "VocabularyName":{
1195          "shape":"VocabularyName",
1196          "documentation":"<p>The name of the vocabulary that you want to delete.</p>"
1197        }
1198      }
1199    },
1200    "DeleteTranscriptionJobRequest":{
1201      "type":"structure",
1202      "required":["TranscriptionJobName"],
1203      "members":{
1204        "TranscriptionJobName":{
1205          "shape":"TranscriptionJobName",
1206          "documentation":"<p>The name of the transcription job to be deleted.</p>"
1207        }
1208      }
1209    },
1210    "DeleteVocabularyFilterRequest":{
1211      "type":"structure",
1212      "required":["VocabularyFilterName"],
1213      "members":{
1214        "VocabularyFilterName":{
1215          "shape":"VocabularyFilterName",
1216          "documentation":"<p>The name of the vocabulary filter to remove.</p>"
1217        }
1218      }
1219    },
1220    "DeleteVocabularyRequest":{
1221      "type":"structure",
1222      "required":["VocabularyName"],
1223      "members":{
1224        "VocabularyName":{
1225          "shape":"VocabularyName",
1226          "documentation":"<p>The name of the vocabulary to delete. </p>"
1227        }
1228      }
1229    },
1230    "DescribeLanguageModelRequest":{
1231      "type":"structure",
1232      "required":["ModelName"],
1233      "members":{
1234        "ModelName":{
1235          "shape":"ModelName",
1236          "documentation":"<p>The name of the custom language model you submit to get more information.</p>"
1237        }
1238      }
1239    },
1240    "DescribeLanguageModelResponse":{
1241      "type":"structure",
1242      "members":{
1243        "LanguageModel":{
1244          "shape":"LanguageModel",
1245          "documentation":"<p>The name of the custom language model you requested more information about.</p>"
1246        }
1247      }
1248    },
1249    "FailureReason":{"type":"string"},
1250    "GetCallAnalyticsCategoryRequest":{
1251      "type":"structure",
1252      "required":["CategoryName"],
1253      "members":{
1254        "CategoryName":{
1255          "shape":"CategoryName",
1256          "documentation":"<p>The name of the category you want information about. This value is case sensitive.</p>"
1257        }
1258      }
1259    },
1260    "GetCallAnalyticsCategoryResponse":{
1261      "type":"structure",
1262      "members":{
1263        "CategoryProperties":{
1264          "shape":"CategoryProperties",
1265          "documentation":"<p>The rules you've defined for a category.</p>"
1266        }
1267      }
1268    },
1269    "GetCallAnalyticsJobRequest":{
1270      "type":"structure",
1271      "required":["CallAnalyticsJobName"],
1272      "members":{
1273        "CallAnalyticsJobName":{
1274          "shape":"CallAnalyticsJobName",
1275          "documentation":"<p>The name of the analytics job you want information about. This value is case sensitive. </p>"
1276        }
1277      }
1278    },
1279    "GetCallAnalyticsJobResponse":{
1280      "type":"structure",
1281      "members":{
1282        "CallAnalyticsJob":{
1283          "shape":"CallAnalyticsJob",
1284          "documentation":"<p>An object that contains the results of your call analytics job.</p>"
1285        }
1286      }
1287    },
1288    "GetMedicalTranscriptionJobRequest":{
1289      "type":"structure",
1290      "required":["MedicalTranscriptionJobName"],
1291      "members":{
1292        "MedicalTranscriptionJobName":{
1293          "shape":"TranscriptionJobName",
1294          "documentation":"<p>The name of the medical transcription job.</p>"
1295        }
1296      }
1297    },
1298    "GetMedicalTranscriptionJobResponse":{
1299      "type":"structure",
1300      "members":{
1301        "MedicalTranscriptionJob":{
1302          "shape":"MedicalTranscriptionJob",
1303          "documentation":"<p>An object that contains the results of the medical transcription job.</p>"
1304        }
1305      }
1306    },
1307    "GetMedicalVocabularyRequest":{
1308      "type":"structure",
1309      "required":["VocabularyName"],
1310      "members":{
1311        "VocabularyName":{
1312          "shape":"VocabularyName",
1313          "documentation":"<p>The name of the vocabulary that you want information about. The value is case sensitive. </p>"
1314        }
1315      }
1316    },
1317    "GetMedicalVocabularyResponse":{
1318      "type":"structure",
1319      "members":{
1320        "VocabularyName":{
1321          "shape":"VocabularyName",
1322          "documentation":"<p>The name of the vocabulary returned by Amazon Transcribe Medical.</p>"
1323        },
1324        "LanguageCode":{
1325          "shape":"LanguageCode",
1326          "documentation":"<p>The valid language code for your vocabulary entries.</p>"
1327        },
1328        "VocabularyState":{
1329          "shape":"VocabularyState",
1330          "documentation":"<p>The processing state of the vocabulary. If the <code>VocabularyState</code> is <code>READY</code> then you can use it in the <code>StartMedicalTranscriptionJob</code> operation.</p>"
1331        },
1332        "LastModifiedTime":{
1333          "shape":"DateTime",
1334          "documentation":"<p>The date and time that the vocabulary was last modified with a text file different from the one that was previously used.</p>"
1335        },
1336        "FailureReason":{
1337          "shape":"FailureReason",
1338          "documentation":"<p>If the <code>VocabularyState</code> is <code>FAILED</code>, this field contains information about why the job failed.</p>"
1339        },
1340        "DownloadUri":{
1341          "shape":"Uri",
1342          "documentation":"<p>The location in Amazon S3 where the vocabulary is stored. Use this URI to get the contents of the vocabulary. You can download your vocabulary from the URI for a limited time.</p>"
1343        }
1344      }
1345    },
1346    "GetTranscriptionJobRequest":{
1347      "type":"structure",
1348      "required":["TranscriptionJobName"],
1349      "members":{
1350        "TranscriptionJobName":{
1351          "shape":"TranscriptionJobName",
1352          "documentation":"<p>The name of the job.</p>"
1353        }
1354      }
1355    },
1356    "GetTranscriptionJobResponse":{
1357      "type":"structure",
1358      "members":{
1359        "TranscriptionJob":{
1360          "shape":"TranscriptionJob",
1361          "documentation":"<p>An object that contains the results of the transcription job.</p>"
1362        }
1363      }
1364    },
1365    "GetVocabularyFilterRequest":{
1366      "type":"structure",
1367      "required":["VocabularyFilterName"],
1368      "members":{
1369        "VocabularyFilterName":{
1370          "shape":"VocabularyFilterName",
1371          "documentation":"<p>The name of the vocabulary filter for which to return information.</p>"
1372        }
1373      }
1374    },
1375    "GetVocabularyFilterResponse":{
1376      "type":"structure",
1377      "members":{
1378        "VocabularyFilterName":{
1379          "shape":"VocabularyFilterName",
1380          "documentation":"<p>The name of the vocabulary filter.</p>"
1381        },
1382        "LanguageCode":{
1383          "shape":"LanguageCode",
1384          "documentation":"<p>The language code of the words in the vocabulary filter.</p>"
1385        },
1386        "LastModifiedTime":{
1387          "shape":"DateTime",
1388          "documentation":"<p>The date and time that the contents of the vocabulary filter were updated.</p>"
1389        },
1390        "DownloadUri":{
1391          "shape":"Uri",
1392          "documentation":"<p>The URI of the list of words in the vocabulary filter. You can use this URI to get the list of words.</p>"
1393        }
1394      }
1395    },
1396    "GetVocabularyRequest":{
1397      "type":"structure",
1398      "required":["VocabularyName"],
1399      "members":{
1400        "VocabularyName":{
1401          "shape":"VocabularyName",
1402          "documentation":"<p>The name of the vocabulary to return information about. The name is case sensitive.</p>"
1403        }
1404      }
1405    },
1406    "GetVocabularyResponse":{
1407      "type":"structure",
1408      "members":{
1409        "VocabularyName":{
1410          "shape":"VocabularyName",
1411          "documentation":"<p>The name of the vocabulary to return.</p>"
1412        },
1413        "LanguageCode":{
1414          "shape":"LanguageCode",
1415          "documentation":"<p>The language code of the vocabulary entries.</p>"
1416        },
1417        "VocabularyState":{
1418          "shape":"VocabularyState",
1419          "documentation":"<p>The processing state of the vocabulary.</p>"
1420        },
1421        "LastModifiedTime":{
1422          "shape":"DateTime",
1423          "documentation":"<p>The date and time that the vocabulary was last modified.</p>"
1424        },
1425        "FailureReason":{
1426          "shape":"FailureReason",
1427          "documentation":"<p>If the <code>VocabularyState</code> field is <code>FAILED</code>, this field contains information about why the job failed.</p>"
1428        },
1429        "DownloadUri":{
1430          "shape":"Uri",
1431          "documentation":"<p>The S3 location where the vocabulary is stored. Use this URI to get the contents of the vocabulary. The URI is available for a limited time.</p>"
1432        }
1433      }
1434    },
1435    "IdentifiedLanguageScore":{"type":"float"},
1436    "InputDataConfig":{
1437      "type":"structure",
1438      "required":[
1439        "S3Uri",
1440        "DataAccessRoleArn"
1441      ],
1442      "members":{
1443        "S3Uri":{
1444          "shape":"Uri",
1445          "documentation":"<p>The Amazon S3 prefix you specify to access the plain text files that you use to train your custom language model.</p>"
1446        },
1447        "TuningDataS3Uri":{
1448          "shape":"Uri",
1449          "documentation":"<p>The Amazon S3 prefix you specify to access the plain text files that you use to tune your custom language model.</p>"
1450        },
1451        "DataAccessRoleArn":{
1452          "shape":"DataAccessRoleArn",
1453          "documentation":"<p>The Amazon Resource Name (ARN) that uniquely identifies the permissions you've given Amazon Transcribe to access your Amazon S3 buckets containing your media files or text data.</p>"
1454        }
1455      },
1456      "documentation":"<p>The object that contains the Amazon S3 object location and access role required to train and tune your custom language model.</p>"
1457    },
1458    "InternalFailureException":{
1459      "type":"structure",
1460      "members":{
1461        "Message":{"shape":"String"}
1462      },
1463      "documentation":"<p>There was an internal error. Check the error message and try your request again.</p>",
1464      "exception":true,
1465      "fault":true
1466    },
1467    "InterruptionFilter":{
1468      "type":"structure",
1469      "members":{
1470        "Threshold":{
1471          "shape":"TimestampMilliseconds",
1472          "documentation":"<p>The duration of the interruption.</p>"
1473        },
1474        "ParticipantRole":{
1475          "shape":"ParticipantRole",
1476          "documentation":"<p>Indicates whether the caller or customer was interrupting.</p>"
1477        },
1478        "AbsoluteTimeRange":{
1479          "shape":"AbsoluteTimeRange",
1480          "documentation":"<p>An object you can use to specify a time range (in milliseconds) for when you'd want to find the interruption. For example, you could search for an interruption between the 30,000 millisecond mark and the 45,000 millisecond mark. You could also specify the time period as the first 15,000 milliseconds or the last 15,000 milliseconds. </p>"
1481        },
1482        "RelativeTimeRange":{
1483          "shape":"RelativeTimeRange",
1484          "documentation":"<p>An object that allows percentages to specify the proportion of the call where there was a interruption. For example, you can specify the first half of the call. You can also specify the period of time between halfway through to three-quarters of the way through the call. Because the length of conversation can vary between calls, you can apply relative time ranges across all calls.</p>"
1485        },
1486        "Negate":{
1487          "shape":"Boolean",
1488          "documentation":"<p>Set to <code>TRUE</code> to look for a time period where there was no interruption.</p>"
1489        }
1490      },
1491      "documentation":"<p>An object that enables you to configure your category to be applied to call analytics jobs where either the customer or agent was interrupted.</p>"
1492    },
1493    "JobExecutionSettings":{
1494      "type":"structure",
1495      "members":{
1496        "AllowDeferredExecution":{
1497          "shape":"Boolean",
1498          "documentation":"<p>Indicates whether a job should be queued by Amazon Transcribe when the concurrent execution limit is exceeded. When the <code>AllowDeferredExecution</code> field is true, jobs are queued and executed when the number of executing jobs falls below the concurrent execution limit. If the field is false, Amazon Transcribe returns a <code>LimitExceededException</code> exception.</p> <p>Note that job queuing is enabled by default for call analytics jobs.</p> <p>If you specify the <code>AllowDeferredExecution</code> field, you must specify the <code>DataAccessRoleArn</code> field.</p>"
1499        },
1500        "DataAccessRoleArn":{
1501          "shape":"DataAccessRoleArn",
1502          "documentation":"<p>The Amazon Resource Name (ARN) of a role that has access to the S3 bucket that contains the input files. Amazon Transcribe assumes this role to read queued media files. If you have specified an output S3 bucket for the transcription results, this role should have access to the output bucket as well.</p> <p>If you specify the <code>AllowDeferredExecution</code> field, you must specify the <code>DataAccessRoleArn</code> field.</p>"
1503        }
1504      },
1505      "documentation":"<p>Provides information about when a transcription job should be executed.</p>"
1506    },
1507    "KMSEncryptionContextMap":{
1508      "type":"map",
1509      "key":{"shape":"NonEmptyString"},
1510      "value":{"shape":"NonEmptyString"},
1511      "max":10,
1512      "min":1
1513    },
1514    "KMSKeyId":{
1515      "type":"string",
1516      "max":2048,
1517      "min":1,
1518      "pattern":"^[A-Za-z0-9][A-Za-z0-9:_/+=,@.-]{0,2048}$"
1519    },
1520    "LanguageCode":{
1521      "type":"string",
1522      "enum":[
1523        "af-ZA",
1524        "ar-AE",
1525        "ar-SA",
1526        "cy-GB",
1527        "da-DK",
1528        "de-CH",
1529        "de-DE",
1530        "en-AB",
1531        "en-AU",
1532        "en-GB",
1533        "en-IE",
1534        "en-IN",
1535        "en-US",
1536        "en-WL",
1537        "es-ES",
1538        "es-US",
1539        "fa-IR",
1540        "fr-CA",
1541        "fr-FR",
1542        "ga-IE",
1543        "gd-GB",
1544        "he-IL",
1545        "hi-IN",
1546        "id-ID",
1547        "it-IT",
1548        "ja-JP",
1549        "ko-KR",
1550        "ms-MY",
1551        "nl-NL",
1552        "pt-BR",
1553        "pt-PT",
1554        "ru-RU",
1555        "ta-IN",
1556        "te-IN",
1557        "tr-TR",
1558        "zh-CN",
1559        "zh-TW",
1560        "th-TH",
1561        "en-ZA",
1562        "en-NZ"
1563      ]
1564    },
1565    "LanguageModel":{
1566      "type":"structure",
1567      "members":{
1568        "ModelName":{
1569          "shape":"ModelName",
1570          "documentation":"<p>The name of the custom language model.</p>"
1571        },
1572        "CreateTime":{
1573          "shape":"DateTime",
1574          "documentation":"<p>The time the custom language model was created.</p>"
1575        },
1576        "LastModifiedTime":{
1577          "shape":"DateTime",
1578          "documentation":"<p>The most recent time the custom language model was modified.</p>"
1579        },
1580        "LanguageCode":{
1581          "shape":"CLMLanguageCode",
1582          "documentation":"<p>The language code you used to create your custom language model.</p>"
1583        },
1584        "BaseModelName":{
1585          "shape":"BaseModelName",
1586          "documentation":"<p>The Amazon Transcribe standard language model, or base model used to create the custom language model.</p>"
1587        },
1588        "ModelStatus":{
1589          "shape":"ModelStatus",
1590          "documentation":"<p>The creation status of a custom language model. When the status is <code>COMPLETED</code> the model is ready for use.</p>"
1591        },
1592        "UpgradeAvailability":{
1593          "shape":"Boolean",
1594          "documentation":"<p>Whether the base model used for the custom language model is up to date. If this field is <code>true</code> then you are running the most up-to-date version of the base model in your custom language model.</p>"
1595        },
1596        "FailureReason":{
1597          "shape":"FailureReason",
1598          "documentation":"<p>The reason why the custom language model couldn't be created.</p>"
1599        },
1600        "InputDataConfig":{
1601          "shape":"InputDataConfig",
1602          "documentation":"<p>The data access role and Amazon S3 prefixes for the input files used to train the custom language model.</p>"
1603        }
1604      },
1605      "documentation":"<p>The structure used to describe a custom language model.</p>"
1606    },
1607    "LanguageOptions":{
1608      "type":"list",
1609      "member":{"shape":"LanguageCode"},
1610      "min":1
1611    },
1612    "LimitExceededException":{
1613      "type":"structure",
1614      "members":{
1615        "Message":{"shape":"String"}
1616      },
1617      "documentation":"<p>Either you have sent too many requests or your input file is too long. Wait before you resend your request, or use a smaller file and resend the request.</p>",
1618      "exception":true
1619    },
1620    "ListCallAnalyticsCategoriesRequest":{
1621      "type":"structure",
1622      "members":{
1623        "NextToken":{
1624          "shape":"NextToken",
1625          "documentation":"<p>When included, <code>NextToken</code>fetches the next set of categories if the result of the previous request was truncated.</p>"
1626        },
1627        "MaxResults":{
1628          "shape":"MaxResults",
1629          "documentation":"<p>The maximum number of categories to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1630        }
1631      }
1632    },
1633    "ListCallAnalyticsCategoriesResponse":{
1634      "type":"structure",
1635      "members":{
1636        "NextToken":{
1637          "shape":"NextToken",
1638          "documentation":"<p>The operation returns a page of jobs at a time. The maximum size of the list is set by the <code>MaxResults</code> parameter. If there are more categories in the list than the page size, Amazon Transcribe returns the <code>NextPage</code> token. Include the token in the next request to the operation to return the next page of analytics categories.</p>"
1639        },
1640        "Categories":{
1641          "shape":"CategoryPropertiesList",
1642          "documentation":"<p>A list of objects containing information about analytics categories.</p>"
1643        }
1644      }
1645    },
1646    "ListCallAnalyticsJobsRequest":{
1647      "type":"structure",
1648      "members":{
1649        "Status":{
1650          "shape":"CallAnalyticsJobStatus",
1651          "documentation":"<p>When specified, returns only call analytics jobs with the specified status. Jobs are ordered by creation date, with the most recent jobs returned first. If you don't specify a status, Amazon Transcribe returns all analytics jobs ordered by creation date.</p>"
1652        },
1653        "JobNameContains":{
1654          "shape":"CallAnalyticsJobName",
1655          "documentation":"<p>When specified, the jobs returned in the list are limited to jobs whose name contains the specified string.</p>"
1656        },
1657        "NextToken":{
1658          "shape":"NextToken",
1659          "documentation":"<p>If you receive a truncated result in the previous request of , include <code>NextToken</code> to fetch the next set of jobs.</p>"
1660        },
1661        "MaxResults":{
1662          "shape":"MaxResults",
1663          "documentation":"<p> The maximum number of call analytics jobs to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used. </p>"
1664        }
1665      }
1666    },
1667    "ListCallAnalyticsJobsResponse":{
1668      "type":"structure",
1669      "members":{
1670        "Status":{
1671          "shape":"CallAnalyticsJobStatus",
1672          "documentation":"<p>When specified, returns only call analytics jobs with that status. Jobs are ordered by creation date, with the most recent jobs returned first. If you don't specify a status, Amazon Transcribe returns all transcription jobs ordered by creation date.</p>"
1673        },
1674        "NextToken":{
1675          "shape":"NextToken",
1676          "documentation":"<p>The operation returns a page of jobs at a time. The maximum size of the page is set by the <code>MaxResults</code> parameter. If there are more jobs in the list than the page size, Amazon Transcribe returns the <code>NextPage</code> token. Include the token in your next request to the operation to return next page of jobs.</p>"
1677        },
1678        "CallAnalyticsJobSummaries":{
1679          "shape":"CallAnalyticsJobSummaries",
1680          "documentation":"<p>A list of objects containing summary information for a transcription job.</p>"
1681        }
1682      }
1683    },
1684    "ListLanguageModelsRequest":{
1685      "type":"structure",
1686      "members":{
1687        "StatusEquals":{
1688          "shape":"ModelStatus",
1689          "documentation":"<p>When specified, returns only custom language models with the specified status. Language models are ordered by creation date, with the newest models first. If you don't specify a status, Amazon Transcribe returns all custom language models ordered by date.</p>"
1690        },
1691        "NameContains":{
1692          "shape":"ModelName",
1693          "documentation":"<p>When specified, the custom language model names returned contain the substring you've specified.</p>"
1694        },
1695        "NextToken":{
1696          "shape":"NextToken",
1697          "documentation":"<p>When included, fetches the next set of jobs if the result of the previous request was truncated.</p>"
1698        },
1699        "MaxResults":{
1700          "shape":"MaxResults",
1701          "documentation":"<p> The maximum number of language models to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1702        }
1703      }
1704    },
1705    "ListLanguageModelsResponse":{
1706      "type":"structure",
1707      "members":{
1708        "NextToken":{
1709          "shape":"NextToken",
1710          "documentation":"<p>The operation returns a page of jobs at a time. The maximum size of the list is set by the MaxResults parameter. If there are more language models in the list than the page size, Amazon Transcribe returns the <code>NextPage</code> token. Include the token in the next request to the operation to return the next page of language models.</p>"
1711        },
1712        "Models":{
1713          "shape":"Models",
1714          "documentation":"<p>A list of objects containing information about custom language models.</p>"
1715        }
1716      }
1717    },
1718    "ListMedicalTranscriptionJobsRequest":{
1719      "type":"structure",
1720      "members":{
1721        "Status":{
1722          "shape":"TranscriptionJobStatus",
1723          "documentation":"<p>When specified, returns only medical transcription jobs with the specified status. Jobs are ordered by creation date, with the newest jobs returned first. If you don't specify a status, Amazon Transcribe Medical returns all transcription jobs ordered by creation date.</p>"
1724        },
1725        "JobNameContains":{
1726          "shape":"TranscriptionJobName",
1727          "documentation":"<p>When specified, the jobs returned in the list are limited to jobs whose name contains the specified string.</p>"
1728        },
1729        "NextToken":{
1730          "shape":"NextToken",
1731          "documentation":"<p>If you a receive a truncated result in the previous request of <code>ListMedicalTranscriptionJobs</code>, include <code>NextToken</code> to fetch the next set of jobs.</p>"
1732        },
1733        "MaxResults":{
1734          "shape":"MaxResults",
1735          "documentation":"<p> The maximum number of medical transcription jobs to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1736        }
1737      }
1738    },
1739    "ListMedicalTranscriptionJobsResponse":{
1740      "type":"structure",
1741      "members":{
1742        "Status":{
1743          "shape":"TranscriptionJobStatus",
1744          "documentation":"<p>The requested status of the medical transcription jobs returned.</p>"
1745        },
1746        "NextToken":{
1747          "shape":"NextToken",
1748          "documentation":"<p>The <code>ListMedicalTranscriptionJobs</code> operation returns a page of jobs at a time. The maximum size of the page is set by the <code>MaxResults</code> parameter. If the number of jobs exceeds what can fit on a page, Amazon Transcribe Medical returns the <code>NextPage</code> token. Include the token in the next request to the <code>ListMedicalTranscriptionJobs</code> operation to return in the next page of jobs.</p>"
1749        },
1750        "MedicalTranscriptionJobSummaries":{
1751          "shape":"MedicalTranscriptionJobSummaries",
1752          "documentation":"<p>A list of objects containing summary information for a transcription job.</p>"
1753        }
1754      }
1755    },
1756    "ListMedicalVocabulariesRequest":{
1757      "type":"structure",
1758      "members":{
1759        "NextToken":{
1760          "shape":"NextToken",
1761          "documentation":"<p>If the result of your previous request to <code>ListMedicalVocabularies</code> was truncated, include the <code>NextToken</code> to fetch the next set of vocabularies.</p>"
1762        },
1763        "MaxResults":{
1764          "shape":"MaxResults",
1765          "documentation":"<p>The maximum number of vocabularies to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1766        },
1767        "StateEquals":{
1768          "shape":"VocabularyState",
1769          "documentation":"<p>When specified, returns only vocabularies with the <code>VocabularyState</code> equal to the specified vocabulary state. Use this field to see which vocabularies are ready for your medical transcription jobs.</p>"
1770        },
1771        "NameContains":{
1772          "shape":"VocabularyName",
1773          "documentation":"<p>Returns vocabularies whose names contain the specified string. The search is not case sensitive. <code>ListMedicalVocabularies</code> returns both \"<code>vocabularyname</code>\" and \"<code>VocabularyName</code>\".</p>"
1774        }
1775      }
1776    },
1777    "ListMedicalVocabulariesResponse":{
1778      "type":"structure",
1779      "members":{
1780        "Status":{
1781          "shape":"VocabularyState",
1782          "documentation":"<p>The requested vocabulary state.</p>"
1783        },
1784        "NextToken":{
1785          "shape":"NextToken",
1786          "documentation":"<p>The <code>ListMedicalVocabularies</code> operation returns a page of vocabularies at a time. You set the maximum number of vocabularies to return on a page with the <code>MaxResults</code> parameter. If there are more jobs in the list will fit on a page, Amazon Transcribe Medical returns the <code>NextPage</code> token. To return the next page of vocabularies, include the token in the next request to the <code>ListMedicalVocabularies</code> operation .</p>"
1787        },
1788        "Vocabularies":{
1789          "shape":"Vocabularies",
1790          "documentation":"<p>A list of objects that describe the vocabularies that match your search criteria.</p>"
1791        }
1792      }
1793    },
1794    "ListTagsForResourceRequest":{
1795      "type":"structure",
1796      "required":["ResourceArn"],
1797      "members":{
1798        "ResourceArn":{
1799          "shape":"TranscribeArn",
1800          "documentation":"<p>Lists all tags associated with a given Amazon Resource Name (ARN).</p>"
1801        }
1802      }
1803    },
1804    "ListTagsForResourceResponse":{
1805      "type":"structure",
1806      "members":{
1807        "ResourceArn":{
1808          "shape":"TranscribeArn",
1809          "documentation":"<p>Lists all tags associated with the given Amazon Resource Name (ARN).</p>"
1810        },
1811        "Tags":{
1812          "shape":"TagList",
1813          "documentation":"<p>Lists all tags associated with the given transcription job, vocabulary, or resource.</p>"
1814        }
1815      }
1816    },
1817    "ListTranscriptionJobsRequest":{
1818      "type":"structure",
1819      "members":{
1820        "Status":{
1821          "shape":"TranscriptionJobStatus",
1822          "documentation":"<p>When specified, returns only transcription jobs with the specified status. Jobs are ordered by creation date, with the newest jobs returned first. If you don’t specify a status, Amazon Transcribe returns all transcription jobs ordered by creation date.</p>"
1823        },
1824        "JobNameContains":{
1825          "shape":"TranscriptionJobName",
1826          "documentation":"<p>When specified, the jobs returned in the list are limited to jobs whose name contains the specified string.</p>"
1827        },
1828        "NextToken":{
1829          "shape":"NextToken",
1830          "documentation":"<p>If the result of the previous request to <code>ListTranscriptionJobs</code> is truncated, include the <code>NextToken</code> to fetch the next set of jobs.</p>"
1831        },
1832        "MaxResults":{
1833          "shape":"MaxResults",
1834          "documentation":"<p>The maximum number of jobs to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1835        }
1836      }
1837    },
1838    "ListTranscriptionJobsResponse":{
1839      "type":"structure",
1840      "members":{
1841        "Status":{
1842          "shape":"TranscriptionJobStatus",
1843          "documentation":"<p>The requested status of the jobs returned.</p>"
1844        },
1845        "NextToken":{
1846          "shape":"NextToken",
1847          "documentation":"<p>The <code>ListTranscriptionJobs</code> operation returns a page of jobs at a time. The maximum size of the page is set by the <code>MaxResults</code> parameter. If there are more jobs in the list than the page size, Amazon Transcribe returns the <code>NextPage</code> token. Include the token in the next request to the <code>ListTranscriptionJobs</code> operation to return in the next page of jobs.</p>"
1848        },
1849        "TranscriptionJobSummaries":{
1850          "shape":"TranscriptionJobSummaries",
1851          "documentation":"<p>A list of objects containing summary information for a transcription job.</p>"
1852        }
1853      }
1854    },
1855    "ListVocabulariesRequest":{
1856      "type":"structure",
1857      "members":{
1858        "NextToken":{
1859          "shape":"NextToken",
1860          "documentation":"<p>If the result of the previous request to <code>ListVocabularies</code> was truncated, include the <code>NextToken</code> to fetch the next set of jobs.</p>"
1861        },
1862        "MaxResults":{
1863          "shape":"MaxResults",
1864          "documentation":"<p>The maximum number of vocabularies to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1865        },
1866        "StateEquals":{
1867          "shape":"VocabularyState",
1868          "documentation":"<p>When specified, only returns vocabularies with the <code>VocabularyState</code> field equal to the specified state.</p>"
1869        },
1870        "NameContains":{
1871          "shape":"VocabularyName",
1872          "documentation":"<p>When specified, the vocabularies returned in the list are limited to vocabularies whose name contains the specified string. The search is not case sensitive, <code>ListVocabularies</code> returns both \"vocabularyname\" and \"VocabularyName\" in the response list.</p>"
1873        }
1874      }
1875    },
1876    "ListVocabulariesResponse":{
1877      "type":"structure",
1878      "members":{
1879        "Status":{
1880          "shape":"VocabularyState",
1881          "documentation":"<p>The requested vocabulary state.</p>"
1882        },
1883        "NextToken":{
1884          "shape":"NextToken",
1885          "documentation":"<p>The <code>ListVocabularies</code> operation returns a page of vocabularies at a time. The maximum size of the page is set in the <code>MaxResults</code> parameter. If there are more jobs in the list than will fit on the page, Amazon Transcribe returns the <code>NextPage</code> token. To return in the next page of jobs, include the token in the next request to the <code>ListVocabularies</code> operation.</p>"
1886        },
1887        "Vocabularies":{
1888          "shape":"Vocabularies",
1889          "documentation":"<p>A list of objects that describe the vocabularies that match the search criteria in the request.</p>"
1890        }
1891      }
1892    },
1893    "ListVocabularyFiltersRequest":{
1894      "type":"structure",
1895      "members":{
1896        "NextToken":{
1897          "shape":"NextToken",
1898          "documentation":"<p>If the result of the previous request to <code>ListVocabularyFilters</code> was truncated, include the <code>NextToken</code> to fetch the next set of collections.</p>"
1899        },
1900        "MaxResults":{
1901          "shape":"MaxResults",
1902          "documentation":"<p>The maximum number of filters to return in each page of results. If there are fewer results than the value you specify, only the actual results are returned. If you do not specify a value, the default of 5 is used.</p>"
1903        },
1904        "NameContains":{
1905          "shape":"VocabularyFilterName",
1906          "documentation":"<p>Filters the response so that it only contains vocabulary filters whose name contains the specified string.</p>"
1907        }
1908      }
1909    },
1910    "ListVocabularyFiltersResponse":{
1911      "type":"structure",
1912      "members":{
1913        "NextToken":{
1914          "shape":"NextToken",
1915          "documentation":"<p>The <code>ListVocabularyFilters</code> operation returns a page of collections at a time. The maximum size of the page is set by the <code>MaxResults</code> parameter. If there are more jobs in the list than the page size, Amazon Transcribe returns the <code>NextPage</code> token. Include the token in the next request to the <code>ListVocabularyFilters</code> operation to return in the next page of jobs.</p>"
1916        },
1917        "VocabularyFilters":{
1918          "shape":"VocabularyFilters",
1919          "documentation":"<p>The list of vocabulary filters. It contains at most <code>MaxResults</code> number of filters. If there are more filters, call the <code>ListVocabularyFilters</code> operation again with the <code>NextToken</code> parameter in the request set to the value of the <code>NextToken</code> field in the response.</p>"
1920        }
1921      }
1922    },
1923    "MaxAlternatives":{
1924      "type":"integer",
1925      "max":10,
1926      "min":2
1927    },
1928    "MaxResults":{
1929      "type":"integer",
1930      "max":100,
1931      "min":1
1932    },
1933    "MaxSpeakers":{
1934      "type":"integer",
1935      "max":10,
1936      "min":2
1937    },
1938    "Media":{
1939      "type":"structure",
1940      "members":{
1941        "MediaFileUri":{
1942          "shape":"Uri",
1943          "documentation":"<p>The S3 object location of the input media file. The URI must be in the same region as the API endpoint that you are calling. The general form is:</p> <p>For example:</p> <p>For more information about S3 object names, see <a href=\"https://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html#object-keys\">Object Keys</a> in the <i>Amazon S3 Developer Guide</i>.</p>"
1944        },
1945        "RedactedMediaFileUri":{
1946          "shape":"Uri",
1947          "documentation":"<p> The S3 object location for your redacted output media file. This is only supported for call analytics jobs.</p>"
1948        }
1949      },
1950      "documentation":"<p>Describes the input media file in a transcription request.</p>"
1951    },
1952    "MediaFormat":{
1953      "type":"string",
1954      "enum":[
1955        "mp3",
1956        "mp4",
1957        "wav",
1958        "flac",
1959        "ogg",
1960        "amr",
1961        "webm"
1962      ]
1963    },
1964    "MediaSampleRateHertz":{
1965      "type":"integer",
1966      "max":48000,
1967      "min":8000
1968    },
1969    "MedicalContentIdentificationType":{
1970      "type":"string",
1971      "enum":["PHI"]
1972    },
1973    "MedicalTranscript":{
1974      "type":"structure",
1975      "members":{
1976        "TranscriptFileUri":{
1977          "shape":"Uri",
1978          "documentation":"<p>The S3 object location of the medical transcript.</p> <p>Use this URI to access the medical transcript. This URI points to the S3 bucket you created to store the medical transcript.</p>"
1979        }
1980      },
1981      "documentation":"<p>Identifies the location of a medical transcript.</p>"
1982    },
1983    "MedicalTranscriptionJob":{
1984      "type":"structure",
1985      "members":{
1986        "MedicalTranscriptionJobName":{
1987          "shape":"TranscriptionJobName",
1988          "documentation":"<p>The name for a given medical transcription job.</p>"
1989        },
1990        "TranscriptionJobStatus":{
1991          "shape":"TranscriptionJobStatus",
1992          "documentation":"<p>The completion status of a medical transcription job.</p>"
1993        },
1994        "LanguageCode":{
1995          "shape":"LanguageCode",
1996          "documentation":"<p>The language code for the language spoken in the source audio file. US English (en-US) is the only supported language for medical transcriptions. Any other value you enter for language code results in a <code>BadRequestException</code> error.</p>"
1997        },
1998        "MediaSampleRateHertz":{
1999          "shape":"MediaSampleRateHertz",
2000          "documentation":"<p>The sample rate, in Hertz, of the source audio containing medical information.</p> <p>If you don't specify the sample rate, Amazon Transcribe Medical determines it for you. If you choose to specify the sample rate, it must match the rate detected by Amazon Transcribe Medical. In most cases, you should leave the <code>MedicalMediaSampleHertz</code> blank and let Amazon Transcribe Medical determine the sample rate.</p>"
2001        },
2002        "MediaFormat":{
2003          "shape":"MediaFormat",
2004          "documentation":"<p>The format of the input media file.</p>"
2005        },
2006        "Media":{"shape":"Media"},
2007        "Transcript":{
2008          "shape":"MedicalTranscript",
2009          "documentation":"<p>An object that contains the <code>MedicalTranscript</code>. The <code>MedicalTranscript</code> contains the <code>TranscriptFileUri</code>.</p>"
2010        },
2011        "StartTime":{
2012          "shape":"DateTime",
2013          "documentation":"<p>A timestamp that shows when the job started processing.</p>"
2014        },
2015        "CreationTime":{
2016          "shape":"DateTime",
2017          "documentation":"<p>A timestamp that shows when the job was created.</p>"
2018        },
2019        "CompletionTime":{
2020          "shape":"DateTime",
2021          "documentation":"<p>A timestamp that shows when the job was completed.</p>"
2022        },
2023        "FailureReason":{
2024          "shape":"FailureReason",
2025          "documentation":"<p>If the <code>TranscriptionJobStatus</code> field is <code>FAILED</code>, this field contains information about why the job failed.</p> <p>The <code>FailureReason</code> field contains one of the following values:</p> <ul> <li> <p> <code>Unsupported media format</code>- The media format specified in the <code>MediaFormat</code> field of the request isn't valid. See the description of the <code>MediaFormat</code> field for a list of valid values.</p> </li> <li> <p> <code>The media format provided does not match the detected media format</code>- The media format of the audio file doesn't match the format specified in the <code>MediaFormat</code> field in the request. Check the media format of your media file and make sure the two values match.</p> </li> <li> <p> <code>Invalid sample rate for audio file</code>- The sample rate specified in the <code>MediaSampleRateHertz</code> of the request isn't valid. The sample rate must be between 8,000 and 48,000 Hertz.</p> </li> <li> <p> <code>The sample rate provided does not match the detected sample rate</code>- The sample rate in the audio file doesn't match the sample rate specified in the <code>MediaSampleRateHertz</code> field in the request. Check the sample rate of your media file and make sure that the two values match.</p> </li> <li> <p> <code>Invalid file size: file size too large</code>- The size of your audio file is larger than what Amazon Transcribe Medical can process. For more information, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/limits-guidelines.html#limits\">Guidelines and Quotas</a> in the <i>Amazon Transcribe Medical Guide</i> </p> </li> <li> <p> <code>Invalid number of channels: number of channels too large</code>- Your audio contains more channels than Amazon Transcribe Medical is configured to process. To request additional channels, see <a href=\"https://docs.aws.amazon.com/general/latest/gr/transcribe-medical.html\">Amazon Transcribe Medical Endpoints and Quotas</a> in the <i>Amazon Web Services General Reference</i> </p> </li> </ul>"
2026        },
2027        "Settings":{
2028          "shape":"MedicalTranscriptionSetting",
2029          "documentation":"<p>Object that contains object.</p>"
2030        },
2031        "ContentIdentificationType":{
2032          "shape":"MedicalContentIdentificationType",
2033          "documentation":"<p>Shows the type of content that you've configured Amazon Transcribe Medical to identify in a transcription job. If the value is <code>PHI</code>, you've configured the job to identify personal health information (PHI) in the transcription output.</p>"
2034        },
2035        "Specialty":{
2036          "shape":"Specialty",
2037          "documentation":"<p>The medical specialty of any clinicians providing a dictation or having a conversation. Refer to <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/transcribe-medical-conversation.html\">Transcribing a medical conversation</a>for a list of supported specialties.</p>"
2038        },
2039        "Type":{
2040          "shape":"Type",
2041          "documentation":"<p>The type of speech in the transcription job. <code>CONVERSATION</code> is generally used for patient-physician dialogues. <code>DICTATION</code> is the setting for physicians speaking their notes after seeing a patient. For more information, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/what-is-transcribe-med.html\">What is Amazon Transcribe Medical?</a>.</p>"
2042        },
2043        "Tags":{
2044          "shape":"TagList",
2045          "documentation":"<p>A key:value pair assigned to a given medical transcription job.</p>"
2046        }
2047      },
2048      "documentation":"<p>The data structure that contains the information for a medical transcription job.</p>"
2049    },
2050    "MedicalTranscriptionJobSummaries":{
2051      "type":"list",
2052      "member":{"shape":"MedicalTranscriptionJobSummary"}
2053    },
2054    "MedicalTranscriptionJobSummary":{
2055      "type":"structure",
2056      "members":{
2057        "MedicalTranscriptionJobName":{
2058          "shape":"TranscriptionJobName",
2059          "documentation":"<p>The name of a medical transcription job.</p>"
2060        },
2061        "CreationTime":{
2062          "shape":"DateTime",
2063          "documentation":"<p>A timestamp that shows when the medical transcription job was created.</p>"
2064        },
2065        "StartTime":{
2066          "shape":"DateTime",
2067          "documentation":"<p>A timestamp that shows when the job began processing.</p>"
2068        },
2069        "CompletionTime":{
2070          "shape":"DateTime",
2071          "documentation":"<p>A timestamp that shows when the job was completed.</p>"
2072        },
2073        "LanguageCode":{
2074          "shape":"LanguageCode",
2075          "documentation":"<p>The language of the transcript in the source audio file.</p>"
2076        },
2077        "TranscriptionJobStatus":{
2078          "shape":"TranscriptionJobStatus",
2079          "documentation":"<p>The status of the medical transcription job.</p>"
2080        },
2081        "FailureReason":{
2082          "shape":"FailureReason",
2083          "documentation":"<p>If the <code>TranscriptionJobStatus</code> field is <code>FAILED</code>, a description of the error.</p>"
2084        },
2085        "OutputLocationType":{
2086          "shape":"OutputLocationType",
2087          "documentation":"<p>Indicates the location of the transcription job's output. This field must be the path of an S3 bucket; if you don't already have an S3 bucket, one is created based on the path you add.</p>"
2088        },
2089        "Specialty":{
2090          "shape":"Specialty",
2091          "documentation":"<p>The medical specialty of the transcription job. Refer to <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/transcribe-medical-conversation.html\">Transcribing a medical conversation</a>for a list of supported specialties.</p>"
2092        },
2093        "ContentIdentificationType":{
2094          "shape":"MedicalContentIdentificationType",
2095          "documentation":"<p>Shows the type of information you've configured Amazon Transcribe Medical to identify in a transcription job. If the value is <code>PHI</code>, you've configured the transcription job to identify personal health information (PHI).</p>"
2096        },
2097        "Type":{
2098          "shape":"Type",
2099          "documentation":"<p>The speech of the clinician in the input audio.</p>"
2100        }
2101      },
2102      "documentation":"<p>Provides summary information about a transcription job.</p>"
2103    },
2104    "MedicalTranscriptionSetting":{
2105      "type":"structure",
2106      "members":{
2107        "ShowSpeakerLabels":{
2108          "shape":"Boolean",
2109          "documentation":"<p>Determines whether the transcription job uses speaker recognition to identify different speakers in the input audio. Speaker recognition labels individual speakers in the audio file. If you set the <code>ShowSpeakerLabels</code> field to true, you must also set the maximum number of speaker labels in the <code>MaxSpeakerLabels</code> field.</p> <p>You can't set both <code>ShowSpeakerLabels</code> and <code>ChannelIdentification</code> in the same request. If you set both, your request returns a <code>BadRequestException</code>.</p>"
2110        },
2111        "MaxSpeakerLabels":{
2112          "shape":"MaxSpeakers",
2113          "documentation":"<p>The maximum number of speakers to identify in the input audio. If there are more speakers in the audio than this number, multiple speakers are identified as a single speaker. If you specify the <code>MaxSpeakerLabels</code> field, you must set the <code>ShowSpeakerLabels</code> field to true.</p>"
2114        },
2115        "ChannelIdentification":{
2116          "shape":"Boolean",
2117          "documentation":"<p>Instructs Amazon Transcribe Medical to process each audio channel separately and then merge the transcription output of each channel into a single transcription.</p> <p>Amazon Transcribe Medical also produces a transcription of each item detected on an audio channel, including the start time and end time of the item and alternative transcriptions of item. The alternative transcriptions also come with confidence scores provided by Amazon Transcribe Medical.</p> <p>You can't set both <code>ShowSpeakerLabels</code> and <code>ChannelIdentification</code> in the same request. If you set both, your request returns a <code>BadRequestException</code> </p>"
2118        },
2119        "ShowAlternatives":{
2120          "shape":"Boolean",
2121          "documentation":"<p>Determines whether alternative transcripts are generated along with the transcript that has the highest confidence. If you set <code>ShowAlternatives</code> field to true, you must also set the maximum number of alternatives to return in the <code>MaxAlternatives</code> field.</p>"
2122        },
2123        "MaxAlternatives":{
2124          "shape":"MaxAlternatives",
2125          "documentation":"<p>The maximum number of alternatives that you tell the service to return. If you specify the <code>MaxAlternatives</code> field, you must set the <code>ShowAlternatives</code> field to true.</p>"
2126        },
2127        "VocabularyName":{
2128          "shape":"VocabularyName",
2129          "documentation":"<p>The name of the vocabulary to use when processing a medical transcription job.</p>"
2130        }
2131      },
2132      "documentation":"<p>Optional settings for the <a>StartMedicalTranscriptionJob</a> operation.</p>"
2133    },
2134    "ModelName":{
2135      "type":"string",
2136      "max":200,
2137      "min":1,
2138      "pattern":"^[0-9a-zA-Z._-]+"
2139    },
2140    "ModelSettings":{
2141      "type":"structure",
2142      "members":{
2143        "LanguageModelName":{
2144          "shape":"ModelName",
2145          "documentation":"<p>The name of your custom language model.</p>"
2146        }
2147      },
2148      "documentation":"<p>The object used to call your custom language model to your transcription job.</p>"
2149    },
2150    "ModelStatus":{
2151      "type":"string",
2152      "enum":[
2153        "IN_PROGRESS",
2154        "FAILED",
2155        "COMPLETED"
2156      ]
2157    },
2158    "Models":{
2159      "type":"list",
2160      "member":{"shape":"LanguageModel"}
2161    },
2162    "NextToken":{
2163      "type":"string",
2164      "max":8192,
2165      "pattern":".+"
2166    },
2167    "NonEmptyString":{
2168      "type":"string",
2169      "max":2000,
2170      "min":1,
2171      "pattern":".*\\S.*"
2172    },
2173    "NonTalkTimeFilter":{
2174      "type":"structure",
2175      "members":{
2176        "Threshold":{
2177          "shape":"TimestampMilliseconds",
2178          "documentation":"<p>The duration of the period when neither the customer nor agent was talking.</p>"
2179        },
2180        "AbsoluteTimeRange":{
2181          "shape":"AbsoluteTimeRange",
2182          "documentation":"<p>An object you can use to specify a time range (in milliseconds) for when no one is talking. For example, you could specify a time period between the 30,000 millisecond mark and the 45,000 millisecond mark. You could also specify the time period as the first 15,000 milliseconds or the last 15,000 milliseconds.</p>"
2183        },
2184        "RelativeTimeRange":{
2185          "shape":"RelativeTimeRange",
2186          "documentation":"<p>An object that allows percentages to specify the proportion of the call where there was silence. For example, you can specify the first half of the call. You can also specify the period of time between halfway through to three-quarters of the way through the call. Because the length of conversation can vary between calls, you can apply relative time ranges across all calls.</p>"
2187        },
2188        "Negate":{
2189          "shape":"Boolean",
2190          "documentation":"<p>Set to <code>TRUE</code> to look for a time period when people were talking.</p>"
2191        }
2192      },
2193      "documentation":"<p>An object that enables you to configure your category to be applied to call analytics jobs where either the customer or agent was interrupted.</p>"
2194    },
2195    "NotFoundException":{
2196      "type":"structure",
2197      "members":{
2198        "Message":{"shape":"String"}
2199      },
2200      "documentation":"<p>We can't find the requested resource. Check the name and try your request again.</p>",
2201      "exception":true
2202    },
2203    "OutputBucketName":{
2204      "type":"string",
2205      "max":64,
2206      "pattern":"[a-z0-9][\\.\\-a-z0-9]{1,61}[a-z0-9]"
2207    },
2208    "OutputKey":{
2209      "type":"string",
2210      "max":1024,
2211      "min":1,
2212      "pattern":"[a-zA-Z0-9-_.!*'()/]{1,1024}$"
2213    },
2214    "OutputLocationType":{
2215      "type":"string",
2216      "enum":[
2217        "CUSTOMER_BUCKET",
2218        "SERVICE_BUCKET"
2219      ]
2220    },
2221    "ParticipantRole":{
2222      "type":"string",
2223      "enum":[
2224        "AGENT",
2225        "CUSTOMER"
2226      ]
2227    },
2228    "Percentage":{
2229      "type":"integer",
2230      "max":100,
2231      "min":0
2232    },
2233    "Phrase":{
2234      "type":"string",
2235      "max":256,
2236      "min":0,
2237      "pattern":".+"
2238    },
2239    "Phrases":{
2240      "type":"list",
2241      "member":{"shape":"Phrase"}
2242    },
2243    "RedactionOutput":{
2244      "type":"string",
2245      "enum":[
2246        "redacted",
2247        "redacted_and_unredacted"
2248      ]
2249    },
2250    "RedactionType":{
2251      "type":"string",
2252      "enum":["PII"]
2253    },
2254    "RelativeTimeRange":{
2255      "type":"structure",
2256      "members":{
2257        "StartPercentage":{
2258          "shape":"Percentage",
2259          "documentation":"<p>A value that indicates the percentage of the beginning of the time range. To set a relative time range, you must specify a start percentage and an end percentage. For example, if you specify the following values:</p> <ul> <li> <p>StartPercentage - 10</p> </li> <li> <p>EndPercentage - 50</p> </li> </ul> <p>This looks at the time range starting from 10% of the way into the call to 50% of the way through the call. For a call that lasts 100,000 milliseconds, this example range would apply from the 10,000 millisecond mark to the 50,000 millisecond mark.</p>"
2260        },
2261        "EndPercentage":{
2262          "shape":"Percentage",
2263          "documentation":"<p>A value that indicates the percentage of the end of the time range. To set a relative time range, you must specify a start percentage and an end percentage. For example, if you specify the following values:</p> <ul> <li> <p>StartPercentage - 10</p> </li> <li> <p>EndPercentage - 50</p> </li> </ul> <p>This looks at the time range starting from 10% of the way into the call to 50% of the way through the call. For a call that lasts 100,000 milliseconds, this example range would apply from the 10,000 millisecond mark to the 50,000 millisecond mark.</p>"
2264        },
2265        "First":{
2266          "shape":"Percentage",
2267          "documentation":"<p>A range that takes the portion of the call up to the time in milliseconds set by the value that you've specified. For example, if you specify <code>120000</code>, the time range is set for the first 120,000 milliseconds of the call.</p>"
2268        },
2269        "Last":{
2270          "shape":"Percentage",
2271          "documentation":"<p>A range that takes the portion of the call from the time in milliseconds set by the value that you've specified to the end of the call. For example, if you specify <code>120000</code>, the time range is set for the last 120,000 milliseconds of the call.</p>"
2272        }
2273      },
2274      "documentation":"<p>An object that allows percentages to specify the proportion of the call where you would like to apply a filter. For example, you can specify the first half of the call. You can also specify the period of time between halfway through to three-quarters of the way through the call. Because the length of conversation can vary between calls, you can apply relative time ranges across all calls. </p>"
2275    },
2276    "Rule":{
2277      "type":"structure",
2278      "members":{
2279        "NonTalkTimeFilter":{
2280          "shape":"NonTalkTimeFilter",
2281          "documentation":"<p>A condition for a time period when neither the customer nor the agent was talking.</p>"
2282        },
2283        "InterruptionFilter":{
2284          "shape":"InterruptionFilter",
2285          "documentation":"<p>A condition for a time period when either the customer or agent was interrupting the other person. </p>"
2286        },
2287        "TranscriptFilter":{
2288          "shape":"TranscriptFilter",
2289          "documentation":"<p>A condition that catches particular words or phrases based on a exact match. For example, if you set the phrase \"I want to speak to the manager\", only that exact phrase will be returned.</p>"
2290        },
2291        "SentimentFilter":{
2292          "shape":"SentimentFilter",
2293          "documentation":"<p>A condition that is applied to a particular customer sentiment.</p>"
2294        }
2295      },
2296      "documentation":"<p>A condition in the call between the customer and the agent that you want to filter for.</p>",
2297      "union":true
2298    },
2299    "RuleList":{
2300      "type":"list",
2301      "member":{"shape":"Rule"},
2302      "max":20,
2303      "min":1
2304    },
2305    "SentimentFilter":{
2306      "type":"structure",
2307      "required":["Sentiments"],
2308      "members":{
2309        "Sentiments":{
2310          "shape":"SentimentValueList",
2311          "documentation":"<p>An array that enables you to specify sentiments for the customer or agent. You can specify one or more values.</p>"
2312        },
2313        "AbsoluteTimeRange":{
2314          "shape":"AbsoluteTimeRange",
2315          "documentation":"<p>The time range, measured in seconds, of the sentiment.</p>"
2316        },
2317        "RelativeTimeRange":{
2318          "shape":"RelativeTimeRange",
2319          "documentation":"<p>The time range, set in percentages, that correspond to proportion of the call.</p>"
2320        },
2321        "ParticipantRole":{
2322          "shape":"ParticipantRole",
2323          "documentation":"<p>A value that determines whether the sentiment belongs to the customer or the agent.</p>"
2324        },
2325        "Negate":{
2326          "shape":"Boolean",
2327          "documentation":"<p>Set to <code>TRUE</code> to look for sentiments that weren't specified in the request. </p>"
2328        }
2329      },
2330      "documentation":"<p>An object that enables you to specify a particular customer or agent sentiment. If at least 50 percent of the conversation turns (the back-and-forth between two speakers) in a specified time period match the specified sentiment, Amazon Transcribe will consider the sentiment a match.</p>"
2331    },
2332    "SentimentValue":{
2333      "type":"string",
2334      "enum":[
2335        "POSITIVE",
2336        "NEGATIVE",
2337        "NEUTRAL",
2338        "MIXED"
2339      ]
2340    },
2341    "SentimentValueList":{
2342      "type":"list",
2343      "member":{"shape":"SentimentValue"},
2344      "min":1
2345    },
2346    "Settings":{
2347      "type":"structure",
2348      "members":{
2349        "VocabularyName":{
2350          "shape":"VocabularyName",
2351          "documentation":"<p>The name of a vocabulary to use when processing the transcription job.</p>"
2352        },
2353        "ShowSpeakerLabels":{
2354          "shape":"Boolean",
2355          "documentation":"<p>Determines whether the transcription job uses speaker recognition to identify different speakers in the input audio. Speaker recognition labels individual speakers in the audio file. If you set the <code>ShowSpeakerLabels</code> field to true, you must also set the maximum number of speaker labels <code>MaxSpeakerLabels</code> field.</p> <p>You can't set both <code>ShowSpeakerLabels</code> and <code>ChannelIdentification</code> in the same request. If you set both, your request returns a <code>BadRequestException</code>.</p>"
2356        },
2357        "MaxSpeakerLabels":{
2358          "shape":"MaxSpeakers",
2359          "documentation":"<p>The maximum number of speakers to identify in the input audio. If there are more speakers in the audio than this number, multiple speakers are identified as a single speaker. If you specify the <code>MaxSpeakerLabels</code> field, you must set the <code>ShowSpeakerLabels</code> field to true.</p>"
2360        },
2361        "ChannelIdentification":{
2362          "shape":"Boolean",
2363          "documentation":"<p>Instructs Amazon Transcribe to process each audio channel separately and then merge the transcription output of each channel into a single transcription. </p> <p>Amazon Transcribe also produces a transcription of each item detected on an audio channel, including the start time and end time of the item and alternative transcriptions of the item including the confidence that Amazon Transcribe has in the transcription.</p> <p>You can't set both <code>ShowSpeakerLabels</code> and <code>ChannelIdentification</code> in the same request. If you set both, your request returns a <code>BadRequestException</code>.</p>"
2364        },
2365        "ShowAlternatives":{
2366          "shape":"Boolean",
2367          "documentation":"<p>Determines whether the transcription contains alternative transcriptions. If you set the <code>ShowAlternatives</code> field to true, you must also set the maximum number of alternatives to return in the <code>MaxAlternatives</code> field.</p>"
2368        },
2369        "MaxAlternatives":{
2370          "shape":"MaxAlternatives",
2371          "documentation":"<p>The number of alternative transcriptions that the service should return. If you specify the <code>MaxAlternatives</code> field, you must set the <code>ShowAlternatives</code> field to true.</p>"
2372        },
2373        "VocabularyFilterName":{
2374          "shape":"VocabularyFilterName",
2375          "documentation":"<p>The name of the vocabulary filter to use when transcribing the audio. The filter that you specify must have the same language code as the transcription job.</p>"
2376        },
2377        "VocabularyFilterMethod":{
2378          "shape":"VocabularyFilterMethod",
2379          "documentation":"<p>Set to <code>mask</code> to remove filtered text from the transcript and replace it with three asterisks (\"***\") as placeholder text. Set to <code>remove</code> to remove filtered text from the transcript without using placeholder text. Set to <code>tag</code> to mark the word in the transcription output that matches the vocabulary filter. When you set the filter method to <code>tag</code>, the words matching your vocabulary filter are not masked or removed.</p>"
2380        }
2381      },
2382      "documentation":"<p>Provides optional settings for the <code>StartTranscriptionJob</code> operation.</p>"
2383    },
2384    "Specialty":{
2385      "type":"string",
2386      "enum":["PRIMARYCARE"]
2387    },
2388    "StartCallAnalyticsJobRequest":{
2389      "type":"structure",
2390      "required":[
2391        "CallAnalyticsJobName",
2392        "Media",
2393        "DataAccessRoleArn"
2394      ],
2395      "members":{
2396        "CallAnalyticsJobName":{
2397          "shape":"CallAnalyticsJobName",
2398          "documentation":"<p>The name of the call analytics job. You can't use the string \".\" or \"..\" by themselves as the job name. The name must also be unique within an Amazon Web Services account. If you try to create a call analytics job with the same name as a previous call analytics job, you get a <code>ConflictException</code> error.</p>"
2399        },
2400        "Media":{"shape":"Media"},
2401        "OutputLocation":{
2402          "shape":"Uri",
2403          "documentation":"<p>The Amazon S3 location where the output of the call analytics job is stored. You can provide the following location types to store the output of call analytics job:</p> <ul> <li> <p>s3://DOC-EXAMPLE-BUCKET1</p> <p> If you specify a bucket, Amazon Transcribe saves the output of the analytics job as a JSON file at the root level of the bucket.</p> </li> <li> <p>s3://DOC-EXAMPLE-BUCKET1/folder/</p> <p>f you specify a path, Amazon Transcribe saves the output of the analytics job as s3://DOC-EXAMPLE-BUCKET1/folder/your-transcription-job-name.json</p> <p>If you specify a folder, you must provide a trailing slash.</p> </li> <li> <p>s3://DOC-EXAMPLE-BUCKET1/folder/filename.json</p> <p> If you provide a path that has the filename specified, Amazon Transcribe saves the output of the analytics job as s3://DOC-EXAMPLEBUCKET1/folder/filename.json</p> </li> </ul> <p>You can specify an Amazon Web Services Key Management Service (KMS) key to encrypt the output of our analytics job using the <code>OutputEncryptionKMSKeyId</code> parameter. If you don't specify a KMS key, Amazon Transcribe uses the default Amazon S3 key for server-side encryption of the analytics job output that is placed in your S3 bucket.</p>"
2404        },
2405        "OutputEncryptionKMSKeyId":{
2406          "shape":"KMSKeyId",
2407          "documentation":"<p>The Amazon Resource Name (ARN) of the Amazon Web Services Key Management Service key used to encrypt the output of the call analytics job. The user calling the operation must have permission to use the specified KMS key.</p> <p>You use either of the following to identify an Amazon Web Services KMS key in the current account:</p> <ul> <li> <p>KMS Key ID: \"1234abcd-12ab-34cd-56ef-1234567890ab\"</p> </li> <li> <p>KMS Key Alias: \"alias/ExampleAlias\"</p> </li> </ul> <p> You can use either of the following to identify a KMS key in the current account or another account:</p> <ul> <li> <p>Amazon Resource Name (ARN) of a KMS key in the current account or another account: \"arn:aws:kms:region:account ID:key/1234abcd-12ab-34cd-56ef1234567890ab\"</p> </li> <li> <p>ARN of a KMS Key Alias: \"arn:aws:kms:region:account ID:alias/ExampleAlias\"</p> </li> </ul> <p>If you don't specify an encryption key, the output of the call analytics job is encrypted with the default Amazon S3 key (SSE-S3).</p> <p>If you specify a KMS key to encrypt your output, you must also specify an output location in the <code>OutputLocation</code> parameter. </p>"
2408        },
2409        "DataAccessRoleArn":{
2410          "shape":"DataAccessRoleArn",
2411          "documentation":"<p>The Amazon Resource Name (ARN) of a role that has access to the S3 bucket that contains your input files. Amazon Transcribe assumes this role to read queued audio files. If you have specified an output S3 bucket for your transcription results, this role should have access to the output bucket as well.</p>"
2412        },
2413        "Settings":{
2414          "shape":"CallAnalyticsJobSettings",
2415          "documentation":"<p>A <code>Settings</code> object that provides optional settings for a call analytics job. </p>"
2416        },
2417        "ChannelDefinitions":{
2418          "shape":"ChannelDefinitions",
2419          "documentation":"<p>When you start a call analytics job, you must pass an array that maps the agent and the customer to specific audio channels. The values you can assign to a channel are 0 and 1. The agent and the customer must each have their own channel. You can't assign more than one channel to an agent or customer. </p>"
2420        }
2421      }
2422    },
2423    "StartCallAnalyticsJobResponse":{
2424      "type":"structure",
2425      "members":{
2426        "CallAnalyticsJob":{
2427          "shape":"CallAnalyticsJob",
2428          "documentation":"<p>An object containing the details of the asynchronous call analytics job.</p>"
2429        }
2430      }
2431    },
2432    "StartMedicalTranscriptionJobRequest":{
2433      "type":"structure",
2434      "required":[
2435        "MedicalTranscriptionJobName",
2436        "LanguageCode",
2437        "Media",
2438        "OutputBucketName",
2439        "Specialty",
2440        "Type"
2441      ],
2442      "members":{
2443        "MedicalTranscriptionJobName":{
2444          "shape":"TranscriptionJobName",
2445          "documentation":"<p>The name of the medical transcription job. You can't use the strings \"<code>.</code>\" or \"<code>..</code>\" by themselves as the job name. The name must also be unique within an Amazon Web Services account. If you try to create a medical transcription job with the same name as a previous medical transcription job, you get a <code>ConflictException</code> error.</p>"
2446        },
2447        "LanguageCode":{
2448          "shape":"LanguageCode",
2449          "documentation":"<p>The language code for the language spoken in the input media file. US English (en-US) is the valid value for medical transcription jobs. Any other value you enter for language code results in a <code>BadRequestException</code> error.</p>"
2450        },
2451        "MediaSampleRateHertz":{
2452          "shape":"MediaSampleRateHertz",
2453          "documentation":"<p>The sample rate, in Hertz, of the audio track in the input media file.</p> <p>If you do not specify the media sample rate, Amazon Transcribe Medical determines the sample rate. If you specify the sample rate, it must match the rate detected by Amazon Transcribe Medical. In most cases, you should leave the <code>MediaSampleRateHertz</code> field blank and let Amazon Transcribe Medical determine the sample rate.</p>"
2454        },
2455        "MediaFormat":{
2456          "shape":"MediaFormat",
2457          "documentation":"<p>The audio format of the input media file.</p>"
2458        },
2459        "Media":{"shape":"Media"},
2460        "OutputBucketName":{
2461          "shape":"OutputBucketName",
2462          "documentation":"<p>The Amazon S3 location where the transcription is stored.</p> <p>You must set <code>OutputBucketName</code> for Amazon Transcribe Medical to store the transcription results. Your transcript appears in the S3 location you specify. When you call the <a>GetMedicalTranscriptionJob</a>, the operation returns this location in the <code>TranscriptFileUri</code> field. The S3 bucket must have permissions that allow Amazon Transcribe Medical to put files in the bucket. For more information, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/security_iam_id-based-policy-examples.html#auth-role-iam-user\">Permissions Required for IAM User Roles</a>.</p> <p>You can specify an Amazon Web Services Key Management Service (KMS) key to encrypt the output of your transcription using the <code>OutputEncryptionKMSKeyId</code> parameter. If you don't specify a KMS key, Amazon Transcribe Medical uses the default Amazon S3 key for server-side encryption of transcripts that are placed in your S3 bucket.</p>"
2463        },
2464        "OutputKey":{
2465          "shape":"OutputKey",
2466          "documentation":"<p>You can specify a location in an Amazon S3 bucket to store the output of your medical transcription job.</p> <p>If you don't specify an output key, Amazon Transcribe Medical stores the output of your transcription job in the Amazon S3 bucket you specified. By default, the object key is \"your-transcription-job-name.json\".</p> <p>You can use output keys to specify the Amazon S3 prefix and file name of the transcription output. For example, specifying the Amazon S3 prefix, \"folder1/folder2/\", as an output key would lead to the output being stored as \"folder1/folder2/your-transcription-job-name.json\". If you specify \"my-other-job-name.json\" as the output key, the object key is changed to \"my-other-job-name.json\". You can use an output key to change both the prefix and the file name, for example \"folder/my-other-job-name.json\".</p> <p>If you specify an output key, you must also specify an S3 bucket in the <code>OutputBucketName</code> parameter.</p>"
2467        },
2468        "OutputEncryptionKMSKeyId":{
2469          "shape":"KMSKeyId",
2470          "documentation":"<p>The Amazon Resource Name (ARN) of the Amazon Web Services Key Management Service (KMS) key used to encrypt the output of the transcription job. The user calling the <a>StartMedicalTranscriptionJob</a> operation must have permission to use the specified KMS key.</p> <p>You use either of the following to identify a KMS key in the current account:</p> <ul> <li> <p>KMS Key ID: \"1234abcd-12ab-34cd-56ef-1234567890ab\"</p> </li> <li> <p>KMS Key Alias: \"alias/ExampleAlias\"</p> </li> </ul> <p>You can use either of the following to identify a KMS key in the current account or another account:</p> <ul> <li> <p>Amazon Resource Name (ARN) of a KMS key in the current account or another account: \"arn:aws:kms:region:account ID:key/1234abcd-12ab-34cd-56ef-1234567890ab\"</p> </li> <li> <p>ARN of a KMS Key Alias: \"arn:aws:kms:region:account ID:alias/ExampleAlias\"</p> </li> </ul> <p>If you don't specify an encryption key, the output of the medical transcription job is encrypted with the default Amazon S3 key (SSE-S3).</p> <p>If you specify a KMS key to encrypt your output, you must also specify an output location in the <code>OutputBucketName</code> parameter.</p>"
2471        },
2472        "KMSEncryptionContext":{
2473          "shape":"KMSEncryptionContextMap",
2474          "documentation":"<p>A map of plain text, non-secret key:value pairs, known as encryption context pairs, that provide an added layer of security for your data.</p>"
2475        },
2476        "Settings":{
2477          "shape":"MedicalTranscriptionSetting",
2478          "documentation":"<p>Optional settings for the medical transcription job.</p>"
2479        },
2480        "ContentIdentificationType":{
2481          "shape":"MedicalContentIdentificationType",
2482          "documentation":"<p>You can configure Amazon Transcribe Medical to label content in the transcription output. If you specify <code>PHI</code>, Amazon Transcribe Medical labels the personal health information (PHI) that it identifies in the transcription output.</p>"
2483        },
2484        "Specialty":{
2485          "shape":"Specialty",
2486          "documentation":"<p>The medical specialty of any clinician speaking in the input media.</p>"
2487        },
2488        "Type":{
2489          "shape":"Type",
2490          "documentation":"<p>The type of speech in the input audio. <code>CONVERSATION</code> refers to conversations between two or more speakers, e.g., a conversations between doctors and patients. <code>DICTATION</code> refers to single-speaker dictated speech, such as clinical notes.</p>"
2491        },
2492        "Tags":{
2493          "shape":"TagList",
2494          "documentation":"<p>Add tags to an Amazon Transcribe medical transcription job.</p>"
2495        }
2496      }
2497    },
2498    "StartMedicalTranscriptionJobResponse":{
2499      "type":"structure",
2500      "members":{
2501        "MedicalTranscriptionJob":{
2502          "shape":"MedicalTranscriptionJob",
2503          "documentation":"<p>A batch job submitted to transcribe medical speech to text.</p>"
2504        }
2505      }
2506    },
2507    "StartTranscriptionJobRequest":{
2508      "type":"structure",
2509      "required":[
2510        "TranscriptionJobName",
2511        "Media"
2512      ],
2513      "members":{
2514        "TranscriptionJobName":{
2515          "shape":"TranscriptionJobName",
2516          "documentation":"<p>The name of the job. You can't use the strings \"<code>.</code>\" or \"<code>..</code>\" by themselves as the job name. The name must also be unique within an Amazon Web Services account. If you try to create a transcription job with the same name as a previous transcription job, you get a <code>ConflictException</code> error.</p>"
2517        },
2518        "LanguageCode":{
2519          "shape":"LanguageCode",
2520          "documentation":"<p>The language code for the language used in the input media file.</p> <p>To transcribe speech in Modern Standard Arabic (ar-SA), your audio or video file must be encoded at a sample rate of 16,000 Hz or higher.</p>"
2521        },
2522        "MediaSampleRateHertz":{
2523          "shape":"MediaSampleRateHertz",
2524          "documentation":"<p>The sample rate, in Hertz, of the audio track in the input media file. </p> <p>If you do not specify the media sample rate, Amazon Transcribe determines the sample rate. If you specify the sample rate, it must match the sample rate detected by Amazon Transcribe. In most cases, you should leave the <code>MediaSampleRateHertz</code> field blank and let Amazon Transcribe determine the sample rate.</p>"
2525        },
2526        "MediaFormat":{
2527          "shape":"MediaFormat",
2528          "documentation":"<p>The format of the input media file.</p>"
2529        },
2530        "Media":{
2531          "shape":"Media",
2532          "documentation":"<p>An object that describes the input media for a transcription job.</p>"
2533        },
2534        "OutputBucketName":{
2535          "shape":"OutputBucketName",
2536          "documentation":"<p>The location where the transcription is stored.</p> <p>If you set the <code>OutputBucketName</code>, Amazon Transcribe puts the transcript in the specified S3 bucket. When you call the <a>GetTranscriptionJob</a> operation, the operation returns this location in the <code>TranscriptFileUri</code> field. If you enable content redaction, the redacted transcript appears in <code>RedactedTranscriptFileUri</code>. If you enable content redaction and choose to output an unredacted transcript, that transcript's location still appears in the <code>TranscriptFileUri</code>. The S3 bucket must have permissions that allow Amazon Transcribe to put files in the bucket. For more information, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/security_iam_id-based-policy-examples.html#auth-role-iam-user\">Permissions Required for IAM User Roles</a>.</p> <p>You can specify an Amazon Web Services Key Management Service (KMS) key to encrypt the output of your transcription using the <code>OutputEncryptionKMSKeyId</code> parameter. If you don't specify a KMS key, Amazon Transcribe uses the default Amazon S3 key for server-side encryption of transcripts that are placed in your S3 bucket.</p> <p>If you don't set the <code>OutputBucketName</code>, Amazon Transcribe generates a pre-signed URL, a shareable URL that provides secure access to your transcription, and returns it in the <code>TranscriptFileUri</code> field. Use this URL to download the transcription.</p>"
2537        },
2538        "OutputKey":{
2539          "shape":"OutputKey",
2540          "documentation":"<p>You can specify a location in an Amazon S3 bucket to store the output of your transcription job.</p> <p>If you don't specify an output key, Amazon Transcribe stores the output of your transcription job in the Amazon S3 bucket you specified. By default, the object key is \"your-transcription-job-name.json\".</p> <p>You can use output keys to specify the Amazon S3 prefix and file name of the transcription output. For example, specifying the Amazon S3 prefix, \"folder1/folder2/\", as an output key would lead to the output being stored as \"folder1/folder2/your-transcription-job-name.json\". If you specify \"my-other-job-name.json\" as the output key, the object key is changed to \"my-other-job-name.json\". You can use an output key to change both the prefix and the file name, for example \"folder/my-other-job-name.json\".</p> <p>If you specify an output key, you must also specify an S3 bucket in the <code>OutputBucketName</code> parameter.</p>"
2541        },
2542        "OutputEncryptionKMSKeyId":{
2543          "shape":"KMSKeyId",
2544          "documentation":"<p>The Amazon Resource Name (ARN) of the Amazon Web Services Key Management Service (KMS) key used to encrypt the output of the transcription job. The user calling the <code>StartTranscriptionJob</code> operation must have permission to use the specified KMS key.</p> <p>You can use either of the following to identify a KMS key in the current account:</p> <ul> <li> <p>KMS Key ID: \"1234abcd-12ab-34cd-56ef-1234567890ab\"</p> </li> <li> <p>KMS Key Alias: \"alias/ExampleAlias\"</p> </li> </ul> <p>You can use either of the following to identify a KMS key in the current account or another account:</p> <ul> <li> <p>Amazon Resource Name (ARN) of a KMS Key: \"arn:aws:kms:region:account ID:key/1234abcd-12ab-34cd-56ef-1234567890ab\"</p> </li> <li> <p>ARN of a KMS Key Alias: \"arn:aws:kms:region:account ID:alias/ExampleAlias\"</p> </li> </ul> <p>If you don't specify an encryption key, the output of the transcription job is encrypted with the default Amazon S3 key (SSE-S3).</p> <p>If you specify a KMS key to encrypt your output, you must also specify an output location in the <code>OutputBucketName</code> parameter.</p>"
2545        },
2546        "KMSEncryptionContext":{
2547          "shape":"KMSEncryptionContextMap",
2548          "documentation":"<p>A map of plain text, non-secret key:value pairs, known as encryption context pairs, that provide an added layer of security for your data.</p>"
2549        },
2550        "Settings":{
2551          "shape":"Settings",
2552          "documentation":"<p>A <code>Settings</code> object that provides optional settings for a transcription job.</p>"
2553        },
2554        "ModelSettings":{
2555          "shape":"ModelSettings",
2556          "documentation":"<p>Choose the custom language model you use for your transcription job in this parameter.</p>"
2557        },
2558        "JobExecutionSettings":{
2559          "shape":"JobExecutionSettings",
2560          "documentation":"<p>Provides information about how a transcription job is executed. Use this field to indicate that the job can be queued for deferred execution if the concurrency limit is reached and there are no slots available to immediately run the job.</p>"
2561        },
2562        "ContentRedaction":{
2563          "shape":"ContentRedaction",
2564          "documentation":"<p>An object that contains the request parameters for content redaction.</p>"
2565        },
2566        "IdentifyLanguage":{
2567          "shape":"Boolean",
2568          "documentation":"<p>Set this field to <code>true</code> to enable automatic language identification. Automatic language identification is disabled by default. You receive a <code>BadRequestException</code> error if you enter a value for a <code>LanguageCode</code>.</p>"
2569        },
2570        "LanguageOptions":{
2571          "shape":"LanguageOptions",
2572          "documentation":"<p>An object containing a list of languages that might be present in your collection of audio files. Automatic language identification chooses a language that best matches the source audio from that list.</p> <p>To transcribe speech in Modern Standard Arabic (ar-SA), your audio or video file must be encoded at a sample rate of 16,000 Hz or higher.</p>"
2573        },
2574        "Subtitles":{
2575          "shape":"Subtitles",
2576          "documentation":"<p>Add subtitles to your batch transcription job.</p>"
2577        },
2578        "Tags":{
2579          "shape":"TagList",
2580          "documentation":"<p>Add tags to an Amazon Transcribe transcription job.</p>"
2581        }
2582      }
2583    },
2584    "StartTranscriptionJobResponse":{
2585      "type":"structure",
2586      "members":{
2587        "TranscriptionJob":{
2588          "shape":"TranscriptionJob",
2589          "documentation":"<p>An object containing details of the asynchronous transcription job.</p>"
2590        }
2591      }
2592    },
2593    "String":{"type":"string"},
2594    "StringTargetList":{
2595      "type":"list",
2596      "member":{"shape":"NonEmptyString"},
2597      "min":1
2598    },
2599    "SubtitleFileUris":{
2600      "type":"list",
2601      "member":{"shape":"Uri"}
2602    },
2603    "SubtitleFormat":{
2604      "type":"string",
2605      "enum":[
2606        "vtt",
2607        "srt"
2608      ]
2609    },
2610    "SubtitleFormats":{
2611      "type":"list",
2612      "member":{"shape":"SubtitleFormat"}
2613    },
2614    "Subtitles":{
2615      "type":"structure",
2616      "members":{
2617        "Formats":{
2618          "shape":"SubtitleFormats",
2619          "documentation":"<p>Specify the output format for your subtitle file.</p>"
2620        }
2621      },
2622      "documentation":"<p>Generate subtitles for your batch transcription job.</p>"
2623    },
2624    "SubtitlesOutput":{
2625      "type":"structure",
2626      "members":{
2627        "Formats":{
2628          "shape":"SubtitleFormats",
2629          "documentation":"<p>Specify the output format for your subtitle file; if you select both SRT and VTT formats, two output files are genereated.</p>"
2630        },
2631        "SubtitleFileUris":{
2632          "shape":"SubtitleFileUris",
2633          "documentation":"<p>Choose the output location for your subtitle file. This location must be an S3 bucket.</p>"
2634        }
2635      },
2636      "documentation":"<p>Specify the output format for your subtitle file.</p>"
2637    },
2638    "Tag":{
2639      "type":"structure",
2640      "required":[
2641        "Key",
2642        "Value"
2643      ],
2644      "members":{
2645        "Key":{
2646          "shape":"TagKey",
2647          "documentation":"<p>The first part of a key:value pair that forms a tag associated with a given resource. For example, in the tag ‘Department’:’Sales’, the key is 'Department'.</p>"
2648        },
2649        "Value":{
2650          "shape":"TagValue",
2651          "documentation":"<p>The second part of a key:value pair that forms a tag associated with a given resource. For example, in the tag ‘Department’:’Sales’, the value is 'Sales'.</p>"
2652        }
2653      },
2654      "documentation":"<p>A key:value pair that adds metadata to a resource used by Amazon Transcribe. For example, a tag with the key:value pair ‘Department’:’Sales’ might be added to a resource to indicate its use by your organization's sales department.</p>"
2655    },
2656    "TagKey":{
2657      "type":"string",
2658      "max":128,
2659      "min":1
2660    },
2661    "TagKeyList":{
2662      "type":"list",
2663      "member":{"shape":"TagKey"},
2664      "max":200,
2665      "min":1
2666    },
2667    "TagList":{
2668      "type":"list",
2669      "member":{"shape":"Tag"},
2670      "max":200,
2671      "min":1
2672    },
2673    "TagResourceRequest":{
2674      "type":"structure",
2675      "required":[
2676        "ResourceArn",
2677        "Tags"
2678      ],
2679      "members":{
2680        "ResourceArn":{
2681          "shape":"TranscribeArn",
2682          "documentation":"<p>The Amazon Resource Name (ARN) of the Amazon Transcribe resource you want to tag.</p>"
2683        },
2684        "Tags":{
2685          "shape":"TagList",
2686          "documentation":"<p>The tags you are assigning to a given Amazon Transcribe resource.</p>"
2687        }
2688      }
2689    },
2690    "TagResourceResponse":{
2691      "type":"structure",
2692      "members":{
2693      }
2694    },
2695    "TagValue":{
2696      "type":"string",
2697      "max":256,
2698      "min":0
2699    },
2700    "TimestampMilliseconds":{
2701      "type":"long",
2702      "max":14400000,
2703      "min":0
2704    },
2705    "TranscribeArn":{
2706      "type":"string",
2707      "max":1011,
2708      "min":1,
2709      "pattern":"arn:aws(-[^:]+)?:transcribe:[a-zA-Z0-9-]*:[0-9]{12}:[a-zA-Z-]*/[0-9a-zA-Z._-]+"
2710    },
2711    "Transcript":{
2712      "type":"structure",
2713      "members":{
2714        "TranscriptFileUri":{
2715          "shape":"Uri",
2716          "documentation":"<p>The S3 object location of the transcript.</p> <p>Use this URI to access the transcript. If you specified an S3 bucket in the <code>OutputBucketName</code> field when you created the job, this is the URI of that bucket. If you chose to store the transcript in Amazon Transcribe, this is a shareable URL that provides secure access to that location.</p>"
2717        },
2718        "RedactedTranscriptFileUri":{
2719          "shape":"Uri",
2720          "documentation":"<p>The S3 object location of the redacted transcript.</p> <p>Use this URI to access the redacted transcript. If you specified an S3 bucket in the <code>OutputBucketName</code> field when you created the job, this is the URI of that bucket. If you chose to store the transcript in Amazon Transcribe, this is a shareable URL that provides secure access to that location.</p>"
2721        }
2722      },
2723      "documentation":"<p>Identifies the location of a transcription.</p>"
2724    },
2725    "TranscriptFilter":{
2726      "type":"structure",
2727      "required":[
2728        "TranscriptFilterType",
2729        "Targets"
2730      ],
2731      "members":{
2732        "TranscriptFilterType":{
2733          "shape":"TranscriptFilterType",
2734          "documentation":"<p>Matches the phrase to the transcription output in a word for word fashion. For example, if you specify the phrase \"I want to speak to the manager.\" Amazon Transcribe attempts to match that specific phrase to the transcription.</p>"
2735        },
2736        "AbsoluteTimeRange":{
2737          "shape":"AbsoluteTimeRange",
2738          "documentation":"<p>A time range, set in seconds, between two points in the call.</p>"
2739        },
2740        "RelativeTimeRange":{
2741          "shape":"RelativeTimeRange",
2742          "documentation":"<p>An object that allows percentages to specify the proportion of the call where you would like to apply a filter. For example, you can specify the first half of the call. You can also specify the period of time between halfway through to three-quarters of the way through the call. Because the length of conversation can vary between calls, you can apply relative time ranges across all calls.</p>"
2743        },
2744        "ParticipantRole":{
2745          "shape":"ParticipantRole",
2746          "documentation":"<p>Determines whether the customer or the agent is speaking the phrases that you've specified.</p>"
2747        },
2748        "Negate":{
2749          "shape":"Boolean",
2750          "documentation":"<p>If <code>TRUE</code>, the rule that you specify is applied to everything except for the phrases that you specify.</p>"
2751        },
2752        "Targets":{
2753          "shape":"StringTargetList",
2754          "documentation":"<p>The phrases that you're specifying for the transcript filter to match.</p>"
2755        }
2756      },
2757      "documentation":"<p>Matches the output of the transcription to either the specific phrases that you specify, or the intent of the phrases that you specify.</p>"
2758    },
2759    "TranscriptFilterType":{
2760      "type":"string",
2761      "enum":["EXACT"]
2762    },
2763    "TranscriptionJob":{
2764      "type":"structure",
2765      "members":{
2766        "TranscriptionJobName":{
2767          "shape":"TranscriptionJobName",
2768          "documentation":"<p>The name of the transcription job.</p>"
2769        },
2770        "TranscriptionJobStatus":{
2771          "shape":"TranscriptionJobStatus",
2772          "documentation":"<p>The status of the transcription job.</p>"
2773        },
2774        "LanguageCode":{
2775          "shape":"LanguageCode",
2776          "documentation":"<p>The language code for the input speech.</p>"
2777        },
2778        "MediaSampleRateHertz":{
2779          "shape":"MediaSampleRateHertz",
2780          "documentation":"<p>The sample rate, in Hertz, of the audio track in the input media file. </p>"
2781        },
2782        "MediaFormat":{
2783          "shape":"MediaFormat",
2784          "documentation":"<p>The format of the input media file.</p>"
2785        },
2786        "Media":{
2787          "shape":"Media",
2788          "documentation":"<p>An object that describes the input media for the transcription job.</p>"
2789        },
2790        "Transcript":{
2791          "shape":"Transcript",
2792          "documentation":"<p>An object that describes the output of the transcription job.</p>"
2793        },
2794        "StartTime":{
2795          "shape":"DateTime",
2796          "documentation":"<p>A timestamp that shows when the job started processing.</p>"
2797        },
2798        "CreationTime":{
2799          "shape":"DateTime",
2800          "documentation":"<p>A timestamp that shows when the job was created.</p>"
2801        },
2802        "CompletionTime":{
2803          "shape":"DateTime",
2804          "documentation":"<p>A timestamp that shows when the job completed.</p>"
2805        },
2806        "FailureReason":{
2807          "shape":"FailureReason",
2808          "documentation":"<p>If the <code>TranscriptionJobStatus</code> field is <code>FAILED</code>, this field contains information about why the job failed.</p> <p>The <code>FailureReason</code> field can contain one of the following values:</p> <ul> <li> <p> <code>Unsupported media format</code> - The media format specified in the <code>MediaFormat</code> field of the request isn't valid. See the description of the <code>MediaFormat</code> field for a list of valid values.</p> </li> <li> <p> <code>The media format provided does not match the detected media format</code> - The media format of the audio file doesn't match the format specified in the <code>MediaFormat</code> field in the request. Check the media format of your media file and make sure that the two values match.</p> </li> <li> <p> <code>Invalid sample rate for audio file</code> - The sample rate specified in the <code>MediaSampleRateHertz</code> of the request isn't valid. The sample rate must be between 8,000 and 48,000 Hertz.</p> </li> <li> <p> <code>The sample rate provided does not match the detected sample rate</code> - The sample rate in the audio file doesn't match the sample rate specified in the <code>MediaSampleRateHertz</code> field in the request. Check the sample rate of your media file and make sure that the two values match.</p> </li> <li> <p> <code>Invalid file size: file size too large</code> - The size of your audio file is larger than Amazon Transcribe can process. For more information, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/limits-guidelines.html#limits\">Limits</a> in the <i>Amazon Transcribe Developer Guide</i>.</p> </li> <li> <p> <code>Invalid number of channels: number of channels too large</code> - Your audio contains more channels than Amazon Transcribe is configured to process. To request additional channels, see <a href=\"https://docs.aws.amazon.com/general/latest/gr/aws_service_limits.html#limits-amazon-transcribe\">Amazon Transcribe Limits</a> in the <i>Amazon Web Services General Reference</i>.</p> </li> </ul>"
2809        },
2810        "Settings":{
2811          "shape":"Settings",
2812          "documentation":"<p>Optional settings for the transcription job. Use these settings to turn on speaker recognition, to set the maximum number of speakers that should be identified and to specify a custom vocabulary to use when processing the transcription job.</p>"
2813        },
2814        "ModelSettings":{
2815          "shape":"ModelSettings",
2816          "documentation":"<p>An object containing the details of your custom language model.</p>"
2817        },
2818        "JobExecutionSettings":{
2819          "shape":"JobExecutionSettings",
2820          "documentation":"<p>Provides information about how a transcription job is executed.</p>"
2821        },
2822        "ContentRedaction":{
2823          "shape":"ContentRedaction",
2824          "documentation":"<p>An object that describes content redaction settings for the transcription job.</p>"
2825        },
2826        "IdentifyLanguage":{
2827          "shape":"Boolean",
2828          "documentation":"<p>A value that shows if automatic language identification was enabled for a transcription job.</p>"
2829        },
2830        "LanguageOptions":{
2831          "shape":"LanguageOptions",
2832          "documentation":"<p>An object that shows the optional array of languages inputted for transcription jobs with automatic language identification enabled.</p>"
2833        },
2834        "IdentifiedLanguageScore":{
2835          "shape":"IdentifiedLanguageScore",
2836          "documentation":"<p>A value between zero and one that Amazon Transcribe assigned to the language that it identified in the source audio. Larger values indicate that Amazon Transcribe has higher confidence in the language it identified.</p>"
2837        },
2838        "Tags":{
2839          "shape":"TagList",
2840          "documentation":"<p>A key:value pair assigned to a given transcription job.</p>"
2841        },
2842        "Subtitles":{
2843          "shape":"SubtitlesOutput",
2844          "documentation":"<p>Generate subtitles for your batch transcription job.</p>"
2845        }
2846      },
2847      "documentation":"<p>Describes an asynchronous transcription job that was created with the <code>StartTranscriptionJob</code> operation. </p>"
2848    },
2849    "TranscriptionJobName":{
2850      "type":"string",
2851      "max":200,
2852      "min":1,
2853      "pattern":"^[0-9a-zA-Z._-]+"
2854    },
2855    "TranscriptionJobStatus":{
2856      "type":"string",
2857      "enum":[
2858        "QUEUED",
2859        "IN_PROGRESS",
2860        "FAILED",
2861        "COMPLETED"
2862      ]
2863    },
2864    "TranscriptionJobSummaries":{
2865      "type":"list",
2866      "member":{"shape":"TranscriptionJobSummary"}
2867    },
2868    "TranscriptionJobSummary":{
2869      "type":"structure",
2870      "members":{
2871        "TranscriptionJobName":{
2872          "shape":"TranscriptionJobName",
2873          "documentation":"<p>The name of the transcription job.</p>"
2874        },
2875        "CreationTime":{
2876          "shape":"DateTime",
2877          "documentation":"<p>A timestamp that shows when the job was created.</p>"
2878        },
2879        "StartTime":{
2880          "shape":"DateTime",
2881          "documentation":"<p>A timestamp that shows when the job started processing.</p>"
2882        },
2883        "CompletionTime":{
2884          "shape":"DateTime",
2885          "documentation":"<p>A timestamp that shows when the job was completed.</p>"
2886        },
2887        "LanguageCode":{
2888          "shape":"LanguageCode",
2889          "documentation":"<p>The language code for the input speech.</p>"
2890        },
2891        "TranscriptionJobStatus":{
2892          "shape":"TranscriptionJobStatus",
2893          "documentation":"<p>The status of the transcription job. When the status is <code>COMPLETED</code>, use the <code>GetTranscriptionJob</code> operation to get the results of the transcription.</p>"
2894        },
2895        "FailureReason":{
2896          "shape":"FailureReason",
2897          "documentation":"<p>If the <code>TranscriptionJobStatus</code> field is <code>FAILED</code>, a description of the error.</p>"
2898        },
2899        "OutputLocationType":{
2900          "shape":"OutputLocationType",
2901          "documentation":"<p>Indicates the location of the output of the transcription job.</p> <p>If the value is <code>CUSTOMER_BUCKET</code> then the location is the S3 bucket specified in the <code>outputBucketName</code> field when the transcription job was started with the <code>StartTranscriptionJob</code> operation.</p> <p>If the value is <code>SERVICE_BUCKET</code> then the output is stored by Amazon Transcribe and can be retrieved using the URI in the <code>GetTranscriptionJob</code> response's <code>TranscriptFileUri</code> field.</p>"
2902        },
2903        "ContentRedaction":{
2904          "shape":"ContentRedaction",
2905          "documentation":"<p>The content redaction settings of the transcription job.</p>"
2906        },
2907        "ModelSettings":{"shape":"ModelSettings"},
2908        "IdentifyLanguage":{
2909          "shape":"Boolean",
2910          "documentation":"<p>Whether automatic language identification was enabled for a transcription job.</p>"
2911        },
2912        "IdentifiedLanguageScore":{
2913          "shape":"IdentifiedLanguageScore",
2914          "documentation":"<p>A value between zero and one that Amazon Transcribe assigned to the language it identified in the source audio. A higher score indicates that Amazon Transcribe is more confident in the language it identified.</p>"
2915        }
2916      },
2917      "documentation":"<p>Provides a summary of information about a transcription job.</p>"
2918    },
2919    "Type":{
2920      "type":"string",
2921      "enum":[
2922        "CONVERSATION",
2923        "DICTATION"
2924      ]
2925    },
2926    "UntagResourceRequest":{
2927      "type":"structure",
2928      "required":[
2929        "ResourceArn",
2930        "TagKeys"
2931      ],
2932      "members":{
2933        "ResourceArn":{
2934          "shape":"TranscribeArn",
2935          "documentation":"<p>The Amazon Resource Name (ARN) of the Amazon Transcribe resource you want to remove tags from.</p>"
2936        },
2937        "TagKeys":{
2938          "shape":"TagKeyList",
2939          "documentation":"<p>A list of tag keys you want to remove from a specified Amazon Transcribe resource.</p>"
2940        }
2941      }
2942    },
2943    "UntagResourceResponse":{
2944      "type":"structure",
2945      "members":{
2946      }
2947    },
2948    "UpdateCallAnalyticsCategoryRequest":{
2949      "type":"structure",
2950      "required":[
2951        "CategoryName",
2952        "Rules"
2953      ],
2954      "members":{
2955        "CategoryName":{
2956          "shape":"CategoryName",
2957          "documentation":"<p>The name of the analytics category to update. The name is case sensitive. If you try to update a call analytics category with the same name as a previous category you will receive a <code>ConflictException</code> error.</p>"
2958        },
2959        "Rules":{
2960          "shape":"RuleList",
2961          "documentation":"<p>The rules used for the updated analytics category. The rules that you provide in this field replace the ones that are currently being used. </p>"
2962        }
2963      }
2964    },
2965    "UpdateCallAnalyticsCategoryResponse":{
2966      "type":"structure",
2967      "members":{
2968        "CategoryProperties":{
2969          "shape":"CategoryProperties",
2970          "documentation":"<p>The attributes describing the analytics category. You can see information such as the rules that you've used to update the category and when the category was originally created. </p>"
2971        }
2972      }
2973    },
2974    "UpdateMedicalVocabularyRequest":{
2975      "type":"structure",
2976      "required":[
2977        "VocabularyName",
2978        "LanguageCode"
2979      ],
2980      "members":{
2981        "VocabularyName":{
2982          "shape":"VocabularyName",
2983          "documentation":"<p>The name of the vocabulary to update. The name is case sensitive. If you try to update a vocabulary with the same name as a vocabulary you've already made, you get a <code>ConflictException</code> error.</p>"
2984        },
2985        "LanguageCode":{
2986          "shape":"LanguageCode",
2987          "documentation":"<p>The language code of the language used for the entries in the updated vocabulary. US English (en-US) is the only valid language code in Amazon Transcribe Medical.</p>"
2988        },
2989        "VocabularyFileUri":{
2990          "shape":"Uri",
2991          "documentation":"<p>The location in Amazon S3 of the text file that contains your custom vocabulary. The URI must be in the same Amazon Web Services Region as the resource that you are calling. The following is the format for a URI:</p> <p> <code> https://s3.&lt;aws-region&gt;.amazonaws.com/&lt;bucket-name&gt;/&lt;keyprefix&gt;/&lt;objectkey&gt; </code> </p> <p>For example:</p> <p> <code>https://s3.us-east-1.amazonaws.com/AWSDOC-EXAMPLE-BUCKET/vocab.txt</code> </p> <p>For more information about Amazon S3 object names, see <a href=\"https://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html#object-keys\">Object Keys</a> in the <i>Amazon S3 Developer Guide</i>.</p> <p>For more information about custom vocabularies in Amazon Transcribe Medical, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-it-works.html#how-vocabulary\">Medical Custom Vocabularies</a>.</p>"
2992        }
2993      }
2994    },
2995    "UpdateMedicalVocabularyResponse":{
2996      "type":"structure",
2997      "members":{
2998        "VocabularyName":{
2999          "shape":"VocabularyName",
3000          "documentation":"<p>The name of the updated vocabulary.</p>"
3001        },
3002        "LanguageCode":{
3003          "shape":"LanguageCode",
3004          "documentation":"<p>The language code for the language of the text file used to update the custom vocabulary. US English (en-US) is the only language supported in Amazon Transcribe Medical.</p>"
3005        },
3006        "LastModifiedTime":{
3007          "shape":"DateTime",
3008          "documentation":"<p>The date and time that the vocabulary was updated.</p>"
3009        },
3010        "VocabularyState":{
3011          "shape":"VocabularyState",
3012          "documentation":"<p>The processing state of the update to the vocabulary. When the <code>VocabularyState</code> field is <code>READY</code>, the vocabulary is ready to be used in a <code>StartMedicalTranscriptionJob</code> request.</p>"
3013        }
3014      }
3015    },
3016    "UpdateVocabularyFilterRequest":{
3017      "type":"structure",
3018      "required":["VocabularyFilterName"],
3019      "members":{
3020        "VocabularyFilterName":{
3021          "shape":"VocabularyFilterName",
3022          "documentation":"<p>The name of the vocabulary filter to update. If you try to update a vocabulary filter with the same name as another vocabulary filter, you get a <code>ConflictException</code> error.</p>"
3023        },
3024        "Words":{
3025          "shape":"Words",
3026          "documentation":"<p>The words to use in the vocabulary filter. Only use characters from the character set defined for custom vocabularies. For a list of character sets, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-vocabulary.html#charsets\">Character Sets for Custom Vocabularies</a>.</p> <p>If you provide a list of words in the <code>Words</code> parameter, you can't use the <code>VocabularyFilterFileUri</code> parameter.</p>"
3027        },
3028        "VocabularyFilterFileUri":{
3029          "shape":"Uri",
3030          "documentation":"<p>The Amazon S3 location of a text file used as input to create the vocabulary filter. Only use characters from the character set defined for custom vocabularies. For a list of character sets, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-vocabulary.html#charsets\">Character Sets for Custom Vocabularies</a>.</p> <p>The specified file must be less than 50 KB of UTF-8 characters.</p> <p>If you provide the location of a list of words in the <code>VocabularyFilterFileUri</code> parameter, you can't use the <code>Words</code> parameter.</p>"
3031        }
3032      }
3033    },
3034    "UpdateVocabularyFilterResponse":{
3035      "type":"structure",
3036      "members":{
3037        "VocabularyFilterName":{
3038          "shape":"VocabularyFilterName",
3039          "documentation":"<p>The name of the updated vocabulary filter.</p>"
3040        },
3041        "LanguageCode":{
3042          "shape":"LanguageCode",
3043          "documentation":"<p>The language code of the words in the vocabulary filter.</p>"
3044        },
3045        "LastModifiedTime":{
3046          "shape":"DateTime",
3047          "documentation":"<p>The date and time that the vocabulary filter was updated.</p>"
3048        }
3049      }
3050    },
3051    "UpdateVocabularyRequest":{
3052      "type":"structure",
3053      "required":[
3054        "VocabularyName",
3055        "LanguageCode"
3056      ],
3057      "members":{
3058        "VocabularyName":{
3059          "shape":"VocabularyName",
3060          "documentation":"<p>The name of the vocabulary to update. The name is case sensitive. If you try to update a vocabulary with the same name as a previous vocabulary you will receive a <code>ConflictException</code> error.</p>"
3061        },
3062        "LanguageCode":{
3063          "shape":"LanguageCode",
3064          "documentation":"<p>The language code of the vocabulary entries. For a list of languages and their corresponding language codes, see <a>transcribe-whatis</a>.</p>"
3065        },
3066        "Phrases":{
3067          "shape":"Phrases",
3068          "documentation":"<p>An array of strings containing the vocabulary entries.</p>"
3069        },
3070        "VocabularyFileUri":{
3071          "shape":"Uri",
3072          "documentation":"<p>The S3 location of the text file that contains the definition of the custom vocabulary. The URI must be in the same region as the API endpoint that you are calling. The general form is </p> <p>For example:</p> <p>For more information about S3 object names, see <a href=\"https://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html#object-keys\">Object Keys</a> in the <i>Amazon S3 Developer Guide</i>.</p> <p>For more information about custom vocabularies, see <a href=\"https://docs.aws.amazon.com/transcribe/latest/dg/how-it-works.html#how-vocabulary\">Custom Vocabularies</a>.</p>"
3073        }
3074      }
3075    },
3076    "UpdateVocabularyResponse":{
3077      "type":"structure",
3078      "members":{
3079        "VocabularyName":{
3080          "shape":"VocabularyName",
3081          "documentation":"<p>The name of the vocabulary that was updated.</p>"
3082        },
3083        "LanguageCode":{
3084          "shape":"LanguageCode",
3085          "documentation":"<p>The language code of the vocabulary entries.</p>"
3086        },
3087        "LastModifiedTime":{
3088          "shape":"DateTime",
3089          "documentation":"<p>The date and time that the vocabulary was updated.</p>"
3090        },
3091        "VocabularyState":{
3092          "shape":"VocabularyState",
3093          "documentation":"<p>The processing state of the vocabulary. When the <code>VocabularyState</code> field contains <code>READY</code> the vocabulary is ready to be used in a <code>StartTranscriptionJob</code> request.</p>"
3094        }
3095      }
3096    },
3097    "Uri":{
3098      "type":"string",
3099      "max":2000,
3100      "min":1,
3101      "pattern":"(s3://|http(s*)://).+"
3102    },
3103    "Vocabularies":{
3104      "type":"list",
3105      "member":{"shape":"VocabularyInfo"}
3106    },
3107    "VocabularyFilterInfo":{
3108      "type":"structure",
3109      "members":{
3110        "VocabularyFilterName":{
3111          "shape":"VocabularyFilterName",
3112          "documentation":"<p>The name of the vocabulary filter. The name must be unique in the account that holds the filter.</p>"
3113        },
3114        "LanguageCode":{
3115          "shape":"LanguageCode",
3116          "documentation":"<p>The language code of the words in the vocabulary filter.</p>"
3117        },
3118        "LastModifiedTime":{
3119          "shape":"DateTime",
3120          "documentation":"<p>The date and time that the vocabulary was last updated.</p>"
3121        }
3122      },
3123      "documentation":"<p>Provides information about a vocabulary filter.</p>"
3124    },
3125    "VocabularyFilterMethod":{
3126      "type":"string",
3127      "enum":[
3128        "remove",
3129        "mask",
3130        "tag"
3131      ]
3132    },
3133    "VocabularyFilterName":{
3134      "type":"string",
3135      "max":200,
3136      "min":1,
3137      "pattern":"^[0-9a-zA-Z._-]+"
3138    },
3139    "VocabularyFilters":{
3140      "type":"list",
3141      "member":{"shape":"VocabularyFilterInfo"}
3142    },
3143    "VocabularyInfo":{
3144      "type":"structure",
3145      "members":{
3146        "VocabularyName":{
3147          "shape":"VocabularyName",
3148          "documentation":"<p>The name of the vocabulary.</p>"
3149        },
3150        "LanguageCode":{
3151          "shape":"LanguageCode",
3152          "documentation":"<p>The language code of the vocabulary entries.</p>"
3153        },
3154        "LastModifiedTime":{
3155          "shape":"DateTime",
3156          "documentation":"<p>The date and time that the vocabulary was last modified.</p>"
3157        },
3158        "VocabularyState":{
3159          "shape":"VocabularyState",
3160          "documentation":"<p>The processing state of the vocabulary. If the state is <code>READY</code> you can use the vocabulary in a <code>StartTranscriptionJob</code> request.</p>"
3161        }
3162      },
3163      "documentation":"<p>Provides information about a custom vocabulary. </p>"
3164    },
3165    "VocabularyName":{
3166      "type":"string",
3167      "max":200,
3168      "min":1,
3169      "pattern":"^[0-9a-zA-Z._-]+"
3170    },
3171    "VocabularyState":{
3172      "type":"string",
3173      "enum":[
3174        "PENDING",
3175        "READY",
3176        "FAILED"
3177      ]
3178    },
3179    "Word":{
3180      "type":"string",
3181      "max":256,
3182      "min":1
3183    },
3184    "Words":{
3185      "type":"list",
3186      "member":{"shape":"Word"},
3187      "min":1
3188    }
3189  },
3190  "documentation":"<p>Operations and objects for transcribing speech to text.</p>"
3191}
3192