1{
2  "version":"2.0",
3  "metadata":{
4    "apiVersion":"2021-11-01",
5    "endpointPrefix":"aoss",
6    "jsonVersion":"1.0",
7    "protocol":"json",
8    "serviceFullName":"OpenSearch Service Serverless",
9    "serviceId":"OpenSearchServerless",
10    "signatureVersion":"v4",
11    "signingName":"aoss",
12    "targetPrefix":"OpenSearchServerless",
13    "uid":"opensearchserverless-2021-11-01"
14  },
15  "operations":{
16    "BatchGetCollection":{
17      "name":"BatchGetCollection",
18      "http":{
19        "method":"POST",
20        "requestUri":"/"
21      },
22      "input":{"shape":"BatchGetCollectionRequest"},
23      "output":{"shape":"BatchGetCollectionResponse"},
24      "errors":[
25        {"shape":"InternalServerException"},
26        {"shape":"ValidationException"}
27      ],
28      "documentation":"<p>Returns attributes for one or more collections, including the collection endpoint and the OpenSearch Dashboards endpoint. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-manage.html\">Creating and managing Amazon OpenSearch Serverless collections</a>.</p>"
29    },
30    "BatchGetEffectiveLifecyclePolicy":{
31      "name":"BatchGetEffectiveLifecyclePolicy",
32      "http":{
33        "method":"POST",
34        "requestUri":"/"
35      },
36      "input":{"shape":"BatchGetEffectiveLifecyclePolicyRequest"},
37      "output":{"shape":"BatchGetEffectiveLifecyclePolicyResponse"},
38      "errors":[
39        {"shape":"InternalServerException"},
40        {"shape":"ValidationException"}
41      ],
42      "documentation":"<p>Returns a list of successful and failed retrievals for the OpenSearch Serverless indexes. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-lifecycle.html#serverless-lifecycle-list\">Viewing data lifecycle policies</a>.</p>"
43    },
44    "BatchGetLifecyclePolicy":{
45      "name":"BatchGetLifecyclePolicy",
46      "http":{
47        "method":"POST",
48        "requestUri":"/"
49      },
50      "input":{"shape":"BatchGetLifecyclePolicyRequest"},
51      "output":{"shape":"BatchGetLifecyclePolicyResponse"},
52      "errors":[
53        {"shape":"InternalServerException"},
54        {"shape":"ValidationException"}
55      ],
56      "documentation":"<p>Returns one or more configured OpenSearch Serverless lifecycle policies. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-lifecycle.html#serverless-lifecycle-list\">Viewing data lifecycle policies</a>.</p>"
57    },
58    "BatchGetVpcEndpoint":{
59      "name":"BatchGetVpcEndpoint",
60      "http":{
61        "method":"POST",
62        "requestUri":"/"
63      },
64      "input":{"shape":"BatchGetVpcEndpointRequest"},
65      "output":{"shape":"BatchGetVpcEndpointResponse"},
66      "errors":[
67        {"shape":"InternalServerException"},
68        {"shape":"ValidationException"}
69      ],
70      "documentation":"<p>Returns attributes for one or more VPC endpoints associated with the current account. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-vpc.html\">Access Amazon OpenSearch Serverless using an interface endpoint</a>.</p>"
71    },
72    "CreateAccessPolicy":{
73      "name":"CreateAccessPolicy",
74      "http":{
75        "method":"POST",
76        "requestUri":"/"
77      },
78      "input":{"shape":"CreateAccessPolicyRequest"},
79      "output":{"shape":"CreateAccessPolicyResponse"},
80      "errors":[
81        {"shape":"InternalServerException"},
82        {"shape":"ConflictException"},
83        {"shape":"ValidationException"},
84        {"shape":"ServiceQuotaExceededException"}
85      ],
86      "documentation":"<p>Creates a data access policy for OpenSearch Serverless. Access policies limit access to collections and the resources within them, and allow a user to access that data irrespective of the access mechanism or network source. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-data-access.html\">Data access control for Amazon OpenSearch Serverless</a>.</p>",
87      "idempotent":true
88    },
89    "CreateCollection":{
90      "name":"CreateCollection",
91      "http":{
92        "method":"POST",
93        "requestUri":"/"
94      },
95      "input":{"shape":"CreateCollectionRequest"},
96      "output":{"shape":"CreateCollectionResponse"},
97      "errors":[
98        {"shape":"OcuLimitExceededException"},
99        {"shape":"InternalServerException"},
100        {"shape":"ConflictException"},
101        {"shape":"ValidationException"},
102        {"shape":"ServiceQuotaExceededException"}
103      ],
104      "documentation":"<p>Creates a new OpenSearch Serverless collection. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-manage.html\">Creating and managing Amazon OpenSearch Serverless collections</a>.</p>",
105      "idempotent":true
106    },
107    "CreateLifecyclePolicy":{
108      "name":"CreateLifecyclePolicy",
109      "http":{
110        "method":"POST",
111        "requestUri":"/"
112      },
113      "input":{"shape":"CreateLifecyclePolicyRequest"},
114      "output":{"shape":"CreateLifecyclePolicyResponse"},
115      "errors":[
116        {"shape":"InternalServerException"},
117        {"shape":"ConflictException"},
118        {"shape":"ValidationException"},
119        {"shape":"ServiceQuotaExceededException"}
120      ],
121      "documentation":"<p>Creates a lifecyle policy to be applied to OpenSearch Serverless indexes. Lifecycle policies define the number of days or hours to retain the data on an OpenSearch Serverless index. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-lifecycle.html#serverless-lifecycle-create\">Creating data lifecycle policies</a>.</p>",
122      "idempotent":true
123    },
124    "CreateSecurityConfig":{
125      "name":"CreateSecurityConfig",
126      "http":{
127        "method":"POST",
128        "requestUri":"/"
129      },
130      "input":{"shape":"CreateSecurityConfigRequest"},
131      "output":{"shape":"CreateSecurityConfigResponse"},
132      "errors":[
133        {"shape":"InternalServerException"},
134        {"shape":"ConflictException"},
135        {"shape":"ValidationException"},
136        {"shape":"ServiceQuotaExceededException"}
137      ],
138      "documentation":"<p>Specifies a security configuration for OpenSearch Serverless. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-saml.html\">SAML authentication for Amazon OpenSearch Serverless</a>. </p>",
139      "idempotent":true
140    },
141    "CreateSecurityPolicy":{
142      "name":"CreateSecurityPolicy",
143      "http":{
144        "method":"POST",
145        "requestUri":"/"
146      },
147      "input":{"shape":"CreateSecurityPolicyRequest"},
148      "output":{"shape":"CreateSecurityPolicyResponse"},
149      "errors":[
150        {"shape":"InternalServerException"},
151        {"shape":"ConflictException"},
152        {"shape":"ValidationException"},
153        {"shape":"ServiceQuotaExceededException"}
154      ],
155      "documentation":"<p>Creates a security policy to be used by one or more OpenSearch Serverless collections. Security policies provide access to a collection and its OpenSearch Dashboards endpoint from public networks or specific VPC endpoints. They also allow you to secure a collection with a KMS encryption key. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-network.html\">Network access for Amazon OpenSearch Serverless</a> and <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-encryption.html\">Encryption at rest for Amazon OpenSearch Serverless</a>.</p>",
156      "idempotent":true
157    },
158    "CreateVpcEndpoint":{
159      "name":"CreateVpcEndpoint",
160      "http":{
161        "method":"POST",
162        "requestUri":"/"
163      },
164      "input":{"shape":"CreateVpcEndpointRequest"},
165      "output":{"shape":"CreateVpcEndpointResponse"},
166      "errors":[
167        {"shape":"InternalServerException"},
168        {"shape":"ConflictException"},
169        {"shape":"ValidationException"},
170        {"shape":"ServiceQuotaExceededException"}
171      ],
172      "documentation":"<p>Creates an OpenSearch Serverless-managed interface VPC endpoint. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-vpc.html\">Access Amazon OpenSearch Serverless using an interface endpoint</a>.</p>",
173      "idempotent":true
174    },
175    "DeleteAccessPolicy":{
176      "name":"DeleteAccessPolicy",
177      "http":{
178        "method":"POST",
179        "requestUri":"/"
180      },
181      "input":{"shape":"DeleteAccessPolicyRequest"},
182      "output":{"shape":"DeleteAccessPolicyResponse"},
183      "errors":[
184        {"shape":"InternalServerException"},
185        {"shape":"ResourceNotFoundException"},
186        {"shape":"ConflictException"},
187        {"shape":"ValidationException"}
188      ],
189      "documentation":"<p>Deletes an OpenSearch Serverless access policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-data-access.html\">Data access control for Amazon OpenSearch Serverless</a>.</p>",
190      "idempotent":true
191    },
192    "DeleteCollection":{
193      "name":"DeleteCollection",
194      "http":{
195        "method":"POST",
196        "requestUri":"/"
197      },
198      "input":{"shape":"DeleteCollectionRequest"},
199      "output":{"shape":"DeleteCollectionResponse"},
200      "errors":[
201        {"shape":"InternalServerException"},
202        {"shape":"ResourceNotFoundException"},
203        {"shape":"ConflictException"},
204        {"shape":"ValidationException"}
205      ],
206      "documentation":"<p>Deletes an OpenSearch Serverless collection. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-manage.html\">Creating and managing Amazon OpenSearch Serverless collections</a>.</p>",
207      "idempotent":true
208    },
209    "DeleteLifecyclePolicy":{
210      "name":"DeleteLifecyclePolicy",
211      "http":{
212        "method":"POST",
213        "requestUri":"/"
214      },
215      "input":{"shape":"DeleteLifecyclePolicyRequest"},
216      "output":{"shape":"DeleteLifecyclePolicyResponse"},
217      "errors":[
218        {"shape":"InternalServerException"},
219        {"shape":"ResourceNotFoundException"},
220        {"shape":"ConflictException"},
221        {"shape":"ValidationException"}
222      ],
223      "documentation":"<p>Deletes an OpenSearch Serverless lifecycle policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-lifecycle.html#serverless-lifecycle-delete\">Deleting data lifecycle policies</a>.</p>",
224      "idempotent":true
225    },
226    "DeleteSecurityConfig":{
227      "name":"DeleteSecurityConfig",
228      "http":{
229        "method":"POST",
230        "requestUri":"/"
231      },
232      "input":{"shape":"DeleteSecurityConfigRequest"},
233      "output":{"shape":"DeleteSecurityConfigResponse"},
234      "errors":[
235        {"shape":"InternalServerException"},
236        {"shape":"ResourceNotFoundException"},
237        {"shape":"ConflictException"},
238        {"shape":"ValidationException"}
239      ],
240      "documentation":"<p>Deletes a security configuration for OpenSearch Serverless. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-saml.html\">SAML authentication for Amazon OpenSearch Serverless</a>.</p>",
241      "idempotent":true
242    },
243    "DeleteSecurityPolicy":{
244      "name":"DeleteSecurityPolicy",
245      "http":{
246        "method":"POST",
247        "requestUri":"/"
248      },
249      "input":{"shape":"DeleteSecurityPolicyRequest"},
250      "output":{"shape":"DeleteSecurityPolicyResponse"},
251      "errors":[
252        {"shape":"InternalServerException"},
253        {"shape":"ResourceNotFoundException"},
254        {"shape":"ConflictException"},
255        {"shape":"ValidationException"}
256      ],
257      "documentation":"<p>Deletes an OpenSearch Serverless security policy.</p>",
258      "idempotent":true
259    },
260    "DeleteVpcEndpoint":{
261      "name":"DeleteVpcEndpoint",
262      "http":{
263        "method":"POST",
264        "requestUri":"/"
265      },
266      "input":{"shape":"DeleteVpcEndpointRequest"},
267      "output":{"shape":"DeleteVpcEndpointResponse"},
268      "errors":[
269        {"shape":"InternalServerException"},
270        {"shape":"ResourceNotFoundException"},
271        {"shape":"ConflictException"},
272        {"shape":"ValidationException"}
273      ],
274      "documentation":"<p>Deletes an OpenSearch Serverless-managed interface endpoint. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-vpc.html\">Access Amazon OpenSearch Serverless using an interface endpoint</a>.</p>",
275      "idempotent":true
276    },
277    "GetAccessPolicy":{
278      "name":"GetAccessPolicy",
279      "http":{
280        "method":"POST",
281        "requestUri":"/"
282      },
283      "input":{"shape":"GetAccessPolicyRequest"},
284      "output":{"shape":"GetAccessPolicyResponse"},
285      "errors":[
286        {"shape":"InternalServerException"},
287        {"shape":"ResourceNotFoundException"},
288        {"shape":"ValidationException"}
289      ],
290      "documentation":"<p>Returns an OpenSearch Serverless access policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-data-access.html\">Data access control for Amazon OpenSearch Serverless</a>.</p>"
291    },
292    "GetAccountSettings":{
293      "name":"GetAccountSettings",
294      "http":{
295        "method":"POST",
296        "requestUri":"/"
297      },
298      "input":{"shape":"GetAccountSettingsRequest"},
299      "output":{"shape":"GetAccountSettingsResponse"},
300      "errors":[
301        {"shape":"InternalServerException"},
302        {"shape":"ValidationException"}
303      ],
304      "documentation":"<p>Returns account-level settings related to OpenSearch Serverless.</p>"
305    },
306    "GetPoliciesStats":{
307      "name":"GetPoliciesStats",
308      "http":{
309        "method":"POST",
310        "requestUri":"/"
311      },
312      "input":{"shape":"GetPoliciesStatsRequest"},
313      "output":{"shape":"GetPoliciesStatsResponse"},
314      "errors":[
315        {"shape":"InternalServerException"}
316      ],
317      "documentation":"<p>Returns statistical information about your OpenSearch Serverless access policies, security configurations, and security policies.</p>"
318    },
319    "GetSecurityConfig":{
320      "name":"GetSecurityConfig",
321      "http":{
322        "method":"POST",
323        "requestUri":"/"
324      },
325      "input":{"shape":"GetSecurityConfigRequest"},
326      "output":{"shape":"GetSecurityConfigResponse"},
327      "errors":[
328        {"shape":"InternalServerException"},
329        {"shape":"ResourceNotFoundException"},
330        {"shape":"ValidationException"}
331      ],
332      "documentation":"<p>Returns information about an OpenSearch Serverless security configuration. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-saml.html\">SAML authentication for Amazon OpenSearch Serverless</a>.</p>"
333    },
334    "GetSecurityPolicy":{
335      "name":"GetSecurityPolicy",
336      "http":{
337        "method":"POST",
338        "requestUri":"/"
339      },
340      "input":{"shape":"GetSecurityPolicyRequest"},
341      "output":{"shape":"GetSecurityPolicyResponse"},
342      "errors":[
343        {"shape":"InternalServerException"},
344        {"shape":"ResourceNotFoundException"},
345        {"shape":"ValidationException"}
346      ],
347      "documentation":"<p>Returns information about a configured OpenSearch Serverless security policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-network.html\">Network access for Amazon OpenSearch Serverless</a> and <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-encryption.html\">Encryption at rest for Amazon OpenSearch Serverless</a>.</p>"
348    },
349    "ListAccessPolicies":{
350      "name":"ListAccessPolicies",
351      "http":{
352        "method":"POST",
353        "requestUri":"/"
354      },
355      "input":{"shape":"ListAccessPoliciesRequest"},
356      "output":{"shape":"ListAccessPoliciesResponse"},
357      "errors":[
358        {"shape":"InternalServerException"},
359        {"shape":"ValidationException"}
360      ],
361      "documentation":"<p>Returns information about a list of OpenSearch Serverless access policies.</p>"
362    },
363    "ListCollections":{
364      "name":"ListCollections",
365      "http":{
366        "method":"POST",
367        "requestUri":"/"
368      },
369      "input":{"shape":"ListCollectionsRequest"},
370      "output":{"shape":"ListCollectionsResponse"},
371      "errors":[
372        {"shape":"InternalServerException"},
373        {"shape":"ValidationException"}
374      ],
375      "documentation":"<p>Lists all OpenSearch Serverless collections. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-manage.html\">Creating and managing Amazon OpenSearch Serverless collections</a>.</p> <note> <p>Make sure to include an empty request body {} if you don't include any collection filters in the request.</p> </note>"
376    },
377    "ListLifecyclePolicies":{
378      "name":"ListLifecyclePolicies",
379      "http":{
380        "method":"POST",
381        "requestUri":"/"
382      },
383      "input":{"shape":"ListLifecyclePoliciesRequest"},
384      "output":{"shape":"ListLifecyclePoliciesResponse"},
385      "errors":[
386        {"shape":"InternalServerException"},
387        {"shape":"ValidationException"}
388      ],
389      "documentation":"<p>Returns a list of OpenSearch Serverless lifecycle policies. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-lifecycle.html#serverless-lifecycle-list\">Viewing data lifecycle policies</a>.</p>"
390    },
391    "ListSecurityConfigs":{
392      "name":"ListSecurityConfigs",
393      "http":{
394        "method":"POST",
395        "requestUri":"/"
396      },
397      "input":{"shape":"ListSecurityConfigsRequest"},
398      "output":{"shape":"ListSecurityConfigsResponse"},
399      "errors":[
400        {"shape":"InternalServerException"},
401        {"shape":"ValidationException"}
402      ],
403      "documentation":"<p>Returns information about configured OpenSearch Serverless security configurations. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-saml.html\">SAML authentication for Amazon OpenSearch Serverless</a>.</p>"
404    },
405    "ListSecurityPolicies":{
406      "name":"ListSecurityPolicies",
407      "http":{
408        "method":"POST",
409        "requestUri":"/"
410      },
411      "input":{"shape":"ListSecurityPoliciesRequest"},
412      "output":{"shape":"ListSecurityPoliciesResponse"},
413      "errors":[
414        {"shape":"InternalServerException"},
415        {"shape":"ValidationException"}
416      ],
417      "documentation":"<p>Returns information about configured OpenSearch Serverless security policies.</p>"
418    },
419    "ListTagsForResource":{
420      "name":"ListTagsForResource",
421      "http":{
422        "method":"POST",
423        "requestUri":"/"
424      },
425      "input":{"shape":"ListTagsForResourceRequest"},
426      "output":{"shape":"ListTagsForResourceResponse"},
427      "errors":[
428        {"shape":"InternalServerException"},
429        {"shape":"ResourceNotFoundException"},
430        {"shape":"ValidationException"}
431      ],
432      "documentation":"<p>Returns the tags for an OpenSearch Serverless resource. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/tag-collection.html\">Tagging Amazon OpenSearch Serverless collections</a>.</p>"
433    },
434    "ListVpcEndpoints":{
435      "name":"ListVpcEndpoints",
436      "http":{
437        "method":"POST",
438        "requestUri":"/"
439      },
440      "input":{"shape":"ListVpcEndpointsRequest"},
441      "output":{"shape":"ListVpcEndpointsResponse"},
442      "errors":[
443        {"shape":"InternalServerException"},
444        {"shape":"ValidationException"}
445      ],
446      "documentation":"<p>Returns the OpenSearch Serverless-managed interface VPC endpoints associated with the current account. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-vpc.html\">Access Amazon OpenSearch Serverless using an interface endpoint</a>.</p>"
447    },
448    "TagResource":{
449      "name":"TagResource",
450      "http":{
451        "method":"POST",
452        "requestUri":"/"
453      },
454      "input":{"shape":"TagResourceRequest"},
455      "output":{"shape":"TagResourceResponse"},
456      "errors":[
457        {"shape":"InternalServerException"},
458        {"shape":"ResourceNotFoundException"},
459        {"shape":"ConflictException"},
460        {"shape":"ValidationException"},
461        {"shape":"ServiceQuotaExceededException"}
462      ],
463      "documentation":"<p>Associates tags with an OpenSearch Serverless resource. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/tag-collection.html\">Tagging Amazon OpenSearch Serverless collections</a>.</p>"
464    },
465    "UntagResource":{
466      "name":"UntagResource",
467      "http":{
468        "method":"POST",
469        "requestUri":"/"
470      },
471      "input":{"shape":"UntagResourceRequest"},
472      "output":{"shape":"UntagResourceResponse"},
473      "errors":[
474        {"shape":"InternalServerException"},
475        {"shape":"ResourceNotFoundException"},
476        {"shape":"ConflictException"},
477        {"shape":"ValidationException"}
478      ],
479      "documentation":"<p>Removes a tag or set of tags from an OpenSearch Serverless resource. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/tag-collection.html\">Tagging Amazon OpenSearch Serverless collections</a>.</p>"
480    },
481    "UpdateAccessPolicy":{
482      "name":"UpdateAccessPolicy",
483      "http":{
484        "method":"POST",
485        "requestUri":"/"
486      },
487      "input":{"shape":"UpdateAccessPolicyRequest"},
488      "output":{"shape":"UpdateAccessPolicyResponse"},
489      "errors":[
490        {"shape":"InternalServerException"},
491        {"shape":"ResourceNotFoundException"},
492        {"shape":"ConflictException"},
493        {"shape":"ValidationException"}
494      ],
495      "documentation":"<p>Updates an OpenSearch Serverless access policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-data-access.html\">Data access control for Amazon OpenSearch Serverless</a>.</p>",
496      "idempotent":true
497    },
498    "UpdateAccountSettings":{
499      "name":"UpdateAccountSettings",
500      "http":{
501        "method":"POST",
502        "requestUri":"/"
503      },
504      "input":{"shape":"UpdateAccountSettingsRequest"},
505      "output":{"shape":"UpdateAccountSettingsResponse"},
506      "errors":[
507        {"shape":"InternalServerException"},
508        {"shape":"ValidationException"}
509      ],
510      "documentation":"<p>Update the OpenSearch Serverless settings for the current Amazon Web Services account. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-scaling.html\">Managing capacity limits for Amazon OpenSearch Serverless</a>.</p>"
511    },
512    "UpdateCollection":{
513      "name":"UpdateCollection",
514      "http":{
515        "method":"POST",
516        "requestUri":"/"
517      },
518      "input":{"shape":"UpdateCollectionRequest"},
519      "output":{"shape":"UpdateCollectionResponse"},
520      "errors":[
521        {"shape":"InternalServerException"},
522        {"shape":"ConflictException"},
523        {"shape":"ValidationException"}
524      ],
525      "documentation":"<p>Updates an OpenSearch Serverless collection.</p>",
526      "idempotent":true
527    },
528    "UpdateLifecyclePolicy":{
529      "name":"UpdateLifecyclePolicy",
530      "http":{
531        "method":"POST",
532        "requestUri":"/"
533      },
534      "input":{"shape":"UpdateLifecyclePolicyRequest"},
535      "output":{"shape":"UpdateLifecyclePolicyResponse"},
536      "errors":[
537        {"shape":"InternalServerException"},
538        {"shape":"ResourceNotFoundException"},
539        {"shape":"ConflictException"},
540        {"shape":"ValidationException"},
541        {"shape":"ServiceQuotaExceededException"}
542      ],
543      "documentation":"<p>Updates an OpenSearch Serverless access policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-lifecycle.html#serverless-lifecycle-update\">Updating data lifecycle policies</a>.</p>",
544      "idempotent":true
545    },
546    "UpdateSecurityConfig":{
547      "name":"UpdateSecurityConfig",
548      "http":{
549        "method":"POST",
550        "requestUri":"/"
551      },
552      "input":{"shape":"UpdateSecurityConfigRequest"},
553      "output":{"shape":"UpdateSecurityConfigResponse"},
554      "errors":[
555        {"shape":"InternalServerException"},
556        {"shape":"ResourceNotFoundException"},
557        {"shape":"ConflictException"},
558        {"shape":"ValidationException"}
559      ],
560      "documentation":"<p>Updates a security configuration for OpenSearch Serverless. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-saml.html\">SAML authentication for Amazon OpenSearch Serverless</a>.</p>",
561      "idempotent":true
562    },
563    "UpdateSecurityPolicy":{
564      "name":"UpdateSecurityPolicy",
565      "http":{
566        "method":"POST",
567        "requestUri":"/"
568      },
569      "input":{"shape":"UpdateSecurityPolicyRequest"},
570      "output":{"shape":"UpdateSecurityPolicyResponse"},
571      "errors":[
572        {"shape":"InternalServerException"},
573        {"shape":"ResourceNotFoundException"},
574        {"shape":"ConflictException"},
575        {"shape":"ValidationException"},
576        {"shape":"ServiceQuotaExceededException"}
577      ],
578      "documentation":"<p>Updates an OpenSearch Serverless security policy. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-network.html\">Network access for Amazon OpenSearch Serverless</a> and <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-encryption.html\">Encryption at rest for Amazon OpenSearch Serverless</a>.</p>",
579      "idempotent":true
580    },
581    "UpdateVpcEndpoint":{
582      "name":"UpdateVpcEndpoint",
583      "http":{
584        "method":"POST",
585        "requestUri":"/"
586      },
587      "input":{"shape":"UpdateVpcEndpointRequest"},
588      "output":{"shape":"UpdateVpcEndpointResponse"},
589      "errors":[
590        {"shape":"InternalServerException"},
591        {"shape":"ConflictException"},
592        {"shape":"ValidationException"}
593      ],
594      "documentation":"<p>Updates an OpenSearch Serverless-managed interface endpoint. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-vpc.html\">Access Amazon OpenSearch Serverless using an interface endpoint</a>.</p>",
595      "idempotent":true
596    }
597  },
598  "shapes":{
599    "AccessPolicyDetail":{
600      "type":"structure",
601      "members":{
602        "createdDate":{
603          "shape":"Long",
604          "documentation":"<p>The date the policy was created.</p>"
605        },
606        "description":{
607          "shape":"PolicyDescription",
608          "documentation":"<p>The description of the policy.</p>"
609        },
610        "lastModifiedDate":{
611          "shape":"Long",
612          "documentation":"<p>The timestamp of when the policy was last modified.</p>"
613        },
614        "name":{
615          "shape":"PolicyName",
616          "documentation":"<p>The name of the policy.</p>"
617        },
618        "policy":{
619          "shape":"Document",
620          "documentation":"<p>The JSON policy document without any whitespaces.</p>"
621        },
622        "policyVersion":{
623          "shape":"PolicyVersion",
624          "documentation":"<p>The version of the policy.</p>"
625        },
626        "type":{
627          "shape":"AccessPolicyType",
628          "documentation":"<p>The type of access policy.</p>"
629        }
630      },
631      "documentation":"<p>Details about an OpenSearch Serverless access policy.</p>"
632    },
633    "AccessPolicyStats":{
634      "type":"structure",
635      "members":{
636        "DataPolicyCount":{
637          "shape":"Long",
638          "documentation":"<p>The number of data access policies in the current account.</p>"
639        }
640      },
641      "documentation":"<p>Statistics for an OpenSearch Serverless access policy.</p>"
642    },
643    "AccessPolicySummaries":{
644      "type":"list",
645      "member":{"shape":"AccessPolicySummary"}
646    },
647    "AccessPolicySummary":{
648      "type":"structure",
649      "members":{
650        "createdDate":{
651          "shape":"Long",
652          "documentation":"<p>The Epoch time when the access policy was created.</p>"
653        },
654        "description":{
655          "shape":"PolicyDescription",
656          "documentation":"<p>The description of the access policy.</p>"
657        },
658        "lastModifiedDate":{
659          "shape":"Long",
660          "documentation":"<p>The date and time when the collection was last modified.</p>"
661        },
662        "name":{
663          "shape":"PolicyName",
664          "documentation":"<p>The name of the access policy.</p>"
665        },
666        "policyVersion":{
667          "shape":"PolicyVersion",
668          "documentation":"<p>The version of the policy.</p>"
669        },
670        "type":{
671          "shape":"AccessPolicyType",
672          "documentation":"<p>The type of access policy. Currently, the only available type is <code>data</code>.</p>"
673        }
674      },
675      "documentation":"<p>A summary of the data access policy.</p>"
676    },
677    "AccessPolicyType":{
678      "type":"string",
679      "enum":["data"]
680    },
681    "AccountSettingsDetail":{
682      "type":"structure",
683      "members":{
684        "capacityLimits":{"shape":"CapacityLimits"}
685      },
686      "documentation":"<p>OpenSearch Serverless-related information for the current account.</p>"
687    },
688    "Arn":{
689      "type":"string",
690      "max":1011,
691      "min":1
692    },
693    "BatchGetCollectionRequest":{
694      "type":"structure",
695      "members":{
696        "ids":{
697          "shape":"CollectionIds",
698          "documentation":"<p>A list of collection IDs. You can't provide names and IDs in the same request. The ID is part of the collection endpoint. You can also retrieve it using the <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/ServerlessAPIReference/API_ListCollections.html\">ListCollections</a> API.</p>"
699        },
700        "names":{
701          "shape":"CollectionNames",
702          "documentation":"<p>A list of collection names. You can't provide names and IDs in the same request.</p>"
703        }
704      }
705    },
706    "BatchGetCollectionResponse":{
707      "type":"structure",
708      "members":{
709        "collectionDetails":{
710          "shape":"CollectionDetails",
711          "documentation":"<p>Details about each collection.</p>"
712        },
713        "collectionErrorDetails":{
714          "shape":"CollectionErrorDetails",
715          "documentation":"<p>Error information for the request.</p>"
716        }
717      }
718    },
719    "BatchGetEffectiveLifecyclePolicyRequest":{
720      "type":"structure",
721      "required":["resourceIdentifiers"],
722      "members":{
723        "resourceIdentifiers":{
724          "shape":"LifecyclePolicyResourceIdentifiers",
725          "documentation":"<p>The unique identifiers of policy types and resource names.</p>"
726        }
727      }
728    },
729    "BatchGetEffectiveLifecyclePolicyResponse":{
730      "type":"structure",
731      "members":{
732        "effectiveLifecyclePolicyDetails":{
733          "shape":"EffectiveLifecyclePolicyDetails",
734          "documentation":"<p>A list of lifecycle policies applied to the OpenSearch Serverless indexes.</p>"
735        },
736        "effectiveLifecyclePolicyErrorDetails":{
737          "shape":"EffectiveLifecyclePolicyErrorDetails",
738          "documentation":"<p>A list of resources for which retrieval failed.</p>"
739        }
740      }
741    },
742    "BatchGetLifecyclePolicyRequest":{
743      "type":"structure",
744      "required":["identifiers"],
745      "members":{
746        "identifiers":{
747          "shape":"LifecyclePolicyIdentifiers",
748          "documentation":"<p>The unique identifiers of policy types and policy names.</p>"
749        }
750      }
751    },
752    "BatchGetLifecyclePolicyResponse":{
753      "type":"structure",
754      "members":{
755        "lifecyclePolicyDetails":{
756          "shape":"LifecyclePolicyDetails",
757          "documentation":"<p>A list of lifecycle policies matched to the input policy name and policy type.</p>"
758        },
759        "lifecyclePolicyErrorDetails":{
760          "shape":"LifecyclePolicyErrorDetails",
761          "documentation":"<p>A list of lifecycle policy names and policy types for which retrieval failed.</p>"
762        }
763      }
764    },
765    "BatchGetVpcEndpointRequest":{
766      "type":"structure",
767      "required":["ids"],
768      "members":{
769        "ids":{
770          "shape":"VpcEndpointIds",
771          "documentation":"<p>A list of VPC endpoint identifiers.</p>"
772        }
773      }
774    },
775    "BatchGetVpcEndpointResponse":{
776      "type":"structure",
777      "members":{
778        "vpcEndpointDetails":{
779          "shape":"VpcEndpointDetails",
780          "documentation":"<p>Details about the specified VPC endpoint.</p>"
781        },
782        "vpcEndpointErrorDetails":{
783          "shape":"VpcEndpointErrorDetails",
784          "documentation":"<p>Error information for a failed request.</p>"
785        }
786      }
787    },
788    "Boolean":{
789      "type":"boolean",
790      "box":true
791    },
792    "CapacityLimits":{
793      "type":"structure",
794      "members":{
795        "maxIndexingCapacityInOCU":{
796          "shape":"IndexingCapacityValue",
797          "documentation":"<p>The maximum indexing capacity for collections.</p>"
798        },
799        "maxSearchCapacityInOCU":{
800          "shape":"SearchCapacityValue",
801          "documentation":"<p>The maximum search capacity for collections.</p>"
802        }
803      },
804      "documentation":"<p>The maximum capacity limits for all OpenSearch Serverless collections, in OpenSearch Compute Units (OCUs). These limits are used to scale your collections based on the current workload. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-scaling.html\">Managing capacity limits for Amazon OpenSearch Serverless</a>.</p>"
805    },
806    "ClientToken":{
807      "type":"string",
808      "max":512,
809      "min":1
810    },
811    "CollectionDetail":{
812      "type":"structure",
813      "members":{
814        "arn":{
815          "shape":"String",
816          "documentation":"<p>The Amazon Resource Name (ARN) of the collection.</p>"
817        },
818        "collectionEndpoint":{
819          "shape":"String",
820          "documentation":"<p>Collection-specific endpoint used to submit index, search, and data upload requests to an OpenSearch Serverless collection.</p>"
821        },
822        "createdDate":{
823          "shape":"Long",
824          "documentation":"<p>The Epoch time when the collection was created.</p>"
825        },
826        "dashboardEndpoint":{
827          "shape":"String",
828          "documentation":"<p>Collection-specific endpoint used to access OpenSearch Dashboards.</p>"
829        },
830        "description":{
831          "shape":"String",
832          "documentation":"<p>A description of the collection.</p>"
833        },
834        "id":{
835          "shape":"CollectionId",
836          "documentation":"<p>A unique identifier for the collection.</p>"
837        },
838        "kmsKeyArn":{
839          "shape":"String",
840          "documentation":"<p>The ARN of the Amazon Web Services KMS key used to encrypt the collection.</p>"
841        },
842        "lastModifiedDate":{
843          "shape":"Long",
844          "documentation":"<p>The date and time when the collection was last modified.</p>"
845        },
846        "name":{
847          "shape":"CollectionName",
848          "documentation":"<p>The name of the collection.</p>"
849        },
850        "standbyReplicas":{
851          "shape":"StandbyReplicas",
852          "documentation":"<p>Details about an OpenSearch Serverless collection.</p>"
853        },
854        "status":{
855          "shape":"CollectionStatus",
856          "documentation":"<p>The current status of the collection.</p>"
857        },
858        "type":{
859          "shape":"CollectionType",
860          "documentation":"<p>The type of collection.</p>"
861        }
862      },
863      "documentation":"<p>Details about each OpenSearch Serverless collection, including the collection endpoint and the OpenSearch Dashboards endpoint.</p>"
864    },
865    "CollectionDetails":{
866      "type":"list",
867      "member":{"shape":"CollectionDetail"}
868    },
869    "CollectionErrorDetail":{
870      "type":"structure",
871      "members":{
872        "errorCode":{
873          "shape":"String",
874          "documentation":"<p>The error code for the request. For example, <code>NOT_FOUND</code>.</p>"
875        },
876        "errorMessage":{
877          "shape":"String",
878          "documentation":"<p>A description of the error. For example, <code>The specified Collection is not found.</code> </p>"
879        },
880        "id":{
881          "shape":"CollectionId",
882          "documentation":"<p>If the request contains collection IDs, the response includes the IDs provided in the request.</p>"
883        },
884        "name":{
885          "shape":"CollectionName",
886          "documentation":"<p>If the request contains collection names, the response includes the names provided in the request.</p>"
887        }
888      },
889      "documentation":"<p>Error information for an OpenSearch Serverless request.</p>"
890    },
891    "CollectionErrorDetails":{
892      "type":"list",
893      "member":{"shape":"CollectionErrorDetail"}
894    },
895    "CollectionFilters":{
896      "type":"structure",
897      "members":{
898        "name":{
899          "shape":"CollectionName",
900          "documentation":"<p>The name of the collection.</p>"
901        },
902        "status":{
903          "shape":"CollectionStatus",
904          "documentation":"<p>The current status of the collection.</p>"
905        }
906      },
907      "documentation":"<p>A list of filter keys that you can use for LIST, UPDATE, and DELETE requests to OpenSearch Serverless collections.</p>"
908    },
909    "CollectionId":{
910      "type":"string",
911      "max":40,
912      "min":3,
913      "pattern":"^[a-z0-9]{3,40}$"
914    },
915    "CollectionIds":{
916      "type":"list",
917      "member":{"shape":"CollectionId"},
918      "max":100,
919      "min":1
920    },
921    "CollectionName":{
922      "type":"string",
923      "max":32,
924      "min":3,
925      "pattern":"^[a-z][a-z0-9-]+$"
926    },
927    "CollectionNames":{
928      "type":"list",
929      "member":{"shape":"CollectionName"},
930      "max":100,
931      "min":1
932    },
933    "CollectionStatus":{
934      "type":"string",
935      "enum":[
936        "CREATING",
937        "DELETING",
938        "ACTIVE",
939        "FAILED"
940      ]
941    },
942    "CollectionSummaries":{
943      "type":"list",
944      "member":{"shape":"CollectionSummary"}
945    },
946    "CollectionSummary":{
947      "type":"structure",
948      "members":{
949        "arn":{
950          "shape":"String",
951          "documentation":"<p>The Amazon Resource Name (ARN) of the collection.</p>"
952        },
953        "id":{
954          "shape":"CollectionId",
955          "documentation":"<p>The unique identifier of the collection.</p>"
956        },
957        "name":{
958          "shape":"CollectionName",
959          "documentation":"<p>The name of the collection.</p>"
960        },
961        "status":{
962          "shape":"CollectionStatus",
963          "documentation":"<p>The current status of the collection.</p>"
964        }
965      },
966      "documentation":"<p>Details about each OpenSearch Serverless collection.</p>"
967    },
968    "CollectionType":{
969      "type":"string",
970      "enum":[
971        "SEARCH",
972        "TIMESERIES",
973        "VECTORSEARCH"
974      ]
975    },
976    "ConfigDescription":{
977      "type":"string",
978      "max":1000,
979      "min":1
980    },
981    "ConfigName":{
982      "type":"string",
983      "max":32,
984      "min":3,
985      "pattern":"^[a-z][a-z0-9-]+$"
986    },
987    "ConflictException":{
988      "type":"structure",
989      "members":{
990        "message":{"shape":"String"}
991      },
992      "documentation":"<p>When creating a resource, thrown when a resource with the same name already exists or is being created. When deleting a resource, thrown when the resource is not in the ACTIVE or FAILED state.</p>",
993      "exception":true
994    },
995    "CreateAccessPolicyRequest":{
996      "type":"structure",
997      "required":[
998        "name",
999        "policy",
1000        "type"
1001      ],
1002      "members":{
1003        "clientToken":{
1004          "shape":"ClientToken",
1005          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1006          "idempotencyToken":true
1007        },
1008        "description":{
1009          "shape":"PolicyDescription",
1010          "documentation":"<p>A description of the policy. Typically used to store information about the permissions defined in the policy.</p>"
1011        },
1012        "name":{
1013          "shape":"PolicyName",
1014          "documentation":"<p>The name of the policy.</p>"
1015        },
1016        "policy":{
1017          "shape":"PolicyDocument",
1018          "documentation":"<p>The JSON policy document to use as the content for the policy.</p>"
1019        },
1020        "type":{
1021          "shape":"AccessPolicyType",
1022          "documentation":"<p>The type of policy.</p>"
1023        }
1024      }
1025    },
1026    "CreateAccessPolicyResponse":{
1027      "type":"structure",
1028      "members":{
1029        "accessPolicyDetail":{
1030          "shape":"AccessPolicyDetail",
1031          "documentation":"<p>Details about the created access policy.</p>"
1032        }
1033      }
1034    },
1035    "CreateCollectionDetail":{
1036      "type":"structure",
1037      "members":{
1038        "arn":{
1039          "shape":"String",
1040          "documentation":"<p>The Amazon Resource Name (ARN) of the collection.</p>"
1041        },
1042        "createdDate":{
1043          "shape":"Long",
1044          "documentation":"<p>The Epoch time when the collection was created.</p>"
1045        },
1046        "description":{
1047          "shape":"String",
1048          "documentation":"<p>A description of the collection.</p>"
1049        },
1050        "id":{
1051          "shape":"CollectionId",
1052          "documentation":"<p>The unique identifier of the collection.</p>"
1053        },
1054        "kmsKeyArn":{
1055          "shape":"String",
1056          "documentation":"<p>The Amazon Resource Name (ARN) of the KMS key with which to encrypt the collection.</p>"
1057        },
1058        "lastModifiedDate":{
1059          "shape":"Long",
1060          "documentation":"<p>The date and time when the collection was last modified.</p>"
1061        },
1062        "name":{
1063          "shape":"CollectionName",
1064          "documentation":"<p>The name of the collection.</p>"
1065        },
1066        "standbyReplicas":{
1067          "shape":"StandbyReplicas",
1068          "documentation":"<p>Creates details about an OpenSearch Serverless collection.</p>"
1069        },
1070        "status":{
1071          "shape":"CollectionStatus",
1072          "documentation":"<p>The current status of the collection.</p>"
1073        },
1074        "type":{
1075          "shape":"CollectionType",
1076          "documentation":"<p>The type of collection.</p>"
1077        }
1078      },
1079      "documentation":"<p>Details about the created OpenSearch Serverless collection.</p>"
1080    },
1081    "CreateCollectionRequest":{
1082      "type":"structure",
1083      "required":["name"],
1084      "members":{
1085        "clientToken":{
1086          "shape":"ClientToken",
1087          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1088          "idempotencyToken":true
1089        },
1090        "description":{
1091          "shape":"CreateCollectionRequestDescriptionString",
1092          "documentation":"<p>Description of the collection.</p>"
1093        },
1094        "name":{
1095          "shape":"CollectionName",
1096          "documentation":"<p>Name of the collection.</p>"
1097        },
1098        "standbyReplicas":{
1099          "shape":"StandbyReplicas",
1100          "documentation":"<p>Indicates whether standby replicas should be used for a collection.</p>"
1101        },
1102        "tags":{
1103          "shape":"Tags",
1104          "documentation":"<p>An arbitrary set of tags (key–value pairs) to associate with the OpenSearch Serverless collection.</p>"
1105        },
1106        "type":{
1107          "shape":"CollectionType",
1108          "documentation":"<p>The type of collection.</p>"
1109        }
1110      }
1111    },
1112    "CreateCollectionRequestDescriptionString":{
1113      "type":"string",
1114      "max":1000,
1115      "min":0
1116    },
1117    "CreateCollectionResponse":{
1118      "type":"structure",
1119      "members":{
1120        "createCollectionDetail":{
1121          "shape":"CreateCollectionDetail",
1122          "documentation":"<p>Details about the collection.</p>"
1123        }
1124      }
1125    },
1126    "CreateLifecyclePolicyRequest":{
1127      "type":"structure",
1128      "required":[
1129        "name",
1130        "policy",
1131        "type"
1132      ],
1133      "members":{
1134        "clientToken":{
1135          "shape":"ClientToken",
1136          "documentation":"<p>A unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1137          "idempotencyToken":true
1138        },
1139        "description":{
1140          "shape":"PolicyDescription",
1141          "documentation":"<p>A description of the lifecycle policy.</p>"
1142        },
1143        "name":{
1144          "shape":"PolicyName",
1145          "documentation":"<p>The name of the lifecycle policy.</p>"
1146        },
1147        "policy":{
1148          "shape":"PolicyDocument",
1149          "documentation":"<p>The JSON policy document to use as the content for the lifecycle policy.</p>"
1150        },
1151        "type":{
1152          "shape":"LifecyclePolicyType",
1153          "documentation":"<p>The type of lifecycle policy.</p>"
1154        }
1155      }
1156    },
1157    "CreateLifecyclePolicyResponse":{
1158      "type":"structure",
1159      "members":{
1160        "lifecyclePolicyDetail":{
1161          "shape":"LifecyclePolicyDetail",
1162          "documentation":"<p>Details about the created lifecycle policy.</p>"
1163        }
1164      }
1165    },
1166    "CreateSecurityConfigRequest":{
1167      "type":"structure",
1168      "required":[
1169        "name",
1170        "type"
1171      ],
1172      "members":{
1173        "clientToken":{
1174          "shape":"ClientToken",
1175          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1176          "idempotencyToken":true
1177        },
1178        "description":{
1179          "shape":"ConfigDescription",
1180          "documentation":"<p>A description of the security configuration.</p>"
1181        },
1182        "name":{
1183          "shape":"ConfigName",
1184          "documentation":"<p>The name of the security configuration.</p>"
1185        },
1186        "samlOptions":{
1187          "shape":"SamlConfigOptions",
1188          "documentation":"<p>Describes SAML options in in the form of a key-value map. This field is required if you specify <code>saml</code> for the <code>type</code> parameter.</p>"
1189        },
1190        "type":{
1191          "shape":"SecurityConfigType",
1192          "documentation":"<p>The type of security configuration.</p>"
1193        }
1194      }
1195    },
1196    "CreateSecurityConfigResponse":{
1197      "type":"structure",
1198      "members":{
1199        "securityConfigDetail":{
1200          "shape":"SecurityConfigDetail",
1201          "documentation":"<p>Details about the created security configuration. </p>"
1202        }
1203      }
1204    },
1205    "CreateSecurityPolicyRequest":{
1206      "type":"structure",
1207      "required":[
1208        "name",
1209        "policy",
1210        "type"
1211      ],
1212      "members":{
1213        "clientToken":{
1214          "shape":"ClientToken",
1215          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1216          "idempotencyToken":true
1217        },
1218        "description":{
1219          "shape":"PolicyDescription",
1220          "documentation":"<p>A description of the policy. Typically used to store information about the permissions defined in the policy.</p>"
1221        },
1222        "name":{
1223          "shape":"PolicyName",
1224          "documentation":"<p>The name of the policy.</p>"
1225        },
1226        "policy":{
1227          "shape":"PolicyDocument",
1228          "documentation":"<p>The JSON policy document to use as the content for the new policy.</p>"
1229        },
1230        "type":{
1231          "shape":"SecurityPolicyType",
1232          "documentation":"<p>The type of security policy.</p>"
1233        }
1234      }
1235    },
1236    "CreateSecurityPolicyResponse":{
1237      "type":"structure",
1238      "members":{
1239        "securityPolicyDetail":{
1240          "shape":"SecurityPolicyDetail",
1241          "documentation":"<p>Details about the created security policy.</p>"
1242        }
1243      }
1244    },
1245    "CreateVpcEndpointDetail":{
1246      "type":"structure",
1247      "members":{
1248        "id":{
1249          "shape":"VpcEndpointId",
1250          "documentation":"<p>The unique identifier of the endpoint.</p>"
1251        },
1252        "name":{
1253          "shape":"VpcEndpointName",
1254          "documentation":"<p>The name of the endpoint.</p>"
1255        },
1256        "status":{
1257          "shape":"VpcEndpointStatus",
1258          "documentation":"<p>The current status in the endpoint creation process.</p>"
1259        }
1260      },
1261      "documentation":"<p>Creation details for an OpenSearch Serverless-managed interface endpoint. For more information, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-vpc.html\">Access Amazon OpenSearch Serverless using an interface endpoint</a>.</p>"
1262    },
1263    "CreateVpcEndpointRequest":{
1264      "type":"structure",
1265      "required":[
1266        "name",
1267        "subnetIds",
1268        "vpcId"
1269      ],
1270      "members":{
1271        "clientToken":{
1272          "shape":"ClientToken",
1273          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1274          "idempotencyToken":true
1275        },
1276        "name":{
1277          "shape":"VpcEndpointName",
1278          "documentation":"<p>The name of the interface endpoint.</p>"
1279        },
1280        "securityGroupIds":{
1281          "shape":"SecurityGroupIds",
1282          "documentation":"<p>The unique identifiers of the security groups that define the ports, protocols, and sources for inbound traffic that you are authorizing into your endpoint.</p>"
1283        },
1284        "subnetIds":{
1285          "shape":"SubnetIds",
1286          "documentation":"<p>The ID of one or more subnets from which you'll access OpenSearch Serverless.</p>"
1287        },
1288        "vpcId":{
1289          "shape":"VpcId",
1290          "documentation":"<p>The ID of the VPC from which you'll access OpenSearch Serverless.</p>"
1291        }
1292      }
1293    },
1294    "CreateVpcEndpointResponse":{
1295      "type":"structure",
1296      "members":{
1297        "createVpcEndpointDetail":{
1298          "shape":"CreateVpcEndpointDetail",
1299          "documentation":"<p>Details about the created interface VPC endpoint.</p>"
1300        }
1301      }
1302    },
1303    "DeleteAccessPolicyRequest":{
1304      "type":"structure",
1305      "required":[
1306        "name",
1307        "type"
1308      ],
1309      "members":{
1310        "clientToken":{
1311          "shape":"ClientToken",
1312          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1313          "idempotencyToken":true
1314        },
1315        "name":{
1316          "shape":"PolicyName",
1317          "documentation":"<p>The name of the policy to delete.</p>"
1318        },
1319        "type":{
1320          "shape":"AccessPolicyType",
1321          "documentation":"<p>The type of policy.</p>"
1322        }
1323      }
1324    },
1325    "DeleteAccessPolicyResponse":{
1326      "type":"structure",
1327      "members":{
1328      }
1329    },
1330    "DeleteCollectionDetail":{
1331      "type":"structure",
1332      "members":{
1333        "id":{
1334          "shape":"CollectionId",
1335          "documentation":"<p>The unique identifier of the collection.</p>"
1336        },
1337        "name":{
1338          "shape":"CollectionName",
1339          "documentation":"<p>The name of the collection.</p>"
1340        },
1341        "status":{
1342          "shape":"CollectionStatus",
1343          "documentation":"<p>The current status of the collection.</p>"
1344        }
1345      },
1346      "documentation":"<p>Details about a deleted OpenSearch Serverless collection.</p>"
1347    },
1348    "DeleteCollectionRequest":{
1349      "type":"structure",
1350      "required":["id"],
1351      "members":{
1352        "clientToken":{
1353          "shape":"ClientToken",
1354          "documentation":"<p>A unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1355          "idempotencyToken":true
1356        },
1357        "id":{
1358          "shape":"CollectionId",
1359          "documentation":"<p>The unique identifier of the collection. For example, <code>1iu5usc406kd</code>. The ID is part of the collection endpoint. You can also retrieve it using the <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/ServerlessAPIReference/API_ListCollections.html\">ListCollections</a> API.</p>"
1360        }
1361      }
1362    },
1363    "DeleteCollectionResponse":{
1364      "type":"structure",
1365      "members":{
1366        "deleteCollectionDetail":{
1367          "shape":"DeleteCollectionDetail",
1368          "documentation":"<p>Details of the deleted collection.</p>"
1369        }
1370      }
1371    },
1372    "DeleteLifecyclePolicyRequest":{
1373      "type":"structure",
1374      "required":[
1375        "name",
1376        "type"
1377      ],
1378      "members":{
1379        "clientToken":{
1380          "shape":"ClientToken",
1381          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1382          "idempotencyToken":true
1383        },
1384        "name":{
1385          "shape":"PolicyName",
1386          "documentation":"<p>The name of the policy to delete.</p>"
1387        },
1388        "type":{
1389          "shape":"LifecyclePolicyType",
1390          "documentation":"<p>The type of lifecycle policy.</p>"
1391        }
1392      }
1393    },
1394    "DeleteLifecyclePolicyResponse":{
1395      "type":"structure",
1396      "members":{
1397      }
1398    },
1399    "DeleteSecurityConfigRequest":{
1400      "type":"structure",
1401      "required":["id"],
1402      "members":{
1403        "clientToken":{
1404          "shape":"ClientToken",
1405          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1406          "idempotencyToken":true
1407        },
1408        "id":{
1409          "shape":"SecurityConfigId",
1410          "documentation":"<p>The security configuration identifier. For SAML the ID will be <code>saml/&lt;accountId&gt;/&lt;idpProviderName&gt;</code>. For example, <code>saml/123456789123/OKTADev</code>.</p>"
1411        }
1412      }
1413    },
1414    "DeleteSecurityConfigResponse":{
1415      "type":"structure",
1416      "members":{
1417      }
1418    },
1419    "DeleteSecurityPolicyRequest":{
1420      "type":"structure",
1421      "required":[
1422        "name",
1423        "type"
1424      ],
1425      "members":{
1426        "clientToken":{
1427          "shape":"ClientToken",
1428          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1429          "idempotencyToken":true
1430        },
1431        "name":{
1432          "shape":"PolicyName",
1433          "documentation":"<p>The name of the policy to delete.</p>"
1434        },
1435        "type":{
1436          "shape":"SecurityPolicyType",
1437          "documentation":"<p>The type of policy.</p>"
1438        }
1439      }
1440    },
1441    "DeleteSecurityPolicyResponse":{
1442      "type":"structure",
1443      "members":{
1444      }
1445    },
1446    "DeleteVpcEndpointDetail":{
1447      "type":"structure",
1448      "members":{
1449        "id":{
1450          "shape":"VpcEndpointId",
1451          "documentation":"<p>The unique identifier of the endpoint.</p>"
1452        },
1453        "name":{
1454          "shape":"VpcEndpointName",
1455          "documentation":"<p>The name of the endpoint.</p>"
1456        },
1457        "status":{
1458          "shape":"VpcEndpointStatus",
1459          "documentation":"<p>The current status of the endpoint deletion process.</p>"
1460        }
1461      },
1462      "documentation":"<p>Deletion details for an OpenSearch Serverless-managed interface endpoint.</p>"
1463    },
1464    "DeleteVpcEndpointRequest":{
1465      "type":"structure",
1466      "required":["id"],
1467      "members":{
1468        "clientToken":{
1469          "shape":"ClientToken",
1470          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
1471          "idempotencyToken":true
1472        },
1473        "id":{
1474          "shape":"VpcEndpointId",
1475          "documentation":"<p>The VPC endpoint identifier.</p>"
1476        }
1477      }
1478    },
1479    "DeleteVpcEndpointResponse":{
1480      "type":"structure",
1481      "members":{
1482        "deleteVpcEndpointDetail":{
1483          "shape":"DeleteVpcEndpointDetail",
1484          "documentation":"<p>Details about the deleted endpoint.</p>"
1485        }
1486      }
1487    },
1488    "Document":{
1489      "type":"structure",
1490      "members":{
1491      },
1492      "document":true
1493    },
1494    "EffectiveLifecyclePolicyDetail":{
1495      "type":"structure",
1496      "members":{
1497        "noMinRetentionPeriod":{
1498          "shape":"Boolean",
1499          "documentation":"<p>The minimum number of index retention days set. That is an optional param that will return as <code>true</code> if the minimum number of days or hours is not set to a index resource.</p>"
1500        },
1501        "policyName":{
1502          "shape":"PolicyName",
1503          "documentation":"<p>The name of the lifecycle policy.</p>"
1504        },
1505        "resource":{
1506          "shape":"Resource",
1507          "documentation":"<p>The name of the OpenSearch Serverless index resource.</p>"
1508        },
1509        "resourceType":{
1510          "shape":"ResourceType",
1511          "documentation":"<p>The type of OpenSearch Serverless resource. Currently, the only supported resource is <code>index</code>.</p>"
1512        },
1513        "retentionPeriod":{
1514          "shape":"String",
1515          "documentation":"<p>The minimum number of index retention in days or hours. This is an optional parameter that will return only if it’s set.</p>"
1516        },
1517        "type":{
1518          "shape":"LifecyclePolicyType",
1519          "documentation":"<p>The type of lifecycle policy.</p>"
1520        }
1521      },
1522      "documentation":"<p>Error information for an OpenSearch Serverless request.</p>"
1523    },
1524    "EffectiveLifecyclePolicyDetails":{
1525      "type":"list",
1526      "member":{"shape":"EffectiveLifecyclePolicyDetail"}
1527    },
1528    "EffectiveLifecyclePolicyErrorDetail":{
1529      "type":"structure",
1530      "members":{
1531        "errorCode":{
1532          "shape":"String",
1533          "documentation":"<p>The error code for the request.</p>"
1534        },
1535        "errorMessage":{
1536          "shape":"String",
1537          "documentation":"<p>A description of the error. For example, <code>The specified Index resource is not found</code>.</p>"
1538        },
1539        "resource":{
1540          "shape":"Resource",
1541          "documentation":"<p>The name of OpenSearch Serverless index resource.</p>"
1542        },
1543        "type":{
1544          "shape":"LifecyclePolicyType",
1545          "documentation":"<p>The type of lifecycle policy.</p>"
1546        }
1547      },
1548      "documentation":"<p>Error information for an OpenSearch Serverless request.</p>"
1549    },
1550    "EffectiveLifecyclePolicyErrorDetails":{
1551      "type":"list",
1552      "member":{"shape":"EffectiveLifecyclePolicyErrorDetail"}
1553    },
1554    "GetAccessPolicyRequest":{
1555      "type":"structure",
1556      "required":[
1557        "name",
1558        "type"
1559      ],
1560      "members":{
1561        "name":{
1562          "shape":"PolicyName",
1563          "documentation":"<p>The name of the access policy.</p>"
1564        },
1565        "type":{
1566          "shape":"AccessPolicyType",
1567          "documentation":"<p>Tye type of policy. Currently, the only supported value is <code>data</code>.</p>"
1568        }
1569      }
1570    },
1571    "GetAccessPolicyResponse":{
1572      "type":"structure",
1573      "members":{
1574        "accessPolicyDetail":{
1575          "shape":"AccessPolicyDetail",
1576          "documentation":"<p>Details about the requested access policy.</p>"
1577        }
1578      }
1579    },
1580    "GetAccountSettingsRequest":{
1581      "type":"structure",
1582      "members":{
1583      }
1584    },
1585    "GetAccountSettingsResponse":{
1586      "type":"structure",
1587      "members":{
1588        "accountSettingsDetail":{
1589          "shape":"AccountSettingsDetail",
1590          "documentation":"<p>OpenSearch Serverless-related details for the current account.</p>"
1591        }
1592      }
1593    },
1594    "GetPoliciesStatsRequest":{
1595      "type":"structure",
1596      "members":{
1597      }
1598    },
1599    "GetPoliciesStatsResponse":{
1600      "type":"structure",
1601      "members":{
1602        "AccessPolicyStats":{
1603          "shape":"AccessPolicyStats",
1604          "documentation":"<p>Information about the data access policies in your account.</p>"
1605        },
1606        "LifecyclePolicyStats":{
1607          "shape":"LifecyclePolicyStats",
1608          "documentation":"<p>Information about the lifecycle policies in your account.</p>"
1609        },
1610        "SecurityConfigStats":{
1611          "shape":"SecurityConfigStats",
1612          "documentation":"<p>Information about the security configurations in your account.</p>"
1613        },
1614        "SecurityPolicyStats":{
1615          "shape":"SecurityPolicyStats",
1616          "documentation":"<p>Information about the security policies in your account.</p>"
1617        },
1618        "TotalPolicyCount":{
1619          "shape":"Long",
1620          "documentation":"<p>The total number of OpenSearch Serverless security policies and configurations in your account.</p>"
1621        }
1622      }
1623    },
1624    "GetSecurityConfigRequest":{
1625      "type":"structure",
1626      "required":["id"],
1627      "members":{
1628        "id":{
1629          "shape":"SecurityConfigId",
1630          "documentation":"<p>The unique identifier of the security configuration.</p>"
1631        }
1632      }
1633    },
1634    "GetSecurityConfigResponse":{
1635      "type":"structure",
1636      "members":{
1637        "securityConfigDetail":{
1638          "shape":"SecurityConfigDetail",
1639          "documentation":"<p>Details of the requested security configuration.</p>"
1640        }
1641      }
1642    },
1643    "GetSecurityPolicyRequest":{
1644      "type":"structure",
1645      "required":[
1646        "name",
1647        "type"
1648      ],
1649      "members":{
1650        "name":{
1651          "shape":"PolicyName",
1652          "documentation":"<p>The name of the security policy.</p>"
1653        },
1654        "type":{
1655          "shape":"SecurityPolicyType",
1656          "documentation":"<p>The type of security policy.</p>"
1657        }
1658      }
1659    },
1660    "GetSecurityPolicyResponse":{
1661      "type":"structure",
1662      "members":{
1663        "securityPolicyDetail":{
1664          "shape":"SecurityPolicyDetail",
1665          "documentation":"<p>Details about the requested security policy.</p>"
1666        }
1667      }
1668    },
1669    "IndexingCapacityValue":{
1670      "type":"integer",
1671      "box":true,
1672      "min":2
1673    },
1674    "InternalServerException":{
1675      "type":"structure",
1676      "members":{
1677        "message":{"shape":"String"}
1678      },
1679      "documentation":"<p>Thrown when an error internal to the service occurs while processing a request.</p>",
1680      "exception":true,
1681      "fault":true
1682    },
1683    "LifecyclePolicyDetail":{
1684      "type":"structure",
1685      "members":{
1686        "createdDate":{
1687          "shape":"Long",
1688          "documentation":"<p>The date the lifecycle policy was created.</p>"
1689        },
1690        "description":{
1691          "shape":"PolicyDescription",
1692          "documentation":"<p>The description of the lifecycle policy.</p>"
1693        },
1694        "lastModifiedDate":{
1695          "shape":"Long",
1696          "documentation":"<p>The timestamp of when the lifecycle policy was last modified.</p>"
1697        },
1698        "name":{
1699          "shape":"PolicyName",
1700          "documentation":"<p>The name of the lifecycle policy.</p>"
1701        },
1702        "policy":{
1703          "shape":"Document",
1704          "documentation":"<p>The JSON policy document without any whitespaces.</p>"
1705        },
1706        "policyVersion":{
1707          "shape":"PolicyVersion",
1708          "documentation":"<p>The version of the lifecycle policy.</p>"
1709        },
1710        "type":{
1711          "shape":"LifecyclePolicyType",
1712          "documentation":"<p>The type of lifecycle policy.</p>"
1713        }
1714      },
1715      "documentation":"<p>Details about an OpenSearch Serverless lifecycle policy.</p>"
1716    },
1717    "LifecyclePolicyDetails":{
1718      "type":"list",
1719      "member":{"shape":"LifecyclePolicyDetail"}
1720    },
1721    "LifecyclePolicyErrorDetail":{
1722      "type":"structure",
1723      "members":{
1724        "errorCode":{
1725          "shape":"String",
1726          "documentation":"<p>The error code for the request. For example, <code>NOT_FOUND</code>.</p>"
1727        },
1728        "errorMessage":{
1729          "shape":"String",
1730          "documentation":"<p>A description of the error. For example, <code>The specified Lifecycle Policy is not found</code>.</p>"
1731        },
1732        "name":{
1733          "shape":"PolicyName",
1734          "documentation":"<p>The name of the lifecycle policy.</p>"
1735        },
1736        "type":{
1737          "shape":"LifecyclePolicyType",
1738          "documentation":"<p>The type of lifecycle policy.</p>"
1739        }
1740      },
1741      "documentation":"<p>Error information for an OpenSearch Serverless request.</p>"
1742    },
1743    "LifecyclePolicyErrorDetails":{
1744      "type":"list",
1745      "member":{"shape":"LifecyclePolicyErrorDetail"}
1746    },
1747    "LifecyclePolicyIdentifier":{
1748      "type":"structure",
1749      "required":[
1750        "name",
1751        "type"
1752      ],
1753      "members":{
1754        "name":{
1755          "shape":"PolicyName",
1756          "documentation":"<p>The name of the lifecycle policy.</p>"
1757        },
1758        "type":{
1759          "shape":"LifecyclePolicyType",
1760          "documentation":"<p>The type of lifecycle policy.</p>"
1761        }
1762      },
1763      "documentation":"<p>The unique identifiers of policy types and policy names.</p>"
1764    },
1765    "LifecyclePolicyIdentifiers":{
1766      "type":"list",
1767      "member":{"shape":"LifecyclePolicyIdentifier"},
1768      "max":40,
1769      "min":1
1770    },
1771    "LifecyclePolicyResourceIdentifier":{
1772      "type":"structure",
1773      "required":[
1774        "resource",
1775        "type"
1776      ],
1777      "members":{
1778        "resource":{
1779          "shape":"ResourceName",
1780          "documentation":"<p>The name of the OpenSearch Serverless ilndex resource.</p>"
1781        },
1782        "type":{
1783          "shape":"LifecyclePolicyType",
1784          "documentation":"<p>The type of lifecycle policy.</p>"
1785        }
1786      },
1787      "documentation":"<p>The unique identifiers of policy types and resource names.</p>"
1788    },
1789    "LifecyclePolicyResourceIdentifiers":{
1790      "type":"list",
1791      "member":{"shape":"LifecyclePolicyResourceIdentifier"},
1792      "max":100,
1793      "min":1
1794    },
1795    "LifecyclePolicyStats":{
1796      "type":"structure",
1797      "members":{
1798        "RetentionPolicyCount":{
1799          "shape":"Long",
1800          "documentation":"<p>The number of retention lifecycle policies in the current account.</p>"
1801        }
1802      },
1803      "documentation":"<p>Statistics for an OpenSearch Serverless lifecycle policy.</p>"
1804    },
1805    "LifecyclePolicySummaries":{
1806      "type":"list",
1807      "member":{"shape":"LifecyclePolicySummary"}
1808    },
1809    "LifecyclePolicySummary":{
1810      "type":"structure",
1811      "members":{
1812        "createdDate":{
1813          "shape":"Long",
1814          "documentation":"<p>The Epoch time when the lifecycle policy was created.</p>"
1815        },
1816        "description":{
1817          "shape":"PolicyDescription",
1818          "documentation":"<p>The description of the lifecycle policy.</p>"
1819        },
1820        "lastModifiedDate":{
1821          "shape":"Long",
1822          "documentation":"<p>The date and time when the lifecycle policy was last modified.</p>"
1823        },
1824        "name":{
1825          "shape":"PolicyName",
1826          "documentation":"<p>The name of the lifecycle policy.</p>"
1827        },
1828        "policyVersion":{
1829          "shape":"PolicyVersion",
1830          "documentation":"<p>The version of the lifecycle policy.</p>"
1831        },
1832        "type":{
1833          "shape":"LifecyclePolicyType",
1834          "documentation":"<p>The type of lifecycle policy.</p>"
1835        }
1836      },
1837      "documentation":"<p>A summary of the lifecycle policy.</p>"
1838    },
1839    "LifecyclePolicyType":{
1840      "type":"string",
1841      "enum":["retention"]
1842    },
1843    "LifecycleResource":{"type":"string"},
1844    "ListAccessPoliciesRequest":{
1845      "type":"structure",
1846      "required":["type"],
1847      "members":{
1848        "maxResults":{
1849          "shape":"ListAccessPoliciesRequestMaxResultsInteger",
1850          "documentation":"<p>An optional parameter that specifies the maximum number of results to return. You can use <code>nextToken</code> to get the next page of results. The default is 20.</p>"
1851        },
1852        "nextToken":{
1853          "shape":"String",
1854          "documentation":"<p>If your initial <code>ListAccessPolicies</code> operation returns a <code>nextToken</code>, you can include the returned <code>nextToken</code> in subsequent <code>ListAccessPolicies</code> operations, which returns results in the next page. </p>"
1855        },
1856        "resource":{
1857          "shape":"ListAccessPoliciesRequestResourceList",
1858          "documentation":"<p>Resource filters (can be collections or indexes) that policies can apply to.</p>"
1859        },
1860        "type":{
1861          "shape":"AccessPolicyType",
1862          "documentation":"<p>The type of access policy.</p>"
1863        }
1864      }
1865    },
1866    "ListAccessPoliciesRequestMaxResultsInteger":{
1867      "type":"integer",
1868      "box":true,
1869      "max":100,
1870      "min":1
1871    },
1872    "ListAccessPoliciesRequestResourceList":{
1873      "type":"list",
1874      "member":{"shape":"Resource"},
1875      "max":1000,
1876      "min":1
1877    },
1878    "ListAccessPoliciesResponse":{
1879      "type":"structure",
1880      "members":{
1881        "accessPolicySummaries":{
1882          "shape":"AccessPolicySummaries",
1883          "documentation":"<p>Details about the requested access policies.</p>"
1884        },
1885        "nextToken":{
1886          "shape":"String",
1887          "documentation":"<p>When <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.</p>"
1888        }
1889      }
1890    },
1891    "ListCollectionsRequest":{
1892      "type":"structure",
1893      "members":{
1894        "collectionFilters":{
1895          "shape":"CollectionFilters",
1896          "documentation":"<p> A list of filter names and values that you can use for requests.</p>"
1897        },
1898        "maxResults":{
1899          "shape":"ListCollectionsRequestMaxResultsInteger",
1900          "documentation":"<p>The maximum number of results to return. Default is 20. You can use <code>nextToken</code> to get the next page of results.</p>"
1901        },
1902        "nextToken":{
1903          "shape":"String",
1904          "documentation":"<p>If your initial <code>ListCollections</code> operation returns a <code>nextToken</code>, you can include the returned <code>nextToken</code> in subsequent <code>ListCollections</code> operations, which returns results in the next page.</p>"
1905        }
1906      }
1907    },
1908    "ListCollectionsRequestMaxResultsInteger":{
1909      "type":"integer",
1910      "box":true,
1911      "max":100,
1912      "min":1
1913    },
1914    "ListCollectionsResponse":{
1915      "type":"structure",
1916      "members":{
1917        "collectionSummaries":{
1918          "shape":"CollectionSummaries",
1919          "documentation":"<p>Details about each collection.</p>"
1920        },
1921        "nextToken":{
1922          "shape":"String",
1923          "documentation":"<p>When <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.</p>"
1924        }
1925      }
1926    },
1927    "ListLifecyclePoliciesRequest":{
1928      "type":"structure",
1929      "required":["type"],
1930      "members":{
1931        "maxResults":{
1932          "shape":"ListLifecyclePoliciesRequestMaxResultsInteger",
1933          "documentation":"<p>An optional parameter that specifies the maximum number of results to return. You can use use <code>nextToken</code> to get the next page of results. The default is 10.</p>"
1934        },
1935        "nextToken":{
1936          "shape":"String",
1937          "documentation":"<p>If your initial <code>ListLifecyclePolicies</code> operation returns a <code>nextToken</code>, you can include the returned <code>nextToken</code> in subsequent <code>ListLifecyclePolicies</code> operations, which returns results in the next page.</p>"
1938        },
1939        "resources":{
1940          "shape":"ListLifecyclePoliciesRequestResourcesList",
1941          "documentation":"<p>Resource filters that policies can apply to. Currently, the only supported resource type is <code>index</code>.</p>"
1942        },
1943        "type":{
1944          "shape":"LifecyclePolicyType",
1945          "documentation":"<p>The type of lifecycle policy.</p>"
1946        }
1947      }
1948    },
1949    "ListLifecyclePoliciesRequestMaxResultsInteger":{
1950      "type":"integer",
1951      "box":true,
1952      "max":100,
1953      "min":1
1954    },
1955    "ListLifecyclePoliciesRequestResourcesList":{
1956      "type":"list",
1957      "member":{"shape":"LifecycleResource"},
1958      "max":1000,
1959      "min":1
1960    },
1961    "ListLifecyclePoliciesResponse":{
1962      "type":"structure",
1963      "members":{
1964        "lifecyclePolicySummaries":{
1965          "shape":"LifecyclePolicySummaries",
1966          "documentation":"<p>Details about the requested lifecycle policies.</p>"
1967        },
1968        "nextToken":{
1969          "shape":"String",
1970          "documentation":"<p>When <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.</p>"
1971        }
1972      }
1973    },
1974    "ListSecurityConfigsRequest":{
1975      "type":"structure",
1976      "required":["type"],
1977      "members":{
1978        "maxResults":{
1979          "shape":"ListSecurityConfigsRequestMaxResultsInteger",
1980          "documentation":"<p>An optional parameter that specifies the maximum number of results to return. You can use <code>nextToken</code> to get the next page of results. The default is 20.</p>"
1981        },
1982        "nextToken":{
1983          "shape":"String",
1984          "documentation":"<p>If your initial <code>ListSecurityConfigs</code> operation returns a <code>nextToken</code>, you can include the returned <code>nextToken</code> in subsequent <code>ListSecurityConfigs</code> operations, which returns results in the next page. </p>"
1985        },
1986        "type":{
1987          "shape":"SecurityConfigType",
1988          "documentation":"<p>The type of security configuration.</p>"
1989        }
1990      }
1991    },
1992    "ListSecurityConfigsRequestMaxResultsInteger":{
1993      "type":"integer",
1994      "box":true,
1995      "max":100,
1996      "min":1
1997    },
1998    "ListSecurityConfigsResponse":{
1999      "type":"structure",
2000      "members":{
2001        "nextToken":{
2002          "shape":"String",
2003          "documentation":"<p>When <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.</p>"
2004        },
2005        "securityConfigSummaries":{
2006          "shape":"SecurityConfigSummaries",
2007          "documentation":"<p>Details about the security configurations in your account.</p>"
2008        }
2009      }
2010    },
2011    "ListSecurityPoliciesRequest":{
2012      "type":"structure",
2013      "required":["type"],
2014      "members":{
2015        "maxResults":{
2016          "shape":"ListSecurityPoliciesRequestMaxResultsInteger",
2017          "documentation":"<p>An optional parameter that specifies the maximum number of results to return. You can use <code>nextToken</code> to get the next page of results. The default is 20.</p>"
2018        },
2019        "nextToken":{
2020          "shape":"String",
2021          "documentation":"<p>If your initial <code>ListSecurityPolicies</code> operation returns a <code>nextToken</code>, you can include the returned <code>nextToken</code> in subsequent <code>ListSecurityPolicies</code> operations, which returns results in the next page. </p>"
2022        },
2023        "resource":{
2024          "shape":"ListSecurityPoliciesRequestResourceList",
2025          "documentation":"<p>Resource filters (can be collection or indexes) that policies can apply to. </p>"
2026        },
2027        "type":{
2028          "shape":"SecurityPolicyType",
2029          "documentation":"<p>The type of policy.</p>"
2030        }
2031      }
2032    },
2033    "ListSecurityPoliciesRequestMaxResultsInteger":{
2034      "type":"integer",
2035      "box":true,
2036      "max":100,
2037      "min":1
2038    },
2039    "ListSecurityPoliciesRequestResourceList":{
2040      "type":"list",
2041      "member":{"shape":"Resource"},
2042      "max":1000,
2043      "min":1
2044    },
2045    "ListSecurityPoliciesResponse":{
2046      "type":"structure",
2047      "members":{
2048        "nextToken":{
2049          "shape":"String",
2050          "documentation":"<p>When <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.</p>"
2051        },
2052        "securityPolicySummaries":{
2053          "shape":"SecurityPolicySummaries",
2054          "documentation":"<p>Details about the security policies in your account.</p>"
2055        }
2056      }
2057    },
2058    "ListTagsForResourceRequest":{
2059      "type":"structure",
2060      "required":["resourceArn"],
2061      "members":{
2062        "resourceArn":{
2063          "shape":"Arn",
2064          "documentation":"<p>The Amazon Resource Name (ARN) of the resource. The resource must be active (not in the <code>DELETING</code> state), and must be owned by the account ID included in the request.</p>"
2065        }
2066      }
2067    },
2068    "ListTagsForResourceResponse":{
2069      "type":"structure",
2070      "members":{
2071        "tags":{
2072          "shape":"Tags",
2073          "documentation":"<p>The tags associated with the resource.</p>"
2074        }
2075      }
2076    },
2077    "ListVpcEndpointsRequest":{
2078      "type":"structure",
2079      "members":{
2080        "maxResults":{
2081          "shape":"ListVpcEndpointsRequestMaxResultsInteger",
2082          "documentation":"<p>An optional parameter that specifies the maximum number of results to return. You can use <code>nextToken</code> to get the next page of results. The default is 20.</p>"
2083        },
2084        "nextToken":{
2085          "shape":"String",
2086          "documentation":"<p>If your initial <code>ListVpcEndpoints</code> operation returns a <code>nextToken</code>, you can include the returned <code>nextToken</code> in subsequent <code>ListVpcEndpoints</code> operations, which returns results in the next page. </p>"
2087        },
2088        "vpcEndpointFilters":{
2089          "shape":"VpcEndpointFilters",
2090          "documentation":"<p>Filter the results according to the current status of the VPC endpoint. Possible statuses are <code>CREATING</code>, <code>DELETING</code>, <code>UPDATING</code>, <code>ACTIVE</code>, and <code>FAILED</code>.</p>"
2091        }
2092      }
2093    },
2094    "ListVpcEndpointsRequestMaxResultsInteger":{
2095      "type":"integer",
2096      "box":true,
2097      "max":100,
2098      "min":1
2099    },
2100    "ListVpcEndpointsResponse":{
2101      "type":"structure",
2102      "members":{
2103        "nextToken":{
2104          "shape":"String",
2105          "documentation":"<p>When <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.</p>"
2106        },
2107        "vpcEndpointSummaries":{
2108          "shape":"VpcEndpointSummaries",
2109          "documentation":"<p>Details about each VPC endpoint, including the name and current status.</p>"
2110        }
2111      }
2112    },
2113    "Long":{
2114      "type":"long",
2115      "box":true
2116    },
2117    "OcuLimitExceededException":{
2118      "type":"structure",
2119      "required":["message"],
2120      "members":{
2121        "message":{
2122          "shape":"String",
2123          "documentation":"<p>Description of the error.</p>"
2124        }
2125      },
2126      "documentation":"<p>Thrown when the collection you're attempting to create results in a number of search or indexing OCUs that exceeds the account limit. </p>",
2127      "exception":true
2128    },
2129    "PolicyDescription":{
2130      "type":"string",
2131      "max":1000,
2132      "min":0
2133    },
2134    "PolicyDocument":{
2135      "type":"string",
2136      "max":20480,
2137      "min":1,
2138      "pattern":"[\\u0009\\u000A\\u000D\\u0020-\\u007E\\u00A1-\\u00FF]+"
2139    },
2140    "PolicyName":{
2141      "type":"string",
2142      "max":32,
2143      "min":3,
2144      "pattern":"^[a-z][a-z0-9-]+$"
2145    },
2146    "PolicyVersion":{
2147      "type":"string",
2148      "max":36,
2149      "min":20,
2150      "pattern":"^([0-9a-zA-Z+/]{4})*(([0-9a-zA-Z+/]{2}==)|([0-9a-zA-Z+/]{3}=))?$"
2151    },
2152    "Resource":{"type":"string"},
2153    "ResourceName":{
2154      "type":"string",
2155      "pattern":"^index/[a-z][a-z0-9-]{3,32}/([a-z;0-9&$%][+.~=\\-_a-z;0-9&$%]*|\\*)$"
2156    },
2157    "ResourceNotFoundException":{
2158      "type":"structure",
2159      "members":{
2160        "message":{"shape":"String"}
2161      },
2162      "documentation":"<p>Thrown when accessing or deleting a resource that does not exist.</p>",
2163      "exception":true
2164    },
2165    "ResourceType":{
2166      "type":"string",
2167      "enum":["index"]
2168    },
2169    "SamlConfigOptions":{
2170      "type":"structure",
2171      "required":["metadata"],
2172      "members":{
2173        "groupAttribute":{
2174          "shape":"samlGroupAttribute",
2175          "documentation":"<p>The group attribute for this SAML integration.</p>"
2176        },
2177        "metadata":{
2178          "shape":"samlMetadata",
2179          "documentation":"<p>The XML IdP metadata file generated from your identity provider.</p>"
2180        },
2181        "sessionTimeout":{
2182          "shape":"SamlConfigOptionsSessionTimeoutInteger",
2183          "documentation":"<p>The session timeout, in minutes. Default is 60 minutes (12 hours).</p>"
2184        },
2185        "userAttribute":{
2186          "shape":"samlUserAttribute",
2187          "documentation":"<p>A user attribute for this SAML integration.</p>"
2188        }
2189      },
2190      "documentation":"<p>Describes SAML options for an OpenSearch Serverless security configuration in the form of a key-value map.</p>"
2191    },
2192    "SamlConfigOptionsSessionTimeoutInteger":{
2193      "type":"integer",
2194      "box":true,
2195      "max":720,
2196      "min":5
2197    },
2198    "SearchCapacityValue":{
2199      "type":"integer",
2200      "box":true,
2201      "min":2
2202    },
2203    "SecurityConfigDetail":{
2204      "type":"structure",
2205      "members":{
2206        "configVersion":{
2207          "shape":"PolicyVersion",
2208          "documentation":"<p>The version of the security configuration.</p>"
2209        },
2210        "createdDate":{
2211          "shape":"Long",
2212          "documentation":"<p>The date the configuration was created.</p>"
2213        },
2214        "description":{
2215          "shape":"ConfigDescription",
2216          "documentation":"<p>The description of the security configuration.</p>"
2217        },
2218        "id":{
2219          "shape":"SecurityConfigId",
2220          "documentation":"<p>The unique identifier of the security configuration.</p>"
2221        },
2222        "lastModifiedDate":{
2223          "shape":"Long",
2224          "documentation":"<p>The timestamp of when the configuration was last modified.</p>"
2225        },
2226        "samlOptions":{
2227          "shape":"SamlConfigOptions",
2228          "documentation":"<p>SAML options for the security configuration in the form of a key-value map.</p>"
2229        },
2230        "type":{
2231          "shape":"SecurityConfigType",
2232          "documentation":"<p>The type of security configuration.</p>"
2233        }
2234      },
2235      "documentation":"<p>Details about a security configuration for OpenSearch Serverless. </p>"
2236    },
2237    "SecurityConfigId":{
2238      "type":"string",
2239      "max":100,
2240      "min":1
2241    },
2242    "SecurityConfigStats":{
2243      "type":"structure",
2244      "members":{
2245        "SamlConfigCount":{
2246          "shape":"Long",
2247          "documentation":"<p>The number of security configurations in the current account.</p>"
2248        }
2249      },
2250      "documentation":"<p>Statistics for an OpenSearch Serverless security configuration.</p>"
2251    },
2252    "SecurityConfigSummaries":{
2253      "type":"list",
2254      "member":{"shape":"SecurityConfigSummary"}
2255    },
2256    "SecurityConfigSummary":{
2257      "type":"structure",
2258      "members":{
2259        "configVersion":{
2260          "shape":"PolicyVersion",
2261          "documentation":"<p>The version of the security configuration.</p>"
2262        },
2263        "createdDate":{
2264          "shape":"Long",
2265          "documentation":"<p>The Epoch time when the security configuration was created.</p>"
2266        },
2267        "description":{
2268          "shape":"ConfigDescription",
2269          "documentation":"<p>The description of the security configuration.</p>"
2270        },
2271        "id":{
2272          "shape":"SecurityConfigId",
2273          "documentation":"<p>The unique identifier of the security configuration.</p>"
2274        },
2275        "lastModifiedDate":{
2276          "shape":"Long",
2277          "documentation":"<p>The timestamp of when the configuration was last modified.</p>"
2278        },
2279        "type":{
2280          "shape":"SecurityConfigType",
2281          "documentation":"<p>The type of security configuration.</p>"
2282        }
2283      },
2284      "documentation":"<p>A summary of a security configuration for OpenSearch Serverless.</p>"
2285    },
2286    "SecurityConfigType":{
2287      "type":"string",
2288      "enum":["saml"]
2289    },
2290    "SecurityGroupId":{
2291      "type":"string",
2292      "max":128,
2293      "min":1,
2294      "pattern":"^[\\w+\\-]+$"
2295    },
2296    "SecurityGroupIds":{
2297      "type":"list",
2298      "member":{"shape":"SecurityGroupId"},
2299      "max":5,
2300      "min":1
2301    },
2302    "SecurityPolicyDetail":{
2303      "type":"structure",
2304      "members":{
2305        "createdDate":{
2306          "shape":"Long",
2307          "documentation":"<p>The date the policy was created.</p>"
2308        },
2309        "description":{
2310          "shape":"PolicyDescription",
2311          "documentation":"<p>The description of the security policy.</p>"
2312        },
2313        "lastModifiedDate":{
2314          "shape":"Long",
2315          "documentation":"<p>The timestamp of when the policy was last modified.</p>"
2316        },
2317        "name":{
2318          "shape":"PolicyName",
2319          "documentation":"<p>The name of the policy.</p>"
2320        },
2321        "policy":{
2322          "shape":"Document",
2323          "documentation":"<p>The JSON policy document without any whitespaces.</p>"
2324        },
2325        "policyVersion":{
2326          "shape":"PolicyVersion",
2327          "documentation":"<p>The version of the policy.</p>"
2328        },
2329        "type":{
2330          "shape":"SecurityPolicyType",
2331          "documentation":"<p>The type of security policy.</p>"
2332        }
2333      },
2334      "documentation":"<p>Details about an OpenSearch Serverless security policy.</p>"
2335    },
2336    "SecurityPolicyStats":{
2337      "type":"structure",
2338      "members":{
2339        "EncryptionPolicyCount":{
2340          "shape":"Long",
2341          "documentation":"<p>The number of encryption policies in the current account.</p>"
2342        },
2343        "NetworkPolicyCount":{
2344          "shape":"Long",
2345          "documentation":"<p>The number of network policies in the current account.</p>"
2346        }
2347      },
2348      "documentation":"<p>Statistics for an OpenSearch Serverless security policy.</p>"
2349    },
2350    "SecurityPolicySummaries":{
2351      "type":"list",
2352      "member":{"shape":"SecurityPolicySummary"}
2353    },
2354    "SecurityPolicySummary":{
2355      "type":"structure",
2356      "members":{
2357        "createdDate":{
2358          "shape":"Long",
2359          "documentation":"<p>The date the policy was created.</p>"
2360        },
2361        "description":{
2362          "shape":"PolicyDescription",
2363          "documentation":"<p>The description of the security policy.</p>"
2364        },
2365        "lastModifiedDate":{
2366          "shape":"Long",
2367          "documentation":"<p>The timestamp of when the policy was last modified.</p>"
2368        },
2369        "name":{
2370          "shape":"PolicyName",
2371          "documentation":"<p>The name of the policy.</p>"
2372        },
2373        "policyVersion":{
2374          "shape":"PolicyVersion",
2375          "documentation":"<p>The version of the policy.</p>"
2376        },
2377        "type":{
2378          "shape":"SecurityPolicyType",
2379          "documentation":"<p>The type of security policy.</p>"
2380        }
2381      },
2382      "documentation":"<p>A summary of a security policy for OpenSearch Serverless.</p>"
2383    },
2384    "SecurityPolicyType":{
2385      "type":"string",
2386      "enum":[
2387        "encryption",
2388        "network"
2389      ]
2390    },
2391    "ServiceQuotaExceededException":{
2392      "type":"structure",
2393      "required":[
2394        "message",
2395        "serviceCode"
2396      ],
2397      "members":{
2398        "message":{
2399          "shape":"String",
2400          "documentation":"<p>Description of the error.</p>"
2401        },
2402        "quotaCode":{
2403          "shape":"String",
2404          "documentation":"<p>Service Quotas requirement to identify originating quota.</p>"
2405        },
2406        "resourceId":{
2407          "shape":"String",
2408          "documentation":"<p>Identifier of the resource affected.</p>"
2409        },
2410        "resourceType":{
2411          "shape":"String",
2412          "documentation":"<p>Type of the resource affected.</p>"
2413        },
2414        "serviceCode":{
2415          "shape":"String",
2416          "documentation":"<p>Service Quotas requirement to identify originating service.</p>"
2417        }
2418      },
2419      "documentation":"<p>Thrown when you attempt to create more resources than the service allows based on service quotas.</p>",
2420      "exception":true
2421    },
2422    "StandbyReplicas":{
2423      "type":"string",
2424      "enum":[
2425        "ENABLED",
2426        "DISABLED"
2427      ]
2428    },
2429    "String":{"type":"string"},
2430    "SubnetId":{
2431      "type":"string",
2432      "max":32,
2433      "min":1,
2434      "pattern":"^subnet-([0-9a-f]{8}|[0-9a-f]{17})$"
2435    },
2436    "SubnetIds":{
2437      "type":"list",
2438      "member":{"shape":"SubnetId"},
2439      "max":6,
2440      "min":1
2441    },
2442    "Tag":{
2443      "type":"structure",
2444      "required":[
2445        "key",
2446        "value"
2447      ],
2448      "members":{
2449        "key":{
2450          "shape":"TagKey",
2451          "documentation":"<p>The key to use in the tag.</p>"
2452        },
2453        "value":{
2454          "shape":"TagValue",
2455          "documentation":"<p>The value of the tag.</p>"
2456        }
2457      },
2458      "documentation":"<p>A map of key-value pairs associated to an OpenSearch Serverless resource.</p>"
2459    },
2460    "TagKey":{
2461      "type":"string",
2462      "max":128,
2463      "min":1
2464    },
2465    "TagKeys":{
2466      "type":"list",
2467      "member":{"shape":"TagKey"},
2468      "max":50,
2469      "min":0
2470    },
2471    "TagResourceRequest":{
2472      "type":"structure",
2473      "required":[
2474        "resourceArn",
2475        "tags"
2476      ],
2477      "members":{
2478        "resourceArn":{
2479          "shape":"Arn",
2480          "documentation":"<p>The Amazon Resource Name (ARN) of the resource. The resource must be active (not in the <code>DELETING</code> state), and must be owned by the account ID included in the request.</p>"
2481        },
2482        "tags":{
2483          "shape":"Tags",
2484          "documentation":"<p>A list of tags (key-value pairs) to add to the resource. All tag keys in the request must be unique.</p>"
2485        }
2486      }
2487    },
2488    "TagResourceResponse":{
2489      "type":"structure",
2490      "members":{
2491      }
2492    },
2493    "TagValue":{
2494      "type":"string",
2495      "max":256,
2496      "min":0
2497    },
2498    "Tags":{
2499      "type":"list",
2500      "member":{"shape":"Tag"},
2501      "max":50,
2502      "min":0
2503    },
2504    "UntagResourceRequest":{
2505      "type":"structure",
2506      "required":[
2507        "resourceArn",
2508        "tagKeys"
2509      ],
2510      "members":{
2511        "resourceArn":{
2512          "shape":"Arn",
2513          "documentation":"<p>The Amazon Resource Name (ARN) of the resource to remove tags from. The resource must be active (not in the <code>DELETING</code> state), and must be owned by the account ID included in the request.</p>"
2514        },
2515        "tagKeys":{
2516          "shape":"TagKeys",
2517          "documentation":"<p>The tag or set of tags to remove from the resource. All tag keys in the request must be unique.</p>"
2518        }
2519      }
2520    },
2521    "UntagResourceResponse":{
2522      "type":"structure",
2523      "members":{
2524      }
2525    },
2526    "UpdateAccessPolicyRequest":{
2527      "type":"structure",
2528      "required":[
2529        "name",
2530        "policyVersion",
2531        "type"
2532      ],
2533      "members":{
2534        "clientToken":{
2535          "shape":"ClientToken",
2536          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
2537          "idempotencyToken":true
2538        },
2539        "description":{
2540          "shape":"PolicyDescription",
2541          "documentation":"<p>A description of the policy. Typically used to store information about the permissions defined in the policy.</p>"
2542        },
2543        "name":{
2544          "shape":"PolicyName",
2545          "documentation":"<p>The name of the policy.</p>"
2546        },
2547        "policy":{
2548          "shape":"PolicyDocument",
2549          "documentation":"<p>The JSON policy document to use as the content for the policy.</p>"
2550        },
2551        "policyVersion":{
2552          "shape":"PolicyVersion",
2553          "documentation":"<p>The version of the policy being updated.</p>"
2554        },
2555        "type":{
2556          "shape":"AccessPolicyType",
2557          "documentation":"<p>The type of policy.</p>"
2558        }
2559      }
2560    },
2561    "UpdateAccessPolicyResponse":{
2562      "type":"structure",
2563      "members":{
2564        "accessPolicyDetail":{
2565          "shape":"AccessPolicyDetail",
2566          "documentation":"<p>Details about the updated access policy.</p>"
2567        }
2568      }
2569    },
2570    "UpdateAccountSettingsRequest":{
2571      "type":"structure",
2572      "members":{
2573        "capacityLimits":{"shape":"CapacityLimits"}
2574      }
2575    },
2576    "UpdateAccountSettingsResponse":{
2577      "type":"structure",
2578      "members":{
2579        "accountSettingsDetail":{
2580          "shape":"AccountSettingsDetail",
2581          "documentation":"<p>OpenSearch Serverless-related settings for the current Amazon Web Services account. </p>"
2582        }
2583      }
2584    },
2585    "UpdateCollectionDetail":{
2586      "type":"structure",
2587      "members":{
2588        "arn":{
2589          "shape":"String",
2590          "documentation":"<p>The Amazon Resource Name (ARN) of the collection.</p>"
2591        },
2592        "createdDate":{
2593          "shape":"Long",
2594          "documentation":"<p>The date and time when the collection was created.</p>"
2595        },
2596        "description":{
2597          "shape":"String",
2598          "documentation":"<p>The description of the collection.</p>"
2599        },
2600        "id":{
2601          "shape":"CollectionId",
2602          "documentation":"<p>The unique identifier of the collection.</p>"
2603        },
2604        "lastModifiedDate":{
2605          "shape":"Long",
2606          "documentation":"<p>The date and time when the collection was last modified.</p>"
2607        },
2608        "name":{
2609          "shape":"CollectionName",
2610          "documentation":"<p>The name of the collection.</p>"
2611        },
2612        "status":{
2613          "shape":"CollectionStatus",
2614          "documentation":"<p>The current status of the collection.</p>"
2615        },
2616        "type":{
2617          "shape":"CollectionType",
2618          "documentation":"<p>The collection type.</p>"
2619        }
2620      },
2621      "documentation":"<p>Details about an updated OpenSearch Serverless collection.</p>"
2622    },
2623    "UpdateCollectionRequest":{
2624      "type":"structure",
2625      "required":["id"],
2626      "members":{
2627        "clientToken":{
2628          "shape":"ClientToken",
2629          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
2630          "idempotencyToken":true
2631        },
2632        "description":{
2633          "shape":"UpdateCollectionRequestDescriptionString",
2634          "documentation":"<p>A description of the collection.</p>"
2635        },
2636        "id":{
2637          "shape":"CollectionId",
2638          "documentation":"<p>The unique identifier of the collection.</p>"
2639        }
2640      }
2641    },
2642    "UpdateCollectionRequestDescriptionString":{
2643      "type":"string",
2644      "max":1000,
2645      "min":0
2646    },
2647    "UpdateCollectionResponse":{
2648      "type":"structure",
2649      "members":{
2650        "updateCollectionDetail":{
2651          "shape":"UpdateCollectionDetail",
2652          "documentation":"<p>Details about the updated collection.</p>"
2653        }
2654      }
2655    },
2656    "UpdateLifecyclePolicyRequest":{
2657      "type":"structure",
2658      "required":[
2659        "name",
2660        "policyVersion",
2661        "type"
2662      ],
2663      "members":{
2664        "clientToken":{
2665          "shape":"ClientToken",
2666          "documentation":"<p>A unique, case-sensitive identifier to ensure idempotency of the request.</p>",
2667          "idempotencyToken":true
2668        },
2669        "description":{
2670          "shape":"PolicyDescription",
2671          "documentation":"<p>A description of the lifecycle policy.</p>"
2672        },
2673        "name":{
2674          "shape":"PolicyName",
2675          "documentation":"<p>The name of the policy.</p>"
2676        },
2677        "policy":{
2678          "shape":"PolicyDocument",
2679          "documentation":"<p>The JSON policy document to use as the content for the lifecycle policy.</p>"
2680        },
2681        "policyVersion":{
2682          "shape":"PolicyVersion",
2683          "documentation":"<p>The version of the policy being updated.</p>"
2684        },
2685        "type":{
2686          "shape":"LifecyclePolicyType",
2687          "documentation":"<p> The type of lifecycle policy.</p>"
2688        }
2689      }
2690    },
2691    "UpdateLifecyclePolicyResponse":{
2692      "type":"structure",
2693      "members":{
2694        "lifecyclePolicyDetail":{
2695          "shape":"LifecyclePolicyDetail",
2696          "documentation":"<p>Details about the updated lifecycle policy.</p>"
2697        }
2698      }
2699    },
2700    "UpdateSecurityConfigRequest":{
2701      "type":"structure",
2702      "required":[
2703        "configVersion",
2704        "id"
2705      ],
2706      "members":{
2707        "clientToken":{
2708          "shape":"ClientToken",
2709          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
2710          "idempotencyToken":true
2711        },
2712        "configVersion":{
2713          "shape":"PolicyVersion",
2714          "documentation":"<p>The version of the security configuration to be updated. You can find the most recent version of a security configuration using the <code>GetSecurityPolicy</code> command.</p>"
2715        },
2716        "description":{
2717          "shape":"ConfigDescription",
2718          "documentation":"<p>A description of the security configuration.</p>"
2719        },
2720        "id":{
2721          "shape":"SecurityConfigId",
2722          "documentation":"<p>The security configuration identifier. For SAML the ID will be <code>saml/&lt;accountId&gt;/&lt;idpProviderName&gt;</code>. For example, <code>saml/123456789123/OKTADev</code>.</p>"
2723        },
2724        "samlOptions":{
2725          "shape":"SamlConfigOptions",
2726          "documentation":"<p>SAML options in in the form of a key-value map.</p>"
2727        }
2728      }
2729    },
2730    "UpdateSecurityConfigResponse":{
2731      "type":"structure",
2732      "members":{
2733        "securityConfigDetail":{
2734          "shape":"SecurityConfigDetail",
2735          "documentation":"<p>Details about the updated security configuration. </p>"
2736        }
2737      }
2738    },
2739    "UpdateSecurityPolicyRequest":{
2740      "type":"structure",
2741      "required":[
2742        "name",
2743        "policyVersion",
2744        "type"
2745      ],
2746      "members":{
2747        "clientToken":{
2748          "shape":"ClientToken",
2749          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
2750          "idempotencyToken":true
2751        },
2752        "description":{
2753          "shape":"PolicyDescription",
2754          "documentation":"<p>A description of the policy. Typically used to store information about the permissions defined in the policy.</p>"
2755        },
2756        "name":{
2757          "shape":"PolicyName",
2758          "documentation":"<p>The name of the policy.</p>"
2759        },
2760        "policy":{
2761          "shape":"PolicyDocument",
2762          "documentation":"<p>The JSON policy document to use as the content for the new policy.</p>"
2763        },
2764        "policyVersion":{
2765          "shape":"PolicyVersion",
2766          "documentation":"<p>The version of the policy being updated.</p>"
2767        },
2768        "type":{
2769          "shape":"SecurityPolicyType",
2770          "documentation":"<p>The type of access policy.</p>"
2771        }
2772      }
2773    },
2774    "UpdateSecurityPolicyResponse":{
2775      "type":"structure",
2776      "members":{
2777        "securityPolicyDetail":{
2778          "shape":"SecurityPolicyDetail",
2779          "documentation":"<p>Details about the updated security policy.</p>"
2780        }
2781      }
2782    },
2783    "UpdateVpcEndpointDetail":{
2784      "type":"structure",
2785      "members":{
2786        "id":{
2787          "shape":"VpcEndpointId",
2788          "documentation":"<p>The unique identifier of the endpoint.</p>"
2789        },
2790        "lastModifiedDate":{
2791          "shape":"Long",
2792          "documentation":"<p>The timestamp of when the endpoint was last modified.</p>"
2793        },
2794        "name":{
2795          "shape":"VpcEndpointName",
2796          "documentation":"<p>The name of the endpoint.</p>"
2797        },
2798        "securityGroupIds":{
2799          "shape":"SecurityGroupIds",
2800          "documentation":"<p>The unique identifiers of the security groups that define the ports, protocols, and sources for inbound traffic that you are authorizing into your endpoint.</p>"
2801        },
2802        "status":{
2803          "shape":"VpcEndpointStatus",
2804          "documentation":"<p>The current status of the endpoint update process.</p>"
2805        },
2806        "subnetIds":{
2807          "shape":"SubnetIds",
2808          "documentation":"<p>The ID of the subnets from which you access OpenSearch Serverless.</p>"
2809        }
2810      },
2811      "documentation":"<p>Update details for an OpenSearch Serverless-managed interface endpoint.</p>"
2812    },
2813    "UpdateVpcEndpointRequest":{
2814      "type":"structure",
2815      "required":["id"],
2816      "members":{
2817        "addSecurityGroupIds":{
2818          "shape":"SecurityGroupIds",
2819          "documentation":"<p>The unique identifiers of the security groups to add to the endpoint. Security groups define the ports, protocols, and sources for inbound traffic that you are authorizing into your endpoint.</p>"
2820        },
2821        "addSubnetIds":{
2822          "shape":"SubnetIds",
2823          "documentation":"<p>The ID of one or more subnets to add to the endpoint.</p>"
2824        },
2825        "clientToken":{
2826          "shape":"ClientToken",
2827          "documentation":"<p>Unique, case-sensitive identifier to ensure idempotency of the request.</p>",
2828          "idempotencyToken":true
2829        },
2830        "id":{
2831          "shape":"VpcEndpointId",
2832          "documentation":"<p>The unique identifier of the interface endpoint to update.</p>"
2833        },
2834        "removeSecurityGroupIds":{
2835          "shape":"SecurityGroupIds",
2836          "documentation":"<p>The unique identifiers of the security groups to remove from the endpoint.</p>"
2837        },
2838        "removeSubnetIds":{
2839          "shape":"SubnetIds",
2840          "documentation":"<p>The unique identifiers of the subnets to remove from the endpoint.</p>"
2841        }
2842      }
2843    },
2844    "UpdateVpcEndpointResponse":{
2845      "type":"structure",
2846      "members":{
2847        "UpdateVpcEndpointDetail":{
2848          "shape":"UpdateVpcEndpointDetail",
2849          "documentation":"<p>Details about the updated VPC endpoint.</p>"
2850        }
2851      }
2852    },
2853    "ValidationException":{
2854      "type":"structure",
2855      "members":{
2856        "message":{"shape":"String"}
2857      },
2858      "documentation":"<p>Thrown when the HTTP request contains invalid input or is missing required input.</p>",
2859      "exception":true
2860    },
2861    "VpcEndpointDetail":{
2862      "type":"structure",
2863      "members":{
2864        "createdDate":{
2865          "shape":"Long",
2866          "documentation":"<p>The date the endpoint was created.</p>"
2867        },
2868        "id":{
2869          "shape":"VpcEndpointId",
2870          "documentation":"<p>The unique identifier of the endpoint.</p>"
2871        },
2872        "name":{
2873          "shape":"VpcEndpointName",
2874          "documentation":"<p>The name of the endpoint.</p>"
2875        },
2876        "securityGroupIds":{
2877          "shape":"SecurityGroupIds",
2878          "documentation":"<p>The unique identifiers of the security groups that define the ports, protocols, and sources for inbound traffic that you are authorizing into your endpoint.</p>"
2879        },
2880        "status":{
2881          "shape":"VpcEndpointStatus",
2882          "documentation":"<p>The current status of the endpoint.</p>"
2883        },
2884        "subnetIds":{
2885          "shape":"SubnetIds",
2886          "documentation":"<p>The ID of the subnets from which you access OpenSearch Serverless.</p>"
2887        },
2888        "vpcId":{
2889          "shape":"VpcId",
2890          "documentation":"<p>The ID of the VPC from which you access OpenSearch Serverless.</p>"
2891        }
2892      },
2893      "documentation":"<p>Details about an OpenSearch Serverless-managed interface endpoint.</p>"
2894    },
2895    "VpcEndpointDetails":{
2896      "type":"list",
2897      "member":{"shape":"VpcEndpointDetail"}
2898    },
2899    "VpcEndpointErrorDetail":{
2900      "type":"structure",
2901      "members":{
2902        "errorCode":{
2903          "shape":"String",
2904          "documentation":"<p>The error code for the failed request.</p>"
2905        },
2906        "errorMessage":{
2907          "shape":"String",
2908          "documentation":"<p>An error message describing the reason for the failure.</p>"
2909        },
2910        "id":{
2911          "shape":"VpcEndpointId",
2912          "documentation":"<p>The unique identifier of the VPC endpoint.</p>"
2913        }
2914      },
2915      "documentation":"<p>Error information for a failed <code>BatchGetVpcEndpoint</code> request.</p>"
2916    },
2917    "VpcEndpointErrorDetails":{
2918      "type":"list",
2919      "member":{"shape":"VpcEndpointErrorDetail"}
2920    },
2921    "VpcEndpointFilters":{
2922      "type":"structure",
2923      "members":{
2924        "status":{
2925          "shape":"VpcEndpointStatus",
2926          "documentation":"<p>The current status of the endpoint.</p>"
2927        }
2928      },
2929      "documentation":"<p>Filter the results of a <code>ListVpcEndpoints</code> request.</p>"
2930    },
2931    "VpcEndpointId":{
2932      "type":"string",
2933      "max":255,
2934      "min":1,
2935      "pattern":"^vpce-[0-9a-z]*$"
2936    },
2937    "VpcEndpointIds":{
2938      "type":"list",
2939      "member":{"shape":"VpcEndpointId"},
2940      "min":1
2941    },
2942    "VpcEndpointName":{
2943      "type":"string",
2944      "max":32,
2945      "min":3,
2946      "pattern":"^[a-z][a-z0-9-]+$"
2947    },
2948    "VpcEndpointStatus":{
2949      "type":"string",
2950      "enum":[
2951        "PENDING",
2952        "DELETING",
2953        "ACTIVE",
2954        "FAILED"
2955      ]
2956    },
2957    "VpcEndpointSummaries":{
2958      "type":"list",
2959      "member":{"shape":"VpcEndpointSummary"}
2960    },
2961    "VpcEndpointSummary":{
2962      "type":"structure",
2963      "members":{
2964        "id":{
2965          "shape":"VpcEndpointId",
2966          "documentation":"<p>The unique identifier of the endpoint.</p>"
2967        },
2968        "name":{
2969          "shape":"VpcEndpointName",
2970          "documentation":"<p>The name of the endpoint.</p>"
2971        },
2972        "status":{
2973          "shape":"VpcEndpointStatus",
2974          "documentation":"<p>The current status of the endpoint.</p>"
2975        }
2976      },
2977      "documentation":"<p>The VPC endpoint object.</p>"
2978    },
2979    "VpcId":{
2980      "type":"string",
2981      "max":255,
2982      "min":1,
2983      "pattern":"^vpc-[0-9a-z]*$"
2984    },
2985    "samlGroupAttribute":{
2986      "type":"string",
2987      "max":2048,
2988      "min":1,
2989      "pattern":"[\\w+=,.@-]+"
2990    },
2991    "samlMetadata":{
2992      "type":"string",
2993      "max":51200,
2994      "min":1,
2995      "pattern":"[\\u0009\\u000A\\u000D\\u0020-\\u007E\\u00A1-\\u00FF]+"
2996    },
2997    "samlUserAttribute":{
2998      "type":"string",
2999      "max":2048,
3000      "min":1,
3001      "pattern":"[\\w+=,.@-]+"
3002    }
3003  },
3004  "documentation":"<p>Use the Amazon OpenSearch Serverless API to create, configure, and manage OpenSearch Serverless collections and security policies.</p> <p>OpenSearch Serverless is an on-demand, pre-provisioned serverless configuration for Amazon OpenSearch Service. OpenSearch Serverless removes the operational complexities of provisioning, configuring, and tuning your OpenSearch clusters. It enables you to easily search and analyze petabytes of data without having to worry about the underlying infrastructure and data management.</p> <p> To learn more about OpenSearch Serverless, see <a href=\"https://docs.aws.amazon.com/opensearch-service/latest/developerguide/serverless-overview.html\">What is Amazon OpenSearch Serverless?</a> </p>"
3005}
3006