1{
2  "version":"2.0",
3  "metadata":{
4    "apiVersion":"2021-09-27",
5    "endpointPrefix":"voiceid",
6    "jsonVersion":"1.0",
7    "protocol":"json",
8    "serviceFullName":"Amazon Voice ID",
9    "serviceId":"Voice ID",
10    "signatureVersion":"v4",
11    "signingName":"voiceid",
12    "targetPrefix":"VoiceID",
13    "uid":"voice-id-2021-09-27"
14  },
15  "operations":{
16    "AssociateFraudster":{
17      "name":"AssociateFraudster",
18      "http":{
19        "method":"POST",
20        "requestUri":"/"
21      },
22      "input":{"shape":"AssociateFraudsterRequest"},
23      "output":{"shape":"AssociateFraudsterResponse"},
24      "errors":[
25        {"shape":"ServiceQuotaExceededException"},
26        {"shape":"ResourceNotFoundException"},
27        {"shape":"ValidationException"},
28        {"shape":"ConflictException"},
29        {"shape":"InternalServerException"},
30        {"shape":"ThrottlingException"},
31        {"shape":"AccessDeniedException"}
32      ],
33      "documentation":"<p>Associates the fraudsters with the watchlist specified in the same domain. </p>"
34    },
35    "CreateDomain":{
36      "name":"CreateDomain",
37      "http":{
38        "method":"POST",
39        "requestUri":"/"
40      },
41      "input":{"shape":"CreateDomainRequest"},
42      "output":{"shape":"CreateDomainResponse"},
43      "errors":[
44        {"shape":"ServiceQuotaExceededException"},
45        {"shape":"ResourceNotFoundException"},
46        {"shape":"ValidationException"},
47        {"shape":"ConflictException"},
48        {"shape":"InternalServerException"},
49        {"shape":"ThrottlingException"},
50        {"shape":"AccessDeniedException"}
51      ],
52      "documentation":"<p>Creates a domain that contains all Amazon Connect Voice ID data, such as speakers, fraudsters, customer audio, and voiceprints. Every domain is created with a default watchlist that fraudsters can be a part of.</p>",
53      "idempotent":true
54    },
55    "CreateWatchlist":{
56      "name":"CreateWatchlist",
57      "http":{
58        "method":"POST",
59        "requestUri":"/"
60      },
61      "input":{"shape":"CreateWatchlistRequest"},
62      "output":{"shape":"CreateWatchlistResponse"},
63      "errors":[
64        {"shape":"ServiceQuotaExceededException"},
65        {"shape":"ResourceNotFoundException"},
66        {"shape":"ValidationException"},
67        {"shape":"ConflictException"},
68        {"shape":"InternalServerException"},
69        {"shape":"ThrottlingException"},
70        {"shape":"AccessDeniedException"}
71      ],
72      "documentation":"<p>Creates a watchlist that fraudsters can be a part of.</p>",
73      "idempotent":true
74    },
75    "DeleteDomain":{
76      "name":"DeleteDomain",
77      "http":{
78        "method":"POST",
79        "requestUri":"/"
80      },
81      "input":{"shape":"DeleteDomainRequest"},
82      "errors":[
83        {"shape":"ResourceNotFoundException"},
84        {"shape":"ValidationException"},
85        {"shape":"ConflictException"},
86        {"shape":"InternalServerException"},
87        {"shape":"ThrottlingException"},
88        {"shape":"AccessDeniedException"}
89      ],
90      "documentation":"<p>Deletes the specified domain from Voice ID.</p>",
91      "idempotent":true
92    },
93    "DeleteFraudster":{
94      "name":"DeleteFraudster",
95      "http":{
96        "method":"POST",
97        "requestUri":"/"
98      },
99      "input":{"shape":"DeleteFraudsterRequest"},
100      "errors":[
101        {"shape":"ResourceNotFoundException"},
102        {"shape":"ValidationException"},
103        {"shape":"ConflictException"},
104        {"shape":"InternalServerException"},
105        {"shape":"ThrottlingException"},
106        {"shape":"AccessDeniedException"}
107      ],
108      "documentation":"<p>Deletes the specified fraudster from Voice ID. This action disassociates the fraudster from any watchlists it is a part of.</p>"
109    },
110    "DeleteSpeaker":{
111      "name":"DeleteSpeaker",
112      "http":{
113        "method":"POST",
114        "requestUri":"/"
115      },
116      "input":{"shape":"DeleteSpeakerRequest"},
117      "errors":[
118        {"shape":"ResourceNotFoundException"},
119        {"shape":"ValidationException"},
120        {"shape":"ConflictException"},
121        {"shape":"InternalServerException"},
122        {"shape":"ThrottlingException"},
123        {"shape":"AccessDeniedException"}
124      ],
125      "documentation":"<p>Deletes the specified speaker from Voice ID.</p>"
126    },
127    "DeleteWatchlist":{
128      "name":"DeleteWatchlist",
129      "http":{
130        "method":"POST",
131        "requestUri":"/"
132      },
133      "input":{"shape":"DeleteWatchlistRequest"},
134      "errors":[
135        {"shape":"ResourceNotFoundException"},
136        {"shape":"ValidationException"},
137        {"shape":"ConflictException"},
138        {"shape":"InternalServerException"},
139        {"shape":"ThrottlingException"},
140        {"shape":"AccessDeniedException"}
141      ],
142      "documentation":"<p>Deletes the specified watchlist from Voice ID. This API throws an exception when there are fraudsters in the watchlist that you are trying to delete. You must delete the fraudsters, and then delete the watchlist. Every domain has a default watchlist which cannot be deleted. </p>"
143    },
144    "DescribeDomain":{
145      "name":"DescribeDomain",
146      "http":{
147        "method":"POST",
148        "requestUri":"/"
149      },
150      "input":{"shape":"DescribeDomainRequest"},
151      "output":{"shape":"DescribeDomainResponse"},
152      "errors":[
153        {"shape":"ResourceNotFoundException"},
154        {"shape":"ValidationException"},
155        {"shape":"InternalServerException"},
156        {"shape":"ThrottlingException"},
157        {"shape":"AccessDeniedException"}
158      ],
159      "documentation":"<p>Describes the specified domain.</p>"
160    },
161    "DescribeFraudster":{
162      "name":"DescribeFraudster",
163      "http":{
164        "method":"POST",
165        "requestUri":"/"
166      },
167      "input":{"shape":"DescribeFraudsterRequest"},
168      "output":{"shape":"DescribeFraudsterResponse"},
169      "errors":[
170        {"shape":"ResourceNotFoundException"},
171        {"shape":"ValidationException"},
172        {"shape":"InternalServerException"},
173        {"shape":"ThrottlingException"},
174        {"shape":"AccessDeniedException"}
175      ],
176      "documentation":"<p>Describes the specified fraudster.</p>"
177    },
178    "DescribeFraudsterRegistrationJob":{
179      "name":"DescribeFraudsterRegistrationJob",
180      "http":{
181        "method":"POST",
182        "requestUri":"/"
183      },
184      "input":{"shape":"DescribeFraudsterRegistrationJobRequest"},
185      "output":{"shape":"DescribeFraudsterRegistrationJobResponse"},
186      "errors":[
187        {"shape":"ResourceNotFoundException"},
188        {"shape":"ValidationException"},
189        {"shape":"InternalServerException"},
190        {"shape":"ThrottlingException"},
191        {"shape":"AccessDeniedException"}
192      ],
193      "documentation":"<p>Describes the specified fraudster registration job.</p>"
194    },
195    "DescribeSpeaker":{
196      "name":"DescribeSpeaker",
197      "http":{
198        "method":"POST",
199        "requestUri":"/"
200      },
201      "input":{"shape":"DescribeSpeakerRequest"},
202      "output":{"shape":"DescribeSpeakerResponse"},
203      "errors":[
204        {"shape":"ResourceNotFoundException"},
205        {"shape":"ValidationException"},
206        {"shape":"InternalServerException"},
207        {"shape":"ThrottlingException"},
208        {"shape":"AccessDeniedException"}
209      ],
210      "documentation":"<p>Describes the specified speaker.</p>"
211    },
212    "DescribeSpeakerEnrollmentJob":{
213      "name":"DescribeSpeakerEnrollmentJob",
214      "http":{
215        "method":"POST",
216        "requestUri":"/"
217      },
218      "input":{"shape":"DescribeSpeakerEnrollmentJobRequest"},
219      "output":{"shape":"DescribeSpeakerEnrollmentJobResponse"},
220      "errors":[
221        {"shape":"ResourceNotFoundException"},
222        {"shape":"ValidationException"},
223        {"shape":"InternalServerException"},
224        {"shape":"ThrottlingException"},
225        {"shape":"AccessDeniedException"}
226      ],
227      "documentation":"<p>Describes the specified speaker enrollment job.</p>"
228    },
229    "DescribeWatchlist":{
230      "name":"DescribeWatchlist",
231      "http":{
232        "method":"POST",
233        "requestUri":"/"
234      },
235      "input":{"shape":"DescribeWatchlistRequest"},
236      "output":{"shape":"DescribeWatchlistResponse"},
237      "errors":[
238        {"shape":"ResourceNotFoundException"},
239        {"shape":"ValidationException"},
240        {"shape":"InternalServerException"},
241        {"shape":"ThrottlingException"},
242        {"shape":"AccessDeniedException"}
243      ],
244      "documentation":"<p>Describes the specified watchlist.</p>"
245    },
246    "DisassociateFraudster":{
247      "name":"DisassociateFraudster",
248      "http":{
249        "method":"POST",
250        "requestUri":"/"
251      },
252      "input":{"shape":"DisassociateFraudsterRequest"},
253      "output":{"shape":"DisassociateFraudsterResponse"},
254      "errors":[
255        {"shape":"ResourceNotFoundException"},
256        {"shape":"ValidationException"},
257        {"shape":"ConflictException"},
258        {"shape":"InternalServerException"},
259        {"shape":"ThrottlingException"},
260        {"shape":"AccessDeniedException"}
261      ],
262      "documentation":"<p>Disassociates the fraudsters from the watchlist specified. Voice ID always expects a fraudster to be a part of at least one watchlist. If you try to disassociate a fraudster from its only watchlist, a <code>ValidationException</code> is thrown. </p>"
263    },
264    "EvaluateSession":{
265      "name":"EvaluateSession",
266      "http":{
267        "method":"POST",
268        "requestUri":"/"
269      },
270      "input":{"shape":"EvaluateSessionRequest"},
271      "output":{"shape":"EvaluateSessionResponse"},
272      "errors":[
273        {"shape":"ResourceNotFoundException"},
274        {"shape":"ValidationException"},
275        {"shape":"ConflictException"},
276        {"shape":"InternalServerException"},
277        {"shape":"ThrottlingException"},
278        {"shape":"AccessDeniedException"}
279      ],
280      "documentation":"<p>Evaluates a specified session based on audio data accumulated during a streaming Amazon Connect Voice ID call.</p>"
281    },
282    "ListDomains":{
283      "name":"ListDomains",
284      "http":{
285        "method":"POST",
286        "requestUri":"/"
287      },
288      "input":{"shape":"ListDomainsRequest"},
289      "output":{"shape":"ListDomainsResponse"},
290      "errors":[
291        {"shape":"ValidationException"},
292        {"shape":"InternalServerException"},
293        {"shape":"ThrottlingException"},
294        {"shape":"AccessDeniedException"}
295      ],
296      "documentation":"<p>Lists all the domains in the Amazon Web Services account. </p>"
297    },
298    "ListFraudsterRegistrationJobs":{
299      "name":"ListFraudsterRegistrationJobs",
300      "http":{
301        "method":"POST",
302        "requestUri":"/"
303      },
304      "input":{"shape":"ListFraudsterRegistrationJobsRequest"},
305      "output":{"shape":"ListFraudsterRegistrationJobsResponse"},
306      "errors":[
307        {"shape":"ResourceNotFoundException"},
308        {"shape":"ValidationException"},
309        {"shape":"InternalServerException"},
310        {"shape":"ThrottlingException"},
311        {"shape":"AccessDeniedException"}
312      ],
313      "documentation":"<p>Lists all the fraudster registration jobs in the domain with the given <code>JobStatus</code>. If <code>JobStatus</code> is not provided, this lists all fraudster registration jobs in the given domain. </p>"
314    },
315    "ListFraudsters":{
316      "name":"ListFraudsters",
317      "http":{
318        "method":"POST",
319        "requestUri":"/"
320      },
321      "input":{"shape":"ListFraudstersRequest"},
322      "output":{"shape":"ListFraudstersResponse"},
323      "errors":[
324        {"shape":"ResourceNotFoundException"},
325        {"shape":"ValidationException"},
326        {"shape":"InternalServerException"},
327        {"shape":"ThrottlingException"},
328        {"shape":"AccessDeniedException"}
329      ],
330      "documentation":"<p>Lists all fraudsters in a specified watchlist or domain.</p>"
331    },
332    "ListSpeakerEnrollmentJobs":{
333      "name":"ListSpeakerEnrollmentJobs",
334      "http":{
335        "method":"POST",
336        "requestUri":"/"
337      },
338      "input":{"shape":"ListSpeakerEnrollmentJobsRequest"},
339      "output":{"shape":"ListSpeakerEnrollmentJobsResponse"},
340      "errors":[
341        {"shape":"ResourceNotFoundException"},
342        {"shape":"ValidationException"},
343        {"shape":"InternalServerException"},
344        {"shape":"ThrottlingException"},
345        {"shape":"AccessDeniedException"}
346      ],
347      "documentation":"<p>Lists all the speaker enrollment jobs in the domain with the specified <code>JobStatus</code>. If <code>JobStatus</code> is not provided, this lists all jobs with all possible speaker enrollment job statuses.</p>"
348    },
349    "ListSpeakers":{
350      "name":"ListSpeakers",
351      "http":{
352        "method":"POST",
353        "requestUri":"/"
354      },
355      "input":{"shape":"ListSpeakersRequest"},
356      "output":{"shape":"ListSpeakersResponse"},
357      "errors":[
358        {"shape":"ResourceNotFoundException"},
359        {"shape":"ValidationException"},
360        {"shape":"InternalServerException"},
361        {"shape":"ThrottlingException"},
362        {"shape":"AccessDeniedException"}
363      ],
364      "documentation":"<p>Lists all speakers in a specified domain.</p>"
365    },
366    "ListTagsForResource":{
367      "name":"ListTagsForResource",
368      "http":{
369        "method":"POST",
370        "requestUri":"/"
371      },
372      "input":{"shape":"ListTagsForResourceRequest"},
373      "output":{"shape":"ListTagsForResourceResponse"},
374      "errors":[
375        {"shape":"ResourceNotFoundException"},
376        {"shape":"ValidationException"},
377        {"shape":"InternalServerException"},
378        {"shape":"ThrottlingException"},
379        {"shape":"AccessDeniedException"}
380      ],
381      "documentation":"<p>Lists all tags associated with a specified Voice ID resource.</p>"
382    },
383    "ListWatchlists":{
384      "name":"ListWatchlists",
385      "http":{
386        "method":"POST",
387        "requestUri":"/"
388      },
389      "input":{"shape":"ListWatchlistsRequest"},
390      "output":{"shape":"ListWatchlistsResponse"},
391      "errors":[
392        {"shape":"ResourceNotFoundException"},
393        {"shape":"ValidationException"},
394        {"shape":"InternalServerException"},
395        {"shape":"ThrottlingException"},
396        {"shape":"AccessDeniedException"}
397      ],
398      "documentation":"<p>Lists all watchlists in a specified domain.</p>"
399    },
400    "OptOutSpeaker":{
401      "name":"OptOutSpeaker",
402      "http":{
403        "method":"POST",
404        "requestUri":"/"
405      },
406      "input":{"shape":"OptOutSpeakerRequest"},
407      "output":{"shape":"OptOutSpeakerResponse"},
408      "errors":[
409        {"shape":"ServiceQuotaExceededException"},
410        {"shape":"ResourceNotFoundException"},
411        {"shape":"ValidationException"},
412        {"shape":"ConflictException"},
413        {"shape":"InternalServerException"},
414        {"shape":"ThrottlingException"},
415        {"shape":"AccessDeniedException"}
416      ],
417      "documentation":"<p>Opts out a speaker from Voice ID. A speaker can be opted out regardless of whether or not they already exist in Voice ID. If they don't yet exist, a new speaker is created in an opted out state. If they already exist, their existing status is overridden and they are opted out. Enrollment and evaluation authentication requests are rejected for opted out speakers, and opted out speakers have no voice embeddings stored in Voice ID.</p>"
418    },
419    "StartFraudsterRegistrationJob":{
420      "name":"StartFraudsterRegistrationJob",
421      "http":{
422        "method":"POST",
423        "requestUri":"/"
424      },
425      "input":{"shape":"StartFraudsterRegistrationJobRequest"},
426      "output":{"shape":"StartFraudsterRegistrationJobResponse"},
427      "errors":[
428        {"shape":"ServiceQuotaExceededException"},
429        {"shape":"ResourceNotFoundException"},
430        {"shape":"ValidationException"},
431        {"shape":"ConflictException"},
432        {"shape":"InternalServerException"},
433        {"shape":"ThrottlingException"},
434        {"shape":"AccessDeniedException"}
435      ],
436      "documentation":"<p>Starts a new batch fraudster registration job using provided details.</p>",
437      "idempotent":true
438    },
439    "StartSpeakerEnrollmentJob":{
440      "name":"StartSpeakerEnrollmentJob",
441      "http":{
442        "method":"POST",
443        "requestUri":"/"
444      },
445      "input":{"shape":"StartSpeakerEnrollmentJobRequest"},
446      "output":{"shape":"StartSpeakerEnrollmentJobResponse"},
447      "errors":[
448        {"shape":"ServiceQuotaExceededException"},
449        {"shape":"ResourceNotFoundException"},
450        {"shape":"ValidationException"},
451        {"shape":"ConflictException"},
452        {"shape":"InternalServerException"},
453        {"shape":"ThrottlingException"},
454        {"shape":"AccessDeniedException"}
455      ],
456      "documentation":"<p>Starts a new batch speaker enrollment job using specified details.</p>",
457      "idempotent":true
458    },
459    "TagResource":{
460      "name":"TagResource",
461      "http":{
462        "method":"POST",
463        "requestUri":"/"
464      },
465      "input":{"shape":"TagResourceRequest"},
466      "output":{"shape":"TagResourceResponse"},
467      "errors":[
468        {"shape":"ResourceNotFoundException"},
469        {"shape":"ValidationException"},
470        {"shape":"ConflictException"},
471        {"shape":"InternalServerException"},
472        {"shape":"ThrottlingException"},
473        {"shape":"AccessDeniedException"}
474      ],
475      "documentation":"<p>Tags a Voice ID resource with the provided list of tags.</p>"
476    },
477    "UntagResource":{
478      "name":"UntagResource",
479      "http":{
480        "method":"POST",
481        "requestUri":"/"
482      },
483      "input":{"shape":"UntagResourceRequest"},
484      "output":{"shape":"UntagResourceResponse"},
485      "errors":[
486        {"shape":"ResourceNotFoundException"},
487        {"shape":"ValidationException"},
488        {"shape":"ConflictException"},
489        {"shape":"InternalServerException"},
490        {"shape":"ThrottlingException"},
491        {"shape":"AccessDeniedException"}
492      ],
493      "documentation":"<p>Removes specified tags from a specified Amazon Connect Voice ID resource.</p>"
494    },
495    "UpdateDomain":{
496      "name":"UpdateDomain",
497      "http":{
498        "method":"POST",
499        "requestUri":"/"
500      },
501      "input":{"shape":"UpdateDomainRequest"},
502      "output":{"shape":"UpdateDomainResponse"},
503      "errors":[
504        {"shape":"ResourceNotFoundException"},
505        {"shape":"ValidationException"},
506        {"shape":"ConflictException"},
507        {"shape":"InternalServerException"},
508        {"shape":"ThrottlingException"},
509        {"shape":"AccessDeniedException"}
510      ],
511      "documentation":"<p>Updates the specified domain. This API has clobber behavior, and clears and replaces all attributes. If an optional field, such as 'Description' is not provided, it is removed from the domain.</p>"
512    },
513    "UpdateWatchlist":{
514      "name":"UpdateWatchlist",
515      "http":{
516        "method":"POST",
517        "requestUri":"/"
518      },
519      "input":{"shape":"UpdateWatchlistRequest"},
520      "output":{"shape":"UpdateWatchlistResponse"},
521      "errors":[
522        {"shape":"ResourceNotFoundException"},
523        {"shape":"ValidationException"},
524        {"shape":"ConflictException"},
525        {"shape":"InternalServerException"},
526        {"shape":"ThrottlingException"},
527        {"shape":"AccessDeniedException"}
528      ],
529      "documentation":"<p>Updates the specified watchlist. Every domain has a default watchlist which cannot be updated. </p>"
530    }
531  },
532  "shapes":{
533    "AccessDeniedException":{
534      "type":"structure",
535      "members":{
536        "Message":{"shape":"String"}
537      },
538      "documentation":"<p>You do not have sufficient permissions to perform this action. Check the error message and try again.</p>",
539      "exception":true
540    },
541    "AmazonResourceName":{
542      "type":"string",
543      "max":1011,
544      "min":1,
545      "pattern":"^arn:aws(-[^:]+)?:voiceid.+:[0-9]{12}:domain/[a-zA-Z0-9]{22}$"
546    },
547    "Arn":{
548      "type":"string",
549      "pattern":"^arn:aws(-[^:]+)?:voiceid.+:[0-9]{12}:domain/[a-zA-Z0-9]{22}$"
550    },
551    "AssociateFraudsterRequest":{
552      "type":"structure",
553      "required":[
554        "DomainId",
555        "FraudsterId",
556        "WatchlistId"
557      ],
558      "members":{
559        "DomainId":{
560          "shape":"DomainId",
561          "documentation":"<p>The identifier of the domain that contains the fraudster.</p>"
562        },
563        "FraudsterId":{
564          "shape":"FraudsterId",
565          "documentation":"<p>The identifier of the fraudster to be associated with the watchlist.</p>"
566        },
567        "WatchlistId":{
568          "shape":"WatchlistId",
569          "documentation":"<p>The identifier of the watchlist you want to associate with the fraudster.</p>"
570        }
571      }
572    },
573    "AssociateFraudsterResponse":{
574      "type":"structure",
575      "members":{
576        "Fraudster":{"shape":"Fraudster"}
577      }
578    },
579    "AuthenticationConfiguration":{
580      "type":"structure",
581      "required":["AcceptanceThreshold"],
582      "members":{
583        "AcceptanceThreshold":{
584          "shape":"Score",
585          "documentation":"<p>The minimum threshold needed to successfully authenticate a speaker.</p>"
586        }
587      },
588      "documentation":"<p>The configuration used to authenticate a speaker during a session.</p>"
589    },
590    "AuthenticationDecision":{
591      "type":"string",
592      "enum":[
593        "ACCEPT",
594        "REJECT",
595        "NOT_ENOUGH_SPEECH",
596        "SPEAKER_NOT_ENROLLED",
597        "SPEAKER_OPTED_OUT",
598        "SPEAKER_ID_NOT_PROVIDED",
599        "SPEAKER_EXPIRED"
600      ]
601    },
602    "AuthenticationResult":{
603      "type":"structure",
604      "members":{
605        "AudioAggregationEndedAt":{
606          "shape":"Timestamp",
607          "documentation":"<p>A timestamp of when audio aggregation ended for this authentication result.</p>"
608        },
609        "AudioAggregationStartedAt":{
610          "shape":"Timestamp",
611          "documentation":"<p>A timestamp of when audio aggregation started for this authentication result.</p>"
612        },
613        "AuthenticationResultId":{
614          "shape":"UniqueIdLarge",
615          "documentation":"<p>The unique identifier for this authentication result. Because there can be multiple authentications for a given session, this field helps to identify if the returned result is from a previous streaming activity or a new result. Note that in absence of any new streaming activity, <code>AcceptanceThreshold</code> changes, or <code>SpeakerId</code> changes, Voice ID always returns cached Authentication Result for this API.</p>"
616        },
617        "Configuration":{
618          "shape":"AuthenticationConfiguration",
619          "documentation":"<p>The <code>AuthenticationConfiguration</code> used to generate this authentication result.</p>"
620        },
621        "CustomerSpeakerId":{
622          "shape":"CustomerSpeakerId",
623          "documentation":"<p>The client-provided identifier for the speaker whose authentication result is produced. Only present if a <code>SpeakerId</code> is provided for the session.</p>"
624        },
625        "Decision":{
626          "shape":"AuthenticationDecision",
627          "documentation":"<p>The authentication decision produced by Voice ID, processed against the current session state and streamed audio of the speaker.</p>"
628        },
629        "GeneratedSpeakerId":{
630          "shape":"GeneratedSpeakerId",
631          "documentation":"<p>The service-generated identifier for the speaker whose authentication result is produced.</p>"
632        },
633        "Score":{
634          "shape":"Score",
635          "documentation":"<p>The authentication score for the speaker whose authentication result is produced. This value is only present if the authentication decision is either <code>ACCEPT</code> or <code>REJECT</code>.</p>"
636        }
637      },
638      "documentation":"<p>The authentication result produced by Voice ID, processed against the current session state and streamed audio of the speaker.</p>"
639    },
640    "Boolean":{"type":"boolean"},
641    "ClientTokenString":{
642      "type":"string",
643      "max":64,
644      "min":1,
645      "pattern":"^[a-zA-Z0-9-_]+$"
646    },
647    "ConflictException":{
648      "type":"structure",
649      "members":{
650        "ConflictType":{
651          "shape":"ConflictType",
652          "documentation":"<p>The type of conflict which caused a ConflictException. Possible types and the corresponding error messages are as follows:</p> <ul> <li> <p> <code>DOMAIN_NOT_ACTIVE</code>: The domain is not active.</p> </li> <li> <p> <code>CANNOT_CHANGE_SPEAKER_AFTER_ENROLLMENT</code>: You cannot change the speaker ID after an enrollment has been requested.</p> </li> <li> <p> <code>ENROLLMENT_ALREADY_EXISTS</code>: There is already an enrollment for this session.</p> </li> <li> <p> <code>SPEAKER_NOT_SET</code>: You must set the speaker ID before requesting an enrollment.</p> </li> <li> <p> <code>SPEAKER_OPTED_OUT</code>: You cannot request an enrollment for an opted out speaker.</p> </li> <li> <p> <code>CONCURRENT_CHANGES</code>: The request could not be processed as the resource was modified by another request during execution.</p> </li> </ul>"
653        },
654        "Message":{"shape":"String"}
655      },
656      "documentation":"<p>The request failed due to a conflict. Check the <code>ConflictType</code> and error message for more details.</p>",
657      "exception":true
658    },
659    "ConflictType":{
660      "type":"string",
661      "enum":[
662        "ANOTHER_ACTIVE_STREAM",
663        "DOMAIN_NOT_ACTIVE",
664        "CANNOT_CHANGE_SPEAKER_AFTER_ENROLLMENT",
665        "ENROLLMENT_ALREADY_EXISTS",
666        "SPEAKER_NOT_SET",
667        "SPEAKER_OPTED_OUT",
668        "CONCURRENT_CHANGES",
669        "DOMAIN_LOCKED_FROM_ENCRYPTION_UPDATES",
670        "CANNOT_DELETE_NON_EMPTY_WATCHLIST",
671        "FRAUDSTER_MUST_BELONG_TO_AT_LEAST_ONE_WATCHLIST"
672      ]
673    },
674    "CreateDomainRequest":{
675      "type":"structure",
676      "required":[
677        "Name",
678        "ServerSideEncryptionConfiguration"
679      ],
680      "members":{
681        "ClientToken":{
682          "shape":"ClientTokenString",
683          "documentation":"<p>A unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If not provided, the Amazon Web Services SDK populates this field. For more information about idempotency, see <a href=\"https://aws.amazon.com/builders-library/making-retries-safe-with-idempotent-APIs/\">Making retries safe with idempotent APIs</a>.</p>",
684          "idempotencyToken":true
685        },
686        "Description":{
687          "shape":"Description",
688          "documentation":"<p>A brief description of this domain.</p>"
689        },
690        "Name":{
691          "shape":"DomainName",
692          "documentation":"<p>The name of the domain.</p>"
693        },
694        "ServerSideEncryptionConfiguration":{
695          "shape":"ServerSideEncryptionConfiguration",
696          "documentation":"<p>The configuration, containing the KMS key identifier, to be used by Voice ID for the server-side encryption of your data. Refer to <a href=\"https://docs.aws.amazon.com/connect/latest/adminguide/encryption-at-rest.html#encryption-at-rest-voiceid\"> Amazon Connect Voice ID encryption at rest</a> for more details on how the KMS key is used. </p>"
697        },
698        "Tags":{
699          "shape":"TagList",
700          "documentation":"<p>A list of tags you want added to the domain.</p>"
701        }
702      }
703    },
704    "CreateDomainResponse":{
705      "type":"structure",
706      "members":{
707        "Domain":{
708          "shape":"Domain",
709          "documentation":"<p>Information about the newly created domain.</p>"
710        }
711      }
712    },
713    "CreateWatchlistRequest":{
714      "type":"structure",
715      "required":[
716        "DomainId",
717        "Name"
718      ],
719      "members":{
720        "ClientToken":{
721          "shape":"ClientTokenString",
722          "documentation":"<p>A unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If not provided, the Amazon Web Services SDK populates this field. For more information about idempotency, see <a href=\"https://aws.amazon.com/builders-library/making-retries-safe-with-idempotent-APIs/\">Making retries safe with idempotent APIs</a>.</p>",
723          "idempotencyToken":true
724        },
725        "Description":{
726          "shape":"WatchlistDescription",
727          "documentation":"<p>A brief description of this watchlist.</p>"
728        },
729        "DomainId":{
730          "shape":"DomainId",
731          "documentation":"<p>The identifier of the domain that contains the watchlist.</p>"
732        },
733        "Name":{
734          "shape":"WatchlistName",
735          "documentation":"<p>The name of the watchlist.</p>"
736        }
737      }
738    },
739    "CreateWatchlistResponse":{
740      "type":"structure",
741      "members":{
742        "Watchlist":{
743          "shape":"Watchlist",
744          "documentation":"<p>Information about the newly created watchlist.</p>"
745        }
746      }
747    },
748    "CustomerSpeakerId":{
749      "type":"string",
750      "max":256,
751      "min":1,
752      "pattern":"^[a-zA-Z0-9][a-zA-Z0-9_-]*$",
753      "sensitive":true
754    },
755    "DeleteDomainRequest":{
756      "type":"structure",
757      "required":["DomainId"],
758      "members":{
759        "DomainId":{
760          "shape":"DomainId",
761          "documentation":"<p>The identifier of the domain you want to delete.</p>"
762        }
763      }
764    },
765    "DeleteFraudsterRequest":{
766      "type":"structure",
767      "required":[
768        "DomainId",
769        "FraudsterId"
770      ],
771      "members":{
772        "DomainId":{
773          "shape":"DomainId",
774          "documentation":"<p>The identifier of the domain that contains the fraudster.</p>"
775        },
776        "FraudsterId":{
777          "shape":"FraudsterId",
778          "documentation":"<p>The identifier of the fraudster you want to delete.</p>"
779        }
780      }
781    },
782    "DeleteSpeakerRequest":{
783      "type":"structure",
784      "required":[
785        "DomainId",
786        "SpeakerId"
787      ],
788      "members":{
789        "DomainId":{
790          "shape":"DomainId",
791          "documentation":"<p>The identifier of the domain that contains the speaker.</p>"
792        },
793        "SpeakerId":{
794          "shape":"SpeakerId",
795          "documentation":"<p>The identifier of the speaker you want to delete.</p>"
796        }
797      }
798    },
799    "DeleteWatchlistRequest":{
800      "type":"structure",
801      "required":[
802        "DomainId",
803        "WatchlistId"
804      ],
805      "members":{
806        "DomainId":{
807          "shape":"DomainId",
808          "documentation":"<p>The identifier of the domain that contains the watchlist.</p>"
809        },
810        "WatchlistId":{
811          "shape":"WatchlistId",
812          "documentation":"<p>The identifier of the watchlist to be deleted.</p>"
813        }
814      }
815    },
816    "DescribeDomainRequest":{
817      "type":"structure",
818      "required":["DomainId"],
819      "members":{
820        "DomainId":{
821          "shape":"DomainId",
822          "documentation":"<p>The identifier of the domain that you are describing.</p>"
823        }
824      }
825    },
826    "DescribeDomainResponse":{
827      "type":"structure",
828      "members":{
829        "Domain":{
830          "shape":"Domain",
831          "documentation":"<p>Information about the specified domain.</p>"
832        }
833      }
834    },
835    "DescribeFraudsterRegistrationJobRequest":{
836      "type":"structure",
837      "required":[
838        "DomainId",
839        "JobId"
840      ],
841      "members":{
842        "DomainId":{
843          "shape":"DomainId",
844          "documentation":"<p>The identifier of the domain that contains the fraudster registration job.</p>"
845        },
846        "JobId":{
847          "shape":"JobId",
848          "documentation":"<p>The identifier of the fraudster registration job you are describing.</p>"
849        }
850      }
851    },
852    "DescribeFraudsterRegistrationJobResponse":{
853      "type":"structure",
854      "members":{
855        "Job":{
856          "shape":"FraudsterRegistrationJob",
857          "documentation":"<p>Contains details about the specified fraudster registration job.</p>"
858        }
859      }
860    },
861    "DescribeFraudsterRequest":{
862      "type":"structure",
863      "required":[
864        "DomainId",
865        "FraudsterId"
866      ],
867      "members":{
868        "DomainId":{
869          "shape":"DomainId",
870          "documentation":"<p>The identifier of the domain that contains the fraudster.</p>"
871        },
872        "FraudsterId":{
873          "shape":"FraudsterId",
874          "documentation":"<p>The identifier of the fraudster you are describing.</p>"
875        }
876      }
877    },
878    "DescribeFraudsterResponse":{
879      "type":"structure",
880      "members":{
881        "Fraudster":{
882          "shape":"Fraudster",
883          "documentation":"<p>Information about the specified fraudster.</p>"
884        }
885      }
886    },
887    "DescribeSpeakerEnrollmentJobRequest":{
888      "type":"structure",
889      "required":[
890        "DomainId",
891        "JobId"
892      ],
893      "members":{
894        "DomainId":{
895          "shape":"DomainId",
896          "documentation":"<p>The identifier of the domain that contains the speaker enrollment job.</p>"
897        },
898        "JobId":{
899          "shape":"JobId",
900          "documentation":"<p>The identifier of the speaker enrollment job you are describing.</p>"
901        }
902      }
903    },
904    "DescribeSpeakerEnrollmentJobResponse":{
905      "type":"structure",
906      "members":{
907        "Job":{
908          "shape":"SpeakerEnrollmentJob",
909          "documentation":"<p>Contains details about the specified speaker enrollment job.</p>"
910        }
911      }
912    },
913    "DescribeSpeakerRequest":{
914      "type":"structure",
915      "required":[
916        "DomainId",
917        "SpeakerId"
918      ],
919      "members":{
920        "DomainId":{
921          "shape":"DomainId",
922          "documentation":"<p>The identifier of the domain that contains the speaker.</p>"
923        },
924        "SpeakerId":{
925          "shape":"SpeakerId",
926          "documentation":"<p>The identifier of the speaker you are describing.</p>"
927        }
928      }
929    },
930    "DescribeSpeakerResponse":{
931      "type":"structure",
932      "members":{
933        "Speaker":{
934          "shape":"Speaker",
935          "documentation":"<p>Information about the specified speaker.</p>"
936        }
937      }
938    },
939    "DescribeWatchlistRequest":{
940      "type":"structure",
941      "required":[
942        "DomainId",
943        "WatchlistId"
944      ],
945      "members":{
946        "DomainId":{
947          "shape":"DomainId",
948          "documentation":"<p>The identifier of the domain that contains the watchlist.</p>"
949        },
950        "WatchlistId":{
951          "shape":"WatchlistId",
952          "documentation":"<p>The identifier of the watchlist that you are describing.</p>"
953        }
954      }
955    },
956    "DescribeWatchlistResponse":{
957      "type":"structure",
958      "members":{
959        "Watchlist":{
960          "shape":"Watchlist",
961          "documentation":"<p>Information about the specified watchlist.</p>"
962        }
963      }
964    },
965    "Description":{
966      "type":"string",
967      "max":1024,
968      "min":1,
969      "pattern":"^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-%@]*)$",
970      "sensitive":true
971    },
972    "DisassociateFraudsterRequest":{
973      "type":"structure",
974      "required":[
975        "DomainId",
976        "FraudsterId",
977        "WatchlistId"
978      ],
979      "members":{
980        "DomainId":{
981          "shape":"DomainId",
982          "documentation":"<p>The identifier of the domain that contains the fraudster.</p>"
983        },
984        "FraudsterId":{
985          "shape":"FraudsterId",
986          "documentation":"<p>The identifier of the fraudster to be disassociated from the watchlist.</p>"
987        },
988        "WatchlistId":{
989          "shape":"WatchlistId",
990          "documentation":"<p>The identifier of the watchlist that you want to disassociate from the fraudster.</p>"
991        }
992      }
993    },
994    "DisassociateFraudsterResponse":{
995      "type":"structure",
996      "members":{
997        "Fraudster":{"shape":"Fraudster"}
998      }
999    },
1000    "Domain":{
1001      "type":"structure",
1002      "members":{
1003        "Arn":{
1004          "shape":"Arn",
1005          "documentation":"<p>The Amazon Resource Name (ARN) for the domain.</p>"
1006        },
1007        "CreatedAt":{
1008          "shape":"Timestamp",
1009          "documentation":"<p>The timestamp of when the domain was created.</p>"
1010        },
1011        "Description":{
1012          "shape":"Description",
1013          "documentation":"<p>The description of the domain.</p>"
1014        },
1015        "DomainId":{
1016          "shape":"DomainId",
1017          "documentation":"<p>The identifier of the domain.</p>"
1018        },
1019        "DomainStatus":{
1020          "shape":"DomainStatus",
1021          "documentation":"<p>The current status of the domain.</p>"
1022        },
1023        "Name":{
1024          "shape":"DomainName",
1025          "documentation":"<p>The name for the domain.</p>"
1026        },
1027        "ServerSideEncryptionConfiguration":{
1028          "shape":"ServerSideEncryptionConfiguration",
1029          "documentation":"<p>The server-side encryption configuration containing the KMS key identifier you want Voice ID to use to encrypt your data.</p>"
1030        },
1031        "ServerSideEncryptionUpdateDetails":{
1032          "shape":"ServerSideEncryptionUpdateDetails",
1033          "documentation":"<p>Details about the most recent server-side encryption configuration update. When the server-side encryption configuration is changed, dependency on the old KMS key is removed through an asynchronous process. When this update is complete, the domain's data can only be accessed using the new KMS key.</p>"
1034        },
1035        "UpdatedAt":{
1036          "shape":"Timestamp",
1037          "documentation":"<p>The timestamp of when the domain was last update.</p>"
1038        },
1039        "WatchlistDetails":{
1040          "shape":"WatchlistDetails",
1041          "documentation":"<p>The watchlist details of a domain. Contains the default watchlist ID of the domain.</p>"
1042        }
1043      },
1044      "documentation":"<p>Contains all the information about a domain.</p>"
1045    },
1046    "DomainId":{
1047      "type":"string",
1048      "max":22,
1049      "min":22,
1050      "pattern":"^[a-zA-Z0-9]{22}$"
1051    },
1052    "DomainName":{
1053      "type":"string",
1054      "max":256,
1055      "min":1,
1056      "pattern":"^[a-zA-Z0-9][a-zA-Z0-9_-]*$",
1057      "sensitive":true
1058    },
1059    "DomainStatus":{
1060      "type":"string",
1061      "enum":[
1062        "ACTIVE",
1063        "PENDING",
1064        "SUSPENDED"
1065      ]
1066    },
1067    "DomainSummaries":{
1068      "type":"list",
1069      "member":{"shape":"DomainSummary"}
1070    },
1071    "DomainSummary":{
1072      "type":"structure",
1073      "members":{
1074        "Arn":{
1075          "shape":"Arn",
1076          "documentation":"<p>The Amazon Resource Name (ARN) for the domain.</p>"
1077        },
1078        "CreatedAt":{
1079          "shape":"Timestamp",
1080          "documentation":"<p>The timestamp of when the domain was created.</p>"
1081        },
1082        "Description":{
1083          "shape":"Description",
1084          "documentation":"<p>The description of the domain.</p>"
1085        },
1086        "DomainId":{
1087          "shape":"DomainId",
1088          "documentation":"<p>The identifier of the domain.</p>"
1089        },
1090        "DomainStatus":{
1091          "shape":"DomainStatus",
1092          "documentation":"<p>The current status of the domain.</p>"
1093        },
1094        "Name":{
1095          "shape":"DomainName",
1096          "documentation":"<p>The client-provided name for the domain.</p>"
1097        },
1098        "ServerSideEncryptionConfiguration":{
1099          "shape":"ServerSideEncryptionConfiguration",
1100          "documentation":"<p>The server-side encryption configuration containing the KMS key identifier you want Voice ID to use to encrypt your data.</p>"
1101        },
1102        "ServerSideEncryptionUpdateDetails":{
1103          "shape":"ServerSideEncryptionUpdateDetails",
1104          "documentation":"<p>Details about the most recent server-side encryption configuration update. When the server-side encryption configuration is changed, dependency on the old KMS key is removed through an asynchronous process. When this update is complete, the domain's data can only be accessed using the new KMS key.</p>"
1105        },
1106        "UpdatedAt":{
1107          "shape":"Timestamp",
1108          "documentation":"<p>The timestamp of when the domain was last updated.</p>"
1109        },
1110        "WatchlistDetails":{
1111          "shape":"WatchlistDetails",
1112          "documentation":"<p>Provides information about <code>watchlistDetails</code> and <code>DefaultWatchlistID</code>. </p>"
1113        }
1114      },
1115      "documentation":"<p>Contains a summary of information about a domain.</p>"
1116    },
1117    "DuplicateRegistrationAction":{
1118      "type":"string",
1119      "enum":[
1120        "SKIP",
1121        "REGISTER_AS_NEW"
1122      ]
1123    },
1124    "EnrollmentConfig":{
1125      "type":"structure",
1126      "members":{
1127        "ExistingEnrollmentAction":{
1128          "shape":"ExistingEnrollmentAction",
1129          "documentation":"<p> The action to take when the specified speaker is already enrolled in the specified domain. The default value is <code>SKIP</code>, which skips the enrollment for the existing speaker. Setting the value to <code>OVERWRITE</code> replaces the existing voice prints and enrollment audio stored for that speaker with new data generated from the latest audio.</p>"
1130        },
1131        "FraudDetectionConfig":{
1132          "shape":"EnrollmentJobFraudDetectionConfig",
1133          "documentation":"<p>The fraud detection configuration to use for the speaker enrollment job.</p>"
1134        }
1135      },
1136      "documentation":"<p>Contains configurations defining enrollment behavior for the batch job.</p>"
1137    },
1138    "EnrollmentJobFraudDetectionConfig":{
1139      "type":"structure",
1140      "members":{
1141        "FraudDetectionAction":{
1142          "shape":"FraudDetectionAction",
1143          "documentation":"<p>The action to take when the given speaker is flagged by the fraud detection system. The default value is <code>FAIL</code>, which fails the speaker enrollment. Changing this value to <code>IGNORE</code> results in the speaker being enrolled even if they are flagged by the fraud detection system.</p>"
1144        },
1145        "RiskThreshold":{
1146          "shape":"Score",
1147          "documentation":"<p>Threshold value for determining whether the speaker is a high risk to be fraudulent. If the detected risk score calculated by Voice ID is greater than or equal to the threshold, the speaker is considered a fraudster.</p>"
1148        },
1149        "WatchlistIds":{
1150          "shape":"EnrollmentJobFraudDetectionConfigWatchlistIds",
1151          "documentation":"<p>The identifier of watchlists against which fraud detection is performed. </p>"
1152        }
1153      },
1154      "documentation":"<p>The fraud detection configuration to be used during the batch speaker enrollment job.</p>"
1155    },
1156    "EnrollmentJobFraudDetectionConfigWatchlistIds":{
1157      "type":"list",
1158      "member":{"shape":"WatchlistId"},
1159      "max":1,
1160      "min":1
1161    },
1162    "EvaluateSessionRequest":{
1163      "type":"structure",
1164      "required":[
1165        "DomainId",
1166        "SessionNameOrId"
1167      ],
1168      "members":{
1169        "DomainId":{
1170          "shape":"DomainId",
1171          "documentation":"<p>The identifier of the domain where the session started.</p>"
1172        },
1173        "SessionNameOrId":{
1174          "shape":"SessionNameOrId",
1175          "documentation":"<p>The session identifier, or name of the session, that you want to evaluate. In Voice ID integration, this is the Contact-Id.</p>"
1176        }
1177      }
1178    },
1179    "EvaluateSessionResponse":{
1180      "type":"structure",
1181      "members":{
1182        "AuthenticationResult":{
1183          "shape":"AuthenticationResult",
1184          "documentation":"<p>Details resulting from the authentication process, such as authentication decision and authentication score.</p>"
1185        },
1186        "DomainId":{
1187          "shape":"DomainId",
1188          "documentation":"<p>The identifier of the domain that contains the session.</p>"
1189        },
1190        "FraudDetectionResult":{
1191          "shape":"FraudDetectionResult",
1192          "documentation":"<p>Details resulting from the fraud detection process, such as fraud detection decision and risk score.</p>"
1193        },
1194        "SessionId":{
1195          "shape":"SessionId",
1196          "documentation":"<p>The service-generated identifier of the session.</p>"
1197        },
1198        "SessionName":{
1199          "shape":"SessionName",
1200          "documentation":"<p>The client-provided name of the session.</p>"
1201        },
1202        "StreamingStatus":{
1203          "shape":"StreamingStatus",
1204          "documentation":"<p>The current status of audio streaming for this session. This field is useful to infer next steps when the Authentication or Fraud Detection results are empty or the decision is <code>NOT_ENOUGH_SPEECH</code>. In this situation, if the <code>StreamingStatus</code> is <code>ONGOING/PENDING_CONFIGURATION</code>, it can mean that the client should call the API again later, after Voice ID has enough audio to produce a result. If the decision remains <code>NOT_ENOUGH_SPEECH</code> even after <code>StreamingStatus</code> is <code>ENDED</code>, it means that the previously streamed session did not have enough speech to perform evaluation, and a new streaming session is needed to try again.</p>"
1205        }
1206      }
1207    },
1208    "ExistingEnrollmentAction":{
1209      "type":"string",
1210      "enum":[
1211        "SKIP",
1212        "OVERWRITE"
1213      ]
1214    },
1215    "FailureDetails":{
1216      "type":"structure",
1217      "members":{
1218        "Message":{
1219          "shape":"String",
1220          "documentation":"<p>A description of the error that caused the batch job failure.</p>"
1221        },
1222        "StatusCode":{
1223          "shape":"Integer",
1224          "documentation":"<p>An HTTP status code representing the nature of the error.</p>"
1225        }
1226      },
1227      "documentation":"<p>Contains error details for a failed batch job.</p>"
1228    },
1229    "FraudDetectionAction":{
1230      "type":"string",
1231      "enum":[
1232        "IGNORE",
1233        "FAIL"
1234      ]
1235    },
1236    "FraudDetectionConfiguration":{
1237      "type":"structure",
1238      "members":{
1239        "RiskThreshold":{
1240          "shape":"Score",
1241          "documentation":"<p>Threshold value for determining whether the speaker is a fraudster. If the detected risk score calculated by Voice ID is higher than the threshold, the speaker is considered a fraudster.</p>"
1242        },
1243        "WatchlistId":{
1244          "shape":"WatchlistId",
1245          "documentation":"<p>The identifier of the watchlist against which fraud detection is performed. </p>"
1246        }
1247      },
1248      "documentation":"<p>The configuration used for performing fraud detection over a speaker during a session.</p>"
1249    },
1250    "FraudDetectionDecision":{
1251      "type":"string",
1252      "enum":[
1253        "HIGH_RISK",
1254        "LOW_RISK",
1255        "NOT_ENOUGH_SPEECH"
1256      ]
1257    },
1258    "FraudDetectionReason":{
1259      "type":"string",
1260      "enum":[
1261        "KNOWN_FRAUDSTER",
1262        "VOICE_SPOOFING"
1263      ]
1264    },
1265    "FraudDetectionReasons":{
1266      "type":"list",
1267      "member":{"shape":"FraudDetectionReason"},
1268      "max":3,
1269      "min":0
1270    },
1271    "FraudDetectionResult":{
1272      "type":"structure",
1273      "members":{
1274        "AudioAggregationEndedAt":{
1275          "shape":"Timestamp",
1276          "documentation":"<p>A timestamp of when audio aggregation ended for this fraud detection result.</p>"
1277        },
1278        "AudioAggregationStartedAt":{
1279          "shape":"Timestamp",
1280          "documentation":"<p>A timestamp of when audio aggregation started for this fraud detection result.</p>"
1281        },
1282        "Configuration":{
1283          "shape":"FraudDetectionConfiguration",
1284          "documentation":"<p>The <code>FraudDetectionConfiguration</code> used to generate this fraud detection result.</p>"
1285        },
1286        "Decision":{
1287          "shape":"FraudDetectionDecision",
1288          "documentation":"<p>The fraud detection decision produced by Voice ID, processed against the current session state and streamed audio of the speaker.</p>"
1289        },
1290        "FraudDetectionResultId":{
1291          "shape":"UniqueIdLarge",
1292          "documentation":"<p>The unique identifier for this fraud detection result. Given there can be multiple fraud detections for a given session, this field helps in identifying if the returned result is from previous streaming activity or a new result. Note that in the absence of any new streaming activity or risk threshold changes, Voice ID always returns cached Fraud Detection result for this API.</p>"
1293        },
1294        "Reasons":{
1295          "shape":"FraudDetectionReasons",
1296          "documentation":"<p>The reason speaker was flagged by the fraud detection system. This is only be populated if fraud detection Decision is <code>HIGH_RISK</code>, and the following possible values: <code>KNOWN_FRAUDSTER</code> and <code>VOICE_SPOOFING</code>.</p>"
1297        },
1298        "RiskDetails":{
1299          "shape":"FraudRiskDetails",
1300          "documentation":"<p>Details about each risk analyzed for this speaker. Currently, this contains KnownFraudsterRisk and VoiceSpoofingRisk details.</p>"
1301        }
1302      },
1303      "documentation":"<p>The fraud detection result produced by Voice ID, processed against the current session state and streamed audio of the speaker.</p>"
1304    },
1305    "FraudRiskDetails":{
1306      "type":"structure",
1307      "required":[
1308        "KnownFraudsterRisk",
1309        "VoiceSpoofingRisk"
1310      ],
1311      "members":{
1312        "KnownFraudsterRisk":{
1313          "shape":"KnownFraudsterRisk",
1314          "documentation":"<p>The details resulting from 'Known Fraudster Risk' analysis of the speaker.</p>"
1315        },
1316        "VoiceSpoofingRisk":{
1317          "shape":"VoiceSpoofingRisk",
1318          "documentation":"<p>The details resulting from 'Voice Spoofing Risk' analysis of the speaker.</p>"
1319        }
1320      },
1321      "documentation":"<p>Details regarding various fraud risk analyses performed against the current session state and streamed audio of the speaker.</p>"
1322    },
1323    "Fraudster":{
1324      "type":"structure",
1325      "members":{
1326        "CreatedAt":{
1327          "shape":"Timestamp",
1328          "documentation":"<p>The timestamp of when Voice ID identified the fraudster.</p>"
1329        },
1330        "DomainId":{
1331          "shape":"DomainId",
1332          "documentation":"<p>The identifier of the domain that contains the fraudster.</p>"
1333        },
1334        "GeneratedFraudsterId":{
1335          "shape":"GeneratedFraudsterId",
1336          "documentation":"<p>The service-generated identifier for the fraudster.</p>"
1337        },
1338        "WatchlistIds":{
1339          "shape":"ResponseWatchlistIds",
1340          "documentation":"<p>The identifier of the watchlists the fraudster is a part of.</p>"
1341        }
1342      },
1343      "documentation":"<p>Contains all the information about a fraudster.</p>"
1344    },
1345    "FraudsterId":{
1346      "type":"string",
1347      "max":25,
1348      "min":25,
1349      "pattern":"^id#[a-zA-Z0-9]{22}$",
1350      "sensitive":true
1351    },
1352    "FraudsterRegistrationJob":{
1353      "type":"structure",
1354      "members":{
1355        "CreatedAt":{
1356          "shape":"Timestamp",
1357          "documentation":"<p>A timestamp of when the fraudster registration job was created.</p>"
1358        },
1359        "DataAccessRoleArn":{
1360          "shape":"IamRoleArn",
1361          "documentation":"<p>The IAM role Amazon Resource Name (ARN) that grants Voice ID permissions to access customer's buckets to read the input manifest file and write the job output file.</p>"
1362        },
1363        "DomainId":{
1364          "shape":"DomainId",
1365          "documentation":"<p>The identifier of the domain that contains the fraudster registration job.</p>"
1366        },
1367        "EndedAt":{
1368          "shape":"Timestamp",
1369          "documentation":"<p>A timestamp of when the fraudster registration job ended.</p>"
1370        },
1371        "FailureDetails":{
1372          "shape":"FailureDetails",
1373          "documentation":"<p>Contains details that are populated when an entire batch job fails. In cases of individual registration job failures, the batch job as a whole doesn't fail; it is completed with a <code>JobStatus</code> of <code>COMPLETED_WITH_ERRORS</code>. You can use the job output file to identify the individual registration requests that failed.</p>"
1374        },
1375        "InputDataConfig":{
1376          "shape":"InputDataConfig",
1377          "documentation":"<p>The input data config containing an S3 URI for the input manifest file that contains the list of fraudster registration job requests.</p>"
1378        },
1379        "JobId":{
1380          "shape":"JobId",
1381          "documentation":"<p>The service-generated identifier for the fraudster registration job.</p>"
1382        },
1383        "JobName":{
1384          "shape":"JobName",
1385          "documentation":"<p>The client-provided name for the fraudster registration job.</p>"
1386        },
1387        "JobProgress":{
1388          "shape":"JobProgress",
1389          "documentation":"<p>Shows the completed percentage of registration requests listed in the input file.</p>"
1390        },
1391        "JobStatus":{
1392          "shape":"FraudsterRegistrationJobStatus",
1393          "documentation":"<p>The current status of the fraudster registration job.</p>"
1394        },
1395        "OutputDataConfig":{
1396          "shape":"OutputDataConfig",
1397          "documentation":"<p>The output data config containing the S3 location where you want Voice ID to write your job output file; you must also include a KMS key ID in order to encrypt the file.</p>"
1398        },
1399        "RegistrationConfig":{
1400          "shape":"RegistrationConfig",
1401          "documentation":"<p>The registration config containing details such as the action to take when a duplicate fraudster is detected, and the similarity threshold to use for detecting a duplicate fraudster.</p>"
1402        }
1403      },
1404      "documentation":"<p>Contains all the information about a fraudster registration job.</p>"
1405    },
1406    "FraudsterRegistrationJobStatus":{
1407      "type":"string",
1408      "enum":[
1409        "SUBMITTED",
1410        "IN_PROGRESS",
1411        "COMPLETED",
1412        "COMPLETED_WITH_ERRORS",
1413        "FAILED"
1414      ]
1415    },
1416    "FraudsterRegistrationJobSummaries":{
1417      "type":"list",
1418      "member":{"shape":"FraudsterRegistrationJobSummary"}
1419    },
1420    "FraudsterRegistrationJobSummary":{
1421      "type":"structure",
1422      "members":{
1423        "CreatedAt":{
1424          "shape":"Timestamp",
1425          "documentation":"<p>A timestamp of when the fraudster registration job was created. </p>"
1426        },
1427        "DomainId":{
1428          "shape":"DomainId",
1429          "documentation":"<p>The identifier of the domain that contains the fraudster registration job.</p>"
1430        },
1431        "EndedAt":{
1432          "shape":"Timestamp",
1433          "documentation":"<p>A timestamp of when the fraudster registration job ended.</p>"
1434        },
1435        "FailureDetails":{
1436          "shape":"FailureDetails",
1437          "documentation":"<p>Contains details that are populated when an entire batch job fails. In cases of individual registration job failures, the batch job as a whole doesn't fail; it is completed with a <code>JobStatus</code> of <code>COMPLETED_WITH_ERRORS</code>. You can use the job output file to identify the individual registration requests that failed.</p>"
1438        },
1439        "JobId":{
1440          "shape":"JobId",
1441          "documentation":"<p>The service-generated identifier for the fraudster registration job.</p>"
1442        },
1443        "JobName":{
1444          "shape":"JobName",
1445          "documentation":"<p>The client-provided name for the fraudster registration job.</p>"
1446        },
1447        "JobProgress":{
1448          "shape":"JobProgress",
1449          "documentation":"<p>Shows the completed percentage of registration requests listed in the input file.</p>"
1450        },
1451        "JobStatus":{
1452          "shape":"FraudsterRegistrationJobStatus",
1453          "documentation":"<p>The current status of the fraudster registration job.</p>"
1454        }
1455      },
1456      "documentation":"<p>Contains a summary of information about a fraudster registration job.</p>"
1457    },
1458    "FraudsterSummaries":{
1459      "type":"list",
1460      "member":{"shape":"FraudsterSummary"}
1461    },
1462    "FraudsterSummary":{
1463      "type":"structure",
1464      "members":{
1465        "CreatedAt":{
1466          "shape":"Timestamp",
1467          "documentation":"<p>The timestamp of when the fraudster summary was created.</p>"
1468        },
1469        "DomainId":{
1470          "shape":"DomainId",
1471          "documentation":"<p>The identifier of the domain that contains the fraudster summary.</p>"
1472        },
1473        "GeneratedFraudsterId":{
1474          "shape":"GeneratedFraudsterId",
1475          "documentation":"<p>The service-generated identifier for the fraudster.</p>"
1476        },
1477        "WatchlistIds":{
1478          "shape":"ResponseWatchlistIds",
1479          "documentation":"<p>The identifier of the watchlists the fraudster is a part of.</p>"
1480        }
1481      },
1482      "documentation":"<p>Contains a summary of information about a fraudster. </p>"
1483    },
1484    "GeneratedFraudsterId":{
1485      "type":"string",
1486      "max":25,
1487      "min":25,
1488      "pattern":"^id#[a-zA-Z0-9]{22}$"
1489    },
1490    "GeneratedSpeakerId":{
1491      "type":"string",
1492      "max":25,
1493      "min":25,
1494      "pattern":"^id#[a-zA-Z0-9]{22}$"
1495    },
1496    "IamRoleArn":{
1497      "type":"string",
1498      "max":2048,
1499      "min":20,
1500      "pattern":"^arn:aws(-[^:]+)?:iam::[0-9]{12}:role/.+$"
1501    },
1502    "InputDataConfig":{
1503      "type":"structure",
1504      "required":["S3Uri"],
1505      "members":{
1506        "S3Uri":{
1507          "shape":"S3Uri",
1508          "documentation":"<p>The S3 location for the input manifest file that contains the list of individual enrollment or registration job requests.</p>"
1509        }
1510      },
1511      "documentation":"<p>The configuration containing input file information for a batch job.</p>"
1512    },
1513    "Integer":{
1514      "type":"integer",
1515      "box":true
1516    },
1517    "InternalServerException":{
1518      "type":"structure",
1519      "members":{
1520        "Message":{"shape":"String"}
1521      },
1522      "documentation":"<p>The request failed due to an unknown error on the server side.</p>",
1523      "exception":true,
1524      "fault":true
1525    },
1526    "JobId":{
1527      "type":"string",
1528      "max":22,
1529      "min":22,
1530      "pattern":"^[a-zA-Z0-9]{22}$"
1531    },
1532    "JobName":{
1533      "type":"string",
1534      "max":256,
1535      "min":1,
1536      "pattern":"^[a-zA-Z0-9][a-zA-Z0-9_-]*$",
1537      "sensitive":true
1538    },
1539    "JobProgress":{
1540      "type":"structure",
1541      "members":{
1542        "PercentComplete":{
1543          "shape":"Score",
1544          "documentation":"<p>Shows the completed percentage of enrollment or registration requests listed in the input file.</p>"
1545        }
1546      },
1547      "documentation":"<p>Indicates the completion progress for a batch job.</p>"
1548    },
1549    "KmsKeyId":{
1550      "type":"string",
1551      "max":2048,
1552      "min":1
1553    },
1554    "KnownFraudsterRisk":{
1555      "type":"structure",
1556      "required":["RiskScore"],
1557      "members":{
1558        "GeneratedFraudsterId":{
1559          "shape":"GeneratedFraudsterId",
1560          "documentation":"<p>The identifier of the fraudster that is the closest match to the speaker. If there are no fraudsters registered in a given domain, or if there are no fraudsters with a non-zero RiskScore, this value is <code>null</code>.</p>"
1561        },
1562        "RiskScore":{
1563          "shape":"Score",
1564          "documentation":"<p>The score indicating the likelihood the speaker is a known fraudster.</p>"
1565        }
1566      },
1567      "documentation":"<p>Contains details produced as a result of performing known fraudster risk analysis on a speaker.</p>"
1568    },
1569    "ListDomainsRequest":{
1570      "type":"structure",
1571      "members":{
1572        "MaxResults":{
1573          "shape":"MaxResultsForListDomainFe",
1574          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>NextToken</code> to obtain more pages of results. The default is 100; the maximum allowed page size is also 100.</p>"
1575        },
1576        "NextToken":{
1577          "shape":"NextToken",
1578          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours.</p>"
1579        }
1580      }
1581    },
1582    "ListDomainsResponse":{
1583      "type":"structure",
1584      "members":{
1585        "DomainSummaries":{
1586          "shape":"DomainSummaries",
1587          "documentation":"<p>A list containing details about each domain in the Amazon Web Services account.</p>"
1588        },
1589        "NextToken":{
1590          "shape":"String",
1591          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours.</p>"
1592        }
1593      }
1594    },
1595    "ListFraudsterRegistrationJobsRequest":{
1596      "type":"structure",
1597      "required":["DomainId"],
1598      "members":{
1599        "DomainId":{
1600          "shape":"DomainId",
1601          "documentation":"<p>The identifier of the domain that contains the fraudster registration Jobs.</p>"
1602        },
1603        "JobStatus":{
1604          "shape":"FraudsterRegistrationJobStatus",
1605          "documentation":"<p>Provides the status of your fraudster registration job.</p>"
1606        },
1607        "MaxResults":{
1608          "shape":"MaxResultsForList",
1609          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>NextToken</code> to obtain more pages of results. The default is 100; the maximum allowed page size is also 100. </p>"
1610        },
1611        "NextToken":{
1612          "shape":"NextToken",
1613          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours.</p>"
1614        }
1615      }
1616    },
1617    "ListFraudsterRegistrationJobsResponse":{
1618      "type":"structure",
1619      "members":{
1620        "JobSummaries":{
1621          "shape":"FraudsterRegistrationJobSummaries",
1622          "documentation":"<p>A list containing details about each specified fraudster registration job.</p>"
1623        },
1624        "NextToken":{
1625          "shape":"String",
1626          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours.</p>"
1627        }
1628      }
1629    },
1630    "ListFraudstersRequest":{
1631      "type":"structure",
1632      "required":["DomainId"],
1633      "members":{
1634        "DomainId":{
1635          "shape":"DomainId",
1636          "documentation":"<p>The identifier of the domain. </p>"
1637        },
1638        "MaxResults":{
1639          "shape":"MaxResultsForList",
1640          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>NextToken</code> to obtain more pages of results. The default is 100; the maximum allowed page size is also 100. </p>"
1641        },
1642        "NextToken":{
1643          "shape":"NextToken",
1644          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. </p>"
1645        },
1646        "WatchlistId":{
1647          "shape":"WatchlistId",
1648          "documentation":"<p>The identifier of the watchlist. If provided, all fraudsters in the watchlist are listed. If not provided, all fraudsters in the domain are listed.</p>"
1649        }
1650      }
1651    },
1652    "ListFraudstersResponse":{
1653      "type":"structure",
1654      "members":{
1655        "FraudsterSummaries":{
1656          "shape":"FraudsterSummaries",
1657          "documentation":"<p>A list that contains details about each fraudster in the Amazon Web Services account. </p>"
1658        },
1659        "NextToken":{
1660          "shape":"String",
1661          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. </p>"
1662        }
1663      }
1664    },
1665    "ListSpeakerEnrollmentJobsRequest":{
1666      "type":"structure",
1667      "required":["DomainId"],
1668      "members":{
1669        "DomainId":{
1670          "shape":"DomainId",
1671          "documentation":"<p>The identifier of the domain that contains the speaker enrollment jobs.</p>"
1672        },
1673        "JobStatus":{
1674          "shape":"SpeakerEnrollmentJobStatus",
1675          "documentation":"<p>Provides the status of your speaker enrollment Job.</p>"
1676        },
1677        "MaxResults":{
1678          "shape":"MaxResultsForList",
1679          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>NextToken</code> to obtain more pages of results. The default is 100; the maximum allowed page size is also 100.</p>"
1680        },
1681        "NextToken":{
1682          "shape":"NextToken",
1683          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours.</p>"
1684        }
1685      }
1686    },
1687    "ListSpeakerEnrollmentJobsResponse":{
1688      "type":"structure",
1689      "members":{
1690        "JobSummaries":{
1691          "shape":"SpeakerEnrollmentJobSummaries",
1692          "documentation":"<p>A list containing details about each specified speaker enrollment job.</p>"
1693        },
1694        "NextToken":{
1695          "shape":"String",
1696          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. </p>"
1697        }
1698      }
1699    },
1700    "ListSpeakersRequest":{
1701      "type":"structure",
1702      "required":["DomainId"],
1703      "members":{
1704        "DomainId":{
1705          "shape":"DomainId",
1706          "documentation":"<p>The identifier of the domain.</p>"
1707        },
1708        "MaxResults":{
1709          "shape":"MaxResultsForList",
1710          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>NextToken</code> to obtain more pages of results. The default is 100; the maximum allowed page size is also 100. </p>"
1711        },
1712        "NextToken":{
1713          "shape":"NextToken",
1714          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours.</p>"
1715        }
1716      }
1717    },
1718    "ListSpeakersResponse":{
1719      "type":"structure",
1720      "members":{
1721        "NextToken":{
1722          "shape":"String",
1723          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. </p>"
1724        },
1725        "SpeakerSummaries":{
1726          "shape":"SpeakerSummaries",
1727          "documentation":"<p>A list containing details about each speaker in the Amazon Web Services account. </p>"
1728        }
1729      }
1730    },
1731    "ListTagsForResourceRequest":{
1732      "type":"structure",
1733      "required":["ResourceArn"],
1734      "members":{
1735        "ResourceArn":{
1736          "shape":"AmazonResourceName",
1737          "documentation":"<p>The Amazon Resource Name (ARN) of the Voice ID resource for which you want to list the tags.</p>"
1738        }
1739      }
1740    },
1741    "ListTagsForResourceResponse":{
1742      "type":"structure",
1743      "members":{
1744        "Tags":{
1745          "shape":"TagList",
1746          "documentation":"<p>The list of tags associated with the specified resource.</p>"
1747        }
1748      }
1749    },
1750    "ListWatchlistsRequest":{
1751      "type":"structure",
1752      "required":["DomainId"],
1753      "members":{
1754        "DomainId":{
1755          "shape":"DomainId",
1756          "documentation":"<p>The identifier of the domain.</p>"
1757        },
1758        "MaxResults":{
1759          "shape":"MaxResultsForList",
1760          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>NextToken</code> to obtain more pages of results. The default is 100; the maximum allowed page size is also 100. </p>"
1761        },
1762        "NextToken":{
1763          "shape":"NextToken",
1764          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. </p>"
1765        }
1766      }
1767    },
1768    "ListWatchlistsResponse":{
1769      "type":"structure",
1770      "members":{
1771        "NextToken":{
1772          "shape":"String",
1773          "documentation":"<p>If <code>NextToken</code> is returned, there are more results available. The value of <code>NextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. </p>"
1774        },
1775        "WatchlistSummaries":{
1776          "shape":"WatchlistSummaries",
1777          "documentation":"<p>A list that contains details about each watchlist in the Amazon Web Services account. </p>"
1778        }
1779      }
1780    },
1781    "MaxResultsForList":{
1782      "type":"integer",
1783      "box":true,
1784      "max":100,
1785      "min":1
1786    },
1787    "MaxResultsForListDomainFe":{
1788      "type":"integer",
1789      "box":true,
1790      "max":10,
1791      "min":1
1792    },
1793    "NextToken":{
1794      "type":"string",
1795      "max":8192,
1796      "min":0,
1797      "pattern":"^\\p{ASCII}{0,8192}$"
1798    },
1799    "OptOutSpeakerRequest":{
1800      "type":"structure",
1801      "required":[
1802        "DomainId",
1803        "SpeakerId"
1804      ],
1805      "members":{
1806        "DomainId":{
1807          "shape":"DomainId",
1808          "documentation":"<p>The identifier of the domain that contains the speaker.</p>"
1809        },
1810        "SpeakerId":{
1811          "shape":"SpeakerId",
1812          "documentation":"<p>The identifier of the speaker you want opted-out.</p>"
1813        }
1814      }
1815    },
1816    "OptOutSpeakerResponse":{
1817      "type":"structure",
1818      "members":{
1819        "Speaker":{
1820          "shape":"Speaker",
1821          "documentation":"<p>Details about the opted-out speaker.</p>"
1822        }
1823      }
1824    },
1825    "OutputDataConfig":{
1826      "type":"structure",
1827      "required":["S3Uri"],
1828      "members":{
1829        "KmsKeyId":{
1830          "shape":"KmsKeyId",
1831          "documentation":"<p>The identifier of the KMS key you want Voice ID to use to encrypt the output file of a speaker enrollment job/fraudster registration job. </p>"
1832        },
1833        "S3Uri":{
1834          "shape":"S3Uri",
1835          "documentation":"<p>The S3 path of the folder where Voice ID writes the job output file. It has a <code>*.out</code> extension. For example, if the input file name is <code>input-file.json</code> and the output folder path is <code>s3://output-bucket/output-folder</code>, the full output file path is <code>s3://output-bucket/output-folder/job-Id/input-file.json.out</code>.</p>"
1836        }
1837      },
1838      "documentation":"<p>The configuration containing output file information for a batch job.</p>"
1839    },
1840    "RegistrationConfig":{
1841      "type":"structure",
1842      "members":{
1843        "DuplicateRegistrationAction":{
1844          "shape":"DuplicateRegistrationAction",
1845          "documentation":"<p>The action to take when a fraudster is identified as a duplicate. The default action is <code>SKIP</code>, which skips registering the duplicate fraudster. Setting the value to <code>REGISTER_AS_NEW</code> always registers a new fraudster into the specified domain.</p>"
1846        },
1847        "FraudsterSimilarityThreshold":{
1848          "shape":"Score",
1849          "documentation":"<p>The minimum similarity score between the new and old fraudsters in order to consider the new fraudster a duplicate.</p>"
1850        },
1851        "WatchlistIds":{
1852          "shape":"RegistrationConfigWatchlistIds",
1853          "documentation":"<p>The identifiers of watchlists that a fraudster is registered to. If a watchlist isn't provided, the fraudsters are registered to the default watchlist. </p>"
1854        }
1855      },
1856      "documentation":"<p>The registration configuration to be used during the batch fraudster registration job.</p>"
1857    },
1858    "RegistrationConfigWatchlistIds":{
1859      "type":"list",
1860      "member":{"shape":"WatchlistId"},
1861      "max":1,
1862      "min":1
1863    },
1864    "ResourceNotFoundException":{
1865      "type":"structure",
1866      "members":{
1867        "Message":{"shape":"String"},
1868        "ResourceType":{
1869          "shape":"ResourceType",
1870          "documentation":"<p>The type of resource which cannot not be found. Possible types are <code>BATCH_JOB</code>, <code>COMPLIANCE_CONSENT</code>, <code>DOMAIN</code>, <code>FRAUDSTER</code>, <code>SESSION</code> and <code>SPEAKER</code>.</p>"
1871        }
1872      },
1873      "documentation":"<p>The specified resource cannot be found. Check the <code>ResourceType</code> and error message for more details.</p>",
1874      "exception":true
1875    },
1876    "ResourceType":{
1877      "type":"string",
1878      "enum":[
1879        "BATCH_JOB",
1880        "COMPLIANCE_CONSENT",
1881        "DOMAIN",
1882        "FRAUDSTER",
1883        "SESSION",
1884        "SPEAKER",
1885        "WATCHLIST"
1886      ]
1887    },
1888    "ResponseWatchlistIds":{
1889      "type":"list",
1890      "member":{"shape":"WatchlistId"}
1891    },
1892    "S3Uri":{
1893      "type":"string",
1894      "max":1024,
1895      "min":0,
1896      "pattern":"^s3://[a-z0-9][\\.\\-a-z0-9]{1,61}[a-z0-9](/.*)?$"
1897    },
1898    "Score":{
1899      "type":"integer",
1900      "box":true,
1901      "max":100,
1902      "min":0
1903    },
1904    "ServerSideEncryptionConfiguration":{
1905      "type":"structure",
1906      "required":["KmsKeyId"],
1907      "members":{
1908        "KmsKeyId":{
1909          "shape":"KmsKeyId",
1910          "documentation":"<p>The identifier of the KMS key to use to encrypt data stored by Voice ID. Voice ID doesn't support asymmetric customer managed keys. </p>"
1911        }
1912      },
1913      "documentation":"<p>The configuration containing information about the customer managed key used for encrypting customer data.</p>"
1914    },
1915    "ServerSideEncryptionUpdateDetails":{
1916      "type":"structure",
1917      "members":{
1918        "Message":{
1919          "shape":"String",
1920          "documentation":"<p>Message explaining the current UpdateStatus. When the UpdateStatus is FAILED, this message explains the cause of the failure.</p>"
1921        },
1922        "OldKmsKeyId":{
1923          "shape":"KmsKeyId",
1924          "documentation":"<p>The previous KMS key ID the domain was encrypted with, before ServerSideEncryptionConfiguration was updated to a new KMS key ID.</p>"
1925        },
1926        "UpdateStatus":{
1927          "shape":"ServerSideEncryptionUpdateStatus",
1928          "documentation":"<p>Status of the server-side encryption update. During an update, if there is an issue with the domain's current or old KMS key ID, such as an inaccessible or disabled key, then the status is FAILED. In order to resolve this, the key needs to be made accessible, and then an UpdateDomain call with the existing server-side encryption configuration will re-attempt this update process.</p>"
1929        }
1930      },
1931      "documentation":"<p>Details about the most recent server-side encryption configuration update. When the server-side encryption configuration is changed, dependency on the old KMS key is removed through an asynchronous process. When this update is complete, the domain’s data can only be accessed using the new KMS key.</p>"
1932    },
1933    "ServerSideEncryptionUpdateStatus":{
1934      "type":"string",
1935      "enum":[
1936        "IN_PROGRESS",
1937        "COMPLETED",
1938        "FAILED"
1939      ]
1940    },
1941    "ServiceQuotaExceededException":{
1942      "type":"structure",
1943      "members":{
1944        "Message":{"shape":"String"}
1945      },
1946      "documentation":"<p>The request exceeded the service quota. Refer to <a href=\"https://docs.aws.amazon.com/connect/latest/adminguide/amazon-connect-service-limits.html#voiceid-quotas\">Voice ID Service Quotas</a> and try your request again.</p>",
1947      "exception":true
1948    },
1949    "SessionId":{
1950      "type":"string",
1951      "max":25,
1952      "min":25,
1953      "pattern":"^id#[a-zA-Z0-9]{22}$"
1954    },
1955    "SessionName":{
1956      "type":"string",
1957      "max":36,
1958      "min":1,
1959      "pattern":"^[a-zA-Z0-9][a-zA-Z0-9_-]*$"
1960    },
1961    "SessionNameOrId":{
1962      "type":"string",
1963      "max":36,
1964      "min":1,
1965      "pattern":"^(id#[a-zA-Z0-9]{22}|[a-zA-Z0-9][a-zA-Z0-9_-]*)$"
1966    },
1967    "Speaker":{
1968      "type":"structure",
1969      "members":{
1970        "CreatedAt":{
1971          "shape":"Timestamp",
1972          "documentation":"<p>A timestamp of when the speaker was created. </p>"
1973        },
1974        "CustomerSpeakerId":{
1975          "shape":"CustomerSpeakerId",
1976          "documentation":"<p>The client-provided identifier for the speaker.</p>"
1977        },
1978        "DomainId":{
1979          "shape":"DomainId",
1980          "documentation":"<p>The identifier of the domain that contains the speaker.</p>"
1981        },
1982        "GeneratedSpeakerId":{
1983          "shape":"GeneratedSpeakerId",
1984          "documentation":"<p>The service-generated identifier for the speaker.</p>"
1985        },
1986        "LastAccessedAt":{
1987          "shape":"Timestamp",
1988          "documentation":"<p>The timestamp of when the speaker was last accessed for enrollment, re-enrollment or a successful authentication. This timestamp is accurate to one hour.</p>"
1989        },
1990        "Status":{
1991          "shape":"SpeakerStatus",
1992          "documentation":"<p>The current status of the speaker.</p>"
1993        },
1994        "UpdatedAt":{
1995          "shape":"Timestamp",
1996          "documentation":"<p>A timestamp of the speaker's last update.</p>"
1997        }
1998      },
1999      "documentation":"<p>Contains all the information about a speaker.</p>"
2000    },
2001    "SpeakerEnrollmentJob":{
2002      "type":"structure",
2003      "members":{
2004        "CreatedAt":{
2005          "shape":"Timestamp",
2006          "documentation":"<p>A timestamp of when the speaker enrollment job was created.</p>"
2007        },
2008        "DataAccessRoleArn":{
2009          "shape":"IamRoleArn",
2010          "documentation":"<p>The IAM role Amazon Resource Name (ARN) that grants Voice ID permissions to access customer's buckets to read the input manifest file and write the job output file.</p>"
2011        },
2012        "DomainId":{
2013          "shape":"DomainId",
2014          "documentation":"<p>The identifier of the domain that contains the speaker enrollment job.</p>"
2015        },
2016        "EndedAt":{
2017          "shape":"Timestamp",
2018          "documentation":"<p>A timestamp of when the speaker enrollment job ended. </p>"
2019        },
2020        "EnrollmentConfig":{
2021          "shape":"EnrollmentConfig",
2022          "documentation":"<p>The configuration that defines the action to take when the speaker is already enrolled in Voice ID, and the <code>FraudDetectionConfig</code> to use.</p>"
2023        },
2024        "FailureDetails":{
2025          "shape":"FailureDetails",
2026          "documentation":"<p>Contains details that are populated when an entire batch job fails. In cases of individual registration job failures, the batch job as a whole doesn't fail; it is completed with a <code>JobStatus</code> of <code>COMPLETED_WITH_ERRORS</code>. You can use the job output file to identify the individual registration requests that failed.</p>"
2027        },
2028        "InputDataConfig":{
2029          "shape":"InputDataConfig",
2030          "documentation":"<p>The input data config containing an S3 URI for the input manifest file that contains the list of speaker enrollment job requests.</p>"
2031        },
2032        "JobId":{
2033          "shape":"JobId",
2034          "documentation":"<p>The service-generated identifier for the speaker enrollment job.</p>"
2035        },
2036        "JobName":{
2037          "shape":"JobName",
2038          "documentation":"<p>The client-provided name for the speaker enrollment job.</p>"
2039        },
2040        "JobProgress":{
2041          "shape":"JobProgress",
2042          "documentation":"<p>Provides details on job progress. This field shows the completed percentage of registration requests listed in the input file.</p>"
2043        },
2044        "JobStatus":{
2045          "shape":"SpeakerEnrollmentJobStatus",
2046          "documentation":"<p>The current status of the speaker enrollment job.</p>"
2047        },
2048        "OutputDataConfig":{
2049          "shape":"OutputDataConfig",
2050          "documentation":"<p>The output data config containing the S3 location where Voice ID writes the job output file; you must also include a KMS key ID to encrypt the file.</p>"
2051        }
2052      },
2053      "documentation":"<p>Contains all the information about a speaker enrollment job.</p>"
2054    },
2055    "SpeakerEnrollmentJobStatus":{
2056      "type":"string",
2057      "enum":[
2058        "SUBMITTED",
2059        "IN_PROGRESS",
2060        "COMPLETED",
2061        "COMPLETED_WITH_ERRORS",
2062        "FAILED"
2063      ]
2064    },
2065    "SpeakerEnrollmentJobSummaries":{
2066      "type":"list",
2067      "member":{"shape":"SpeakerEnrollmentJobSummary"}
2068    },
2069    "SpeakerEnrollmentJobSummary":{
2070      "type":"structure",
2071      "members":{
2072        "CreatedAt":{
2073          "shape":"Timestamp",
2074          "documentation":"<p>A timestamp of when of the speaker enrollment job was created.</p>"
2075        },
2076        "DomainId":{
2077          "shape":"DomainId",
2078          "documentation":"<p>The identifier of the domain that contains the speaker enrollment job.</p>"
2079        },
2080        "EndedAt":{
2081          "shape":"Timestamp",
2082          "documentation":"<p>A timestamp of when the speaker enrollment job ended.</p>"
2083        },
2084        "FailureDetails":{
2085          "shape":"FailureDetails",
2086          "documentation":"<p>Contains details that are populated when an entire batch job fails. In cases of individual registration job failures, the batch job as a whole doesn't fail; it is completed with a <code>JobStatus</code> of <code>COMPLETED_WITH_ERRORS</code>. You can use the job output file to identify the individual registration requests that failed.</p>"
2087        },
2088        "JobId":{
2089          "shape":"JobId",
2090          "documentation":"<p>The service-generated identifier for the speaker enrollment job.</p>"
2091        },
2092        "JobName":{
2093          "shape":"JobName",
2094          "documentation":"<p>The client-provided name for the speaker enrollment job.</p>"
2095        },
2096        "JobProgress":{
2097          "shape":"JobProgress",
2098          "documentation":"<p>Provides details regarding job progress. This field shows the completed percentage of enrollment requests listed in the input file.</p>"
2099        },
2100        "JobStatus":{
2101          "shape":"SpeakerEnrollmentJobStatus",
2102          "documentation":"<p>The current status of the speaker enrollment job.</p>"
2103        }
2104      },
2105      "documentation":"<p>Contains a summary of information about a speaker enrollment job.</p>"
2106    },
2107    "SpeakerId":{
2108      "type":"string",
2109      "max":256,
2110      "min":1,
2111      "pattern":"^(id#[a-zA-Z0-9]{22}|[a-zA-Z0-9][a-zA-Z0-9_-]*)$",
2112      "sensitive":true
2113    },
2114    "SpeakerStatus":{
2115      "type":"string",
2116      "enum":[
2117        "ENROLLED",
2118        "EXPIRED",
2119        "OPTED_OUT",
2120        "PENDING"
2121      ]
2122    },
2123    "SpeakerSummaries":{
2124      "type":"list",
2125      "member":{"shape":"SpeakerSummary"}
2126    },
2127    "SpeakerSummary":{
2128      "type":"structure",
2129      "members":{
2130        "CreatedAt":{
2131          "shape":"Timestamp",
2132          "documentation":"<p>A timestamp showing the speaker's creation time. </p>"
2133        },
2134        "CustomerSpeakerId":{
2135          "shape":"CustomerSpeakerId",
2136          "documentation":"<p>The client-provided identifier for the speaker.</p>"
2137        },
2138        "DomainId":{
2139          "shape":"DomainId",
2140          "documentation":"<p>The identifier of the domain that contains the speaker.</p>"
2141        },
2142        "GeneratedSpeakerId":{
2143          "shape":"GeneratedSpeakerId",
2144          "documentation":"<p>The service-generated identifier for the speaker. </p>"
2145        },
2146        "LastAccessedAt":{
2147          "shape":"Timestamp",
2148          "documentation":"<p>The timestamp when the speaker was last accessed for enrollment, re-enrollment or a successful authentication. This timestamp is accurate to one hour.</p>"
2149        },
2150        "Status":{
2151          "shape":"SpeakerStatus",
2152          "documentation":"<p>The current status of the speaker.</p>"
2153        },
2154        "UpdatedAt":{
2155          "shape":"Timestamp",
2156          "documentation":"<p>A timestamp showing the speaker's last update.</p>"
2157        }
2158      },
2159      "documentation":"<p>Contains a summary of information about a speaker.</p>"
2160    },
2161    "StartFraudsterRegistrationJobRequest":{
2162      "type":"structure",
2163      "required":[
2164        "DataAccessRoleArn",
2165        "DomainId",
2166        "InputDataConfig",
2167        "OutputDataConfig"
2168      ],
2169      "members":{
2170        "ClientToken":{
2171          "shape":"ClientTokenString",
2172          "documentation":"<p>A unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If not provided, the Amazon Web Services SDK populates this field. For more information about idempotency, see <a href=\"https://aws.amazon.com/builders-library/making-retries-safe-with-idempotent-APIs/\">Making retries safe with idempotent APIs</a>.</p>",
2173          "idempotencyToken":true
2174        },
2175        "DataAccessRoleArn":{
2176          "shape":"IamRoleArn",
2177          "documentation":"<p>The IAM role Amazon Resource Name (ARN) that grants Voice ID permissions to access customer's buckets to read the input manifest file and write the Job output file. Refer to the <a href=\"https://docs.aws.amazon.com/connect/latest/adminguide/voiceid-fraudster-watchlist.html\">Create and edit a fraudster watchlist</a> documentation for the permissions needed in this role.</p>"
2178        },
2179        "DomainId":{
2180          "shape":"DomainId",
2181          "documentation":"<p>The identifier of the domain that contains the fraudster registration job and in which the fraudsters are registered.</p>"
2182        },
2183        "InputDataConfig":{
2184          "shape":"InputDataConfig",
2185          "documentation":"<p>The input data config containing an S3 URI for the input manifest file that contains the list of fraudster registration requests.</p>"
2186        },
2187        "JobName":{
2188          "shape":"JobName",
2189          "documentation":"<p>The name of the new fraudster registration job.</p>"
2190        },
2191        "OutputDataConfig":{
2192          "shape":"OutputDataConfig",
2193          "documentation":"<p>The output data config containing the S3 location where Voice ID writes the job output file; you must also include a KMS key ID to encrypt the file.</p>"
2194        },
2195        "RegistrationConfig":{
2196          "shape":"RegistrationConfig",
2197          "documentation":"<p>The registration config containing details such as the action to take when a duplicate fraudster is detected, and the similarity threshold to use for detecting a duplicate fraudster. </p>"
2198        }
2199      }
2200    },
2201    "StartFraudsterRegistrationJobResponse":{
2202      "type":"structure",
2203      "members":{
2204        "Job":{
2205          "shape":"FraudsterRegistrationJob",
2206          "documentation":"<p>Details about the started fraudster registration job.</p>"
2207        }
2208      }
2209    },
2210    "StartSpeakerEnrollmentJobRequest":{
2211      "type":"structure",
2212      "required":[
2213        "DataAccessRoleArn",
2214        "DomainId",
2215        "InputDataConfig",
2216        "OutputDataConfig"
2217      ],
2218      "members":{
2219        "ClientToken":{
2220          "shape":"ClientTokenString",
2221          "documentation":"<p>A unique, case-sensitive identifier that you provide to ensure the idempotency of the request. If not provided, the Amazon Web Services SDK populates this field. For more information about idempotency, see <a href=\"https://aws.amazon.com/builders-library/making-retries-safe-with-idempotent-APIs/\">Making retries safe with idempotent APIs</a>.</p>",
2222          "idempotencyToken":true
2223        },
2224        "DataAccessRoleArn":{
2225          "shape":"IamRoleArn",
2226          "documentation":"<p>The IAM role Amazon Resource Name (ARN) that grants Voice ID permissions to access customer's buckets to read the input manifest file and write the job output file. Refer to <a href=\"https://docs.aws.amazon.com/connect/latest/adminguide/voiceid-batch-enrollment.html\">Batch enrollment using audio data from prior calls</a> for the permissions needed in this role.</p>"
2227        },
2228        "DomainId":{
2229          "shape":"DomainId",
2230          "documentation":"<p>The identifier of the domain that contains the speaker enrollment job and in which the speakers are enrolled. </p>"
2231        },
2232        "EnrollmentConfig":{
2233          "shape":"EnrollmentConfig",
2234          "documentation":"<p>The enrollment config that contains details such as the action to take when a speaker is already enrolled in Voice ID or when a speaker is identified as a fraudster.</p>"
2235        },
2236        "InputDataConfig":{
2237          "shape":"InputDataConfig",
2238          "documentation":"<p>The input data config containing the S3 location for the input manifest file that contains the list of speaker enrollment requests.</p>"
2239        },
2240        "JobName":{
2241          "shape":"JobName",
2242          "documentation":"<p>A name for your speaker enrollment job.</p>"
2243        },
2244        "OutputDataConfig":{
2245          "shape":"OutputDataConfig",
2246          "documentation":"<p>The output data config containing the S3 location where Voice ID writes the job output file; you must also include a KMS key ID to encrypt the file.</p>"
2247        }
2248      }
2249    },
2250    "StartSpeakerEnrollmentJobResponse":{
2251      "type":"structure",
2252      "members":{
2253        "Job":{
2254          "shape":"SpeakerEnrollmentJob",
2255          "documentation":"<p>Details about the started speaker enrollment job.</p>"
2256        }
2257      }
2258    },
2259    "StreamingStatus":{
2260      "type":"string",
2261      "enum":[
2262        "PENDING_CONFIGURATION",
2263        "ONGOING",
2264        "ENDED"
2265      ]
2266    },
2267    "String":{
2268      "type":"string",
2269      "min":1
2270    },
2271    "Tag":{
2272      "type":"structure",
2273      "required":[
2274        "Key",
2275        "Value"
2276      ],
2277      "members":{
2278        "Key":{
2279          "shape":"TagKey",
2280          "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>"
2281        },
2282        "Value":{
2283          "shape":"TagValue",
2284          "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>"
2285        }
2286      },
2287      "documentation":"<p>The tags used to organize, track, or control access for this resource. For example, { \"tags\": {\"key1\":\"value1\", \"key2\":\"value2\"} }.</p>"
2288    },
2289    "TagKey":{
2290      "type":"string",
2291      "max":128,
2292      "min":1,
2293      "pattern":"^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-@]*)$",
2294      "sensitive":true
2295    },
2296    "TagKeyList":{
2297      "type":"list",
2298      "member":{"shape":"TagKey"},
2299      "max":200,
2300      "min":0
2301    },
2302    "TagList":{
2303      "type":"list",
2304      "member":{"shape":"Tag"},
2305      "max":200,
2306      "min":0
2307    },
2308    "TagResourceRequest":{
2309      "type":"structure",
2310      "required":[
2311        "ResourceArn",
2312        "Tags"
2313      ],
2314      "members":{
2315        "ResourceArn":{
2316          "shape":"AmazonResourceName",
2317          "documentation":"<p>The Amazon Resource Name (ARN) of the Voice ID resource you want to tag.</p>"
2318        },
2319        "Tags":{
2320          "shape":"TagList",
2321          "documentation":"<p>The list of tags to assign to the specified resource.</p>"
2322        }
2323      }
2324    },
2325    "TagResourceResponse":{
2326      "type":"structure",
2327      "members":{
2328      }
2329    },
2330    "TagValue":{
2331      "type":"string",
2332      "max":256,
2333      "min":0,
2334      "pattern":"^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-@]*)$",
2335      "sensitive":true
2336    },
2337    "ThrottlingException":{
2338      "type":"structure",
2339      "members":{
2340        "Message":{"shape":"String"}
2341      },
2342      "documentation":"<p>The request was denied due to request throttling. Please slow down your request rate. Refer to <a href=\"https://docs.aws.amazon.com/connect/latest/adminguide/amazon-connect-service-limits.html##voiceid-api-quotas\"> Amazon Connect Voice ID Service API throttling quotas </a> and try your request again.</p>",
2343      "exception":true
2344    },
2345    "Timestamp":{"type":"timestamp"},
2346    "UniqueIdLarge":{
2347      "type":"string",
2348      "max":22,
2349      "min":22,
2350      "pattern":"^[a-zA-Z0-9]{22}$"
2351    },
2352    "UntagResourceRequest":{
2353      "type":"structure",
2354      "required":[
2355        "ResourceArn",
2356        "TagKeys"
2357      ],
2358      "members":{
2359        "ResourceArn":{
2360          "shape":"AmazonResourceName",
2361          "documentation":"<p>The Amazon Resource Name (ARN) of the Voice ID resource you want to remove tags from.</p>"
2362        },
2363        "TagKeys":{
2364          "shape":"TagKeyList",
2365          "documentation":"<p>The list of tag keys you want to remove from the specified resource.</p>"
2366        }
2367      }
2368    },
2369    "UntagResourceResponse":{
2370      "type":"structure",
2371      "members":{
2372      }
2373    },
2374    "UpdateDomainRequest":{
2375      "type":"structure",
2376      "required":[
2377        "DomainId",
2378        "Name",
2379        "ServerSideEncryptionConfiguration"
2380      ],
2381      "members":{
2382        "Description":{
2383          "shape":"Description",
2384          "documentation":"<p>A brief description about this domain.</p>"
2385        },
2386        "DomainId":{
2387          "shape":"DomainId",
2388          "documentation":"<p>The identifier of the domain to be updated.</p>"
2389        },
2390        "Name":{
2391          "shape":"DomainName",
2392          "documentation":"<p>The name of the domain.</p>"
2393        },
2394        "ServerSideEncryptionConfiguration":{
2395          "shape":"ServerSideEncryptionConfiguration",
2396          "documentation":"<p>The configuration, containing the KMS key identifier, to be used by Voice ID for the server-side encryption of your data. Changing the domain's associated KMS key immediately triggers an asynchronous process to remove dependency on the old KMS key, such that the domain's data can only be accessed using the new KMS key. The domain's <code>ServerSideEncryptionUpdateDetails</code> contains the details for this process.</p>"
2397        }
2398      }
2399    },
2400    "UpdateDomainResponse":{
2401      "type":"structure",
2402      "members":{
2403        "Domain":{
2404          "shape":"Domain",
2405          "documentation":"<p>Details about the updated domain</p>"
2406        }
2407      }
2408    },
2409    "UpdateWatchlistRequest":{
2410      "type":"structure",
2411      "required":[
2412        "DomainId",
2413        "WatchlistId"
2414      ],
2415      "members":{
2416        "Description":{
2417          "shape":"WatchlistDescription",
2418          "documentation":"<p>A brief description about this watchlist.</p>"
2419        },
2420        "DomainId":{
2421          "shape":"DomainId",
2422          "documentation":"<p>The identifier of the domain that contains the watchlist.</p>"
2423        },
2424        "Name":{
2425          "shape":"WatchlistName",
2426          "documentation":"<p>The name of the watchlist.</p>"
2427        },
2428        "WatchlistId":{
2429          "shape":"WatchlistId",
2430          "documentation":"<p>The identifier of the watchlist to be updated.</p>"
2431        }
2432      }
2433    },
2434    "UpdateWatchlistResponse":{
2435      "type":"structure",
2436      "members":{
2437        "Watchlist":{
2438          "shape":"Watchlist",
2439          "documentation":"<p>Details about the updated watchlist.</p>"
2440        }
2441      }
2442    },
2443    "ValidationException":{
2444      "type":"structure",
2445      "members":{
2446        "Message":{"shape":"String"}
2447      },
2448      "documentation":"<p>The request failed one or more validations; check the error message for more details.</p>",
2449      "exception":true
2450    },
2451    "VoiceSpoofingRisk":{
2452      "type":"structure",
2453      "required":["RiskScore"],
2454      "members":{
2455        "RiskScore":{
2456          "shape":"Score",
2457          "documentation":"<p>The score indicating the likelihood of speaker’s voice being spoofed.</p>"
2458        }
2459      },
2460      "documentation":"<p>The details resulting from 'Voice Spoofing Risk' analysis of the speaker.</p>"
2461    },
2462    "Watchlist":{
2463      "type":"structure",
2464      "members":{
2465        "CreatedAt":{
2466          "shape":"Timestamp",
2467          "documentation":"<p>The timestamp of when the watchlist was created.</p>"
2468        },
2469        "DefaultWatchlist":{
2470          "shape":"Boolean",
2471          "documentation":"<p>Whether the specified watchlist is the default watchlist of a domain.</p>"
2472        },
2473        "Description":{
2474          "shape":"WatchlistDescription",
2475          "documentation":"<p>The description of the watchlist.</p>"
2476        },
2477        "DomainId":{
2478          "shape":"DomainId",
2479          "documentation":"<p>The identifier of the domain that contains the watchlist.</p>"
2480        },
2481        "Name":{
2482          "shape":"WatchlistName",
2483          "documentation":"<p>The name for the watchlist.</p>"
2484        },
2485        "UpdatedAt":{
2486          "shape":"Timestamp",
2487          "documentation":"<p>The timestamp of when the watchlist was updated.</p>"
2488        },
2489        "WatchlistId":{
2490          "shape":"WatchlistId",
2491          "documentation":"<p>The identifier of the watchlist.</p>"
2492        }
2493      },
2494      "documentation":"<p>Contains all the information about a watchlist.</p>"
2495    },
2496    "WatchlistDescription":{
2497      "type":"string",
2498      "max":1024,
2499      "min":1,
2500      "pattern":"^([\\p{L}\\p{Z}\\p{N}_.:/=+\\-%@]*)$",
2501      "sensitive":true
2502    },
2503    "WatchlistDetails":{
2504      "type":"structure",
2505      "required":["DefaultWatchlistId"],
2506      "members":{
2507        "DefaultWatchlistId":{
2508          "shape":"WatchlistId",
2509          "documentation":"<p>The identifier of the default watchlist.</p>"
2510        }
2511      },
2512      "documentation":"<p>Details of the watchlists in a domain.</p>"
2513    },
2514    "WatchlistId":{
2515      "type":"string",
2516      "max":22,
2517      "min":22,
2518      "pattern":"^[a-zA-Z0-9]{22}$"
2519    },
2520    "WatchlistName":{
2521      "type":"string",
2522      "max":256,
2523      "min":1,
2524      "pattern":"^[a-zA-Z0-9][a-zA-Z0-9_-]*$",
2525      "sensitive":true
2526    },
2527    "WatchlistSummaries":{
2528      "type":"list",
2529      "member":{"shape":"WatchlistSummary"}
2530    },
2531    "WatchlistSummary":{
2532      "type":"structure",
2533      "members":{
2534        "CreatedAt":{
2535          "shape":"Timestamp",
2536          "documentation":"<p>The timestamp of when the watchlist was created.</p>"
2537        },
2538        "DefaultWatchlist":{
2539          "shape":"Boolean",
2540          "documentation":"<p>Whether the specified watchlist is the default watchlist of a domain.</p>"
2541        },
2542        "Description":{
2543          "shape":"WatchlistDescription",
2544          "documentation":"<p>The description of the watchlist.</p>"
2545        },
2546        "DomainId":{
2547          "shape":"DomainId",
2548          "documentation":"<p>The identifier of the domain that contains the watchlist.</p>"
2549        },
2550        "Name":{
2551          "shape":"WatchlistName",
2552          "documentation":"<p>The name for the watchlist.</p>"
2553        },
2554        "UpdatedAt":{
2555          "shape":"Timestamp",
2556          "documentation":"<p>The timestamp of when the watchlist was last updated.</p>"
2557        },
2558        "WatchlistId":{
2559          "shape":"WatchlistId",
2560          "documentation":"<p>The identifier of the watchlist.</p>"
2561        }
2562      },
2563      "documentation":"<p>Contains a summary of information about a watchlist.</p>"
2564    }
2565  },
2566  "documentation":"<p>Amazon Connect Voice ID provides real-time caller authentication and fraud risk detection, which make voice interactions in contact centers more secure and efficient.</p>"
2567}
2568